(1)「電気・電子工学のための数値計算法入門」橋本修著 総合電子出版社
(2)「ディジタル信号処理技術」玉井徳みち、長島厚、藤田泰弘、若井修造著 日経BP社
(3)「よくわかる有限要素法」福森栄次著 Ohmsha
http://szksrv.isc.chubu.ac.jp/java/physics/rlc/rlc0.html
http://www.asahi-net.or.jp/~jk2m-mrt/kiso_RLC.htm
http://ja.wikipedia.org/wiki/%E4%B8%89%E8%A7%92%E9%96%A2%E6%95%B0
http://www.cmplx.cse.nagoya-u.ac.jp/~furuhashi/education/CircuitMaker/chap1.pdf
http://www.akita-nct.ac.jp/~yamamoto/lecture/2003/5E/lecture_5E/diff_eq/node2.html
http://chemeng.on.coocan.jp/cemath/cemath08.html
http://homepage3.nifty.com/skomo/f6/hp6_3.htm
http://homepage1.nifty.com/gfk/rungekutta.htm
(a) 微分の説明
微分方程式の解を求める
(b) 微分方程式の解を数値計算で求める
(c) 積分の説明
(d) 関数が微分の形の形で表されているときの積分値を求める
(一般的に数値積分をする意味は、関数自体が変化の式(例えば速度の関数)などで表されているとき
ある時刻から時刻までの距離を求めたいときなどで使用される。
もちろんその変化の式が、手計算によって計算可能ならば積分によって時間と距離の関係を導出し
その時間を入れることで直接距離を導いたほうが早い。
しかし、一般的に時間と距離の関係のような式自体が導出することが不可能な場合が世の中には多く
時間と速度の関係のような変化の式を見つけ出すことの方が容易なのだが、これを手計算で積分すること
は非常に難しいため数値積分が提案された)
ここでは積分を台形法とシンプソン法を用いてプログラムで計算してみます。
台形法は、一つの区間だけを考えます。
シンプソン法は、二つの区間を考えます。
区間[a,b]で連続な関数を等間隔にn分割して、その分割点を
(1-1)
としたとき、その関数曲線上の点
(1-2)
を通る曲線の方程式を近似式で表したもの
(1-3)
ここでいま、区間[a,b]内の一つの区間を考えて、
その区間と
の2点を結ぶ直線の方程式を(1-3)式から求めると
(1-4)
これにより、区間の積分値は、
いま、
とすると、
(1-5)
になるので、
これを一区間ではなく、区間[a,b]にまで拡張します。
すると区間[a,b]を等間隔にn分割すると、
ここで
区間,
,
,
,
の各微小台形の面積の総和は、
(1-6)
となります。
#include "stdafx.h" #include<iostream> #include<fstream> #include<io.h> float f(float x); int _tmain(int argc, _TCHAR* argv[]) { errno_t err; FILE *fp_output; float a=1.0; float b=3.0; float ans=0; if( err = fopen_s(&fp_output,"data_sekibun.txt","w") != 0){ exit(2);} //printf("微小区間を代入してください\n"); //printf("h << 0の値です\n"); //scanf("%f",&h); //%fはfloatでないといけない //printf("h=%f\n",h); //rewind(stdin); //分割数を1から200まで分割する for(int n=1;n<=200;n++){ float h = (b-a)/(float)n; ans=0; for(int i=1;i<=n;i++){ ans=ans+f(a+(i-1)*h)+f(a+(i*h)); } ans=h/2*ans; fprintf_s(fp_output,"%f %f\n",h,ans); } if(fp_output != NULL) fclose(fp_output); getchar(); return 0; } float f(float x){ float y; y=3.0*(x*x) + 10; return y; }
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % 3.3 数値積分 % written by embedded.samurai %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% echo off clear all close all load 'data_sekibun.txt' % comp1には行 comp2には列が入る [comp1 comp2]=size(data_sekibun); hi=data_sekibun(:,1); iti=ones(size(hi)); sekibun_real=iti.*46.0; sekibun_daikei=data_sekibun(:,2); semilogx(hi,sekibun_real,'r-','linewidth',3); hold on semilogx(hi,sekibun_daikei,'m+-','linewidth',2); hold on grid on xlabel('微小区間(h)','Fontsize',18) ylabel('積分値','Fontsize',18) h=legend('積分(理論)',..., '積分(台形法)',..., 2); set(h,'FontSize',18) axis([0.01 2.0 45 50]); h=gca get(h) set(h,'LineWidth',2,..., 'FontSize',18) print -djpeg suuti_sekibun_daikei.jpg