Skip to main content

Delta Modulation & Demodulation


Delta Modulation & Demodulation Technique



Another name for delta modulation is a 1-bit quantizer. As a result, compared to PCM or DPCM, less bandwidth is needed here.


We know that bandwidth (BW),


BW = nfs/2 .........(1)




Where n = number of bits per sample


          fs = Frequency of Sampling





To avoid the cause of under-sampling, fs cannot be decreased in the above equation 1 to decrease bandwidth (BW). To retrieve the intended signal at the receiver side, we must keep our sample frequency at least two times the frequency of the message signal.



Alternatively, fs > 2fm



In this case, fm stands for message signal frequency, which is often the highest frequency available in message transmission.




However, in delta modulation, the bandwidth will be reduced to the smallest amount feasible by picking the lowest possible value of n, i.e. 1 bit/sample.


Assume that Rb = nfs is the data rate.


As a result, Rb = fs (if n=1 bit/sample)


So, in the delta modulation scheme, we can say,



Bit rate = Pulse rate = Sampling rate



Because we're only allocating 1 bit/sample, the number of levels is L = 2^(1) = 2. In general, the highest level is represented by '+∆', while the lowest level is represented by '-∆'. From the quantizer value we decide whether the sampling bit is '1' or '0'.










In delta modulation, we actually accomplish the following:



We compare the current sample value to the prior sample value in this modulation. When the difference (also known as "error") value exceeds the threshold value, the value is detected as "1." In the same way, if it goes below the threshold value, it will be '0'.







Diagram:











                                                                       Fig: Delta Modulation



Here, the input of the quantizer,


e(nTs) = m(nTs) – m^(nTs)


Where, m(nTs) = current sample

m^(nTs) = previous sample

The difference between the current sample value and the previous sample value (or, e(nTs)) is the quantizer's input. The modulated signal is represented as bit '1' if the difference value is greater than the threshold value (say, 0 Volt); otherwise, it is represented as bit '0'.


With the use of diagrams, we'll now discuss delta modulation (DM) and demodulation at the receiver side.



Delta Demodulation


Assume there are two levels (due to the one-bit quantizer) or that the quantizer step value is '+∆' and '–∆' on the negative side. '+∆' indicates a higher level, whereas '-∆' indicates a lower level.


