|  | SA API
    | 
The flow of any program interfacing a Signal Hound device will be as follows:
The API provides functions for each step in this process. We have strived to mimic the functionality and naming conventions of SCPIs IviSpecAn Class Specification where possible. It is not necessary to be familiar with this specification but those who are should feel comfortable with our API immediately. The following sections further detail each of the six steps listed above.
Before attempting to open a device programmatically, it must be physically connected to a USB 2.0 port with the provided cable. Ensure the power light is lit on the device and is solid green. Once the device is connected it can be opened. The functions saOpenDevice and saOpenDeviceBySerialNumber provide this functionality. These functions return an integer ID to the device that was opened. Up to SA_MAX_DEVICES devices may be connected and interfaced through our API using the IDs. The integer ID returned is required for every function call in the API, as it uniquely identifies which device you are interfacing.
All Signal Hound SA series spectrum analyzers need two calibration files to operate. These files reside on internal flash memory for newer models, and on older models, on the Signal Hound web server. The files are copied to the host machine the first time a device is opened on a particular machine. The files are saved at C:/ProgramData/SignalHound cal_files. For models that need the calibration data from the Signal Hound server, the first time the device is opened the host PC needs to have an active network connection. Downloading this file from our server, or pulling it from the device internal flash can cause the first invocation of saOpenDevice to block for up to 10 seconds. Once these files are on a host PC this process does not need to be performed again. If the devices have been used in Spike, then the calibration files will already exist on the host PC.
Once the device is opened, it may be configured. The API provides a number of configuration routines for its many operating states. Configuration routines modify the device global state, such as the sweep frequency or I/Q sampling rate. The configurations do not take effect until the device is initiated.
Each device has two states:
All configurations functions modify the global state which does not immediately affect the operation of the device. Once you have configured the global state to your liking, you may re-initiate the device into a mode of operation, in which the global state is copied into the running state. At this point, the running state is separate and not affected by future configuration function calls.
The saInitiate function is used to initialize the device and enter one of the operational modes. The device can only be in one operational mode at a time. If saInitiate is called on a device that is already initialized, the current mode is aborted before entering the new specified mode.
Once a device has been successfully initiated you can begin retrieving data from the device. Every mode of operation returns different types, and different amounts of data. The Modes of Operation section will help you determine how to collect data from the API for any given mode. Helper routines are also used for certain modes to determine how much data to expect from the device.
Aborting the operation of the device is achieved through the saAbort function. This causes the device to cancel any pending operations and return to an idle state. Calling saAbort explicitly is never required. If you attempt to initiate an already active device, saAbort will be called for you. Also if you attempt to close an active device, saAbort will be called. There are a few reasons you may wish to call saAbort manually though.
When you are finished, you must call saCloseDevice. This function attempts to safely close the USB 2.0 connection to the device and clean up any resources which may be allocated. A device may also be closed and opened multiple times during the execution of a program. This may be necessary if you want to change USB ports, or swap a device.