亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fourier.pas

?? Delphi 的數學控件
?? PAS
字號:
(*==========================================================================

    fourier.pas  -  Don Cross <dcross@intersrv.com>

    Modified by Jean Debord <JDebord@compuserve.com> for use with TP Math.

    This is a Turbo Pascal Unit for calculating the Fast Fourier Transform
    (FFT) and the Inverse Fast Fourier Transform (IFFT).
    Visit the following URL for the latest version of this code.
    This page also has a C/C++ version, and a brief discussion of the
    theory behind the FFT algorithm.

       http://www.intersrv.com/~dcross/fft.html#pascal

    Revision history [most recent first]:

2002 January 20 [Jean Debord]
     Modified for use with Delphi 6:
    1. Renamed MaxPower as MaxPowerOfTwo. Interfaced this variable.
       Set its default value to 20.
    2. Changed vector type PVector to dynamic array type TVector.
    3. Used overloaded procedure FFT for both real and integer inputs.
    4. Removed procedure FFT_Integer_Cleanup which was no longer necessary.
    5. Slightly modified function NumberOfBitsNeeded so that Delphi does
       not complain that its value may be undefined.

1998 November 27 [Jean Debord]
     Replaced the constant MAXPOWER by a variable which is initialized
     according to the value of MAX_FLT defined in MATRICES.PAS

1997 March 1 [Jean Debord]
     Modifications for use with the TP Math library:
    1. Added a USES clause for the TP Math units.
    2. Set real type to Float (defined in FMATH.PAS)
    3. Added a constant MAXPOWER to define the maximum number of points.
       Modified functions IsPowerOfTwo and NumberOfBitsNeeded accordingly.
    4. Changed array types to those defined in TP Math. Modified array
       allocation, deallocation and reference accordingly.
    5. Removed compiler directives, which were no longer necessary.
    6. Modified some typographical and formatting options so that the
       code looks like the other TP Math units.
    No modification was made to the original algorithm.

1996 December 11 [Don Cross]
    Improved documentation of the procedure CalcFrequency.
    Fixed some messed up comments in procedure IFFT.

1996 December 6 [Don Cross]
    Made procedure 'fft_integer' more efficient when buffer size changes
    in successive calls:  the buffer is now only resized when the input
    has more samples, not a differing number of samples.
    Also changed the way 'fft_integer_cleanup' works so that it is
    more "bullet-proof".

1996 December 4 [Don Cross]
    Adding the procedure 'CalcFrequency', which calculates the FFT
    at a specific frequency index p=0..n-1, instead of the whole
    FFT.  This is O(n^2) instead of O(n*log(n)).

1996 November 30 [Don Cross]
    Adding a routine to allow FFT of an input array of integers.
    It is called 'fft_integer'.

1996 November 18 [Don Cross]
    Added some comments.

1996 November 17 [Don Cross]
    Wrote and debugged first version.

==========================================================================*)

unit fourier;

interface

uses
  fmath, matrices;

var
  MaxPowerOfTwo : Integer;

(*---------------------------------------------------------------------------
  procedure FFT

  Calculates the Fast Fourier Transform of the array of complex numbers
  represented by 'RealIn' and 'ImagIn' to produce the output complex
  numbers in 'RealOut' and 'ImagOut'.
---------------------------------------------------------------------------*)
procedure FFT(NumSamples                       : Integer;
              RealIn, ImagIn, RealOut, ImagOut : TVector); overload;

(*---------------------------------------------------------------------------
  procedure FFT for integer input arrays.
---------------------------------------------------------------------------*)
procedure FFT(NumSamples       : Integer;
              RealIn, ImagIn   : TIntVector;
              RealOut, ImagOut : TVector); overload;

(*---------------------------------------------------------------------------
  procedure IFFT

  Calculates the Inverse Fast Fourier Transform of the array of complex
  numbers represented by 'RealIn' and 'ImagIn' to produce the output complex
  numbers in 'RealOut' and 'ImagOut'.
---------------------------------------------------------------------------*)
procedure IFFT(NumSamples                       : Integer;
               RealIn, ImagIn, RealOut, ImagOut : TVector);

(*--------------------------------------------------------------------------
   procedure CalcFrequency

   This procedure calculates the complex frequency sample at a given
   index directly.  Use this instead of 'FFT' when you only need one
   or two frequency samples, not the whole spectrum.

   It is also useful for calculating the Discrete Fourier Transform (DFT)
   of a number of data which is not an integer power of 2. For example,
   you could calculate the DFT of 100 points instead of rounding up to
   128 and padding the extra 28 array slots with zeroes.
--------------------------------------------------------------------------*)
procedure CalcFrequency(NumSamples, FrequencyIndex : Integer;
                        RealIn, ImagIn             : TVector;
                        var RealOut, ImagOut       : Float);

