Digital Signal Processing Lab
Digital Signal Processing Lab
FACULTY OF ENGINEERING
TELECOMMUNICATION ENGINEERING DEPARTMENT
2013/2014
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Report notes:
Good luck
1
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Total Credits 1
major compulsory
Prerequisites P1 : Digital Signal Processing (69441)
Course Contents
The DSP Lab is equipped with complete set of hardware and software to perform DSP
experiments in this course. Real -Time DSP is used to understand the real-time DSP systems
principles and Real-world applications. It also includes sampling and waveform generation,
quantization, PCM encoding, delta modulation, digital modulation schemes (ASK, PSK, FSK),
error correcting codes, read write from CODEC, fast Fourier transform, FIR Filter
implementation (Low Pass, High Pass Band Stop), IIR Filter implementation, linear convolution
auto correlation and power spectral density.
Student
Intended Learning Outcomes (ILO's) Outcomes Contribution
(SO's)
1 An ability to use DSP processor in the design of C 30 %
communication systems, speech processing, image processing,
digital filtering (FIR, IIR), spectral estimation.
2 An ability to function on multidisciplinary teams D 25 %
3 Ability to communicate effectively through the various lab G 25 %
reports
4 Ability to design real system using DSP processor via Matlab K 20 %
Simulink interface Software
Textbook and/ or Refrences
Digital Signal Processing and Applications with the C6713 and C6416 DSK, Rulph chassaing,
John Wiley, 2005
Assessment Criteria Percent (%)
Laboratory Work 65 %
Final Exam 35 %
Course Plan
Week Topic
1 Introduction and project creation
2 Waveform generation and sampling
3 ASK, BPSK and FSK modulation and demodulation
4 QPSK modulation and demodulation
5 FIR filtering
6 IIR filtering
7 Adaptive filtering and noise cancellation spectral estimation
8 Audio Effects (Echo and Reverb, Harmonics, and Distortion)
9 Echo cancelling and voice scrambling
2
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Table of Contents
3
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
4
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
3 Experiment 3 Amplitude Shift Keying (ASK) and Frequency shift keying (FSK)...................................40
3.1 Objectives..........................................................................................................................40
3.2 Introduction......................................................................................................................40
3.3 Theory of ASK....................................................................................................................40
3.4 Theory of FSK....................................................................................................................41
3.5 Experimental procedures..................................................................................................42
4 Experiment 4 QPSK............................................................................................................................46
4.1 Objectives..........................................................................................................................46
4.2 Theory...............................................................................................................................46
4.2.1 Implementation.................................................................................................................47
4.2.2 Generation and demodulation of QPSK signal...................................................................47
4.3 Experimental procedures..................................................................................................48
5 Experiment 5 FIR filter.......................................................................................................................52
5.1 Objectives..........................................................................................................................52
5.2 Experimental procedures..................................................................................................52
5.2.1 Low pass filter....................................................................................................................52
5.2.2 Low pass, high pass, band pass and pass band filter..........................................................55
5.2.3 Effects on voice using three FIR low pass filters (FIR3LP)...................................................58
6 Experiment 6 IIR filter........................................................................................................................61
6.1 Objectives..........................................................................................................................61
6.2 Theory...............................................................................................................................61
6.2.1 Cascade form structure......................................................................................................62
6.2.2 Parallel form structure.......................................................................................................63
6.3 Experimental procedures..................................................................................................63
6.3.1 IIR Filter Implementation Using Second-Order Stages in Cascade (IIR)..............................63
6.3.2 IIR Inverse Filter (IIR inverse)..............................................................................................68
7 Experiment 7 Adaptive filters............................................................................................................72
7.1 Theory...............................................................................................................................72
7.2 Applications of adaptive filters.......................................................................................73
7.3 Experimental procedures..................................................................................................75
7.3.1 Adaptive Filter for Sinusoidal Noise Cancellation...............................................................75
5
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
7.4 Adaptive FIR filter for noise cancellation using external inputs...................................78
7.4.1 Adaptive FIR Filter for System ID of a Fixed FIR as an Unknown System............................81
8 Experiment 8 audio effects................................................................................................................86
8.1 Objectives..........................................................................................................................86
8.2 Introduction......................................................................................................................86
8.2.1 Delay..................................................................................................................................86
8.2.2 Echo...................................................................................................................................86
8.2.3 Reverberation....................................................................................................................87
8.3 Experiment procedure.......................................................................................................88
8.3.1 Echo generation.................................................................................................................88
8.3.2 Echo with Control for Different Effects...............................................................................89
9 Experiment 9 echo cancelling and voice scrambling..........................................................................92
9.1 Objectives..........................................................................................................................92
9.2 Echo canceling using adaptive algorithm.......................................................................92
9.3 Voice Scrambling Using Filtering and Modulation (Scrambler)....................................94
9.3.1 Experiment procedures...................................................................................................97
10 Experiment 10 DFT and FFT...........................................................................................................98
10.1 Objectives..........................................................................................................................98
10.2 Introduction......................................................................................................................98
10.3 FFT of a Real-Time Input Signal Using an FFT Function in C.............................................100
10.3.1 Testing procedures...........................................................................................................102
10.4 Fast Convolution..............................................................................................................102
10.4.1 Testing procedure............................................................................................................105
11 Experiment 11 Hamming Codes...................................................................................................107
11.1 Objectives........................................................................................................................107
11.2 Theory of Hamming Code...............................................................................................107
11.3 Experimental procedures................................................................................................110
12 Dual-Tone Multi frequency DTMF................................................................................................113
12.1 Objectives........................................................................................................................113
12.2 Theory of ASK..................................................................................................................113
12.3 Experimental procedures................................................................................................113
6
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
7
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The following instructions provide guidelines for handling two types of electrical emergencies:
1. Electric Shock:
When someone suffers serious electrical shock, he or she may be knocked unconscious. If the victim
is still in contact with the electrical current, immediately turn off the electrical power source. If you
cannot disconnect the power source, depress the Emergency Power Off switch.
IMPORTANT:
Do not touch a victim that is still in contact with a live power source;
you could be electrocuted.
Have someone call for emergency medical assistance immediately. Administer first-aid, as
appropriate.
2. Electrical Fire:
If an electrical fire occurs, try to disconnect the electrical power source, if possible. If the fire is small
and you are not in immediate danger; and you have been properly trained in fighting fires, use the
correct type of fire extinguisher to extinguish the fire. When in doubt, push in the Emergency Power
Off button.
8
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Every week before lab, each student should read over the laboratory experiment
and work out the various calculations, etc. that are outlined in the prelab. The student should
refer to Digital signal processing and Applications with C6713 and C6416 DSK, by Rulph
Chassaing.
a) Return parts and all equipment have to correct locations when you are finished with
them.
b) Give suspected defective parts to the Lab technician for testing or disposal.
c) Report all equipment problems to Lab Instructor or Lab technician.
d) Most experiments have several parts; students must alternate in doing these parts as
they are expected to work in group.
e) Laboratory and equipment maintenance is the responsibility of not only the Lab
technician, but also the students. A concerted effort to keep the equipment in excellent
condition and the working environment well-organized will result in a productive and
safe laboratory.
f) Each student must have a laboratory notebook. The notebook should be a permanent
document that is maintained and witnessed properly, and that contains accurate records
of all lab sessions.
9
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Laboratory Notebook
The laboratory notebook is a record of all work pertaining to the experiment. This
record should be sufficiently complete so that you or anyone else of similar technical
background can duplicate the experiment and data by simply following your laboratory
notebook. Record everything directly into the notebook during the experiment. Do not
use scratch paper for recording data. Do not trust your memory to fill in the details at a later
time.
10
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
There is no one best format for all technical reports but there are a few simple rules
concerning technical presentations which should be followed. Adapted to this laboratory they
may be summarized in the following recommended report format:
Title page
Introduction
Experimental procedure
Experimental data
Discussion
Conclusions
Title Page:
The title page should be prepared according to the ABET form included at the beginning
of this lab manual. The title page should contain the following informations
Your name
ID
Date submitted
11
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Instructors Name
Introduction:
It should contain a brief statement in which you state the objectives, or goals of the
experiment. It should also help guide the reader through the report by stating, for
example, that experiments were done with different DSP algorithms or consisted of two
parts etc. or that additional calculations or data sheets can be found in the appendix,
or at the end of the report.
The Procedure
It describes the experimental setup and how the measurements were made. Include
here block diagrams or flow charts. Mention instruments used and describe any special
measurement procedure that was used.
Results/Questions:
This section of the report should be used to answer any questions presented in the
lab handout. Any tables and/or circuit diagrams representing results of the experiment
should be referred to and discussed/explained with detail. All questions should be
answered very clearly in paragraph form. Any unanswered questions from the lab
handout will result in loss of marks on the report.
The Discussion
It is a critical part of the report which testifies to the students understanding of the
experiments and its purpose. In this part of the report you should compare the
expected outcome of the experiment, such as derived from theory or computer
simulation, with the measured value. Before you can make such comparison you may
have to do some data analysis or manipulation.
When comparing experimental data with numbers obtained from theory or simulation,
make very clear which is which. It does not necessarily mean that your experiment was
a failure. The results will be accepted, provided that you can account for the
discrepancy. Your ability to read the scales may be one limitation. The value of some
circuit components may not be well known and a nominal value given by the
12
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
manufacturer does not always correspond to reality. Very often, however, the reason
for the difference between the expected and measured values lies in the experimental
procedure or in not taking into account all factors that enter into analysis.
Conclusion:
A brief conclusion summarizing the work done, theory applied, and the results of the
completed work should be included here. Data and analyses are not appropriate for the
conclusion.
Notes
Typed Reports are required. Any drawings done by hand must be done with
neatness, using a straight edge and drawing guides wherever possible. Free hand
drawings will not be accepted.
Prelab results should be reported in the provided sheets at the end of the manual. It is
your responsibility to obtain the instructors signature and to include the signed sheet
with your final experiment report.
13
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1.2 Introduction
A signal is a physical quantity that is usually a function of time, position, pressure, etc. For
example, the voltage output from a microphone represents sound pressure as a function of
time. Signals that we encounter frequently in our daily life include speech, music, data, images,
video signals. The objective of signal processing is to transmit or store signals, to enhance
desired signal components, and to extract useful information carried by the signals.
Signal Processing is a method of extracting information from the signal which in turn depends
on the type of signal and the nature of information it carries.
Digital signal processing is concerned with the digital representation of signals and use of digital
processors to analyze, modify or extract information from signals. Most signals in nature are
analog. Analog signals are varying with time, and represent the variations of physical quantities
1
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
such as sound waves. The signals used in most popular forms of DSP are derived from analog
signals which have been sampled at regular intervals and converted into digital form. The
specific mean for processing a digital signal may be, for example, to remove interference of
noise from the signal, to obtain the spectrum of the data or to transform the signal from the
signal in to more suitable form. DSP is now used in many areas where analog methods were
previously used and in entirely new applications which were difficult with analog methods. Basic
building block of digital signal processing is shown in Figure 1
Digital Signal Processor (DSP) is a microcontroller designed specifically for signal processing
applications. This is achieved as specified in Figure 2. Commonly used operations in signal
processing applications are convolution, filtering, and frequency to time domain conversions.
These operations need recursive multiplication and additions. In other words, they need
multiply and accumulate (MAC) operations. Standard microprocessors execute the
multiplication operation as a recursive addition operation. This means for a standard
microprocessor, the MAC operation is processed by excessive number of addition operations.
This takes time. However, DSPs contain special MAC units that can execute the same operation
in a single machine cycle. For example, a 150 MIPS DSP can process approximately 32 million
data samples per second. For a standard 150 MIPS microprocessor, this reduces to 2 million
data samples per second. Like microcontrollers, DSPs are equipped with different peripheral
devices according to their usage area. TMS320C6713 does not contain any ADC or DAC but it
contains SPI and I2C interfaces. Therefore, its development kit, ST6000 [TMS320C6713 DSK],
contains an AIC23 codec chip working as an ADC and DAC interface. It communicates with the
DSP over the SPI.
Mostly sensors generate analog signals in response to various phenomena. Signal processing
can be carried out either in analog or digital domain. To do processing of analog signals in digital
domain, first digital signal is obtained by sampling and followed by quantization (digitization).
The digitization can be obtained by analog to digital converter (ADC). The role of digital signal
processor (DSP) is the manipulation of digital signals so as to extract desired information. In
2
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
order to interface DSP with analog world, digital to analog converters (DAC) are used. Figure 3
shows the basic components of a DSP system.
ADC captures and inputs the signal. The resulting digital representation of the input signal is
processed by DSP such as C6x and then output through DAC. Within in the basic DSP system,
anti-aliasing filter at input to remove erroneous signals and output filter to smooth the
processed data is also used.
Perfect Reproducibility: Identical performance from unit to unit is obtained since there is
no variation due to component tolerances. For example, using DSP technique, a digital
recording can be copied to or reproduced several times over without any degradation in
the signal quality.
Superior Performance: DSP can be used to perform functions not possible with analog
signal processing. For example linear phase response can be achieved. And complex
adaptive filtering algorithms can be implemented using DSP technique.
3
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Consider a software system in which the inputs represent digital data from hardware such as
imaging devices or other software system's and the output share digital data that control
external hardware such as displays. The time between the presentation of a set of inputs and
the appearance of all the associated outputs is called the response time. A real-time system is
one that must satisfy explicit bounded response time constraints to avoid failure. Equivalently, a
real-time system is one whose logical correctness is based both on the correctness of the
outputs and their timeliness. Notice that response time of, for example, microseconds are not
needed to characterize a real-time system. It simply must have response times that are
constrained and thus predictable. In fact, the misconception that real-time systems must be
"fast" is because in most instances, the deadlines are on the order of microseconds. But the
time lines constraints or deadlines are generally a reflection of the underlying physical process
being controlled. For example, in image processing involving screen update for viewing
continuous motion, the deadlines are on the order of 30 microseconds. In practical situations,
the main difference between real-time and non-real-time systems is an emphasis on response
time prediction and its reduction. Upon reflection, one realizes that every system can be made
to conform to the real-time definition simply are setting deadlines (arbitrary or otherwise). For
example, a one-time image filtration algorithm for medical imaging, which might not be
regarded as real-time, really is real-time if the procedure is related to an illness in which
diagnosis and treatment have some realistic
DSP systems are often embedded in larger systems to perform specialized DSP operations, thus
allowing the overall systems to handle general purpose tasks. For example, a DSP processor is a
modem used for data transmission in the embedded DSP system of a computer. Often this type
of a DSP system runs only one application and is not programmed by the end user.
Texas instrument introduced the first DSP processor, the TMS32010 is the first DSP processor of
TMS320 family. Today it consists of fixed point and floating point processors. The 16 bit fixed
point processor includes the TMS320C2000 (C2x and C28x), C5000 (the C54x and C55x) and
C6000 (the C62x and C64x) generations. The 32 bit floating point processors consist of C3x, C4x
and C67x generations.
4
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The applications of the digital signal processing will include the following main applications.
waveform generation
Digital filtering
Adaptive filtering
2. Audio applications
Audio watermarking
5
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Effects generator
3. Communications:
Communication security
Detection
Software radios
The onboard codec AIC23 uses a sigmadelta technology that provides ADC and DAC. It is
connected to a 12-MHz system clock. Variable sampling rates from 8 to 96 kHz can be set
readily. A daughter card expansion is also provided on the DSK board. Two 80-pin connectors
provide for external peripheral and external memory interfaces.
The DSK board includes 16MB (megabytes) of synchronous dynamic random access memory
(SDRAM) and 256kB (kilobytes) of flash memory. Four connectors on the board provide input
and output: MIC IN for microphone input, LINE IN for line input, LINE OUT for line output, and
HEADPHONE for a headphone output (multiplexed with line output). The status of the four user
dip switches on the DSK board can be read from a program and provides the user with a
feedback control interface. The DSK operates at 225 MHz. Also onboard the DSK are voltage
regulators that provide 1.26 V for the C6713 core and 3.3 V for its memory and peripherals.
6
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
(a)
(b)
7
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Figure 4 TMS320C6713-based DSK board: (a) board; (b) diagram. (Courtesy of Texas Instruments)
1.6.1 TLV320AIC23 (AIC23) ONBOARD STEREO CODEC FOR INPUT AND OUTPUT
The DSK board includes the TLV320AIC23 (AIC23) codec for input and output. The ADC circuitry
on the codec converts the input analog signal to a digital representation to be processed by the
DSP. The maximum level of the input signal to be converted is determined by the specific ADC
circuitry on the codec, which is 6Vp-p with the onboard codec. After the captured signal is
processed, the result needs to be sent to the outside world. Along the output path in Figure 3 is
a DAC, which performs the reverse operation of the ADC. An output filter smooths out or
reconstructs the output signal. ADC, DAC, and all required filtering functions are performed by
the single-chip codec AIC23 on board the DSK.
The AIC23 is a stereo audio codec based on sigmadelta technology. The functional block
diagram of the AIC23 codec is shown in Figure 5. It performs all the functions required for ADC
and DAC, low pass filtering, oversampling, and so on. The AIC23 codec contains specifications
for data transfer of words with length16, 20, 24, and 32 bits.
Sigmadelta converters can achieve high resolution with high over sampling ratios but with
lower sampling rates. They belong to a category in which the sampling rate can be much higher
8
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
than the Nyquist rate. Sample rates of 8, 16, 24, 32, 44.1, 48, and 96 kHz are supported and can
be readily set in the program.
9
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
A digital interpolation filter produces the oversampling. The quantization noise power in such
devices is independent of the sampling rate. A modulator is included to shape the noise so that
it is spread beyond the range of interest. The noise spectrum is distributed between 0 and
Fs
, so that only a small amount of noise is within the signal frequency band. Therefore,
2
within the actual band of interest, the noise power is considerably lower. A digital filter is also
included to remove the out-of band noise.
A 12-MHz crystal supplies the clocking to the AIC23 codec (as well as to the DSP and the USB
interface). Using this 12-MHz master clock, with over sampling rates of 250 F s and
272 F s , an exact audio sample rate of 48 kHz (12MHz/250) and a CD rate of 44.1kHz
(12MHz/272) can be obtained. The sampling rate is set by the codecs register SAMPLERATE.
The ADC converts an input signal into discrete output digital words in a 2scomplementformat
that corresponds to the analog signal value. The DAC includes an interpolation filter and a digital
modulator. A decimation filter reduces the digital data rate to the sampling rate. The DACs
output is first passed through an internal low pass reconstruction filter to produce an output
analog signal. Low noise performance for both ADC and DAC is achieved using oversampling
techniques with noise shaping provided by sigmadelta modulators. Communication with the
AIC23 codec for input and output uses two multichannel buffered serial ports McBSPs on the
C6713. McBSP0 is used as a unidirectional channel to send a 16-bit control word to the AIC23.
McBSP1 is used as a bidirectional channel to send and receive audio data. Alternative I/O
daughter cards can be used for input and output. Such cards can plug into the DSK through the
external peripheral interface 80-pin connector J3 on the DSK board.
In order to program the DSK kit to perform a certain signal processing task we can use C code
via a program called code composer studio or via MATLAB using simulink. In this lab we will use
both programing methods, but the code composer studio will be considered first
CCS provides an IDE to incorporate the software tools. CCS includes tools for code generation,
such as a C compiler, an assembler, and a linker. It has graphical capabilities and supports real-
time debugging. It provides an easy-to-use software tool to build and debug programs. The C
compiler compiles a C source program with extension.c to produce an assembly source file with
extension.asm. The assembler assembles an .asm source file to produce a machine language
object file with extension.obj. The linker combines object files and object libraries as input to
10
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
produce an executable file with extension.out. This executable file represents a linked common
object file format (COFF), popular in Unix-based systems and adopted by several makers of
digital signal processors. This executable file can be loaded and run directly on the C6713
processor.
Any project created by the code composer must contain several files with different file types,
these file types are listed below
3. file.asm: assembly source program created by the user, by the C compiler, or by the
linear optimizer
4. file.sa: linear assembly source program. The linear optimizer uses file.sa as input to
produce an assembly program file.asm
9. file.out: executable file created by the linker to be loaded and run on the C6713
processor
The following support files located in the folder support (except the library files) are used for
most of the examples and projects discussed in this lab:
1. C6713dskinit.c: contains functions to initialize the DSK, the codec, the serial ports, and
for I/O. you can find this file under the support folder provided by this lab
11
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. C6713dskinit.h: header file with function prototypes. Features such as those used to
select the mic input in lieu of line input (by default), input gain, and so on are obtained
from this header file (modified from a similar file included with CCS).
3. C6713dsk.cmd: sample linker command file. This generic file can be changed when using
external memory in lieu of internal memory.
4. Vectors_intr.asm: a modified version of a vector file included with CCS to handle
interrupts. Twelve interrupts, INT4 through INT15, are available, and INT11 is selected
within this vector file. They are used for interrupt-driven programs.
5. Vectors_poll.asm: vector file for programs using polling.
6. rts6700.lib, dsk6713bsl.lib, csl6713.lib: run-time, board, and chip support library files,
respectively. These files are included with CCS and are located in C6000\cgtools\lib,
C6000\dsk6713\lib, and c6000\bios\lib, respectively.
12
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Three programming examples are introduced to illustrate some of the features of CCS and the
DSK board. The primary focus is to become familiar with both the software and hardware tools.
It is strongly suggested that you complete these three examples before proceeding to
subsequent chapters
Example 1: Sine Generation Using Eight Points with DIP Switch Control (sine8_LED)
This example generates a sinusoid using a table lookup method. More important, it illustrates
some features of CCS for editing, building a project, accessing the code generation tools, and
running a program on the C6713 processor. The C source program sine8_LED.c shown in Figure
6 implements the sine generation and is included in the folder sine8_LED.
Program Consideration
Although the purpose is to illustrate some of the tools, it is useful to understand the program
sine8_LED.c. A table or buffer sine_table is created and filled with eight points representing
sin(t), where t = 0, 45, 90, 135, 180, 225, 270, and 315 degrees (scaled by 1000).
Within the function main, another function, comm_poll(), is called that is located in the
communication and initialization support file c6713dskinit.c. It initializes the DSK, the AIC23
codec onboard the DSK, and the two McBSPs on the C6713 processor.
Within c6713dskinit.c, the function DSK6713_init initializes the BSL file, which must be called
before the two subsequent BSL functions, DSK6713_LED_init() and DSK6713_DIP_init(), are
invoked that initialize the four LEDs and the four dip switches.
The statement while (1) within the function main creates an infinite loop. When dip switch #0 is
pressed, LED #0 turns on and the sinusoid is generated. Otherwise, DSK6713_DIP_get(0) will be
false (true if the switch is unpressed) and LED #0 will be off.
13
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
eight data values (0.125 ms apart) are output to generate a sinusoidal signal. The period of the
1
output signal is T =8 ( 0 . 125ms )=1 ms , corresponding to a frequency of f = =1 kHz .
T
Figure 6 Sine generation program using eight points with dip switch control (sine8_LED.c).
14
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. Copy the files under support folder (you can find it in desktop) into
your project folder.
4. Repeat step 3, use the pull-down menu for files of type, and select ASM
Source Files. Double-click on the assembly source vector file
vectors_poll.asm to add it to the project. Repeat again and select files
of type: Linker Command File, and add C6713dsk.cmd to the project.
5. To add the library support files to the project. Repeat the previous step,
but select files of type: Object and Library Files. Look in c:\
ccstudiov3.1\c6000\cgtools\lib and select the run-time support library
file rts6700.lib (which supports the C67x architecture) to add to the
project. Continue this process to add the BSL file dsk6713bsl.lib located
in c:\ccstudiov3.1\c6000\dsk6713\lib, and the chip support library (CSL)
file csl6713.lib located in c:\ ccstudiv3.1\c6000\csl\lib.
6. Verify from the Files window that the project (.pjt) file, the linker
command (.cmd) file, the three library (.lib) files, the two C source (.c)
files, and the assembly (.asm) file have been added to the project as
shown in Figure 7 b. The GEL file dsk6713.gel is added automatically
when you create the project. It initializes the C6713 DSK invoking the
BSL to use the phase-locked loop (PLL) to set the central processing
unit (CPU) clock to 225 MHz (otherwise, the C6713 runs at 50 MHz by
default).
7. Note that there are no include files yet. Select Project Scan All File
Dependencies. This adds/includes the header files c6713dskinit.h,
along with several board and chip support header files included with
CCS.
15
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The Files window in CCS should look as in Figure 7 b. Any of the files
(except the library files) from CCSs Files window can be displayed by
clicking on it. You should not add header or include files to the project.
They are added to the project automatically when you select: Scan All File
Dependencies. (They are also added when you build the project.)
(a)
16
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
(b)
Figure 7 CCS Project windows for sine8_LED: (a) project creation; (b) project view files.
Various options are associated with the code generation tools: C compiler
and linker to build a project.
Compiler Option
Select Project Build Options. Figure 8 shows the CCS window Build Options
for the compiler. Select the following for the compiler option with Basic (for
Category): (1) c671x{-mv6710} (for Target Version), (2) Full Symbolic Debug
17
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
(for Generate Debug Info), (3) Speed most critical (for Opt Speed vs. Size),
(4) None (for Opt Level and Program Level Opt). Select the Preprocessor
Category and type for Define Symbols {d}: CHIP_6713, and (5) form
Advanced Category change Memory Model to "Far(--
mem_model:data=far),and from the Feedback Category, select for
Interlisting: OPT/C and ASM{-s}. The resulting compiler option is
-g -s
18
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
-s -o3
The -o3 option invokes the highest level of optimization for performance or
execution speed. For now, speed is not critical (neither is debugging). Use
the compiler options -gs (which you can also type directly in the compiler
command window).Initially, one would not optimize for speed but to facilitate
debugging
Linker Option
Note that you can/should choose to store the executable file in the subfolder
Debug, within the folder sine8_LED, especially during the debugging stage
of a project.
Again, these various compiler and linker options can be typed directly within
the appropriate command windows.
In lieu of adding the three library files to the project by retrieving them from
their specific locations, it is more convenient to add them within the linker
option window Include Libraries{-l}, typing them directly, separated by a
comma. However, they will not be shown in the Files window.
19
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. Build this project as sine8_LED. Select Project Rebuild All or press the
toolbar with the three down arrows. This compiles and assembles all
the C files using cl6x and assembles the assembly file vectors_poll.asm
usingasm6x. The resulting object files are then linked with the library
files usinglnk6x. This creates an executable file sine8_LED.out that can
be loaded into the C6713 processor and run. Note that the commands
for compiling, assembling, and linking are performed with the Build
option. A log filecc_build_Debug.log is created that shows the files that
are compiled and assembled, along with the compiler options selected.
It also lists the support functions that are used. Figure 10 shows
20
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
21
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Verify that the processor is still running (and dip switch #0 is pressed). Note
the indicator DSP RUNNING at the bottom left of CCS. The Watch window
allows you to change the value of a parameter or to monitor a variable:
Since the AIC23 is a stereo codec, we can send data to both 16-bit channels
within each sampling period. This is introduced in a later experiment.
Sending data to both codec channels can be useful to experiment with the
stereo effects of output signals. In other experiment, we use both channels
for adaptive filtering where it is necessary to input one type of signal (such
as noise) on one 16-bit channel and another signal (such as a desired signal)
on the other 16-bit channel. In this book, we will mostly use the codec as a
mono device without the need to use an adapter that is required when using
both channels
22
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
through different values while the processor is running. All variables must
first be defined in your source program.
1. Select File new and create new file. Write the code shown in Figure 11
in the new file and save this file in your project directory (sine8_LED)
as gain.gel
2. Select File Load GEL and open the file gain.gel. By creating the slider
function gain shown in Figure 11, you can start with an initial value of
10 (first value) for the variable gain that is set in the C program, up to
a value of 35 (second value), incremented by 5 (third value).
3. Select GEL Sine Gain Gain. This should bring out the Slider window
shown in Figure 12, with the minimum value of 10 set for the gain.
4. Press the up-arrow key to increase the gain value from 10 to 15, as
displayed in the Slider window. Verify that the volume of the sine wave
generated has increased. Press the up-arrow key again to continue
increasing the slider, incrementing by 5 up to 30. The amplitude of the
sine wave should be about 2.5 V p-p with a gain value set at 30. Now
use the mouse to click directly on the Slider window and slowly
increase the slider position to 31, then 32, and verify that the
frequency generated is still 1 kHz. Increase the slider to 33 and verify
that you are no longer generating a 1-kHz sine wave. The table values,
scaled by the gain value, are now between 33,000 (beyond the
acceptable range by the codec).
Figure 11 GEL file to slide through different gain values in the sine generation program (gain.gel).
23
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Figure 12 Slider window for varying the gain of generated sine wave.
2. Change the number of points in the lookup table to four points in lieu
of eight points for example, {0, 1000, 0, -1000}. The size of the array
sine_table and the loop index also need to be changed. Verify that the
Fs
generated frequency is f = .
number of points
Note that the sinusoid is no longer generated if the dip switch #0 is not
pressed. If a different dip switch such as switch #3 is desired (in lieu of
switch #0), the BSL functions DSK6713_DIP_get(3), DSK6713_LED_on(3),
and DSK6713_LED_off(3) can be substituted in the C source program.
Two sliders can readily be used, one to change the gain and the other to
change the frequency. A different signal frequency can be generated by
changing the loop index within the C program (e.g., stepping through
every two points in the table).When you exit CCS after you build a project,
24
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
all changes made to the project can be saved. You can later return to the
project with the status as you left it before. For example, when returning
to the project after launching CCS, select Project Open to open an
existing project such as sine8_LED.pjt (with all the necessary files for the
project already added).
This example illustrates input and output with the AIC23 codec. Figure 2.4
shows the C source program loop_intr.c, which implements the loop
program. It is interrupt-driven using INT11.
25
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. Create and build this project as loop_intr. The main C source file is in
the folder loop_intr. Note that the vector file for the interrupt-driven
and linker command file located in the folder support, and the
runtime support, board support, and chip support library files that
can be added with the building option for the linker.
2. Input a sinusoidal waveform to the LINE IN connector on the DSK,
with an amplitude of approximately 2 V p-p and a frequency
26
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Rebuild the project, making sure that you are adding c6713dskinit.c
from the folder loop_intr (and not from the folder support). In this
fashion, the corresponding header file c6713dskinit.h that will be
included will come from that same folder.
Load/run the executable file loop_intr.out, and verify that the output
amplitude is not attenuated and is the same as the input amplitude
of 2V p-p. Values for the set-up register 0 from 0x0018 to 0x001c
will cause the output amplitude to increase from 0.8 to 2V p-p.
27
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
28
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
3- Choose Target for TI C6000 library again ,then choose C6713 DSK
Board Support, then drag DAC (digital to analog convertor) to your file
29
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
30
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
31
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
6- Double Click on Sine Wave Block and Choose the required parameters:
7- Double Click on Sine Wave Block and choose the required parameters:
32
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Note that the sampling frequency for both Sine wave and DAC must be
the same.
8- Save your file in any directory , and select this directory before
execution ( change Current Directory).
9- From SimulationSimulation ParametersSolver , change stop time to
inf.
10- Choose incremental build icon (Notice the execution steps that
done automatically). Verify the results on CRO.
11- Try to modify the frequency and amplitude.
33
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2.1 Objectives
a) Show the students how to use DSP processors to generate real time signals such as square wave,
ramp signal
Square wave can be generated either by using either the Fourier series expansion or by using direct
synthesis. Each of these methods will be described briefly in the next subsection
Square wave can be generated as a an infinite sum of odd harmonics according to Fourier series
expansion as described mathematically by
n=
1
s (t )= sin ( n 0 t)( SEQ Equation 1)
n=1 n
n odd
1
n=
In equation (1 s ( t ) = 1 sin ( n 0 t) Error: Reference source not found) s (t ) represent the
n=1 n
n odd
square wave, n is the number of harmonics and 0 is the fundamental radian frequency of the
generated wave.
However it is practically impossible to include an infinite number of harmonics to synthesize the square
wave. Only few numbers of harmonics can be used to synthesize the square wave.
34
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
If for example we used two harmonics to generate the square wave then we would have a square wave
as shown Figure 14
If the number of harmonics n is increased to n=11 , then the signal gets closer to the perfect
square as shown in Figure 15
If the number of harmonics is increased more, then the synthesized square wave gets closer to an ideal
square wave as shown by Figure 16
35
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Figure 16 Square wave generated by the addition of harmonics where the number of harmonics n=79 .
It can be noticed from the previous graph that the ripple present in the generated wave from, and both
the rise and the fall time became smaller as the number of the harmonics used is increased more. The
ripple is known as the Gibbs phenomenon.
The second way to generate square wave is to use a lookup table with a finite length. If half of the look
up table is filled by the maximum DAC amplitude of the AIC23 codec (
15
maximum amplitude=2 1=32767 and the second half of the table is filled by minimum
amplitude ( minimum amplitude=215=32768 ), then a square wave will be generated.
Ramp signals are useful type of signal used in measurement systems to perform sweep operation. This
kind of signals can be used in the design of spectrum analyzers, GSM jammers and many other
applications.
2.3 Sampling
Sampling is the process of converting a continuous time signal into discrete time signal. As we know from
the sampling theory, the sampling frequency must be at least greater than twice the bandwidth of the
analog signal as explained by the sampling theory
f s 2 f m 1
In this experiment a simple program for sampling a signal from the function generator will be considered
36
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
In this section the various methods for square wave and ramp signal generation will be produced using
the procedures detailed below.
1. Open the project that you have made in the previous lab
short square_table[N]={0}; //a look table used to store sample values for the square
wave
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to the
interrupt service routine
37
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
for (j=0;j<n;n++) //This loop counts advances the sampling time (nTs) which is
used in computing the samples
for (i=1;i<=N;i+=2) // This for loop computes sample from each harmonic and adds
them up all the samples in one memory location
square_table[j]=square_table[j]+(21*gain/i)*sin(2*pi*f0*i*j*Ts);
return; // program execution goes back to while(1) and then again starts listening for
next interrupt and this process goes on
void main()
while(1); //program execution halts and it starts listening for the interrupt which
occur at every sampling period Ts.
6. Exercise add slider to your program in order to change the number of harmincs from 1 to 11
and see the effect on the ripple and the.
Question 1. What happens to the ripple if the number of harmonics is increased? What
happens to the ripple if the number of harmonics is reduced?
1. Write a c code to generate a square wave using interrupt technique. You may use the code in
Figure 17 for assistance
38
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. Write a c code to generate a ramp wave using the interrupt technique. You may use the code
in Figure 18 for assistance
39
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Observer the generated signal you see on the oscilloscope and explain how the frequency and slope of
the ramp signal can be changed
In this part of the circuit a small program will be written to read data from the function generator
connected to line in of the DSK6713 kit. The sampling frequency used for reading the data is 8 kHz
1. Write a c program to read the signal from the LINE IN input of the DSK6713 and write the
data back to the line out. You can use the code shown in Figure 19 to help you performing
this task
40
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. After compiling and running your program, connect a signal from the function generator to
the LINE IN terminal
3. Set the function generator to sine wave, the amplitude of the signal to 1 V PP, and the
frequency to 1 kHz and plot the signal as it appears on the screen of the oscilloscope
4. Repeat step 3 for a square wave
5. Increase the frequency of the modulated signal from 1 kHz to 5 kHz, then plot the signal as it
appears on the oscilloscope. Explain the signal shape of the signal you see on the
oscilloscope
Question 5. Determine the frequency of the reconstructed signal if the input signal
frequency is f =7 kHz and the sampling frequency is 8 kHz
In this part of the experiment you will take samples from a signal applied to LINE IN taken from the
function generator; at a frequency of 8 kHz, then investigate the effect of down sampling.
Recall that from the DSP course that down sampling was performed on a given signal in order to reduce
the processing time taken by the DSP processor. Down sampling is illustrated by Figure 20
41
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
If a signal down sampled by factor M , then its spectrum is increased t by a factor of M . This
increase in the spectrum may lead to aliasing as illustrated by the Figure 21
However, the effect of aliasing resulting from the down sampling process can be reduced by using a low
pass filter before the down sampler. This filter is known as antialias filter. The cut off frequency of the
fs
antialias filter is selected such that f c= .
2M
In this part of the experiment students will examine the effect of down sampling on a given signal, then
down sample the captured samples and investigate the effect of aliasing and the use of antialis filter
42
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
43
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
3.1 Objectives
The aim of this experiment to show that a complex modulation schemes such as ASK or FSK can
be generated by DSP processors before transmitting data such as voice through a wireless
channel
3.2 Introduction
Amplitude Shift Keying (ASK) and frequency shift keying are two fundamental digital modulation
techniques. The generation of these two modulation schemes will be considered in this
experiment
s (t )=
{ Acos(2 f c t ) logic one
0 logic zero }
Amplitude shift keying in the context of digital signal communications is a modulation process,
which imparts to a sinusoid two or more discrete amplitude levels. These are related to the
number of levels adopted by the digital message. For a binary message sequence there are two
levels, one of which is typically zero. Thus the modulated waveform consists of bursts of a
sinusoid. Figure 22 illustrates a binary bit stream and the ASK modulated signal. Neither signal is
band limited.
44
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
There are sharp discontinuities shown at the transition points. These result in the signal having an
unnecessarily wide bandwidth. Band limiting is generally introduced before transmission, in which case
these discontinuities would be rounded off. The band limiting may be applied to the digital message, or
the modulated signal itself. The data rate is often made a sub-multiple of the carrier frequency. This has
been done as illustrated in Figure 22.
Recall that ASK signal is generated by multiplying the bit stream by the carrier signal. The carrier
frequency and the number of cycles per bit are related by
numbr of cycles
f c=
Tb
If for example a given bit stream is to be transmitted at a bit rate of 1200 bits/s, then the bit duration is
1
T b= =833 .33 s . If the carrier is to have 4 cycles per bit then, then the carrier frequency
1200
4
must be selected such that f c = 6
=4800 Hz .
833 . 33 10
The other parameters to specify when implementing ASK is to specify the sampling frequency and the
number of samples. For the example mentioned in this experiment, the sampling frequency must be
f s 2 f m 2 4800 9600 Hz . Therefore we select a sampling frequency of 48 kHz to satisfy the
Nyquist criteria. The number of samples is determined from
nf c 4800
=number of cycles n =4 n=40 samples
fs 48000
45
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Frequency-shift keying (FSK) is a method of transmitting digital signals. The two binary states, logic 0
(low) and 1 (high), are each represented by an analog waveform. Logic 0 is represented by a wave at
a specific frequency, and logic 1 is represented by a wave at a different frequency. A modem
converts the binary data from a computer to FSK for transmission over telephone lines, cables,
optical fiber, or wireless media. The modem also converts incoming FSK signals to digital low
and high states, which the computer can "understand."
The relation between the carrier frequencies used to represent logic 1 and logic 0 are determined
from
h
f 1 f 2 =
Tb
Where f 1 is the frequency used to represent logic 1 while f 2 is the frequency used to
represent logic 0, and h=0 .5 , 1 ,1 . 5 , ,etc is called the deviation ratio.
If h=0 .5 , then the we have a special kind of FSK called minimum shift keying (MSK). In MSK
minimum means that the minimum frequency spacing between logic 1 and logic where the
carriers are still orthogonal. If h<0 . 5 then the carriers representing logic 1 and logic 0 are no
longer orthogonal, this will degrade the average probability of error performance of the FSK
system.
if h is made larger, the demodulation of the FSK signal became simpler. However larger
values of h means that the peak frequency deviation is larger, which means that a larger
bandwidth requirements for the FSK signal.
The approximate bandwidth (using Carsons rule) required for the transmission of the FSK signal
is given by
BW =2 f + 2 Rb
46
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. Set the sampling frequency to f s=32 kHz and the carrier frequency f c =4000 Hz
2. Set the number of samples to 16 samples
3. Use the following code to generate an ASK modulated signal.
#include "dsk6713.h"
int cnt=0,data[8]={0},k;
short i,j,sine_table[N],cos_table[N];
void main()
47
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
comm_poll();
printf("Enter the Binary Elements of Sequence (0 or 1)\n"); //prints the line on CCS
window
for(k=0;k<=7;k++)
for(i = 0;i<N;i++)
// write the sample values of waveform at every sampling instant
48
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
sine_table[i] = 10000*sin((2.0*pi*i/32000)*4000); //
generation of sine-wave signal using formula, value is taken in a loop.
if(i>N) i = 0;
while(1)
//program execution halts and it starts listening for the interrupt which occur at every
sampling period Ts.
if(cnt<=7)
for(j=0;j<N;j++)
output_sample(sine_table[j]);
49
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
else for(j=0;j<N;j++)
output_sample(0);
if(j>=N)j=0;
cnt++;
if(cnt>7) cnt=0;
50
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Note that sampling frequency must be 32kHz (as in modulator), samples/frame=1, cut off frequency of
the low pass filter =2 kHz.
Question 4. Is there any alternative way to demodulate the ASK signal? Explain in your
report
6. Modify the above code in order to generate an FSK signal
Question 5. How can the FSK signal be demodulated?
Question 6. Suppose that the carrier frequency used to generate logic 1 is 4 kHz and that
used to generate logic zero is 8 kHz, what would be the bandwidth required for this FSK
signal? Is there any special name given this FSK modulation scheme?
51
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
4 Experiment 4 QPSK
4.1 Objectives
The objectives of this experiment is to show students how to generate QPSK signal using DSP processors
4.2 Theory
Quadrature Phase Shift Keying (QPSK) can be interpreted as two independent BPSK systems
(one on the I-channel and one on Q-channel). Therefore it has twice the bandwidth efficiency
compared with BPSK. Quadrature Phase Shift Keying has twice the bandwidth efficiency of BPSK
since two bits are transmitted in a single modulation symbol.
In QPSK there are large envelope variations occur due to abrupt phase transitions, thus QPSK
signal requires linear amplification in the receiver.
QPSK uses four points on the constellation diagram, equally spaced around a circle as shown in
Error: Reference source not found. With four phases, QPSK can encode two bits per symbol,
shown in the diagram with gray coding to minimize the bit error rate (BER) sometimes
misperceived as twice the BER of BPSK.
The mathematical analysis shows that QPSK can be used either to double the data rate
compared with a BPSK system while maintaining the same bandwidth of the signal, or to
maintain the data-rate of BPSK but halving the bandwidth needed. In this latter case, the BER of
QPSK is exactly the same as the BER of BPSK and deciding differently is a common confusion
when considering or describing QPSK.
Given that radio communication channels are allocated by agencies such as the Federal
Communication Commission giving a prescribed (maximum) bandwidth, the advantage of QPSK
over BPSK becomes evident: QPSK transmits twice the data rate in a given bandwidth compared
to BPSK at the same BER. The engineering penalty that is paid is that QPSK transmitters and
52
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
receivers are more complicated than the ones for BPSK. However, with modern electronics
technology, the penalty in cost is very moderate.
4.2.1 Implementation
The implementation of QPSK is more general than that of BPSK and also indicates the
implementation of M-ary PSK. QPSK is described mathematically by
s i (t )=
( 2 Es
Ts ) (
cos 2 f c t +
2 (i 1 )
4 )
, i=1 ,2 , 3 , 4
3 5 7
This yields the four phases of the carrier , , and . The previous
4 4 4 4
equation can be further simplified by expanding the cosine term using trigonometric identities
as shown below
s i ( t )= E s cos
This results in a two-dimensional signal space diagram with unit basis functions. The first basis
function; 1 ( t )=
2
Ts
cos ( 2 f c t ) ; is used as the in-phase component of the signal and the
Hence, the signal constellation consists of the signal-space 4 points. The four symbol points in
vector form are given by
[ ]
s=i
( ( 2 i1 ) )
Es cos 4
E sin ( ( 2i1 ) )
s
4
53
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
In this experiment both modulator and demodulator for QPSK will be implemented by using the
DSK6713 starter kit.
QPSK signal can be generated in the code by using the following procedure
1. Initialize temporary variables to hold a sample values from both the in-phase and quadrature
phase components.
2. If the first bit in the data sequence is one multiply the in-phase carrier by one and add the result
to the temporary in-phase component defined in step 1 else multiply the carrier by -1 and add
the result to the temporary in-phase component defined in step 1.
3. If the second bit in the sequence is 1 multiply the quadrature- phase carrier by one and add the
result to the temporary quadrature-phase component else multiply the quadri-phase carrier by
-1 and add the result to the temporary quadrature-phase.
4. Add the in-phase and quadrature-phase components, then send the result to the DAC output
using output_sample ( ) function.
5. Repeat step 4 until the 16th carrier samples are sent.
6. Reset the sample counter to zero.
7. Get the next two bits from the data buffer and repeat steps 1-5 again.
8. Repeat step 7 until all the data bits are being transmitted.
54
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
7. Set the sampling frequency to f s=32 kHz and the carrier frequency f c =4000 Hz
8. Set the number of samples to 16 samples
9. Use the following code to generate an QPSK modulated signal.
#include "dsk6713.h"
int cnt=0,data[8]={0},k;
short i,j,sine_table[N],cos_table[N];
void main()
55
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
printf("Enter the Binary Elements of Sequence (0 or 1)\n"); //prints the line on CCS
window
for(k=0;k<=7;k++)
for(i = 0;i<N;i++)
// write the sample values of waveform at every sampling instant
if(i>N) i = 0;
cos_table[i] = 10000*cos((2.0*pi*i/32000)*4000); //
generation of cos-wave signal using formula, value is taken in a loop.
56
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
while(1)
{
if(j>=N)
j=0;
cnt++;
if(cnt>7) cnt=0;
57
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
DSK6713 of your colleagues kit. Setup the design shown in Figure 24 by using simulink in the
receiving DSK6713 kit. Verify that this circuit demodulates the QPSK signal
Note that sampling frequency must be 32 kHz (as in modulator), samples/frame=1, cut off frequency of
the low pass filter =2 kHz. Embedded MATLAB Function is used as comparator device , you can write the
following code inside:
Question 9. Explain in your report how to achieve synchronization between the carriers in
both the transmitter and receiver.
58
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. In MATLAB open the filter design tool by typing the fdatool in the MATLAB command window. A
design window such as the one shown in Figure 29 will appear on the screen.
59
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. Set the response type to Low pass filter, the design method to FIR window, filter order 100,
window Hamming, sampling frequency to f s=8 kHz and the carrier frequency
f c =2400 Hz
3. Press on the design button to design the filter.
4. In order to obtain the filter coefficients go to the file menu then select export. A small dialog box
such as the one shown in Figure 30 will appear. Select export to coefficient File (ASCII) and press
on the export button. Name your file as lpf.cof and save it under your project directory. The
file contains the filter coefficient that is needed by project
5. Modify the filter coefficient file by adding the following two statements
#define N 101 //number of coefficients
6. To implement the filter on the DSK6713 kit open the existing project that you worked on last
time and add the following c code to it.
#include "lpf.cof" //coefficient file
60
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
short i;
return;
void main()
7. After you build the project, load it on the DSK6713 kit, then run the program.
8. To test the designed LPF filter, connect a sine wave from the function generator to the LINE IN
terminal of the DSK6713 kit.
9. Set the amplitude of the sign wave to 1V pp and vary the frequency of the sine wave from 50
Hz to 3.4 kHz in steps of 200 Hz. Measure the amplitude of the output wave at every frequency
point and tabulate your results as shown in Table 1
freq 50 400 600 1000 1400 1600 1800 2000 2200 2400 2600 3000 3200 3400
Am
Table 1
61
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
10. An alternative way to test your filter is to apply an input random signal, then connect the filter
output to the spectrum analyzer. This can be achieved by generated the random signal through
the MATLAB Simulink as shown in Figure 31
11. Set the sample time for the noise to 1/8000 and it type is Gaussian.
12. Connect the output of the DSK kit to your pico-scope and adjust the scope for spectrum
operation
13. Sketch the frequency response of the filter as it appears on the screen of the spectrum analyzer
5.2.2 Low pass, high pass, band pass and pass band filter
In this exercise we will design four filters using the same procedure used in the previous section. The
student is supposed to design the four filter types in MATLAB then export the filters coefficients to a
different file depending on the filter type.
A slider can be used to select which filter to use as illustrated by the following c source file. Select the
cutoff frequency of the low pass filter as f c =1500 Hz , the cut off frequency of the High pass filter as
f c =2200 Hz , the center frequency of the bandpass filter as f c =1750 Hz , and the band stop of
the band stop filter as f bs=790 Hz .
FIR filter:
62
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
High pass,2200hz,
**********************************************************************************************/
Uint32 fs=DSK6713_AIC23_FREQ_8KHZ; // set the sampling frequency, Different sampling frequencies supported by
AIC23 codec are 8, 16, 24, 32, 44.1, 48, and 96 kHz.
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to the interrupt service routine
63
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
output_sample(yn >> 15); //output filter,the value in the buffer yn indexed by the
variable loop is written on to the codec.
void main()
for (i=0; i<N; i++) //for loop which takes in the value of i from 0 to
N=4 and switches to corresponding filter co-efficients
You need also to add the following GEL file to your project
64
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
5.2.3 Effects on voice using three FIR low pass filters (FIR3LP)
In this exercise you will implement three FIR low pass filters with cutoff frequencies at 600, 1500, and
3000Hz, respectively. The three low pass filters were designed with MATLABs fdatool to yield the
corresponding three sets of coefficients.
If for example LP_number is set to 0, h[0][i] is equal to hlp600[i] (within the for loop in the
function main), which is the address of the first set of coefficients. The coefficients file LP600.cof
represents an 81-coefficient FIR low pass filter with a 600-Hz cutoff frequency, using the Kaiser window
function. your program may appear as the one shown below. LP_number can be changed to 1 or 2 to
implement the 1500- or 3000-Hz low pass filter, respectively.
65
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
short i;
void main()
short i;
66
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
With the GEL file FIR3LP.gel, one can vary LP_number from 0 to 2 and slide through the three different
filters. Build this project as FIR3LP. Use a .wav file from your PC as input and observe the effects of the
three low pass filters on the input voice. Connect the LINE OUT of the DSK6713 to a speaker and observe
what happens when the different filters are used
67
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
6.2 Theory
Infinite impulse response (IIR) filters are described by the general difference equation which is
given by
N M
y [ n ] = a k x [nk ] b j y [n j]
k=0 j=1
This difference equation can be solved recursively to produce the output samples from the
input samples.
The design of an IIR filter require the computation of the filter coefficients a k and bk .
These filter coefficients can be determined either by using the impulse invariance method or by
using the bilinear transformation design techniques presented by the DSP course. However the
calculation of the filter coefficients is greatly simplified by using commercial software such as
MATLAB or digifilter.
IIR filters can be implemented by using either direct form I or direct form II structure as
illustrated in Error: Reference source not found.
(b)
(a)
68
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Figure 32 (a) direct form I IIR structure. (b) Direct form II IIR structure.
Direct form II requires almost half the delay elements compared with direct form I, therefore
direct form II is the commonly used structure used to implement IIR filters.
The transfer function of the filter can be implemented by using structures other than direct
form I and direct form II structures. Some of these structures are the transposed form structure,
cascade form structure, parallel form structure and the lattice structure.
In this experiment only cascade form structure and parallel form structure will be considered.
H ( z ) =CH 1 ( z ) H 2 ( z ) . H r ( z )
The cascade (series) connection of the first or second order sections is illustrated by the block
diagram shown in Figure 33
For example, a fourth-order IIR structure can be implemented in terms of two second-order sections in
cascade is shown in Figure 34.
Figure 34 Fourth-order IIR filter with two direct form II sections in cascade.
The transfer function of the above mentioned fourth order IIR filter is given mathematically by
69
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
H ( z ) =C+ H 1 ( z )+ H 2 ( z ) ++ H 3 (z )
This can be obtained by using a partial fraction expansion. The block diagram of the parallel form
structure is shown in Figure 35. Each of the transfer functions H 1 ( z) , H 2 (z) , ., etc.
As with the cascade structure, the parallel form can be efficiently represented in terms of second-order
direct form II structure sections. For example, for a fourth-order transfer function, H (z) can be
expressed as
70
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. In MATLAB command window open the SPTool filter design tool by typing SPTool in the MATLAB
command window. A design window such as the one shown in Figure 29 will appear on the
screen.
2. From the startup window; second column in Figure 29; select new. A design window such as the
one shown in Figure 37 will pop up. From the design window select an IIR filter Elliptic, set the
response to low pass and specify the filter order to 10. Set the sampling frequency to
f s=8 kHz and the cut off frequency f c =2400 Hz
71
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
3. Access the startup window in SPTool again. Select EditName. Change the name (enter new
variable name) to lp2400
4. Select File Export Export to workspace the lp2400 design.
5. Access MATLABs workspace and type the following commands:
>>[z,p,k] = tf2zp(lp2400.tf.num, lp2400.tf.den);
>>sec_ord_sec = zp2sos(z,p,k);
>>sec_ord_sec = round(sec_ord_sec*2^15)
The first command finds the roots of the numerator and the denominator (zeros and poles). The
second command converts the resulting floating-point coefficients into a format for implementation
as second-order sections. The third command scales these coefficients for a fixed-point
implementation. The resulting numerator and denominator coefficients should be listed as
72
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The coefficients using SPTool should be contained in the file lp2400.cof, listed below. This file shows
25 coefficients (in lieu of 30).
//lp200.cof IIR low pass coefficient file, with cut off at 2400Hz
};
};
73
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
6. The IIR filter can be implemented by using the following two equations associated with each
stage :
u ( n )=x ( n )b1 u (n1)b2 u (n2)
7. The loop section of code within the program is processed five times (the number of stages) for
each value of n , or sample period. For the first stage, x (n) is the newly acquired input
sample. However, for the other stages, the input x (n) is the output y (n) of the
preceding stage.
8. The coefficients b[ i][0] and b[i][1] correspond to b1 and b2 , respectively; where
i represents each stage. The delays dly [i][0] and dly [i][1] correspond to u(n1)
and u(n2) , respectively.
9. To implement the filter IIR filter on the DSK6713 kit open the existing project that you worked on
last time and add the following c code to it.
//IIR.c IIR filter using cascaded Direct Form II
//Coefficients a's and b's correspond to b's and a's from MATLAB
short i, input;
un=input-((b[i][0]*dly[i][0])>>15) - ((b[i][1]*dly[i][1])>>15);
yn=((a[i][0]*un)>>15)+((a[i][1]*dly[i][0])>>15)+((a[i][2]*dly[i][1])>>15);
74
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
void main()
10. After you build the project, load it on the DSK6713 kit, then run the program.
11. To test the designed LPF filter, connect a sine wave from the function generator to the LINE IN
terminal of the DSK6713 kit.
12. Set the amplitude of the sign wave to 1V pp and vary the frequency of the sine wave from 50
Hz to 3.4 kHz in steps of 200 Hz. Measure the amplitude of the output wave at every frequency
point and tabulate your results as shown in Table 1
freq 50 400 600 1000 1400 1600 1800 2000 2200 2400 2600 3000 3200 3400
Am
Table 2
13. Repeat the process and design high pass with cutoff frequency of 2200 Hz, band pass filter with
a center frequency of 1750 Hz and a bandstop filter with band stop centered at 1750 Hz
frequency of
75
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
This example illustrates an IIR inverse filter. With noise as input, a forward IIR filter is calculated. The
output of the forward filter becomes the input to an inverse IIR filter. The output of the inverse filter is
the original input noise sequence.
N 1
ai zi
H ( z ) = Mi=0
1
b j zi
j=1
N1 M1
y ( n )= a i x (ni) b j x (n j)
i=0 j =1
where x (ni) represents the input sequence. The input sequence x (n) can then be recovered
using x^ (n) as an estimate of x (n) , or
M1 N1
^x ( n )=
( y ( n ) + b j y ( n j ) a i ^x ( ni )
j=1 i=1
)
a0
The program IIRinverse.c implements the inverse IIR filter. Build this project as IIRinverse. Use noise as
input to the system. Run the program and verify that the resulting output is the input noise (with the
slider in the default position 1).
Change the slider and verify that the output of the forward IIR filter is an IIR bandpass filter centered at
2 kHz. The coefficient file bp2000.cof was used in Example 5.1 to implement an IIR filter. With the slider
in position 3, verify that the output of the inverse IIR filter is the original input noise.
In this example, the forward filters characteristics are known. This example can be extended so that the
filters characteristics are unknown. In such a case, the unknown forward filters coefficients, as and bs,
can be estimated using Pronys method [9].
76
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
a1 = ((a[i][1]*dly[i][0])>>15); //a1*u(n-1)
a2 = ((a[i][2]*dly[i][1])>>15); //a2*u(n-2)
b1 = ((b[i][0]*dly[i][0])>>15); //b1*u(n-1)
b2 = ((b[i][1]*dly[i][1])>>15); //b2*u(n-2)
a0=((a[i][0]*un1)>>15);
77
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
a1 = ((a[i][1]*dly[i][0])>>15); //a1u(n-1)
a2 = ((a[i][2]*dly[i][1])>>15); //a2u(n-2)
b1 = ((b[i][0]*dly[i][0])>>15); //b1u(n-1)
b2 = ((b[i][1]*dly[i][1])>>15); //b2u(n-2)
void main()
78
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Adaptive filters are filters with varying coefficients. These filters are used in applications where a
given system is changing its coefficients in an unknown manner. A typical system can be either a
communication channel whose coefficients are changing with either temperature or number of
users.
In such cases it is highly desirable to design the filter to be self-learning so that it can adapt itself
to the situation at hand.
The coefficients of an adaptive filter are adjusted to compensate for changes in input signal,
output signal, or system parameters. Instead of being rigid, an adaptive system can learn the
signal characteristics and track slow changes. An adaptive filter can be very useful when there is
uncertainty about the characteristics of a signal or when these characteristics change.
Conceptually, the adaptive scheme is fairly simple. Most of the adaptive schemes can be
described by the structure shown in Figure 38. This is a basic adaptive filter structure in which
the adaptive filters output y is compared with a desired signal d to yield an error signal
e , which is fed back to the adaptive filter.
The error signal is input to the adaptive algorithm, which adjusts the filters coefficients to
satisfy some predetermined criteria or rules. The desired signal is usually the most difficult one
to obtain. One of the first questions that probably come to mind is: Why are we trying to
generate the desired signal at y if we already know it? Surprisingly, in many applicationsthe
desired signal does exist somewhere in the system or is known a priori. The challenge in
applying adaptive techniques is to figure out where to get the desired signal, what to make the
output y , and what to make the error e .
79
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The coefficients of the adaptive filter are adjusted, or optimized, using an LMS algorithm based
on the error signal. Here we discuss only the LMS searching algorithm with a linear combiner
(FIR filter), although there are several strategies for performing adaptive filtering. The output of
the adaptive filter in Figure 38 is
N 1
y [ n ] = w k [ n ] x [nk ]
k=0
Where w k [n] represent N weights or coefficients for a specific time n . The above
mentioned equation represents the convolution which was implemented for the FIR
experiment.
The error signal is defined as the difference between the desired signal d [ n ] and the
adaptive filters output y [ n] .
e [ n ] =d [ n ] y [n]
The weights or coefficients w k [n] are adjusted such that a mean squared error function is
minimized. This mean squared error function is E[e 2 [n]] , where E represents the
expected value. Since there are k weights or coefficients, a gradient of the mean squared
error function is required. An estimate can be found instead using the gradient of e 2 [n ],
yielding
w k [ n+1 ]=wk [ n ] +2 e [ n ] x [ nk ] k =0 , 1, , N1
Adaptive filters have been used for different applications such as:
1. For noise cancellation as illustrated in Figure 39. The desired signal d is corrupted by
uncorrelated additive noise n . The input to the adaptive filter is a noise n ' that is
correlated with the noise n . The noise n ' could come from the same source as
n but modified by the environment. The adaptive filters output y is adapted to
the noise n . When this happens, the error signal approaches the desired signal d .
The overall output is this error signal and not the adaptive filters output y . If d is
uncorrelated with n , the strategy is to minimize E( e2 ) , where E( ) is the
expected value. The expected value is generally unknown; therefore, it is usually
approximated with a running average or with the instantaneous function itself. Its signal
2
component, E ( d 2 ) , will be unaffected and onlyits noise component E[ ( n y ) ] will
be minimized.
80
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. For system identification. Figure 40 shows an adaptive filter structure that can be used
for system identification or modeling. The same input is to an unknown system in
parallel with an adaptive filter. The error signal e is the difference between the
response of the unknown system d and the response of the adaptive filter y . This
error signal is fed back to the adaptive filter and is used to update the adaptive filters
coefficients until the overall output y=d .When this happens, the adaptation process
is finished, and e approaches zero. If the unknown system is linear and not time-
varying, then after the adaptation is complete, the filters characteristics no longer
change. In this scheme, the adaptive filter models the unknown system. This structure is
illustrated later with three programming examples.
3. Inverse system modeling (e.g. channel equalization in modems) which is shown in Figure 41
81
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
4. Adaptive predictor. Figure 42 shows an adaptive predictor structure that can provide an estimate
of an input. This structure is illustrated later with a programming example.
A desired sine wave of 1500 Hz with an additive (undesired) sine wave noise of 312 Hz forms one of two
inputs to the adaptive filter structure. A reference (template) cosine signal, with a frequency of 312Hz, is
the input to a 30-coefficient adaptive FIR filter. The 312-Hz reference cosine signal is correlated with the
312-Hz additive sine noise but not with the 1500-Hz desired sine signal.
For each time n , the output of the adaptive FIR filter is calculated and the 30 weights or coefficients
are updated along with the delay samples. The error signal e is the overall desired output of the
adaptive structure. This error signal is the difference between the desired signal and additive noise
(dplusn) and the adaptive filters output, y (n) .
1. In MATLAB,generate the desired signal, the noise plus the desired signal and the reference noise
according to the following MATLAB commands
%Adaptnoise.m Generates: dplusn.h, refnoise.h, and sin1500.h
for i=1:128
end
82
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
dplusn= desired+addnoise;
fprintf(fid,'short sin1500[128]={');
fprintf(fid,'%d' ,desired(128));
fprintf(fid,'};\n');
fclose(fid);
fprintf(fid,'short dplusn[128]={');
fprintf(fid,'%d' ,dplusn(128));
fprintf(fid,'};\n');
fclose(fid);
fprintf(fid,'short refnoise[128]={');
fprintf(fid,'%d' ,refnoise(128));
fprintf(fid,'};\n');
fclose(fid);
2. In your code composer studio use the following code to implement an adaptive filter
#include"DSK6713_AIC23.h"//codecDSKsupportfile
uint32fs=DSK6713_AIC23_FREQ_8KHZ;//setsamplingrate
#include"refnoise.h"//cosine312Hz
#include"dplusn.h"//sin(1500)+sin(312)
#definebeta1E10//rateofconvergence
83
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
#defineN30//#ofweights(coefficients)
#defineNS128//#ofoutputsamplepoints
floatw[N];//bufferweightsofadaptfilter
floatdelay[N];//inputbuffertoadaptfilter
shortoutput;//overalloutput
shortout_type=1;//outputtypeforslider
interruptvoidc_int11()//ISR
shorti;
staticshortbuffercount=0;//initcountof#outsamples
floatyn,E;//outputfilter/"error"signal
delay[0]=refnoise[buffercount];//cos(312Hz)inputtoadaptFIR
yn=0;//initoutputofadaptfilter
for(i=0;i<N;i++)//tocalculateoutofadaptFIR
yn+=(w[i]*delay[i]);//outputofadaptivefilter
E=dplusn[buffercount]yn;//"error"signal=(d+n)yn
for(i=N1;i>=0;i)//toupdateweightsanddelays
w[i]=w[i]+beta*E*delay[i];//updateweights
delay[i]=delay[i1];//updatedelaysamples
buffercount++;//incrementbuffercount
if(buffercount>=NS)//ifbuffercount=#outsamples
buffercount=0;//reinitcount
if(out_type==1)//ifsliderinposition1
84
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
output=((short)E*10);//"error"signaloveralloutput
elseif(out_type==2)//ifsliderinposition2
output=dplusn[buffercount]*10;//desired(1500)+noise(312)
output_sample(output);//overalloutputresult
return;//returnfromISR
voidmain()
shortT=0;
for(T=0;T<30;T++)
w[T]=0;//initbufferforweights
delay[T]=0;//initbufferfordelaysamples
comm_intr();//initDSK,codec,McBSP
while(1);//infiniteloop
7.4 Adaptive FIR filter for noise cancellation using external inputs
This example extends the previous one to cancel an undesirable sinusoidal noise using external inputs.
The source program shown below allows two external inputs: a desired signal and a sinusoidal
85
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
interference. The program uses the union structure introduced in Chapter 2 with the project example
loop_stereo. A 32-bit signal is captured using this structure that allows an external 16-bit input signal
through each channel. The 16-bit desired signal is input through the left channel and the undesirable 16-
bit signal through the right channel. An adapter with two connectors at one end for each input signal
and one connector at the other end, which connects to the DSK, was introduced in Chapter 2 with the
loop_stereo project and is required to implement this example. The basic adaptive structure in Figure 39 is
applied here along with the LMS algorithm.
#include"DSK6713_AIC23.h"//codecDSKsupportfile
uint32fs=DSK6713_AIC23_FREQ_48KHZ;//setsamplingrate
#definebeta1E13//rateofconvergence
#defineN30//#ofweights(coefficients)
#defineLEFT0
//leftchannel
#defineRIGHT1//rightchannel
floatw[N];//weightsforadaptfilter
floatdelay[N];//inputbuffertoadaptfilter
shortoutput;//overalloutput
shortout_type=1;//outputtypeforslider
volatileunion{unsignedintuint;shortchannel[2];}AIC23_data;
interruptvoidc_int11()//ISR
shorti;
floatyn=0,E=0,dplusn=0,desired=0,noise=0;
AIC23_data.uint=input_sample();//input32bitfrombothchannels
dplusn=(AIC23_data.channel[LEFT]);//inputleftchannel
noise=(AIC23_data.channel[RIGHT]);//inputrightchannel
delay[0]=noise;//noiseasinputtoadaptFIR
for(i=0;i<N;i++)//tocalculateoutofadaptFIR
yn+=(w[i]*delay[i]);//outputofadaptivefilter
E=(dplusn)yn;//"error"signal=(d+n)yn
86
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
for(i=N1;i>=0;i)//toupdateweightsanddelays
w[i]=w[i]+beta*E*delay[i];//updateweights
delay[i]=delay[i1];//updatedelaysamples
if(out_type==1)//ifsliderinposition1
output=((short)E);//errorsignalasoveralloutput
elseif(out_type==2)//ifsliderinposition2
output=((short)dplusn);//output(desired+noise)
output_sample(output);//overalloutputresult
return;
voidmain()
shortT=0;
for(T=0;T<30;T++)
w[T]=0;//initbufferforweights
delay[T]=0;//initbufferfordelaysamples
comm_intr();//initDSK,codec,McBSP
while(1);//infiniteloop
1. Using your PC soundcard and the MATLAB. Generate 1.5 kHz sinusoidal signal from the function
generator to represent the desired signal and another sinusoidal signal with 2 kHz; which
represents the additive noise signal; and another cosine 2 kHz signal to represent reference
noise as shown in Figure 43:
87
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Figure 43
2. Run the program. Verify that the 2-kHz noise signal is being canceled gradually. You can adjust
the rate of convergence by changing beta by a factor of 10 in the program.
3. Access/load the slider program adaptnoise_2IN.gel and change the slider position from 1 to 2.
Verify the output as the two original sinusoidal signals at 1.5 kHz and at 2 kHz.
4. Desired: wideband random noise; undesired: 2 kHz. Input random noise (from a noise generator,
MATLAB.) as the desired wideband signal into the left input channel and the undesired 2-kHz
sinusoidal noise signal into the right input channel. Restart/run the program. Verify that the 2-
kHz sinusoidal noise signal is being canceled gradually, with the wideband random noise signal
remaining. With the slider in position 2, observe that both the undesired and desired input
signals are.
7.4.1 Adaptive FIR Filter for System ID of a Fixed FIR as an Unknown System
Adaptive filters can be used for system identification as illustrated in Figure 40.
To test the adaptive scheme, the unknown system to be identified is chosen as an FIR bandpass filter
with 55 coefficients centered at Fs/4=2 kHz . The coefficients of this fixed FIR filter are in the file
bp55.cof, introduced in Chapter 4. A 60-coefficient adaptive FIR filter models the fixed unknown FIR band
pass filter.
A pseudorandom noise sequence is generated within the program (see examples 2.16 and 4.4 in Rulph
chassing) and becomes the input to both the fixed (unknown) and the adaptive FIR filters. This input
signal represents a training signal. The adaptation process continues until the error signal is minimized.
This feedback error signal is the difference between the output of the fixed unknown FIR filter and the
output of the adaptive FIR filter.
An extra memory location is used in each of the two delay sample buffers (fixedand adaptive FIR). This is
used to update the delay samples (see method B in Example 4.8 in Rulph chassing).
88
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. Design an FIR banpass filter with a center frequency of f c =2 kHz , bandwidth of 400 Hz. Use
55 coefficients in designing the filter. Export the filter coefficients to a file called bp55.cof
2. Use the following header file required for the random noise generation in your project directory
3. Build and run this project as adaptIDFIR. Verify that the output (adaptfir_out) of the adaptive FIR
filter converges to a bandpass filter centered at 2kHz(with the slider in position 1 by default).
4. With the slider in position 2, verify the output (fir_out) of the fixed FIR bandpass filter centered
at 2 kHz and represented by the coefficient file bp55.cof. It can be observed that this output is
practically identical to the adaptive filters output.
#include "DSK6713_AIC23.h" //codec-DSK support file
89
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
int prnseq;
sreg.regval<<=1;
int i;
90
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
return;
void main()
91
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
92
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
8.2 Introduction
8.2.1 Delay
Delay is the simplest audio effect which holds input signal and then plays it back after a period
of time. Delay is used very often by musicians. It is also the main block for other audio effects
such as reverb, chorus, and flanging.
The difference equation for the delay operation is y [ n]=x [nn0 ] where n0 is the delay
amount. Since the difference equation between the output and the input is specified, it can be
directly coded in C language. To implement the delay operation, the best way is defining an
array which stores input audio signals. In Figure 44, we demonstrate the delay operation using
n0 +1 length array which should be defined beforehand. To feed the delayed audio signal to
output, first we should store the audio signal on the first entry of the array. At each operation
cycle, each entry in the array should be shifted towards right, to open space to the new input.
This way, an input which is taken at time n will reach to the end of the array n0 cycles
later.
93
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
8.2.2 Echo
The echo block simply takes an audio signal and plays it after summing with a delayed version of
the same signal. The delay time can range from several milliseconds to several seconds.
The difference equation which describes the echo system is y [n]=x [ n]+ x[ nn0 ] ; where
is the delay mix parameter, n0 is the delay amount.
In order to generate the echo effect, both the present and the delayed signal are needed. In order to
access to the delayed signal, we should store the input audio signal in an array to generate the delayed
version of the signal as explained in the previous sub-section. Using this Objectives
The objectives of this experiment is show students how can an adaptive filter be used for different
applications such as noise cancelation and system identifications
8.2.3 Reverberation
Reverberation is also one of the most heavily used effects in music. The effects of combining an
original signal with a very short (<20ms) time-delayed version of itself results is reverberation. In
fact, when a signal is delayed for a very short time and then added to the original, the ear
perceives a fused sound rather than two separate sounds. If a number of very short delays (that
are fed back) are mixed together, a crude form of reverberation can be achieved. The block
diagram of a basic reverberation system is given in Figure below.
94
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The difference equation for this system is y [n]=y[nn0 ]+ x [nn0 ] . The value of
normally falls between 0 and 1.
1. In this part of the experiment you are going to generate an echo signal by reading an audio
samples form the LINE IN terminal then delay and process these signals according to the echo
equation. Your code may appear as shown below
#include "dsk6713_aic23.h" //codec-DSK support file
Uint32 fs=DSK6713_AIC23_FREQ_8KHZ; //set sampling rate
short input, output;
short bufferlength = 3000; //buffer size for delay
short buffer[3000]; //create buffer
short i = 0;
short amplitude = 5; //to vary amplitude of echo
interrupt void c_int11() //ISR
{
input = input_sample(); //newest input sample data
output=input + 0.1*amplitude*buffer[i];//newest + oldest samples
output_sample(output); //output sample
buffer[i] = input; //store newest input sample
i++; //increment buffer count
if (i >= bufferlength) i = 0; //if end of buffer reinit
}
main()
{
comm_intr(); //init DSK, codec, McBSP
while(1); //infinite loop
95
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. Vary the buffer size from 1000 to 8000 and listen to the played recorded wave. What effect do
you observe on heard signal?
3. In your code change the statement buffer[i]=input into buffer[i]=output and listen to the
recorded signal. What effect to the signal happens here?
4. Try to implement multi echo by using different buffers with different buffer lengths and modify
your code as shown below
* File Name : echogeneration.c
* Target : TMS320C6713
* Version : 3.1
* Description : This Program tells about the Echo generation.
Input is taken from Mic-in using Mic, n output can be analysed
by using headphone.
*************************************************************************************
*********/
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to
the interrupt service routine
{
input = input_sample(); // input from Mic
output =input + 0.4*amplitude*buffer[i]+0.3*amplitude*buffer1[j]+ 0.2*amplitude*buffer2[k]+
0.1*amplitude*buffer3[l];
output_sample(output); // // the value in the buffer sine_table
indexed by the variable loop is written on to the codec.
buffer[i] = input;
buffer1[j] = buffer[i];
buffer2[k] = buffer1[j];
buffer3[l] = buffer2[k];
i++;
96
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
j++;
k++;
l++;
if(i >= bufferlength) i = 0;
if(j >= bufferlength1) j = 0;
if(k >= bufferlength2) k = 0;
if(l >= bufferlength3) l = 0;
}
main() // main routin call
{
comm_intr(); // ISR function is called, using the given command
while(1); // program execution halts and it starts listening for the
interrupt which occur at every sampling period Ts.
}
1. If the echo_type is set by the slider to 1 then fading is selected otherwise normal echo is used
2. The delay of the echo also can be made variable by using a delay parameter called delay. The
delay parameter either increase or decrease the length of the buffer from 1000 to 8000 in steps
of 1000
3. The amplitude parameter of the delayed version of the input also can be made variable,
therefore generating different effects on the echo signal
4. Type the program shown below and the subsequent gel files to accomplish this task
//Echo_control.c Echoeffectswithfading
97
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
98
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Echo occurs in telephone systems or in acoustic room recording when the voice of a speaker at
the far end picked up by a microphone at the near end. Sometimes echo represents undesirable
phenomena. One way to cancel this echo is to use an adaptive filter as illustrated in Figure 47
The adaptive filter takes the un-echoed signal from the far end microphone as the desired signal
d (n) . The error signal is defined as the difference between the adaptive filter output and the
echoed signal x [n] as given by
99
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
e [ n ] = y [ n ] x [n]
The adaptive filter tries to generate a delayed version of the original un-echoed signal d [n]
at its output. When the error is computed, the error represents a clean signal with no echo.
In order to implement an echo cancelling using an adaptive filter first it is needed n next. This
process can be illustrated by the code listed below
output_sample(output2);
buffer[i] = input; //store newest input sample
i++; //increment buffer count
if (i >= bufferlength) i = 0; //if end of buffer reinit
100
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
}
main()
{
comm_intr(); //init DSK, codec, McBSP
while(1); //infinite loop
}
short Echo_cancellation(short input,short echo_output) //the control passes to the function
Echo_cancellation( ), called by above.& its call by value function
{
// store the input signal into a variable
echo1=lecho_output; // store the echo signal into echo1 variable
delay[0]=echo1; //noise as input to adapt FIR
lcecho_output = E;
return lcecho_output; // program execution goes back to the function called and then again
starts listening for next call and this process goes on
This exercise illustrates a voice scrambling/descrambling scheme. The approach makes use of
basic algorithms for filtering and modulation. With voice as input, the resulting output is
scrambled voice. The original unscrambled voice is recovered when the output of the DSK is
used as the input to a second DSK running the same program.
The scrambling method used is commonly referred to as frequency inversion. It takes an audio
range, represented by the band 0.3 to 3 kHz, and folds it about a carrier signal. The frequency
inversion is achieved by multiplying (modulating) the audio input by a carrier signal, causing a
shift in the frequency spectrum with upper and lower sidebands. On the lower sideband that
represents the audible speech range, the low tones are high tones, and vice versa.
Figure 48 is a block diagram of the scrambling scheme. At point A we have a band-limited signal
0 to 3.7 kHz. At point B we have a double-sideband signal with suppressed carrier. At point C the
101
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
upper sideband is filtered out. Its attractiveness comes from its simplicity, since only simple DSP
algorithms are utilized: filtering, and sine generation and modulation.
In order to implement voice scrambling you may use the following code
//Scrambler.cVoice scrambler/de-scrambler program
#include "dsk6713_aic23.h" //codec-dsk support file
uint32 fs=DSK6713_AIC23_FREQ_8KHZ; //set sampling rate
#include "sine160.h" //sine data values
#include "lp114.cof" //filter coefficient file
short filtmodfilt(short data);
short filter(short inp,short *dly);
short sinemod(short input);
static short filter1[N],filter2[N];
short input, output;
void main()
{
short i;
comm_poll(); //init DSK using polling
for (i=0; i< N; i++)
{
filter1[i] = 0; //init 1st filter buffer
filter2[i] = 0; //init 2nd filter buffer
}
while(1)
{
input=input_sample(); //input new sample data
filtmodfilt(input); //process sample twice(upsample)
output=filtmodfilt(input); //and throw away 1st result
output_sample(output); //then output
}
}
short filtmodfilt(short data) //filtering & modulating
{
data = filter(data,filter1); //newest in ->1st filter
102
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The input signal is first lowpass-filtered and the resulting output (at point A in Figure 48) is
multiplied (modulated) by a 4-kHz sine wave with data values in a buffer (lookup table).The
modulated signal (at point B) is filtered again, and the overall output is a scrambled signal (at
point C).
There are three functions in the code in addition to the function main. One of the functions,
filtmodfilt () , calls a filter function to implement the first lowpass filteras an antialiasing
filter.The resulting output (filtered input) becomes the input to amultiplier/modulator. The
function sinemod ( ) modulates (multiplies) the filtered input with the 4-kHz sine data values.
This produces higher and lower sidebandcomponents.The modulated output is again filtered, so
that only the lower sidebandcomponents are kept.
A buffer is used to store the 114 coefficients that represent the lowpass filter.Thecoefficient file
lp114.cof can be downloaded from your course container. Two other buffers are used for the
delaysamples, one for each filter. The samples are arranged in memory as
103
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
x ( n( N1 ) ) , x ( n ( N 2 ) ) , x ( n( N3 ) ) , , x (n)
with the oldest sample at the beginning of the buffer and the newest sample at theend
(bottom) of the buffer.The file sine160.h with 160 data values over 40 cycles your course
number of cycles 16 , 000 ( 40 )
container. The frequency generated is f =Fs = =4 kHz .
number of points 200
i=0:199;
desired= round(10000*sin(2*pi*(i)*4000/16000)); %sin(1500)addnoise=
round(100*sin(2*pi*(i)*312/8000)); %sin(312)
fid=fopen('sin200.h','w'); %desired sin(1500)
fprintf(fid,'short sin200[]={');
fprintf(fid,'%d, ' ,desired(1:199));
fprintf(fid,'%d' ,desired(200));
fprintf(fid,'};\n');
fclose(fid);
#ifndef NSINE
#endif
104
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Using the resulting output as the input to a second DSK running the same algorithm, the original
unscrambled input is recovered as the output of the second DSK.Note that the program can still
run on the first DSK when the USB connector cable is removed from the DSK.
An optional up-sampling (by a factor of 2) scheme is used to obtain a 16-kHzsampling rate. This
scheme is achieved by processing the input data twice while retaining only the second result.
This allows for a wider input signal bandwidth to be scrambled, resulting in a better
performance.
105
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
10.2 Introduction
In this part of the experiment the implementation of the DFT for a sine wave using look up table
will be illustrated. The discrete Fourier transform for a given input sequence x [n] is defined
by
N 1
X ( k ) = x [ n ] W nk k =0 , 1 , , N1
n=0
j2
Where W =e N is the twiddle constant. The series of X ( k ) can be decomposed into a
sum of real components and a sum of imaginary components as illustrated below
N1
{ X ( k ) }= x [ n ] cos
n =0
( 2 nk
N )
N1
2 nk
{ X ( k ) }= x [ n ] sin (
n=0 N )
Using a sequence of real numbers with an integer number of cycles m, X (k)=0 for all k,
except at k =m and at k =Nm .
The input x [n] is a cosine wave with N=8 data points. The program that is used to
compute the DFT for the input signal is illustrated below.
#include<stdio.h>
#include<math.h>
voiddft(short*x,shortk,int*out);//functionprototype
#defineN8//numberofdatavalues
floatpi=3.1416;
intout[2]={0,0};//initReandImresults
shortx[N]={1000,707,0,707,1000,707,0,707};//1cyclecosine
//shortx[N]={0,602,974,974,602,0,602,974,974,602,
//0,602,974,974,602,0,602,974,974,602};//2cyclessine
voiddft(short*x,shortk,int*out)//DFTfunction
106
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
intsumRe=0,sumIm=0;//initreal/imagcomponents
floatcs=0,sn=0;//initcosine/sinecomponents
inti=0;
for(i=0;i<N;i++)//forNpointDFT
cs=cos(2*pi*(k)*i/N);//realcomponent
sn=sin(2*pi*(k)*i/N);//imaginarycomponent
sumRe=sumRe+x[i]*cs;//sumofrealcomponents
sumIm=sumImx[i]*sn;//sumofimaginarycomponents
out[0]=sumRe;//sumofrealcomponents
out[1]=sumIm;//sumofimaginarycomponents
voidmain()
intj;
for(j=0;j<N;j++)
dft(x,j,out);//callDFTfunction
}
To test the results, build the project, load the program and follow these steps
1. Select View Watch Window and insert the two expressions j and out (right
click on the Watch window). Click on +out to expand and view out [0] and
out [1] , which represent the real and imaginary components, respectively.
2. Place a breakpoint at the bracket } that follows the DFT function call.
3. Select Debug Animate (Animation speed can be controlled through Options). Verify
that the real component value out [0] is large (3996) at j=1 and at j=7 , while
small otherwise. Since x [n] is a one-cycle sequence, m=1 . Since the number of
points is N=8 , a spike occurs at j=m=1 and at j=N m=7 .
4. Use the two-cycle sine data table (in the program) with 20 points as input x [n] .
Within the program, change N=20 , comment the table that corresponds to the
cosine (first input), and instead use the sine table values. Rebuild and animate again.
Verify a large negative value at j=m=2(10 ,232) and a large positive value at
j=N m=18 (10 ,232) . For a real-time implementation, the magnitude of
107
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
#include"dsk6713_aic23.h"
Uint32fs=DSK6713_AIC23_FREQ_8KHZ;
#include<math.h>
#definePTS256//#ofpointsforFFT
#definePI3.14159265358979
typedefstruct{floatreal,imag;}COMPLEX;
voidFFT(COMPLEX*Y,intn);//FFTprototype
floatiobuffer[PTS];//asinputandoutputbuffer
floatx1[PTS];//intermediatebuffer
shorti;//generalpurposeindexvariable
shortbuffercount=0;//numberofnewsamplesiniobuffer
shortflag=0;//setto1byISRwheniobufferfull
COMPLEXw[PTS];//twiddleconstantsstoredinw
COMPLEXsamples[PTS];//primaryworkingbuffer
main()
for(i=0;i<PTS;i++)//setuptwiddleconstantsinw
w[i].real=cos(2*PI*i/512.0);//Recomponentoftwiddleconstants
w[i].imag=sin(2*PI*i/512.0);//Imcomponentoftwiddleconstants
comm_intr();//initDSK,codec,McBSP
while(1)//infiniteloop
108
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
while(flag==0);//waituntiliobufferisfull
flag=0;//resetflag
for(i=0;i<PTS;i++)//swapbuffers
samples[i].real=iobuffer[i];//bufferwithnewdata
iobuffer[i]=x1[i];//processedframetoiobuffer
for(i=0;i<PTS;i++)
samples[i].imag=0.0;//imagcomponents=0
FFT(samples,PTS);//callfunctionFFT.c
for(i=0;i<PTS;i++)//computemagnitude
x1[i]=sqrt(samples[i].real*samples[i].real
+samples[i].imag*samples[i].imag)/16;
x1[0]=32000.0;//negativespikeforreference
}//endofinfiniteloop
}//endofmain
interruptvoidc_int11()//ISR
output_sample((short)(iobuffer[buffercount]));//outputfromiobuffer
iobuffer[buffercount++]=(float)((short)input_sample());//input>iobuffer
if(buffercount>=PTS)//ifiobufferfull
buffercount=0;//reinitbuffercount
flag=1;//setflag
109
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
The twiddle constants are generated within the program. The imaginary components of the
input data are set to zero to illustrate this implementation. The magnitude of the resulting FFT
(scaled) is taken for output to the codec. Three buffers are used:
In every sample period, an output value from a buffer (iobuffer) is sent to the codecs DAC and
an input value is acquired and stored into the same buffer. An index (buffercount) to this buffer
is used to set a flag when this buffer is full.
When this buffer is full, it is copied to another buffer (samples), which will be used when calling
the FFT function. The magnitude (scaled) of the processed FFT data, contained in a buffer x1,
can now be copied to the I/O buffer, iobuffer, for output. In a filtering algorithm, processing can
be done as each new sample is acquired. On the other hand, an FFT algorithm requires that an
entire frame of data be available for processing.
To implement an FIR filter and illustrate the fast convolutions overlap-add scheme. TIs floating-point FFT
support functions, bitrev, digitrev_index, and cfftr2_dit were introduced in examples 6.3 and 6.4 in Rulph
Chassing). In addition, TIs inverse complex FFT function icfftr2_dif (radix-2, DIF) is used here. This
function expects its input to be scrambled or to be in bit-reversed order. As a result, the bit-reversed
output of the complex FFT function cfftr2_d it need not be reordered, and the support files for bit
reversal, digitrev_index.c and bitrev.sa, are not needed after the FFT section of the program. Both data
(samples) and filter coefficients (h) are in bit-reversed order and may be multiplied together in that
order.
#include"DSK6713_AIC23.h"//codecDSKsupportfile
110
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Uint32fs=DSK6713_AIC23_FREQ_8KHZ;//setsamplingrate
#include<math.h>
#include"coeffs.h"//timedomainFIRcoefficients
#definePI3.14159265358979
#definePTS256//numberofpointsforFFT
#defineSQRT_PTS16//usedintwiddlefactorcalc.
#defineRADIX2//passedtoTIFFTroutines
#defineDELTA(2*PI)/PTS
typedefstructComplex_tag{floatreal,imag;}COMPLEX;
#pragmaDATA_ALIGN(W,sizeof(COMPLEX))
#pragmaDATA_ALIGN(samples,sizeof(COMPLEX))
#pragmaDATA_ALIGN(h,sizeof(COMPLEX))
COMPLEXW[PTS/RADIX];//twiddlefactorarray
COMPLEXsamples[PTS];//processingbuffer
COMPLEXh[PTS];//FIRfiltercoefficients
shortbuffercount=0;//buffercountforiobuffersamples
floatiobuffer[PTS/2];//primaryinput/outputbuffer
floatoverlap[PTS/2];//intermediateresultbuffer
shorti;//indexvariable
shortflag=0;//settoindicateiobufferfull
floata,b;//variablesusedincomplexmultiply
shortNUMCOEFFS=sizeof(coeffs)/sizeof(float);
shortiTwid[SQRT_PTS];//PTS/2+1>sqrt(PTS)
interruptvoidc_int11(void)//ISR
output_sample((short)(iobuffer[buffercount]));
iobuffer[buffercount++]=(float)((short)input_sample());
if(buffercount>=PTS/2)//foroverlapaddmethodiobuffer
111
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
{//ishalfsizeofFFTused
buffercount=0;
flag=1;
main()
{//setuparrayoftwiddlefactors
digitrev_index(iTwid,PTS/RADIX,RADIX);
for(i=0;i<PTS/RADIX;i++)
W[i].real=cos(DELTA*i);
W[i].imag=sin(DELTA*i);
bitrev(W,iTwid,PTS/RADIX);//bitreverseorderW
for(i=0;i<PTS;i++)//initialisePTSelement
{//ofCOMPLEXtoholdrealvalued
h[i].real=0.0;//timedomainFIRfiltercoefficients
h[i].imag=0.0;
for(i=0;i<NUMCOEFFS;i++)
{//readFIRfiltercoeffs
h[i].real=coeffs[i];//NUMCOEFFSshouldbelessthanPTS/2
cfftr2_dit(h,W,PTS);//transformfiltercoeffs
comm_intr();//initialiseDSK,codec,McBSP
while(1)//frameprocessinginfiniteloop
while(flag==0);//waitforiobufferfull
112
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
flag=0;
for(i=0;i<PTS/2;i++)//iobufferintofirsthalfof
{//samplesbuffer
samples[i].real=iobuffer[i];
iobuffer[i]=overlap[i];//previouslyprocessedoutput
}//toiobuffer
for(i=0;i<PTS/2;i++)
{//secondhalfofsamplestooverlap
overlap[i]=samples[i+PTS/2].real;
samples[i+PTS/2].real=0.0;//zeropadinputfromiobuffer
for(i=0;i<PTS;i++)
samples[i].imag=0.0;//initimagpartsinsamplesbuffer
cfftr2_dit(samples,W,PTS);//complexFFTfunctionfromTI
for(i=0;i<PTS;i++)//frequencydomainrepresentation
{//complexmultiplysamplesbyh
a=samples[i].real;
b=samples[i].imag;
samples[i].real=h[i].real*ah[i].imag*b;
samples[i].imag=h[i].real*b+h[i].imag*a;
icfftr2_dif(samples,W,PTS);//inverseFFTfunctionfromTI
for(i=0;i<PTS;i++)
samples[i].real/=PTS;
for(i=0;i<PTS/2;i++)//addfirsthalfofsamples
overlap[i]+=samples[i].real;//tooverlap
}//endofwhile(1)
}//endofmain()
113
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Several buffers are used, and iobuffer is the primary input/output buffer. At each sampling interval, the
ISR is executed. The next output value is read from iobuffer, output to the codec, and then replaced by a
new input sample. After PTS/2 sampling instants, iobuffer contains a new frame of PTS/2 input samples.
This situation is signaled by setting flag to 1. The main program waits for this flag signal using
1. Resets flag to 0
2. Copies the contents of the buffer iobuffer (frame of new input samples) to the first PTS/2
locations of the buffer samples
3. Copies the contents of the buffer overlap (previously computed frame of output samples) to the
buffer iobuffer
4. Processes the new frame of input samples to compute the next frame of output samples
The frame processing operation (within an infinite loop) has PTS/2 sampling periods in which to execute
and comprises the following steps:
1. The contents of the last PTS/2 locations of the samples buffer (real parts) are copied to the
overlap buffer. These time-domain data may be thought of as the overlapping latter half (PTS/2
samples) of the previous frame processing operation.
2. The last PTS/2 locations of the buffer samples are zero-padded. The buffer samples now contains
PTS/2 new samples followed by PTS/2 zeros.
3. The buffer samples is transformed in-place into the frequency domain using a PTS-point FFT.
4. The complex frequency-domain sample values are multiplied by the complex frequency-domain
filter coefficients stored in h.
5. The results are transformed back into the time domain by applying a PTSpoint IFFT to the
contents of the samples buffer. The resulting PTS time domain samples will be real-valued.
6. The contents of the first PTS/2 locations of the buffer samples (i.e., the former half of the current
frame processing result) are added to the contents of the overlap buffer.
Since the input and output signals are real-valued, so are the buffers iobuffer and overlap. However,
since the frequency-domain representation of these signals is complex, the buffer samples and the array
of filter coefficients h are complex, requiring two floating-point values (real and imaginary parts) per
sample. 240 Fast Fourier Transform
A faster and more efficient implementation of buffering is possible using pointers rather than copying
data from one buffer to another, but the latter approach is adopted for purposes of clarity.
114
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
11.1 Objectives
To brief student with hamming codes for error correction and detection
In mathematical terms, Hamming codes are a class of binary linear codes. For each integer
m 2 there is a code with m parity bits and 2m m 1 data bits. The parity check matrix of a
Hamming code is constructed by listing all columns of length m that are pair wise independent.
Hamming codes are an example of perfect codes, codes that exactly match the theoretical
upper bound on the number of distinct code words for a given number of bits and ability to
correct errors.
Because of the simplicity of Hamming codes, they are widely used in computer memory (RAM).
General algorithm
The following general algorithm generates a single-error correcting (SEC) code for
115
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
2. Write the bit numbers in binary. 1, 10, 11, 100, 101, etc.
3. All bit positions that are powers of two (have only one 1 bit in the binary form
4. All other bit positions, with two or more 1 bits in the binary form of their
5. Each data bit is included in a unique set of 2 or more parity bits, as determined
1. Parity bit 1 covers all bit positions which have the least significant bit set: bit 1 (the
parity bit itself), 3, 5, 7, 9, etc.
2. Parity bit 2 covers all bit positions which have the second least significant bit set: bit 2
(the parity bit itself), 3, 6, 7, 10, 11, etc.
3. Parity bit 4 covers all bit positions which have the third least significant bit set: bits 4
7, 1215, 2023, etc.
116
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
As you can see, if you have m parity bits, it can cover bits from 1 up to 2m1 . If we
m
subtract out the parity bits, we are left with 2 m1 we can use for the data. As
The key to the Hamming Code is the use of extra parity bits to allow the identification
117
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
1. Mark all bit positions that are powers of two as parity bits. (Positions 1, 2, 4, 8, 16, 32,
64, etc.)
2. All other bit positions are for the data to be encoded. (Positions 3, 5, 6, 7, 9, 10, 11, 12,
13, 14, 15, 17, etc.)
3. Each parity bit calculates the parity for some of the bits in the code word. The position
of the parity bit determines the sequence of bits that it alternately checks and skips.
Position 1: check 1 bit, skip 1 bit, check 1 bit, skip 1 bit, etc.
(1,3,5,7,9,11,13,15,...)
Position 2: check 2 bits, skip 2 bits, check 2 bits, skip 2 bits, etc.
(2,3,6,7,10,11,14,15,...)
Position 4: check 4 bits, skip 4 bits, check 4 bits, skip 4 bits, etc.
(4,5,6,7,12,13,14,15,20,21,22,23,...)
Position 8: check 8 bits, skip 8 bits, check 8 bits, skip 8 bits, etc.
(8-15,24-31,40-47,...)
p1=P3 P 5 P 7 P 9
p2=P 3 P 6 P7 P 10 P 11
4. Set a parity bit to 1 if the total number of ones in the positions it checks is odd. Set a
parity bit to 0 if the total number of ones in the positions it checks is even.
118
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
Every integer m there is a ( 2m1 ) bit Hamming code which contains m parity bits and
2 1m information bits.
m
The parity bits are intermixed with the information bits as
follows:
If we number the bit positions from 1 to 2m1 , the bits in position 2k , where
0 k m1 , are the parity bits, and the bits in the remaining positions are information bits.
The value of each parity bit is chosen so that the total number of 1's in a specific group of bit
positions is even.
c 1=P1 P 3 P 5 P 7
119
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
c 2=P 2 P 3 P 6 P 7
c 3=P 4 P 5 P 6 P 7
void main()
int d[4],c[7],i,cod[7];
for(i=0;i<4;i++)
scanf("%d",&d[i]); // takes in values from the user in the form of '0' and '1'
120
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
for(i=0;i<4;i++)
c[i]=d[i];
c[4]=(d[0]+d[1]+d[3])%2;
c[5]=(d[0]+d[2]+d[3])%2;
c[6]=(d[1]+d[2]+d[3])%2;
cod[0]=c[4];
cod[1]=c[5];
cod[2]=c[0];
cod[3]=c[6];
cod[4]=c[1];
cod[5]=c[2];
cod[6]=c[3];
printf("\n The data bit appended with correction bit is \n"); // displays the line on
CCS screen
121
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to the interrupt
service routine
13. Use the following code to detect a (7,4) hamming code errors and correct it if there is
one bit error.
122
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
printf("\nthere is no error\n");
printf("\n The corrected recieved data\n");
printf("%d",c[2]);
printf("%d",c[4]);
printf("%d",c[5]);
printf("%d",c[6]);
}
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to the interrupt
service routine
{
comm_poll(); // ISR function is called, using the given command,it
uses a continuous procedure of testing when the data is ready
}
123
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
In this experiment it is desired to write a c program that reads the status of the on board DIP switches
and generates a DTMF dial tone according to the following table
124
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
# On On Off On
A Off Off On On
B On Off On On
C Off On On On
D On On On On
Table 4
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to the
interrupt service routine
{
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==0)&&(DSK6
713_DIP_get(3)==0))
{
output_sample(output); // the value in the buffer ouput indexed by the
variable loop is written on to the codec.
output = sine_table1[i] + sine_table5[i]; // 1
if(i< N-1) ++i; // the index loop is incremented by an amount equal to N
else i = 0; // if i is greater than the N than make value of i=0
}
//Add other combinations according to tables 1 &2
return;
}
float pi = 3.14159; // variable declaration
DSK6713_DIP_init(); // initialize DIP switches
for(i = 0;i< N;i++) // write the sample values of waveform on the codec at
every sampling instant
{ //each sine_wave have different frequency
sine_table1[i] = 1000*sin((2.0*pi*i/8000)*697); // generation of sine-wave signal
using formula, value is taken in a loop
sine_table2[i] = 1000*sin((2.0*pi*i/8000)*770); // generation of sine-wave signal
125
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
#include"dsk6713_aic23.h"
short sine_table5[N],sine_table6[N],sine_table7[N],sine_table8[N];
interrupt void c_int11() // ISR call, At each Interrupt, program execution goes to the interrupt service
routine
126
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==0))
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==0))
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==0))
127
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==1))
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==0))
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==0))
128
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==0))
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==1))
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==0))
129
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==1))
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==1))
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==1))
130
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==1))
if((DSK6713_DIP_get(0)==0)&&(DSK6713_DIP_get(1)==0)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==0))
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==1)&&(DSK6713_DIP
_get(3)==1))
131
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
if((DSK6713_DIP_get(0)==1)&&(DSK6713_DIP_get(1)==1)&&(DSK6713_DIP_get(2)==0)&&(DSK6713_DIP
_get(3)==1))
return;
void main(){
132
Digital Signal Processing Lab Telecommunication Engineering Department
An-Najah National University
for(i = 0;i< N;i++) // write the sample values of waveform on the codec at every
sampling instant
while(1); //program execution halts and it starts listening for the interrupt which
occur at every sampling period Ts.
133