最小二乘法实际应用:大气二氧化碳浓度数据拟合
创作时间:
作者:
@小白创作中心
最小二乘法实际应用:大气二氧化碳浓度数据拟合
引用
CSDN
1.
https://m.blog.csdn.net/qq_50930131/article/details/144274004
最小二乘法是一种数学优化技术,它通过最小化误差的平方和寻找数据的最佳函数匹配。这种方法广泛应用于回归分析中,特别是在线性回归模型中。本文将通过一个实际案例,演示如何使用最小二乘法拟合大气二氧化碳浓度数据。
使用最小二乘法拟合大气二氧化碳浓度数据。数据保存在monthly_co2.xls文件中(只截取部分)。
Python需要安装的库
- xlrd
- numpy
- pandas
- matplotlib
绘制图像代码(绘制整体数据趋势图)
# -*- coding: utf-8 -*-
"""
@File : 绘制趋势图.py
@Time : 2024/11/27 23:52:44
@Version :
@Desc :
"""
"""
@Python version : 3.8.7
@matplotlib version : 3.5.1
@pandas version : 1.4.2
@numpy version : 1.22.3
"""
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from matplotlib.ticker import MultipleLocator #从ticker中导入MultipleLocator类
df = pd.read_excel(io="./monthly_co2.xls", header=2) # 数据在第一个sheet中
# 删除索引为0的行
df.drop(index=0, inplace=True) # 删除第三行数据 直接在原始dataframe上修改
df.replace(-99.99, np.nan, inplace=True) # 处理缺失值
df.dropna(inplace=True) # 删除缺失值的行
# df['Year_Month'] = df['Yr'] + (df['Mn'] - 1) / 12 # 将年份和月份转换为小数形式
# [:, 0] 表示选择所有行
df['Year_Month'] = df.iloc[:, 0] + (df.iloc[:, 1] - 1) / 12 # 使用列index索引而不是名称索引
x_vec = df['Year_Month'].values # x
y_vec = df.iloc[:, 2].values # y
# matplotlib字体设置
plt.rcParams['font.family'] = "Times New Roman" # 设置全局字体
# marker='o' 散点图绘制为圆形
# edgecolor='r' 设置圆圈的边缘颜色为红色
custom_color = '#f0a1a8'
plt.scatter(x_vec, y_vec, marker='o', edgecolors=custom_color, facecolors='none', label='Actual Data') # 原始数据
plt.xlabel("Year_Month", fontsize=16)
plt.ylabel("CO2 Concentration [ppm]", fontsize=16)
plt.title("Trend Chart of CO2 Concentration Over Time", fontsize=20) # 二氧化碳浓度随时间变化趋势图
plt.legend(loc='upper left')
# 美化图表
plt.rcParams['axes.facecolor'] = 'lightgray'
plt.rcParams['legend.fontsize'] = 10 # 设置图例字体大小
# 刻度值设置
ax = plt.gca() # 获取当前坐标轴
ax.xaxis.set_major_locator(MultipleLocator(10)) # 设置x轴的主刻度间隔
ax.xaxis.set_minor_locator(MultipleLocator(5)) # 设置x轴的次刻度间隔
ax.yaxis.set_major_locator(MultipleLocator(20)) # 设置y轴的主刻度间隔
ax.yaxis.set_minor_locator(MultipleLocator(10)) # 设置y轴的次刻度间隔
plt.grid(True, color='gray', linestyle='--', linewidth=0.5) # 添加自定义样式网格线
plt.show()
二次函数拟合
# -*- coding: utf-8 -*-
"""
@File : 二次函数拟合结果.py
@Time : 2024/11/28 11:19:38
@Version :
@Desc :
"""
"""
@Python version : 3.8.7
@matplotlib version : 3.5.1
@pandas version : 1.4.2
@numpy version : 1.22.3
"""
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from matplotlib.ticker import MultipleLocator #从ticker中导入MultipleLocator类
df = pd.read_excel(io="./monthly_co2.xls", header=2) # 数据在第一个sheet中

