forked from pauldcarroll/Forecasting
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbaselines.py
31 lines (17 loc) · 886 Bytes
/
baselines.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# Baseline section.
### 3 ways to measure baselines with Time Series Forecasting,.
import numpy as np
import pandas as pd
# 1. Take the mean for the whole dataset, and use this as the next forecast. This is a version of a baseline.
import statistics
statistics.mean(df.x)
# 2. Take a slice of the dataset and calculate this mean. This can be most useful where you have either trend and / or seasonality.
# e.g. the most recent 6 datapoints will have most relevance to a rising trend dataset of 100 long, than the first 6.
# Where x is the length of the mean to calculate, sliding window mean function.
def most_recent_mean(df.z, x):
a = len(df.z)
b = a-x
y = sum(df.z.iloc[b:a])
return y/x
# 3. Run a basic linear regression model on your dataset. Note this may be your best performing model for a small dataset.
# view the Linear Regression .py file