
1/(z^2-1) のマクローリン展開と、z = 1 の周りを 0<|z-1|<2 でローラン展開したときの、近似値をチェックするために以下のようにCでコーディングしたのですが、ローラン展開の実部が怪しいです。関数の使い方に誤りがあるのでしょうか? コンパイラは gcc です。
ちなみに、十進BASICでは問題ありませんでした。
z = 0.5 + 0.02i で確認
1/(z^2-1)
-1.33168 -0.0354924i
-1 - z^2 - z^4 - z^6 - z^8
-1.33048 -0.03495i
1/(2*(z-1)) - 1/4 + (z-1)/8 - (z-1)^2/16 + (z-1)^3/32
-1.07262 -0.0366546i
↑がおかしい。
----------------------------------------------------------------
#include <stdio.h>
#include <complex.h>
// 複素数の表示
void cprint(double complex z)
{
//printf("%g% + gi\n", creal(z), cimag(z));
if (cimag(z) < 0)
printf("%g %gi\n", creal(z), cimag(z));
else
printf("%g + %gi\n", creal(z), cimag(z));
}
//FuncO(z) = 1/(z^2-1)
double complex FuncO(double complex z)
{
double complex dmy = 1/(z*z-1);
return dmy;
}
//cpow(x, y) = x^y
//マクローリン展開
//FuncM(z) = -1 - z^2 - z^4 - z^6 - z^8
double complex FuncM(double complex z)
{
double complex dmy = -1 - cpow(z,2) - cpow(z,4) - cpow(z,6) - cpow(z,8);
return dmy;
}
//z=1 (0<|z-1|<2)でローラン展開
//FuncR(z) = 1/(2*(z-1)) - 1/4 + (z-1)/8 - (z-1)^2/16 + (z-1)^3/32
double complex FuncR(double complex z)
{
double complex dmy = 1/(2*(z-1)) - 1/4 + (z-1)/8 - cpow(z-1,2)/16 - cpow(z-1,3)/32;
//double complex dmy = 1/(2*(z-1)) - 1/4 + (z-1)/8 - (z-1)*(z-1)/16 - (z-1)*(z-1)*(z-1)/32;
//としてもいっしょ
return dmy;
}
int main(void)
{
double complex a = 0.5 + 0.02 * I;
printf("1/(z^2-1)\n");
cprint(FuncO(a));
printf("-1 - z^2 - z^4 - z^6 - z^8\n");
cprint(FuncM(a));
printf("1/(2*(z-1)) - 1/4 + (z-1)/8 - (z-1)^2/16 + (z-1)^3/32\n");
cprint(FuncR(a));
return 0;
}

No.2ベストアンサー
- 回答日時:
ローラン展開についてはわかりませんが、
double complex dmy = 1/(2*(z-1)) - 1/4 + (z-1)/8 - cpow(z-1,2)/16 - cpow(z-1,3)/32;
を
double complex dmy = 1.0/(2.0*(z-1.0)) - 1.0/4.0 + (z-1.0)/8.0 - cpow(z-1.0,2.0)/16.0 - cpow(z-1.0,3.0)/32.0;
にしてみてください。
結果が
-1.07262 -0.0366546i
から
-1.32262 -0.0366546i
になります。
No.3
- 回答日時:
試してみようと手で打っていて気付いた. 1/4 って 0 じゃん....
なお「ローラン展開」の「ローラン」は Laurent だね.
No.1
- 回答日時:
^はべき乗じゃなくて、排他的論理和演算子かと。
回答ありがとうございます。
> ^はべき乗じゃなくて、排他的論理和演算子かと。
いや、それは表示用です。プログラムでのべき乗は複素数専用の cpow を使っています。
ローラン展開の数式は
1/(2(z-1)) - 1/4 + (z-1)/8 - (z-1)^2/16 + (z-1)^3/32
なので、プログラムでは
double complex dmy
= 1/(2*(z-1)) - 1/4 + (z-1)/8 - cpow(z-1,2)/16 - cpow(z-1,3)/32;
したのですけれど、期待された結果が出ないので、この使い方に問題はないのかということをお聞きしたいのです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
c言語で、繰り返し文の中で、0....
-
doubleの変数にintとintの割り...
-
数値を指数部と仮数部に分離したい
-
^この記号を使わない
-
C言語でsqrt(a^2+b^2)のテーブ...
-
doubleは常に%lfとするべきなのか
-
至急です! マクロ定義で #defi...
-
C 開放してるのにエラー(doubl...
-
最早開始時間と最遅完了時刻を...
-
【C++】関数ポインタの使い方
-
既定のコンストラクタがありま...
-
Aの値からBの値を除するとは??
-
「Aに対するBの割合」と「Aに対...
-
信頼区間の1.96や1.65ってどこ...
-
a^2の√=a が成り立たない場合
-
VB6.0での小数点の扱いについて
-
配列をnビットシフトする
-
数学 一次関数 関数 y=-3/4x+k(...
-
c languageで 簡単な質問があ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
C 開放してるのにエラー(doubl...
-
c言語で、繰り返し文の中で、0....
-
doubleの変数にintとintの割り...
-
至急です! マクロ定義で #defi...
-
C言語 関数プロトタイプ宣言の...
-
浮動小数点の定数
-
DWORDの警告
-
C言語の型による処理速度の違い
-
C言語で台形公式を使った二重積...
-
C言語を実行すると-infが出てき...
-
int とdoubleの比較
-
C言語初心者 構造体 課題について
-
たくさんの数の平均を求める方...
-
EXE1→DLL→EXE2数値を受け渡す方法
-
プログラミングでのテイラー展開
-
C++初心者です。簡単なスコア計...
-
【C言語】二階微分方程式をル...
-
fgets()による繰り返し入力(c言語)
-
2分法で方程式の複数の解を自...
おすすめ情報
> double complex dmy = 1/(2*(z-1)) - 1/4 + (z-1)/8 - cpow(z-1,2)/16 - cpow(z-1,3)/32;
第5項が負になっていました。
double complex dmy = 1/(2*(z-1)) - 1/4 + (z-1)/8 - cpow(z-1,2)/16 + cpow(z-1,3)/32;
が正しいです。結果も少し違いますが、実部はやはりおかしいです。
1/(2*(z-1)) - 1/4 + (z-1)/8 - (z-1)^2/16 + (z-1)^3/32
-1.08039 -0.0357176i