Use Databin to Store Time Series
The arrival times in a PoissonProcess are independent and follow an ExponentialDistribution. You can simulate a path of a PoissonProcess by sending signals to a Databin in time intervals specified by a simulation of an exponential distribution.
In[1]:=
data:image/s3,"s3://crabby-images/b2bad/b2bad90be47c0e8142d3596cd9f8160dbf8d3dd0" alt="Click for copyable input"
SeedRandom["11"];
\[Lambda] = 0.5;
times = RandomVariate[ExponentialDistribution[\[Lambda]], 30];
Create a Databin.
In[2]:=
data:image/s3,"s3://crabby-images/39686/39686d48d2ad534e094816a0c55ebad05d809b14" alt="Click for copyable input"
bin = CreateDatabin[]
Use the simulated times to send 1 to the databin in time intervals.
In[3]:=
data:image/s3,"s3://crabby-images/fb827/fb8279e108d2a892b1cb42ff7843d0ab6584f36e" alt="Click for copyable input"
Table[DatabinAdd[bin, <|"arrivals" -> 1|>]; Pause[t], {t, times}];
The recorded signal with the time stamps.
In[4]:=
data:image/s3,"s3://crabby-images/cb3f7/cb3f72a043ce27a56c8c4e711c3611317f2f73a1" alt="Click for copyable input"
TimeSeries[bin]
Out[4]=
data:image/s3,"s3://crabby-images/3959e/3959e456441363c258b74c6baeed83d2d74794de" alt=""
Extract the TimeSeries object.
In[5]:=
data:image/s3,"s3://crabby-images/cb1f7/cb1f777b05ae865636863f5580ae330737508272" alt="Click for copyable input"
ts1 = TimeSeries[bin]["arrivals"]
Out[5]=
data:image/s3,"s3://crabby-images/579cc/579cc3eb528adde1436c31d10cdfeb1cbd9d2f54" alt=""
This time series is irregularly sampled.
In[6]:=
data:image/s3,"s3://crabby-images/7371f/7371f90a1658cc3bb3471089a5cba0b3f1e0fa93" alt="Click for copyable input"
RegularlySampledQ[ts1]
Out[6]=
data:image/s3,"s3://crabby-images/a4cae/a4caeddc21bbaed35833fbc51b1fa5eb4b7fd0c1" alt=""
Assume TemporalRegularity so that Accumulate does not use interpolation to resample the time series with respect to the minimum time increment.
In[7]:=
data:image/s3,"s3://crabby-images/b7976/b7976c81c368e15aed6b52ecac1ac26d53bc0c95" alt="Click for copyable input"
ts2 = Accumulate[TimeSeries[ts1, TemporalRegularity -> True]]
Out[7]=
data:image/s3,"s3://crabby-images/819fe/819fea3ff5a88b500747ecece875cdfd06420b2e" alt=""
In[8]:=
data:image/s3,"s3://crabby-images/a1330/a13304522f3a4f70ed9ccd40ac71f50468809ee6" alt="Click for copyable input"
DateListStepPlot[ts2, Joined -> False, PlotTheme -> "Detailed"]
Out[8]=
data:image/s3,"s3://crabby-images/d8919/d8919a7e4be04a597b89cc2b0d35da7e2323cbea" alt=""
Estimate the PoissonProcess parameter from the signal and compare to the parameter of the ExponentialDistribution used to simulate time stamps.
In[9]:=
data:image/s3,"s3://crabby-images/c9cc2/c9cc20b8436398093917f4b77c32d603248597d6" alt="Click for copyable input"
{FindProcessParameters[ts2, PoissonProcess[\[Mu]]], \[Lambda]}
Out[9]=
data:image/s3,"s3://crabby-images/d28cf/d28cfb99d6fce5ecefcb40b3a815b9fc5308c30c" alt=""