Generating Sinusoidal Signals

Slides:



Advertisements
Similar presentations
EE445S Real-Time Digital Signal Processing Lab Spring 2014 Lecture 15 Quadrature Amplitude Modulation (QAM) Transmitter Prof. Brian L. Evans Dept. of Electrical.
Advertisements

Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE445S Real-Time Digital Signal Processing Lab Spring.
Noise on Analog Systems
Lecture 3 Data Encoding and Signal Modulation
EE313 Linear Systems and Signals Fall 2010 Initial conversion of content to PowerPoint by Dr. Wade C. Schwartzkopf Prof. Brian L. Evans Dept. of Electrical.
EE313 Linear Systems and Signals Fall 2010 Initial conversion of content to PowerPoint by Dr. Wade C. Schwartzkopf Prof. Brian L. Evans Dept. of Electrical.
EE513 Audio Signals and Systems Digital Signal Processing (Systems) Kevin D. Donohue Electrical and Computer Engineering University of Kentucky.
Modulation, Demodulation and Coding Course
Lecture 1 Signals in the Time and Frequency Domains
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE345S Real-Time Digital Signal Processing Lab Spring.
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE345S Real-Time Digital Signal Processing Lab Fall.
Digital Communication I: Modulation and Coding Course
Digital Pulse Amplitude Modulation (PAM)
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE445S Real-Time Digital Signal Processing Lab Fall.
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE 382C-9 Embedded Software Systems Lecture 14 Communication.
EE345S Real-Time Digital Signal Processing Lab Fall 2006 Lecture 16 Quadrature Amplitude Modulation (QAM) Receiver Prof. Brian L. Evans Dept. of Electrical.
Interpolation and Pulse Shaping
Quadrature Amplitude Modulation (QAM) Transmitter
Signals and Systems Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE 382C-9 Embedded Software Systems.
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin Lecture 4 EE 345S Real-Time.
Chapter 6. Effect of Noise on Analog Communication Systems
Quiz 1 Review. Analog Synthesis Overview Sound is created by controlling electrical current within synthesizer, and amplifying result. Basic components:
EE 3220: Digital Communication
Generating Sinusoidal Signals Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE 445S Real-Time Digital.
EE445S Real-Time Digital Signal Processing Lab Spring 2014 Lecture 16 Quadrature Amplitude Modulation (QAM) Receiver Prof. Brian L. Evans Dept. of Electrical.
Software Defined Radio PhD Program on Electrical Engineering Sampling Theory and Quantization José Vieira.
Prof. Nizamettin AYDIN Advanced Digital Signal Processing 1.
Sampling and Aliasing.
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin Lecture 3
EE345S Real-Time Digital Signal Processing Lab Fall 2006 Lecture 17 Fast Fourier Transform Prof. Brian L. Evans Dept. of Electrical and Computer Engineering.
EE445S Real-Time Digital Signal Processing Lab Fall 2016 Lecture 16 Quadrature Amplitude Modulation.
Communications and Signal Processing Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin June 12, 2002.
Eeng Chapter4 Bandpass Signalling  Bandpass Filtering and Linear Distortion  Bandpass Sampling Theorem  Bandpass Dimensionality Theorem  Amplifiers.
Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin EE445S Real-Time Digital Signal Processing Lab Spring.
Chapter 4 Dynamical Behavior of Processes Homework 6 Construct an s-Function model of the interacting tank-in-series system and compare its simulation.
Chapter 4 Dynamical Behavior of Processes Homework 6 Construct an s-Function model of the interacting tank-in-series system and compare its simulation.
Fourier Series Prof. Brian L. Evans
Sampling and Aliasing Prof. Brian L. Evans
Amplitude Modulation X1(w) Y1(w) y1(t) = x1(t) cos(wc t) cos(wc t)
EEE4176 Applications of Digital Signal Processing
Periodic Signals Prof. Brian L. Evans
디지털통신 Bandpass Modulation 1 임 민 중 동국대학교 정보통신공학과.
Sampling and Aliasing Prof. Brian L. Evans
Principios de Comunicaciones EL4005
Sampling and Quantization
The Laplace Transform Prof. Brian L. Evans
Lecture Signals with limited frequency range
Sampling and Reconstruction
Fast Fourier Transform
Lecture 14 Digital Filtering of Analog Signals
Amplitude Modulation.
Chapter 4 Bandpass Circuits Limiters
Chapter4 Bandpass Signalling Definitions
لجنة الهندسة الكهربائية
Lecture 10 Digital to Analog (D-to-A) Conversion
Digital Pulse Amplitude Modulation (PAM)
Fourier Transform Analysis of Signals and Systems
Chapter4 Bandpass Signalling Definitions
Quadrature Amplitude Modulation (QAM) Transmitter
Interpolation and Pulse Shaping
Chapter 2 Ideal Sampling and Nyquist Theorem
Rectangular Sampling.
Quadrature Amplitude Modulation (QAM) Transmitter
Chapter4 Bandpass Signalling Bandpass Filtering and Linear Distortion
Digital Signal Processing
Fast Fourier Transform
Sampling and Aliasing.
Lab 6: Week 1 Quadrature Amplitude Modulation (QAM) Transmitter
State Space approach State Variables of a Dynamical System
Presentation transcript:

