## Midterm — March 14, 2007

Write out and sign the honor pledge:

- 1. (2 pts) Print your name on *each and every* sheet.
- 2. (8 pts) Write down the equations for the forward and inverse Discrete Fourier Transform. Indicate which is which. Use the "standard" definitions.

- 3. (2 pts) FPGA technology (component density and speed) has been benefiting from Moore's law. It is now at a point where (the instructor claims) that it will be a major player in DSP applications. This evidenced by the recent introduction of DSP oriented FPGA devices by Xilnx, Altera, Lattice and others. What do the letters FPGA stand for?
- 4. (2 pts) Typically a microcomputer or FPGA is be felt to have been designed for use in doing digital signal processing if it possesses a

instruction.

- 5. (8 pts) A time waveform x(t) is sample at a rate of  $f_s$  for T seconds resulting in a set of N samples.
  - (a) How are  $f_s$ , T, and N related (i.e., equation):
  - (b) The DFT is taken of the *N* sample values. What are the frequencies, associated with the following values of *k*?
    - i. k = 0 \_\_\_\_\_ Hz. ii. k = 1 \_\_\_\_\_ Hz. iii. k = -2 \_\_\_\_\_ Hz.
- 6. (4 pts) The filter preceeding an A/D converter is termed an anti-\_\_\_\_\_\_ filter.
- 7. (4 pts) The filter following a D/A converter is terms an anti-\_\_\_\_\_\_\_ filter.
- 8. (2 pts) The TI C5510 divides data memory into pages. The number of 16-bit data words per page is K.

9. (2 pts) The size of the C5510 on-chip memory is Kwords.

- 10. (2 pts) The C5510 has on-chip timers.
- 11. (2 pts) The C5510 has McBSP channels.
- 12. (6 pts) The C5510 supports three addresses spaces. These are

- 13. (2 pts) The C5510 has two -bit high speed multipliers.
- 14. (4 pts) The product line of the Xilinx FPGAs used in lab is named
- 15. (2 pts) The clock rate used with the C5510 DSK is  $$\rm MHz.$$

Midterm

16. (2 pts) The clock rate used on the FPGA boards in the lab is

MHz.

17. (10 pts) A useful aspect of sampling is to alias a bandlimited signal to lower frequencies. This is accomplished by using sample rates lower than or equal to Nyquist.



Sketch and label the spectrum after sampling using the following sampling rates:

(a)  $f_s = 45$  MHz. a =\_\_\_\_\_ MHz. b =\_\_\_\_\_ MHz. c =\_\_\_\_\_ MHz. d =\_\_\_\_\_ MHz. The Nyquist range is from \_\_\_\_\_ to \_\_\_\_ MHz. (b)  $f_s = 16$  MHz. a =\_\_\_\_\_ MHz. b =\_\_\_\_\_ MHz. c =\_\_\_\_\_ MHz. d =\_\_\_\_\_ MHz. 18. (4 pts) The C5510 has \_\_\_\_\_ -bit accumulators.

3

- 19. (2 pts) The C5510 has status registers.
- 20. (4 pts) The AIC23 CODEC chip used on the C5510 DSK connects to the C5510 using two McBSP channels, one for setup and one for data transfer.
  - (a) Which McBSP channel is used for setup using the SPI protocol?
  - (b) Which McBSP channel is used for moving sample values between the AIC23 and the C5510?
- 21. True (T) or false (F) (2 pts each):
  - The AIC23 only supports two sample rates, these are 8 kHz and 48 kHz.
  - One should operate a DSP processor at as slow a clock rate as possible as determined by the application being implemented.
  - The TI C compiler generates code for the C5510's floating point unit.
  - The C5510 has 32 memory mapped registers.
  - \_\_\_\_\_ The C5510's PLL is used to convert the 20 MHz USB clock to the CPU's 200 clock.
  - An advantage of the two's complement number representation is that the same add/sub hardware is used as is with unsigned numbers.
  - Two's complement multiplication has the advantage that it can be accomplished using the a multiplier designed to implement unsigned multiplication.
  - \_\_\_\_\_ 32-bit fixed point values have the potential to give results more accurate than those obtained using 32-bit floating point.
  - \_\_\_\_\_ The C5510 subc instruction can be used to implement unsigned division.
  - \_\_\_\_\_ FPGAs allow performance increases over DSP devices because they readily support parallel operation.
  - It has been stated in the lecture notes that "there must be significant commercial potential" in the class projects.
  - The class projects need not make any use of digital signal processing.
  - The MATLAB fftshift function forms the fft and then re-orders the result so that 0 Hz is centered in the output array.
  - In order to construct a complicated system is is desirable to beak the problem down into smaller manageable pieces. Each subproblem can then be further broken down until the entire system is decomposed into fundamental building blocks.

