当前位置: 首页 > news >正文

网站的成本网站刷单账务处理怎么做

网站的成本,网站刷单账务处理怎么做,如何做网站词库,网页界面设计特点添加原始数据的交互特征#xff08;interaction feature#xff09;和多项式特征#xff08;polynomial feature#xff09;可以丰富特征表示#xff0c;特别是对于线性模型。这种特征工程可以用统计建模和许多实际的机器学习应用中。 上一次学习#xff1a;线性模型对w…添加原始数据的交互特征interaction feature和多项式特征polynomial feature可以丰富特征表示特别是对于线性模型。这种特征工程可以用统计建模和许多实际的机器学习应用中。 上一次学习线性模型对wave数据集中的每个箱子都学到一个常数值。但我们知道线性模型不仅可以学习偏移还可以学习斜率。想要向分箱数据上的线性模型添加斜率一种方法是重新加入原始特征。这样会得到11维的数据集如下代码 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizerX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) print(X_combined.shape)reg LinearRegression().fit(X_combined, y)line_combined np.hstack([line, line_binned]) plt.plot(line, reg.predict(line_combined), labellinear regression combined) plt.vlines(kb.bin_edges_[0], -3, 3, linewidth1, alpha.2) plt.legend(locbest) plt.ylabel(Regression output) plt.xlabel(Input feature) plt.plot(X[:, 0], y, o, ck) plt.show() 输出结果(100, 11) 输出图形 输出的图形是使用分箱特征和单一全局斜率的线性回归。 在这个例子中模型在每个箱子中都学到一个偏移还学到一个斜率。学到的斜率是向下的并且在所有箱子中都相同——只有一个x轴特征也就只有一个斜率。因为斜率在所有箱子中是相同的所以它似乎不是很有用。我们更希望每个箱子都有一个不同的斜率。为了实现这一点我们可以添加交互特征或乘积特征用来表示数据点所在的箱子以及数据点在x轴上的位置。这个特征是箱子指示符与原始特征的乘积。下面来创建数据集 import numpy as np import mglearn #import matplotlib.pyplot as plt #from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizerX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) #print(X_combined.shape)line_combined np.hstack([line, line_binned])# 创建数据集 X_product np.hstack([X_binned, X * X_binned]) print(X_product.shape) 输出(100, 20)  。这个数据集现在有20个特征数据点所在箱子的指示符与原始特征和箱子指示符的乘积。可以将乘积特征看作每个箱子x轴特征的单独副本。它在箱子内等于原始特征在其他 位置等于零。下面我们代码绘图给出线性模型在这种新表示上的结果 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizerX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) #print(X_combined.shape)# 创建数据集 X_product np.hstack([X_binned, X * X_binned]) #print(X_product.shape)reg LinearRegression().fit(X_product, y)line_product np.hstack([line_binned, line * line_binned])plt.plot(line, reg.predict(line_product), labellinear regression product) plt.vlines(kb.bin_edges_[0], -3, 3, linewidth1, alpha.2) plt.plot(X[:, 0], y, o, ck) plt.ylabel(Regression output) plt.xlabel(Input feature) plt.legend(locbest) plt.show() 输出图形 上图显示每个箱子具有不同的偏移和斜率。使用分箱是扩展连续特征的一种方法。另一种方法是 使用原始特征的多项式polynomial。对于给定特征x我们可以考虑x ** 2、x ** 3、x ** 4等等。这在preprocessing模块的PolynomialFeatures中实现 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizer from sklearn.preprocessing import PolynomialFeaturesX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) #print(X_combined.shape)# 创建数据集 #X_product np.hstack([X_binned, X * X_binned]) #print(X_product.shape)# 包含直到x ** 10的多项式: # 默认的include_biasTrue添加恒等于1的常数特征 poly PolynomialFeatures(degree10, include_biasFalse) poly.fit(X) X_poly poly.transform(X) # 多项式的次数为 10因此生成10个特征 print(X_poly.shape: {}.format(X_poly.shape)) 输出X_poly.shape: (100, 10) 比较X_ploy和X的元素 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizer from sklearn.preprocessing import PolynomialFeaturesX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) #print(X_combined.shape)# 创建数据集 #X_product np.hstack([X_binned, X * X_binned]) #print(X_product.shape)# 包含直到x ** 10的多项式: # 默认的include_biasTrue添加恒等于1的常数特征 poly PolynomialFeatures(degree10, include_biasFalse) poly.fit(X) X_poly poly.transform(X) # 多项式的次数为 10因此生成10个特征 print(X_poly.shape: {}.format(X_poly.shape))# 比较 X_poly 和 X 的元素 print(Entries of X:\n{}.format(X[:5])) print(Entries of X_poly:\n{}.format(X_poly[:5])) 输出 Entries of X: [[-0.75275929]  [ 2.70428584]  [ 1.39196365]  [ 0.59195091]  [-2.06388816]] Entries of X_poly: [[-7.52759287e-01  5.66646544e-01 -4.26548448e-01  3.21088306e-01   -2.41702204e-01  1.81943579e-01 -1.36959719e-01  1.03097700e-01   -7.76077513e-02  5.84199555e-02]  [ 2.70428584e00  7.31316190e00  1.97768801e01  5.34823369e01    1.44631526e02  3.91124988e02  1.05771377e03  2.86036036e03    7.73523202e03  2.09182784e04]  [ 1.39196365e00  1.93756281e00  2.69701700e00  3.75414962e00    5.22563982e00  7.27390068e00  1.01250053e01  1.40936394e01    1.96178338e01  2.73073115e01]  [ 5.91950905e-01  3.50405874e-01  2.07423074e-01  1.22784277e-01    7.26822637e-02  4.30243318e-02  2.54682921e-02  1.50759786e-02    8.92423917e-03  5.28271146e-03]  [-2.06388816e00  4.25963433e00 -8.79140884e00  1.81444846e01   -3.74481869e01  7.72888694e01 -1.59515582e02  3.29222321e02   -6.79478050e02  1.40236670e03]] 我们可以通过调用 get_feature_names_out 方法来获取特征的语义给出每个特征的指数 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizer from sklearn.preprocessing import PolynomialFeaturesX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) #print(X_combined.shape)# 创建数据集 #X_product np.hstack([X_binned, X * X_binned]) #print(X_product.shape)# 包含直到x ** 10的多项式: # 默认的include_biasTrue添加恒等于1的常数特征 poly PolynomialFeatures(degree10, include_biasFalse) poly.fit(X) X_poly poly.transform(X) # 多项式的次数为 10因此生成10个特征 print(X_poly.shape: {}.format(X_poly.shape))# 比较 X_poly 和 X 的元素 print(Entries of X:\n{}.format(X[:5])) print(Entries of X_poly:\n{}.format(X_poly[:5]))#调用 get_feature_names_out 方法来获取特征的语义给出每个特征的指数 print(Polynomial feature names:\n{}.format(poly.get_feature_names_out())) 输出 Polynomial feature names: [x0 x0^2 x0^3 x0^4 x0^5 x0^6 x0^7 x0^8 x0^9 x0^10] 可以看到X_poly 的第一列与 X 完全对应而其他列则是第一列的幂。有趣的是可以发现有些值非常大。第二行有大于 20000 的元素数量级与其他行都不相同。将多项式特征与线性回归模型一起使用可以得到经典的多项式回归polynomial regression模型见如下代码实现 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression #from sklearn.tree import DecisionTreeRegressor #from sklearn.preprocessing import OneHotEncoder from sklearn.preprocessing import KBinsDiscretizer from sklearn.preprocessing import PolynomialFeaturesX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)# 生成10个箱子 #kb KBinsDiscretizer(n_bins10, strategyuniform) #kb.fit(X)kb KBinsDiscretizer(n_bins10, strategyuniform, encodeonehot-dense) kb.fit(X) #X_binned kb.transform(X) # 记录每个数据点所属的箱子。 X_binned kb.transform(X) #line_binned kb.transform(line)# 加入原始特征 X_combined np.hstack([X, X_binned]) #print(X_combined.shape)# 创建数据集 #X_product np.hstack([X_binned, X * X_binned]) #print(X_product.shape)# 包含直到x ** 10的多项式: # 默认的include_biasTrue添加恒等于1的常数特征 poly PolynomialFeatures(degree10, include_biasFalse) poly.fit(X) X_poly poly.transform(X) # 多项式的次数为 10因此生成10个特征 #print(X_poly.shape: {}.format(X_poly.shape))# 比较 X_poly 和 X 的元素 #print(Entries of X:\n{}.format(X[:5])) #print(Entries of X_poly:\n{}.format(X_poly[:5]))#调用 get_feature_names 方法来获取特征的语义给出每个特征的指数 #print(Polynomial feature names:\n{}.format(poly.get_feature_names_out()))reg LinearRegression().fit(X_poly, y)line_poly poly.transform(line) plt.plot(line, reg.predict(line_poly), labelpolynomial linear regression) plt.plot(X[:, 0], y, o, ck) plt.ylabel(Regression output) plt.xlabel(Input feature) plt.legend(locbest) plt.show() 输出图形 上图是具有 10 次多项式特征的线性回归。多项式特征在这个一维数据上得到了非常平滑的拟合。但高次多项式在边界上或数据很少的区域可能有极端的表现。作为对比下面是在原始数据上学到的核SVM模型没有做任何变换 import numpy as np import mglearn import matplotlib.pyplot as plt from sklearn.svm import SVRX, y mglearn.datasets.make_wave(n_samples100) line np.linspace(-3, 3, 1000, endpointFalse).reshape(-1, 1)for gamma in [1, 10]:svr SVR(gammagamma).fit(X, y)plt.plot(line, svr.predict(line), labelSVR gamma{}.format(gamma))plt.plot(X[:, 0], y, o, ck) plt.ylabel(Regression output) plt.xlabel(Input feature) plt.legend(locbest) plt.show() 输出图形对于RBF核的SVM使用不同 gamma 参数的对比 使用更加复杂的模型即核 SVM能够学到一个与多项式回归的复杂度类似的预测结果且不需要进行显式的特征变换。
http://www.hkea.cn/news/14483392/

相关文章:

  • 昊诺网站建设网络推广重庆营销网站建设公司
  • 移动端网站seo伪静态 wordpress
  • 网站社区建设嘉兴网站排名优化报价
  • 免费品牌网站制作金融网站设计方向
  • 网站建设公司 合肥成都it外包公司
  • 网站点击换图片的效果怎么做电商网站开发前景
  • 网站建设类型报价表编程培训机构有哪些
  • 用dedecms做的网站 脚本是什么云商城
  • 企业网站如何推广网站模板下载软件
  • 晋城客运东站网站开发烟台市福山区住房和建设局网站
  • 高品质网站建设公司网页游戏排行榜百战沙城
  • 会展网站代码源码网页设计实验报告心得和总结500字
  • 做视频网站把视频放在哪里wordpress就是博客吗
  • 第三方交易网站怎么做运动服装商城网站建设
  • 网站怎么做外链接做电影平台网站怎么赚钱吗
  • aspx网站开发 案例miit网站备案
  • 徐州cms建站电商学院建设设计网站
  • 建造师免费自学网站seo网站技术培训
  • wordpress建设网站网站 欣赏
  • 视觉传达毕业设计作品网站温州网页设计
  • 广州h5设计网站公司中国版动漫网站模板
  • 2018网站设计报价表做网站微信朋友圈应该怎么发
  • sns社区网站开发怎么做网站编辑
  • 咸宁网站制作培训百度信息流推广是什么意思
  • 新乡网站建设制作报价方案陕西煤业化工建设集团网站
  • 电商网站建设 教学总结各大搜索引擎收录入口
  • 百度如何推广网站wordpress视频自动播放
  • 多网站建设网页编辑和发布流程不包括以下哪个选项
  • 重庆网站平台网站备案 收费
  • Iis 建网站为什么说没有该用户唐山seo设计网站