欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python機(jī)器學(xué)習(xí)之預(yù)測黃金價格

 更新時間:2022年01月19日 11:06:03   作者:老貢講Python  
這篇文章主要介紹了如何使用機(jī)器學(xué)習(xí)方法來預(yù)測最重要的貴金屬之一黃金的價格,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以試一試

讀取黃金 ETF 數(shù)據(jù)

本文使用機(jī)器學(xué)習(xí)方法來預(yù)測最重要的貴金屬之一黃金的價格。我們將創(chuàng)建一個線性回歸模型,該模型從過去的黃金 ETF (GLD) 價格中獲取信息,并返回對第二天黃金 ETF 價格的預(yù)測。GLD是直接投資實物黃金的最大ETF。(掃描本文最下方二維碼獲取全部完整源碼和Jupyter Notebook 文件打包下載。)

首先要做的是:導(dǎo)入所有必要庫。

# LinearRegression 是一個用于線性回歸的機(jī)器學(xué)習(xí)庫  
from sklearn.linear_model import LinearRegression  
# pandas 和 numpy 用于數(shù)據(jù)操作  
import pandas as pd  
import numpy as np  
# matplotlib 和 seaborn 用于繪制圖形  
import matplotlib.pyplot as plt  
%matplotlib inline  
plt.style.use('seaborn-darkgrid')  
# yahoo Finance用于獲取數(shù)據(jù)  
import yfinance as yf 

然后,我們讀取過去 12 年的每日黃金 ETF 價格數(shù)據(jù)并將其存儲在 Df 中。我們刪除不相關(guān)的列并使用 dropna() 函數(shù)刪除 NaN 值。然后,我們繪制黃金 ETF 收盤價。

Df = yf.download('GLD', '2008-01-01', '2020-6-22', auto_adjust=True)  
DfDf = Df[['Close']]  
DfDf = Df.dropna()  
Df.Close.plot(figsize=(10, 7),color='r')  
plt.ylabel("Gold ETF Prices")  
plt.title("Gold ETF Price Series")  
plt.show() 

定義解釋變量

解釋變量是一個被操縱以確定第二天黃金 ETF 價格的變量。簡單地說,它們是我們想要用來預(yù)測黃金 ETF 價格的特征。

該策略中的解釋變量是過去 3 天和 9 天的移動平均線。我們使用 dropna() 函數(shù)刪除 NaN 值并將特征變量存儲在 X 中。

但是,您可以向 X 添加更多您認(rèn)為對預(yù)測黃金 ETF 價格有用的變量。這些變量可以是技術(shù)指標(biāo)、其他 ETF 的價格,例如黃金礦工 ETF (GDX) 或石油 ETF (USO),或美國經(jīng)濟(jì)數(shù)據(jù)。

定義因變量

同樣,因變量取決于解釋變量的值。簡而言之,這是我們試圖預(yù)測的黃金 ETF 價格。我們將黃金 ETF 價格存儲在 y 中。

Df['S_3'] = Df['Close'].rolling(window=3).mean()  
Df['S_9'] = Df['Close'].rolling(window=9).mean() 
Df['next_day_price'] = Df['Close'].shift(-1)  
DfDf = Df.dropna()  
X = Df[['S_3', 'S_9']]  
y = Df['next_day_price'] 

將數(shù)據(jù)拆分為訓(xùn)練和測試數(shù)據(jù)集

在這一步中,我們將預(yù)測變量和輸出數(shù)據(jù)拆分為訓(xùn)練數(shù)據(jù)和測試數(shù)據(jù)。通過將輸入與預(yù)期輸出配對,訓(xùn)練數(shù)據(jù)用于創(chuàng)建線性回歸模型。

測試數(shù)據(jù)用于估計模型的訓(xùn)練效果。

•前 80% 的數(shù)據(jù)用于訓(xùn)練,剩余的數(shù)據(jù)用于測試

•X_train & y_train 是訓(xùn)練數(shù)據(jù)集

•X_test & y_test 是測試數(shù)據(jù)集

