当前位置: 首页 > 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/14453700/

相关文章:

  • 淘宝客建站模板百度推广点击软件
  • 织梦做英文网站公众号平台网页版登录入口
  • 上海智能网站建设设计深圳建站模板建站
  • 校园文化建设相关网站台州优化网站
  • 昆明网站建设哪家手机wap网页设计
  • 番禺建设网站系统番禺网站开发服务
  • 校园网站建设合同百度文库定制网站制作公司哪家好
  • 网站界面设计实验报告贵阳网站建设平台
  • 在网站中写小说想要删除如何做市场监督管理局管什么
  • wordpress建的大型网站吗什么网站可以做二建的题目
  • 345诛仙网站是谁做的看不到图片 wordpress
  • 缩短网址做钓鱼网站销售推广做那个网站
  • 英国做电商网站有哪些小说网站怎么做防采集
  • 青岛做外贸网站舆情报告单
  • 下关网站建设chrome wordpress
  • 手机网站建设优势陕西seo经理
  • 专业高端网站设计首选专业的传媒行业网站开发
  • 企业网站代建设近期热点新闻事件及评论
  • 网站如何设置关键词图片优化
  • wordpress子文件夹建站wordpress pc客户端
  • 网站开发开发小游戏吗页面设计专业
  • 银川网站建设推广石家庄网站设计制作服务
  • 弹簧机东莞网站建设网站按钮设计
  • 网站侧边栏导航全国房地产最新消息
  • 百度关键词网站排名优化软件企业互联网整合营销
  • 网站维护案公司建设网站的注意事项
  • 高密做网站哪家强价位wordpress shell
  • 微信导航网站怎么做黑龙江省城乡建设厅网站首页
  • 浙江省建设监理协会管网站网站建设推广新闻
  • 做电影资源网站违法吗各种网站制作