- All FIR filters have a linear phase response.
- All IIR filters have a linear phase response.
- The FPGA boards used in lab provide off-FPGA memory.
- 22. (2 pts) When doing signed arithmetic the C5510 needs to the sign bits of a 16-bit value when it is being added into an accumulator.
- 23. (4 pts) One method of forming the two's complement of a binary number is to \_\_\_\_\_\_ and \_\_\_\_\_.
- 24. (2 pts) What needs to be placed between the carry in and the carry out of a one-bit adder to make it into a bit-serial adder?
- 25. (2 pts) When using a 12-bit A/D converter on a 16-bit processor we would place the sample values in the \_\_\_\_\_\_\_\_\_ significant bits of a 16-bit word.
- 26. (2 pts) The instructor claims that, almost always, if we design a low pass FIR filter having max gain of 1 that the FIR coefficient values will be bounded by .
- 27. (2 pts) The numeric weight associated with the most significant bit of a B-bit straight (unsigned) binary value is
- 28. (2 pts) The numeric weight associated with the most significant bit of a B-bit two's complement binary value is \_\_\_\_\_.
- 29. (2 pts) If we multiply a *Q*5 value by a *Q*9 value \_\_\_\_\_\_ is the *Q* number of the result.
- 30. (2 pts) When doing multiplication in the C5510 if we want the result to be automatically left shifted by one afterward we need to set the \_\_\_\_\_\_\_ bit in the status registers.
- 31. (4 pts) When discarding low bits of a binary bit it is best to round first. The two methods of rounding that we considered are named

and rounding.

32. (2 pts) Floating point is not recommended for general use when doing DSP on the C5510 because

## EECS 452 Digital Signal Processing Design Laboratory Winter 2007

| 33. | (6 pts) In VHDL                                                                                                                                                        |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | are the basic logic units.                                                                                                                                             |
|     | are the visible connections,                                                                                                                                           |
|     | and the defines the internal signals and describes the de-<br>sign.                                                                                                    |
| 34. | (4 pts) The two basic components of a state machine are                                                                                                                |
|     | and                                                                                                                                                                    |
| 35. | (2 pts) Xilinx constraint files use file extension                                                                                                                     |
| 36. | (4 pts) The C5510 on-chip ROM contains (how many) 16-bit samples of the function.                                                                                      |
| 37. | (2 pts) Many C5510 instructions do not support explicit naming of particu-<br>lar registers. However, because all of the registers are<br>they can be accessed anyway. |
| 38. | (8 pts) We have been asked to design a direct digital synthesizer (DDS) using a 32-bit accumulator and an update clock of 48000 Hz.                                    |
|     | (a) Frequencies that can be synthesized are multiples of                                                                                                               |
|     | $f_{\rm step} =$ Hz.                                                                                                                                                   |
|     | (b) The frequency tuning value (FTV) that will most closely generate a 1000 Hz sinewave is                                                                             |
|     |                                                                                                                                                                        |
| 39. | (2 pts) We say that $h()$ is <i>linear</i> if                                                                                                                          |

for all choices of a, b, x(t) and y(t).

40. (2 pts) We say that h() is *time-invariant* if for y(t) = h[x(t)] we have

- 41. (2 pts) We say that a system is *causal* if
- 42. (2 pts) We say a system is *stable* if
- 43. (2 pts) Where must a digital filter's transfer function's poles be located in the *z*-plane if the filter is to be stable?
- 44. (2 pts) The moving average filter has *z*-transform

 $H(z) = 1 + z^{-1} + z^{-2} + z^{-3} + \cdots + z^{-(N-1)}$ .

This series can be written in a more compact (closed) form as

- 45. (2 pts) The MATLAB program that we use to design filters is named
- 46. We are working in C using Q15 values. The following code segment multiplies two Q15 values together to obtain a Q15 result. It does not work correctly. Correct it making minimal change.

int x,y,z; . .

- z = (x\*y)>>15;
- 47. (2 pts) The MANT :: NEXP instruction(s) takes a value contained in an accumulator and converts (normalizes) it into Q?? form counting the number shifts required. The value of ?? is

48. (4 pts) When we characterize a filter the two most commonly quantities associated with it's transfer function that are used are

