FftFlat 1.0.1

dotnet add package FftFlat --version 1.0.1
NuGet\Install-Package FftFlat -Version 1.0.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FftFlat" Version="1.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FftFlat --version 1.0.1
#r "nuget: FftFlat, 1.0.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install FftFlat as a Cake Addin
#addin nuget:?package=FftFlat&version=1.0.1

// Install FftFlat as a Cake Tool
#tool nuget:?package=FftFlat&version=1.0.1

FftFlat

The purpose of this library is to provide a fast FFT (Fast Fourier Transform) implementation, entirely in pure C#. This library is adapted from General Purpose FFT Package by Ooura, modified to be compatible with the .NET Standard complex number type.

This library was created as an FFT implementation for NumFlat, a comprehensive numerical computing library written in pure C#. If you're interested in numerical computing with C#, please check out NumFlat.

Features

  • Fast: More than four times as fast as the managed FFT implementation in Math.NET Numerics.
  • Lightweight: Small code size, with no dependencies other than .NET Standard 2.1.

Installation

The NuGet package is available:

Install-Package FftFlat

If you don't want to add a DLL, copy the .cs files to your project.

Usage

First, add a using statement for the FftFlat namespace.

using FftFlat;

To perform FFT or IFFT, create an instance of FastFourierTransform and call the appropriate method.

var samples = new Complex[1024];
samples[0] = 1;

var fft = new FastFourierTransform(1024);
fft.Forward(samples);

Important Notices

Ooura's original FFT implementation is based on a different definition from that used in Math.NET Numerics. FFtFlat adjusts this difference, ensuring its results match those of Math.NET Numerics' FFT.

Normalization is only done during the IFFT. This is similar to using FourierOptions.AsymmetricScaling for FFT in Math.NET Numerics.

Note that the FastFourierTransform object is not thread-safe. If performing FFT across multiple threads, ensure a separate instance is provided for each thread.

Demo

In this demo video, the spectrum is visualized in real-time as sound is played using AudioStream of RayLib-CsLo.

https://www.youtube.com/watch?v=KTpG_z_ejZ0

Performance

The following is a benchmark comparing this with other pure C# FFT implementations. In this benchmark, the time taken to perform FFT and IFFT on a random signal was measured. The FFT lengths used were powers of two, ranging from 256 to 8192.

Complex FFT

Method Length Mean Error StdDev Median Allocated
FftFlat 2048 17.664 μs 0.0444 μs 0.0415 μs 17.664 μs -
FftSharp 2048 203.196 μs 0.6797 μs 0.6358 μs 203.137 μs -
MathNet 2048 71.875 μs 0.5197 μs 0.4340 μs 71.836 μs 25660 B
FftFlat 4096 36.990 μs 0.2119 μs 0.1983 μs 37.014 μs -
FftSharp 4096 439.636 μs 1.4182 μs 1.3265 μs 439.750 μs -
MathNet 4096 157.341 μs 0.6241 μs 0.5211 μs 157.270 μs 33650 B
FftFlat 8192 83.777 μs 0.1272 μs 0.1128 μs 83.769 μs -
FftSharp 8192 954.118 μs 2.7325 μs 2.5560 μs 953.749 μs -
MathNet 8192 343.381 μs 5.1914 μs 4.8561 μs 339.598 μs 47481 B

Real FFT

Method Length Mean Error StdDev Median Allocated
FftFlat 2048 10.303 μs 0.0359 μs 0.0336 μs 10.296 μs -
FftSharp 2048 208.290 μs 0.6072 μs 0.5679 μs 208.354 μs 98416 B
MathNet 2048 77.546 μs 0.5357 μs 0.4749 μs 77.576 μs 90663 B
FftFlat 4096 22.647 μs 0.1032 μs 0.0966 μs 22.640 μs -
FftSharp 4096 454.185 μs 1.5450 μs 1.4452 μs 454.305 μs 196720 B
MathNet 4096 179.540 μs 1.2277 μs 1.1484 μs 179.667 μs 165035 B
FftFlat 8192 47.374 μs 0.2011 μs 0.1881 μs 47.337 μs -
FftSharp 8192 1,034.310 μs 3.5584 μs 3.1544 μs 1,034.975 μs 393356 B
MathNet 8192 417.383 μs 0.5965 μs 0.5288 μs 417.317 μs 309285 B

Todo

  • ✅ FFT for power-of-two length samples
  • ✅ Real FFT
  • ⬜ Other transformations (such as cosine transform)
  • ⬜ Support for 32-bit floating-point numbers
  • ⬜ FFT for arbitrary length samples

License

FftFlat is available under the MIT license.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.1

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on FftFlat:

Package Downloads
NumFlat

A numerical computation library for C#

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.1 239 1/13/2024
1.0.0 88 1/10/2024
0.3.1 91 1/7/2024
0.3.0 104 12/28/2023
0.2.1 97 12/16/2023
0.2.0 104 12/15/2023
0.1.0 168 10/24/2023