1 机器学习之线性回归

news/2024/10/22 7:26:26/

学习笔记自,慕课网 《Python3 入门人工智能》
https://coding.imooc.com/lesson/418.html#mid=33109

麻雀虽小,五脏俱全

1.1 回归分析

在这里插入图片描述

1.2 线性回归问题求解

在这里插入图片描述

1.3 寻找最合适的 a、b,引入损失函数的概念

尽可能使损失函数最小即找到了最合适的 a、b
![](https://img-blog.csdnimg.cn/a251f3cf46bf4721bd906a31c2e8993f.png)

1.4 损失函数的计算

在这里插入图片描述

1.5 怎么找a b 值呢,使用梯度下降法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.6 怎么利用梯度下降法找 a 、b值呢

在这里插入图片描述
在这里插入图片描述

--------------------------------------------------------分割线------------------------------------------------

2. 任务:

步骤:
1)使用模型预测合理房价,根据预测结果做出判断
2)生成损失函数
3)选择回归模型
4)使用梯度下降或者其他方法求解最小化损失函数的模型参数

2.1 Sklearn包介绍

42.png)

2.2 使用Sklearn求解a、b值

基于generated_data.csv数据,建立线性回归模型,预测x=3.5对应的y值,评估模型表现

generated_data.csv数据如下:
在这里插入图片描述
拟合结果: y = 2x + 5

## 回归分析 -- 房价 = F(面积)
import pandas as pd
import numpy as np
from matplotlib import pyplot as plt
from sklearn.linear_model import LinearRegression
from sklearn.metrics import mean_squared_error,r2_scoredata = pd.read_csv('generated_data.csv')
data.head()
x = data.loc[:,'x']
y = data.loc[:,'y']
#print("原始输入 x, y", x, y)
plt.figure(figsize=(20,20))
plt.scatter(x,y)
plt.show()
lr_model = LinearRegression()
x = np.array(x)
x = x.reshape(-1,1)
y = np.array(y)
y = y.reshape(-1,1)
# print(type(x),x.shape,type(y),y.shape)
# print(type(x),x.shape)
lr_model.fit(x,y)
a = lr_model.coef_
b = lr_model.intercept_
print("拟合结果 a b", a, b)
# 对新数据3.5进行预测
y_3 = lr_model.predict([[3.5]])
#print(y_3)
#print(y)
# 模型均方误差评估
y_predict = lr_model.predict(x)
#print("y_predict", y_predict)
# MSE越小越好,R2越接近1越好
MSE = mean_squared_error(y,y_predict)
R2 = r2_score(y,y_predict)
print("MSE R2", MSE, R2)
plt.figure()
plt.plot(y, y_predict)
plt.show()

在这里插入图片描述


http://www.ppmy.cn/news/10274.html

相关文章

Java中indexOf函数详解

1.定义 Java String 类的 indexOf() 方法返回指定字符串中指定字符或字符串第一次出现的位置。 String 类的 indexOf() 方法在字符串中查找子字符串出现的位置,如果存在返回字符串出现的位置(第一位为0),如果不存在返回 -1&#x…

Java 如何不使用 volatile 和锁实现共享变量的同步操作

前言 熟悉 Java 并发编程的都知道,JMM(Java 内存模型) 中的 happen-before(简称 hb)规则,该规则定义了 Java 多线程操作的有序性和可见性,防止了编译器重排序对程序结果的影响。 按照官方的说法: 当一个变量被多个线程读取并且至…

xv6 - lab0 - Introduction

MIT 6.S081 课程介绍 1 说明背景 1.1 课程概述 核心理念:边做边学目录描述:操作系统的设计与实现,将用于系统编程的基础。主题包括:虚拟内存、文件系统、多线程、上下文切换、内核、中断、系统调4)用、进程间通信、…

STM32MP157驱动开发——Linux DAC驱动

STM32MP157驱动开发——Linux DAC驱动0.前言一、DAC 简介二、驱动源码分析1.设备树下的 DAC 节点2.驱动源码分析1)stm32_dac 结构体2)stm32_adc_probe 函数3)stm32_dac_iio_info 结构体三、驱动开发1.修改设备树2.使能DAC驱动四、 运行测试0.…

Spring Boot学习篇(八)

Spring Boot学习篇(八) 1.thymeleaf模板引擎使用篇(二) 1.1 配置通过地址栏直接访问html页面 1.1.1 在zlz包下创建filter包,其目录结构如下所示 1.1.2 在filter包下创建HTMLFilter类,其内容如下所示 package com.zlz.filter;import javax.servlet.*; import javax.servlet.…

创建List保存学生信息

1 问题创建一个存储学生对象的集合,存储3个学生对象,使用程序实现在控制台遍历该集合。2 方法1、定义学生类2、创建List集合对象3、创建学生对象4、将学生添加到集合5、遍历集合创建的学生类代码:package no10;public class Student { …

Linux中的哈希表:基于双链表的内核模块

1. 前言Linux内核中选取双向链表作为其基本的数据结构,并将其嵌入到其他的数据结构中,使得其他的数据结构不必再一一实现其各自的双链表结构。实现了双链表结构的统一,同时可以演化出其他复杂数据结构。本文对linux中基于双链表实现的哈希表进…

一体化Ethercat通信伺服电机在汇川H5U PLC上的应用案例介绍(下)

内容介绍了一体化低压伺服Ethercat通信的电机在汇川H5UPLC上的使用,一体化Ethercat通信伺服电机在汇川H5U PLC上的应用案例介绍(上)主要讲解环境的搭建以及使用AutoShop软件的在线调试功能,简单控制电机位置、速度模式运行。那么本篇我们就来讲解下使用汇…