Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 40 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
40
Dung lượng
7,69 MB
Nội dung
22 Chapter 1 F IGURE 1.13 Block diagram of an analog-to-digital converter. The input analog voltage is compared with the output of a digital-to-analog converter. When the two voltages match, the number held in the binary buffer is equivalent to the input voltage with the resolution of the converter. Different strategies can be used to adjust the contents of the binary buffer to attain a match. proportional voltage, V DAC . This DAC voltage, V DAC , is then compared to the input voltage, and the binary number in the buffer is adjusted until the desired level of match between V DAC and V in is obtained. This approach begs the question “How are DAC’s constructed?” In fact, DAC’s are relatively easy to construct using a simple ladder network and the principal of current superposition. The controller adjusts the binary number based on whether or not the comparator finds the voltage out of the DAC, V DAC , to be greater or less than the input voltage, V in . One simple adjustment strategy is to increase the binary number by one each cycle if V DAC < V in , or decrease it otherwise. This so-called tracking ADC is very fast when V in changes slowly, but can take many cycles when V in changes abruptly (Figure 1.14). Not only can the conversion time be quite long, but it is variable since it depends on the dynamics of the input signal. This strategy would not easily allow for sampling an analog signal at a fixed rate due to the variability in conversion time. An alternative strategy termed successive approximation allows the con- version to be done at a fixed rate and is well-suited to digital technology. The successive approximation strategy always takes the same number of cycles irre- spective of the input voltage. In the first cycle, the controller sets the most significant bit (MSB) of the buffer to 1; all others are cleared. This binary number is half the maximum possible value (which occurs when all the bits are TLFeBOOK Introduction 23 F IGURE 1.14 Voltage waveform of an ADC that uses a tracking strategy. The ADC voltage (solid line) follows the input voltage (dashed line) fairly closely when the input voltage varies slowly, but takes many cycles to “catch up” to an abrupt change in input voltage. 1), so the DAC should output a voltage that is half its maximum voltage—that is, a voltage in the middle of its range. If the comparator tells the controller that V in > V DAC , then the input voltage, V in , must be greater than half the maximum range, and the MSB is left set. If V in < V DAC , then that the input voltage is in the lower half of the range and the MSB is cleared (Figure 1.15). In the next cycle, the next most significant bit is set, and the same comparison is made and the same bit adjustment takes place based on the results of the comparison (Figure 1.15). After N cycles, where N is the number of bits in the digital output, the voltage from the DAC, V DAC , converges to the best possible fit to the input voltage, V in . Since V in Ϸ V DAC , the number in the buffer, which is proportional to V DAC , is the best representation of the analog input voltage within the resolu- tion of the converter. To signal the end of the conversion process, the ADC puts TLFeBOOK 24 Chapter 1 F IGURE 1.15 V in and V DAC in a 6-bit ADC using the successive approximation strategy. In the first cycle, the MSB is set (solid line) since V in > V DAC . In the next two cycles, the bit being tested is cleared because V in < V DAC when this bit was set. For the fourth and fifth cycles the bit being tested remained set and for the last cycle it was cleared. At the end of the sixth cycle a conversion complete flag is set to signify the end of the conversion process. out a digital signal or flag indicating that the conversion is complete (Figure 1.15). TIME SAMPLING: BASICS Time sampling transforms a continuous analog signal into a discrete time signal, a sequence of numbers denoted as x(n) = [x 1 , x 2 , x 3 , x N ],* Figure 1.16 (lower trace). Such a representation can be thought of as an array in computer memory. (It can also be viewed as a vector as shown in the next chapter.) Note that the array position indicates a relative position in time, but to relate this number sequence back to an absolute time both the sampling interval and sampling onset time must be known. However, if only the time relative to conversion onset is important, as is frequently the case, then only the sampling interval needs to be *In many textbooks brackets, [ ], are used to denote digitized variables; i.e., x[n]. Throughout this text we reserve brackets to indicate a series of numbers, or vector, following the MATLAB format. TLFeBOOK Introduction 25 F IGURE 1.16 A continuous signal (upper trace) is sampled at discrete points in time and stored in memory as an array of proportional numbers (lower trace). known. Converting back to relative time is then achieved by multiplying the sequence number, n, by the sampling interval, T s : x(t) = x(nT s ). Sampling theory is discussed in the next chapter and states that a sinusoid can be uniquely reconstructed providing it has been sampled by at least two equally spaced points over a cycle. Since Fourier series analysis implies that any signal can be represented is a series of sin waves (see Chapter 3), then by extension, a signal can be uniquely reconstructed providing the sampling fre- quency is twice that of the highest frequency in the signal. Note that this highest frequency component may come from a noise source and could be well above the frequencies of interest. The inverse of this rule is that any signal that con- tains frequency components greater than twice the sampling frequency cannot be reconstructed, and, hence, its digital representation is in error. Since this error is introduced by undersampling, it is inherent in the digital representation and no amount of digital signal processing can correct this error. The specific nature of this under-sampling error is termed aliasing and is described in a discussion of the consequences of sampling in Chapter 2. From a practical standpoint, aliasing must be avoided either by the use of very high sampling rates—rates that are well above the bandwidth of the analog system—or by filtering the analog signal before analog-to-digital conversion. Since extensive sampling rates have an associated cost, both in terms of the TLFeBOOK 26 Chapter 1 ADC required and memory costs, the latter approach is generally preferable. Also note that the sampling frequency must be twice the highest frequency present in the input signal, not to be confused with the bandwidth of the analog signal. All frequencies in the sampled waveform greater than one half the sam- pling frequency (one-half the sampling frequency is sometimes referred to as the Nyquist frequency) must be essentially zero, not merely attenuated. Recall that the bandwidth is defined as the frequency for which the amplitude is re- duced by only 3 db from the nominal value of the signal, while the sampling criterion requires that the value be reduced to zero. Practically, it is sufficient to reduce the signal to be less than quantization noise level or other acceptable noise level. The relationship between the sampling frequency, the order of the anti-aliasing filter, and the system bandwidth is explored in a problem at the end of this chapter. Example 1.1. An ECG signal of 1 volt peak-to-peak has a bandwidth of 0.01 to 100 Hz. (Note this frequency range has been established by an official standard and is meant to be conservative.) Assume that broadband noise may be present in the signal at about 0.1 volts (i.e., −20 db below the nominal signal level). This signal is filtered using a four-pole lowpass filter. What sampling frequency is required to insure that the error due to aliasing is less than −60 db (0.001 volts)? Solution. The noise at the sampling frequency must be reduced another 40 db (20 * log (0.1/0.001)) by the four-pole filter. A four-pole filter with a cutoff of 100 Hz (required to meet the fidelity requirements of the ECG signal) would attenuate the waveform at a rate of 80 db per decade. For a four-pole filter the asymptotic attenuation is given as: Attenuation = 80 log( f 2 /f c )db To achieve the required additional 40 db of attenuation required by the problem from a four-pole filter: 80 log( f 2 /f c ) = 40 log( f 2 /f c ) = 40/80 = 0.5 f 2 /f c = 10.5 =;f 2 = 3.16 × 100 = 316 Hz Thus to meet the sampling criterion, the sampling frequency must be at least 632 Hz, twice the frequency at which the noise is adequately attenuated. The solution is approximate and ignores the fact that the initial attenuation of the filter will be gradual. Figure 1.17 shows the frequency response characteris- tics of an actual 4-pole analog filter with a cutoff frequency of 100 Hz. This figure shows that the attenuation is 40 db at approximately 320 Hz. Note the high sampling frequency that is required for what is basically a relatively low frequency signal (the ECG). In practice, a filter with a sharper cutoff, perhaps TLFeBOOK Introduction 27 F IGURE 1.17 Detailed frequency plot (on a log-log scale) of a 4-pole and 8-pole filter, both having a cutoff frequency of 100 Hz. an 8-pole filter, would be a better choice in this situation. Figure 1.17 shows that the frequency response of an 8-pole filter with the same 100 Hz frequency provides the necessary attenuation at less than 200 Hz. Using this filter, the sampling frequency could be lowered to under 400 Hz. FURTHER STUDY: BUFFERING AND REAL-TIME DATA PROCESSING Real-time data processing simply means that the data is processed and results obtained in sufficient time to influence some ongoing process. This influence may come directly from the computer or through human intervention. The pro- cessing time constraints naturally depend on the dynamics of the process of interest. Several minutes might be acceptable for an automated drug delivery system, while information on the electrical activity the heart needs to be imme- diately available. TLFeBOOK 28 Chapter 1 The term buffer, when applied digital technology, usually describes a set of memory locations used to temporarily store incoming data until enough data is acquired for efficient processing. When data is being acquired continuously, a technique called double buffering can be used. Incoming data is alternatively sent to one of two memory arrays, and the one that is not being filled is pro- cessed (which may involve simply transfer to disk storage). Most ADC software packages provide a means for determining which element in an array has most recently been filled to facilitate buffering, and frequently the ability to determine which of two arrays (or which half of a single array) is being filled to facilitate double buffering. DATA BANKS With the advent of the World Wide Web it is not always necessary to go through the analog-to-digital conversion process to obtain digitized data of physiological signals. A number of data banks exist that provide physiological signals such as ECG, EEG, gait, and other common biosignals in digital form. Given the volatil- ity and growth of the Web and the ease with which searches can be made, no attempt will be made to provide a comprehensive list of appropriate Websites. However, a good source of several common biosignals, particularly the ECG, is the Physio Net Data Bank maintained by MIT—http://www.physionet.o rg. Some data banks are specific to a given set of biosignals or a given signal proces sing approach. An example of the latter is the ICALAB Data Bank in Japan—http:// www.bsp.brain .rike n.go. jp/ICALAB/—which includes data that can be used to evaluate independent component analy sis (s ee Chapter 9) algorithms. Numerous other data banks containing biosignals and/or images can be found through a quick search of the Web, and many more are likely to come online in the coming years. This is also true for some of the signal processing algorithms as will be described in more detail later. For example, the ICALAB Website mentioned above also has algorithms for independent component analy- sis in MATLAB m-file format. A quick Web search can provide both signal processing algorithms and data that can be used to evaluate a signal processing system under development. The Web is becoming an evermore useful tool in signal and image processing, and a brief search of the Web can save consider- able time in the development process, particularly if the signal processing sys- tem involves advanced approaches. PROBLEMS 1. A single sinusoidal signal is contained in noise. The RMS value of the noise is 0.5 volts and the SNR is 10 db. What is the peak-to-peak amplitude of the sinusoid? TLFeBOOK Introduction 29 2. A resistor produces 10 µV noise when the room temperature is 310°K and the bandwidth is 1 kHz. What current noise would be produced by this resistor? 3. The noise voltage out of a 1 MΩ resistor was measured using a digital volt meter as 1.5 µV at a room temperature of 310 °K. What is the effective band- width of the voltmeter? 4. The photodetector shown in Figure 1.4 has a sensitivity of 0.3µA/µW (at a wavelength of 700 nm). In this circuit, there are three sources of noise. The photodetector has a dark current of 0.3 nA, the resistor is 10 MΩ, and the amplifier has an input current noise of 0.01 pA/√ Hz. Assume a bandwidth of 10 kHz. (a) Find the total noise current input to the amplifier. (b) Find the minimum light flux signal that can be detected with an SNR = 5. 5. A lowpass filter is desired with the cutoff frequency of 10 Hz. This filter should attenuate a 100 Hz signal by a factor of 85. What should be the order of this filter? 6. You are given a box that is said to contain a highpass filter. You input a series of sine waves into the box and record the following output: Frequency (Hz): 2 10 20 60 100 125 150 200 300 400 V out volts rms: .15×10 −7 0.1×10 −3 0.002 0.2 1.5 3.28 4.47 4.97 4.99 5.0 What is the cutoff frequency and order of this filter? 7. An 8-bit ADC converter that has an input range of ± 5 volts is used to convert a signal that varies between ± 2 volts. What is the SNR of the input if the input noise equals the quantization noise of the converter? 8. As elaborated in Chapter 2, time sampling requires that the maximum fre- quency present in the input be less than f s /2 for proper representation in digital format. Assume that the signal must be attenuated by a factor of 1000 to be considered “not present.” If the sampling frequency is 10 kHz and a 4th-order lowpass anti-aliasing filter is used prior to analog-to-digital conversion, what should be the bandwidth of the sampled signal? That is, what must the cutoff frequency be of the anti-aliasing lowpass filter? TLFeBOOK TLFeBOOK 2 Basic Concepts NOISE In Chapter 1 we observed that noise is an inherent component of most measure- ments. In addition to physiological and environmental noise, electronic noise arises from the transducer and associated electronics and is intermixed with the signal being measured. Noise is usually represented as a random variable, x(n). Since the variable is random, describing it as a function of time is not very useful. It is more common to discuss other properties of noise such as its proba- bility distribution, range of variability, or frequency characteristics. While noise can take on a variety of different probability distributions, the Central Limit Theorem implies that most noise will have a Gaussian or normal distribution*. The Central Limit Theorem states that when noise is generated by a large num- ber of independent sources it will have a Gaussian probability distribution re- gardless of the probability distribution characteristics of the individual sources. Figure 2.1A shows the distribution of 20,000 uniformly distributed random numbers between −1 and +1. The distribution is approximately flat between the limits of ±1 as expected. When the data set consists of 20,000 numbers, each of which is the average of two uniformly distributed random numbers, the distri- bution is much closer to Gaussian (Figure 2.1B, upper right). The distribution *Both terms are used and reader should be familiar with both. We favor the term “Gaussian” to avoid the value judgement implied by the word “normal.” 31 TLFeBOOK [...]... corrcoef(x) % and correlation matrix The output from this program is a covariance and correlation matrix The covariance matrix is: TLFeBOOK Basic Concepts 53 S= 0.5 020 0.0000 0.0000 0.0000 0.0000 -0.4474 0.0000 2. 0078 -0.0000 -0.0000 1.91 72 -0.0137 0.0000 -0.0000 1. 129 4 0.0000 -0.0000 0.9586 0.0000 -0.0000 0.0000 4.5176 -2. 0545 -0. 020 6 0.0000 1.91 72 -0.0000 -2. 0545 2. 8548 0.0036 -0.4474 -0.0137 0.9586 -0. 020 6... autocorrelation curves shown in Figure 2. 8 above The two figures were obtained for bandlimited noise having bandwidths of π /20 rad/sec and π/8 rad/sec The variable wc specifies the cutoff frequency of the lowpass filter in the code below The theory and implementation of a lowpass filter such as used below are presented in Chapter 4 Example 2. 2 Generate bandlimited noise and compute and plot the autocorrelation... and compute and plot the autocorrelation function for two different bandwidths % Example 2. 2 and Figure 2. 8 % Generate colored noise having two different bandwidths % and evaluate using autocorrelation % close all; clear all; N = 1 024 ; % Size of arrays L = 100; % FIR filter length w = pi /20 ; % Lowpass filter cutoff frequency noise = randn(N,1); % Generate noise % % Compute the impulse response of a lowpass... 32 Chapter 2 FIGURE 2. 1 (A) The distribution of 20 ,000 uniformly distributed random numbers (B) The distribution of 20 ,000 numbers, each of which is the average of two uniformly distributed random numbers (C) and (D) The distribution obtained when 3 and 8 random numbers, still uniformly distributed, are averaged together Although... mean, or average value, and its variance, the term 2 in Eq (1) The arithmetic quantities of mean and variance are frequently used in signal processing algorithms, and their computation is well-suited to discrete data The mean value of a discrete array of N samples is evaluated as: x= ¯ 1 N N ∑x (2) k k=1 Note that the summation in Eq (2) is made between 1 and N as opposed to 0 and N − 1 This protocol... standard deviation is the square root of the variance and the standard deviations add as the √N times the average standard deviation [Eq (5)] Accordingly, the mean standard deviation is the average of the individual standard deviations divided by √N [Eq (6)] From Eq (4): N ∑ σ 2k, k=1 N hence: ∑ σk = √N σ 2 = √N σ k=1 (5) TLFeBOOK 34 Chapter 2 Mean Standard Deviation = 1 N N ∑σ k=1 k = 1 σ √N σ = N √N... functions subplot (1 ,2, k); plot(lags(1,:),cor(:,1),‘k’); % Plot using ‘lags’ vector axis([-50 50 -.5 1.1]); % Define axes scale TLFeBOOK 52 Chapter 2 ylabel(‘Rxx’); xlabel(‘Lags(n)’); title([‘Bandwidth = ‘num2str(wc)]); end % Labels Example 2. 3 evaluates the covariance and correlation of sinusoids that are, and are not, orthogonal Specifically, this example demonstrates the lack of correlation and covariance... sine and a cosine, a 2 Hz sine and cosine, and a 1.5 Hz sine and cosine The six sinusoids should all be at different amplitudes The first four sinusoids are orthogonal and should show negligible correlation while the two 1.5 Hz sinusoids should show some correlation with the other sinusoids % Example 2. 3 % Application of the correlation and covariance matrices to % sinusoids that are orthogonal and. .. all; close all; N = 25 6; % Number of data points in % each waveform fs = 25 6; % Sample frequency n = (1:N)/fs; % Generate 1 sec of data % % Generate the sinusoids as columns of the matrix x(:,1) = sin (2* pi*n)’; % Generate a 1 Hz sin x(: ,2) = 2* cos (2* pi*n); % Generate a 1 Hx cos x(:,3) = 1.5*sin(4*pi*n)’; % Generate a 2 Hz sin x(:,4) = 3*cos(4*pi*n)’; % Generate a 2 Hx cos x(:,5) = 2. 5*sin(3*pi*n)’; %... crosscorrelation and autocorrelation sequences are derived from the expectation operation applied to infinite data In signal processing, data lengths are finite, so the expec- FIGURE 2. 8 Autocorrelation functions of a random time series with a narrow bandwidth (left) and broader bandwidth (right) Note the inverse relationship between the autocorrelation function and the spectrum: the broader the bandwidth . box and record the following output: Frequency (Hz): 2 10 20 60 100 125 150 20 0 300 400 V out volts rms: .15×10 −7 0.1×10 −3 0.0 02 0 .2 1.5 3 .28 4.47 4.97 4.99 5.0 What is the cutoff frequency and. signal processing algorithms and data that can be used to evaluate a signal processing system under development. The Web is becoming an evermore useful tool in signal and image processing, and a. equation: p(x) = 1 σ √ 2 e −x 2 /2 2 (1) TLFeBOOK Basic Concepts 33 Two important properties of a random variable are its mean, or average value, and its variance, the term σ 2 in Eq. (1). The arithmetic