FUNCTION_AFG31000
Set the parameters for the built-in function generator. This block should also work with compatible Tektronix AFG31XXX instruments. Params: connection : VisaConnection The VISA address (requires the CONNECTION_AFG31000 block). channel : select, default=1 Choose the channel to alter. functions : select, default=sinusoid Choose the function to output frequency : float, default=1e6 The voltage of the waveform to set, in Hz. amplitude : float, default=1 The voltage of the waveform to set. offset : float, default=0 The voltage offset to set the waveform to, in volts. phase : float, default=0 The phase to set the waveform to, in degrees. pulse_width : float, default=1e-6 The pulse width in nanoseconds if the PULS waveform is used. ramp_symmetry : float, default=50 The ramp symmetry if the RAMP waveform is used, in percent. Returns: out : String Placeholder
Python Code
from flojoy import flojoy, DataContainer, String, VisaConnection
from typing import Optional, Literal
@flojoy(inject_connection=True)
def FUNCTION_AFG31000(
connection: VisaConnection,
source: Literal["1", "2"] = "1",
functions: Literal[
"sinusoid",
"square",
"pulse",
"ramp",
"prnoise",
"DC",
"sinc",
"gaussian",
"lorentz",
"erise",
"edecay",
"haversine",
] = "sinusoid",
frequency: float = 1e6,
amplitude: float = 1,
offset: float = 0,
phase: float = 0,
pulse_width: float = 1e-6,
ramp_symmetry: float = 50,
input: Optional[DataContainer] = None,
) -> String:
"""Set the parameters for the built-in function generator.
This block should also work with compatible Tektronix AFG31XXX instruments.
Parameters
----------
connection: VisaConnection
The VISA address (requires the CONNECTION_AFG31000 block).
channel: select, default=1
Choose the channel to alter.
functions: select, default=sinusoid
Choose the function to output
frequency: float, default=1e6
The voltage of the waveform to set, in Hz.
amplitude: float, default=1
The voltage of the waveform to set.
offset: float, default=0
The voltage offset to set the waveform to, in volts.
phase: float, default=0
The phase to set the waveform to, in degrees.
pulse_width: float, default=1e-6
The pulse width in nanoseconds if the PULS waveform is used.
ramp_symmetry: float, default=50
The ramp symmetry if the RAMP waveform is used, in percent.
Returns
-------
String
Placeholder
"""
assert -180.0 <= phase <= 180.0, "The phase must be between -180 and 180 degrees."
afg = connection.get_handle()
afg.write(f"SOURCE{source}:FUNCtion:SHAPe {functions}")
afg.write(f"SOURCE{source}:FREQUENCY {frequency}")
afg.write(f"SOURCE{source}:VOLTAGE:AMPLITUDE {amplitude}")
afg.write(f"SOURCE{source}:VOLTAGE:OFFSET {offset}")
afg.write(f"SOURCE{source}:PHASE:ADJUST {phase}DEG")
if functions == "pulse":
afg.write(f"SOURCE{source}:PULSE:WIDTH {pulse_width}")
if functions == "ramp":
assert 0 <= ramp_symmetry <= 100.0, "The phase must be between 0 and 100%."
afg.write(f"SOURCE{source}:FUNCtion:RAMP:SYMMETRY {ramp_symmetry}")
return String(s="Set FG parameters")
Videos
Control the AFG31000 Function Generator with Flojoy
Example
Having problems with this example app? Join our Discord community and we will help you out!
In this example, an Tektronix AFG31000 is used to generate two waveforms.
First the necessary blocks were added:
CONNECT_AFG31000
RESET_AFG31000
- 2x
FUNCTION_AFG31000
ALIGN_PHASES_AFG31000
OUTPUT_AFG31000
SAVE_STATE_AFG31000
The instrument address was set for each AFG31000
block. Ensure the OUTPUT_AFG31000
block has both channels turn on.
The blocks were connected as shown and the app was run. The SAVE_STATE_AFG31000
block can be used to save and recall the current state of the AFG. However, you must use a OUTPUT_AFG31000
block to turn the outputs back on.
An oscilloscope was connected to the AFG31000 resulting in waveform: