梯度漸進迴歸樹GBDT(Gradient Boosting Decision Tree)是一種迭代決策樹演算法,適用於線性及非線性迴歸情境。
組件配置
您可以使用以下任意一種方式,配置GBDT迴歸組件參數。
方式一:可視化方式
在Designer工作流程頁面配置組件參數。
頁簽 | 參數 | 描述 |
欄位設定 | 輸入列 | 輸入資料來源中,參與訓練的特徵列。支援DOUBLE及BIGINT類型。 說明 特徵列數量不能超過800。 |
標籤列 | 支援DOUBLE及BIGINT類型。 | |
分組列 | 支援DOUBLE及BIGINT類型,預設將全表作為一組。 | |
參數設定 | 損失函數類型 | 支援gbrank loss、lambdamart dcg loss、lambdamart ndcg loss及regression loss類型。 |
gbrank loss中的Tau參數 | 取值範圍為[0,1]。 | |
gbrank與regression loss中的指數底數 | 取值範圍為[1,10]。 | |
metric類型 | 支援NDCG及DCG類型。 | |
樹數量 | 取值範圍為1~10000。 | |
學習速率 | 取值範圍為(0,1)。 | |
最大葉子數 | 取值範圍為1~1000。 | |
一棵樹的最大深度 | 取值範圍為1~100。 | |
葉子節點容納的最少樣本數 | 取值範圍為1~1000。 | |
樣本採樣比例 | 取值範圍為(0,1)。 | |
訓練中採集的特徵比例 | 取值範圍為(0,1)。 | |
測試樣本數比例 | 取值範圍為[0,1)。 | |
隨機數產生器種子 | 取值範圍為[0,10]。 | |
是否使用newton方法來學習 | 使用Newton方法的開關。 | |
一個特徵分裂的最大數量 | 取值範圍為1~1000。 | |
執行調優 | 計算核心數 | 系統根據輸入資料量,自動分配訓練的執行個體數量。 |
每個核記憶體 | 系統根據輸入資料量,自動分配記憶體。單位為MB。 |
方式二:PAI命令方式
使用PAI命令方式,配置該組件參數。您可以使用SQL指令碼組件進行PAI命令調用,詳情請參見SQL指令碼。
PAI -name gbdt
-project algo_public
-DfeatureSplitValueMaxSize="500"
-DlossType="0"
-DrandSeed="0"
-DnewtonStep="0"
-Dshrinkage="0.05"
-DmaxLeafCount="32"
-DlabelColName="campaign"
-DinputTableName="bank_data_partition"
-DminLeafSampleCount="500"
-DsampleRatio="0.6"
-DgroupIDColName="age"
-DmaxDepth="11"
-DmodelName="xlab_m_GBDT_83602"
-DmetricType="2"
-DfeatureRatio="0.6"
-DinputTablePartitions="pt=20150501"
-Dtau="0.6"
-Dp="1"
-DtestRatio="0.0"
-DfeatureColNames="previous,cons_conf_idx,euribor3m"
-DtreeCount="500"
參數 | 是否必選 | 描述 | 預設值 |
inputTableName | 是 | 輸入表的名稱。 | 無 |
featureColNames | 否 | 輸入表中,用於訓練的特徵列名。支援DOUBLE及BIGINT類型。 | 所有數值列 |
labelColName | 是 | 輸入表中的標籤列名,支援DOUBLE及BIGINT類型。 | 無 |
inputTablePartitions | 否 | 輸入表中,參與訓練的分區。支援的格式包括:
說明 如果指定多個分區,則使用英文逗號(,)分隔。 | 所有分區 |
modelName | 是 | 輸出的模型名稱。 | 無 |
outputImportanceTableName | 否 | 輸出特徵重要性的表名。 | 無 |
groupIDColName | 否 | 資料分組列。 | 全表 |
lossType | 否 | 損失函數包括以下類型:
| 0 |
metricType | 否 | 包括以下類型:
| 0 |
treeCount | 否 | 樹數量,取值範圍為1~10000。 | 500 |
shrinkage | 否 | 學習速率,取值範圍為(0,1)。 | 0.05 |
maxLeafCount | 否 | 最大葉子數,取值範圍為1~1000。 | 32 |
maxDepth | 否 | 樹的最大深度,取值範圍為1~100。 | 10 |
minLeafSampleCount | 否 | 葉子節點容納的最少樣本數,取值範圍為1~1000。 | 500 |
sampleRatio | 否 | 訓練採集的樣本比例,取值範圍為(0,1)。 | 0.6 |
featureRatio | 否 | 訓練採集的特徵比例,取值範圍為(0,1)。 | 0.6 |
tau | 否 | GBRank Loss中的Tau參數,取值範圍為[0,1]。 | 0.6 |
p | 否 | GBRank Loss中的p參數,取值範圍為[1,10]。 | 1 |
randSeed | 否 | 隨機數種子,取值範圍為[0,10]。 | 0 |
newtonStep | 否 | 使用Newton迭代法的開關,取值範圍為{0,1}。 | 1 |
featureSplitValueMaxSize | 否 | 特徵分裂的最大數量,取值範圍為1~1000。 | 500 |
lifecycle | 否 | 輸出表的生命週期。 | 無 |
樣本
使用SQL語句,產生測試資料。
drop table if exists gbdt_ls_test_input; create table gbdt_ls_test_input as select * from ( select cast(1 as double) as f0, cast(0 as double) as f1, cast(0 as double) as f2, cast(0 as double) as f3, cast(0 as bigint) as label union all select cast(0 as double) as f0, cast(1 as double) as f1, cast(0 as double) as f2, cast(0 as double) as f3, cast(0 as bigint) as label union all select cast(0 as double) as f0, cast(0 as double) as f1, cast(1 as double) as f2, cast(0 as double) as f3, cast(1 as bigint) as label union all select cast(0 as double) as f0, cast(0 as double) as f1, cast(0 as double) as f2, cast(1 as double) as f3, cast(1 as bigint) as label union all select cast(1 as double) as f0, cast(0 as double) as f1, cast(0 as double) as f2, cast(0 as double) as f3, cast(0 as bigint) as label union all select cast(0 as double) as f0, cast(1 as double) as f1, cast(0 as double) as f2, cast(0 as double) as f3, cast(0 as bigint) as label ) a;
產生的測試資料表gbdt_ls_test_input如下。
f0
f1
f2
f3
label
1.0
0.0
0.0
0.0
0
0.0
0.0
1.0
0.0
1
0.0
0.0
0.0
1.0
1
0.0
1.0
0.0
0.0
0
1.0
0.0
0.0
0.0
0
0.0
1.0
0.0
0.0
0
使用PAI命令,提交GBDT迴歸組件的訓練參數。
drop offlinemodel if exists gbdt_ls_test_model; PAI -name gbdt -project algo_public -DfeatureSplitValueMaxSize="500" -DlossType="3" -DrandSeed="0" -DnewtonStep="1" -Dshrinkage="0.5" -DmaxLeafCount="32" -DlabelColName="label" -DinputTableName="gbdt_ls_test_input" -DminLeafSampleCount="1" -DsampleRatio="1" -DmaxDepth="10" -DmetricType="0" -DmodelName="gbdt_ls_test_model" -DfeatureRatio="1" -Dp="1" -Dtau="0.6" -DtestRatio="0" -DfeatureColNames="f0,f1,f2,f3" -DtreeCount="10"
使用PAI命令,提交預測組件參數。
drop table if exists gbdt_ls_test_prediction_result; PAI -name prediction -project algo_public -DdetailColName="prediction_detail" -DmodelName="gbdt_ls_test_model" -DitemDelimiter="," -DresultColName="prediction_result" -Dlifecycle="28" -DoutputTableName="gbdt_ls_test_prediction_result" -DscoreColName="prediction_score" -DkvDelimiter=":" -DinputTableName="gbdt_ls_test_input" -DenableSparse="false" -DappendColNames="label"
查看預測結果表gbdt_ls_test_prediction_result。
label
prediction_result
prediction_score
prediction_detail
0
NULL
0.0
{“label”: 0}
0
NULL
0.0
{“label”: 0}
1
NULL
0.9990234375
{“label”: 0.9990234375}
1
NULL
0.9990234375
{“label”: 0.9990234375}
0
NULL
0.0
{“label”: 0}
0
NULL
0.0
{“label”: 0}