Filter Time Series with Dates
Get the temperature for given dates using WeatherData. Create a new time series with specified MissingDataMethod to fill in missing data.
In[1]:=
data:image/s3,"s3://crabby-images/4cda3/4cda3c09b541ec10a9a2d4186571c638a4f0e239" alt="Click for copyable input"
data = TimeSeries[
WeatherData["Chicago",
"Temperature", {{2015, 1, 1}, {2015, 12, 31}}],
MissingDataMethod -> "Interpolation"]
Out[1]=
data:image/s3,"s3://crabby-images/324f4/324f4a29deb2043f1e1d5f34629dfd5932b46a53" alt=""
In[2]:=
data:image/s3,"s3://crabby-images/2f784/2f784ffb5ad16404d7a88fcf0df04c03a2cb642f" alt="Click for copyable input"
DateListPlot[data, FrameLabel -> Automatic]
Out[2]=
data:image/s3,"s3://crabby-images/401b0/401b088937c3a819217ce79c8cf4200d37533feb" alt=""
Use MinFilter with one-month range to analyze when the last and first freeze occurred that year.
In[3]:=
data:image/s3,"s3://crabby-images/9c9dd/9c9dddc7d94e32902bbb35f8da1b83f5403cabc9" alt="Click for copyable input"
minF = MinFilter[data, Quantity[1, "Month"]];
show complete Wolfram Language input
Out[5]=
data:image/s3,"s3://crabby-images/b8446/b844600d8d9464ba004e6c42fc041f7c98f0e771" alt=""
First day after last spring freeze.
In[6]:=
data:image/s3,"s3://crabby-images/e12d8/e12d8a69d64fe2ce03d86d1ae7d40353e086d4e2" alt="Click for copyable input"
spring = TimeSeriesWindow[minF, {"15 April 2015", "15 May 2015"}];
In[7]:=
data:image/s3,"s3://crabby-images/a8722/a8722640ba3bd719e5742de077ec0df6e8919547" alt="Click for copyable input"
DateObject[
First@FirstCase[
spring["Path"], _?(#[[2]] > Quantity[0, "DegreesCelsius"] &)]]
Out[7]=
data:image/s3,"s3://crabby-images/39256/3925642e8ae60140dcfc4c2d904821115141883f" alt=""
First fall freeze.
In[8]:=
data:image/s3,"s3://crabby-images/e1678/e1678529f8e3209e80132a6d7738fc2b6f0605cf" alt="Click for copyable input"
fall = TimeSeriesWindow[minF, {"1 Oct 2015", "31 Oct 2015"}];
In[9]:=
data:image/s3,"s3://crabby-images/f9f23/f9f230b27d3d125973d921e9585976d4f616cfdf" alt="Click for copyable input"
DateObject[
First@FirstCase[
fall["Path"], _?(#[[2]] <= Quantity[0, "DegreesCelsius"] &)]]
Out[9]=
data:image/s3,"s3://crabby-images/484e1/484e1565467957580bea14a18c5e2a53c9b6b99a" alt=""