implementation

  function IsPowerOfTwo(X : Integer) : Boolean;
  var
    I, Y : Integer;
  begin
    Y := 2;
    for I := 1 to Pred(MaxPowerOfTwo) do
      begin
        if X = Y then
          begin
            IsPowerOfTwo := True;
            Exit;
          end;
        Y := Y shl 1;
      end;
    IsPowerOfTwo := False;
  end;

  function NumberOfBitsNeeded(PowerOfTwo : Integer) : Integer;
  var
    I : Integer;
  begin
    for I := 0 to MaxPowerOfTwo do
      begin
        if (PowerOfTwo and (1 shl I)) <> 0 then
          begin
            NumberOfBitsNeeded := I;
            Exit;
          end;
      end;
    NumberOfBitsNeeded := 0;
  end;

  function ReverseBits(Index, NumBits : Integer) : Integer;
  var
    I, Rev : Integer;
  begin
    Rev := 0;
    for I := 0 to NumBits - 1 do
      begin
        Rev := (Rev shl 1) or (Index and 1);
        Index := Index shr 1;
      end;
    ReverseBits := Rev;
  end;

  procedure FourierTransform(AngleNumerator                   : Float;
                             NumSamples                       : Integer;
                             RealIn, ImagIn, RealOut, ImagOut : TVector);
  var
    NumBits, I, J, K, N, BlockSize, BlockEnd : Integer;
    Delta_angle, Delta_ar                    : Float;
    Alpha, Beta                              : Float;
    Tr, Ti, Ar, Ai                           : Float;
  begin
    if not IsPowerOfTwo(NumSamples) or (NumSamples < 2) then
      begin
        Write('Error in procedure Fourier:  NumSamples=', NumSamples);
        WriteLn(' is not a positive integer power of 2.');
        Halt;
      end;

    NumBits := NumberOfBitsNeeded(NumSamples);
    for I := 0 to NumSamples - 1 do
      begin
        J := ReverseBits(I, NumBits);
        RealOut[J] := RealIn[I];
        ImagOut[J] := ImagIn[I];
      end;

    BlockEnd := 1;
    BlockSize := 2;
    while BlockSize <= NumSamples do
      begin
        Delta_angle := AngleNumerator / BlockSize;
        Alpha := Sin(0.5 * Delta_angle);
        Alpha := 2.0 * Alpha * Alpha;
        Beta := Sin(Delta_angle);

        I := 0;
        while I < NumSamples do 
          begin
            Ar := 1.0;    (* cos(0) *)
            Ai := 0.0;    (* sin(0) *)

            J := I;
            for N := 0 to BlockEnd - 1 do
              begin
                K := J + BlockEnd;
                Tr := Ar * RealOut[K] - Ai * ImagOut[K];
                Ti := Ar * ImagOut[K] + Ai * RealOut[K];
                RealOut[K] := RealOut[J] - Tr;
                ImagOut[K] := ImagOut[J] - Ti;
                RealOut[J] := RealOut[J] + Tr;
                ImagOut[J] := ImagOut[J] + Ti;
                Delta_ar := Alpha * Ar + Beta * Ai;
                Ai := Ai - (Alpha * Ai - Beta * Ar);
                Ar := Ar - Delta_ar;
                Inc(J);
              end;

            I := I + BlockSize;
          end;

        BlockEnd := BlockSize;
        BlockSize := BlockSize shl 1;
      end;
  end;

  procedure FFT(NumSamples                       : Integer;
                RealIn, ImagIn, RealOut, ImagOut : TVector);
  begin
    FourierTransform(2 * PI, NumSamples, RealIn, ImagIn, RealOut, ImagOut);
  end;

  procedure IFFT(NumSamples                       : Integer;
                 RealIn, ImagIn, RealOut, ImagOut : TVector);
  var
    I : Integer;
  begin
    FourierTransform(- 2 * PI, NumSamples, RealIn, ImagIn, RealOut, ImagOut);

    { Normalize the resulting time samples }
    for I := 0 to NumSamples - 1 do
      begin
        RealOut[I] := RealOut[I] / NumSamples;
        ImagOut[I] := ImagOut[I] / NumSamples;
      end;
  end;

