はじめに
np.polyfit, scipy.optimizeのcurve_fit, lmfitによる線形近似の実行速度の比較をmatplotlibのエラーバー付き棒グラフで表示する。
コード
data:image/s3,"s3://crabby-images/bd021/bd0218ca07032a6216f64f0540a9332ec6fd0745" alt=""
解説
モジュールのインポート
バージョン
データの作成
np.arange(0,10,1)で0から9の1刻みの配列を作成して、yのdataにnp.random.rand(10)でばらつきを付与する。
numpyのpolyfitの場合
np.polyfit(x,y,1)で1次の式でのフィッティングの係数を求める。具体的にはy=ax+bのaとbがこれでもとまる。
np.polyval(pf,x)で係数pfを使った1次の式のyのdataを生成する。
データと近似式を表示すると下図のようになる。
data:image/s3,"s3://crabby-images/3353d/3353d96f446740aad833ea5df08ab902251b915d" alt=""
numpy polyfitの実行時間の計測
%timeitで実行時間を計測する。
scipyのcurve_fitの場合
関数を定義して、curve_fitに関数とデータと初期値を渡すことで、係数が求まる。np.polyval(popt,x)で係数poptを使った1次の式のyのdataを生成する。
データと近似式を表示すると下図のようになる。
data:image/s3,"s3://crabby-images/c5f36/c5f361e1196d2a31b142ac795962962fa0f6eb0a" alt=""
なお、決定係数の求め方については下記記事で解説した。
data:image/s3,"s3://crabby-images/ff249/ff249f26453d8b60db36363e11e1478321d29dca" alt=""
[SciPy] 1. Scipyのcurve_fitで最小2乗法近似、決定係数R2も求める
Scipyのcurve_fitの使い方と決定係数R2の求め方について説明する。
scipy curve_fitの実行時間の計測
%timeitで実行時間を計測する。
lmfitの場合
lmfitは非線形近似の高レベルなインターフェイスであり、詳細な情報を得ることができる。condaでインストールする場合は、下記のようになる。
conda install -c conda-forge lmfit
基本的な使い方はcurve_fitと同じであり、modelを定義して、初期値とデータを渡して近似を行う。近似データはresult.best_fitで得ることができる。
データと近似式を表示すると下図のようになる。
data:image/s3,"s3://crabby-images/e9cbf/e9cbf22cbddcf19ec403c695f3d3a40d7314738f" alt=""
lmfitの実行時間の計測
%timeitで実行時間を計測する。
実行時間の比較
polyfitが最速で、curve_fit, lmfitの順で実行時間が長い。
data:image/s3,"s3://crabby-images/bd021/bd0218ca07032a6216f64f0540a9332ec6fd0745" alt=""
参考
numpy.polyfit — NumPy v2.2 Manual
numpy.polyval — NumPy v2.2 Manual
curve_fit — SciPy v1.15.1 Manual
Non-Linear Least-Squares Minimization and Curve-Fitting for Python — Non-Linear Least-Squares Minimization and Curve-Fitting for Python
コメント