久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx

使用Python怎么對時間序列進行分解和預測-創新互聯

使用Python怎么對時間序列進行分解和預測?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

創新互聯專注于海東網站建設服務及定制,我們擁有豐富的企業做網站經驗。 熱誠為您提供海東營銷型網站建設,海東網站制作、海東網頁設計、海東網站官網定制、小程序定制開發服務,打造海東網絡公司原創品牌,更為您提供海東網站排名全網營銷落地服務。

什么是時間序列?


顧名思義,時間序列是按照固定時間間隔記錄的數據集。換句話說,以時間為索引的一組數據是一個時間序列。請注意,此處的固定時間間隔(例如每小時,每天,每周,每月,每季度)是至關重要的,意味著時間單位不應改變。別把它與序列中的缺失值混為一談。我們有相應的方法來填充時間序列中的缺失值。

在開始使用時間序列數據預測未來值之前,思考一下我們需要提前多久給出預測是尤其重要的。你是否應該提前一天,一周,六個月或十年來預測(我們用“界限”來表述這個技術術語)?需要進行預測的頻率是什么?在開始預測未來值的詳細工作之前,與將要使用你的預測結果的人談一談也不失為一個好主意。

如何在Python中繪制時間序列數據?

可視化時間序列數據是數據科學家了解數據模式,時變性,異常值,離群值以及查看不同變量之間的關系所要做的第一件事。從繪圖查看中獲得的分析和見解不僅將有助于建立更好的預測,而且還將引導我們找到最合適的建模方法。這里我們將首先繪制折線圖。折線圖也許是時間序列數據可視化最通用的工具。

這里我們用到的是AirPassengers數據集。該數據集是從1949年到1960年之間的每月航空旅客人數的集合。下面是一個示例數據,以便你對數據信息有個大概了解。

#Reading Time Series Data
Airpassenger = pd.read_csv("AirPassengers.csv")
Airpassenger.head(3)

現在,我們使用折線圖繪制數據。在下面的示例中,我們使用set_index()將date列轉換為索引。這樣就會自動在x軸上顯示時間。接下來,我們使用rcParams設置圖形大小,最后使用plot()函數繪制圖表。

Airpassenger = Airpassenger.set_index('date')
pyplot.rcParams["figure.figsize"] = (12,6)
Airpassenger.plot()
pyplot.show()

使用Python怎么對時間序列進行分解和預測

1949-1960年間,乘飛機旅行的乘客人數穩定增長。規律性間隔的峰值表明增長似乎在有規律的時間間隔內重復。

讓我們看看每個季度的趨勢是怎樣的。為了便于理解,從不同的維度觀察信息是個好主意。為此,我們需要使用Python中的datetime包從date變量中得出季度和年份。在進行繪圖之前,我們將連接年份和季度信息,以了解旅客數量在季節維度上如何變化。

from datetime import datetime
# Airpassenger["date"] = Airpassenger["date"].apply(lambda x: datetime.strptime(x, "%d-%m-%Y"))
Airpassenger["year"] = Airpassenger["date"].apply(lambda x: x.year)
Airpassenger["qtr"] = Airpassenger["date"].apply(lambda x: x.quarter)
Airpassenger["yearQtr"]=Airpassenger['year'].astype(str)+'_'+Airpassenger['qtr'].astype(str)
airPassengerByQtr=Airpassenger[["passengerCount", "yearQtr"]].groupby(["yearQtr"]).sum()

準備好繪制數據后,我們繪制折線圖,并確保將所有時間標簽都放到x軸。x軸的標簽數量非常多,因此我們決定將標簽旋轉呈現。

pyplot.rcParams["figure.figsize"] = (14,6)
pyplot.plot(airPassengerByQtr)
pyplot.xticks(airPassengerByQtr.index, rotation='vertical')

使用Python怎么對時間序列進行分解和預測

這幅圖非常有趣,它清晰地表明,在1949-1960年之間的所有年份中,航空旅客人數每季度都在顯著增加。

時間序列的要素是什么?

