Pyspark 線性回歸梯度下降交叉驗(yàn)證知識(shí)點(diǎn)詳解
我正在嘗試在 pyspark 中的 SGD 模型上執(zhí)行交叉驗(yàn)證,我正在使用pyspark.mllib.regression,ParamGridBuilder和CrossValidator都來(lái)自pyspark.ml.tuning庫(kù)的LinearRegressionWithSGD。
在 Spark 網(wǎng)站上跟蹤文件資料之后,我希望運(yùn)行此方法可以正常工作
資料參考:https://spark.apache.org/docs/2.1.0/ml-tuning.html
lr = LinearRegressionWithSGD()
pipeline=Pipeline(stages=[lr])
paramGrid = ParamGridBuilder()\
.addGrid(lr.stepSize, Array(0.1, 0.01))\
.build()
crossval = CrossValidator(estimator=pipeline,estimatorParamMaps= paramGrid,
evaluator=RegressionEvaluator(),
numFolds=10)
但是LinearRegressionWithSGD()沒(méi)有屬性stepSize(也沒(méi)有運(yùn)氣嘗試過(guò)其他人)。
我可以將 lr 設(shè)置為L(zhǎng)inearRegression,但是我無(wú)法在模型中使用 SGD 并進(jìn)行交叉驗(yàn)證。
斯卡拉中有kFold方法,但我不確定如何從 pyspark 訪問(wèn)該方法
解決方案
您可以使用LinearRegressionWithSGD中的step參數(shù)來(lái)定義步長(zhǎng),但由于您正在混合不兼容的庫(kù),因此這將使代碼無(wú)法正常工作。不幸的是,我不知道如何使用SGD優(yōu)化對(duì)ml庫(kù)進(jìn)行交叉驗(yàn)證,我想知道自己,但是您正在混合使用pyspark.ml和pyspark.mllib庫(kù)。具體來(lái)說(shuō),您不能將LinearRegressionWithSGD與pyspark.ml庫(kù)一起使用。您必須使用pyspark.ml.regression.LinearRegression。
好消息是您可以將pyspark.ml.regression.LinearRegression的setsolver屬性設(shè)置為使用'gd'。因此,您可能可以將'gd'優(yōu)化器的參數(shù)設(shè)置為以SGD運(yùn)行,但是我不確定求解器文檔在哪里或如何設(shè)置求解器屬性(例如批大小)。該api顯示了調(diào)用Param()的LinearRegression對(duì)象,但是我不確定它是否使用pyspark.mllib優(yōu)化器。如果有人知道如何設(shè)置求解器屬性,則可以通過(guò)允許您將Pipeline,ParamGridBuilder和CrossValidation ml軟件包用于LinearRegression進(jìn)行模型選擇,并利用SGD優(yōu)化進(jìn)行參數(shù)調(diào)整來(lái)回答您的問(wèn)題。
到此這篇關(guān)于Pyspark 線性回歸梯度下降交叉驗(yàn)證知識(shí)點(diǎn)詳解的文章就介紹到這了,更多相關(guān)Pyspark 線性回歸梯度下降交叉驗(yàn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解Django 中是否使用時(shí)區(qū)的區(qū)別
本篇文章主要介紹了詳解Django 中是否使用時(shí)區(qū)的區(qū)別,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
Python實(shí)現(xiàn)分割文件及合并文件的方法
這篇文章主要介紹了Python實(shí)現(xiàn)分割文件及合并文件的方法,涉及Python針對(duì)文件的分割與合并操作相關(guān)技巧,通過(guò)自定義函數(shù)split與join實(shí)現(xiàn)了文件的分割與合并操作,需要的朋友可以參考下2015-07-07
python tornado微信開(kāi)發(fā)入門(mén)代碼
這篇文章主要為大家詳細(xì)介紹了python tornado微信開(kāi)發(fā)入門(mén)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08
python 兩個(gè)數(shù)據(jù)庫(kù)postgresql對(duì)比
這篇文章主要介紹了python 兩個(gè)數(shù)據(jù)庫(kù)postgresql對(duì)比,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
selenium中g(shù)et_cookies()和add_cookie()的用法詳解
這篇文章主要介紹了selenium中g(shù)et_cookies()和add_cookie()的用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01

