Arduino: Frequency Transform (DFT)

by abhilash_patel in Circuits > Arduino

15613 Views, 21 Favorites, 0 Comments

Arduino: Frequency Transform (DFT)

Untitled-1.jpg

this program is to calculate frequency transform on arduino with batter control over parameters.it is solved using desecrate fouriior transform.

this is not FFT .

FFT is algorithm used to solve DFT with smaller time.

Code for FFT can be found herehere.

How It Works(concept):

Untitled-3.jpg
Untitled-4.jpg

Given program for frequency transform provides great control over output you required. this program evaluates frequency range given by user at given input for data-set.

  • In figure a data set made of two frequencies named f2 and f5 given which need to be tested. f2 and f5 are random names for two frequency, higher number for relatively higher frequency. here smaller frequency f2 has higher amplitude and f5 has smaller amplitude.
  • It can be shown mathematically that -summation of multiplication of two harmonic data-set having different frequency tends to zero(higher number of data can lead to batter result). In our case If these two multiplication frequency has same (or very close) frequency that sum of multiplication is nonzero number where amplitude depends on amplitude of data.
  • to detect specific frequency given data-set can be multiplied by various test frequencies and result can give component of that frequency in data.

How It Works(in Code):

mi.jpg
o.jpg

for that given data (f2+f5) one by one f1 to f6 is multiplies and value of sum is noted down. that final sum represents content of that frequency. rest (non-matching) of frequency should be ideally zero but it is not possible in real case. to make sum zero it is required to have infinite size of data-sets.

  • as can be shown in figure f1 to f6 trial frequency and its multiplication with data set at every point is shown.
  • in second figure summation of that multiplication at each frequency is plotted. two peaks at 1 and 5 is identifiable.

so using same approach for a random data we can evaluate for so many frequency and analyze frequency content of data.

Using Code for Frequency Analysing:

ft.jpg

for an example lets use this code to find DFT of square wave.

  • first paste attached code(dft function) after loop as shown image.

8 TERMS THAT NEEDS TO BE SPECIFY

  1. an array of which dft need to be taken
  2. size of an array
  3. time interval between 2 reading in array in milliSECONDS
  4. lower value of frequency range in Hz
  5. upper value of frequency range in Hz
  6. size of steps for frequency range
  7. repeatation of a signal(minimum 1) higher number batter accuracy but increased solution time
  8. window function:

    0 for no window
    1 for flat-top window
    2 for hann window
    3 for hamming window

(if you do not have any idea about selecting window keep default 3)

example: dft(a,8,0.5,0,30,0.5,10,3); here a is an array of size 8 element to be checked for 0 Hz to 30 Hz with 0.5 step (0,0.5,1,1.5, ... ,29,29.5,30) 10 repeatation and hamming window

here it is possible to use bigger sized array as much as arduino can handle.

Downloads

Output:

res.jpg
mon.jpg

if you comment out

Serial.print(f);
Serial.print("\t");

from code serial plotter will give nature of frequency spectrum an if not Serial monitor would give frequency with its amplitude.

Checking Various Window and Sample Sizes:

dft.jpg

in figure, frequency of sine wave is measured using different setting.

Example:

aasasas.jpg

in figure transform of data using SciLab and arduino is compared.