Undergrad How Do You Fit a Sine Wave to Data Points?

Click For Summary
SUMMARY

To fit a sine wave to a set of data points, one must determine the parameters: frequency (f), amplitude (a), and phase (p) for the function f(x) = a ⋅ sin(x ⋅ f + p). The typical approach involves using least squares fitting to minimize the sum of squared deviations. Resources such as statistics textbooks and online tutorials provide foundational knowledge on least squares methods and nonlinear optimization techniques. Additionally, Fourier transforms (FFT, DFT) can be employed for fitting sine and cosine functions.

PREREQUISITES
  • Understanding of least squares fitting
  • Familiarity with sine and cosine functions
  • Knowledge of nonlinear optimization algorithms
  • Basic concepts of Fourier transforms (FFT, DFT)
NEXT STEPS
  • Study least squares fitting techniques in statistics textbooks
  • Learn about nonlinear quadratic optimization algorithms
  • Explore Fourier transform methods for function fitting
  • Implement a sine wave fitting function in programming languages like Python or MATLAB
USEFUL FOR

Data analysts, statisticians, and software developers interested in implementing sine wave fitting algorithms for data analysis and modeling.

Simoyd
Messages
3
Reaction score
0
So my question is, how does this work (hopefully I'm allowed to do hyperlinks):
https://www.desmos.com/calculator/zlvrts7mul

Given a table of x and y coordinates, how do I find the sin wave of best fit. I need to get f (frequency), a (amplitude), and p (phase) for the function in this form f(x) = a ⋅ sin( x ⋅ f + p )

My end goal is to have a software function that can do this. I'm really having difficulty figuring out where to start :(. I'd like to also be able to do this for cos(), but I'm not sure if I can figure out cos based on how sin works.

I'd like to understand how it's done, but at the same time I'm a bit scared that this might be way over my head. Any help would be appreciated.
 
Mathematics news on Phys.org
It depends a bit on your data, the typical approach would be a least squares fit where you find parameters a,f,p that minimize the sum of squared deviations (or squared [deviations divided by the uncertainty], if known for each entry). There are programs to do that automatically.
It doesn't matter if you fit a sine or a cosine or any other reasonable function, the algorithm is the same.

f in your formula is the frequency multiplied by 2 pi, by the way.
 
oh yes, 2 pi I forgot.

I guess I know that there are programs that do this. I want to have my own program do this. I'm very confused with how least squares works. I've looked it up on google a bunch but just get confused. Is there maybe a resource that you would suggest?
 
Every statistics textbook should cover it, and various websites should have good descriptions. The basic idea is not complicated, doing that efficiently for more complex functions can be challenging but with a sine wave it should be fine.
 
And, of course, you can use some form of a Fourier transform, FFT, DFT,...
 
For linear models, a typical statistics book would cover this process. For nonlinear functions with parameters like you have, nonlinear quadratic optimization algorithms have been developed. They use the gradient of the quadratic error function to find the changes of parameters a, f, and p that will lead it (usually step-by-step) to values a=a0, f=f0, p=p0, that give a minimum error. It is a studied in nonlinear programming.
 

Similar threads

  • · Replies 7 ·
Replies
7
Views
3K
  • · Replies 8 ·
Replies
8
Views
2K
  • · Replies 6 ·
Replies
6
Views
3K
  • · Replies 3 ·
Replies
3
Views
1K
  • · Replies 2 ·
Replies
2
Views
3K
  • · Replies 61 ·
3
Replies
61
Views
11K
Replies
7
Views
2K
  • · Replies 1 ·
Replies
1
Views
1K
  • · Replies 2 ·
Replies
2
Views
3K
  • · Replies 2 ·
Replies
2
Views
2K