Generating Sinusoidal Signals EE 445S Real-Time Digital Signal Processing Lab Fall 2018 Generating Sinusoidal Signals Prof. Brian L. Evans Dept. of Electrical and Computer Engineering The University of Texas at Austin Lecture 1 http://www.ece.utexas.edu/~bevans/courses/realtime

Outline Bandwidth Sinusoidal amplitude modulation Sinusoidal generation Design tradeoffs

Bandwidth Non-zero extent in positive frequencies Ideal Lowpass Spectrum fmax -fmax f Bandwidth fmax Ideal Bandpass Spectrum f1 f2 f –f2 –f1 Bandwidth W = f2 – f1 Applies to continuous-time & discrete-time signals In practice, spectrum won’t be ideally bandlimited Thermal noise has “flat” power spectrum from 0 to 1015 Hz Finite observation time of signal leads to infinite bandwidth Alternatives to “non-zero extent”?

Bandwidth of Lowpass Signal in Noise How to determine fmax? Lowpass Spectrum in Noise f Apply threshold and eyeball it OR approximate Estimate fmax that captures certain percentage (say 90%) of energy Idealized Lowpass Spectrum fmax -fmax f In practice, (a) use large frequency in place of  and (b) integrate measured spectrum numerically Baseband signal: energy in frequency domain concentrated around DC

Bandwidth of Bandpass Signal in Noise How to find W = f2 – f1 ? Bandpass Spectrum In Noise f fc - fc Apply threshold and eyeball it OR approximate Assume knowledge of fc and estimate f1 = fc  W/2 and f2 = fc + W/2 that capture percentage of energy Idealized Bandpass Spectrum f1 f2 f –f2 –f1 In practice, (a) use large frequency in place of  and (b) integrate measured spectrum numerically

Amplitude Modulation by Cosine y1(t) = x1(t) cos(wc t) Assume x1(t) is ideal lowpass signal with bandwidth w1 << wc w 1 w1 -w1 X1(w) Y1(w) ½ -wc - w1 -wc + w1 -wc wc - w1 wc + w1 wc ½X1(w - wc) ½X1(w + wc) lower sidebands Y1(w) has (transmission) bandwidth of 2w1 Y1(w) is real-valued if X1(w) is real-valued Demodulation: modulation then lowpass filtering

Amplitude Modulation by Sine y2(t) = x2(t) sin(wc t) Assume x2(t) is ideal lowpass signal with bandwidth w2 << wc w 1 w2 -w2 X2(w) Y2(w) j ½ -wc – w2 -wc + w2 -wc wc – w2 wc + w2 wc -j ½X2(w - wc) j ½X2(w + wc) -j ½ lower sidebands Y2(w) has (transmission) bandwidth of 2w2 Y2(w) is imaginary-valued if X2(w) is real-valued Demodulation: modulation then lowpass filtering

How to Use Bandwidth Efficiently? Amplitude Modulation How to Use Bandwidth Efficiently? Send lowpass signals x1(t) and x2(t) with 1 = 2 over same transmission bandwidth + cos(c t) sin(c t) x1(t) x2(t) s(t) Called Quadrature Amplitude Modulation (QAM) Used in DSL, cable, Wi-Fi, LTE, and smart grid communications Cosine modulated signal is in theory orthogonal to sine modulated signal at transmitter Receiver separates x1(t) and x2(t) through demodulation