時間序列數據包含4個主要元素:
1.趨勢性–趨勢性表示數據隨時間增加或減少的一般趨勢。這很容易理解。例如,1949年至1960年之間航空旅客數量呈增加趨勢,或者可以說呈上升趨勢。
2.季節性–如同一年四季,數據模式出現在有規律的間隔之后,代表了時間序列的季節性組成部分。它們在特定的時間間隔(例如日,周,月,年等)之后重復。有時我們很容易弄清楚季節性,有時則未必。通常,我們可以繪制圖表并直觀檢驗季節性元素的存在。但是有時,我們可能不得不依靠統計方法來檢驗季節性。
3.周期性–可被視為類似季節性,但的區別是周期性不會定期出現。這個屬性使得它很難被辨識。例如,地震可以在我們知道將要發生的任何時間發生,但是我們其實不知道何時何地發生。
4.隨機噪聲–不屬于上述三類情況的時間序列數據中的突然變化,而且也很難被解釋,因此被稱為隨機波動或隨機噪聲。

如何分解時間序列?

有兩種技術可以獲取時間序列要素。在進行深入研究和查看相關Python抽取函數之前,必須了解以下兩點:

  • 時間序列不必具有所有要素。

  • 弄清該時間序列是可加的還是可乘的。


那么什么是可加和可乘時間序列模型呢?

可加性模型–在可加性模型中,要素之間是累加的關系。y(t)=季節+趨勢+周期+噪音

可乘性模型–在可乘性模型中,要素之間是相乘的關系。y(t)=季節趨勢周期*噪音

你想知道為什么我們還要分解時間序列嗎?你看,分解背后的目的之一是估計季節性影響并提供經過季節性調整的值。去除季節性的值就可以輕松查看趨勢。例如,在美國,由于農業領域需求的增加,夏季的失業率有所下降。從經濟學角度來講,這也意味著6月份的失業率與5月份相比有所下降。現在,如果你已經知道了邏輯,這并不代表真實的情況,我們必須調整這一事實,即6月份的失業率始終低于5月份。

這里的挑戰在于,在現實世界中,時間序列可能是可加性和可乘性的組合。這意味著我們可能并不總是能夠將時間序列完全分解為可加的或可乘的。

現在你已經了解了不同的模型,下面讓我們研究一些提取時間序列要素的常用方法。

經典分解法

