Smooth a Simulated Particle Trajectory
Use a combination of BlockMap and TrimmedMean to smooth out data from a particle trajectory.
Simulate a stochastic path by adding noise to an exact trajectory.
In[1]:=
data:image/s3,"s3://crabby-images/5c474/5c474b6244a707bf887d585730190fceaea18551" alt="Click for copyable input"
exact[u_] := {u Cos[u], u Sin[u]}
noise[u_] := RandomReal[CauchyDistribution[0, 1], 2]
data = Table[exact[u] + noise[u], {u, 0, 6 \[Pi], 1/100}];
In[2]:=
data:image/s3,"s3://crabby-images/96d00/96d00670e1fc29c1655dc3339ac9d48652f8ad28" alt="Click for copyable input"
ListPlot[data, AspectRatio -> Automatic]
Out[2]=
data:image/s3,"s3://crabby-images/66b94/66b94a705379bdb627c1063aa73ca872fb289e82" alt=""
Smooth the simulated trajectory with BlockMap using a moving TrimmedMean to eliminate possible outliers.
In[3]:=
data:image/s3,"s3://crabby-images/0f5ae/0f5ae43db0ac2b3a8addd4904eabee309f25c7ac" alt="Click for copyable input"
smooth[r_] := BlockMap[TrimmedMean, data, r, 1]
Increase the window size to get a smoother trajectory.
In[4]:=
data:image/s3,"s3://crabby-images/1f1fd/1f1fd19256295d861572321f9fffe461314f40df" alt="Click for copyable input"
Table[ListPlot[smooth[r],
AspectRatio -> Automatic], {r, {25, 50, 100, 200}}]
Out[4]=
data:image/s3,"s3://crabby-images/dc4bd/dc4bd9fbcbc7a935632bcc3db982a11c2447442d" alt=""