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

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

新規登録して質問してみよう
ただいま回答率
85.46%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

1回答

1869閲覧

[c言語]点群からラグランジュ補間してy=0の時のxを推定したい

oinari03

総合スコア59

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

0グッド

0クリップ

投稿2020/10/21 15:03

編集2020/10/21 15:22

やりたいこと

ラグランジュの補間を使って以下の点群からy=0の時のxの値を推定したい

double px[] = {1.0,1.3,1.6,2.0}; double py[] = {-0.403,-0.158,0.896,1.513};

pxがx座標,pyがy座標

やったこと

yを推定することはできた。
以下にx=0.0の時のyの推定をしたプログラムを書きます。

double lagrange(double *px, double *py, int N, double x) { // P double y =0.0; for (int k=0; k < N; k++) { // L double l_k = 1.0; for (int j=0; j< N; j++) { if (k == j) continue; l_k *= (x - px[j]) / (px[k] - px[j]); } y += py[k] * l_k; printf("l_k[%d] = %1f\n", k, l_k); } return y; } int main(void) { double px[] = {1.0,1.3,1.6,2.0}; double py[] = {-0.403,-0.158,0.896,1.513}; double N = sizeof(px) / sizeof(px[0]); double x = 0.0; printf("x=%.15f,y=%.15f",x,lagrange(px, py, N, x)); return 0; }

これである程度yの推定はできました。

お願いしたいこと

上記のコードからy=0の時のxの値を推定するようなアドバイスを頂けないでしょうか?
どうかアドバイスだけでもお願いします。
逆がわかりません。
yに値を与えた時にもxを推定する動作するようにしたいです。

どうかよろしくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

px,pyふくめたx,yを変えただけでした。

double lagrange(double *px, double *py, int N, double y) { // P double x =0.0; for (int k=0; k < N; k++) { // L double l_k = 1.0; for (int j=0; j< N; j++) { if (k == j) continue; l_k *= (y - py[j]) / (py[k] - py[j]); } x += px[k] * l_k; printf("l_k[%d] = %1f\n", k, l_k); } return x; } int main(void) { double px[] = {1.0,1.3,1.6,2.0}; double py[] = {-0.403,-0.158,0.896,1.513}; double N = sizeof(px) / sizeof(px[0]); double y = 0.0; printf("y=%.1f,x=%.15f",y,lagrange(px, py, N, y)); return 0; }

投稿2020/10/21 15:35

oinari03

総合スコア59

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問