# Getting Started with Python

If at any point, your output doesn't match what's listed below, please refer to the Troubleshooting section.

# Requirements

  • Python 3.5+
  • Knowledge of your Moku's IP Address (see below)

# Quickstart

Download the mokucli installer from Utilities (opens new window) and follow the installer prompts to install the mokucli commandline tool. Then download the required firmware version as below, you can easily check that the installation succeeded by running the simple Python command listed below.

$ mokucli download 600
$ python
>>> from moku.instruments import Oscilloscope
>>> osc = Oscilloscope('192.168.XXX.XX')
>>> osc.get_data()
1
2
3
4
5

You should see an array of data captured from your newly-deployed Oscilloscope object. If not, please refer to the Troubleshooting section.

# Full Procedure

# 1. Check your Python Installation

At a command prompt (e.g. cmd.exe, Windows Terminal, MacOS Terminal) check your Python version. It should be greater than or equal to 3.5.0. In particular, Python 2 (e.g. 2.7.0) is not supported.

$: python --version
Python 3.9.0
1
2

# 2. Install mokucli Library

At a command prompt, install mokucli by downloading the installer from Utilities (opens new window). You can easily check that the installation succeeded by running the simple Python command listed below. If the output begins the same as the output shown below, then the installation has succeeded. Read more about Moku CLI (mokucli) command line features here.

$ mokucli --help
Usage: mokucli [OPTIONS] COMMAND [ARGS]...

  MOKU command line utlity

  Version: X.X.X
...
1
2
3
4
5
6
7

# 3. Download the data files

The Moku Scripting API for Python requires data files to be downloaded before any program can be run. These data files may be several hundred megabytes. Please ensure you have a suitable internet connection before you proceed, this step is only required to be run whenever you install or upgrade the library.

At a terminal or command prompt, issue the download command. This may take a while to complete, depending on your internet connection.

$: mokucli download 600
Downloading latest instruments for firmware version 591...
[===========================================================================]
1
2
3

# 4. Find Your IP Address

For more detail and other options, see Finding your IP Address

$: mokucli list
Name                 Serial  HW     FW     IP
--------------------------------------------------------
MokuGo-000010        10      Go     600    10.1.XXX.XXX
1
2
3
4

# 5. Run Your First Program

Use your IP address as found above in place of the one below.

$ python
>>> from moku.instruments import Oscilloscope
>>> osc = Oscilloscope('192.168.XXX.XX')
>>> osc.get_data()
1
2
3
4

You should see an array of data captured from your newly-deployed Oscilloscope object. If not, please refer to the Troubleshooting below.

# Next Steps

Check out our Python Examples for more inspiration. Happy Coding!

# Troubleshooting

# 'python' is not recognized as an internal or external command, operable program or batch file

Python is not correctly installed on your Windows machine. Follow the instructions here (opens new window).

# python: command not found

Python is not correctly installed on your Mac, or you're using a UNIX terminal on Windows that also cannot find Python. For Mac, follow the instructions here (opens new window).

# The system cannot find the file C:\Users\user\AppData\Local\Microsoft\WindowsApps\python.exe

Newer versions of Windows ship with Python installed by default. This error message indicates that the default installation has become corrupted somehow. Liquid Instruments recommends installing Python from scratch, according to the instructions here (opens new window).

# ModuleNotFoundError: No module named 'pip'

You have tried to execute the pip command from within Python, rather that from a command prompt. Try using a terminal like Windows Terminal, Mac Terminal or cmd.exe.

# Listed Version is less than 3.5

You must upgrade your Python to 3.5 or newer. See the installation instructions for Windows (opens new window) or Mac (opens new window)

# ModuleNotFoundError: No module named 'moku'

If you are trying to install the moku Library with pip install moku [depricated] you may find that Python cannot find the newly-installed moku library. This commonly occurs for one of two reasons:

  • The pip command didn't complete successfully, OR
  • A problem in your Python installation means that your pip and python executables have got out of sync with each other.

If you are sure that the pip command completed successfully, then you can resolve the problem option by executing pip directly from the Python installation, rather than separately.

$: python -m pip install moku
$: python -c 'import moku'
$:
1
2
3

# Connection to (ip address) timed out, Max retries exceeded

The Moku library was unable to connect to the Moku device. Ensure you have the correct IP address using the steps above.

If the IP address is correct, check that the network is reachable from your computer. The easiest way to achieve this is to simply try and connect using the Moku Desktop Application.

# USB Connection Issues

On Windows (only, not Mac or Linux), the Moku requires a driver to be installed in order to work over USB. This driver is installed automatically when you install the Moku Desktop Application. If you are working in an environment where you are not able to install the full Desktop Application, a standalone driver installer is available by contacting our Support Engineers.

The Moku API uses IPv6 to connect to the Moku over USB. If your computer does not have IPv6 enabled (e.g. disabled by an Administrator) then the USB connection will not be operable. Please reach out to our Support Engineers for guidance and other options.

This extends to environments inside your computer where IPv6 may be limited, such as Microsoft Windows Subsystem for Linux v2 (WSL2). For information on possible workarounds for WSLv2 support, see the original bug report (opens new window) and this resulting discussion (opens new window).

# LocationParseError/InvalidURL: Failed to parse

This is usually seen when using USB and comes from the underlying libraries being unable to decipher the Link Local address used. This can be fixed by updating those libraries as follows.

$: python -m pip install --upgrade urllib3 requests
1

Windows

On Windows, there is a small chance that the specific IPv6 address used by the Moku can trigger a bug in a core Python library (opens new window), leading to an InvalidURL error. If the above steps don't help, the work-around is to replace the % character in the IP address with the sequence %2525 (i.e. a doubly-escaped percent character). For example, if the original IP address ended in 023e%61:

o = Oscilloscope('[fe80:0000:0000:0000:7269:79ff:feb9:023e%252561]')
1

# IPv6 (including USB) Connection Issues

There are some environmental limitations when using IPv6, including using the Moku USB interface. See this section for more information.

# Access Requests.session

The connection to the Moku device uses the Python requests module internally. To configure request session attributes, for example custom proxy or authentication parameters, prepend session_ to the Session attribute and pass it to the instrument constructor. For example, trust_env can be configured as session_trust_env.

o = Oscilloscope("192.168.###.###", session_trust_env=False)
1

# Breaking changes with firmware version 600

# Important Notice: Breaking Changes in Firmware 600

Starting with firmware version 600, there are some breaking changes that require you to update your Python client package to version 3.3.1. If you encounter the following error:

>>> i = Oscilloscope('192.168.###.###', force_connect=True)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  ...
  File "moku/__init__.py", line 45, in __init__
    if int(props['firmware']) < MIN_COMPAT_FW:
       ^^^^^^^^^^^^^^^^^^^^^^
ValueError: invalid literal for int() with base 10: '600.0'
1
2
3
4
5
6
7
8

This indicates that you are using an older version of the client package. To resolve this issue, please ensure you have the latest version installed.

# moku Library [deprecated]

Previously you could download the bitstreams with the moku library with the following instructions. This has been deprecated and you should use the mokucli commands and instructions.

At a command prompt, install the moku library using pip. You can easily check that the installation succeeded by running the simple Python command listed below. If there is no output from the Python command, then the installation has succeeded. If you see an error message, refer to the Troubleshooting section below.

$ pip install moku
$ moku download
$ python
>>> from moku.instruments import Oscilloscope
>>> osc = Oscilloscope('192.168.XXX.XX')
>>> osc.get_data()
1
2
3
4
5
6

You should see an array of data captured from your newly-deployed Oscilloscope object. If not, please refer to the Troubleshooting below.