ラザフォードの散乱のプログラミングを書いているのですが、コンパイルエラーへの対処がわからないです。
先ほども質問しました。回答ありがとうございます。
回答を頼りにプログラミングを書き直してみましたが、
30行目で「invalid operands to binary expression ('double ()' and 'double')」
41行目で「non-object type 'double (double, double)' is not assignable」
43行目で「returning 'double (double, double)' from a function with incompatible result type 'double'」
50行目で「non-object type 'double ()' is not assignable」
というようなエラーが出ました。
特に、「double(double , double )」の意味が分からないです。
何度も質問して申し訳ございません。よろしくお願いします。
C
1#include <stdio.h> 2#include <math.h> 3 4 5double x=-2000.00, b=2000.00,y={10.00}; //yの初期値 6double n=4000,t,vy,q=5.30*2,Y,X; 7 8 9 10 11 12double g(double u,double o); 13double vx(); 14 15int main() { 16 double i; 17 double h=(b-x)/n; 18 19 for(i = 0 ; i <=n ; i++) 20 { 21 double k1,k2,k3,k4; 22 23 t+=h; 24 k1 = g(t,vy); 25 k2 = g(t+h*0.5,vy+k1*0.5); 26 k3 = g(t+h*0.5,vy+k2*0.5); 27 k4 = g(t+h,vy+k3); 28 vy = vy + (k1+2.0*k2+2.0*k3+k4)/6.0; 29 Y=y+vy*t; 30 X=x+vx*t; 31 printf("%2f %f %f\n",t,X,Y); 32 33 return 0; 34 } 35} 36 37double g(double u,double o){ 38 double z=79,m=3.141592,e=8.854*pow(10,-12),r=sqrt(pow(u,2)+pow(o,2)); 39 double ma=6.664*pow(10,-27); 40 41 g =2*z*z*o/(4*m*e*ma*pow(sqrt(pow(u,2)+pow(o,2)),3)); 42 43 return(g); 44} 45 46double vx(){ 47 double ma=6.664*pow(10,-27); 48 double M=q/ma; 49 50 vx=pow(M,0.5); 51} 52
回答1件
あなたの回答
tips
プレビュー