| and |  |
|-----|--|
|-----|--|

49. (4 pts) Given a set of *N* values x[0], x[1], ..., x[N-1] we form the DFT to obtain a set of *N* values X[0], X[1], ..., X[N-1]. We next form the DFT of the complex conjugates of these values to obtain a set of values y[0], y[1], ..., y[N-1].

How are the x[] and y[] values related?

50. (6 pts) From lecture we have the transfer function of a pole pair that is near the unit circle as shown. What is the:



51. (4 pts) For the following decimation-in-time FFT data flow diagram what are the required index values on the input *x* values?

Midterm



52. (4 pts) Write the equation describing the Fourier Transform Frequency Shifting Theorem.

53. (4 pts) What does the following instruction do?

54. (4 pts) What does the following instruction do?

rnd(hi(saturate(ac0))),\*ar1+

## 55. (8 pts) What do the following symbols denote when programming using the TI mnemonic assembler?

| #  |  |
|----|--|
| \$ |  |
| *  |  |
| Q  |  |

56. (6 pts) A waveform is sampled using rate 8000 samples per second.The alias frequency is Hz.

Two seconds of waveform samples are DFT'd. The frequency step between DFT values is Hz.

If the waveform had been sampled at 16000 Hz and the DFT of two seconds of sampled had been formed, the frequency step between DFT values would have been Hz.

57. (8 pts) Using the C5510 C/C++ system, variables declared as

| char | use | bits. |
|------|-----|-------|
|      |     |       |

int use \_\_\_\_\_ bits.

long use bits.

double use bits.

58. (8 pts) The C5510 C system uses named memory sections to organize data and code. The following named sections are used to contain what?

| .text  | · |
|--------|---|
| .bss   |   |
| .cinit |   |
| .stack |   |

- 59. (4 pts) A waveform is sampled using a sample rate of 8 kHz. How many samples are required in order to have a frequency spacing of 2 Hz in the DFT of the sample set?
- 60. (8 pts) The C5510 C system uses a data structure referred to as a *stack* hold six types of information. List four.

| (a) |  |
|-----|--|
| (b) |  |
| (c) |  |
| (d) |  |

- 61. (2 pts each) Assume a 8-bit word size with bits ordered most significant bit left most (bit 7) and least significant right most (bit 0). What is the
  - (a) Q7 unsigned value of 1000 0000?
  - (b) Q7 signed value of 1000 0000?
  - (c) Q7 unsigned value of 0100 0000?
  - (d) Q7 signed value of 0100 0000?
  - (e) Q-2 unsigned value of 1000 0000?
- 62. (2 pts) For proper extended-precision arithmetic in the C5510 the status bit, satd, should be set or cleared to prevent the accumulator from saturating during the computations?

- 63. (2 pts) Given the 16-bit hexadecimal value F237 express its two's complement using hexadecimal.
- 64. (8 pts) We normally use positional notation when writing binary numbers. Associated with each position is a weight which is a power of two. For the 6-bit binary number  $b_5b_4b_3b_2b_1b_0$  (Q0) where the *b*'s take on values 0 and 1, what is the weight,
  - (a) for unsigned values, associated with  $b_2$ ?
  - (b) for unsigned values, associated with  $b_5$ ?
  - (c) for two's complement values, associated with  $b_2$ ?
  - (d) for two's complement values, associated with  $b_5$ ?
- 65. (4 pts) Because addition and subtraction in a fixed point computer use a fixed word size there are two situations where one can have arithmetic overflow. These are
  - (a)
  - (b)
- 66. (4 pts) Assume multiplication of two *B*-bit numbers with the product being placed into a 2*B*-bit accumulator. When not doing fractional multiplication (frct bit = 0) there is no chance of overflow in the result. When frct bit = 1 it is possible to have an overflow. What values will cause this?
- 67. (2 pts) When implementing floating point, which operation, addition or multiplication, is going to be the more difficult to do?
- 68. (5 pts) The arctangent function implemented in class mapped the radian angle range from \_\_\_\_\_ to \_\_\_\_ into the range from \_\_\_\_\_ to \_\_\_\_\_ using units of \_\_\_\_\_.
- 69. (4 pts) Polynomial approximations for the arctangent, the base 2 logarithm and square root were discussed. The approximation method of choice was the \_\_\_\_\_\_ approximation.

- 70. (2 pts) The data transfer protocol is used on the C5510DSK to program/configure AIC23 CODEC device.
- 71. (8 pts) You are given a digital filter described using a biquadratic transfer function of the form