# 删除索引为0的行
df.drop(index=0, inplace=True) # 删除第三行数据 直接在原始dataframe上修改
df.replace(-99.99, np.nan, inplace=True) # 处理缺失值
df.dropna(inplace=True) # 删除缺失值的行
# df['Year_Month'] = df['Yr'] + (df['Mn'] - 1) / 12 # 将年份和月份转换为小数形式
# [:, 0] 表示选择所有行
df['Year_Month'] = df.iloc[:, 0] + (df.iloc[:, 1] - 1) / 12 # 使用列index索引而不是名称索引
x_vec = df['Year_Month'].values # x
y_vec = df.iloc[:, 2].values # y
# 这里添加代码
M = df.shape[0] # 数据点个数
# 方程组的系数矩阵
Phi = np.zeros((M, 3)) # 创建空矩阵
for i in range(M):
Phi[i][0] = 1
Phi[i][1] = x_vec[i]
Phi[i][2] = x_vec[i]**2
# 正规方程组
A = Phi.T @ Phi
b = Phi.T @ y_vec
x = np.linalg.solve(A, b)
print(x)
a_0 = x[0]
a_1 = x[1]
a_2 = x[2]
# f_x = a_2x^2 + a_1x + a_0
varphi_x = lambda x: a_2 * x**2 + a_1 * x + a_0 # 拟合函数
# 可视化图像
y_vec_model = varphi_x(x_vec)
# 均方根误差
RMSE = np.sqrt(np.sum((y_vec - y_vec_model)**2) / M)
print("均方根误差: ", RMSE)
# matplotlib字体设置
plt.rcParams['font.family'] = "Times New Roman" # 设置全局字体
plt.plot(x_vec, y_vec_model-279, label='Fitted Line', color='red')
# marker='o' 散点图绘制为圆形
# edgecolor='r' 设置圆圈的边缘颜色为红色
custom_color = '#f0a1a8'
plt.scatter(x_vec, y_vec-279, marker='o', edgecolors=custom_color, facecolors='none', label='Actual Data') # 原始数据
plt.xlabel("Year_Month", fontsize=16)
plt.ylabel("CO2 Concentration [ppm]", fontsize=16)
plt.title("Trend Chart of CO2 Concentration Over Time", fontsize=20) # 二氧化碳浓度随时间变化趋势图
plt.legend(loc='upper left')
# 美化图表
plt.rcParams['axes.facecolor'] = 'lightgray'
plt.rcParams['legend.fontsize'] = 10 # 设置图例字体大小
# 刻度值设置
ax = plt.gca() # 获取当前坐标轴
ax.xaxis.set_major_locator(MultipleLocator(10)) # 设置x轴的主刻度间隔
ax.xaxis.set_minor_locator(MultipleLocator(5)) # 设置x轴的次刻度间隔
ax.yaxis.set_major_locator(MultipleLocator(20)) # 设置y轴的主刻度间隔
ax.yaxis.set_minor_locator(MultipleLocator(10)) # 设置y轴的次刻度间隔
plt.grid(True, color='gray', linestyle='--', linewidth=0.5) # 添加自定义样式网格线
# 添加RMSE文本信息
# (0.02, 0.85) 以轴的百分比来表示 分别对应x轴和y轴的为转移
plt.text(0.09, 0.95, f"RMSE: {RMSE:.2f}", transform=plt.gca().transAxes, fontsize=18)
plt.show()
程序运行结果:
热门推荐
南昌行政区划大变局:新建区和南昌县崛起
双重威胁:解析游戏中的僵尸恐龙组合
植物合成加神兽养成,<恐龙大战僵尸>重塑经典塔防玩法
塔防新作“恐龙大战僵尸”:融合创新题材与深度策略
四成老年人存在抑郁情绪,如何守护他们的心理健康?
5种头皮按摩法,轻松缓解头耳疼痛
重庆市沙坪坝区人民医院儿科:区域医疗中心的守护者
沙坪坝区人民医院发布冬季防疫指南:科学防护,共筑健康防线
沙坪坝区人民医院开展痴呆健康教育活动,助力全民科学素质提升
离婚后如何找到靠谱的心理咨询?
沈阳房价普跌:和平区跌15%,沈河区跌破万元
交通事故责任划分:从证据收集到赔偿计算的完整指南
沈阳二手房市场:挂牌价虚高,实际成交已跌两成
麻辣烤鱼的做法及配方
椒盐九肚鱼
冬季咳嗽克星:蜂蜜水、梨子、姜茶、鸡汤
中医妙招:告别凌晨咳嗽烦恼
冬季夜间咳嗽加重怎么办?
述职报告助力团队管理:从问题发现到持续改进
一文详解:年终述职报告与工作总结的区别与写法
西藏定日县地震为何造成重大人员伤亡?救援最需要哪些物资?
国家安全生产应急救援队伍——以“演”筑防 以“练”备战
自驾游穷游党必看:床车VS房车,究竟哪种方式能让你笑到最后
广西防城港至云南风情之旅:全方位自驾与自助游攻略指南
家暴不是家务事:报警取证,依法维权
健康的生活方式、合理饮食和充分体育锻炼,可减少约40%癌症发生率与死亡率
哺乳期被辞退可获双倍赔偿,女职工维权有法可依
民法典明确:这些情况下,祖孙有抚养赡养义务
美国大选关键时刻:亚利桑那州、内华达州和宾夕法尼亚州的决战
掌握“2放2不放”,轻松炖出完美排骨汤