Take a look at the quantizer diagram below. If the difference (or error value) between the current sample value and the prior sample value exceeds the threshold value, the sample will be converted to bit '1' (For your convenience, let's say, the threshold is 0 Volt). If the above-mentioned difference value is between 0 and + ∆ Volt, we convert it to bit '1'. Similarly, we translate to bit '0'  for values between 0 and - ∆ Volt.




Diagram of DM Quantizer:








DM Encoder:









DM Decoder at receiver side:








In decoding process, at t=0, sample value = 0

At, t = Ts, sample value = 0+∆ = +∆

      t = 2Ts, sample value = +∆ +∆ = +2∆

      t = 3Ts, sample value = +2∆ +∆ = +3∆

      t = 4Ts, sample value = +3∆ -∆ = +2∆

      t = 5Ts, sample value = +2∆ -∆ = +∆


Whenever the signal reaches the receiver it was 0, at t=0 & t< Ts; At t=Ts, we receive +∆. Now, the summation of the present sample value and previous sample value (which is '0' at the start) equals 0 +∆= +∆; At t=2Ts,  the sum of the current sample value and previous sample value = +∆ +∆ = +2∆ and so on (as shown in the above chart).

MATLAB Code for Delta Modulation and Demodulation

 
 
 

 
                                                                 (Get MATLAB Code)

Read also about

[1] MATLAB Code for Delta Modulation and Demodulation

People are good at skipping over material they already know!

View Related Topics to







Admin & Author: Salim

profile

  Website: www.salimwireless.com
  Interests: Signal Processing, Telecommunication, 5G Technology, Present & Future Wireless Technologies, Digital Signal Processing, Computer Networks, Millimeter Wave Band Channel, Web Development
  Seeking an opportunity in the Teaching or Electronics & Telecommunication domains.
  Possess M.Tech in Electronic Communication Systems.


Contact Us

Name

Email *

Message *

Popular Posts

BER vs SNR for M-ary QAM, M-ary PSK, QPSK, BPSK, ...

Modulation Constellation Diagrams BER vs. SNR BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ... What is Bit Error Rate (BER)? The abbreviation BER stands for bit error rate, which indicates how many corrupted bits are received (after the demodulation process) compared to the total number of bits sent in a communication process. It is defined as,  In mathematics, BER = (number of bits received in error / total number of transmitted bits)  On the other hand, SNR refers to the signal-to-noise power ratio. For ease of calculation, we commonly convert it to dB or decibels.   What is Signal the signal-to-noise ratio (SNR)? SNR = signal power/noise power (SNR is a ratio of signal power to noise power) SNR (in dB) = 10*log(signal power / noise power) [base 10] For instance, the SNR for a given communication system is 3dB. So, SNR (in ratio) = 10^{SNR (in dB) / 10} = 2 Therefore, in this instance, the s...

MATLAB code for BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ...

Modulation Constellation Diagrams BER vs. SNR MATLAB code for BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ...   MATLAB Script for  BER vs. SNR for M-QAM, M-PSK, QPSk, BPSK %Written by Salim Wireless %Visit www.salimwireless.com for study materials on wireless communication %or, if you want to learn how to code in MATLAB clc; clear; close all; % Parameters num_symbols = 1e5; % Number of symbols snr_db = -20:2:20; % Range of SNR values in dB % PSK and QAM orders to be tested psk_orders = [2, 4, 8, 16, 32]; qam_orders = [4, 16, 64, 256]; % Initialize BER arrays ber_psk_results = zeros(length(psk_orders), length(snr_db)); ber_qam_results = zeros(length(qam_orders), length(snr_db)); % BER calculation for each PSK order and SNR value for i = 1:length(psk_orders) psk_order = psk_orders(i); for j = 1:length(snr_db) % Generate random symbols data_symbols = randi([0, psk_order-1], 1, num_symb...

Theoretical BER vs SNR for BPSK

Let's simplify the explanation for the theoretical Bit Error Rate (BER) versus Signal-to-Noise Ratio (SNR) for Binary Phase Shift Keying (BPSK) in an Additive White Gaussian Noise (AWGN) channel.  Key Points Fig 1: Constellation Diagrams of BASK, BFSK, and BPSK [↗] BPSK Modulation: Transmits one of two signals: +√Eb ​ or -√Eb , where Eb​ is the energy per bit. These signals represent binary 0 and 1 . AWGN Channel: The channel adds Gaussian noise with zero mean and variance N0/2 (where N0 ​ is the noise power spectral density). Receiver Decision: The receiver decides if the received signal is closer to +√Eb​ (for bit 0) or -√Eb​ (for bit 1) . Bit Error Rate (BER) The probability of error (BER) for BPSK is given by a function called the Q-function. The Q-function Q(x) measures the tail probability of the normal distribution, i.e., the probability that a Gaussian random variable exceeds a certain value x.  Formula for BER: BER=Q(...

Constellation Diagrams of ASK, PSK, and FSK

Modulation ASK, FSK & PSK Constellation BASK (Binary ASK) Modulation: Transmits one of two signals: 0 or -√Eb, where Eb​ is the energy per bit. These signals represent binary 0 and 1.  BFSK (Binary FSK) Modulation: Transmits one of two signals: +√Eb​ ( On the y-axis, the phase shift of 90 degrees with respect to the x-axis, which is also termed phase offset ) or √Eb (on x-axis), where Eb​ is the energy per bit. These signals represent binary 0 and 1.  BPSK (Binary PSK) Modulation: Transmits one of two signals: +√Eb​ or -√Eb (they differ by 180 degree phase shift), where Eb​ is the energy per bit. These signals represent binary 0 and 1.  This article will primarily discuss constellation diagrams, as well as what constellation diagrams tell us and the significance of constellation diagrams. Constellation diagrams can often demonstrate how the amplitude and phase of signals or symbols differ. These two characteristics lessen the interference between t...

Theoretical and simulated BER vs. SNR for ASK, FSK, and PSK

  BER vs. SNR denotes how many bits in error are received in a communication process for a particular Signal-to-noise (SNR) ratio. In most cases, SNR is measured in decibel (dB). For a typical communication system, a signal is often affected by two types of noises 1. Additive White Gaussian Noise (AWGN) 2. Rayleigh Fading In the case of additive white Gaussian noise (AWGN), random magnitude is added to the transmitted signal. On the other hand, Rayleigh fading (due to multipath) attenuates the different frequency components of a signal differently. A good signal-to-noise ratio tries to mitigate the effect of noise.  Calculate BER for Binary ASK Modulation The theoretical BER for binary ASK (BASK) in an AWGN channel is given by: BER  = (1/2) * erfc(0.5 * sqrt(SNR_ask));   Enter SNR (dB): Calculate BER BER vs. SNR curves for ASK, FSK, and PSK Calculate BER for Binary FSK Modulation The theoretical BER for binary FSK (BFSK) in a...

OFDM in MATLAB

  MATLAB Script % The code is written by SalimWireless.Com 1. Initialization clc; clear all; close all; 2. Generate Random Bits % Generate random bits numBits = 100; bits = randi([0, 1], 1, numBits); 3. Define Parameters % Define parameters numSubcarriers = 4; % Number of subcarriers numPilotSymbols = 3; % Number of pilot symbols cpLength = ceil(numBits / 4); % Length of cyclic prefix (one-fourth of the data length) 4. Add Cyclic Prefix % Add cyclic prefix dataWithCP = [bits(end - cpLength + 1:end), bits]; 5. Insert Pilot Symbols % Insert pilot symbols pilotSymbols = ones(1, numPilotSymbols); % Example pilot symbols (could be any pattern) dataWithPilots = [pilotSymbols, dataWithCP];   6. Perform OFDM Modulation (IFFT) % Perform OFDM modulation (IFFT) dataMatrix = reshape(dataWithPilots, numSubcarriers, []); ofdmSignal = ifft(dataMatrix, numSubcarriers); ofdmSignal = reshape(ofdmSignal, 1, []); 7. Display the Generated Data % Display the generated data disp("Original Bits:"); ...

Why is Time-bandwidth Product Important?

Time-Bandwidth Product (TBP) The time-bandwidth product (TBP) is defined as: TBP = Δ f ⋅ Δ t Δf (Bandwidth) : The frequency bandwidth of the signal, representing the range of frequencies over which the signal is spread. Δt (Time duration) : The duration for which the signal is significant, i.e., the time interval during which the signal is non-zero. The TBP is a measure of the "spread" of the signal in both time and frequency domains. A higher TBP means the signal is both spread over a larger time period and occupies a wider frequency range.     To calculate the period of a signal with finite bandwidth, Heisenberg’s uncertainty principle plays a vital role where the time-bandwidth product indicates the processing gain of the signal. We apply spread spectrum techniques in wireless communication for various reasons, such as interference resili...