Please note that the recommended version of Scilab is 2024.1.0. This page might be outdated.
See the recommended documentation of this function
intg
定積分
呼び出し手順
[v, err [,ierr]]=intg(a, b, f [,ea [,er]])
引数
- a, b
実数
- f
外部 (関数またはリストまたは文字列)
- ea, er
実数
- ea
結果に指定する絶対誤. デフォルト値: 1.d-14.
- er
結果に指定する相対誤差. デフォルト値: 1.d-8.
- err
結果に関する絶対誤差の推定値.
- ierr
エラーフラグ番号(エラーが発生しなかった場合は 0).
説明
intg(a,b,f)
は,
f(t)dt
の
a
から b
までの
定積分を計算します.
関数 f(t)
は連続である必要があります.
この計算は以下の精度を満たすことが期待されます:
abs(I-v)<= max(ea,er*abs(I))
ただし
I
はこの積分の真値を意味します.
f
は以下のような外部ルーチンです :
f
が関数の場合,
y = f(t)
のように定義されている必要があります.
f
がリストの場合,
このリストは以下のようである必要があります:
list(f,x1,x2,...)
ただし f
は呼び出し手順が f(t,x1,x2,...)
の関数です.
f
が文字列の場合,
以下の規定の呼出し手順を有する
Fortran関数またはCプロシージャの名前を指しています:
Fortran の場合, 呼出し手順は
double precision function f(x)
とします.
ただし, x
も倍精度実数となります.
Cの場合, 呼出し手順は double
f(double *x)
とします.
既知の制限
他の積分ルーチンと同様に intg
は
スパイク欠損の制約を受けます.
スパイクを有するフラットな関数は, スパイクが十分にスティフな場合には完全にフラットな関数に見えます.
これは回避できず,積分処理の動作をよく知ることが必要です.
つまり, intg
は 21点 Gauss-Kronrod法を
使用します.
このため, 2つの連続する積分点の間にスパイクがある場合,
検出されず, この関数はスムーズであるとみなされます.
しかし, 関数が非常にスムースな場合には警告メッセージが発行されます. この際,ユーザは積分区間を減らすよう提案されており, スパイクを見失っていないかを検討する必要があります.
以下のグラフがこの現象を図示しています.
9番目と10番目の積分点の間に,検出されないスパイクがあり,
intg
はこの関数をフラットであるとみなします.
次の図では, スパイクは十分に大きく,
積分点によりカバーされます.
ソルバがエラーを発生した場合でも,
ユーザが計算された回を表示しようとすると,
3番目の出力引数ierr
を追加する必要があり,
これによりエラーを警告に変換します.
これは主に丸め誤差の場合に使用されます.
例
//Scilabで記述された外部関数 function y=f(x),y=x*sin(30*x)/sqrt(1-((x/(2*%pi))^2)),endfunction exact=-2.5432596188; I=intg(0,2*%pi,f) abs(exact-I) //1つの引数を有するScilabで記述された関数 function y=f1(x, w),y=x*sin(w*x)/sqrt(1-((x/(2*%pi))^2)),endfunction I=intg(0,2*%pi,list(f1,30)) abs(exact-I) // Fortranで記述された外部関数 (Fortranコンパイラが必要) // Fortranコードの記述 cd TMPDIR; F=[' double precision function ffun(x)' ' double precision x,pi' ' pi=3.14159265358979312d+0' ' ffun=x*sin(30.0d+0*x)/sqrt(1.0d+0-(x/(2.0d+0*pi))**2)' ' return' ' end']; mputl(F,fullfile(TMPDIR,'ffun.f')) // Fortranコードをコンパイル l=ilib_for_link('ffun',fullfile(TMPDIR,'ffun.f'),[],'f'); // インクリメンタルリンクの実行 link(l,'ffun','f') // 関数の積分 I=intg(0,2*%pi,'ffun') abs(exact-I) // Cで記述された外部関数 (Cコンパイラが必要) // Cコードの記述 C=['#include <math.h>' 'double cfun(double *x)' '{' ' double y,pi=3.14159265358979312;' ' y=*x/(2.0e0*pi);' ' return *x*sin(30.0e0**x)/sqrt(1.0e0-y*y);' '}']; mputl(C,fullfile(TMPDIR,'cfun.c')) // Cコードをコンパイル l=ilib_for_link('cfun',fullfile(TMPDIR,'cfun.c'),[],'c'); // インクリメンタルリンクの実行 link(l,'cfun','c') // 関数の積分 I=intg(0,2*%pi,'cfun') abs(exact-I)
参照
使用される関数
関連するルーチンは SCI/modules/differential_equations/src/fortran ディレクトリにあります :
quadpackのdqags.f および dqagse.f
Report an issue | ||
<< integrate | Differential Equations, Integration | intl >> |