Lab 2: Sinusoidal Generation Compute sinusoidal waveform Function call Lookup table Difference equation Output waveform off chip Polling data transmit register Software interrupts Quantization effects in digital-to-analog (D/A) converter Expected outcomes are to understand Signal quality vs. implementation complexity tradeoffs Interrupt mechanisms

See handout on sampling unit step function Design Tradeoffs in Generating Sinusoidal Signals Sinusoidal Waveforms One-sided discrete-time cosine (or sine) signal with fixed-frequency 0 in rad/sample has form cos(0 n) u[n] Consider one-sided continuous-time analog-amplitude cosine of frequency f0 in Hz cos(2  f0 t) u(t) See handout on sampling unit step function Sample at rate fs by substituting t = n Ts = n / fs (1/Ts) cos(2  (f0 / fs) n) u[n] Discrete-time frequency 0 = 2  f0 / fs in units of rad/sample Example: f0 = 1200 Hz and fs = 8000 Hz, 0 = 3/10  How to determine gain for D/A conversion?

Design Tradeoffs in Generating Sinusoidal Signals Math Library Call in C Uses double-precision floating-point arithmetic No standard in C for internal implementation Appropriate for desktop computing On desktop computer, accuracy is a primary concern, so additional computation is often used in C math libraries In embedded scenarios, implementation resources generally at premium, so alternate methods are typically employed GNU Scientific Library (GSL) cosine function Function gsl_sf_cos_e in file specfunc/trig.c Version 1.8 uses 11th order polynomial over 1/8 of period 20 multiply, 30 add, 2 divide and 2 power calculations per output value (additional operations to estimate error)

Efficient Polynomial Implementation Design Tradeoffs in Generating Sinusoidal Signals Efficient Polynomial Implementation Use 11th-order polynomial Direct form a11 x11 + a10 x10 + a9 x9 + ... + a0 Horner's form minimizes number of multiplications a11 x11 + a10 x10 + a9 x9 + ... + a0 = ( ... (((a11 x + a10) x + a9) x ... ) + a0 Comparison Realization Multiply Operations Addition Operations Memory Usage Direct form 66 10 13 Horner’s form 11 12

Initial conditions are all zero Design Tradeoffs in Generating Sinusoidal Signals Difference Equation Difference equation with input x[n] and output y[n] y[n] = (2 cos 0) y[n-1] - y[n-2] + x[n] - (cos 0) x[n-1] From inverse z-transform of z-transform of cos(0 n) u[n] Impulse response gives cos(0 n) u[n] Similar difference equation for sin(0 n) u[n] Initial conditions are all zero Implementation complexity Computation: 2 multiplications and 3 additions per cosine value Memory Usage: 2 coefficients, 2 previous values of y[n] and 1 previous value of x[n] Drawbacks Buildup in error as n increases due to feedback Fixed value for 0

Design Tradeoffs in Generating Sinusoidal Signals Difference Equation If implemented with exact precision coefficients and arithmetic, output would have perfect quality Accuracy loss as n increases due to feedback from Coefficients cos(0) and 2 cos(0) are irrational, except when cos(0) is equal to -1, -1/2, 0, 1/2, and 1 Truncation/rounding of multiplication-addition results Reboot filter after each period of samples by resetting filter to its initial state Reduce loss from truncating/rounding multiplication-addition Adapt/update 0 if desired by changing cos(0) and 2 cos(0)

See handout on discrete-time periodicity Design Tradeoffs in Generating Sinusoidal Signals Lookup Table Precompute samples offline and store them in table Cosine frequency 0 = 2  N / L Remove common factors between integers N & L cos(2  f0 t) has continuous-time period T0 = 1 / f0 cos(2  (N / L) n) has discrete-time period of L samples Store L samples in lookup table (N continuous-time periods) See handout on discrete-time periodicity Built-in lookup tables in read-only memory (ROM) Samples of cos() and sin() at uniformly spaced values for  Interpolate values to generate sinusoids of various frequencies Allows adaptation of 0 if desired

Design Tradeoffs in Generating Sinusoidal Signals Signal quality vs. implementation complexity in generating cos(0 n) u[n] with 0 = 2  N / L Method MACs/ sample ROM (words) RAM (words) Quality in floating pt. Quality in fixed point C math library call 30 22 1 Second Best N/A Difference equation 2 3 Worst Lookup table L Best MAC Multiplication-accumulation RAM Random Access Memory (writeable) ROM Read-Only Memory