t = .8  
t = int(t*len(Df))  
XX_train = X[:t]  
yy_train = y[:t]  
XX_test = X[t:]  
yy_test = y[t:] 

創(chuàng)建線性回歸模型

我們現(xiàn)在將創(chuàng)建一個線性回歸模型。但是,什么是線性回歸?

如果我們試圖捕捉“x”和“y”變量之間的數(shù)學(xué)關(guān)系,通過對散點圖擬合一條線,“最好”根據(jù)“x”的觀察值解釋“y”的觀察值,那么這樣的方程 x 和 y 之間的關(guān)系稱為線性回歸分析。

為了進(jìn)一步分解,回歸用自變量解釋了因變量的變化。因變量“y”是您要預(yù)測的變量。自變量“x”是您用來預(yù)測因變量的解釋變量。以下回歸方程描述了這種關(guān)系:

Y = m1 * X1 + m2 * X2 + C  
Gold ETF price = m1 * 3 days moving average + m2 * 15 days moving average + c  

然后我們使用擬合方法擬合自變量和因變量(x 和 y)以生成回歸系數(shù)和常數(shù)。

linear = LinearRegression().fit(X_train, y_train)  
print("Linear Regression model")  
print("Gold ETF Price (y) = %.2f * 3 Days Moving Average (x1) \  
+ %.2f * 9 Days Moving Average (x2) \  
+ %.2f (constant)" % (linear.coef_[0], linear.coef_[1], linear.intercept_)) 

輸出線性回歸模型:

黃金 ETF 價格 (y) = 1.20 * 3 天移動平均線 (x1) + -0.21 * 9 天移動平均線 (x2) + 0.43(常數(shù))

預(yù)測黃金ETF價格

現(xiàn)在,是時候檢查模型是否在測試數(shù)據(jù)集中工作了。我們使用使用訓(xùn)練數(shù)據(jù)集創(chuàng)建的線性模型來預(yù)測黃金 ETF 價格。預(yù)測方法找到給定解釋變量 X 的黃金 ETF 價格 (y)。

predicted_price = linear.predict(X_test)  
predicted_price = pd.DataFrame(  
    predicted_price, index=y_test.index, columns=['price'])  
predicted_price.plot(figsize=(10, 7))  
y_test.plot()  
plt.legend(['predicted_price', 'actual_price'])  
plt.ylabel("Gold ETF Price")  
plt.show() 

該圖顯示了黃金 ETF 的預(yù)測價格和實際價格。

現(xiàn)在,讓我們使用 score() 函數(shù)計算擬合優(yōu)度。

r2_score = linear.score(X[t:], y[t:])*100  
float("{0:.2f}".format(r2_score)) 

輸出:

99.21

可以看出,模型的 R 平方為 99.21%。R 平方始終介于 0 和 100% 之間。接近 100% 的分?jǐn)?shù)表明該模型很好地解釋了黃金 ETF 的價格。

繪制累積收益

讓我們計算一下這個策略的累積收益來分析它的表現(xiàn)。

累計收益計算步驟如下:

•  生成黃金價格的每日百分比變化

•  當(dāng)?shù)诙斓念A(yù)測價格高于當(dāng)天的預(yù)測價格時,創(chuàng)建一個以“1”表示的買入交易信號

•  通過將每日百分比變化乘以交易信號來計算策略回報。

•  最后,我們將繪制累積收益圖

gold = pd.DataFrame()  
gold['price'] = Df[t:]['Close']  
gold['predicted_price_next_day'] = predicted_price  
gold['actual_price_next_day'] = y_test  
gold['gold_returns'] = gold['price'].pct_change().shift(-1)  
gold['signal'] = np.where(gold.predicted_price_next_day.shift(1) < gold.predicted_price_next_day,1,0)  
gold['strategy_returns'] = gold.signal * gold['gold_returns']  
((gold['strategy_returns']+1).cumprod()).plot(figsize=(10,7),color='g')  
plt.ylabel('Cumulative Returns')  
plt.show() 

輸出如下:

我們還將計算夏普比:

