網(wǎng)站首頁 編程語言 正文
一、背景描述
在一個普通的摸魚早晨,群里居然出現(xiàn)了一個不合時(shí)宜頗為突兀的正經(jīng)問題,原來是一個博士同學(xué)需要対實(shí)驗(yàn)數(shù)據(jù)進(jìn)行曲線擬合并且批量計(jì)算出多項(xiàng)式方程
一般來說,這種問題對于經(jīng)常做實(shí)驗(yàn)的同學(xué)來說并不陌生,通常使用MATLAB或者Origin Pro這類專業(yè)的數(shù)據(jù)計(jì)算軟件,甚至Excel也可以實(shí)現(xiàn).
但是作為程序員肯定第一想到的還是使用強(qiáng)大的Python來實(shí)現(xiàn),但是因?yàn)楸救酥饕鰆ava開發(fā),python知之甚少,但也知道python強(qiáng)大在各種現(xiàn)成的類庫,所以實(shí)現(xiàn)估計(jì)并不難,按我們就上手試試?
再來一張圖更直觀的表述下,博士同學(xué)就是有多組實(shí)驗(yàn)數(shù)據(jù),可以分布在坐標(biāo)系,例如圖中的各個散點(diǎn),而他想做的就是將散點(diǎn)擬合為一條曲線,獲得曲線的方程式,從而可以通過輸入其他x坐標(biāo)的值預(yù)測結(jié)果數(shù)據(jù).這在非常多的地方都有極大的用處
二、前期準(zhǔn)備
在開始前還是需要対一些基本概念和類庫進(jìn)行了解和介紹,因?yàn)椴⒉皇菍I(yè)做研究的,所以對于以下名詞只做簡單的描述,達(dá)到理解并且可以使用的目的即可
最小二乘法
最小二乘法(又稱最小平方法)是一種數(shù)學(xué)優(yōu)化技術(shù)。它通過最小化誤差的平方和尋找數(shù)據(jù)的最佳函數(shù)匹配。利用最小二乘法可以簡便地求得未知的數(shù)據(jù),并使得這些求得的數(shù)據(jù)與實(shí)際數(shù)據(jù)之間誤差的平方和為最小
最小二乘法是解決曲線擬合問題最常用的方法。
其基本思路是:事先選定的一組線性無關(guān)的函數(shù), 是待定系數(shù) ,擬合準(zhǔn)則是使實(shí)驗(yàn)數(shù)據(jù)(笛卡爾坐標(biāo)系的坐標(biāo)數(shù)據(jù))與待擬合曲線的距離的平方和最小,稱為最小二乘準(zhǔn)則.
總結(jié)來說,我們通常就是使用最小二乘法來做曲線擬合,通過計(jì)算最小值來獲得多項(xiàng)式的系數(shù)與誤差數(shù)值.
(關(guān)于最小二乘法的原理大家可以自行了解,甚至可以讓你重新感知到數(shù)學(xué)邏輯之美)
Python類庫
NumPy
NumPy 是一個 Python 包。 它代表 “Numeric Python”。 它是一個由多維數(shù)組對象和用于處理數(shù)組的例程集合組成的庫。支持大量的維度數(shù)組與矩陣運(yùn)算,此外也針對數(shù)組運(yùn)算提供大量的數(shù)學(xué)函數(shù)庫。
Matplotlib
Matplotlib 是 Python 的繪圖庫。 它可與 NumPy 一起使用,提供了一種有效的 MatLab 開源替代方案。
三、代碼實(shí)現(xiàn)
這里我們舉一個例子來展示下,相信下面這道數(shù)學(xué)題大家一定不陌生.
某公司為合理定價(jià),在試銷期間得到單價(jià)x(單位:元)與銷售量y(單位:件)的數(shù)據(jù)如表:
單價(jià)(x) 80 82 84 86 88 90
銷量(y) 90 84 83 80 75 68
如果換做之前,我們肯定就熟練的直接開始列方程解未知數(shù)了,但是現(xiàn)在我已經(jīng)失去了這項(xiàng)能力,那么不妨使用我們準(zhǔn)備好的擬合曲線讓程序來幫我們計(jì)算下.
話不多說,直接上代碼
import matplotlib.pyplot as plt
import numpy as np
# 準(zhǔn)備數(shù)據(jù),將(x,y)坐標(biāo)點(diǎn)進(jìn)行輸入
x = np.arange(80, 92, 2) # x = 80,82,84,86,88,90
y = np.array([90, 84, 83, 80, 75, 68])
# 使用polyfit方法來擬合,并選擇多項(xiàng)式,這里先使用2次方程
z1 = np.polyfit(x, y, 2)
# 使用poly1d方法獲得多項(xiàng)式系數(shù),按照階數(shù)由高到低排列
p1 = np.poly1d(z1)
# 在屏幕上打印擬合多項(xiàng)式
print(p1)
# 求對應(yīng)x的各項(xiàng)擬合函數(shù)值
fx = p1(x)
# 繪制坐標(biāo)系散點(diǎn)數(shù)據(jù)及擬合曲線圖
plot1 = plt.plot(x, y, '*', label='origin data')
plot2 = plt.plot(x, fx, 'r', label='polyfit data')
plt.xlabel('x-price')
plt.ylabel('y-amount')
plt.legend(loc=4) # 指定legend的位置,類似象限的位置
plt.title('polyfit')
plt.show()
plt.savefig('polyfit.png')
代碼其實(shí)比較簡單,輸入坐標(biāo)數(shù)據(jù),使用polyfit擬合曲線,輸出方程并且將圖標(biāo)畫出來,我們來執(zhí)行下看看結(jié)果如何
左邊那個就是擬合出來的二次方程,因?yàn)楦袷絾栴},2次方在上面一行,大家能看懂就行,右邊就是這個曲線的圖,但是可以看出曲線并不能非常好的貼合散點(diǎn)數(shù)據(jù)
這里我們將多項(xiàng)式改為3次方式再試一下
z1 = np.polyfit(x, y, 3)
再試一下
可以看出三次方程對于數(shù)據(jù)的貼合度還是比較好的,而如何選擇合適的多項(xiàng)式,或者其他類型函數(shù),比如指數(shù)函數(shù),冪函數(shù)等就需要人自己的合理選擇了.
好了,文章就到這里了,在python強(qiáng)大類庫的幫助下,總體還是比較簡單的
總結(jié)
原文鏈接:https://blog.csdn.net/Roy_70/article/details/123853693
相關(guān)推薦
- 2022-12-15 C++進(jìn)程鏈接工具之通信器詳解_C 語言
- 2022-07-08 Python?3.x對.CSV數(shù)據(jù)按任意行、列讀取的過程_python
- 2022-08-05 Redis實(shí)現(xiàn)短信驗(yàn)證碼登錄的示例代碼_Redis
- 2022-05-23 python列表排序用?sort()和sorted()的區(qū)別_python
- 2022-07-31 pycharm終端解釋器與Python解釋器配置_python
- 2022-08-02 C#中的延時(shí)函數(shù)sleep_C#教程
- 2022-05-01 oracle刪除超過N天數(shù)據(jù)腳本的方法_oracle
- 2022-08-27 C#過濾sql特殊字符串的方法_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支