The Laplace Transform is a particular tool that is used in mathematics, science, engineering and so on. There are many books, web pages, and so on about it.
My animations are now on Wikipedia: https://en.wikipedia.org/wiki/Laplace_transform
And yet I cannot find a single decent visualization of it! Not a single person that I can find appears to have tried to actually visualize what it is doing. There are plenty of animations for the Fourier Transform like:
But nothing for Laplace Transform that I can find.
So, I will attempt to fill that gap.
What is the Laplace Transform?
It’s a way to represent a function that is 0 for time < 0 (typically) as a sum of many waves that look more like:
Note that what I just said isn’t entirely true, because there’s an imaginary component here too, and we’re actually integrating. So take this as a crude idea just to get started, and let’s move onto the math to get a better idea:
The goal of this is to visualize how the Laplace Transform works:
To do this, we need to look at the definition of the inverse Laplace Transform:
While pretty, it’s not so nice to work with, so let’s make the substitution:
so that our new limits are just to , and giving:
Which we will now approximate as:
The code turned out to be a bit too large for a blog post, so I’ve put it here:
Note: The graphs say “Next frequency to add: … where “, but really it should be “Next two frequencies to add: … where ” since we are adding two frequencies at a time, in such a way that their imaginary parts cancel out, allowing us to keep everything real in the plots. I fixed this comment in the code, but didn’t want to rerender all the videos.
A cubic polynomial:
A cosine wave:
Now a square wave. This has infinities going to infinity, so it’s not technically possible to plot. But I tried anyway, and it seems to visually work:
Now some that it absolutely can’t handle, like: . (A function that is 0 everywhere, except a sharp peak at exactly time = 0). In the S domain, this is a constant, meaning that we never converge. But visually it’s still cool.
Note that this never ‘settles down’ (converges) because the frequency is constantly increasing while the magnitude remains constant.
There is visual ‘aliasing’ (like how a wheel can appear to go backwards as its speed increases). This is not “real” – it is an artifact of trying to render high frequency waves. If we rendered (and played back) the video at a higher resolution, the effect would disappear.
At the very end, it appears as if the wave is just about to converge. This is not a coincidence and it isn’t real. It happens because the frequency of the waves becomes too high so that we just don’t see them, making the line appear to go smooth, when in reality the waves are just too close together to see.
The code is automatically calculating this point and setting our time step such that it only breaksdown at the very end of the video. If make the timestep smaller, this effect would disappear.
And a simple step function: