python 预测值和真实值分析 散点图

参考:https://ask.csdn.net/questions/7464230.

import numpy as np
# import csv
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib
matplotlib.rcParams['font.sans-serif'] = ['SimHei']
matplotlib.rcParams['font.family']=['sans-serif']
dataframe = pd.read_csv("LR_data_exam.csv", sep=",")
x = dataframe['battery'].tolist()
y = dataframe['KM'].tolist()
# 画出数据的散点图
fig = plt.figure()  # 整个绘图区分成一行两列,当前图是第一个。
fig.set_size_inches(10, 10)   # 整个绘图区域的宽度10和高度4
# # 画出数据和拟合直线的图
plt.scatter(x, y)
t = np.linspace(0,25,100)
plt.plot(t, 5.5*t) #线性回归线,5.5是斜率
#plt.plot(t, k*t+b) #线性回归线,k是斜率,b截距
plt.xlabel("真实值")
plt.ylabel("预测值")
plt.title("拟合结果")
plt.show()

求斜率和截距:

class MLR:
    def __init__(self,x,y,intercept=True):
        self.x=x
        self.y=y
        self.ic=intercept
    def fit(self):
        if self.ic:
            ones=np.ones(len(self.x) )
            X=np.c_[ones,self.x]
        else:
            X=self.x
        y=self.y
        self.a=np.linalg.inv(X.T@X)@X.T@y
    def predict(self,x_new):
        if self.ic:
           ones=np.ones(x_new.shape)
           x=np.c_[ones,x_new]
        else:
            x=x_new
        y=x @ self.a
        return y
model = MLR(x,y)
model.fit() #回归
k = float(model.a[1])  #斜率
b = float(model.a[0])   #截距
print("斜率:{}\n截距:{}".format(k,b))

在这里插入图片描述

  • 3
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值