Hauptinhalt

capture

Capture RF data using SDRu receiver

Since R2023b

Add-On Required: This feature requires the Wireless Testbench™ Support Package for NI™ USRP™ Radios add-on.

Description

[data,metadata] = capture(rx,length) captures ceil(length) continuous data samples using the USRP™ radio hardware associated with a comm.SDRuReceiver System object™ rx. The function returns the captured data samples, data, and the capture-time configuration settings for the radio device, metadata.

example

[data,metadata] = capture(rx,length,unit) specifies the capture length unit, unit, in addition to the input arguments in the previous syntax. The function converts length units into N samples and returns ceil(N) samples.

example

[data,metadata,timestamp] = capture(rx,length,unit) returns the timestamp of each received sample from a USRP radio, timestamp, in addition to the output arguments in the previous syntaxes.

[data,metadata,timestamp] = capture(___,Filename=filename) saves the captured data and metadata to a baseband file reader file named filename.

Examples

collapse all

Create an SDRu receiver System object for your USRP radio. Set the master clock rate and center frequency.

rx = comm.SDRuReceiver(Platform='X310',IPAddress='192.168.10.2');

Set master clock rate and center frequency.

rx.MasterClockRate = 184.32e6;
rx.CenterFrequency = 2.4e9;

Capture 5 seconds of data.

[data,~] = capture(rx,5,'Seconds');

Release the hardware.

release(rx);

Input Arguments

collapse all

Receiver, specified as a comm.SDRuReceiver System object. The capture function uses this object to communicate with the USRP radio connected to the host computer.

Capture duration, specified as a positive scalar. Specify the unit of capture duration as samples or seconds using the unit input argument.

The maximum number of samples you can capture is 256e6. When you set the ChannelMapping property, the object restricts the number of samples per channel to equal fractions of 256e6 divided by the number of channels.

Data Types: double

Capture duration unit, specified as one of these values:

  • "Samples" — The function returns ceil(length) samples.

  • "Seconds" — The function converts length seconds into N samples based on the BasebandSampleRate property of the input receiver System object rx. The function returns ceil(N) samples.

File name for saving captured data and metadata, specified as a string scalar or character vector. Use this option to save the captured data and metadata to a baseband file. If the file name does not include an extension, the function appends the file name with .bb.

To read the baseband file, use the comm.BasebandFileReader System object.

Example: "rxdata.bb" or "rxdata"

Data Types: char | string

Output Arguments

collapse all

Output signal, returned as a complex-valued matrix. The number of columns in the matrix depends on the number of channels specified by the ChannelMapping property of the input receiver System object rx. Each column contains the complex data received on one channel. The number of rows is equal to the length of the received data.

The output signal supports complex values with these data types:

  • 8-bit signed integers — data is the raw 8-bit in-phase (I) and quadrature phase (Q) samples from the board.

  • 16-bit signed integers — data is the raw 16-bit I and Q samples from the USRP radio.

  • Single-precision floating point — data is the scaled output values in the range [–1, 1].

  • Double-precision floating point — data is the scaled output values in the range [–1, 1].

To specify the data type, use the OutputDataType property of the input receiver System object rx.

Data Types: int8 | int16 | single | double
Complex Number Support: Yes

Capture-time configuration settings of the radio device, returned as a structure containing these fields. The radio device is the USRP radio associated with the input receiver rx.

FieldDescription
Date

Date and time of the data capture.

DeviceName

Model number of the USRP radio device.

ChannelMapping

Channel mapping value of the radio device.

BasebandSampleRate

Baseband sample rate in Hz of the radio device.

CaptureLengthSamples

Capture length in samples.

CaptureLengthSeconds

Capture length in seconds.

CenterFrequency

Center frequency in Hz of the radio device.

GainSource

Gain source of the radio device, returned as either "Input Port" or "Property".

Gain

Gain value in dB of the radio device.

SDRuReceiverConfiguration

Structure than includes the property values and settings that describe the System object state of the input receiver rx.

Data Types: struct

Timestamp of each received sample, returned as a column vector. The length of this output equals the length of received data.

  • To get the GPS timestamp of each received sample from a USRP radio, set the PPSSource property of the input receiver System object rx to "GPSDO".

  • To get the timestamp of each received sample from bundled radios, set the PPSSource property of the input receiver System object rx to "GPSDO" or "External".

Version History

Introduced in R2023b

expand all