A flask web app that leverages Facebook Prophet to provide people with the ability to build simple baseline forecasts from within a guided user interface.
What is forecastr?
Demo
How does this app work?
Data Collection on the User Experience
Requirements
References
forecastr is an experimental flask app I created as a proof of concept to see what it would take to create a UI on top of Facebook Prophet. It provides the user with a 3 step interface that guides them towards building a baseline forecast with Facebook Prophet.
Here is a screenshot of the app after the user has built a forecast:
This app generates a forecast in 3 steps:
- Upload your csv
- Configure your initial forecast (choose forecast length and model type - linear or logistic)
- View Forecast and Tweak settings
This app doesn't store any data about the contents of the uploaded csv within a database. This is a session based product.
Once the csv has been uploaded to the app, the data is then stored within temporary variables in the client and data is then sent back and forth between to client and server until the forecast is generated.
At a high level, data flows like this:
{{INSERT Data flow PIC}}
As an example, Let’s say a user is at Step 1. They’ve decided to try the app and click on the CTA “Browse File” and choose a CSV to upload. The app then parses this data and sends it server side to a python script that calculates some basic statistics about the data before sending it back and then forward to visualize on the second tab (ie. Step 2: Review Data + Setup Model).
Again, this app does not store any data about the contents of the uploaded csv. I also used the logging python library to suppress any logs echoed during transit between the client and the server.
There is data collected on how people use the app. This data is collected using Google Analytics via a Google Tag Manager implementation.
At a high level, I use Google Analytics to understand:
- Whether a user successfully creates a forecast during their session
- Whether a user successfully uploads a csv
- How a user interacts with different web elements (ie. buttons, links)
- Whether a user has downloaded a sample csv.
You can view the forecastr_v4.js and behavioural_analytics.js files to see what data is being passed to Google Analytics via the dataLayer.push().
Example: This event is triggered when the pre-forecast chart is successfully rendered on Step 2 of the flow. window.dataLayer.push({'event': 'step2-pre-forecast-chart-rendered'});
I then use Google Tag Manager to create rules that listen for any ux events and then send that data to Google Analytics.
This app uses the following python libraries, which you will need to install:
- fbprophet
- pandas
- datetime
- flask
- flask_socketio
- requests
- numpy
- logging (to suppress)
On the client side:
- jquery
- bootstrap
Here are some links that I found very useful:
- Flask: http://flask.pocoo.org/
- SocketIO: https://flask-socketio.readthedocs.io/en/latest/
- Stackoverflow: https://www.stackeroverflow.com
- How to export data as a csv in javascript: https://halistechnology.com/2015/05/28/use-javascript-to-export-your-data-as-csv/