.. _Command Reference: Command Reference ================= The controller implements the standard commands prefixed with two plus (``++``) character sequence to indicate that the following sequence is an interface command. Commands, with the exception of the ``++savecfg`` command, should be fully compatible with the Prologix GPIB-USB controller. However, the interface also implements a number of additional custom commands. Prologix-compatible commands ---------------------------- ``++addr`` ++++++++++ This is used to set or query the GPIB address. At present, only primary addresses are supported. In controller mode, the address refers to the GPIB address of the instrument that the operator desires to communicate with. The address of the controller is 0. In device mode, the address represents the address of the interface which is now acting as a device. When issued without a parameter, the command will return the current GPIB address. :Modes: controller, device :Syntax: ``++addr [1-29]`` where 1-29 is a decimal number representing the primary GPIB address of the device. ``++auto`` ++++++++++ Configure the instrument to automatically send data back to the controller. When auto is enabled, the user does not have to issue ``++read`` commands repeatedly. This command has additional options when compared with the Prologix version. When set to zero, auto is disabled. When set to 1, auto is designed to emulate the Prologix setting. The controller will automatically attempt to read a response from the instrument after any instrument command or, in fact, any character sequence that is not a controller command beginning with ``++``, has been sent. When set to 2, auto is set to “on-query” mode. The controller will automatically attempt to read the response from the instrument after a character sequence that is not a controller command beginning with ``++`` is sent to the instrument, but only if that sequence ends in a ``?`` character, i.e. it is a query command such as ``*IDN?``. When set to 3, auto is set to “continuous” mode. The controller will execute continuous read operations after the first ``++read`` command is issued, returning a continuous stream of data from the instrument. The command can be terminated by turning off auto with ``++auto 0`` or performing a reset with ``++rst``. :Modes: controller :Syntax: ``++auto [0|1|2|3]`` where 0 disables and 1 enables automatically sending data to the controller Note: Some instruments generate a “Query unterminated or “-420” error if they are addressed after sending an instrument command that does not generate a response. This simply means that the instrument has no information to send and this error may be ignored. Alternatively, auto can be turned off (``++auto 0``) and a ``++read`` command issued following the instrument command to read the instrument response. ``++clr`` +++++++++ This command sends a `Selected Device Clear` (``SDC``) to the currently addressed instrument. Details of how the instrument should respond may be found in the instrument manual. :Modes: controller :Syntax: ``++clr`` ``++eoi`` +++++++++ This command enables or disables the assertion of the ``EOI`` signal. When a data message is sent in binary format, the ``CR/LF`` terminators cannot be differentiated from the binary data bytes. In this circumstance, the ``EOI`` signal can be used as a message terminator. When ``ATN`` is not asserted and ``EOI`` is enabled, the ``EOI`` signal will be briefly asserted to indicate the last character sent in a multi- byte sequence. Some instruments require their command strings to be terminated with an EOI signal in order to properly detect the command. The ``EOI`` line is also used in conjunction with ``ATN`` to initiate a parallel poll, however, this command has no bearing on that activity. When issued without a parameter, the command will return the current configuration. :Modes: controller, device :Syntax: ``++eoi [0|1]`` where 0 disables and 1 enables asserting EOI to signal the last character sent ``++eos`` +++++++++ Specifies the GPIB termination character. When data from the host (e.g. a command sequence) is received over USB, all non-escaped ``LF``, ``CR`` or ``Esc`` characters are removed and replaced by the GPIB termination character, which is appended to the data sent to the instrument. This command does not affect data being received from the instrument. When issued without a parameter, the command will return the current configuration. :Modes: controller, device :Syntax: ``++eos [0|1|2|3]`` where 0=CR+LF, 1=CR, 2=LF, 3=none ``++eot_enable`` ++++++++++++++++ This command enables or disables the appending of a user specified character to the USB output from the interface to the host whenever ``EOI`` is detected while reading data from the GPIB port. The character to send is specified using the ``++eot_char`` command. When issued without a parameter, the command will return the current configuration. :Modes: controller, device :Syntax: ``++eot_enable [0|1]`` where 0 disables and 1 enables sending the ``EOT`` character to the USB output. ``++eot_char`` ++++++++++++++ This command specifies the character to be appended to the USB output from the interface to the host whenever an ``EOI`` signal is detected while reading data from the GPIB bus. The character is a decimal ASCII character value that is less than 256. When issued without a parameter, the command will return a decimal number corresponding to the ASCII character code of the current character. :Modes: controller, device :Syntax: ``++eot_char []`` where is a decimal number that is less than 256. .. _++help: ``++help`` ++++++++++ Display the list of commands with a short description, or the short desription of given command. :Modes: controller, device :Syntax: ``help [command]`` ``++ifc`` +++++++++ Assert the GPIB ``IFC`` signal for 150 microseconds, making the AR488 the Controller-in-Charge on the GPIB bus. :Modes: controller :Syntax: ++ifc ``++llo`` +++++++++ Disable front panel operation on the currently addressed instrument. In the original HPIB specification, sending the ``LLO`` signal to the GPIB bus would lock the ``LOCAL`` control on ALL instruments on the bus. In the Prologix specification, this command disables front panel operation of the addressed instrument only, in effect taking control of that instrument. The AR488 follows the Prologix specification, but adds a parameter to allow the simultaneous assertion of remote control over all instruments on the GPIB bus as per the HPIB specification. This command requires the Remote Enable (``REN``) line to be asserted otherwise it will be ignored. In controller mode, the ``REN`` signal is asserted by default unless its status is changed by the ``++ren`` command. When the ``++llo`` command is issued without a parameter, it behaves the same as it does on the Prologix controller. The ``LLO`` signal is sent to the currently addressed instrument and this locks out the ``LOCAL`` key on the instrument control panel. Because the instrument has been addressed and ``REN`` is already asserted, the command automatically takes remote control of the instrument. Most instruments will display ``REM`` on their display or control panel to indicate that remote control is active and front/rear panel controls will be disabled. If the ``++llo`` command is issued with the ``all`` parameter, this will send the ``LLO`` signal to the bus, putting every instrument into remote control mode simultaneously. At this point, instruments will not yet show the ``REM`` indicator and it may still be possible to operate the front panel controls. On some instruments the ``LOCAL`` key may be locked out. However, as soon as an instrument has been addressed and sent a command (assuming that a ``LOC`` signal has not been sent yet first), the controller will automatically lock in remote control of that instrument , the ``REM`` indicator will be displayed and front/rear panel controls will be disabled. :Modes: controller :Syntax: ``++llo [all]`` ``++loc`` +++++++++ Relinquish remote control and re-enable front panel operation of the currently addressed instrument. This command relinquishes remote control of the instrument by de-asserting ``REN`` and sending the ``GTL`` signal. The Remote Enable (``REN``) line must be asserted and the instrument must already be under remote control otherwise the command has no effect. In the original HPIB specification, this command would place all instuments back into local mode, re-enabling the ``LOCAL`` key and panel controls on ALL instruments currently connected to the GPIB bus. In the Prologix specification, this command relinquishes remote control of the currently addressed instrument only. The AR488 follows the Prologix specification, but adds a parameter to allow the simultaneous release of remote control over all instruments currently addressed as listeners on the GPIB bus as per the HPIB specification. If the command is issued without a parameter, it will re-enable the ``LOCAL`` key on the control panel on the currently addressed instrument and relinquish remote control of the instrument. If issued with the ``all`` parameter, it puts all devices on the GPIB bus in local control state. The ``REM`` indicator should no longer be visible when the instrument has returned to local control state. :Modes: controller :Syntax: ``++loc [all]`` ``++lon`` +++++++++ The ``++lon`` command configures the controller to listen only to traffic on the GPIB bus. In this mode the interface does require to have a GPIB address assigned so the assigned GPIB address is ignored. Traffic is received irrespective of the currently set GPIB address. The interface can receive but not send, so effectively becomes a “listen-only” device. When issued without a parameter, the command returns the current state of ``lon`` mode. :Modes: device :Syntax: ``++lon [0|1]`` where 0=disabled; 1=enabled ``++mode`` ++++++++++ This command configures the AR488 to serve as a controller or a device. In controller mode the AR488 acts as the Controller-in-Charge (CIC) on the GPIB bus, receiving commands terminated with ``CRLF`` over USB and sending them to the currently addressed instrument via the GPIB bus. The controller then passes the received data back over USB to the host. In device mode, the AR488 can act as another device on the GPIB bus. In this mode, the AR488 can act as a GPIB talker or listener and expects to receive commands from another controller (``CIC``). All data received by the AR488 is passed to the host via USB without buffering. All data from the host via USB is buffered until the AR488 is addressed by the controller to talk. At this point the AR488 sends the buffered data to the controller. Since the memory on the controller is limited, the AR488 can buffer only 120 characters at a time. When sending data followed by a command, the buffer must first be read by the controller before a subsequent command can be accepted, otherwise the command will be treated as characters to be appended to the existing data in the buffer. Once the buffer has been read, it is automatically cleared and the parser can then detect the ``++`` command prefix on the next line. Therefore sufficient delay must be allowed for the buffer to be read before sending a subsequent command. If the command is issued without a parameter, the current mode is returned. :Modes: controller, device :Syntax: ``++mode [0|1]`` where 0=device, 1=controller ``++read`` ++++++++++ This command can be used to read data from the currently addressed instrument. Data is read until: - the ``EOI`` signal is detected - a specified character is read - timeout expires Timeout is set using the read_tmo_ms command and is the maximum permitted delay for a single character to be read. It is not related to the time taken to read all of the data. For details see the description of the ``read_tmo_ms`` command. :Modes: controller :Syntax: ``++read [eoi|]`` where is a decimal number corresponding to the ASCII character to be used as a terminator and must be less than 256. ``++read_tmo_ms`` +++++++++++++++++ This specifies the timeout value, in milliseconds, that is used by the ``++read`` (and ``++spoll``) commands to wait for a character to be transmitted while reading data from the GPIB bus. The timeout value may be set between 0 and 32,000 milliseconds (32 seconds). :Modes: controller :Syntax: ``++read_tmo_ms