Professional Documents
Culture Documents
INSTALLATION:4
DOWNLOAD PYCHARM4
Most often, the components of time series data will include a trend,
seasonality, noise or randomness, a curve, and the level. Before we go on to
defining these terms. most business data will likely contain seasonality
such as retail sales peaking in the fourth quarter.
‘Time’ is the most important factor which ensures success in a business. It’s
difficult to keep up with the pace of time. But, technology has developed
some powerful methods using which we can ‘see things’ ahead of time.
INSTALLATION:
In order to install PyCharm on Ubuntu, we will need to get some
prerequisites out of the way first. For this exercise, make sure that your
service is fully updated.
# apt update && apt upgrade -y
DOWNLOAD PYCHARM
# mv pycharm2018-3.1/usr/local/pycharm
Next, we will run shell file of PyCharm.
ubuntu@ubuntu:~/Downloads/pycharm-community-2018.3.1/bin$ ./pycharm.sh
import numpy as np
import datetime
#%matplotlib inline
sns.set()
rcParams['figure.figsize'] = 15, 6
print (data.head())
print (data.dtypes)
print (data.index)
ts = data[['code']].head(30)
#------------print(ts['1991'])
plt.plot(ts)
plt.show()
def test_stationarity(timeseries):
rolstd = pd.DataFrame.rolling(timeseries,window=6,center=False).std()
plt.legend(loc='best')
plt.show(block=True)
print(dfoutput)
#test_stationarity(ts)
ts_log = np.log(ts)
plt.plot(ts_log)
expwighted_avg =
pd.DataFrame.ewm(ts_log,halflife=6,min_periods=0,adjust=True,ignore_na=False)
.mean()
plt.plot(ts_log)
plt.plot(expwighted_avg, color='red')
plt.show()
test_stationarity(ts_log_ewma_diff)
print("------------------------------------------------------")
plt.plot(ts_log_diff)
ts_log_diff.dropna(inplace=True)
test_stationarity(ts_log_diff)
decomposition = seasonal_decompose(ts_log,freq=10)
trend = decomposition.trend
seasonal = decomposition.seasonal
residual = decomposition.resid
plt.subplot(411)
plt.plot(ts_log, label='Original')
plt.legend(loc='best')
plt.subplot(412)
plt.plot(trend, label='Trend')
plt.legend(loc='best')
plt.subplot(413)
plt.plot(seasonal,label='Seasonality')
plt.legend(loc='best')
plt.subplot(414)
plt.plot(residual, label='Residuals')
plt.legend(loc='best')
plt.tight_layout()
ts_log_decompose = residual
ts_log_decompose.dropna(inplace=True)
test_stationarity(ts_log_decompose)
plt.subplot(121)
plt.plot(lag_acf)
plt.axhline(y=0,linestyle='--',color='gray')
plt.axhline(y=-1.96/np.sqrt(len(ts_log_diff)),linestyle='--',color='gray')
plt.axhline(y=1.96/np.sqrt(len(ts_log_diff)),linestyle='--',color='gray')
plt.title('Autocorrelation Function')
plt.subplot(122)
plt.plot(lag_pacf)
plt.axhline(y=0,linestyle='--',color='gray')
plt.axhline(y=-1.96/np.sqrt(len(ts_log_diff)),linestyle='--',color='gray')
plt.axhline(y=1.96/np.sqrt(len(ts_log_diff)),linestyle='--',color='gray')
plt.tight_layout()
plt.show()
import time
print("----------AR MODEL-------------")
results_AR = model.fit(disp=-1)
plt.plot(ts_log_diff)
plt.plot(results_AR.fittedvalues, color='red')
plt.show()
print("--------------MA MODEL------------")
results_MA = model.fit(disp=-1)
plt.plot(ts_log_diff)
plt.plot(results_MA.fittedvalues, color='red')
plt.show()
print("-----------Combined Model----------------")
results_ARIMA = model.fit(disp=-1)
plt.plot(ts_log_diff)
plt.plot(results_ARIMA.fittedvalues, color='red')
plt.show()
print(predictions_ARIMA_diff.head())
predictions_ARIMA_diff_cumsum = predictions_ARIMA_diff.cumsum()
print( predictions_ARIMA_diff_cumsum.head())
predictions_ARIMA_log =
predictions_ARIMA_log.add(predictions_ARIMA_diff_cumsum,fill_value=0)
print(predictions_ARIMA_log.head())
predictions_ARIMA = np.exp(predictions_ARIMA_log)
plt.plot(ts)
plt.plot(predictions_ARIMA)
plt.show()