题目太长啦!文档下载【传送门

第1题

简述:设计一个5*5的单位矩阵。

 import numpy as np
A = np.eye(5)
print(A)

运行结果:

第2题

简述:实现单变量线性回归。

 import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D #-----------------计算代价值函数-----------------------
def computeCost(X, y, theta):
m = np.size(X[:,0])
J = 1/(2*m)*np.sum((np.dot(X,theta)-y)**2)
return J #----------------根据人口预测利润----------------------
#读取数据集中数据,第一列是人口数据,第二列是利润数据
data = np.loadtxt('ex1data1.txt',delimiter=",",dtype="float")
m = np.size(data[:,0])
# print(data) #------------------绘制样本点--------------------------
X = data[:,0:1]
y = data[:,1:2]
plt.plot(X,y,"rx")
plt.xlabel('Population of City in 10,000s')
plt.ylabel('Profit in $10,000s')
# plt.show() #-----------------梯度下降计算局部最优解----------------
#添加第一列1
one = np.ones(m)
X = np.insert(X,0,values=one,axis=1)
# print(X) #设置α、迭代次数、θ
theta = np.zeros((2,1))
iterations = 1500
alpha = 0.01 #梯度下降,并显示线性回归
J_history = np.zeros((iterations,1))
for iter in range(0,iterations):
theta = theta - alpha/m*np.dot(X.T,(np.dot(X,theta)-y))
J_history[iter] = computeCost(X,y,theta)
plt.plot(data[:,0],np.dot(X,theta),'-')
plt.show()
# print(theta)
# print(J_history) #--------------------显示三维图------------------------
theta0 = np.linspace(-10,10,100)
theta1 = np.linspace(-1,4,100)
J_vals = np.zeros((np.size(theta0),np.size(theta1)))
for i in range(0,np.size(theta0)):
for j in range(0,np.size(theta1)):
t = np.asarray([theta0[i],theta1[j]]).reshape(2,1)
J_vals[i,j] = computeCost(X,y,t)
# print(J_vals)
J_vals = J_vals.T #需要转置一下,否则轴会反
fig1 = plt.figure()
ax = Axes3D(fig1)
ax.plot_surface(theta0,theta1,J_vals,rstride=1,cstride=1,cmap=plt.get_cmap('rainbow'))
ax.set_xlabel('theta0')
ax.set_ylabel('theta1')
ax.set_zlabel('J')
plt.show() #--------------------显示轮廓图-----------------------
lines = np.logspace(-2,3,20)
plt.contour(theta0,theta1,J_vals,levels = lines)
plt.xlabel('theta0')
plt.ylabel('theta1')
plt.plot(theta[0],theta[1],'rx')
plt.show()

运行结果:

第3题

简述:实现多元线性回归。

 import numpy as np
import matplotlib.pyplot as plt #-----------------计算代价值函数-----------------------
def computeCost(X, y, theta):
m = np.size(X[:,0])
J = 1/(2*m)*np.sum((np.dot(X,theta)-y)**2)
return J #-------------------根据面积和卧室数量预测房价----------
#读取数据集中数据,第一列是面积数据,第二列是卧室数量,第三列是房价
data = np.loadtxt('ex1data2.txt',delimiter=",",dtype="float")
m = np.size(data[:,0])
# print(data)
X = data[:,0:2]
y = data[:,2:3] #----------------------均值归一化---------------------
mu = np.mean(X,0)
sigma = np.std(X,0)
X_norm = np.divide(np.subtract(X,mu),sigma)
one = np.ones(m) #添加第一列1
X_norm = np.insert(X_norm,0,values=one,axis=1)
# print(mu)
# print(sigma)
# print(X_norm) #----------------------梯度下降-----------------------
alpha = 0.05
num_iters = 100
theta = np.zeros((3,1));
J_history = np.zeros((num_iters,1))
for iter in range(0,num_iters):
theta = theta - alpha/m*np.dot(X_norm.T,(np.dot(X_norm,theta)-y))
J_history[iter] = computeCost(X_norm,y,theta)
# print(theta)
x_col = np.arange(0,num_iters)
plt.plot(x_col,J_history,'-b')
plt.xlabel('Number of iterations')
plt.ylabel('Cost J')
plt.show() #----------使用上述结果对[1650,3]的数据进行预测--------
test1 = [1,1650,3]
test1[1:3] = np.divide(np.subtract(test1[1:3],mu),sigma)
price = np.dot(test1,theta)
print(price) #输出预测结果[292455.63375132] #-------------使用正规方程法求解----------------------
one = np.ones(m)
X = np.insert(X,0,values=one,axis=1)
theta = np.dot(np.dot(np.linalg.pinv(np.dot(X.T,X)),X.T),y)
# print(theta)
price = np.dot([1,1650,3],theta)
print(price) #输出预测结果[293081.46433497]

运行结果:【一个疑惑>>两种方法求解的估算价格很小,但θ相差较大?】

最新文章

  1. 实现放大转场动画 from cocoachina
  2. hhvm的正确安装姿势 http://dl.hhvm.com 镜像
  3. usb驱动开发18之设备生命线
  4. Tarjan算法详解理解集合
  5. yaffs文件系统
  6. hdu 2717 Catch That Cow(BFS,剪枝)
  7. L006-oldboy-mysql-dba-lesson06
  8. Unity3d ngui基础教程
  9. 通俗理解angularjs中的$apply,$digest,$watch
  10. html查看器android
  11. 关于postgresql group by 报错
  12. VSCode汉化
  13. 【转】再有人问你Http协议是什么,把这篇文章发给他
  14. SpringBoot点滴(1)
  15. centos7 下安装 nginx-1.12.2
  16. 多模匹配算法之Aho-Corasick
  17. JavaScript数据去掉空值
  18. <深入理解JavaScript>学习笔记(5)_强大的原型和原型链
  19. php 内存泄漏
  20. [Python]简单的外星人入侵游戏

热门文章

  1. 检测APK是否存在Janus漏洞步骤
  2. Python 编程入门(1):基本数据类型
  3. 全文检索以及Lucene的应用
  4. 通过Java代码获取系统信息
  5. Mac-App Store 购买过程中出错 请求超时
  6. (未完成)【Android】MVP模式初见(一)
  7. JavaScript 浅复制和深复制
  8. 面向对象编程(什么是对象)——java
  9. Html介绍,了解html与css关系
  10. Windows通过DOS命令行设置IP地址