var
  RealTemp, ImagTemp : TVector;
  TempArraySize      : Integer;

  procedure FFT(NumSamples       : Integer;
                RealIn, ImagIn   : TIntVector;
                RealOut, ImagOut : TVector); overload;
  var
    I : Integer;
  begin
    if NumSamples > TempArraySize then
      begin
        DimVector(RealTemp, NumSamples);
        DimVector(ImagTemp, NumSamples);
        TempArraySize := NumSamples;
      end;

    for I := 0 to NumSamples - 1 do
      begin
        RealTemp[I] := RealIn[I];
        ImagTemp[I] := ImagIn[I];
      end;

    FourierTransform(2 * PI, NumSamples, RealTemp, ImagTemp, RealOut, ImagOut);
  end;

  procedure CalcFrequency(NumSamples, FrequencyIndex : Integer;
                          RealIn, ImagIn             : TVector;
                          var RealOut, ImagOut       : Float);
  var
    K                             : Integer;
    Cos1, Cos2, Cos3, Theta, Beta : Float;
    Sin1, Sin2, Sin3              : Float;
  begin
    RealOut := 0.0;
    ImagOut := 0.0;
    Theta := 2 * PI * FrequencyIndex / NumSamples;
    Sin1 := Sin(- 2 * Theta);
    Sin2 := Sin(- Theta);
    Cos1 := Cos(- 2 * Theta);
    Cos2 := Cos(- Theta);
    Beta := 2 * Cos2;
    for K := 0 to NumSamples - 1 do
      begin
        { Update trig values }
        Sin3 := Beta * Sin2 - Sin1;
        Sin1 := Sin2;
        Sin2 := Sin3;

        Cos3 := Beta * Cos2 - Cos1;
        Cos1 := Cos2;
        Cos2 := Cos3;

        RealOut := RealOut + RealIn[K] * Cos3 - ImagIn[K] * Sin3;
        ImagOut := ImagOut + ImagIn[K] * Cos3 + RealIn[K] * Sin3;
      end;
  end;

begin
  MaxPowerOfTwo := 20;
  TempArraySize := 0;   { Flag that buffers RealTemp, ImagTemp not allocated }
