Skip to main content

Simple python library to control Arbitrary Waveform Generators from various manufacturers.

Project description

PyAWG

A simple (unofficial) python library to control some functions of Arbitrary Waveform Generators (aka Function / Signal Generators) from various manufacturers.

Currently following function generators are supported. Volunteers are welcome to extend it to support other models keeping the basic functions same.

Siglent

Rigol

System Requirements

  • Python (>=3.8,<4.0)

Installation

Installation of the library is very simple via pip command as shown below.

>>> pip install pyawg

Functions

Following functions are implemented in the library. In case, any other command needs to be sent to the AWG, the write() and query() functions can be used to send any command to the AWG. The library will automatically add the required line terminator to the command. All bugs and new implementations/extensions are welcome via Github issues and/or pull requests.

Functionality Function Implemented Tested Description
Identify get_id() Yes Yes Get the ID of the connected AWG.
Reset reset() Yes Yes Reset the AWG to system defaults.
Close close() Yes Yes Close the connection to the AWG.
Set Output set_output() Yes Yes Enables or disables the output.
Set Output Load set_output_load() Yes Set the output load impedance.
Set Waveform set_waveform() Yes Yes Set the waveform type.
Set Frequency set_frequency() Yes Yes Set the frequency of the waveform in Hz, KHz, MHz.
Set Amplitude set_amplitude() Yes Yes Set the amplitude of the waveform in Vpp.
Set Offset set_offset() Yes Yes Set the offset voltage in Vdc.
Set Duty Cycle set_duty_cycle() Yes Yes Set the duty cycle of the waveform in percentage.
Set Pulse Width set_pulse_width() Yes Set the pulse width of the waveform in seconds.
Set Phase set_phase() Yes Yes Set the phase shift in degrees.
Synchronize Phase sync_phase() Yes Yes Synchronize the phase of the channels.
Enable Burst Mode enable_burst_mode() Yes Enable or disable burst mode.
Set Burst Delay set_burst_delay() Yes Set the burst delay.
Set Burst Mode set_burst_mode() Yes Set the burst mode.
Set Burst Period set_burst_period() Yes Set the period of the burst.
Set Burst State set_burst_state() Yes Turns the burst mode ON or OFF.
Set Burst Trigger Source set_burst_trigger_source() Yes Set the trigger source for burst mode.
Trigger Burst trigger_burst() Yes Trigger the burst.
Write write() Yes Yes Write any documented command to the AWG. Please refer official programming guide for your instrument.
Query query() Yes Yes Query any documented command and retrieve the information from the AWG. Please refer official programming guide for your instrument.

Usage

Here is an exmaple with Rigol DG1032Z Arbitrary Waveform Generator. For the variants from other manufacturers, the DEBUG logs would be printed slightly different based on their respective syntax.

>>> from pyawg import awg_control, AmplitudeUnit, FrequencyUnit, WaveformType

>>> # Example for Square Wave of 10KHz, 5VPP with offset of 2.5V and phase shift of 90°

>>> awg = awg_control('192.168.1.100')
[2025.03.06 21:12:46][DEBUG] Connected to AWG at 192.168.1.100
[2025.03.06 21:12:46][DEBUG] Sent query: *IDN?, Received: Rigol Technologies,DG1032Z,DG1ZA2012604407,03.01.12  
[2025.03.06 21:12:46][DEBUG] RigolDG1000Z instance created.

>>> awg.set_waveform(1, WaveformType.SQUARE)
[2025.03.06 21:15:51][DEBUG] Sent command: SOUR1:FUNC SQU
[2025.03.06 21:15:51][DEBUG] Channel 1 waveform set to SQU

>>> awg.set_frequency(1, 10, FrequencyUnit.KHZ)
[2025.03.06 21:16:41][DEBUG] Sent command: SOUR1:FREQ 10KHZ
[2025.03.06 21:16:41][DEBUG] Channel 1 frequency set to 10KHZ

>>> awg.set_amplitude(1, 5, AmplitudeUnit.VPP)
[2025.03.06 21:18:19][DEBUG] Sent command: SOUR1:VOLT 5VPP
[2025.03.06 21:18:19][DEBUG] Channel 1 amplitude set to 5VPP

>>> awg.set_offset(1, 2.5)
[2025.03.06 21:20:02][DEBUG] Sent command: SOUR1:VOLT:OFFS 2.5
[2025.03.06 21:20:02][DEBUG] Channel 1 offset voltage set to 2.5 Vdc

>>> awg.set_phase(1, 90)
[2025.03.06 21:25:08][DEBUG] Sent command: SOUR1:PHAS 90
[2025.03.06 21:25:08][DEBUG] Channel 1 phase set to 90°

>>> awg.set_output(1, True)
[2025.03.06 21:25:34][DEBUG] Sent command: OUTP1 ON
[2025.03.06 21:25:34][DEBUG] Channel 1 output has been set to ON

>>> awg.close()
[2025.03.06 21:35:13][DEBUG] Disconnected from AWG

Exceptions

The library raises following exceptions in case of any error.

  • InvalidChannelNumber : This exception is raised when the channel number is invalid. The valid channel numbers are 1 and 2.
  • TypeError : This exception is raised when the datatype of an argument passed while calling a method is not valid. For example, if the frequency is passed as a string instead of a float.
  • ValueError : This exception is raised when the value of an argument passed while calling a method is not valid. For example, if the frequency is passed as a negative number.
  • Exception : This exception is raised when there is an error in the communication with the AWG. For example, if the AWG is not connected or if the command sent to the AWG is not valid.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyawg-0.3.12.0.tar.gz (25.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyawg-0.3.12.0-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

Details for the file pyawg-0.3.12.0.tar.gz.

File metadata

  • Download URL: pyawg-0.3.12.0.tar.gz
  • Upload date:
  • Size: 25.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.12.3 Linux/6.11.0-21-generic

File hashes

Hashes for pyawg-0.3.12.0.tar.gz
Algorithm Hash digest
SHA256 fec384233563baec9f194a558714af63796a1ad84b93c49bf1a8cc6d32528d94
MD5 07eac31a2d7db309a2c2bac43c7f8972
BLAKE2b-256 75b59940f4c79b3740869aaad8b5220de299436d1dab7ae4e0a087fa117ff072

See more details on using hashes here.

File details

Details for the file pyawg-0.3.12.0-py3-none-any.whl.

File metadata

  • Download URL: pyawg-0.3.12.0-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.12.3 Linux/6.11.0-21-generic

File hashes

Hashes for pyawg-0.3.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bc6c4192db9c1a35765aed99e5250e67c0460d8591c984f650afcadfde06da99
MD5 f36e41047cbdcca07777ec421782c964
BLAKE2b-256 314077e71b621b3a9954d81c67aaeb89cdf6ae70864ef52487dd9e6e22f2c329

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page