import matplotlib.pyplot as plt
import numpy as np
from statsmodels.tsa.stattools import adfuller
2: Augmented Dickey-Fuller Test#
def generate_ar_process(lags, coefs, length):
#cast coefs to np array
coefs = np.array(coefs)
#initial values
series = [np.random.normal() for _ in range(lags)]
for _ in range(length):
#get previous values of the series, reversed
prev_vals = series[-lags:][::-1]
#get new value of time series
new_val = np.sum(np.array(prev_vals) * coefs) + np.random.normal()
series.append(new_val)
return np.array(series)
def perform_adf_test(series):
result = adfuller(series)
print('ADF Statistic: %f' % result[0])
print('p-value: %f' % result[1])
AR(1) Process#
Stationary#
ar_1_process = generate_ar_process(1, [.5], 100)
plt.figure(figsize=(10,4))
plt.plot(ar_1_process)
plt.title('Stationary AR(1) Process', fontsize=18)
Text(0.5, 1.0, 'Stationary AR(1) Process')
data:image/s3,"s3://crabby-images/22f12/22f12558908ee019d13d4cdfc843f7c61e3445d7" alt="../../../_images/d68d7c7ba4bdd7d0fbaf0b5d65740ab9723faadfb75080a008826c44039172b4.png"
perform_adf_test(ar_1_process)
ADF Statistic: -5.700818
p-value: 0.000001
Non-Stationary#
ar_1_process_unit_root = generate_ar_process(1, [1], 100)
plt.figure(figsize=(10,4))
plt.plot(ar_1_process_unit_root)
plt.title('Non-Stationary AR(1) Process', fontsize=18)
Text(0.5, 1.0, 'Non-Stationary AR(1) Process')
data:image/s3,"s3://crabby-images/ceec6/ceec6786d7d7e249894b3019122ce3f3f53cf1f9" alt="../../../_images/d1a96382b5b114680812105b76081a40ea4c461fdffdc8a83a04a94ba8207be8.png"
perform_adf_test(ar_1_process_unit_root)
ADF Statistic: -1.768932
p-value: 0.395991
AR(2) Process#
Stationary#
ar_2_process = generate_ar_process(2, [.5, .3], 100)
plt.figure(figsize=(10,4))
plt.plot(ar_2_process)
plt.title('Stationary AR(2) Process', fontsize=18)
Text(0.5, 1.0, 'Stationary AR(2) Process')
data:image/s3,"s3://crabby-images/f809b/f809be5d7042dd27207031ec2b65680ab09910cb" alt="../../../_images/855db13baba27d362d9faf9db33b94de4bad81bf213102b826203a7355e0e86f.png"
perform_adf_test(ar_2_process)
ADF Statistic: -3.015991
p-value: 0.033428
Non-Stationary#
ar_2_process_unit_root = generate_ar_process(2, [.7, .3], 100)
plt.figure(figsize=(10,4))
plt.plot(ar_2_process_unit_root)
plt.title('Non-Stationary AR(2) Process', fontsize=18)
Text(0.5, 1.0, 'Non-Stationary AR(2) Process')
data:image/s3,"s3://crabby-images/b85c4/b85c43bc7a1ad2aa0ffee35f6844aba5aea7c633" alt="../../../_images/164fec2598e319dbd3071aed6fb2fb5a2084f09272b98e52008a5cbf75dce3a3.png"
perform_adf_test(ar_2_process_unit_root)
ADF Statistic: -2.427619
p-value: 0.134092