HNNewShowAskJobs
Built with Tanstack Start
An Interactive Guide to the Fourier Transform(betterexplained.com)
247 points by pykello 7 days ago | 43 comments
  • geokon15 hours ago

    On thing that is often overlooked but should be emphasized is that the considered frequencies are fixed values while the phase shifts are continuous values. This creates tons of downstream problems

    If your underlying signal is at frequency that is not a harmonic of the sampling length, then you get "ringing" and it's completely unclear how to deal with it (something something Bessel functions)

    Actually using DFTs is a nightmare ..

    - If I have several dominant frequencies (not multiples of the sampling rate) and I want to know them precisely, it's unclear how I can do that with an FFT

    - If I know the frequency a priori and just want to know the phase shift.. also unclear

    - If I have missing values.. how do i fill the gaps to distort the resulting spectrum as little as possible?

    - If I have samples that are not equally spaced, how am I supposed to deal with that?

    - If my measurements have errors, how do I propagate errors through the FFT to my results?

    So outside of audio where you control the fixed sample rate and the frequencies are all much lower than the sample rate... it's really hard to use. I tried to use it for a research project and while the results looked cool.. I just wasn't able to backup my math in a convincing way (though it's been a few years so I should try again with ChatGPT's hand-holding)

    I recommend people poke around this webpage to get a taste of what a complicated scary monster you're dealing with

    https://ccrma.stanford.edu/~jos/sasp/sasp.html

    • hasley14 hours ago |parent

      FFT/DFT is not precise if you do not have the exact harmonic in you signal. If you are also (or only) interested in phases you might use a maximum likelihood estimator (which brings other problems though).

      And as the previous answer said: compressed sensing (or compressive sensing) can help as well for some non-standard cases.

      • geokon12 hours ago |parent

        Do you have any good reference for compressed sensing?

        The high level description on wikipedia seems very compelling.. And would you say it'd be a huge task to really grok it?

        • ghtbircshotbe9 hours ago |parent

          Article by Terrence Tao: https://terrytao.wordpress.com/2007/04/13/compressed-sensing...

          Paper by Stan Osher et al: https://arxiv.org/abs/1104.0262

    • dsego10 hours ago |parent

      You can use single bin DFTs and not FFTs? Basically use precomputed twiddles for a specific frequency. FFT is only fast because it reuses operation across multiple frequencies, but if you need a specific frequency instead of the whole spectrum, then a single-bin DFT makese sense, right?

      https://github.com/dsego/strobe-tuner/blob/main/core/dft.odi...

    • NL80715 hours ago |parent

      Somewhat related field, compressive sensing, attempts to answer some of those questions (particularly missing data, uneven sampling and errors) using a L1 minimisation technique.

      • geokon12 hours ago |parent

        Can you recommend where to learn more about it? It looks like what I should be looking at.. hopefully not a rabbit hole :))

  • dmda day ago

    The absolute best teaching of the Fourier transform I've ever encountered is the extremely bizarre book "Who is Fourier?"

    https://www.amazon.com/Who-Fourier-Mathematical-Transnationa...

  • devanshp20 hours ago

    It's quite interesting that our ears implement a better-than-Fourier-like algorithm internally: https://arxiv.org/pdf/1208.4611

    • gsf_emergency_619 hours ago |parent

      Article on how this might work (nonlinearity)

      https://jontalle.web.engr.illinois.edu/Public/AllenSpeechPro...

      Note the two electric circuit models figs 3.2 & 3.8

  • arialdomartini21 hours ago

    Brilliant!

    I would just suggest the author to replace the sentence “99% of the time, it refers to motion in one dimension” with “most of the time” since this is a mathematical article and there’s no need to use specific numbers when they don’t reflect actual data.

  • freshtakea day ago

    If you're only interested in the gist of the concept and how it can be applied to compression, without the mathematical rigor, here is my go to: https://bertolami.com/index.php?engine=blog&content=posts&de...

  • HPsquared11 hours ago

    I'd never thought about it in this way before but the idea of writing a number as a decimal (or other) string of numerals, bears some resemblance to a Fourier transform.

    Think of the components of a written number: ones, tens, hundreds etc which have a repeating pattern. Digits are inherently periodic. Not too far from periodic basis functions.

    Both involve breaking something down into periodic components, and reversing the process by adding up the components.

    • IAmBroom2 hours ago |parent

      Clever, but only really appropriate for the most significant digit.

      The one's digit gives info about parity (odd/even), but nothing else.

  • kensa day ago

    If you're dealing with computer graphics, audio, or data analysis, I highly recommend learning Fourier transforms, because they explain a whole lot of things that are otherwise mysterious.

  • hasley14 hours ago

    I have not read the whole article. But, what is shown at the beginning is not the Fourier Transform, it is the Discrete Fourier Transform (DFT).

    Though the DFT can be implemented efficiently using the Fast Fourier Transform (FFT) algorithm, the DFT is far from being the best estimator for frequencies contained in a signal. Other estimators (like Maximum Likelihood [ML], [Root-]MUSIC, or ESPRIT) are in general far more accurate - at the cost of higher computational effort.

    • roflmaostc12 hours ago |parent

      Can you provide more details please?

      The FFT is still easy to use, and it you want a higher frequency resolution (not higher max frequency), you can zero pad your signal and get higher frequency resolution.

      • hasley8 hours ago |parent

        Zero-padding gives you a smoother curve, i.e., more points to look at. But it does not add new peaks. So, if you have two very close frequencies that produce a single peak in the DFT (w/o zero-padding), you would not get two peaks after zero-padding. In the field, were I work, resolution is understood as the minimum distance between two frequencies such that you are able to detect them individually (and not as a single frequency).

        Zero-padding helps you to find the true position (frequency) of a peak in the DFT-spectrum. So, your frequency estimates can get better. However, the peaks of a DFT are the summits of hills that are usually much wider than compared to other techniques (like Capon or MUSIC) whose spectra tend to have much narrower hills. Zero-padding does not increase the sharpness of these hills (does not make them narrower). Likewise the DFT tends to be more noisy in the frequency domain compared to other techniques which could lead to false detections (e.g. with a CFAR variant).

    • casparvitch13 hours ago |parent

      Not a particularly fair comparison, the DFT is a non-statistical operation.

      • hasley13 hours ago |parent

        Why do you think, that it is not fair?

        You can even use these algorithms with a single snapshot (spatial smoothing).

  • analog31a day ago

    My only quibble is that the article is about the discrete Fourier transform.

    • shasha day ago |parent

      It’s usually easier to explain the dft. and easier to do a periodic function than a totally arbitrary sequence.

      • krackers19 hours ago |parent

        I've actually found the opposite, it's easier to conceptually understand the continuous FT, then analyze the DTFT, DFT, and Fourier Series as special cases of applying a {periodic summation, discrete sampling} operator before the FT.

  • seam_carvera day ago

    If anyone wants to learn about the 2D DFT, the best explanation I've ever read was the relevant chapter in Digital Image Processing by Nick Efford.

    If anyone wants to see my favorite application of the 2D DFT, I made a video of how the DFT is used to remove rainbows in manga on Kaleido 3 color eink on Kobo Colour:

    https://youtu.be/Dw2HTJCGMhw?si=J6dUYOj2IRX1nPRF

    • brad0a day ago |parent

      In the video you show a 2D mask to blur diagonal lines. How is that mask applied to the DFT? Is the mask also converted to a DFT and the two signals get combined?

      • seam_carver19 hours ago |parent

        Just remove anything under the mask basically, similar to a low pass filter.

  • stevenjgarner6 hours ago

    This is great! I would love to see this method extended to the full Pasterski–Strominger–Zhiboedov (PSZ) triangle, where Fourier transforms are the binding relationships tying together soft theorems and memory effects. Such an extended guide would be a powerful interaction encompassing also vacuum transitions and Ward's identities. A "smoothie" combining the theory of relativity, quantum field theory and quantum gravity might make those subjects more accessible.

  • vismit200012 hours ago

    This is the best content on this topic - a 2023 video by Reducible: https://www.youtube.com/watch?v=yYEMxqreA10

  • biophysboya day ago

    My favorite application of the Fourier transform is converting convolution into pointwise multiplication. This is used to speed up multiple sequence alignment in bioinformatics.

  • zkmona day ago

    It is more about the duality between the amplitude and frequency spaces and conversion between them. A bit similar to Hadamard gate for transforming a quantum state from computational basis to diagonal basis.

  • kuharicha day ago

    Past comments: https://news.ycombinator.com/item?id=38652794

  • mohas14 hours ago

    Will I ever be able to learn the Fourier transform?

    • rkomorn14 hours ago |parent

      Yes! Step 1 is forgetting about the name so it doesn't feel as daunting.

      Disclaimer: I've not actually done step 1, but I have more faith in you than in myself.

  • amarant15 hours ago

    I've decided math isn't my thing. The first part of the article I couldn't stop thinking "how the hell would you construct a banana filter?" And the entire smoothie metaphor seemed to describe nothing at all.

    Then there was something about circles and why do some people call them some other silly thing?

    So far, so utterly meaningless, as far as I could tell. just seemed like meaningless babble to make even a kindergartner feel comfortable with the article, but it didn't seem to have communicated much of anything, really.

    Then there were circles. Some of them were moving, one of them had a sinus wave next to it and some balls were tracing both in sync, indicating which part of the sinus wave equalled which part of the circle I guess?

    I understood none of it.

    I asked chat gpt to explain to me, i think it has read this article cause it used the smoothie analogy as well. I still don't understand what that analogy is meant to mean.

    Then finally I found this: If someone plays a piano chord, you hear one sound. But that sound is actually made of multiple notes (multiple frequencies).

    The Fourier Transform is the tool that figures out:

    which notes (frequencies) are present, and how loud each one is

    That, finally, makes sense.

    • yatopifo4 hours ago |parent

      The piano analogy is incomplete. First, of all, a piano constructs sounds by combining multiple string sounds in a unique manner. But the idea behind transforms (Fourier being a particular case) is that you can take a function (“sound”) that isn’t necessarily produced by combining components and you can still decompose it into a sum of components. This decomposition is not unique in the general case as there are many different transforms yielding different results. However, from the mathematical (and i believe, quantum mechanical) standpoint, there is full equivalence between the original function and its transforms.

      The other important point is that Fourier doesn’t really give you frequency and loudness. It gives you complex numbers that can be used to estimate the loudness of different frequencies. But the complex nature of the transform is somewhat more complex than that (accidental pun).

      A fun fact. The Heisenberg uncertainty principle can be viewed as the direct consequence of the nature of the Fourier transform. In other words, it is not an unexplained natural wonder but rather a mathematical inevitability. I only wish we could say the same about the rest of quantum theory!

      • IAmBroom2 hours ago |parent

        All analogies are incomplete. It's kinda inherent in the definition of the word.

        But it is a lovely, real-world and commonly understood example of how harmonics can work, and thus a nice baby-step into the idea of spectral analysis.

    • dsego10 hours ago |parent

      I wonder if my approach would help with your understanding?

      https://dsego.github.io/demystifying-fourier/

  • constantcryinga day ago

    >The Fourier Transform is one of deepest insights ever made.

    No, it is not. In fact it is quite a superficial example of a much deeper theory, behind functions, their approximations and their representations.

    • fedsocpuppeta day ago |parent

      The Fourier transform predates functional analysis by a century. I don't see the point in downplaying its significance just because 'duh it's simply a unitary linear operator on L2'.

      • NewsaHackOa day ago |parent

        But is it the deepest insights ever made?

        • badlibrariana day ago |parent

          The Fourier Transform isn't even Fourier's deepest insight. Unless we're now ranking scientific discoveries based on whether or not they get a post every weekend on HN.

          The FFT is nifty but that's FINO. The Google boys also had a few O(N^2) to O(N log N) moments. Those seemed to move the needle a bit as well.

          But even if we restrict to "things that made Nano Banana Pro possible" Shannon and Turing leapfrog Fourier.

          • lispisoka day ago |parent

            >Unless we're now ranking scientific discoveries based on whether or not they get a post every weekend on HN.

            Glad I'm not the only one who noticed there is a weekly (or more) post on what Fourier transform is.

            • chemotaxis16 hours ago |parent

              It's really getting in the way of all the daily AI opinion pieces I come here to read.

              More seriously, there are tens of thousands of people who come to HN. If Fourier stuff gets upvoted, it's because people find it informative. I happen to know the theory, but I wouldn't gatekeep.