RSA API Reference 077103102 Rev B
RSA API Reference 077103102 Rev B
Programming Reference
Revision B
*P077103102*
077-1031-02
xx RSA306, RSA306B, and
RSA500A/600A Series
Spectrum Analyzers
Application Programming Interface (API)
ZZZ
Programming Reference
Revision B
www.tek.com
077-1031-02
Copyright Tektronix. All rights reserved. Licensed software products are owned by Tektronix or its subsidiaries or suppliers, and are
protected by national copyright laws and international treaty provisions.
Tektronix products are covered by U.S. and foreign patents, issued and pending. Information in this publication supersedes that in all
previously published material. Specifications and price change privileges reserved.
TEKTRONIX and TEK are registered trademarks of Tektronix, Inc.
Contacting Tektronix
Tektronix, Inc.
14150 SW Karl Braun Drive
P.O. Box 500
Beaverton, OR 97077
USA
Table of Contents
Preface .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . ii
API function groups. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . 1
Alignment functions. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . 2
Audio functions .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . 3
Configure functions . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . 7
Device functions . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 13
DPX functions. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 20
GNSS functions.. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 32
IF streaming functions . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 37
IQ block functions. .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 42
IQ streaming functions . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 49
Playback functions (R3F file format) . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 68
Power functions.. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 70
Spectrum functions . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 71
Time functions . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 78
Tracking generator functions . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . . . . .. 82
Trigger functions . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 84
Example Python program . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . . . 88
Programming file attachment . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 89
Streaming Sample Data File Format. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 90
RSA API version compatibility . . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. . .. 95
Index
API Reference i
Preface
Preface
This document describes the RSA API function calls to interface with the RSA306, RSA306B, RSA500A Series, and
RSA600A Series Spectrum Analyzers through Microsoft Windows.
The API driver is required to use the function calls. This driver is automatically installed with the installation of the SignalVu-PC
software. If you wish to install the API driver without SignalVu-PC software, it is available on the Flash drive provided. Open
the flash drive, and navigate to the API installer. The supplied driver is for the Microsoft Windows operating system.
Programing languages supported by this driver include: C, C++, and Python. An example program written in Python is
provided. (See page 89, Programming file attachment.)
This document supports API version 2. A compatibility chart from API version 1 to version 2 is provided. (See page 95, RSA
API version compatibility.)
ii API Reference
API function groups
API Reference 1
Alignment functions
Alignment functions
ALIGN_GetAlignmentNeeded Determines if an alignment is needed or not.
Declaration: ReturnStatus ALIGN_GetAlignmentNeeded(bool* needed);
Parameters:
needed: Pointer to a bool. True indicates an alignment is needed. False indicates an
alignment is not needed.
Return Values:
noError: The function has completed successfully.
errorNotConnected: The device is not connected.
Additional Detail: It is based on the difference between the current temperature and the
temperature from the last alignment.
2 API Reference
Audio functions
Audio functions
AUDIO_SetFrequencyOffset Sets the audio demodulation carrier frequency offset from the Center Frequency.
Declaration: ReturnStatus AUDIO_SetFrequencyOffset(double freqOffsetHz);
Parameters:
freqOffsetHz: Amount of frequency offset from the Center Frequency.
Range: 20e6 freqOffsetHz 20e6
Return Values:
noError: The function completed successfully.
errorParameter: Input parameter out of range.
Additional Detail: This function allows the audio demodulation carrier frequency to be offset from
the devices Center Frequency. This allows tuning different carrier frequencies
without changing the Center Frequency. The audio demodulation is performed
at a carrier frequency of (Center Frequency + freqOffsetHz). The freqOffsetHz
is set to an initial value of 0 Hz at the time the device is connected.
AUDIO_GetFrequencyOffset Queries the audio carrier frequency offset from the Center Frequency.
Declaration: ReturnStatus AUDIO_GetFrequencyOffset(double* freqOffsetHz);
Parameters:
freqOffsetHz: Pointer to a double variable. Returns the current audio frequency offset from
the Center Frequency in Hz.
Return Values:
noError: The function completed successfully.
API Reference 3
Audio functions
4 API Reference
Audio functions
AUDIO_GetVolume Queries the volume and must be a real value ranging from 0 to 1.
Declaration: ReturnStatus AUDIO_GetVolume(float* _volume);
Parameters:
_volume: Pointer to a float. Contains a real number ranging from 0 to 1.
Return Values:
noError: The volume has been successfully queried.
Additional Detail: If the value is outside of the specified range, clipping occurs.
AUDIO_SetVolume Sets the volume value and must be a real number ranging from 0 to 1.
Declaration: ReturnStatus AUDIO_SetVolume(float volume);
Parameters:
volume: Volume value.
Range: 0.0 to 1.0.
Return Values:
noError: The volume has successfully been set.
Additional Detail: If the value is outside of the specified range, clipping occurs.
API Reference 5
Audio functions
6 API Reference
Configure functions
Configure functions
CONFIG_GetCenterFreq Queries the center frequency.
Declaration: ReturnStatus CONFIG_GetCenterFreq(double* cf);
Parameters:
cf: Pointer to a double. Contains the center frequency when the function completes.
Return Values:
noError: The center frequency has been queried.
errorNotConnected: The device is not connected.
Additional Detail: The center frequency determines the center location for the spectrum view.
API Reference 7
Configure functions
CONFIG_Preset This function sets the trigger mode to Free Run, the center frequency to 1.5
GHz, the span to 40 MHz, the IQ record length to 1024 samples and the
reference level to 0 dBm.
Declaration: ReturnStatus CONFIG_Preset();
Return Values:
noError: The preset values have been set.
errorNotConnected: The device is not connected.
8 API Reference
Configure functions
API Reference 9
Configure functions
10 API Reference
Configure functions
API Reference 11
Configure functions
12 API Reference
Device functions
Device functions
DEVICE_Connect Connects to a device specified by the deviceID parameter.
Declaration: ReturnStatus DEVICE_Connect(int deviceID);
Parameters:
deviceID: Device ID found during the Search function call.
Return Values:
noError: The device has been connected.
errorTransfer: The POST status could not be retrieved from the device.
errorIncompatibleFirmware: The firmware version is incompatible with the API version.
errorNotConnected: The device is not connected.
Additional Detail: The deviceID value must be found by the Search function call.
DEVICE_Disconnect Stops data acquisition and disconnects from the connected device.
Declaration: ReturnStatus DEVICE_Disconnect();
Return Values:
noError: The device has been disconnected.
errorDisconnectFailure: The disconnect failed.
DEVICE_GetErrorString Returns a string that corresponds to the ReturnStatus value specified by the
status parameter.
Declaration: ReturnStatus const char* DEVICE_GetErrorString(ReturnStatus status);
Parameters:
status: A ReturnStatus value.
Return Values: Pointer to a string corresponding to the status input value. ReturnStatus error
codes are listed in the RSA_API.h interface file.
API Reference 13
Device functions
DEVICE_GetHWVersion Stores the hardware version in a string. It has the form: V versionNumber.
Declaration: ReturnStatus DEVICE_GetHWVersion(char* hwVersion);
Parameters:
hwVersion: String that contains the hardware version when the function completes.
Return Values:
noError: The HW version number is stored in the hwVersion parameter.
errorNotConnected: The device is not connected.
Obtaining a devices nomenclature can be accomplished with similar functions. These functions are grouped together.
DEVICE_GetNomenclature Stores the name of the device in the nomenclature parameter.
Declaration: ReturnStatus DEVICE_GetNomenclature(char* nomenclature);
DEVICE_GetNomenclatureW Stores the name of the device in the nomenclatureW parameter.
Declaration: ReturnStatus DEVICE_GetNomenclatureW(wchar_t* nomenclatureW);
Parameters:
nomenclature: Char string that contains the name of the device when the function completes.
nomenclatureW: Wchar_t string that contains the name of the device when the function
completes.
Return Values:
noError: The string name has been set.
14 API Reference
Device functions
DEVICE_GetSerialNumber Stores the serial number of the device in the serialNum parameter.
Declaration: ReturnStatus DEVICE_GetSerialNumber(char* serialNum);
Parameters:
serialNum: String that contains the serial number of the device when the function completes.
Return Values:
noError: The device serial number has been set.
errorNotConnected: The device is not connected.
DEVICE_PrepareForRun Performs all of the internal tasks necessary to put the system in a known state
ready to stream data, but does not actually initiate data transfer.
Declaration: ReturnStatus DEVICE_PrepareForRun();
Return Values:
noError: The system is ready to start streaming data.
Additional Detail: During file playback mode, this is useful to allow other parts of your
application to prepare to receive data before starting the transfer. (See
DEVICE_StartFrameTransfer). This is in comparison to the Run() function,
which immediately starts data streaming without waiting for a Go signal.
API Reference 15
Device functions
Searching for devices can be accomplished with several similar functions. These functions are grouped together.
DEVICE_Search Searches for connectable devices (user buffers)
Declaration: ReturnStatus DEVICE_Search(int* numDevicesFound, int deviceIDs[],
char deviceSerial[][DEVSRCH_SERIAL_MAX_STRLEN], char
deviceType[][DEVSRCH_TYPE_MAX_STRLEN]);
DEVICE_SearchW Searches for connectable devices (user buffers, w_char strings).
Declaration: ReturnStatus DEVICE_SearchW(int* numDevicesFound, int deviceIDs[],
wchar_t deviceSerial[][DEVSRCH_SERIAL_MAX_STRLEN], wchar_t
deviceType[][DEVSRCH_TYPE_MAX_STRLEN]);
DEVICE_SearchInt Searches for connectable devices (internal buffers).
Declaration: ReturnStatus DEVICE_SearchInt(int* numDevicesFound, int* deviceIDs[], const
char** deviceSerial[], const char** deviceType[]);
16 API Reference
Device functions
API Reference 17
Device functions
18 API Reference
Device functions
API Reference 19
DPX functions
DPX functions
DPX_Configure Enables or disables the DPX spectrum and DPX spectrogram modes.
Declaration: ReturnStatus DPX_Configure(bool enableSpectrum, bool enableSpectrogram);
Parameters:
enableSpectrum: Enables or disables DPX spectrum.
enableSpectrogram: Enables or disables DPX spectrogram.
Return Values:
noError: The function has executed successfully.
Additional Detail: This function must be called after any DPX settings have been changed and the
device is in Stop state. This function configures all the DPX settings.
See the following steps for an example of how to setup and acquire DPX data:
1. Set the device in Stop state.
2. Setup DPX settings.
3. Call DPX_SetEnable() to enable DPX acquisition.
4. Set the device in Run state.
5. While the device is in Run state, call DPX_WaitForDataReady() to wait for
DPX frame buffer available.
6. When DPX frame is available, call DPX_GetFrameBuffer() to get DPX
bitmaps and traces.
7. Call DPX_FinishFrameBuffer() to indicate the caller has finished transferring
the DPX frame data.
8. Repeat waiting and getting the next DPX frame buffer.
9. After DPX acquisition has completed and the device is in Stop state, you
can use the following functions to get high resolution lines in the DPX
spectrogram (if SPX spectrogram is enabled):
DPX_GetSogramHiResLineCountLatest()
DPX_GetSogramHiResLine()
DPX_GetSogramHiResLineTimestamp()
DPX_GetSogramHiResLineTriggered()
DPX_FinishFrameBuffer This function specifies that the frame is finished. It must be called before the
next frame will be available.
Declaration: ReturnStatus DPX_FinishFrameBuffer();
Return Values:
noError: The function has executed successfully.
20 API Reference
DPX functions
DPX_GetFrameBuffer This function returns the DPX Frame Buffer containing the latest DPX bitmaps
and traces.
Declaration: ReturnStatus DPX_GetFrameBuffer(DPX_FrameBuffer* frameBuffer);
Parameters:
frameBuffer: Pointer to DPX_FrameBuffer struct.
See DPX_FrameBuffer table for descriptions. (See Table 1 on page 21.)
Return Values:
noError: The function has executed successfully.
API Reference 21
DPX functions
float** spectrumTraces Spectrum traces array. The first n elements represents spectrum
trace 0 and the next n elements represents spectrum trace 1
and so forth, where n is the value of spectrumTraceLength (see
SPECTRUM_SetSettings). Each trace point represents the
spectrum power in Watts.
int32_t sogramBitmapWidth Spectrogram bitmap width in pixels.
int32_t sogramBitmapHeight Spectrogram bitmap height in pixels.
int32_t sogramBitmapSize Total number of pixels in Spectrogram bitmap (sogramBitmapWidth
* sogramBitmapHeight).
int32_t sogramBitmapNumValidLines Number of valid horizontal lines (spectrums) in Spectrogram bitmap.
22 API Reference
DPX functions
API Reference 23
DPX functions
24 API Reference
DPX functions
API Reference 25
DPX functions
DPX_GetSogramHiResLine Queries the high resolution line specified by the lineIndex parameter.
Declaration: ReturnStatus DPX_GetSogramHiResLine(int16_t* vData, int32_t* vDataSize,
int32_t lineIndex, double* dataSF, int32_t tracePoints, int32_t firstValidPoint);
Parameters:
vData: Pointer to a 16 bit integer array. The array returns the data stored in the
spectrogram high resolution line.
vDataSize: Pointer to a 32 bit integer. Returns the amount of valid elements in the vData
parameter array.
lineIndex: The spectrogram line index.
dataSF: Pointer to a double. Returns the scale factor. The spectrogram high resolution
line signal level in dBm unit can be calculated by multiplying dataSF with the
elements in vData array.
tracePoints: The amount of trace points to return.
firstValidPoint: First valid trace point.
Return Values:
noError: The function has executed successfully.
Additional Detail: The data stored at the specified line is stored in the vData parameter.
For example, if the firstValidPoint parameter is 10 and tracePoints parameter is
100, then the values of the high resolution line trace points from index 10 to 109
will be returned in the vData array in index 0 to 99.
Since the spectrogram high resolution lines are updated continuously while DPX
is acquiring, this function should be called when DPX is stopped.
DPX_GetSogramHiResLineCountLat- Queries the amount of high resolution lines in the DPX spectrogram.
est
Declaration: ReturnStatus DPX_GetSogramHiResLineCountLatest(int32_t* lineCount);
Parameters:
lineCount: Pointer to a 32 bit integer. Contains the amount of high resolution lines in the
spectrogram when the function completes.
Return Values:
noError: The function has executed successfully.
Additional Details: Each high resolution line may be composed from multiple FFT acquisitions and
the DPX acquisition can be stopped at any time. Therefore, the latest high
resolution line may not contain all the FFTs in a high resolution line.
26 API Reference
DPX functions
DPX_GetSogramHiResLineTriggered Queries the triggered status of a DPX spectrogram high resolution line.
Declaration: ReturnStatus DPX_GetSogramHiResLineTriggered(bool* triggered, int32_t
lineIndex);
Parameters:
triggered: Pointer to a bool. True indicates the specified high resolution line is triggered.
False indicates the specified high resolution line is not triggered.
lineIndex: The index of the high resolution spectrogram line.
Return Values:
noError: The function has executed successfully.
Additional Detail: Since the spectrogram high resolution lines are updated continuously while DPX
is acquiring, this function should be called when DPX is stopped.
DPX_GetSogramSettings Queries DPX spectrogram bitmap width, bitmap height, trace line time and
bitmap line time.
Declaration: ReturnStatus DPX_GetSogramSettings(DPX_SogramSettingsStruct
*sogramSettings);
Parameters:
sogramSettings: Pointer to DPX_SogramSettingsStruct.
DPX_SogramSettingsStruct
Item Description
int32_t bitmapWidth DPX spectrogram bitmap width in pixels.
int32_t bitmapHeight DPX spectrogram bitmap height in pixels.
double sogramTrace- Time per each DPX spectrogram high
LineTime resolution trace line in seconds.
double sogram- Time per each DPX spectrogram bitmap line
BitmapLineTime in seconds
Return Values:
noError: The function has executed successfully.
API Reference 27
DPX functions
DPX_Reset Clears the spectrum bitmap, resets the spectrum traces, resets the spectrogram
bitmap, resets the spectrogram traces, sets the FFT count to 0, and sets the
frame count to 0.
Declaration: ReturnStatus DPX_Reset();
Return Values:
noError: The function has executed successfully.
28 API Reference
DPX functions
DPX_SetParameters Sets the DPX span, resolution bandwidth, trace points per pixel, Y-axis units,
maximum Y-axis value, minimum Y-axis value, infinite persistence, persistence
time and show only trigger frame.
Declaration: ReturnStatus DPX_SetParameters(double fspan, double rbw, int32_t
bitmapWidth, int32_t tracePtsPerPixel, VerticalUnitTypes yUnit, double yTop,
double yBottom, bool infinitePersistence, double persistenceTimeSec, bool
showOnlyTrigFrame);
Parameters:
fspan: Span measured in Hz.
This value must be greater than 0 and less than or equal to 40 MHz.
rbw: Resolution bandwidth measured in Hz.
This value must be greater than 0.
bitmapWidth: Bitmap width measured in pixels.
This value must be greater than 0 and less than or equal to 801.
tracePtsPerPixel: Trace points per pixel. The total number of trace points is equal to
tracePtsPerPixel * bitmapWidth.
Valid values are: 1, 3, 5.
yUnit: Units of the Y-axis.
VerticalUnitType Value
VerticalUnit_dBm 0
VerticalUnit_Watt 1
VerticalUnit_Volt 2
VerticalUnit_Amp 3
yTop: The maximum value on the Y-axis in yUnit.
This value must be higher than yBottom.
yBottom: The minimum value on the Y-axis in yUnit.
infinitePersistence: Enables or disables infinite persistence. It causes every data point to remain
on the screen when enabled.
persistenceTimeSec: The amount of time that previous signals remain on the screen.
showOnlyTrigFrame: Enables or disables showing only trigger frames. If true, DPX frame is only
available when a trigger occurs. If false, DPX frame is available continuously.
Return Values:
noError: The function has executed successfully.
API Reference 29
DPX functions
DPX_SetSogramParameters Sets the amount of time that each spectrogram line represents and the signal
level range of the spectrogram.
Declaration: ReturnStatus DPX_SetSogramParameters(double timePerBitmapLine, double
timeResolution, double maxPower, double minPower);
Parameters:
timePerBitmapLine: The amount of time per bitmap line in seconds. Each bitmap line is composed
of one or more spectrogram high resolution lines.
timeResolution: The amount of time that each spectrogram high resolution line represents in
seconds. This value must be greater than or equal to 1 ms.
maxPower: The maximum signal level of the spectrogram bitmap in current Vertical Unit
(yUnit in DPX_SetParameters).
minPower: The minimum signal level of the spectrogram bitmap in current Vertical Unit
(yUnit in DPX_SetParameters).
Return Values:
noError: The function has executed successfully.
Additional Detail: See sogramBitmap item in DPX_FrameBuffer description table for the usage of
maxPower and minPower. (See Table 1 on page 21.)
30 API Reference
DPX functions
DPX_SetSpectrumTraceType Specifies one of the three traces with the traceIndex parameter and sets its
trace type with the type parameter.
Declaration: ReturnStatus DPX_SetSpectrumTraceType(int32_t traceIndex, TraceType
type);
Parameters:
traceIndex: Specifies the trace to be set. It can be 0, 1, or 2.
type: A value of type TraceType.
TraceType Value
TraceTypeAverage 0
TraceTypeMax 1
TraceTypeMaxHold 2
TraceTypeMin 3
TraceTypeMinHold 4
Return Values:
noError: The function has executed successfully.
API Reference 31
GNSS functions
GNSS functions
The RSA500A Series and RSA600A Series devices include a Global Navigation Satellite System (GNSS) receiver (Telit
SL869-V2) capable of tracking GPS, Glonass, or Beidou satellite navigation signals. The GNSS receiver provides status,
position, and time messages in NMEA 0183 format, along with a high accuracy 1-Pulse-Per-Second (1PPS) timing pulse
usable for internal signal timestamping. User access to the navigation message stream and 1PPS event are provided
through API GNSS functions. User-controllable GNSS antenna power output is also provided.
32 API Reference
GNSS functions
API Reference 33
GNSS functions
34 API Reference
GNSS functions
API Reference 35
GNSS functions
36 API Reference
IF streaming functions
IF streaming functions
NOTE. Before calling the API function IFSTREAM_SetEnable(true), you must have made at least one call to Run() to
initialize the channel correction data structures or the frame header information in at least one of your streamed files
will be incomplete.
After calling IFSTREAM_SetEnable(true), you must not make any changes to hardware settings until you call
IFSTREAM_SetEnable(false) or until enough time has elapsed such that all automatically created streamed files are
completely written to disk.
API Reference 37
IF streaming functions
IFSTREAM_SetDiskFilenameSuffix Sets the control that determines what, if any, filename suffix is appended to
the output file base filename.
Declaration: ReturnStatus IFSTREAM_SetDiskFilenameSuffix(int suffixCtl);
Parameters:
suffixCtl: Sets the filename suffix control value.
Note that the IFSSDFN_SUFFIX_TIMESTAMP setting is the default, and is
applied automatically if the suffix control is not set after connection.
Return Values:
noError: The setting was accepted.
Additional Detail The complete IF output filename has the following format:
<filePath><filenameBase><suffix><.ext>
where:
<filePath>,<filenameBase>: set by their associated IFSTREAM
configuration functions
<suffix>: as set by filename suffix control using this function
<.ext>: as set by IFSTREAM file mode configurationfunction
[ .r3f or .r3h+.r3a]
If separate data and header files are generated, the same path/filename is used
for both, with different extensions to indicate the contents.
suffixCtl value Suffix generated
IFSSDFN_SUFFIX_NONE None. Filename is created without
(-2) suffix. (Note that the output filename
will not change automatically, so
each output file will overwrite the
previous one unless the filename is
explicitly changed by calling the IF-
STREAM_SetDiskFilenameBase()
function.)
IFSSDFN_SUFFIX_TIMESTAMP String formed from file
(-1) creation time Format:
-YYYY.MM.DD.hh.mm.ss.msec
(Note this time is not directly linked
to the data timestamps, so it should
not be used as a high-accuracy
timestamp of the file data.)
(Auto-increment index) 5 digit auto-incrementing index,
0 initial value = suffixCtl.
Format: -nnnnn
(Note the index value
auto-increments by 1 each
time a new file is created.)
38 API Reference
IF streaming functions
IFSTREAM_GetActiveStatus Allows the current status of the ADC data streaming operation to be queried.
Declaration: ReturnStatus IFSTREAM_GetActiveStatus(bool *enabled);
Parameters:
enabled: Reports the current status of the ADC data streaming operation.
Return Values:
noError: The operation has completed successfully.
IFSTREAM_SetDiskFileCount Sets the maximum number of files to open for streamed data.
Declaration: ReturnStatus IFSTREAM_SetDiskFileCount(int maximum);
Parameters:
maximum: Maximum number of files to save.
Return Values:
noError: The operation has completed successfully.
errorStreamADC- ADC streaming is already in operation.
ToDiskAlreadyStreaming:
API Reference 39
IF streaming functions
IFSTREAM_SetDiskFileLength Sets the maximum recording time for any single data file.
Declaration: ReturnStatus IFSTREAM_SetDiskFileLength(int msec);
Parameters:
msec: Sets the maximum recording time for ADC files.
Return Values:
noError: The operation has completed successfully.
errorStreamADC- ADC streaming is already in operation.
ToDiskAlreadyStreaming:
40 API Reference
IF streaming functions
API Reference 41
IQ block functions
IQ block functions
IQBLK_GetIQAcqInfo Queries the IQ acquisition status information for the most recently retrieved
IQ Block record.
Declaration: ReturnStatus IQBLK_GetIQAcqInfo(IQBLK_ACQINFO* acqInfo);
Parameters:
acqInfo: Pointer to IQBLK_ACQINFO structure allocated by the caller.
Return Values:
noError: The function has completed successfully.
errorNotConnected: The device is not connected.
Additional Detail: IQBLK_GetIQAcqInfo() may be called after an IQ block record is
retrieved with IQBLK_GetIQData(), IQBLK_GetIQDataInterleaved(), or
IQBLK_GetIQDataComplex(). The returned information applies to the IQ record
returned by the "GetData" functions.
The IQBLK_ACKINFO structure contains these items:
sample0Timestamp: uint64_t timestamp of the first sample of the
IQ block record
triggerSampleIndex: uint64_t index to the sample corresponding to
the trigger point
triggerTimestamp: uint64_t timestamp of the trigger sample
acqStatus: uint32_t word with acquistiion status bits.
A status bit value of 1 indicates that event
occurred during the signal acquisition, a value
of 0 indicates no occurrence.
The valid status bits are described in the
following Status Bits table.
42 API Reference
IQ block functions
API Reference 43
IQ block functions
44 API Reference
IQ block functions
API Reference 45
IQ block functions
46 API Reference
IQ block functions
IQBLK_GetMaxIQRecordLength Queries the maximum number of IQ samples which can be generated in one
IQ block record.
Declaration: ReturnStatus IQBLK_GetMaxIQRecordLength(int* maxSamples);
Parameters:
maxCF: Pointer to an integer. Contains the maximum IQ record length value when
the function completes.
Return Values:
noError: The maxSamples value has been queried.
API Reference 47
IQ block functions
48 API Reference
IQ streaming functions
IQ streaming functions
NOTE. When IQ Streaming is active, it should be the only API data processing function in operation. No other processing
function (DPx, IQ Block, Audio, IF streaming or Spectrum) should be running at the same time. If other data processing is
active, it may overload the computer processing capability, causing gaps or dropouts in the streamed IQ data. There can also
be conflicts in some control parameters between IQ Streaming and the other processing operations.
Most IQSTREAM control parameters should only be set/changed while IQStream processing is in its Stopped state
(IQSTREAM_Stop()). Changing parameters while IQStream processing is running does not correctly apply the new values.
IQSTREAM_ClearAcqStatus Resets the sticky status bits of the acqStatus info element during an IQ
Streaming run interval.
Declaration: void IQSTREAM_ClearAcqStatus();
Parameters:
none:
Return Values:
none:
Additional Detail: This is affective for both client and file destination runs.
API Reference 49
IQ streaming functions
IQSTREAM_GetAcqParameters Reports the processing parameters of IQ output bandwidth and sample rate
resulting from the users requested bandwidth.
Declaration: ReturnStatus IQSTREAM_GetAcqParameters(double* bwHz_act, double*
srSps);
Parameters:
bwHz_act: Pointer to a double. Returns actual acquisition bandwidth of IQ Streaming
output data, in Hz.
srSps: Pointer to a double. Returns actual sample rate of IQ Streaming output data, in
Samples/sec
Return Values:
noError: The query was successful.
Additional Detail: This is the mapping of requested bandwidth to actual output bandwidth and
sample rate.
Requested BW Output BW Output Sample Rate
BW 5 MHz 5 MHz 7.0 Msps
5 MHz < BW 10 MHz 10 MHz 14.0 Msps
10 MHz < BW 20 MHz 20 MHz 28.0 Msps
BW > 20 MHz 40 MHz 56.0 Msps
50 API Reference
IQ streaming functions
IQSTREAM_GetDiskFileInfo Returns an information structure about the previous file output operation.
Declaration: ReturnStatus IQSTREAM_GetDiskFileInfo(IQSTRMFILEINFO* fileinfo);
Parameters:
fileinfo: Pointer to a struct. Returns a structure of information about the file output
operation.
Return Values:
noError: The query was successful.
Additional Detail: This information is intended to be queried after the file output operation has
completed. It can be queried during file writing as an ongoing status, but some
of the results may not be valid at that time.
IQSTRMFILEINFO structure content:
Item Description
numberSamples Number of IQ sample pairs written to the file.
sample0Timestamp Timestamp of the first sample written to file.
triggerSampleIndex Sample index where the trigger event occurred.
This is only valid if triggering has been enabled.
Set to 0 otherwise.
triggerTimestamp Timestamp of the trigger event. This is only valid if
triggering has been enabled. Set to 0 otherwise.
filenames Ptrs-to-wchar_t strings of the filenames of the
output files:
filenames[IQSTRM_FILENAME_DATA_IDX]:
data filename
filename[IQSTRM_FILENAME_HEADER_ID-
X]: header filename
If data and header output are in the same file, the
strings will be identical. The string storage is in an
internal static buffer, overwritten with each call to
the function.
API Reference 51
IQ streaming functions
52 API Reference
IQ streaming functions
API Reference 53
IQ streaming functions
IQSTREAM_GetIQData Allows the client application to retrieve IQ data blocks generated by the IQ
Stream processing.
Declaration: ReturnStatus IQSTREAM_GetIQData(void* iqdata, int* iqlen, IQSTRMIQINFO*
iqinfo);
Parameters:
iqdata: Pointer to iqbuffer. Returns IQ sample data block.
iqlen: Pointer to an integer. Returns the number of IQ data pairs returned in iqbuffer. 0
indicates no data available.
iqinfo: Pointer to a struct. Returns a structure containing information about the IQ data
block. (Set value to NULL if the info struct is not wanted).
Return Values:
noError: The query was successful.
Additional Detail: Allows the client application to retrieve IQ data blocks generated by the IQ
Stream processing. Data blocks are copied out to the buffer pointed to by
iqdata, which must be allocated by the client large enough to hold the output
record. See IQSTREAM_GetIQDataBufferSize() to get the required buffer size.
The underlying data buffer organization is interleaved I/Q data pairs of the
data type configured. It is recommended to use the correct complex data
type: Cplx32 (Single data type), CplxInt32 (Int32), CplxInt16 (Int16) to simplify
accessing the data, although any buffer pointer type will be accepted.
iqlen returns the number of IQ sample pairs copied out to the buffer. The
returned value is 0 if no data is available. The client can poll the function, waiting
for iqlen>0 to indicate data is available. If possible, the client should not do this
in a tight loop to avoid heavily loading the processor while waiting for data.
IMPORTANT: Client applications must retrieve the data blocks at a fast enough
rate to avoid backing up a large amount of data within the API, which can
result in loss of data. The minimum retrieval rate can be calculated as (srSps
/maxSize). For example, with a sample rate of 56 Msps (40 MHz Acq BW)
and IQ block maxSize of 130,848 samples (default), blocks must be retrieved
at an average rate of no less than 56e6/130848 = 428 blocks/sec, or less than
2.34 msecs/block. The interval can be increased by requesting larger blocks
sizes, or decreased if desired.
54 API Reference
IQ streaming functions
The API has an internal buffer which can hold up to 100 msec of output IQ
samples at 40 MHz, to allow the client to occasionally take longer than the
average required output rate. But if the client output retrieval rate continually
averages less than the required rate, the buffer will eventually overflow and data
will be lost. The same output buffer is used for all output sample rates so the
buffers effective time-size increases for lower sample rates (2x for 20 MHz, 4x
for 10 MHz, etc).
iqinfo returns a copy of an IQSTRMIQINFO structure with the following content:
Item Description
timestamp Timestamp of first sample of block.
triggerIndices Number of trigger events occurring during block.
Maximum of 100 trigger events per block.
triggerIndices List of sample indices where trigger(s) occurred,
triggerCount in length. This list is stored in an
internal static buffer and is overwritten on each call to
IQSTREAM_GetIQData(). To preserve it longer, the
client must copy the values to an external buffer before
the next call.
scaleFactor Scale factor to convert Int16 or Int32 data types to
standard voltage values. This value is set to 1.0 for
Single data type since those values are already scaled
to voltage.
API Reference 55
IQ streaming functions
acqStatus Acquisition status flags for this block and entire run
interval. Individual bits are used as indicators as
follows:
Individual Retrieved Block status (Bits 0-15, starting
from LSB):
Bit0: 1=Input overrange
Bit1: 1=USB data stream discontinuity
Bit2: 1=Input buffer>75% full (IQStream processing
heavily loaded)
Bit3: 1=Input buffer overflow (IQStream processing
overloaded, data loss has occurred)
Bit4: 1=Output buffer>75% full (Client falling
behind unloading data)
Bit5: 1=Output buffer overflow (Client unloading
data too slow, data loss has occurred)
Bit6-Bit15: (unused, always 0)
Entire run summary status (sticky bits)
The bits in this range are essentially the same as
Bits0-15, except once they are set (->1) they remain
set for the entire run interval. They can be used to
determine if any of the status events occurred at any
time during the run. (Bits16-31, starting from LSB):
Bit16: 1=Input overrange
Bit17: 1=USB data stream discontinuity
Bit18: 1=Input buffer>75% full (IQStream
processing heavily loaded)
Bit19: 1=Input buffer overflow (IQStream
processing overloaded, data loss has occurred)
Bit20: 1=Output buffer>75% full (Client falling
behind unloading data)
Bit21: 1=Output buffer overflow (Client unloading
data too slow, data loss has occurred)
Bit22-Bit31: (unused, always 0)
IQSTREAM_ClearAcqStatus can be called to clear the sticky bits during the
run if it is desired to reset them.
56 API Reference
IQ streaming functions
IQSTREAM_GetIQDataBufferSize Returns the maximum number of IQ sample pairs which will be returned by the
IQSTREAM_GetIQData () function.
Declaration: ReturnStatus IQSTREAM_GetIQDataBufferSize(int* maxSize);
Parameters:
maxSize: Pointer to an integer. Returns maximum size IQ output data buffer required
when using client IQ access. Size value is in IQ sample pairs.
Return Values:
noError: The query was successful.
Additional Detail: The requested size value can be increased or decreased using the
IQSTREAM_SetIQDataBufferSize () function. Available size values are integer
multiples of 65,424 (integer multiplier range 1..8), with default size of 2*65242 =
130,848 IQ samples. The client should use the value returned by this function.
Do not assume the above sizes will remain fixed.
The client application must allocate a buffer large enough to accept maxSize IQ
data pairs returned when the IQSTREAM_GetIQData() function is called. The
required allocated buffer sizes are given below:
Data Type IQ Buffer data type Required Client Buffer
size
Single Cplx32 maxSize * size(Cplx32)
Int32 CplxInt32 maxSize * size(CplxInt32)
Int16 CplxInt16 maxSize * size(CplxInt16)
Example C code client buffer allocation code (using either malloc() or new is
acceptable):
Single: Cplx32* pCplx32 = new Cplx32[maxSize];
Int32: CplxInt32* pCplxInt32 = malloc(maxSize*sizeof(CplxInt32));
Int16: CplxInt16* pCplxInt16 = malloc(maxSize*sizeof(CplxInt16));
Example client function use:
int maxSize;
IQSTREAM_SetIQDataBufferSize (500000); // request 500,000 IQ sample
pairs
IQSTREAM_GetIQDataBufferSize (&maxSize); // maxSize = 261696
returned
Cplx32* pIQdata = new Cplx32[maxSize];
IQSTREAM_GetIQData(pIQdata, &iqlen, &iqinfo);
API Reference 57
IQ streaming functions
IQSTREAM_SetAcqBandwidth Sets the users request for the acquisition bandwidth of the output IQ data
stream samples.
Declaration: ReturnStatus IQSTREAM_SetAcqBandwidth(double bwHz_req);
Parameters:
bwHz_req: Requested acquisition bandwidth of IQ Streaming output data, in Hz.
Return Values:
noError: The requested value was accepted
Additional Detail: No checking of the input value is done by this function. See the table in
IQSTREAM_GetAcqParameters() for the mapping of requested bandwidth
to actual output bandwidth provided.
NOTE. The Acq Bandwidth setting should only be changed when the
instrument is in the global Stopped state. The new BW setting does not take
effect until the global system state is cycled from Stopped to Running.
58 API Reference
IQ streaming functions
Sets the base filename for file output can be accomplished with similar functions. These functions are grouped together.
IQSTREAM_SetDiskFilenameBase Sets the base filename for file output (char string)
Declaration: ReturnStatus IQSTREAM_SetDiskFilenameBase(const char* filenameBase);
IQSTREAM_SetDiskFilenameBaseW Sets the base filename for file output (wchar_t string)
Declaration: QSTREAM_SetDiskFilenameBaseW(const wchar_t* filenameBaseW)
Parameters:
filenameBase: Base filename for file output. This can include drive/path, as well as the common
base filename portion of the file. The filename base should not include a file
extension, as the file writing operation will automatically append the appropriate
one for the selected file format.
filenameBaseW: Base filename for file output. This can include drive/path, as well as the common
base filename portion of the file. The filename base should not include a file
extension, as the file writing operation will automatically append the appropriate
one for the selected file format.
Return Values:
noError: The setting was accepted.
Additional Detail: The complete output filename has the following format:
<filenameBase><suffix><.ext>
<filenameBase>: as set by this function
<suffix>: as set by filename suffix control in IQSTREAM_SetDiskFilename-
Suffix()
<.ext>: as set by destination control in IQSTREAM_SetOutputConfigura-
tion(), [ .tiq, .siq, .siqh+.siqd]
If separate data and header files are generated, the same path/filename is used
for both, with different extensions to indicate the contents.
API Reference 59
IQ streaming functions
IQSTREAM_SetDiskFilenameSuffix Sets the control that determines what, if any, filename suffix is appended to the
output base filename.
Declaration: ReturnStatus IQSTREAM_SetDiskFilenameSuffix(int suffixCtl);
Parameters:
suffixCtl: Sets the filename suffix control value.
Return Values:
noError: The setting was accepted.
Additional Detail: See description of IQSTREAM_SetDiskFilename() for the full filename format.
suffixCtl value Suffix generated
IQSSDFN_SUFFIX_NONE None. Base filename is used without
(-2) suffix. (Note that the output filename
will not change automatically from
one run to the next, so each output file
will overwrite the previous one unless
the filename is explicitly changed by
calling the Set function again.)
IQSSDFN_SUFFIX_TIMESTAMP String formed from file creation time
(-1) Format:
-YYYY.MM.DD.hh.mm.ss.msec
(Note this time is not directly linked
to the data timestamps, so it should
not be used as a high-accuracy
timestamp of the file data!)
0 5 digit auto-incrementing index, initial
value = suffixCtl.
Format: -nnnnn
(Note index auto-increments by 1
each time IQSTREAM_Start() is
invoked with file data destination
setting.)
60 API Reference
IQ streaming functions
IQSTREAM_SetIQDataBufferSize Sets the requested size in IQ sample pairs of the IQ record returned to the client.
Declaration: ReturnStatus IQSTREAM_SetIQDataBufferSize(int reqSize);
Parameters:
reqSize: Requested size of IQ output data buffer in IQ sample pairs. 0 resets to default.
Return Values:
noError: The value was accepted.
Additional Detail: Any size can be requested, but only a limited set of actual sizes are available.
Client must use IQSTREAM_GetIQDataBufferSize() to determine the actual
maximum size which will be returned. The nearest available size smaller or
equal to the requested size will be used.
If the default output size is acceptable, this function does not need to be used.
API Reference 61
IQ streaming functions
62 API Reference
IQ streaming functions
IQSTREAM_Stop This function terminates IQ Stream processing and disables data output.
Declaration: ReturnStatus IQSTREAM_Stop();
Parameters:
(none):
Return Values:
noError: The operation was successful.
Additional Detail: If the data destination is file, file writing is stopped and the output file is closed.
API Reference 63
IQ streaming functions
Header Block. The Header consists of lines of 8-bit ASCII text characters, each line terminated by a LF/CR (0x0D/0x0A)
control character pair.
Example Header Block:
RSASIQHT:1024,1
FileDateTime:2015-04-29T10:12:33.170
Hardware:RSA306-Q000004
Software/Firmware:3.6.0034-V1.7-V1.1-V3
ReferenceLevel:0.00
CenterFrequency:100000000.00
SampleRate:56000000.00
AcqBandwidth:40000000.00
NumberSamples:56000
NumberFormat:IQ-Int16
DataScale:6.2660977E-005
DataEndian:Little
RecordUtcSec:001430327553.177054669
RecordUtcTime:2015-04-29T17:12:33.177054669
RecordLclTime:2015-04-29T10:12:33.177054669
TriggerIndex:0
TriggerUtcSec:001430327553.177054669
TriggerUtcTime:2015-04-29T17:12:33.177054669
TriggerLclTime:2015-04-29T10:12:33.177054669
AcqStatus:0x00000000
Header Identifier. The Header Identifier is always the first line of the header block. It is the only fixed location item in the
header section. In addition to the fixed Header identifier string (RSASIQHT), it also contains the header size and version.
64 API Reference
IQ streaming functions
(Line1): RSASIQHT<:headerSizeInBytes>,<versionNumber>
Example: Header size: 1024 bytes, Version: 1
RSASIQHT:1024,1
In combined .siq files, the headerSizeInBytes value indicates the starting location (in bytes from the beginning of the file) of
the Data section. This value should always be read and used as an index to the Data, as it may vary from file to file. Not
all of the header may be needed for header content. Unused header range is filled with space characters (0x20) from the
last piece of useful header data to the end of the header itself. In .siqd files, data always starts with the first byte, so the
header size value should be ignored then.
The versionNumber is used to indicate different header content formats. Initially there is only one header format, version
number = 1. However, it may change in future SW releases, so should be verified when decoding header information.
Header Information. Following the Header Identifier are lines with parameters describing the associated Data block
values.
Each line has the format:
<InfoIDstring>:<InfoValueString>
The Header Information entries may be in any order. The table below describes the Header information content.
API Reference 65
IQ streaming functions
66 API Reference
IQ streaming functions
Data Block. Data block format is the same for all SIQx file selections. It consists of IQ sample pairs in alternating
I/Q order as shown here:
I(0) Q(0) I(1) Q(1) I(2) Q(2) . I(N-2) Q(N-2) I(N-1) Q(N-1)
where N equals the NumberSamples parameter value.
Each IQ Sample pair forms a complex baseband time-domain sample, at the sample rate given by the header block
SampleRate parameter.
Each I and Q value is represented by a binary number in the data format specified by the header block NumberFormat
parameter (Single, Int32 or Int16), with endian-ness specified by the DataEndian parameter.
Int32 and Int16 I and Q samples values can be scaled to volts into 50 ohms form by multiplying each integer value by the
header block DataScale parameter value. Single values are prescaled to the correct form, so do not need to be multiplied by
the scale factor (it is set to 1.0 to indicate this).
API Reference 67
Playback functions (R3F file format)
PLAYBACK_OpenDiskFile Opens a .r3f file on disk and prepares the system for playback according to
the parameters passed.
Declaration: ReturnStatus PLAYBACK_OpenDiskFile(const wchar_t * fileName, int
startPercentage, int stopPercentage, double skipTimeBetweenFullAcquisitions,
bool loopAtEndOfFile, bool emulateRealTime);
Parameters:
filename: The Unicode name of an accessible disk file in .r3f format. The file must exist
and you must have read permission to its contents.
startPercentage: The starting location in the file from which to commence playback. Units are
in percent of the total file length. File playback will skip the portion of the file
prior to Start Position whenever it plays the file from the beginning, including
repeatedly skipping that portion of the file if loop mode is enabled.
Minimum allowed value: 0
Maximum allowed value: 99
Units: percentage
stopPercentage: The stopping location in the file at which playback terminates. Units are in
percent of total file length. File playback will skip the portion of the file after Stop
Position to the end of the file, including skipping it every time the file plays if
loop mode is enabled.
Minimum allowed value: 1
Maximum allowed value: 100
Units: percentage
skipTimeBetweenFullAcquisi- The amount of time to skip in the file in order to accomplish fast-forwarding.
tions: The playback mechanism will play a contiguous slice of the file contents, the
size of which is determined by the needs of the active measurements. Once
that slice has been processed, file playback will skip a section of data roughly
corresponding to Skip time, then start processing a new slice. Please note that
skip time is not completely arbitrary it is rounded up and discretized to the
nearest USB data frame boundary, approximately 73 s.
Minimum allowed value: 0 (implies no portion of the file is skipped)
Maximum allowed value: undefined, determined by the actual length of
the input file.
Units: time in seconds, rounded up to the nearest ~73 s unit.
68 API Reference
Playback functions (R3F file format)
loopAtEndOfFile: Controls if the file playback automatically wraps around to the start position
when the stop position is reached during playback.
Allowed values:
true (loop at end of file) loops the file indefinitely until a stop request is
received.
false (do not loop and end of file) terminates playback when the stop
position (or end of file) is reached.
emulateRealTime: This setting, when true, puts the system in a real time emulation mode. Data
is processed in a fashion indistinguishable from a live connection to an RSA
device. A 60 second recording will take ~60 seconds to replay, and there is no
guarantee that every frame of data is processed by the system. This mode is
particularly useful for replaying files that contain audio data that you wish to hear.
When set to false, the system uses a deterministic playback method that
processes every frame of data. Deterministic playback is significantly more time
consuming and should only be used for analyzing small significant portions
of a file.
Be aware that real time emulation mode is dependent on sufficient hardware
processing power in order to read the data at the full necessary data rate (an
SSD drive is typically necessary) and for the data processing demands of the
streamed playback data.
Allowed values: true for emulating real time playback, false for deterministic
playback.
Return Values:
noError: The file successfully opened for playback.
errorStreamedFileOpenFail- The file could not be opened. Check the file for existence, access permissions,
ure: non-zero length, or other issues which might interfere with its use.
errorStreamedFileInvalid- The metadata stored in the file by the API appears to be corrupt. This data is
Header: necessary for playback to match the circumstances under which it was captured.
errorStreamingInvalidParam- One of the parameters passed to the function was out of range. Verify the
eters: ranges and types of parameters.
Additional Detail: Once playback has commenced (via a call to Run() or equivalent), the system
behaves much as it would when connected to actual hardware.
PLAYBACK_GetReplayComplete Determine if a file being replayed has reached the end of the file contents.
Declaration: ReturnStatus PLAYBACK_GetReplayComplete(bool * complete);
Parameters:
complete: Pointer to a boolean. True indicates file playback has completed. False
indicates it has not completed. Note that in loop back mode, a file will never
report true from a call to PLAYBACK_GetReplayComplete().
Return Values:
noError: The operation completed successfully.
API Reference 69
Power functions
Power functions
POWER_GetStatus RSA500A Series only.
Queries the device power and battery status information.
Declaration: ReturnStatus POWER_GetStatus(POWER_INFO* powerInfo);
Parameters:
powerInfo: Pointer to a POWER_INFO struct. On return, the structure contains the current
power and battery status information. See Additional Detail below for structure
content.
Return Values:
noError: The status has been successfully queried.
errorMonitoringNotSup- The device does not support battery monitoring.
ported:
Additional Detail: POWER_INFO structure content:
externalPowerPresent True indicates an external power supply is
(boolean): connected. False indicates no external power
supply is connected.
batteryPresent True indicates a battery is installed in the
(boolean): device. False indicates no battery installed.
If batteryPresent is false, the following
battery-related status indicators are invalid and
should be ignored.
batteryChargeLevel Indicates battery charge level in percent
(double): (0.0=fully discharged, 100.0=fully charged).
batteryOverTemperature During charge, the over temp alarm can be set
(boolean): if the pack exceeds 45 C. The charger should
stop charging when the alarm is set. If charging
doesn't stop, the pack will open a resettable
protection FET.
During discharge, the over temp alarm will set
if the pack exceeds 60 C. The pack will set
the alarm bit, but if the temperature doesn't
decrease, the pack will open a resettable
protection FET and shut down the device.
batteryHardwareError True indicates the battery controller has detected
(boolean): an error in the battery hardware. False indicates
the battery hardware is operating normally.
RSA600A Series devices can also return a result from this function. However,
since they do not have an internal battery, they will always report the following
status:
externalPowerPresent = true
batteryPresent = false
70 API Reference
Spectrum functions
Spectrum functions
SPECTRUM_AcquireTrace Initiates a spectrum trace acquisition
Declaration: ReturnStatus SPECTRUM_AcquireTrace();
Return Values:
noError: The function has completed successfully.
errorNotConnected: The device is not connected.
Additional Detail: Executing this function initiates a spectrum trace acquisition. Before calling this
function, all acquisition parameters must be set to valid states. These include
Center Frequency, Reference Level, any desired Trigger conditions, and the
SPECTRUM configuration settings.
API Reference 71
Spectrum functions
72 API Reference
Spectrum functions
API Reference 73
Spectrum functions
74 API Reference
Spectrum functions
API Reference 75
Spectrum functions
SpectrumWindows Value
SpectrumWindow_Kaiser 0
SpectrumWindow_Mil6dB 1
SpectrumWindow_BlackmanHarris 2
SpectrumWindow_Rectangular 3
SpectrumWindow_FlatTop 4
SpectrumWindow_Hann 5
SpectrumVerticalUnits Value
SpectrumVerticalUnit_dBm 0
SpectrumVerticalUnit_Watt 1
SpectrumVerticalUnit_Volt 2
SpectrumVerticalUnit_Amp 3
SpectrumVerticalUnit_dBmV 4
Return Values:
noError: The function has completed successfully.
errorNotConnected: The device is not connected.
76 API Reference
Spectrum functions
API Reference 77
Time functions
Time functions
These functions support manipulation of data time and timestamp information based on the internal time/timestamp
association. The internal time association is automatically initialized when the instrument is connected, and aligned to the
current local time based on the Windows OS time function.
78 API Reference
Time functions
REFTIME_GetCurrentTime Returns the current RSA API system time (in second and nanoseconds
components), and the corresponding current timestamp value.
Declaration: ReturnStatus IQSTREAM_GetCurrentTime (time_t* o_timeSec, uint64_t*
o_timeNsec, uint64_t* o_timestamp);
Parameters:
o_timeSec: Pointer to time_t. Returns seconds component of current time. (Input NULL
argument value if return value not desired).
o_timeNsec: Pointer to uint64_t. Returns nanoseconds component of current time. (Input NULL
argument value if return value not desired).
o_timestamp: Pointer to uint64_t. Returns timestamp of current time. (Input NULL argument
value if return value not desired).
Return Values:
noError: The query was successful.
Additional Detail: The timeSec value is the number of seconds elapsed since midnight (00:00:00),
Jan 1, 1970, UTC. The timeNsec value is the number of nanoseconds into the
specified second. The time and timestamp values are accurately aligned with
each other at the time of the function call.
API Reference 79
Time functions
REFTIME_GetIntervalSinceRef- Returns the number of seconds that have elapsed since the internal RSA API
TimeSet time and timestamp association was set.
Declaration: ReturnStatus QSTREAM_GetIntervalSinceRefTimeSet (double* sec);
Parameters:
sec: Pointer to a double. Returns seconds since the internal Reference time/timestamp
association was last set.
Return Values:
noError: The query was successful.
REFTIME_GetTimeFromTimes- The input timestamp value is converted to equivalent second and nanosecond
tamp component values, using the current internal reference time/timestamp
association.
Declaration: ReturnStatus IQSTREAM_GetTimeFromTimestamp(uint64_t i_timestamp, time_t*
o_timeSec, uint64_t* o_timeNsec);
Parameters:
i_timestamp: Timestamp counter time to convert to time values.
o_timeSec: Pointer to time_t. Returns time value seconds component.
o_timeNsec: Pointer to uint64_t. Returns time value nanoseconds component.
Return Values:
noError: The query was successful.
Additional Detail: The timeSec value is the number of seconds elapsed since midnight (00:00:00),
Jan 1, 1970, UTC. The timeNsec value is the number of nanoseconds into the
specified second.
REFTIME_GetTimestampFrom- The input time specified by the second and nanosecond component values is
Time converted to the equivalent timestamp value, using the current internal reference
time/timestamp association.
Declaration: ReturnStatus IQSTREAM_GetTimestampFromTime (time_t i_timeSec, uint64_t
i_timeNsec, uint64_t* o_timestamp);
Parameters:
i_timeSec: Time-seconds component to convert to timestamp.
i_timeNsec: Time-nanoseconds component to convert to timestamp.
o_timestamp: Pointer to uint64_t. Returns equivalent timestamp value.
Return Values:
noError: The query was successful.
Additional Detail: The timeSec value is the number of seconds elapsed since midnight (00:00:00),
Jan 1, 1970, UTC. The timeNsec value is the number of nanoseconds into the
specified second.
80 API Reference
Time functions
REFTIME_GetTimestampRate Returns value of the clock rate of the continuously running timestamp counter
in the instrument.
Declaration: ReturnStatus IQSTREAM_GetTimestampRate(uint64_t* refTimestampRate);
Parameters:
refTimestampRate: Pointer to uint64_t. Returns timestamp counter clock rate.
Return Values:
noError: The query was successful.
Additional Detail: This function can be used for calculations on timestamp values.
API Reference 81
Tracking generator functions
82 API Reference
Tracking generator functions
API Reference 83
Trigger functions
Trigger functions
TRIG_ForceTrigger Forces the device to trigger.
Declaration: ReturnStatus TRIG_ForceTrigger();
Return Values:
noError: The operation completed successfully.
84 API Reference
Trigger functions
API Reference 85
Trigger functions
86 API Reference
Trigger functions
API Reference 87
Example Python program
88 API Reference
Example Python program
NOTE. Typically, Adobe Acrobat uses a paper clip icon to display attachments.
Other PDF file viewers may use other indicators for attachments. If needed, refer to the PDF viewers documentation.
API Reference 89
Streaming Sample Data File Format
Filename Extensions
Formatted files use a file extension of .r3f.
Raw files use a file extension of .r3a for the raw ADC sample data files, and .r3h for the configuration (header) info files.
90 API Reference
Streaming Sample Data File Format
Footers contain information about the samples in that frame. These include trigger indicators, frame counters and other
synchronization information. Footer information can be ignored if only the raw ADC data is needed.
API Reference 91
Streaming Sample Data File Format
In Framed file format, the header block is inserted at the beginning of the file, before the sample data content, which
also contains the USB transport framing. In Raw format, the entire header block is contained in a separate file from the
sample data.
Data in the header is encoded as either ASCII character strings or binary data, in fixed location fields. This is so that users
can access each item by indexing to the fixed location rather than requiring a parser like XML to interpret it.
The File Format value indicates the overall revision level of the file format.
NOTE. All strings are null-terminated (0x00 byte following the final string character). If in a fixed length field, the unused
portion of the field is filled with 0x00 byte values.
EOB means End-of-Block.
92 API Reference
Streaming Sample Data File Format
API Reference 93
Streaming Sample Data File Format
94 API Reference
RSA API version compatibility
NOTE. API version 1 functions are deprecated and will eventually be removed (not supported).
The RSA_API version_compatibility.xlsx attachment is a compatibility spreadsheet to map the old version 1 function
names to the new version 2 function names. The spreadsheet also indicates if the arguments or returns were modified
in addition to changing the name.
NOTE. Typically, Adobe Acrobat uses a paper clip icon to display attachments.
Other PDF file viewers may use other indicators for attachments. If needed, refer to the PDF viewers documentation.
API Reference 95
RSA API version compatibility
96 API Reference
Index
Index
A Configure functions D
Alignment functions CONFIG_GetAutoAttenuatio- Device functions
ALIGN_GetAlignment- nEnable, 9 DEVICE_Connect, 13
Needed, 2 CONFIG_GetCenterFreq, 7 DEVICE_Disconnect, 13
ALIGN_GetWarmupStatus, 2 CONFIG_GetExternalRefEn- DEVICE_GetAPIVersion, 15
ALIGN_RunAlignment, 2 able, 7 DEVICE_GetEnable, 13
API version compatibility, 95 CONFIG_GetExternalRefFre- DEVICE_GetErrorString, 13
Audio functions quency, 7 DEVICE_GetEventStatus, 19
AUDIO_GetData, 4 CONFIG_GetMaxCenter- DEVICE_GetFPGAVersion, 14
AUDIO_GetEnable, 3 Freq, 7 DEVICE_GetFWVersion, 14
AUDIO_GetFrequencyOff- CONFIG_GetMinCenter- DEVICE_GetHWVersion, 14
set, 3 Freq, 8 DEVICE_GetInfo, 15
AUDIO_GetMode, 4 CONFIG_GetRefer- DEVICE_GetNomencla-
AUDIO_GetMute, 4 enceLevel, 8 ture, 14
AUDIO_GetVolume, 5 CONFIG_GetRFAttenuator, 11 DEVICE_GetNomencla-
AUDIO_SetFrequencyOffset, 3 CONFIG_GetRFPreampEn- tureW, 14
AUDIO_SetMode, 5 able, 10 DEVICE_GetOverTempera-
AUDIO_SetMute, 5 CONFIG_Preset, 8 tureStatus, 16
AUDIO_SetVolume, 5 CONFIG_SetAutoAttenuatio- DEVICE_GetSerialNumber, 15
AUDIO_Start, 6 nEnable, 10 DEVICE_PrepareForRun, 15
AUDIO_Stop, 6 CONFIG_SetCenterFreq, 8 DEVICE_Reset, 16
CONFIG_SetExternalRefEn- DEVICE_Run, 16
able, 9 DEVICE_Search, 16
C CONFIG_SetRefer- DEVICE_SearchInt, 16
Compatibility enceLevel, 9 DEVICE_SearchIntW, 17
API version 1 to 2, 95 CONFIG_SetRFAttenuator, 12 DEVICE_SearchW, 16
CONFIG_SetRFPreampEn- DEVICE_StartFrameTrans-
able, 11 fer, 18
DEVICE_Stop, 18
API Reference 97
Index
DPX functions F I
DPX_Configure, 20 Function groups IF streaming functions
DPX_FinishFrameBuffer, 20 Alignment, 2 IFSTREAM_GetActiveSta-
DPX_GetEnable, 21 Audio, 3 tus, 39
DPX_GetFrameBuffer, 21 Configure, 7 IFSTREAM_SetDiskFile-
DPX_GetFrameInfo, 24 Device, 13 Count, 39
DPX_GetRBWRange, 24 DPX, 20 IFSTREAM_SetDiskFile-
DPX_GetSettings, 25 GNSS, 32 Length, 40
DPX_GetSogramHiRes- IF streaming, 37 IFSTREAM_SetDiskFile-
Line, 26 IQ block, 42 Mode, 40
DPX_GetSogramHiRes- IQ Streaming, 49 IFSTREAM_SetDiskFilename-
LineCountLatest, 26 Playback, 68 Base, 40
DPX_GetSogramHiResLine- Power, 70 IFSTREAM_SetDiskFilename-
Timestamp, 27 Spectrum, 71 Suffix, 38
DPX_GetSogramHiRes- Time, 78 IFSTREAM_SetDisk-
LineTriggered, 27 Tracking generator, 82 FilePath, 40
DPX_GetSogramSettings, 27 Trigger, 84 IFSTREAM_SetEnable, 41
DPX_IsFrameBufferAvail- IQ block functions
able, 28 IQBLK_AcquireIQData, 43
DPX_Reset, 28 G IQBLK_GetIQAcqInfo, 42
DPX_SetEnable, 28 GNSS functions IQBLK_GetIQBandwidth, 43
DPX_SetParameters, 29 GNSS_ClearNavMessage- IQBLK_GetIQData, 44
DPX_SetSogramParame- Data, 32 IQBLK_GetIQDataCplx, 45
ters, 30 GNSS_Get1PPSTimes- IQBLK_GetIQDataDeinter-
DPX_SetSogramTrace- tamp, 32 leaved, 46
Type, 30 GNSS_GetAntennaPower, 33 IQBLK_Ge-
DPX_SetSpectrumTrace- GNSS_GetEnable, 33 tIQRecordLength, 46
Type, 31 GNSS_GetHwInstalled, 33 IQBLK_GetIQSampleRate, 47
DPX_WaitForDataReady, 31 GNSS_GetNavMessage- IQBLK_GetMaxIQBand-
Data, 34 width, 47
GNSS_GetSatSystem, 34 IQBLK_GetMax-
GNSS_SetAntennaPower, 35 IQRecordLength, 47
GNSS_SetEnable, 35 IQBLK_GetMinIQBand-
GNSS_SetSatSystem, 36 width, 47
IQBLK_SetIQBandwidth, 48
IQBLK_Se-
tIQRecordLength, 48
IQBLK_WaitForIQ-
DataReady, 48
98 API Reference
Index
API Reference 99