| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 724 人关注过本帖
标题:关于经典龙格库塔法的源程序
只看楼主 加入收藏
aixiaoxin810
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2011-10-3
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:1 
关于经典龙格库塔法的源程序
这个程序是龙格库塔法 4阶乘的源程序  小弟实在是看不明白
void rk(t,y,n,h,k,z,f)
void (*f)();
int n,k;
double t,h,y[],z[];
{
    int i,j,l;
    double a[4],tt,*b,*d;
    b=malloc(n*sizeof(double));
    d=malloc(n*sizeof(double));
    a[0]=h/2.0;a[1]=a[0];
    a[2]=h;a[3]=h;
    for (i=0;i<=n-1;i++) z[i*k]=y[i];
    for (l=1;l<=k-1;l++)
      {
       (*f)(t,y,n,d);
       for(i=0;i<=n-1;i++) b[i]=y[i];
       for(j=0;j<=2;j++)
        {
            for(i=0;i<=n-1;i++)
           {
            y[i]=z[i*k+l-1]+a[j]*d[i];
            b[i]=b[i]+a[j+1]*d[i]/3.0;
           }
          tt=t+a[j];
         (*f)(tt,y,n,d) ;
        }
      for (i=0;i<=n-1;i++)
        z[i*k+l]=y[i];
      t=t+h;
     }
   free(b);free(d);
} 辛苦您了
搜索更多相关主题的帖子: 源程序 经典 double 
2011-10-03 09:56
pauljames
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:千里冰封
威 望:9
帖 子:1555
专家分:10000
注 册:2011-5-8
收藏
得分:14 
找本数值分析的书,现把算法原理搞清楚,再看程序

经常不在线不能及时回复短消息,如有c/单片机/运动控制/数据采集等方面的项目难题可加qq1921826084。
2011-10-03 20:51
快速回复:关于经典龙格库塔法的源程序
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028406 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved