質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

1908閲覧

二次曲線によるフィッティング

hamberger

総合スコア24

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/06/28 05:21

編集2020/06/28 06:41

与えられたデータについて2次曲線ax^2 +bでフィッティングしたいのですが、(一次の部分はなし)何か方法はないでしょうか。polyfitではできないようです。

皆様ありがとうございました。最小二乗法を手で解いてきました。以下のコードでです。大変お世話になりました。

# x, yはarray. A, Bはy = A*x**2 + Bの値 n = len(x) A = ( -n*np.dot(x**2,y)+ np.sum(y)*np.sum(x**2) )/( (np.sum(x**2))**2 - n*np.sum(x**4) ) B = ( -np.sum(x**2)*np.dot(x**2,y) + np.sum(x**4)*np.sum(y) )/( n*np.sum(x**4) - (np.sum(x**2))**2.0 )

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

やり方

イメージ説明

最小二乗法は sklearn.linear_model.LinearRegression または numpy.linalg.lstsq を使う。

参考

サンプルコード

python

1import matplotlib.pyplot as plt 2import numpy as np 3from sklearn.linear_model import LinearRegression 4 5np.random.seed(0) 6 7a, b = 1.2, 2 # 真のパラメータ 8 9 10def make_dataset(n, noise=False): 11 x = np.linspace(-3, 3, n) 12 y = a * x ** 2 + b 13 if noise: 14 y += np.random.normal(0, 0.5, n) 15 16 return x, y 17 18 19# 訓練集合を作成する。 20x_train, y_train = make_dataset(10, noise=True) 21x, y = make_dataset(100) 22 23 24def to_polynominal_feature(x): 25 return np.column_stack([x ** 2, x ** 0]) # [x^2, 1] 26 27 28X_train = to_polynominal_feature(x_train) 29X = to_polynominal_feature(x) 30 31model = LinearRegression(fit_intercept=False).fit(X_train, y_train) 32 33# 最小二乗法の解 34a_sol, b_sol = model.coef_ 35 36# 近似した曲線 37y_pred = model.predict(X) 38 39# 描画する。 40fig, ax = plt.subplots() 41 42ax.scatter(x_train, y_train, s=50, fc="none", ec="b", label="train") 43ax.plot(x, y_pred, "r", label=fr"${a_sol:.2f} x^2 + {b_sol:.2f}$") 44ax.plot(x, y, "g", label=fr"${a:.2f} x^2 + {b:.2f}$") 45ax.legend() 46ax.grid() 47 48plt.show()

イメージ説明

投稿2020/06/28 06:26

編集2020/06/28 06:28
tiitoi

総合スコア21956

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

手元のデータがどういうものなのかがわからないので方針だけ記載しておきます。

1.手元のxを使ってxの二乗をあらかじめ計算しておく。
2.xの二乗を単回帰のにおけるx、手元のyを目的変数とみなして回帰モデルとして重みと係数を学習

polyfitでもパラメータの指定や多少の工夫でもできた記憶があります。とりあえず、実装してみてうまくいかない点をあらためて質問していただけるといいかと思います。

投稿2020/06/28 06:26

R.Shigemori

総合スコア3376

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問