sharpe = gold['strategy_returns'].mean()/gold['strategy_returns'].std()*(252**0.5)  
'Sharpe Ratio %.2f' % (sharpe) 

輸出如下:

'Sharpe Ratio 1.06'

預(yù)測每日價格

您可以使用以下代碼來預(yù)測黃金價格,并給出我們應(yīng)該購買 GLD 還是不持倉的交易信號:

import datetime as dt  
current_date = dt.datetime.now()  
data = yf.download('GLD', '2008-06-01', current_date, auto_adjust=True)  
data['S_3'] = data['Close'].rolling(window=3).mean()  
data['S_9'] = data['Close'].rolling(window=9).mean()  
datadata = data.dropna()  
data['predicted_gold_price'] = linear.predict(data[['S_3', 'S_9']])  
data['signal'] = np.where(data.predicted_gold_price.shift(1) < data.predicted_gold_price,"Buy","No Position")  
data.tail(1)[['signal','predicted_gold_price']].T 

輸出如下:

以上就是Python機(jī)器學(xué)習(xí)之預(yù)測黃金價格的詳細(xì)內(nèi)容,更多關(guān)于Python機(jī)器學(xué)習(xí)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python實戰(zhàn)之整蠱神器合集加速友盡

    Python實戰(zhàn)之整蠱神器合集加速友盡

    讀萬卷書不如行萬里路,學(xué)的扎不扎實要通過實戰(zhàn)才能看出來,本篇文章手把手帶用python來做幾個整蠱的小程序,大家可以在過程中查缺補(bǔ)漏,看看自己掌握程度怎么樣,發(fā)給朋友加固一下友誼
    2021-10-10
  • Python通過pytesseract庫實現(xiàn)識別圖片中的文字

    Python通過pytesseract庫實現(xiàn)識別圖片中的文字

    Pytesseract是一個Python的OCR庫,它可以識別圖片中的文本并將其轉(zhuǎn)換成文本形式。本文就來用pytesseract庫實現(xiàn)識別圖片中的文字,感興趣的可以了解一下
    2023-05-05
  • 簡單了解python字符串前面加r,u的含義

    簡單了解python字符串前面加r,u的含義

    這篇文章主要介紹了簡單了解python字符串前面加r,u的含義,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • 深入理解Pytorch中的torch. matmul()

    深入理解Pytorch中的torch. matmul()

    這篇文章主要介紹了Pytorch中的torch. matmul()的相關(guān)資料,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • Python操作Word批量生成文章的方法

    Python操作Word批量生成文章的方法

    這篇文章主要介紹了Python操作Word批量生成文章的方法,需要的朋友可以參考下
    2015-07-07
  • python使用json序列化datetime類型實例解析

    python使用json序列化datetime類型實例解析

    這篇文章主要介紹了python使用json序列化datetime類型實例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Django處理文件上傳File Uploads的實例

    Django處理文件上傳File Uploads的實例

    今天小編就為大家分享一篇Django處理文件上傳File Uploads的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 詳解Python開發(fā)語言中的基本數(shù)據(jù)類型

    詳解Python開發(fā)語言中的基本數(shù)據(jù)類型

    數(shù)據(jù)類型想必大家都知道是什么含義,指的是輸入數(shù)據(jù)的類型,任何數(shù)據(jù)都有明確的數(shù)據(jù)類型。本文主要和大家聊聊Python的三種基本數(shù)據(jù)類型,感興趣的可以了解一下
    2022-10-10
  • 教你使用Python從文件中提取IP地址

    教你使用Python從文件中提取IP地址

    Python提供了高效的高級數(shù)據(jù)結(jié)構(gòu),還能簡單有效地面向?qū)ο缶幊?下面這篇文章主要給大家介紹了關(guān)于如何使用Python從文件中提取IP地址的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • Python3.5集合及其常見運算實例詳解

    Python3.5集合及其常見運算實例詳解

    這篇文章主要介紹了Python3.5集合及其常見運算,結(jié)合實例形式分析了Python3.5集合的定義、功能、交集、并集、差集等常見操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2019-05-05

最新評論