对python实现二维函数高次拟合的示例详解

作者:赵迁的博客 时间:2021-06-30 11:24:06 

在参加“数据挖掘”比赛中遇到了关于函数高次拟合的问题,然后就整理了一下源码,以便后期的学习与改进。

在本次“数据挖掘”比赛中感觉收获最大的还是对于神经网络的认识,在接近一周的时间里,研究了进40种神经网络模型,虽然在持续一周的挖掘比赛把自己折磨的惨不忍睹,但是收获颇丰。现在想想也挺欣慰自己在这段时间里接受新知识的能力。关于神经网络方面的理解会在后续博文中补充(刚提交完论文,还没来得及整理),先分享一下高次拟合方面的知识。


# coding=utf-8
import matplotlib.pyplot as plt
import numpy as np
import scipy as sp
import csv
from scipy.stats import norm
from sklearn.pipeline import Pipeline
from sklearn.linear_model import LinearRegression
from sklearn.preprocessing import PolynomialFeatures
from sklearn import linear_model

''''' 数据导入 '''
def loadDataSet(fileName):
dataMat = []
labelMat = []
csvfile = file(fileName, 'rb')
reader = csv.reader(csvfile)
b = 0
for line in reader:
 if line[50] is '':
  b += 1
 else:
  dataMat.append(float(line[41])/100*20+30)
  labelMat.append(float(line[25])*100)

csvfile.close()
print "absence time number: %d" % b
return dataMat,labelMat

xArr,yArr = loadDataSet('data.csv')
x = np.array(xArr)
y = np.array(yArr)
# x = np.arange(0, 1, 0.002)
# y = norm.rvs(0, size=500, scale=0.1)
# y = y + x ** 2

def rmse(y_test, y):
return sp.sqrt(sp.mean((y_test - y) ** 2))

def R2(y_test, y_true):
return 1 - ((y_test - y_true) ** 2).sum() / ((y_true - y_true.mean()) ** 2).sum()

def R22(y_test, y_true):
y_mean = np.array(y_true)
y_mean[:] = y_mean.mean()
return 1 - rmse(y_test, y_true) / rmse(y_mean, y_true)

plt.scatter(x, y, s=5)
#分别进行1,2,3,6次拟合
degree = [1, 2,3, 6]
y_test = []
y_test = np.array(y_test)

for d in degree:
#普通
# clf = Pipeline([('poly', PolynomialFeatures(degree=d)),
#     ('linear', LinearRegression(fit_intercept=False))])
# clf.fit(x[:, np.newaxis], y)

# 岭回归
clf = Pipeline([('poly', PolynomialFeatures(degree=d)),
    ('linear', linear_model.Ridge())])
clf.fit(x[:, np.newaxis], y)
y_test = clf.predict(x[:, np.newaxis])

print('多项式参数%s' %clf.named_steps['linear'].coef_)
print('rmse=%.2f, R2=%.2f, R22=%.2f, clf.score=%.2f' %
  (rmse(y_test, y),
  R2(y_test, y),
  R22(y_test, y),
  clf.score(x[:, np.newaxis], y)))

plt.plot(x, y_test, linewidth=2)

plt.grid()
plt.legend(['1', '2','3', '6'], loc='upper left')
plt.show()

来源:https://blog.csdn.net/QianZhaoVic/article/details/70545119

标签:python,二维,高次,拟合
0
投稿

猜你喜欢

  • mysql高级学习之索引的优劣势及规则使用

    2024-01-13 16:21:33
  • CSS分栏布局的方法:绝对定位和浮动

    2009-04-30 13:10:00
  • mysql 日期和时间函数

    2024-01-12 18:56:13
  • 使用Python编写简单的端口扫描器的实例分享

    2023-07-20 20:18:32
  • js实时监听文本框状态的方法

    2024-04-25 13:10:58
  • SQL Server忘记sa账号密码重新添加新管理账号

    2024-01-18 09:59:44
  • 常用于后台开发的jQuery插件

    2010-09-25 12:47:00
  • python多线程分块读取文件

    2023-10-29 18:48:51
  • python结合shell查询google关键词排名的实现代码

    2023-10-11 21:28:47
  • python字符串,数值计算

    2022-12-28 11:20:32
  • python文件操作之目录遍历实例分析

    2021-05-16 11:46:16
  • 初学者必读:提高SQL执行效率的几点建议

    2009-05-07 13:52:00
  • JavaScript实现省市联动过程中bug的解决方法

    2024-04-19 10:46:05
  • mysql数据库创建账号、授权、数据导出、导入操作示例

    2024-01-26 06:44:42
  • Python运行的17个时新手常见错误小结

    2023-05-20 00:13:17
  • Flask框架模板渲染操作简单示例

    2023-06-07 00:02:45
  • Python实现队列的方法示例小结【数组,链表】

    2023-09-27 13:52:11
  • python使用openpyxl操作excel的方法步骤

    2022-09-30 20:59:24
  • Python设计实现的计算器功能完整实例

    2021-07-17 12:26:05
  • javascript设置页面背景色及背景图片的方法

    2023-09-06 22:00:51
  • asp之家 网络编程 m.aspxhome.com