$$H(z) = \frac{b_0 + b_1 z^{-1} + b_2 z^{-2}}{1 + a_1 z^{-1} + a_2 z^{-2}}$$

and a sample rate of  $f_s$  Hz.

(a) What is the value of H(z) at 0 Hz?

(b) What is the value of H(z) at  $f_s/2$  Hz?

- 72. (8 pts) If \*(0x100)=1, \*(0x101)=2 and \*(0x102)=3, what will be the content of AC0 after the following instructions are executed?
  - (a) MOV #0x100,AR0
    MOV dbl(\*AR0),AC0
  - (b) MOV #0x101,AR0 MOV dbl(\*AR0),AC0
- 73. (4 pts) Rewrite the following equation using Horner's method/ordering:

 $a_4x^4 + a_3x^3 + a_1x^1 + a_0 =$ 

## EECS 452 Digital Signal Processing Design Laboratory Winter 2007

| 74. | (2 pts) VHDL and Verilog are | lan- |
|-----|------------------------------|------|
|     | guages.                      |      |

- 75. (2 pts) " is a highlevel design methodology in which the design is described by registers and the necessary of functions describing the transfer of data between these registers."
- 76. (6 pts) Given a *B*-bit A/D converter whose output uses the 2's complement number format. The converter is set so that a zero input voltage corresponds to the mid range of the zero output value. The voltage corresponding to the most negative value is  $-V_p$ .

(a) The most positive output value is \_\_\_\_\_.

- (b) The most negative output value is \_\_\_\_\_.
- (c) The voltage change which precisely produces a change of one count in the A/D output is  $\Delta V =$  .

77. (4 pts) In many instances it is useful to have a nonlinear relationship between the voltage at the input of an A/D converter and its output values. This is particulary true in the telephone system where a compression technique called \_\_\_\_\_\_\_\_ is used with an 8bit A/D converter to give a perceptual quality of a \_\_\_\_\_\_\_ bit linear A/D converter.

- 78. (2 pts) Given the *z*-transform of a filter transfer function the associated frequency response can be determined by evaluating the transfer function where in the *z*-plane?
- 79. (2 pts) A finite response filter uses the current input sample and the *M*
- 80. (2 pts) An all-pole filter uses the the current input sample and the N

- 81. (4 pts) Write a line of MATLABcode to generate a table, sine\_table of N samples of one period of an unit amplitude sine wave.
- 82. (4 pts) For the filter shown below draw its transposed form.



83. For the above filter:

- (a) (4 pts) what is the transfer function, H(z)?
- (b) (3 pts) what are the values of H(z) at f = 0,  $f_s/4$  and  $f_s/2$ ?

- 84. (8 pts) A set of measurements is made in order to estimate the group delay though a reasonably broad band measurement system.
  - Hz phase (degrees)
  - 1000 -120
  - 1250 90
  - 1500 -60
  - 1750 150

What is the group delay? Hint: plot the data then think about it.

- 85. Let  $x(t) = 3\sin(2\pi f_{c1}t) + 2\sin(2\pi f_{c2}t)$  where  $f_{c1} = 800$  Hz and  $f_{c2} = 1200$  Hz. We sample the signal at  $f_s = 2500$  Hz.
  - (a) (2 pts) Before we sample the signal, we pass it through an anti-alias filter. The filter response looks like the following



Can this filter prevent aliasing?

(b) (6 pts) Next we take N = 100 samples at the anti-alias filter output, and take a *N*-point DFT using the "non-standard" definition by multiplying the forward DFT with 1/N. What does the spectrum looks like? Specify the magnitude of the DFT and the range AND the resolution in frequency that can be observed. Is there any leakage?

86. (4 pts) The following code is used to generate a DTMF signal. Will the code work as desired? If not, what is the problem with this code?

```
#include "McBSP_452.h"
int SineTable[256] = { ... };
int LeftInput, RightInput;
void AIC23_IO(unsigned port, int LeftValue, int RightValue)
{
    . . .
}
void main()
{
    int index1, index2, output;
    long ac1, ac2, ftv1, ftv2;
    setup_codec();
    ftv1 = 62366504;
    ftv2 = 108179488;
    while(1){
    ac1 = ac1 + ftv1;
    ac2 = ac2 + ftv2;
    index1 = ac1 >> (32-8);
    index2 = ac2 >> (32-8);
    output = SineTable[index1] + SineTable[index2];
    AIC23_IO(2,output,RightInput);
    }
}
```