欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

博客园小技巧

程序员文章站 2023-01-11 14:14:41
传送门:人工智能视频列表-尚学堂,点开任意一个之后会发现他们会提供系列课程整合到一起的百度网盘下载,包括视频+代码+资料,都是免费的 这里:博客园小技巧,我觉得这个很好玩,可以拿来用。 第一种方法:利用numpy使用常规等式的数学方法,类似解数学方程,并利用matplot实现可视化。 有用到概率学方 ......

传送门:,点开任意一个之后会发现他们会提供系列课程整合到一起的百度网盘下载,包括视频+代码+资料,都是免费的

这里:博客园小技巧我觉得这个很好玩,可以拿来用。

第一种方法:利用numpy使用常规等式的数学方法,类似解数学方程,并利用matplot实现可视化。

有用到概率学方面的知识,比如似然什么的,大概了解下就ok,下面是代码:

 1 import numpy as np
 2 import matplotlib.pyplot as plt
 3 
 4 # create an array of the given shape and populate it with random samples from a uniform distribution over ``[0, 1)``
 5 x = 2 * np.random.rand(100, 1)
 6 # 认为设置y值,np.random.randn(100, 1)是设置error,randn是标准正态分布
 7 y = 4 + 3 * x + np.random.randn(100, 1)
 8 # 整合x0和x1,拼接到一起了
 9 x_b = np.c_[np.ones((100, 1)), x]
10 print(x_b)
11 
12 # 常规等式法求解theta,求逆,转置,点乘
13 theta_best = np.linalg.inv(x_b.t.dot(x_b)).dot(x_b.t).dot(y)
14 print(theta_best)
15 
16 # 创建测试集里面的x1
17 x_new = np.array([[0], [2]])
18 x_new_b = np.c_[(np.ones((2, 1))), x_new]
19 print(x_new_b)
20 y_predict = x_new_b.dot(theta_best)
21 print(y_predict)
22 
23 plt.plot(x_new, y_predict, 'r-')    # 红色 线图
24 plt.plot(x, y, 'b.')                       # 蓝色 点图
25 plt.axis([0, 2, 0, 15])                # x轴,y轴区间
26 plt.show()

想说个小技巧,选中调用的函数,快捷键crtl+b,或者单击右键,go to,declaration;就可以快速转到调用的函数那儿,注:我用的是pycharm + anaconda3.

第二种方法:使用sklearn框架,看着很简单呢。主要用到的是fit,predict

import numpy as np
from sklearn.linear_model import linearregression

x = 2 * np.random.rand(100, 1)
y = 4 + 3 * x + np.random.randn(100, 1)

lin_reg = linearregression()
lin_reg.fit(x, y)
print(lin_reg.intercept_, lin_reg.coef_)

x_new = np.array([[0], [2]])
print(lin_reg.predict(x_new))

还有,我觉得动手写最重要,然后哪里不会找哪里,多看看相关的博客,总会用到的;而且博客很好玩,自己写下来可以随时再看,真的方便,也要多写写博客,完。

哎,这个该放到哪一类呢?

今天就是这些了,有些少,早上睡懒觉了,晚上有个考研讲座要去听(关于我们专业的,不是数学、英语,政治的),over