Time Series Forecasting
Datasiv provides a suite of machine learning components you can embed on top of data sources in your application.
In this sample tutorial, we will show you how to run time series forecasting on historical data in Google Sheets.
Start by creating a new application.
Loading in Google Sheet Data
First, we will create a query that loads in historical time series data stored in the Google Sheets at this link: https://docs.google.com/spreadsheets/d/1n_LqGYTt5M4AZY4vYxCdRrOSmEhp_Zj5SQRuEE_GbR0.
data:image/s3,"s3://crabby-images/59046/590464fabc2143febf880bc9bb38ff4723599539" alt="1.png 2326"
First, click Add Data Query and select Google Sheets Api.
data:image/s3,"s3://crabby-images/a238b/a238bd6a7cf9536195f7e61d77147fc0d5eb9101" alt="2.png 3332"
Use the following spreadsheet id: 1n_LqGYTt5M4AZY4vYxCdRrOSmEhp_Zj5SQRuEE_GbR0
,
and change the range to be Sheet1!A1:E2193
.
data:image/s3,"s3://crabby-images/69da7/69da79bdf3c39d8028a15c8f1ce4d8b27e1ae952" alt="3.png 2556"
Set Automatic Execution to On Document Load
. Congratulations! You've connected your Google Sheets data so that it is automatically loaded into your app.
DataSiv provides integrations and read/write capabilities across multiple sources
Although we use Google Sheets in this tutorial, you can swap these out with other supported integrations, such as a Rest Api Endpoint, GraphQL, Salesforce, Stripe, etc.
Now that our data query is connected, we would like to display the results in a table.
Drag a table component to the grid from the left sidebar. On the properties of the table (right sidebar), click Edit data.
data:image/s3,"s3://crabby-images/f0ba7/f0ba7203e524adcda9bf1a1e651df38cbc050240" alt="Messages Image(81354510).png 3252"
For the datasource, choose queries.googleSheetsApi0.data.values. This will ensure that the data.values
property of the googleSheetsApi0
query is displayed in a table.
data:image/s3,"s3://crabby-images/b51e2/b51e2e094fff71df07e61a6c1f0f4768c6bc9a48" alt="5.png 1992"
Although this data is good as-is for display into a table, we need to run forecasting on it as well. For us to forecast results from our data, we need to process it in the right format for our Analytics component.
We will do that using our transforms! To begin, click Add Transform on the top menu.
What are transforms good for?
Transforms, such as the one we're about to create, allow you an easy way to mix and merge data sources together, filter them, or write code to get it into the right format before inserting it into a database. You can write raw javascript, client-side SQL, or other transforms to get started quickly.
Select the Transform type.
data:image/s3,"s3://crabby-images/e2b75/e2b75afa579412c4979ff57ad5bcb5bbfe45f27a" alt="7.png 2588"
Click Edit data and select queries.googleSheetsApi0.data.values
as your data source.
data:image/s3,"s3://crabby-images/31b12/31b12fb8e2a54b759b3fe658966a6322e48ef9a5" alt="8.png 2908"
We need to transform the data so it has the proper format for the time series component. Our time series component expects an array of arrays as the input. So for the transform, paste the following code:
element => {
return [
element.Series,
element.Date,
Number.parseFloat(element.Consumption),
Number.parseFloat(element.Wind),
Number.parseFloat(element.Solar)
]
}
data:image/s3,"s3://crabby-images/e3f4d/e3f4dbd1eebdc3fb10e8b6c1a77a600f6279bd47" alt="9.png 2140"
This transform, which runs on every row in the input, will convert each row into an array. Save the transform component.
Adding Analytics #
Now that we've loaded, displayed and transformed the data, we will perform analytics on it!
Add an analytics component of type time series.
data:image/s3,"s3://crabby-images/f2392/f2392571eb573619b410e542f833eba5c819713b" alt="10.png 1988"
For the Analytics Type, choose Datasiv Forecasting
, our proprietary forecasting component.
data:image/s3,"s3://crabby-images/9393f/9393f799ed18df07a43a8c9838dc85befa6ec16c" alt="11.png 1988"
What is Datasiv Forecasting good for?
Our forecasting component currently performs well in settings that range from single time series to heterogenous, multiple, intertwined time series that have seasonality.
The Forecasting analytics component forecasts data on the input property.
Click Edit input, and select data.transform0.result
, the output of the transform component you previously created.
data:image/s3,"s3://crabby-images/0562b/0562b424d10632ab5b9e14dacfff45d8f404b40e" alt="12.png 1984"
Set the remaining parameters for analytics specifics as defined below.
Series Name should be Series
, Response should be Consumption
, Timestamp should be Date
, Date Format should be true
, Max Shift should be 7
, Predict Steps should be 49
, and lastly the N Estimators should be 200
.
data:image/s3,"s3://crabby-images/45186/45186ba80bd0161974e835df5e32422b61f3943c" alt="13.png 2552"
We also need to describe which entries in the input correspond to which properties (Response, Series Name, Timestamp).
To do so, click Show Advanced options, and click edit headers. Paste the following json array:
[ "Series", "Date", "Consumption", "Wind", "Solar" ]
. This will define what each column in the input represents.
data:image/s3,"s3://crabby-images/fafc3/fafc37bccf1028b41fdd8fca231dd5a23b452592" alt="16.png 1974"
Congratulations! You've created your analytics component.
We'll add a button that allows us to call our analytics component.
Now, go back to the main menu, and add a Button. Change the text to Forecast Future Consumption and the code to DataSiv.ExecuteAnalytics("analytics.datasivForecasting0", {})
. This will run the forecast component on button click.
Triggering Analytics Queries
Like data queries, the button's code property allows you to specify and trigger data queries with the special
DataSiv.ExecuteQuery(...)
function.
Click the button to run the analytics component.
data:image/s3,"s3://crabby-images/84b2a/84b2a0a62b8e384ff7b609ae476ecfc642e63d41" alt="Messages Image(2994124560).png 3252"
Displaying the results of the analytics component
Finally, we want to display the results in a line chart, side by side with historical data. To do so, click Add Frontend Widget and select Multi Line Chart V2.
In the properties menu on the right, click Edit Data and choose analytics.datasivForecasting0.data.modelPredictions
as your data source. This will connect the outputs of the analytics component to the input of the chart component.
data:image/s3,"s3://crabby-images/98ab0/98ab0d085ceef7e7ad43ac7a7144b55d44d3fa79" alt="17.png 1994"
We need to specify which fields in the data array correspond to the x and y axes. To do so, click Edit xAxis and enter the following values.
The Data Key should be time
, Name should be Time
, and all of the other properties should be unchanged.
data:image/s3,"s3://crabby-images/800f9/800f98d375c9e80f097055d6d8132af59fe5a506" alt="18.png 1582"
Next, click Edit yAxis and enter the following values.
The Data Keys should be actual
and prediction
. The Name should be Value
, and everything else should be unchanged.
data:image/s3,"s3://crabby-images/22422/22422969118f9466554178c2a1c63b58b7672960" alt="19.png 1578"
Congratulations! You have built an end-to-end system that loads in data, transforms it, and runs time series forecasting on it.
When you click Forecast Consumption, you should get a plot like the one below.
data:image/s3,"s3://crabby-images/cfe90/cfe90e252cf6adf43fe623ed96a02c712cf84c22" alt="Messages Image(3946937436).png 3256"
Updated almost 2 years ago