线性回归_最小二乘法

news2024/12/28 4:51:57
from numpy import *
import matplotlib.pyplot as plt

1.导入数据

# 1.导入数据
# 模型 y = wx + b
points = genfromtxt('linear_regress_lsm_data.csv', delimiter=',')
N = len(points)
print('point count %d'%N)
x = array(points[:, 0])
y = array(points[:, 1])
plt.scatter(x, y)
plt.show
point count 100





<function matplotlib.pyplot.show(close=None, block=None)>

在这里插入图片描述

2.损失函数

# 2.损失函数
def compute_cost(points, w, b):
    total_cost = 0
    length = len(points)
    for i in range(length):
        x = points[i, 0]
        y = points[i, 1]
        total_cost = (y - w * x - b) ** 2
    return total_cost / float (length)
    

3.训练

# 3.训练
def average(nums):
    sum = 0
    length = len(nums)
    for i in range(length):
        sum += nums[i]
    return sum / float(length)


def fit(points):
    length = len(points)
    x_bar = average(array(points[:, 0]))
    
    sum_y_x = 0
    sum_x_power = 0
    sum_b = 0
    
    # 求 w
    for i in range(length):
        x = points[i, 0]
        y = points[i, 1]
        sum_y_x += y * (x - x_bar)
        sum_x_power += x ** 2
    
    w = sum_y_x / (sum_x_power - x_bar ** 2 * float(length))
    
    # 求 b
    for i in range(length):
        x = points[i, 0]
        y = points[i, 1]
        sum_b += y - w * x
    b = sum_b / float(length)
    return w, b

4.测试

# 4.测试
w, b = fit(points)
print("w is : ", w)
print("b is : ", b)
cost = compute_cost(points, w, b)
print("cost is :", cost)

w is :  1.3224310227553846
b is :  7.991020982269173
cost is : 1.4963859648775966

5.画拟合曲线

# 5. 画拟合曲线
plt.scatter(x, y)
y_predict = w * x + b
plt.plot(x, y_predict, c = 'y')
plt.show
<function matplotlib.pyplot.show(close=None, block=None)>

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2132047.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

超详细超实用!!!零基础java开发之云风笔记笔记列表接口模糊查询(八)

云风网 云风笔记 云风知识库 笔记列表数据接口除了获取全部数据&#xff0c;还需要考虑分页获取/以及各个参数查询获取数据。这样才符合日常需要。 模糊查询一般是定义一个固定的查询参数searchName,查询同数据类型的参数&#xff0c;比如都是字符串数据类型。由于我们名称、类…

网络插件 Cilium 更换 Calico

网络插件 Cilium 更换 Calico 集群使用 submariner &#xff0c;通过网络检测发现 Cilium 插件可能兼容性不太好 subctl diagnose allCilium 彻底卸载 helm uninstall cilium -n kube-system# 检查集群中的所有 CNI 插件&#xff08;集群的每个节点都需要删除&#xff09; s…

ELK在Linux服务器下使用docker快速部署(超详细)

ELK是什么&#xff1f; 首先说说什么是ELK ELK 是一个开源的日志管理和分析平台&#xff0c;由三个主要组件组成&#xff1a; Elasticsearch&#xff1a;一个分布式搜索和分析引擎&#xff0c;能够快速存储、搜索和分析大量数据。它是 ELK 堆栈的核心&#xff0c;负责数据的…

【FOC】【001】Clarke变换--- 2024.9.13

目录 前言背景知识介绍Clarke变换结束语 前言 在电机控制领域&#xff0c;想必大家都听过foc矢量控制&#xff0c;比我们耳熟能详的pid控制效果更好&#xff0c;那具体foc干了哪几件事呢&#xff1f;接下来本栏中会详细的讲解foc的原理。 该栏目部分参考于《慧驱动》 背景知识介…

gin配置swagger文档

一、基本准备工作 1、安装依赖包 go get -u github.com/swaggo/swag/cmd/swag go get -u github.com/swaggo/gin-swagger go get -u github.com/swaggo/files2、在根目录上配置swagger的路由文件 //2.初始化路由router : initialize.Routers()// 配置swaggerdocs.SwaggerInfo…

Redis系列之底层数据结构SDS

Redis系列之底层数据结构SDS 实验的环境 Redis 6.0VSCode 1.88.1 什么是SDS? SDS&#xff1a;Simple Dynamic String&#xff0c;翻译为简单动态字符串。SDS是一种用于存储二进制数据的数据结构&#xff0c;具有动态扩容的特点&#xff0c;代码位于src/sds.h和src/sds.c …

解决“找不到msvcp140.dll无法继续执行代码”问题:技术困境与解决方案

在现代计算机技术的发展中&#xff0c;软件依赖性问题日益凸显&#xff0c;其中“找不到msvcp140.dll无法继续执行代码”错误尤为常见。本文将从技术背景、问题成因、解决方案及预防措施四个方面&#xff0c;深入探讨这一技术困境&#xff0c;旨在为读者提供全面的理解和有效的…

来云栖大会!探展云上开发,沉浸式体验云原生 + AI 新奇玩法

2024 云栖大会来了&#xff01; 本届云栖大会将于 9 月 19 日至 9 月 21 日 在杭州云栖小镇召开 汇集全球最新云计算、AI 硬科技 云栖大会的主论坛将设置三个对话环节&#xff0c;大模型、自动驾驶和机器人领域的领军技术人和明星创业者将分享 AI 前沿趋势和应用进展。 20…

北京网页制作-网站策划

北京网页制作与网站策划 随着互联网的快速发展&#xff0c;网页制作和网站策划逐渐成为企业成功的重要因素。在北京这座现代化的大都市&#xff0c;各行各业都意识到网络的重要性&#xff0c;纷纷投身于网页制作与网站策划的浪潮中。本文将探讨北京网页制作的现状、常见的策划流…

基于Java web技术开发设计的学生信息管理系统

学生信息管理系统&#xff1a;Java Web技术与MySQL数据库的融合应用 包含初始化sql脚本 本毕业设计聚焦于构建一套高效、安全的学生信息管理系统&#xff0c;该系统采用先进的Java Web技术进行开发&#xff0c;并依托MySQL数据库实现数据的高效存储与管理。 背景与挑战&…

超声波清洗机的优势有哪些?四款精品超声波清洗机推荐,闭眼入

在这个快节奏的时代里&#xff0c;清洁和卫生变得尤为重要。对于那些追求精致生活的人们来说&#xff0c;家中配备一台超声波清洗机无疑是一件居家的好选择。本文将为您介绍四款广受好评的超声波清洗机&#xff0c;让您在日常清洗中也能享受到科技带来的便捷与舒适。无论是眼镜…

九、Redis 的实际使用与Redis的设计

一、多级缓存架构 在线上系统中&#xff0c;一定不会单纯的只部署一个Redis集群&#xff0c;而是使用Redis结合其他的多级缓存应用进行架构。 使用多级缓存架构的优点就是可以使不同类型的数据分布在不同的应用中&#xff0c;比如redis的热点key可以存储到nginx本地缓存、服务…

[渗透测试]-CVE-2016-4437-Shiro550漏洞复现

Shiro550漏洞爆出的时间是2016年为第4437个漏洞&#xff0c;所以它的CVE编码是2016-4437 文章目录 前言 什么是Shiro550漏洞&#xff1f; 1.Shiro550漏洞原理&#xff1a; 2.漏洞利用 3.漏洞复现&#xff1a; 前提&#xff1a;下载并打开vulhub靶场。 CVE-2016-4437-shiro550漏…

基于react native的锚点

基于react native的锚点 效果示例图示例代码 效果示例图 示例代码 /* eslint-disable react-native/no-inline-styles */ import React, { useEffect, useRef, useState } from react; import {Image,ImageBackground,ScrollView,StyleSheet,Text,TouchableOpacity,View, } fr…

怎么选到好用的运动耳机?这五款年度精选骨传导耳机非常好用!

在过去的两年里&#xff0c;骨传导耳机逐渐被大众的所熟知。可能毕竟长时间使用音量过大的传统入耳式耳机&#xff0c;多多少少会对我们的听力健康构成威胁。所以很多人就想找一款不伤耳朵的耳机。然后就了解到了骨传导耳机&#xff0c;所以就会延伸出这些问题——骨传导耳机好…

【Canvas与密铺】90年代马赛克密铺效果 1920x1080

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>20世纪90年代马赛克瓷砖效果1920x1080</title><style type&…

美创获评CNVD年度原创漏洞发现贡献单位!

9月10日&#xff0c;第21届中国网络安全年会暨网络安全协同治理分论坛在广州成功举办。会上&#xff0c;美创科技首次获评“CNVD年度原创漏洞发现贡献单位”。 美创科技依托第59号安全实验室&#xff0c;专注数据安全技术和攻防研究。凭借深厚的技术积累与优势&#xff0c;被遴…

SEAFARING靶场渗透

一.SQL注入漏洞 1.输入id1 -- 下方出现数据说明闭合成功 2.测试得出数据库有三列 3.三处都是回显点 4.联合查询爆出库名 5.查表名 ?id-1 union select 1,group_concat(table_name),3 from information_schema.tables where table_schematest-- 6.查字段名 ?id-1 union sele…

vscode spring boot项目编辑yaml不自动提示补全如何解决

文章目录 properties能够自动弹出提示但是YAML文件就不会自动弹出提示ctrl空格不出提示的解决办法 properties能够自动弹出提示 但是YAML文件就不会自动弹出提示 只是不会自动弹出来而已&#xff0c;按ctrl空格即可解决 ctrl空格不出提示的解决办法 如果按ctrl空格没有用 …

WGCLOUD使用指南 - 自动计算磁盘剩余空间的可使用天数

WGCLOUD是一款免费开源的运维监控软件&#xff0c;性能优秀&#xff0c;部署简单&#xff0c;轻巧使用&#xff0c;支持大部分的Linux和Windows、安卓、MacOS等平台安装部署 最近发布的新版本&#xff0c;WGCLOUD新增了可以自动计算每个磁盘剩余空间的可使用天数&#xff0c;主…