comm.SDRuTransmitter
Send data to USRP device
Add-On Required: This feature requires the Communications Toolbox Support Package for USRP Radio add-on.
Description
The comm.SDRuTransmitter
System object™ sends data to a USRP™ radio, enabling simulation and development for various software-defined radio
applications; for USRP
N3xx series and X series radios, see the Wireless Testbench™ documentation.
Use this object to communicate with a USRP radio on the same Ethernet subnetwork or via a USB connection. You can write a MATLAB® application that uses the System object, or generate code for the System object without connecting to a USRP radio.
This object accepts a column vector or matrix input signal from MATLAB and transmits signal and control data to a USRP radio using the universal hardware driver (UHD™) from Ettus Research™. The System object is a sink that sends the data it receives to a USRP radio.
To send data from a USRP radio device:
Create the
comm.SDRuTransmitter
object and set its properties.Call the object as if it were a function.
To learn more about how System objects work, see What Are System Objects?.
Note
Starting in R2024a, the MathWorks® products and support packages you require to use this System object depend on your radio device.
Radio Device | Required MathWorks Products | Support Package Installation |
---|---|---|
USRP2™ USRP N200, N210 USRP B200, B210 | Communications Toolbox™ Support Package for USRP Radio | Install Communications Toolbox Support Package for USRP Radio |
USRP N300, N310, N320, N321 USRP X300, X310 | Wireless Testbench Wireless Testbench Support Package for NI™ USRP Radios | Install Support Package for NI USRP Radios (Wireless Testbench) |
For details on how to use this System object with a radio device supported by Wireless Testbench Support Package for NI
USRP Radios, see comm.SDRuTransmitter
(Wireless Testbench).
Creation
Syntax
Description
creates a default
SDRu transmitter System object. tx
= comm.SDRuTransmitter
sets the tx
= comm.SDRuTransmitter(address
)IPAddress
property to the address of the connected USRP device.
sets Properties
using one or more name-value pairs in addition to any input argument combination from
previous syntaxes. For example, tx
= comm.SDRuTransmitter(___,Name
= Value
)CenterFrequency
=
5e6
specifies the center frequency as 5 MHz.
Properties
Unless otherwise indicated, properties are nontunable, which means you cannot change their
values after calling the object. Objects lock when you call them, and the
release
function unlocks them.
If a property is tunable, you can change its value at any time.
For more information on changing property values, see System Design in MATLAB Using System Objects.
Connection PropertiesPlatform
— Model number of radio
"N200/N210/USRP2"
(default) | "B200"
| "B210"
Model number of the radio, specified as one of these values.
"N200/N210/USRP2"
"B200"
"B210"
Data Types: char
| string
IPAddress
— IP address of USRP device
"192.168.10.2"
(default) | character vector | string scalar
IP address of the USRP radio, specified as a character vector or string scalar containing dotted-quad values. When you specify more than one IP address, you must separate each address using commas or spaces.
This value must match the physical IP address of the radio device assigned during hardware setup. For more information, see Guided USRP Radio Support Package Hardware Setup. If you configure the radio device with an IP address other than the default, update this property accordingly.
To find the logical network location of all connected USRP radios, use the findsdru
function.
Example: "192.168.10.2, 192.168.10.5"
or "192.168.10.2
192.168.10.5"
specifies IP addresses for two radio devices.
Dependencies
To enable this property, set Platform
to "N200/N210/USRP2"
.
Data Types: char
| string
SerialNum
— Serial number of radio
character vector | string scalar
Serial number of the radio hardware, specified as a character vector or string scalar.
This property must match the serial number of the radio hardware assigned during hardware setup. For more information, see Guided USRP Radio Support Package Hardware Setup. If you configure the radio hardware with a serial number other than the default, update this property accordingly.
Dependencies
To enable this property, set Platform
to "B200"
or "B210"
.
Data Types: char
| string
ChannelMapping
— Channel mapping for radio or bundled radios
1
(default) | positive scalar | row vector of positive values
Channel mapping for the radio or bundled radios, specified as a positive scalar or a row vector of positive values. This table shows the valid values for each radio platform.
Platform Property Value |
ChannelMapping Property Value |
---|---|
| 1-by-N row vector, where N is
the number of IP addresses in the |
|
|
|
|
When IPAddress
contains multiple IP addresses, the
channels defined by ChannelMapping
are ordered first by the order
in which the IP addresses appear in the list and then by the channel order within the
same radio.
For example, if the Platform
is
"N210"
and IPAddress
is
"192.168.20.2, 192.168.10.3"
, then the
ChannelMapping
must be [1 2]
. Channel 1 of the
bundled radio refer to channel 1 of the radio with IP address 192.168.20.2. Channel 2 of
the bundled radio refer to channel 1 of the radio with IP address 192.168.10.3.
Data Types: double
CenterFrequency
— Center frequency
2.45e9
| nonnegative scalar | row vector of nonnegative values
Center frequency in Hz, specified as a nonnegative scalar or a row vector of nonnegative values. The valid range of values for this property depends on the RF daughter card of the USRP device.
Specify the center frequency value according to these conditions.
For a single-input single output (SISO) configuration, specify the value for the center frequency as a nonnegative scalar.
For multiple-input multiple output (MIMO) configurations that use the same center frequency, specify the center frequency as a nonnegative scalar. The object sets the center frequency for each channel by using scalar expansion.
For MIMO configurations that use different center frequencies, specify the values in a row vector (for example,
[70e6 100e6]
). The object applies the ith element of the vector to the ith channel that you specify in theChannelMapping
property.Note
For a MIMO scenario, the center frequency for a B210 radio must be a scalar. You cannot specify the frequencies as a vector.
Tunable: Yes
Data Types: double
LocalOscillatorOffset
— Local oscillator (LO) offset frequency
0
(default) | scalar | row vector
LO offset frequency in Hz, specified as a scalar or row vector. The valid range of this property depends on the RF daughterboard of the USRP device.
The LO offset does not affect the transmitted center frequency. However, the LO offset does affect the intermediate center frequency in the USRP radio, as shown in the diagram.
In this diagram:
f center is the center frequency that you set in the System object.
f LO offset is the LO offset frequency.
Use this property to move the center frequency away from interference or harmonics generated by the USRP radio.
To change the LO offset, specify the value according to these conditions.
For a SISO configuration, specify the LO offset as a scalar.
For MIMO configurations, the LO offset must be zero. This restriction is due to a UHD limitation. In this case, you can specify the LO offset as 0.
Tunable: Yes
Data Types: double
Gain
— Overall gain for USRP radio transmitter data path
8
(default) | scalar | row vector
Overall gain in dB for the USRP radio receiver data path, including analog and digital components, specified as a scalar or row vector. The valid range of this property depends on the RF daughterboard of the USRP device.
Specify the gain according to these conditions.
For a SISO configuration, specify the gain as a scalar.
For MIMO configurations that use the same gain value, specify the gain as a scalar. The gain is set by scalar expansion.
For MIMO configurations that use different gains, specify the values in a row vector (for example,
[32 30]
). The object applies the ith element of the vector to the ith channel that you specify in theChannelMapping
property.
Tunable: Yes
Data Types: double
PPSSource
— PPS signal source
"Internal"
(default) | "External"
| "GPSDO"
Pulse per second (PPS) signal source, specified one of these values.
"Internal"
— Use the internal PPS signal of the USRP radio."External"
— Use the PPS signal from an external signal generator."GPSDO"
— Use the PPS signal from a global positioning system disciplined oscillator (GPSDO).
To synchronize the time for all the channels of the bundled radios, you can:
Provide a common external PPS signal to all of the bundled radios and set this property to
"External"
.Use the PPS signal from each GPSDO that is available on the USRP radio by setting this property to
"GPSDO"
.
To get the lock
status of the GPSDO to the GPS constellation, set this property to
"GPSDO"
and use the gpsLockedStatus
function.
Data Types: char
| string
EnforceGPSTimeSync
— Option to enforce GPS time synchronization
false
or 0
(default) | true
or 1
Option to enforce GPS time synchronization, specified as one of these values.
1
(true
) — Synchronize the USRP radio time to the valid global positioning system (GPS) time if the GPSDO is locked to the GPS constellation at the beginning of the transmit or receive operation.0
(false
) — Set the USRP radio time to the GPSDO time if the GPSDO is not locked to the GPS constellation at the beginning of the transmit or receive operation.
Each time you call the System object, it checks the lock status of the GPSDO. When the GPSDO is locked to the GPS constellation, the System object sets the USRP radio time to the valid GPS time.
Dependencies
To enable this property, set the PPSSource
property to
"GPSDO"
.
Data Types: logical
ClockSource
— Clock source
"Internal"
(default) | "External"
| "GPSDO"
Clock source, specified as one of these values.
"Internal"
— Use the internal clock signal of the USRP radio."External"
— Use the 10 MHz clock signal from an external clock generator."GPSDO"
— Use the 10 MHz clock signal from a GPSDO.
For B-series radios, the external clock port has the label 10 MHz.For N2xx series and USRP2 radios, the external clock port has the label REF IN.
To synchronize the frequency for all the channels of the bundled radios, you can:
Provide a common external 10 MHz clock signal to all of the bundled radios and set this property to
"External"
.Provide a 10 MHz clock signal from each GPSDO to the corresponding radio and set this property to
"GPSDO"
.
To synchronize the frequency for all channels, set this property to "GPSDO"
and then verify that the outputs of the referenceLockedStatus
and gpsLockedStatus
functions both return an output of
1
.
Data Types: char
| string
MasterClockRate
— Master clock rate
positive scalar
Master clock rate in Hz, specified as a positive scalar. The master clock rate is the analog to digital (A/D) and digital to analog (D/A) clock rate. The valid range of values for this property depends on the connected radio platform.
Platform Property Value | MasterClockRate Property
Value (in Hz) |
---|---|
|
|
| Scalar in the range from
When you use a B210 radio with multiple channels, the clock rate must be less than or equal to 30.72e6. This restriction is a hardware limitation for two-channel operations on B210 radios. The default value is
|
Data Types: double
InterpolationFactor
— Interpolation factor for SDRu transmitter
512
(default) | integer in the range [1,1024]
Interpolation factor for the SDRu transmitter, specified as an integer in the range
[1,1024]
with restrictions that depend on the radio you use.
InterpolationFactor Property Value | B-Series | N2xx-Series |
---|---|---|
| Valid | Not valid |
| Valid | Valid only when you set the |
| Valid | Not valid |
Odd integer from 4 to 128 | Valid | Valid |
Even integer from 4 to 128 | Valid | Valid |
Even integer from 128 to 256 | Valid | Valid |
Integer multiple of 4 from 256 to 512 | Valid | Valid |
Integer multiple of 8 from 512 to 1024 | Not valid | Not valid |
The radio uses the interpolation factor when it upconverts the complex baseband signal to an intermediate frequency (IF) signal.
Data Types: double
EnableTimeTrigger
— Option to enable timed transmission and reception
0
or false
(default) | 1
or true
Option to enable timed transmission and reception, specified as a numeric or logical
value of 1
(true
) or 0
(false
). When you set this property to 1
(true
), you can:
Transmit or receive after the time specified in the
TriggerTime
property.Transmit or receive at the specified GPS time in the
TriggerTime
property if you set thePPSSource
property to"GPSDO"
.Simultaneously transmit and receive after the time specified in the
TriggerTime
property.
Data Types: logical
TriggerTime
— Trigger time in seconds
5
(default) | nonnegative scalar
Trigger time in seconds, specified as a nonnegative scalar. Specify the trigger time
after which the radio starts transmitting or receiving data. The
TriggerTime
value must be greater than the current USRP radio time. Use the getRadioTime
function to get the current USRP radio time.
Note
After you call the getRadioTime
function, call the System
object before releasing it to ensure that the object is released properly.
When you set the PPSSource
property to
"GPSDO"
, specify the TriggerTime
property
as the exact GPS time in seconds at which you want the radio to start transmitting or
receiving data.
Note
For AD936x-based USRP B2xx series radios, you can expect a consistent delay between the specified trigger time and the start of transmission or reception.
Dependencies
To enable this property, set the EnableTriggerTime
property
to true
.
Data Types: double
EnableMIMOCableSync
— Option to enable MIMO cable synchronization
0
or false
(default) | 1
or true
Since R2024b
Option to enable MIMO cable synchronization, specified as a numeric or logical value
of 1
(true
) or 0
(false
). When you set this property to 1
(true
), you can:
Synchronize two USRP N200/N210 radios.
Transmit or receive frequency, phase, and time synchronized data across multiple channels.
Share Ethernet across two N200/N210 USRP radios.
To build larger MIMO systems, up to 16 x 16, set the PPSSource
and ClockSource
property to either "External"
or
"GPSDO"
.
Dependencies
To enable this property, set the Platform
to
"N200/N210/USRP2"
.
Data Types: logical
TransportDataType
— Transport data type
"int16"
(default) | "int8"
Transport data type, specified as one of these values:
"int16"
— Use 16-bit transport to achieve higher precision."int8"
— Use 8-bit transport to achieve a transport data rate that is approximately two times faster than 16-bit transport. The quantization step is 256 times larger than 16-bit transport.
The default transport data type assigns the first 16 bits to the in-phase (I) component and the remaining 16 bits to the quadrature (Q) component, resulting in 32 bits for each complex sample of transport data.
Data Types: char
| string
EnableBurstMode
— Option to enable burst mode
0
or false
(default) | 1
or true
Option to enable burst mode, specified as a numeric or logical
value of 1
(true
) or
0
(false
). To produce a set
of contiguous frames without an overrun or underrun to the radio,
set this property to 1
(true
).
Enable burst mode to simulate models that cannot run in real
time.
When you enable burst mode, specify the number of frames in a burst by using the
NumFramesInBurst
property. For more information, see Detect Underruns and Overruns.
Data Types: logical
NumFramesInBurst
— Number of frames in contiguous burst
1
(default) | nonnegative integer
Number of frames in a contiguous burst, specified as a nonnegative integer.
Dependencies
To enable this property, set EnableBurstMode
to
1
(true
).
Data Types: double
Usage
Description
Input Arguments
data
— Data to transmit
complex column vector | complex matrix
Data to transmit, specified as a complex column vector or complex matrix. The number of columns in the matrix depends on the number of channels in use, which you specify in the property. For a single-channel radio, this input must be a column vector. For a multichannel radio, this input must be a matrix. Each column in this matrix corresponds to complex data sent on one channel.
The complex data in the transmitted signal must be one of these data types:
16-bit signed integers — Complex values in the range [–32768, 32767]
Single-precision floating point — Complex values in the range [–1, 1]
Double-precision floating point — Complex values in the range [–1, 1]
Data Types: double
| single
| int16
Complex Number Support: Yes
Output Arguments
underrun
— Data discontinuity flag
0
| 1
Data discontinuity flag, returned as one of these values.
0
— The object does not detect underrun.1
— The object detects an underrun. The input data does not represent contiguous data from the host to the USRP radio.
Although the value of this output does not represent the actual number of packets dropped, as this value increases, the farther your execution of the object is from achieving real-time performance. You can use this value as a diagnostic tool to determine real-time execution of the object. For more information, see Detect Underruns and Overruns.
Data Types: uint32
Object Functions
To use an object function, specify the
System object as the first input argument. For
example, to release system resources of a System object named obj
, use
this syntax:
release(obj)
Specific to comm.SDRuTransmitter
info | Current USRP radio settings |
referenceLockedStatus | Lock status of USRP radio to 10 MHz clock signal |
gpsLockedStatus | Lock status of GPSDO to GPS constellation |
getRadioTime | Get current USRP radio time |
Examples
Transmit Signals with B210 Radio and SDRu Transmitter System Object
Configure a B210 radio with serial number 30F59A1
. Set the radio to transmit at 2.5 GHz with an interpolation factor of 256.
Create an SDRu Transmitter System object for data transmission.
tx = comm.SDRuTransmitter(... Platform = "B210", ... SerialNum = "30F59A1", ... CenterFrequency = 2.5e9, ... InterpolationFactor = 256);
Create a DPSK modulator as the data source using comm.DPSKModulator
System object. Inside a for-
loop, transmit the data using the tx
System object.
mod = comm.DPSKModulator(BitInput = true); for counter = 1:20 data = randi([0 1],30,1); modSignal = mod(data); tx(modSignal); end
Get B210 Radio Information
Use the info
object function to get information from a connected B210 radio. The function shows the actual values for the radio. These values can vary slightly from the values specified in the object.
radio = comm.SDRuTransmitter(Platform ="B210",SerialNum ="31B92DD"); radio.CenterFrequency = 912.3456e6; radio.LocalOscillatorOffset = 1000; radio.Gain = 8.3; radio.MasterClockRate = 10.56789e6; radio.InterpolationFactor = 510; info(radio)
ans = struct with fields:
Mboard: 'B210'
RXSubdev: 'FE-RX2'
TXSubdev: 'FE-TX2'
MinimumCenterFrequency: 4.4716e+07
MaximumCenterFrequency: 6.0053e+09
MinimumGain: 0
MaximumGain: 89.7500
GainStep: 0.2500
CenterFrequency: 9.1235e+08
LocalOscillatorOffset: -999.7189
Gain: 8.2500
MasterClockRate: 1.0568e+07
InterpolationFactor: 512
BasebandSampleRate: 2.0640e+04
Detect Lost Samples using SDRuTransmitter System Object
Configure an B210 radio with serial number 30F59A1
. Set the radio to transmit at 2.5 GHz with an interpolation factor of 125 and master clock rate of 56 MHz.
Create an SDRu Transmitter System object for data transmission.
tx = comm.SDRuTransmitter(... Platform = "B210", ... SerialNum = "30F59A1", ... CenterFrequency = 2.5e9, ... InterpolationFactor = 125, ... MasterClockRate = 56e6);
Create a DPSK modulator as the data source using comm.DPSKModulator
System object.
modulator = comm.DPSKModulator(BitInput = true);
Inside a for-
loop, transmit the data using the tx
System object and return underrun
output argument. Display messages when the transmitter indicates an underrun with data loss.
for frame = 1:20000 data = randi([0 1], 30, 1); modSignal = modulator(data); underrun = tx(modSignal); if underrun~=0 msg = ['Underrun detected in frame # ', int2str(frame)]; end end release(tx)
Burst-Mode Buffering to Overcome Underruns at Transmitter
Configure a B200 radio with serial number set to 30FD838
. Set the radio to transmit at 2.5 GHz with an interpolation factor of 125 and master clock rate of 56 MHz. Enable burst-mode buffering to overcome underruns. Set the number of frames in a burst to 20.
Create an SDRu Transmitter System object for data transmission.
tx = comm.SDRuTransmitter(... Platform = "B200", ... SerialNum = "30FD838", ... CenterFrequency = 2.5e9, ... InterpolationFactor = 125, ... MasterClockRate = 56e6); tx.EnableBurstMode = true; tx.NumFramesInBurst = 20;
Create a DPSK modulator as the data source using comm.DPSKModulator
System object.
modulator = comm.DPSKModulator(BitInput = true); data = randi([0 1],37500,1); modSignal = modulator(data);
Inside a for
loop, transmit the data using the tx
System object.
numFrames = 100; for frame = 1:numFrames underrun = tx(modSignal); end
no tx ack
release(tx)
Transmit Signal at GPS Trigger Time Using SDRU Transmitter System Object
This example shows how to transmit a signal at GPS trigger time using a USRP™ radio.
Generate a sine wave with a frequency of 30 kHz.
sinewave = dsp.SineWave(1,30e3);
sinewave.SampleRate = 100e6/100;
sinewave.SamplesPerFrame = 1e4;
sinewave.OutputDataType = 'double';
sinewave.ComplexOutput = true;
data = sinewave();
Create an SDRu transmitter System object tx
to transmit the sine wave. Set the serial number to 3136D5F. To transmit the signal at the GPS time, set the PPS signal source to the PPS signal from a GPSDO, clock source to GPSDO, and enable GPS time synchronization.
Fs = 15e6; % Sample Rate interpDecim = 2; % Interpolation or Decimation factor of interest masterClkRate = interpDecim*Fs; % Master clock rate txGain = 45; txChannelMapping = 1; tx = comm.SDRuTransmitter(Platform = "B210", SerialNum='3136D5F', ... PPSSource = "GPSDO", EnforceGPSTimeSync=true, ... ClockSource= "GPSDO", MasterClockRate=masterClkRate,... InterpolationFactor=interpDecim, ChannelMapping=txChannelMapping,... Gain=txGain, CenterFrequency=3.21e9);
To enable the transmitter to start transmitting at the GPS time, set the EnableTimeTrigger
to 1
or true
. Add a time delay to the GPS trigger time.
time_now = datetime('now'); trigger_time = time_now + hours(0) + minutes(0) + seconds(10); % Provide the time delay trigger_time
trigger_time = datetime
20-Jun-2023 17:15:09
trigger_time.TimeZone = 'Asia/Calcutta'; usrp_trigger_time = posixtime(trigger_time); % Provide as input to trigger time tx.EnableTimeTrigger = true; tx.TriggerTime = usrp_trigger_time;
Transmit the signal.
numFrames = 100; for i=1:numFrames txdata = data; underrun = tx(txdata); end
USRP time synchronized to GPS time
Release the transmitter System object.
release(tx);
FMCW Radar Waveform Based Range Calculation Using Time Trigger
This example shows how to use time triggering with a B210 radio to calculate the range of a target using frequency-modulated continuous wave (FMCW) radar waveform.
Generate FMCW radar waveform
Set the sample rate, interpolation factor or decimation factor, and master clock rate.
Fs = 30e6; % Sample Rate interpDecim = 1; % Interpolation or Decimation factor of interest masterClkRate = interpDecim*Fs; % Master clock rate
Set the sweep time and sweep bandwidth. Divide the sweep bandwidth by the sweep time to obtain the slope.
% Specify sweep time and sweep bandwidth
sweepTime = 1e-3;
sweepBW = 15e6;
slope = sweepBW/sweepTime;
Use the bw2rangeres
(Phased Array System Toolbox) function to calculate the range resolution corresponding to the signal bandwidth and the time2range
(Phased Array System Toolbox) function to calculate the maximum range the signal propagates during sweepTime/6
seconds.
% Calculate the range resolution and maximum range rangeRes = bw2rangeres(sweepBW); fprintf('Range resolution = %d',rangeRes)
Range resolution = 9.993082e+00
maxRange = time2range(sweepTime/6);
fprintf('Maximum range = %d',maxRange)
Maximum range = 2.498270e+04
Create a phased.FMCWWaveform
(Phased Array System Toolbox) object.
hwav = phased.FMCWWaveform(SampleRate=Fs, SweepTime=sweepTime,... SweepBandwidth=sweepBW, OutputFormat='Sweeps', NumSweeps=1);
Generate the FMCW radar waveform.
xRef = hwav(); NumSamps = length(xRef);
Set Transmitter Properties
Create a comm.SDRuTransmitter
object.
txGain = 45; txChannelMapping = 1; tx = comm.SDRuTransmitter(Platform = "B210", SerialNum='3136D5F', ... PPSSource = "Internal", ... ClockSource= "Internal", ... MasterClockRate=masterClkRate,... InterpolationFactor=interpDecim,... ChannelMapping=txChannelMapping,... Gain=txGain, CenterFrequency=3.21e9);
Set the EnableTimeTrigger
property for the transmitter object as true
and set the desired trigger time for transmission.
% Provide trigger time
usrpTriggerTime = 12;
tx.EnableTimeTrigger = true;
tx.TriggerTime = usrpTriggerTime;
Set Receiver Properties
Create a comm.SDRuReceiver
object.
rxGain = 45; rxChannelMapping = 2; rx = comm.SDRuReceiver(Platform = "B210", SerialNum='3136D5F', ... PPSSource = "Internal", ... ClockSource= "Internal", ... MasterClockRate=masterClkRate,... DecimationFactor=interpDecim, ... SamplesPerFrame = NumSamps,... OutputDataType="double",... ChannelMapping=rxChannelMapping, Gain=rxGain,CenterFrequency=3.21e9);
Set the EnableTimeTrigger
property for the receiver object as true
and set the desired trigger time for reception.
rx.EnableTimeTrigger = true;
rx.TriggerTime = usrpTriggerTime; % Same as tx trigger time
Set Timescope and Spectrumscope properties
Set the spectrumAnalyzer
and timescope
properties.
decimfact = 4; spectrumScope1 = spectrumAnalyzer(SampleRate=Fs); spectrumScope2 = spectrumAnalyzer(SampleRate=Fs/decimfact); spectrumScope3 = spectrumAnalyzer(SampleRate=Fs/decimfact); spectrumScope2.PeakFinder.Enabled = true; spectrumScope3.PeakFinder.Enabled = true; % Set the number of frames you would like to process numFrames = 1; frameTime = NumSamps/Fs; timeSpan = numFrames*frameTime; timeScope = timescope(SampleRate=Fs, ... TimeSpanSource="property", ... TimeSpan = timeSpan, ... LayoutDimensions=[2,1]);
Transmit and Receive FMCW Radar Waveform
Transmit the FMCW radar waveform and receive the reflected FMCW radar waveform from the target after the specified trigger time.
yBuff = zeros(numFrames*NumSamps,1); xRefBuff = zeros(numFrames*NumSamps,1); for i=1:numFrames txData = hwav(); underrun = tx(txData); if underrun==0 disp('Transmission successful') else disp('Transmission failed') end % Receive the signal [rxdata, ~,overflow, rx_time_stamp] = rx(); if overflow==0 disp('Reception successful') else disp('Reception failed') end yDechirp = dechirp(rxdata,txData); yBuff((i-1)*NumSamps+1:i*NumSamps,1) = yDechirp; xRefBuff((i-1)*NumSamps+1:i*NumSamps,1) = txData; spectrumScope1(txData) spectrumScope2(decimate(yDechirp,decimfact)) end
Transmission successful
Reception successful
Calculate the Range of the Target Based On the Beat Frequency
To calculate the beat frequency, use spectrum analyzer to find the peak frequency.
spectrumData1 = getMeasurementsData(spectrumScope2); beatFreq = spectrumData1.PeakFinder.Frequency(1); c = 3e8; % Speed of light beatFreqRange = beat2range(beatFreq,slope,c); fprintf('Range of the target based on beat frequency = %d',beatFreqRange)
Range of the target based on beat frequency = 8.056641e+02
timeScope(real(xRefBuff),real(yBuff));
Release the timescope, spectrumscope, transmitter and receiver System objects.
release(timeScope); release(spectrumScope1); release(spectrumScope2); release(rx); release(tx);
MIMO Cable Synchronization using N2xx Radios
Since R2024b
This example shows how to synchronize two N2xx series USRP™ radios using a MIMO cable for transmission and reception.
Connect two N2xx series radios using a MIMO cable. Connect the transmitter output to a power splitter and then connect each output of the splitter to the receive channels of the N2xx radios.
Run the transmitter_mimo.m
script in a different MATLAB® session to start transmission.
Set the sample rate and master clock rate.
radioFrontEndSampleRate = 1e6; radioMasterClockRate = 100e6;
Calculate the decimation factor by dividing the master clock rate by the sample rate.
decimationFactor = radioMasterClockRate/radioFrontEndSampleRate;
Set the frame length.
frameLength = 1e4;
Create a receiver System object.
rx = comm.SDRuReceiver(Platform = "N200/N210/USRP2",... IPAddress ="192.168.10.2,192.168.10.3",... CenterFrequency = 2e9,Gain = 30,... SamplesPerFrame = frameLength,... DecimationFactor = decimationFactor,... ChannelMapping = [1,2],... OutputDataType = "double");
Enable MIMO cable synchronization.
rx.EnableMIMOCableSync = true;
Set the frame duration.
frameDuration = frameLength /radioFrontEndSampleRate ;
Create a spectrumAnalyzer
System object to visualize the captured signal.
spectrumScope = spectrumAnalyzer(SampleRate = radioFrontEndSampleRate);
Create a timescope
System object to display the captured signal in time domain.
timeScope = timescope(TimeSpan = 4/10e3,SampleRate = radioFrontEndSampleRate); timeScope.YLimits=[-0.5, 0.5];
Receive the signal.
time = 0;
disp("Reception started");
Reception started
while time<10 recvData = rx(); % Compute cross-correlation [c, lags] = xcorr(recvData(:,2), recvData(:,1)); % Find the lag with maximum correlation [~, I] = max(abs(c)); timeOffset = lags(I)/radioFrontEndSampleRate; % Convert lag to time freqOfFirst = fft( recvData(:,1)); freqOfSecond = fft( recvData(:,2)); spectrumScope(recvData); timeScope(recvData); time = time+frameDuration; end
Release the receiver System object.
release(rx);
Generate MEX Function from MATLAB Function Using SDRu Transmitter System Object
This example shows how to generate a MEX file
called sdruTransmitMex
from the function
sdruTransmitData
. When you run this MEX file, the
code shows a performance improvement and no underruns for data frames
that contain 10000 samples.
Create a function that configures a
comm.SDRuTransmitter
System object. Generate a
sine wave of 100 kHz for transmission. The function calculates the
sample rate by using the master clock
rate and interpolation factor. Set the frame duration for the radio
to transmit sine wave based on the samples per frame and sample
rate. Display a message when transmission starts. Inside a
for
-loop, transmit the data using the
tx
System object and return the
underrun
as an output argument.
function[transmitTime,underrunCount] = sdruTransmitData() duration = 10; samplesPerFrame = 1e4; masterClockRate = 20e6; interpolationFactor = 1; sampleRate = masterClockRate/interp; frameDuration = samplesPerFrame/sampleRate; iterations = duration/frameDuration; sinGen = dsp.SineWave(Frequency =100e3, SampleRate = sampleRate, ... SamplesPerFrame = samplesPerFrame, ... ComplexOutput = true); data = sinGen(); tx = comm.SDRuTransmitter(Platform = "B210",SerialNum = "30F59A1", ... CenterFrequency = 2.45e9, ... MasterClockRate = masterClockRate, ... InterpolationFactor = interpolationFactor); tx(data); disp("Started Transmission..."); underrunCount = 0; tic for i = 1:iterations underrun = tx(data); if underrun underrunCount = underrunCount + 1; end end transmitTime = toc; release(tx); end
Generate a MEX file with the name
sdruTransmitMex
from the function
sdruTransmitData
.
codegen sdruTransmitData -o sdruTransmitMex;
Run this MEX file to transmit data using the generated MEX and observe the transmission time and number of underruns.
[transmitTime,underrunCount] = sdruTransmitMex()
More About
Single- and Multiple-Channel Output
USRP N200, N210, B200, and USRP2 radios support a single channel that you can use to:
Send data with the
comm.SDRuTransmitter
System object. Thecomm.SDRuTransmitter
System object transmits a column vector signal with a fixed length.Receive data with the
comm.SDRuReceiver
System object. Thecomm.SDRuReceiver
System object outputs a column vector signal with a fixed length.
USRP B210 radios support two channels that you can use to transmit and receive data with System objects. You can use both channels or a single channel (either channel 1 or 2).
The
comm.SDRuTransmitter
System object transmits a matrix signal, where each column is a channel of data of fixed length.The
comm.SDRuReceiver
System object outputs a matrix signal, where each column is a channel of data of fixed length.
You can set the CenterFrequency
,
LocalOscillatorOffset
, and Gain
properties
independently for each channel. Alternatively, you can apply the same setting to all
channels. All other System object property values apply to all channels.
For more information, see Single Channel Input and Output Operations and Multiple Channel Input and Output Operations.
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using MATLAB® Coder™.
Usage notes and limitations:
getRadioTime
System object method is not supported for code generation.
For more information on codegen
support to the
System objects, see System Objects in MATLAB Code Generation (MATLAB Coder).
For more information on MATLAB Compiler™ support to the System objects, see Acceleration and Deployment
Version History
Introduced in R2011bR2024b: Synchronize N2xx series USRP radios using shared MIMO cable
Bundle two N2xx series USRP radios using a MIMO cable to share the clock reference, timing reference, and
Ethernet interface. To synchronize multichannel transmission and reception using bundled
N2xx radios, use the EnableMIMOCableSync
property in the comm.SDRuTransmitter
and comm.SDRuReceiver
System objects in MATLAB.
R2024a: Support for N3xx and X3xx series radio devices moved to Wireless Testbench
Support for NI USRP N3xx and X3xx series radio devices has moved from Communications Toolbox Support Package for USRP Radio to Wireless Testbench Support Package for NI USRP Radios.
To configure these radios for use with Wireless Testbench, see Install Support Package for NI USRP Radios (Wireless Testbench).
R2023b: Enhanced support for time triggering in SDRu System objects
You can now specify trigger time to enable transmission and reception of data at a
specified time for a USRP radio. This property is available in the comm.SDRuTransmitter
and comm.SDRuReceiver
System objects.
R2022b: Reduced setup time for comm.SDRuTransmitter
The time required to initialize the comm.SDRuTransmitter
System Object™ is now about
17 seconds faster for B2xx radio and about 30 seconds faster for
N210 radios compared to R2022a release.
Simulation performance results for
comm.SDRuTransmitter
System Object:
Platform: B210
Frame time: 0.001 s
Release | Time Required to Set Center Frequency (s) | Time Required to Set Gain (s) | Time Required to Run System Object (s) | Total Time Required to Set Properties and Call System Object (s) |
R2022a | 9.108438 | 9.084412 | 8.614395 | ~26.8 |
R2022b | 0.002963 | 0.003463 | 8.705884 | ~8.71 |
The code execution was timed on a Windows® 10, Intel® Xeon® W-2133 CPU @ 3.60 GHz installed RAM 64.0 GB test system.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: United States.
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)