end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费成人在线视频观看| 蜜臀av一区二区在线免费观看| 亚洲欧洲制服丝袜| 亚洲国产日日夜夜| 麻豆精品一区二区三区| 国产成人a级片| 欧美影视一区在线| 久久久三级国产网站| 亚洲日本一区二区三区| 一区二区不卡在线播放| 久久国产乱子精品免费女| 国产成人福利片| 欧美日韩成人综合在线一区二区| 久久毛片高清国产| 一区二区日韩电影| 国产美女娇喘av呻吟久久| 91久久久免费一区二区| 久久嫩草精品久久久久| 婷婷成人综合网| www.色精品| 91精品国产综合久久香蕉的特点 | 成人精品视频网站| 欧美人狂配大交3d怪物一区 | 欧美视频在线播放| 欧美激情综合五月色丁香小说| 亚洲一区影音先锋| 国产99久久久国产精品免费看| 欧美日本韩国一区二区三区视频| 中文字幕日韩精品一区 | 精品99一区二区三区| 一区二区在线观看不卡| 国产精品99久久久久久宅男| 欧美一区二区三区视频在线观看 | 亚洲欧美综合色| 美女视频免费一区| av中文字幕亚洲| 久久精品欧美一区二区三区麻豆| 婷婷久久综合九色综合伊人色| 日本韩国精品在线| 国产精品乱子久久久久| 国产精品99精品久久免费| 欧美一区二区视频网站| 亚洲成a人片综合在线| 色婷婷综合久久| 亚洲免费观看高清完整版在线观看 | 六月丁香婷婷色狠狠久久| 欧美性猛交xxxx黑人交| 一区二区三区中文免费| 色综合视频在线观看| 国产欧美一区二区在线观看| 精品一区二区日韩| 欧美草草影院在线视频| 青草av.久久免费一区| 日韩一级大片在线| 日韩国产成人精品| 91麻豆精品国产| 三级在线观看一区二区| 欧美一区二区三区在线视频| 日韩高清在线一区| 久久久久久久国产精品影院| 水蜜桃久久夜色精品一区的特点| 欧美日韩一区二区在线观看视频| 亚洲图片欧美视频| 欧美精三区欧美精三区| 另类小说欧美激情| 国产喂奶挤奶一区二区三区| 不卡的电影网站| 亚洲一二三四在线| www.日本不卡| 亚洲一卡二卡三卡四卡五卡| 欧美日本一区二区在线观看| 男人操女人的视频在线观看欧美| 欧美刺激脚交jootjob| 国产精品69久久久久水密桃| 欧美亚洲图片小说| 麻豆精品在线视频| 亚洲午夜久久久久中文字幕久| 精品成人在线观看| 欧美日韩一区国产| 99久久精品国产毛片| 蜜臀av一区二区在线免费观看| 亚洲色图欧美偷拍| 欧美大胆一级视频| 在线免费观看成人短视频| 国产精品一卡二| 日本美女一区二区三区视频| 亚洲欧美日韩中文字幕一区二区三区 | 在线观看日产精品| www.欧美日韩| 国产91精品一区二区麻豆亚洲| 亚洲成人免费在线| 亚洲欧美偷拍卡通变态| 亚洲国产高清在线| 国产丝袜欧美中文另类| 欧美一级二级三级蜜桃| 欧美三电影在线| 色欧美乱欧美15图片| 95精品视频在线| 99久久婷婷国产综合精品| 粉嫩在线一区二区三区视频| 久久99国产精品麻豆| 日韩专区中文字幕一区二区| 亚洲午夜av在线| 亚洲成人先锋电影| 三级欧美韩日大片在线看| 亚洲午夜视频在线观看| 一区二区三区日韩| 一区二区三区av电影 | 欧美综合一区二区| 91麻豆精品一区二区三区| 成人精品一区二区三区四区 | 欧美日韩国产影片| 欧美撒尿777hd撒尿| 精品视频在线看| 欧美日韩久久不卡| 67194成人在线观看| 欧美日韩午夜精品| 欧美视频在线一区二区三区 | 色综合久久久久网| 欧美性猛片xxxx免费看久爱| 欧美色图12p| 91麻豆精品久久久久蜜臀| 欧美高清性hdvideosex| 欧美一区二区三区不卡| 精品理论电影在线观看| 国产色产综合产在线视频| 国产欧美日韩在线视频| 国产精品美女久久久久久久| 国产精品伦理在线| 一区二区三区在线视频播放| 亚洲综合色噜噜狠狠| 亚洲超丰满肉感bbw| 免费在线观看视频一区| 国产精品一二二区| 91亚洲国产成人精品一区二区三| 色综合一区二区三区| 91国偷自产一区二区使用方法| 欧美日韩极品在线观看一区| 日韩欧美二区三区| 国产精品精品国产色婷婷| 亚洲一区二区三区四区在线观看| 日韩国产高清影视| 国产69精品一区二区亚洲孕妇| 97久久精品人人做人人爽| 91麻豆精品国产自产在线观看一区| 欧美成人精品1314www| 国产精品成人免费| 日韩成人精品在线| www.99精品| 91精品国产色综合久久ai换脸 | 亚洲一区自拍偷拍| 国产在线播放一区| 在线视频国产一区| 欧美精品一区二区三区高清aⅴ | 国产精品一区二区果冻传媒| 欧美在线制服丝袜| 久久精品夜夜夜夜久久| 亚洲高清在线视频| 成人高清免费观看| 欧美一区日韩一区| 亚洲伦理在线免费看| 狠狠久久亚洲欧美| 欧美色网站导航| 国产精品色噜噜| 美日韩黄色大片| 欧美主播一区二区三区美女| 久久视频一区二区| 日韩精彩视频在线观看| 99久久免费视频.com| 精品国产91久久久久久久妲己 | 国产精品国产馆在线真实露脸| 秋霞午夜鲁丝一区二区老狼| 日本久久一区二区| 久久这里只精品最新地址| 亚洲午夜久久久久久久久久久| 国产精品亚洲一区二区三区妖精 | 青青草精品视频| 欧美日韩日日骚| 亚洲另类在线制服丝袜| 不卡电影免费在线播放一区| 精品国产髙清在线看国产毛片| 日韩中文字幕区一区有砖一区 | 国产电影一区在线| 在线电影国产精品| 亚洲自拍偷拍欧美| 在线欧美日韩精品| 亚洲综合激情小说| 色av一区二区| 亚洲理论在线观看| 日本乱人伦aⅴ精品| 亚洲免费观看高清完整版在线观看| 成人国产精品视频| 欧美国产精品中文字幕| 国产成人av电影在线| 久久久久97国产精华液好用吗| 九九**精品视频免费播放| 欧美不卡一二三| 国产一区中文字幕| 日本一区二区免费在线观看视频| 国产美女视频91|