Ideal receiver for BLE PHY waveform
Download Required: To use bleIdealReceiver, first download Communications Toolbox™ Library for the Bluetooth® Protocol. For more information, see Get and Manage Add-Ons (MATLAB). Alternatively, see Communications Toolbox Library for the Bluetooth Protocol File Exchange.
Create an input message column vector of length 1000 containing random binary values. Generate a BLE transmit waveform from the transmission bits by using the
txBits = randi([0 1],1000,1); txWaveform = bleWaveformGenerator(txBits);
Pass the transmit waveform through a noisy channel and obtain the received waveform.
snr = 30; % specified in dB rxWaveform = awgn(txWaveform,snr);
Recover data bits from the received BLE waveform using
bleIdealReceiver. Check for the number of bit errors in the recovered bits. The returned value indicates that the BLE waveform was successfully decoded.
[rxBits,accessAddr] = bleIdealReceiver(rxWaveform); numErr = biterr(txBits,rxBits)
numErr = 0
Specify the values of PHY generating mode, channel index and samples per symbol (sps).
phyMode = 'LE125K'; chanIndex = 2; sps = 4;
Generate transmission bits containing random binary values. Obtain the BLE transmit waveform from the transmission bits and the specified name-value pairs using the
txBits = randi([0 1],100,1); txWaveform = bleWaveformGenerator(txBits,'Mode',phyMode,... 'SamplesPerSymbol',sps,'ChannelIndex',chanIndex);
Recover the data bits, and then compare them with the transmission bits. The result indicates that the transmission bits match the recovered data bits, meaning the BLE waveform was successfuly decoded.
rxBits = bleIdealReceiver(txWaveform,'Mode',phyMode,... 'SamplesPerSymbol',sps,'ChannelIndex',chanIndex); isequal(txBits,rxBits)
ans = logical 1
waveform— Received time-domain signal
Received time-domain signal, specified as a complex-valued signal with size
Ns represents the number of received
samples. The values of Ns depend on the
name-value pairs, according to the constraints specified in this table. For example, if
the value of
'LE1M' and the value of
'SamplesPerSymbol' is 4 then the value of
Ns must be greater than or equal to 160 and
a multiple of
|Value of ||Value of Ns||Multiple of|
comma-separated pairs of
the argument name and
Value is the corresponding value.
Name must appear inside quotes. You can specify several name and value
pair arguments in any order as
'Mode'— PHY transmission mode
PHY transmission mode, specified as the comma-separated pair consisting of
'LE125K'. This value indicates
the type of PHY used to decode the received BLE waveform.
'ChannelIndex'— Channel Index
37(default) | integer in the range [0, 39]
Channel index, specified as the comma-separated pair consisting of
'ChannelIndex' and an integer in the range [0, 39]. For data
channels, this value must be in the range [0, 36]. For advertising channels, this
value must be in the range [37, 39]. This value is used by the data-dewhitening
'SamplesPerSymbol'— Samples per symbol
8(default) | positive integer
Samples per symbol, specified as the comma-separated pair consisting of
'SamplesPerSymbol' and a positive integer. This value is used for
the Gaussian frequency shift keying (GFSK) modulation.
bits— Payload bits
Payload bits, returned as a column vector of maximum length 260 bytes. This output represents the recovered information bits.
accessAddr— Access address information
Access address information, returned as a 32-bit column vector. This output is used by the higher layers for validating a packet.
 Bluetooth Hompage. https://www.bluetooth.com/.
 Bluetooth Special Interest Group (SIG). "Bluetooth Core Specification." Version 5.0.