Skip to main content

AI-based Fourier Analysis using sinusoidal neural networks

Project description

AI-Based Fourier Analysis (aifourier)

aifourier_logo

“Machines can learn Fourier analysis.”

A Python library that approximates Fourier decomposition using a sinusoidal neural network.

Instead of explicitly computing Fourier integrals, this library learns the frequency components of a signal through optimization.


✨ Features

  • 🔊 Analyze audio signals (.wav, .mp3, .flac, .ogg)

  • 🧠 Neural network with sinusoidal activation

  • 📊 Extract:

    • Frequencies in Hz
    • Phase shift
    • Amplitude
  • ⚡ Simple one-line API

  • 📁 Output as Pandas DataFrame


📦 Installation

pip install aifourier

🚀 Usage

import aifourier as aif

df = aif.analyze("audio.mp3")

print(df.head())

📊 Output

The result is a DataFrame containing:

Column Description
Frequencies Learned frequencies (Hz)
Phase shift Phase of each component
Amplitudes Contribution strength of each mode

🧠 How It Works

The signal is approximated as:

y(t) ≈ Σ Aᵢ sin(ωᵢ t + φᵢ)

Where:

  • Aᵢ = amplitude
  • ωᵢ = angular frequency
  • φᵢ = phase

These parameters are learned by a neural network instead of computed analytically.


⚙️ Parameters

aif.analyze(audio_path, max_modes=10000, epochs=256,use_phase_shift=True,learning_rate=0.00001,save_model=None,verbose=2,positive_freqs_only=True,abs_amplitudes=True)
  • audio_path : Path to audio file
  • max_modes : Number of sinusoidal components
  • epochs : Training iterations (higher = better approximation)
  • use_phase_shift : If this set to False, all phase shifts are set to zero.
  • learning_rate : Learning rate of NN
  • save_model : Path to save learned model
  • verbose : Modes to show training behavior, which can be set to 0,1,2.
  • positive_freqs_only : If this set to True, this will keep the positive frequencies and delete the negative ones.
  • abs_amplitudes : If this set to True, all negative amplitudes will be positive-valued.

📁 Example

See the examples/ folder for a complete demo:

cd examples
python example.py

This will:

  • Analyze bird.mp3
  • Generate frequency components
  • Save results
  • Plot the spectrum

The frequency spectrum of bird.mp3 is shown below:

Spectrum of bird.mp3


⚖️ Comparison with FFT

Method Approach
FFT Analytical, deterministic
aifourier Learning-based, approximate

This project explores whether neural networks can discover Fourier structure from data.


🚧 Limitations

  • Approximation quality depends on training
  • Slower than FFT
  • Results may vary between runs

💡 Future Ideas

  • Signal reconstruction from learned parameters
  • FFT comparison mode
  • Real-time signal analysis (oscilloscope / radio)
  • Complex-valued extensions

👤 Author

Jovan, 2026


📜 License

MIT License


“What Fourier derives analytically, neural networks can approximate through learning.”

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aifourier-2.0.2.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aifourier-2.0.2-py3-none-any.whl (5.3 kB view details)

Uploaded Python 3

File details

Details for the file aifourier-2.0.2.tar.gz.

File metadata

  • Download URL: aifourier-2.0.2.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for aifourier-2.0.2.tar.gz
Algorithm Hash digest
SHA256 c7fcab459d5223e93232ddcd35b17c96a1abca54bddca5fbf58d917d37293a2f
MD5 950bd4223b32f7227ccf62deffe582fc
BLAKE2b-256 614f4035c7af2c640ef7eea3966ca5f4edf0ab6055c424685cf59b617003bc4b

See more details on using hashes here.

File details

Details for the file aifourier-2.0.2-py3-none-any.whl.

File metadata

  • Download URL: aifourier-2.0.2-py3-none-any.whl
  • Upload date:
  • Size: 5.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for aifourier-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 96e477f619d72391618fb4d43fb8712711157ec587e5d6102a72f883b4acc64e
MD5 de208d8b98d495a607f3a7f7e00590c2
BLAKE2b-256 d6e25cd9011606e5ec1db6cb5964dcb7bbb170196976b810528906ba3ed37731

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page