該方法起源于1920年,是諸多方法的鼻祖。經典分解法有兩種形式:加法和乘法。Python中的statsmodels庫中的函數season_decompose()提供了經典分解法的實現。在經典分解法中,需要你指出時間序列是可加的還是可乘的。你可以在此處(https://otexts.com/fpp2/classical-decomposition.html)了解有關加法和乘法分解的更多信息。

在下面的代碼中,要獲得時間序列的分解,只需賦值model=additive。

import numpy as np
from pandas import read_csv
import matplotlib.pyplot as plt
from statsmodels.tsa.seasonal import seasonal_decompose
from pylab import rcParams
 
elecequip = read_csv(r"C:/Users/datas/python/data/elecequip.csv")
result = seasonal_decompose(np.array(elecequip), model='multiplicative', freq=4)
 
rcParams['figure.figsize'] = 10, 5
result.plot()
pyplot.figure(figsize=(40,10))
pyplot.show()

使用Python怎么對時間序列進行分解和預測

上圖的第一行代表實際數據,底部的三行顯示了三個要素。這三個要素累加之后即可以獲得原始數據。第二個樣本集代表趨勢性,第三個樣本集代表季節性。如果我們考慮完整的時間范圍,你會看到趨勢一直在變化,并且在波動。對于季節性,很明顯,在規律的時間間隔之后可以看到峰值。

如何獲得季節性調整值?

對于可加性模型,可以通過y(t)– s(t)獲得季節性調整后的值,對于乘法數據,可以使用y(t)/ s(t)來調整值。

如果你正想問為什么我們需要季節性調整后的數據,讓我們回顧一下剛才討論過的有關美國失業率的示例。因此,如果季節性本身不是我們的主要關注點,那么季節性調整后的數據將更有用。盡管經典方法很常見,但由于以下原因,不太建議使用它們:

  • 該技術對異常值不可靠。

  • 它傾向于使時間序列數據中的突然上升和下降過度平滑。

  • 假設季節性因素每年只重復一次。

  • 對于前幾次和最后幾次觀察,該方法都不會產生趨勢周期估計。


其他可用于分解的更好方法是X11分解,SEAT分解或STL分解。現在,我們將看到如何在Python中生成它們。

與經典法,X11和SEAT分解法相比,STL具有許多優點。接下來,讓我們探討STL分解法。

STL分解法

STL代表使用局部加權回歸(Loess)進行季節性和趨勢性分解。該方法對異常值具有魯棒性,可以處理任何類型的季節性。這個特性還使其成為一種通用的分解方法。使用STL時,你控制的幾件事是:

  • 趨勢周期平滑度

  • 季節性變化率

  • 可以控制對用戶異常值或異常值的魯棒性。這樣你就可以控制離群值對季節性和趨勢性的影響。

同任何其他方法一樣,STL也有其缺點。例如,它不能自動處理日歷的變動。而且,它僅提供對可加性模型的分解。但是你可以得到乘法分解。你可以首先獲取數據日志,然后通過反向傳播要素來獲取結果。但是,這超出了本文討論的范圍。

Import pandas as pd
Import seaborn as sns
Import matplotlib.pyplot as plt
From statsmodels.tsa.seasonal import STL

elecequip =read_csv(r"C:/Users/datas/python/data/elecequip.csv")
stl = STL(elecequip, period=12, robust=True)
res_robust = stl.fit()
fig = res_robust.plot()

使用Python怎么對時間序列進行分解和預測

時間序列預測的基本方法

盡管有許多統計技術可用于預測時間序列數據,我們這里僅介紹可用于有效的時間序列預測的最直接、最簡單的方法。這些方法還將用作其他方法的基礎。

PYTHON中的簡單移動平均(SMA)

簡單移動平均是可以用來預測的所有技術中最簡單的一種。通過取最后N個值的平均值來計算移動平均值。我們獲得的平均值被視為下一個時期的預測。

為什么使用簡單移動平均?

移動平均有助于我們快速識別數據趨勢。你可以使用移動平均值確定數據是遵循上升趨勢還是下降趨勢。它可以消除波峰波谷等不規則現象。這種計算移動平均值的方法稱為尾隨移動平均值。在下面的示例中,我們使用rolling()函數來獲取電氣設備銷售數據的移動平均線。

Import pandas as pd
from matplotlib import pyplot
 
elecequip = pd.read_csv(r"C:/Users/datas/python/data/elecequip.csv")
 
# Taking moving average of last 6 obs
rolling = elecequip.rolling(window=6)
rolling_mean = rolling.mean()
 
# plot the two series
pyplot.plot(elecequip)
pyplot.plot(rolling_mean, color='red')
pyplot.show()

使用Python怎么對時間序列進行分解和預測

另一種方法是“中心移動平均”。在這里將任意給定時間(t)的值計算為當前,之前和之后的平均值。啟用center = True將提供中心移動平均值。

elecequip["x"].rolling(window=3, center=True).mean()

PYTHON中的加權移動平均(WMA)

簡單移動平均非常樸素,因為它對過去的所有值給予同等的權重。但是當假設新數據與實際值密切相關,則對新值賦予更多權重可能更有意義。

要計算WMA,我們要做的就是將過去的每個觀察值乘以一定的權重。例如,在6周的滾動窗口中,我們可以將6個權重賦給最近值,將1個權重賦給最后一個值。

import random
rand = [random.randint(1, i) for i in range(100,110)]
data = {}
data["Sales"] = rand

df = pd.DataFrame(data)
weights = np.array([0.5, 0.25, 0.10])

sum_weights = np.sum(weights)
df['WMA']=(df['Sales']
.rolling(window=3, center=True)
.apply(lambda x: np.sum(weights*x)/sum_weights, raw=False)

)
print(df['WMA'])

PYTHON中的指數移動平均(EMA)

在“指數移動平均”中,隨著觀察值的增加,權重將按指數遞減。該方法通常是一種出色的平滑技術,可以從數據中消除很多噪聲,從而獲得更好的預測。

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from statsmodels.tsa.api import ExponentialSmoothing
 
EMA_fit = ExponentialSmoothing(elecequip, seasonal_periods=12, trend='add', seasonal='add').fit(use_boxcox=True)
fcast3 = EMA_fit.forecast(12)
 
 
ax = elecequip.plot(figsize=(10,6), marker='o', color='black', title="Forecasts from Exponential Smoothing" )
ax.set_ylabel("Electrical Equipment")
ax.set_xlabel("Index")
 
# For plotting fitted values
# EMA_fit.fittedvalues.plot(ax=ax, style='--', color='red')

EMA_fit.forecast(12).rename('EMS Forecast').plot(ax=ax, style='--',
 marker='o', color='blue', legend=True)

該方法具有以下兩種變體:
1.簡單指數平滑–如果時間序列數據是具有恒定方差且沒有季節性的可加性模型,則可以使用簡單指數平滑來進行短期預測。
2.Holt指數平滑法–如果時間序列是趨勢增加或減少且沒有季節性的可加性模型,則可以使用Holt指數平滑法進行短期預測。

以下是從python中的statsmodels包導入兩個模型的代碼。現在,你可以在練習中運行上述模型。

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from statsmodels.tsa.api import SimpleExpSmoothing, Holt

關于使用Python怎么對時間序列進行分解和預測問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創新互聯行業資訊頻道了解更多相關知識。

當前標題:使用Python怎么對時間序列進行分解和預測-創新互聯
文章位置:http://www.js-pz168.com/article20/dscoco.html

成都網站建設公司_創新互聯,為您提供動態網站手機網站建設用戶體驗網站內鏈電子商務定制網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

營銷型網站建設
久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx
亚洲欧洲一区二区福利| 国产亚洲精品久| 日本一区二区三区在线不卡| 亚洲欧美日韩综合aⅴ视频| 视频一区视频二区中文| 国产成人精品在线看| 国内精品国语自产拍在线观看| 亚洲欧美在线网| 日韩免费在线观看| 亚洲男人都懂的| 激情文学综合插| 国产免费高清一区| 欧美在线小视频| 亚洲国产精品成人综合色在线婷婷| 亚洲大型综合色站| 成人av电影在线网| 欧洲一区二区日韩在线视频观看免费| 欧美日韩在线播放三区| 国产精品视频九色porn| 欧美aaaaa成人免费观看视频| 97精品国产97久久久久久久久久久久| 日韩欧美亚洲区| 精品日韩成人av| 亚洲bdsm女犯bdsm网站| www.亚洲在线| 一区精品视频| 国产三级精品三级| 久久国产夜色精品鲁鲁99| 国产乱子伦精品| 欧美男女性生活在线直播观看| 国产精品久久久久久久第一福利 | 日韩不卡在线观看日韩不卡视频| zzijzzij亚洲日本少妇熟睡| 一区二区精品在线| 久久九九99视频| 久久99国产精品麻豆| 久久婷婷开心| 精品久久五月天| 天天av天天翘天天综合网| 97超碰人人模人人爽人人看| 欧美性三三影院| 亚洲精品国久久99热| 99视频精品全部免费在线| 日本乱人伦aⅴ精品| 中文字幕五月欧美| 粉嫩高潮美女一区二区三区 | 国产精品国产一区二区| 欧美日韩国产欧美日美国产精品| 亚洲乱码日产精品bd| 99热精品国产| 精品视频一区二区三区免费| 亚洲靠逼com| 91丝袜美腿高跟国产极品老师| 色8久久精品久久久久久蜜| 中文字幕综合网| 成人av电影在线| 欧美在线观看禁18| 悠悠色在线精品| 99porn视频在线| 777奇米四色成人影色区| 亚洲成人av在线电影| 黄色小网站91| 久久久久久一二三区| 国产伦精品一区二区三区免费迷| 亚洲制服欧美久久| 亚洲丝袜制服诱惑| 97在线资源站| 日韩一区二区电影| 另类欧美日韩国产在线| 日韩电影免费观看在| 中文字幕不卡一区| 不卡一区在线观看| 制服丝袜亚洲播放| 免费在线看成人av| 亚洲成人蜜桃| 亚洲综合区在线| 久久国产精品精品国产色婷婷| 久久日韩粉嫩一区二区三区 | 婷婷综合久久一区二区三区| 久久久99国产精品免费| 国产日产欧美一区| 99久久久国产精品免费蜜臀| 欧美一区二区三区系列电影| 久久不见久久见免费视频7| 中文字幕一区综合| 夜夜精品视频一区二区| 久久精品国产综合精品| 亚洲国产经典视频| 91av免费看| 久久久久国产成人精品亚洲午夜| 不卡一区二区三区四区| 日韩视频中午一区| 福利一区在线观看| 日韩视频一区二区三区在线播放 | 欧美伊人久久久久久午夜久久久久| 亚洲国产综合人成综合网站| 欧美极品视频一区二区三区| 中文字幕欧美一| 国产在线精品一区二区中文 | 日韩精品专区在线影院观看| 国产一区二区电影| 欧美日韩精品系列| 精品无人码麻豆乱码1区2区| 欧美自拍丝袜亚洲| 久久精品国产澳门| 欧美性xxxxxx少妇| 久久精品久久综合| 欧美人伦禁忌dvd放荡欲情| 卡一卡二国产精品 | 丝袜美腿亚洲一区二区图片| 亚洲高清在线播放| 午夜日韩在线电影| 一本色道久久综合亚洲91 | 国产精品18久久久久| 欧美巨大另类极品videosbest| 久国产精品韩国三级视频| 欧美日韩一区三区| 国产剧情一区二区三区| 7777精品伊人久久久大香线蕉经典版下载 | 成人免费看黄yyy456| 欧美成人精品福利| 91亚洲资源网| 国产精品网站在线播放| 国产亚洲第一区| 1000部国产精品成人观看| 玖玖玖精品中文字幕| 一区二区三区影院| 亚洲午夜高清视频| 青青草91视频| 欧美精品xxxxbbbb| 成人黄色小视频| 国产欧美日韩亚州综合| 精品一区二区三区视频日产| 亚洲精品乱码久久久久久 | 97超碰人人看人人| 1区2区3区精品视频| 色99中文字幕| 秋霞影院一区二区| 51午夜精品国产| 91在线高清观看| 日韩美女精品在线| 亚洲高清在线播放| 激情综合五月婷婷| 精品欧美一区二区在线观看| 岛国一区二区三区高清视频| 亚洲四区在线观看| 一区二区在线高清视频| 国产主播一区二区| 久久先锋影音av鲁色资源| 国产久一道中文一区| 亚洲国产视频在线| 欧美日韩一级黄| 91在线视频免费观看| 综合久久久久综合| 在线国产精品网| 风间由美一区二区av101 | 欧美区一区二区三区| 9人人澡人人爽人人精品| 日韩美女视频一区| 色成年激情久久综合| 成人午夜电影网站| 成人免费一区二区三区视频| 中文字幕欧美日韩一区二区三区| 国产精品白丝jk白祙喷水网站| 久久综合丝袜日本网| 欧美精品一区二区三区久久| 免费人成精品欧美精品| 精品久久久久99| 麻豆久久久av免费| 美女久久久精品| 久久日韩精品一区二区五区| 日本一区免费看| 国产精品一区二区在线播放 | 亚洲国产日韩综合久久精品| 欧美老人xxxx18| 国产成人一区二区三区免费看| 亚洲大片免费看| 欧美一区二区大片| 久久国产精品亚洲va麻豆| 美女视频网站黄色亚洲| 久久久美女艺术照精彩视频福利播放| 欧美一级爽aaaaa大片| 国产一区在线不卡| 国产精品成人免费| 欧美视频在线观看一区| 国产精品麻豆免费版| 日本午夜一区二区| 久久精品亚洲精品国产欧美| 亚洲一区二区高清视频| 成人av电影在线| 婷婷综合五月天| 久久精品日产第一区二区三区高清版 | 99精品国产99久久久久久白柏| 亚洲综合激情网| 日韩欧美一区电影| 日韩欧美一区二区三区久久婷婷| 国产激情一区二区三区四区| 亚洲男人的天堂在线观看| 91精品国产麻豆| 日韩精品国内|