Difference between revisions of "Signal Representation/Possible Errors when using DFT"
(22 intermediate revisions by 2 users not shown) | |||
Line 6: | Line 6: | ||
}} | }} | ||
− | ==The | + | ==The mean square error as a quality criteria== |
<br> | <br> | ||
− | In the following, we briefly discuss some error possibilities when applying the DFT, whereby we restrict ourselves to the transformation from the time to the frequency domain. Even in its samples, the spectrum D(μ)/fA determined via the DFT will generally differ from the actual spectrum X(μ⋅fA) due to two processes: | + | In the following, we briefly discuss some error possibilities when applying the DFT, whereby we restrict ourselves to the transformation from the time to the frequency domain. Even in its samples, the spectrum D(μ)/fA determined via the DFT will generally differ from the actual spectrum X(μ⋅fA) due to two processes: |
− | *the | + | *the »sampling«, that is, the reduction of information about x(t) to N numerical values, |
− | *the | + | |
+ | *the »windowing» that may falsely limit the signal x(t). | ||
{{BlaueBox|TEXT= | {{BlaueBox|TEXT= | ||
Definition: | Definition: | ||
− | A quality criteria that takes both types | + | A quality criteria that takes both error types into account is the »'''mean square error'''« (German: "mittlerer quadratischer Fehler" ⇒ MQF): |
:$${\rm MQF} = \frac{1}{N}\cdot \sum_{\mu = 0 }^{N-1} | :$${\rm MQF} = \frac{1}{N}\cdot \sum_{\mu = 0 }^{N-1} | ||
\left\vert X(\mu \cdot f_{\rm A})-\frac{D(\mu)}{f_{\rm A} }\right \vert^2 \hspace{0.05cm}.$$ | \left\vert X(\mu \cdot f_{\rm A})-\frac{D(\mu)}{f_{\rm A} }\right \vert^2 \hspace{0.05cm}.$$ | ||
− | It is always MQF≠0, since with finite N degradation due to sampling and due to windowing cannot be made zero at the same time}} | + | It is always MQF≠0, since with finite N the degradation due to sampling and due to windowing cannot be made zero at the same time.}} |
The magnitude of this evaluation quantity MQF depends on the following parameters: | The magnitude of this evaluation quantity MQF depends on the following parameters: | ||
− | + | #The properties of the present signal x(t) and of its spectrum X(f), | |
− | + | #the DFT parameter N; the larger N is chosen, the smaller MQF becomes, | |
− | + | #one of the four further DFT parameters, e.g. fA. | |
− | For a given N the other DFT parameters are determined via the equations fP=N⋅fA | + | For a given N the other DFT parameters are determined via the equations |
+ | :$$f_{\rm P} = N \cdot f_{\rm A},$$ | ||
+ | :$$T_{\rm P} = 1/f_{\rm A},$$ | ||
+ | :$$T_{\rm A} = T_{\rm P}/N.$$ | ||
− | We refer you already here to the | + | We refer you already here to the following $($German language$)$ learning video, which clarifies the content of this chapter:<br> [[Fehlermöglichkeiten_bei_Anwendung_der_DFT_(Lernvideo)|»Fehlermöglichkeiten bei Anwendung der DFT«]] ⇒ "Possible errors when using the DFT". |
− | |||
− | |||
{{GraueBox|TEXT= | {{GraueBox|TEXT= | ||
Example 1: | Example 1: | ||
− | As an example, we consider a Gaussian pulse with | + | As an example, we consider a Gaussian pulse with equivalent pulse duration Δt=T, where T is simultaneously used as a normalization parameter: |
+ | [[File:EN_Sig_T_5_1_S1.png|right|frame|Quasi error-free DFT with N=16; MQF: mean square error <u>Note:</u><br>The given MQF values apply to a 16 bit processor. For a 32 bit processor (smaller quantization errors of the computer) MQF would be even smaller, but never zero.]] | ||
:x(t)=e−π(t/T)2. | :x(t)=e−π(t/T)2. | ||
− | The Gaussian pulse is very suitable for the application of DFT due to its fast | + | The Gaussian pulse is very suitable for the application of the DFT due to its fast (exponential) decay in both time and frequency domain. |
− | The graph below shows the DFT | + | The graph below shows the DFT result |
*for N=16 and | *for N=16 and | ||
− | *TA/T=0.25 ⇒ fA⋅T=0.25. | + | *TA/T=0.25 ⇒ $f_{\rm A} \cdot T = 0.25 ⇒ T_{\rm P}/T = 4$. |
− | + | ||
+ | |||
The following should be noted about this plot: | The following should be noted about this plot: | ||
− | + | #The considered samples of x(t) are in the range |t/T|≤2. Since x(±2T) is very small, periodization in time domain with $T_{\rm P}/T = N \cdot T_{\rm A}/T = 4$ does not lead to serious errors. | |
− | + | #With fA⋅T=0.25 and N=16 the $(normalized)$ DFT parameter is fP⋅T=4. The discrete spectral lines thus lie in the range −2/T≤f<+2/T. | |
− | + | #The mean squared error is relatively small (MQF≈10−12), which is due to the favourable choice of fA⋅T=0.25 (for the given N=16) . | |
− | + | #The DFT accuracy can be improved by increasing N : | |
− | + | #For N=1024 the minimum value MQF≈8⋅10−17 is obtained, if fA⋅T=0.125 is chosen. | |
− | + | #The following then applies to the other DFT parameters: | |
− | :: fP⋅T=128,TA/T=1/128,TP/T=N⋅TA/T=8. | + | :: fP⋅T=128,TA/T=1/128,TP/T=N⋅TA/T=8. }} |
− | |||
− | ==DFT | + | ==DFT falsification due to windowing – Truncation error== |
<br> | <br> | ||
− | A typical error when using the DFT is due to | + | A typical error when using the DFT is due to »windowing«. This falsification, known as »'''truncation error'''« can be explained as follows: |
− | + | #The windowing implicit in the DFT algorithm corresponds to the multiplication of the signal x(t) by a rectangular function of height 1 and duration TP=N⋅TA. | |
− | + | #If the signal x(t) is not limited to the range TP the DFT result does not coincide with the actual spectrum X(f) but is obtained from it by convolution with the spectral function $T_{\rm P} \cdot \text{sinc}(f\cdot T_{\rm P})$. | |
− | + | #In the limiting case TP→∞, which for a given distance TA of the samples would also mean an infinitely large number N of interpolation points, $T_{\rm P} \cdot \text{sinc}(f\cdot T_{\rm P})$ degenerates to a Dirac delta function and the original spectrum X(f) would remain. | |
− | + | #The DFT of an unlimited signal in time – for example a periodic signal – will always cause a truncation error which can only be kept within limits by special measures. This is discussed in more detail in the chapter [[Signal_Representation/Spectrum_Analysis|»Spectrum Analysis«]]. | |
− | + | #For time-limited signals ⇒ »pulses«, the truncation error can be avoided by choosing TP sufficiently large. By further enlarging the window into areas with $x(t) \equiv 0 no additional information gain results ⇒ \text{MQF}$ does not become smaller. | |
− | + | #By this addition of zeros called »'''zero-padding'''« the X(f) samples now occur at a smaller distance fA=1/TA. By doubling TP one achieves an interpolation of the frequency samples exactly in the middle between two previous grid points. | |
− | The following example shows a | + | The following example shows a »truncation error« due to unfavourably chosen DFT parameters. Again, we refer to the learning video (in German language) <br> [[Fehlermöglichkeiten_bei_Anwendung_der_DFT_(Lernvideo)|»Fehlermöglichkeiten bei Anwendung der DFT«]] ⇒ "Possible errors when using the DFT". |
− | |||
{{GraueBox|TEXT= | {{GraueBox|TEXT= | ||
Example 2: | Example 2: | ||
− | The graph shows the result | + | The graph shows the DFT result for the same x(t) and X(f) as well as the same N=16 as in [[Signal_Representation/Possible_Errors_when_using_DFT#The_mean_square_error_as_a_quality_criteria|$\text{Example 1}$]], but now with finer sampling in the time domain by a factor of 2 ⇒ $T_{\rm A}/T = 0.125$ |
− | + | [[File:EN_Sig_T_5_1_S2.png|right|frame|Truncation error for a DFT with N=16; MQF: Mean square error]] | |
+ | |||
+ | The comparison with [[Signal_Representation/Possible_Errors_when_using_DFT#The_mean_square_error_as_a_quality_criteria|Example 1]] shows: | ||
+ | *The spacing of the frequency samples increases from fA⋅T=0.25 to $f_{\rm A} \cdot T = 0.5$ . | ||
+ | |||
+ | *At the same time, TP/T decreases from $4$ to 2. | ||
− | + | *With this, only the signal components in the range |t|<T are now captured by the DFT. | |
− | * | ||
− | |||
− | |||
− | |||
− | + | ⇒ With these parameters, a »truncation error« or »termination error« arises, by which the mean square error is significantly increased from MQF=10−12 to MQF=4⋅10−5. | |
+ | }} | ||
− | ==DFT | + | ==DFT falsification due to sampling – Aliasing error== |
<br> | <br> | ||
− | An unsuitable sampling of the time function x(t) can also significantly falsify the DFT result. This so-called '''aliasing error''' can be explained as follows: | + | An unsuitable sampling of the time function x(t) can also significantly falsify the DFT result. This so-called »'''aliasing error'''« can be explained as follows: |
− | *Sampling x(t) at a distance TA causes a periodic continuation of the spectrum at multiples of the | + | *Sampling x(t) at a distance TA causes a periodic continuation of the spectrum at multiples of the periodization frequency fP=1/TA. |
− | *If | + | |
− | *Only with a band-limited signal | + | *If X(f) has spectral components at |f|>fP/2, the sampling theorem is not fulfilled and overlaps of the shifted frequency components to be added occur. |
− | *The aliasing error is reduced by finer sampling ( | + | |
+ | *Only with a band-limited signal the aliasing error can be avoided by suitable DFT parameters. In contrast, this error is unavoidable with time-limited signals ⇒ »pulses«, since time-limited signals cannot be band-limited at the same time. | ||
+ | |||
+ | *The aliasing error is reduced by finer sampling (smaller TA=1/fP). This can only be achieved with a constant TA – in order not to let the truncation error increase – by a larger N and thus a greater computational effort. | ||
The following Example 3 shows such an aliasing error due to wrongly chosen DFT parameters: | The following Example 3 shows such an aliasing error due to wrongly chosen DFT parameters: | ||
− | *Compared to the & | + | *Compared to the comparison system according to [[Signal_Representation/Possible_Errors_when_using_DFT#The_mean_square_error_as_a_quality_criteria|$\text{Example 1}$]]: TA is too large and fA is too small dimensioned. |
− | *The number of interpolation points is in both cases N=16. | + | |
+ | *The number of interpolation points is in both cases: N=16. | ||
− | |||
{{GraueBox|TEXT= | {{GraueBox|TEXT= | ||
Example 3: | Example 3: | ||
− | Let the DFT parameters be N=16 and fA⋅T=0.125. Thus, for the other three DFT parameters | + | Let the DFT parameters be N=16 and fA⋅T=0.125. Thus, we get for the other three DFT parameters: |
− | * $T_{\rm P}/T = 8 | + | [[File:EN_Sig_T_5_1_S3._neu.png|right|frame|Aliasing error of a DFT with N=16; MQF: mean square error]] |
− | * $f_{\rm P} \cdot T = 2 | + | * $T_{\rm P}/T = 8 \hspace{0.8cm} \text{(Example 1:} \ \ T_{\rm P}/T = 4)$, |
+ | * $f_{\rm P} \cdot T = 2 \hspace{0.75cm} \text{(Example 1:} \ \ f_{\rm P} \cdot T = 4)$, | ||
* TA/T=0.5(Example 1: TA/T=0.25). | * TA/T=0.5(Example 1: TA/T=0.25). | ||
This results in the following consequences: | This results in the following consequences: | ||
− | + | #The truncation error continues to play no role because of TP/T=8 $($already TP/T=4 was sufficient$)$. | |
− | + | #However, aliasing now arises, because the DFT is derived from many Gaussian functions at distance fP⋅T=2 $($thin dashed curves in the graph$)$. | |
− | + | #The DFT coefficients are falsified differently: The mean DFT coefficient (for f=0) is almost correct, while the errors of the DFT coefficients increase significantly towards the edges. | |
− | + | #Here, the DFT coefficient for f⋅T=−1 is twice as large as it should be, since the Gaussian function with the center at f⋅T=−2 gives the same contribution as the Gaussian function around f⋅T=0 (see yellow background). | |
− | Thus, here with MQF≈2⋅10−4 an error value four times larger than that caused by the | + | Thus, here with MQF≈2⋅10−4 an error value four times larger than that caused by the truncation error in [[Signal_Representation/Possible_Errors_when_using_DFT#DFT_falsification_due_to_windowing_.E2.80.93_Truncation_error|$\text{Example 2}$]]. |
− | Again, we refer to the | + | Again, we refer to the $($German language$)$ learning video:<br> [[Fehlermöglichkeiten_bei_Anwendung_der_DFT_(Lernvideo)|»Fehlermöglichkeiten bei Anwendung der DFT«]] ⇒ "Possible errors when using the DFT". }} |
− | ==Exercises | + | ==Exercises for the chapter== |
<br> | <br> | ||
[[Aufgaben:Exercise 5.3: Mean Square Error|Exercise 5.3: Mean Square Error]] | [[Aufgaben:Exercise 5.3: Mean Square Error|Exercise 5.3: Mean Square Error]] |
Latest revision as of 17:16, 24 June 2023
Contents
The mean square error as a quality criteria
In the following, we briefly discuss some error possibilities when applying the DFT, whereby we restrict ourselves to the transformation from the time to the frequency domain. Even in its samples, the spectrum D(μ)/fA determined via the DFT will generally differ from the actual spectrum X(μ⋅fA) due to two processes:
- the »sampling«, that is, the reduction of information about x(t) to N numerical values,
- the »windowing» that may falsely limit the signal x(t).
Definition: A quality criteria that takes both error types into account is the »mean square error« (German: "mittlerer quadratischer Fehler" ⇒ MQF):
- MQF=1N⋅N−1∑μ=0|X(μ⋅fA)−D(μ)fA|2.
It is always MQF≠0, since with finite N the degradation due to sampling and due to windowing cannot be made zero at the same time.
The magnitude of this evaluation quantity MQF depends on the following parameters:
- The properties of the present signal x(t) and of its spectrum X(f),
- the DFT parameter N; the larger N is chosen, the smaller MQF becomes,
- one of the four further DFT parameters, e.g. fA.
For a given N the other DFT parameters are determined via the equations
- fP=N⋅fA,
- TP=1/fA,
- TA=TP/N.
We refer you already here to the following (German language) learning video, which clarifies the content of this chapter:
»Fehlermöglichkeiten bei Anwendung der DFT« ⇒ "Possible errors when using the DFT".
Example 1: As an example, we consider a Gaussian pulse with equivalent pulse duration Δt=T, where T is simultaneously used as a normalization parameter:
- x(t)=e−π(t/T)2.
The Gaussian pulse is very suitable for the application of the DFT due to its fast (exponential) decay in both time and frequency domain.
The graph below shows the DFT result
- for N=16 and
- TA/T=0.25 ⇒ fA⋅T=0.25 ⇒ TP/T=4.
The following should be noted about this plot:
- The considered samples of x(t) are in the range |t/T|≤2. Since x(±2T) is very small, periodization in time domain with TP/T=N⋅TA/T=4 does not lead to serious errors.
- With fA⋅T=0.25 and N=16 the (normalized) DFT parameter is fP⋅T=4. The discrete spectral lines thus lie in the range −2/T≤f<+2/T.
- The mean squared error is relatively small (MQF≈10−12), which is due to the favourable choice of fA⋅T=0.25 (for the given N=16) .
- The DFT accuracy can be improved by increasing N :
- For N=1024 the minimum value MQF≈8⋅10−17 is obtained, if fA⋅T=0.125 is chosen.
- The following then applies to the other DFT parameters:
- fP⋅T=128,TA/T=1/128,TP/T=N⋅TA/T=8.
DFT falsification due to windowing – Truncation error
A typical error when using the DFT is due to »windowing«. This falsification, known as »truncation error« can be explained as follows:
- The windowing implicit in the DFT algorithm corresponds to the multiplication of the signal x(t) by a rectangular function of height 1 and duration TP=N⋅TA.
- If the signal x(t) is not limited to the range TP the DFT result does not coincide with the actual spectrum X(f) but is obtained from it by convolution with the spectral function TP⋅sinc(f⋅TP).
- In the limiting case TP→∞, which for a given distance TA of the samples would also mean an infinitely large number N of interpolation points, TP⋅sinc(f⋅TP) degenerates to a Dirac delta function and the original spectrum X(f) would remain.
- The DFT of an unlimited signal in time – for example a periodic signal – will always cause a truncation error which can only be kept within limits by special measures. This is discussed in more detail in the chapter »Spectrum Analysis«.
- For time-limited signals ⇒ »pulses«, the truncation error can be avoided by choosing TP sufficiently large. By further enlarging the window into areas with x(t)≡0 no additional information gain results ⇒ MQF does not become smaller.
- By this addition of zeros called »zero-padding« the X(f) samples now occur at a smaller distance fA=1/TA. By doubling TP one achieves an interpolation of the frequency samples exactly in the middle between two previous grid points.
The following example shows a »truncation error« due to unfavourably chosen DFT parameters. Again, we refer to the learning video (in German language)
»Fehlermöglichkeiten bei Anwendung der DFT« ⇒ "Possible errors when using the DFT".
Example 2: The graph shows the DFT result for the same x(t) and X(f) as well as the same N=16 as in Example 1, but now with finer sampling in the time domain by a factor of 2 ⇒ TA/T=0.125
The comparison with Example 1 shows:
- The spacing of the frequency samples increases from fA⋅T=0.25 to fA⋅T=0.5 .
- At the same time, TP/T decreases from 4 to 2.
- With this, only the signal components in the range |t|<T are now captured by the DFT.
⇒ With these parameters, a »truncation error« or »termination error« arises, by which the mean square error is significantly increased from MQF=10−12 to MQF=4⋅10−5.
DFT falsification due to sampling – Aliasing error
An unsuitable sampling of the time function x(t) can also significantly falsify the DFT result. This so-called »aliasing error« can be explained as follows:
- Sampling x(t) at a distance TA causes a periodic continuation of the spectrum at multiples of the periodization frequency fP=1/TA.
- If X(f) has spectral components at |f|>fP/2, the sampling theorem is not fulfilled and overlaps of the shifted frequency components to be added occur.
- Only with a band-limited signal the aliasing error can be avoided by suitable DFT parameters. In contrast, this error is unavoidable with time-limited signals ⇒ »pulses«, since time-limited signals cannot be band-limited at the same time.
- The aliasing error is reduced by finer sampling (smaller TA=1/fP). This can only be achieved with a constant TA – in order not to let the truncation error increase – by a larger N and thus a greater computational effort.
The following Example 3 shows such an aliasing error due to wrongly chosen DFT parameters:
- Compared to the comparison system according to Example 1: TA is too large and fA is too small dimensioned.
- The number of interpolation points is in both cases: N=16.
Example 3: Let the DFT parameters be N=16 and fA⋅T=0.125. Thus, we get for the other three DFT parameters:
- TP/T=8(Example 1: TP/T=4),
- fP⋅T=2(Example 1: fP⋅T=4),
- TA/T=0.5(Example 1: TA/T=0.25).
This results in the following consequences:
- The truncation error continues to play no role because of TP/T=8 (already TP/T=4 was sufficient).
- However, aliasing now arises, because the DFT is derived from many Gaussian functions at distance fP⋅T=2 (thin dashed curves in the graph).
- The DFT coefficients are falsified differently: The mean DFT coefficient (for f=0) is almost correct, while the errors of the DFT coefficients increase significantly towards the edges.
- Here, the DFT coefficient for f⋅T=−1 is twice as large as it should be, since the Gaussian function with the center at f⋅T=−2 gives the same contribution as the Gaussian function around f⋅T=0 (see yellow background).
Thus, here with MQF≈2⋅10−4 an error value four times larger than that caused by the truncation error in Example 2.
Again, we refer to the (German language) learning video:
»Fehlermöglichkeiten bei Anwendung der DFT« ⇒ "Possible errors when using the DFT".
Exercises for the chapter
Exercise 5.3: Mean Square Error