定步长,可以在稍微修改之后变为变步长形式,代码如下:

void rkf78c( double h, double& T, vxd& X, double& err)
{
    int N = X.size();

    vxd X1(N);
    ;
    vxd Y0(N), Y1(N), Y2(N), Y3(N), Y4(N), Y5(N), Y6(N), Y7(N), Y8(N), Y9(N), Y10(N), Y11(N), Y12(N);

    ; i != N ; i++)
    {
        X1[i] = X[i];
    }
    T1 = T;
    dxdt(T1, X1, Y0);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*2.0/27.0*Y0[i];
    }
    T1 = T + h*2.0/27.0;
    dxdt(T1, X1, Y1);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]+3.0*Y1[i])/36.0;
    }
    T1 = T + h*1.0/9.0;
    dxdt(T1, X1, Y2);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]+3.0*Y2[i])/24.0;
    }
    T1 = T + h*1.0/6.0;
    dxdt(T1, X1, Y3);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]*20.0+(-Y2[i]+Y3[i])*75.0)/48.0;
    }
    T1 = T + h*5.0/12.0;
    dxdt(T1, X1, Y4);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]+Y3[i]*5.0+Y4[i]*4.0)/20.0;
    }
    T1 = T + h*1.0/2.0;
    dxdt(T1, X1, Y5);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(-Y0[i]*25.0+Y3[i]*125.0-Y4[i]*260.0+Y5[i]*250.0)/108.0;
    }
    T1 = T + h*5.0/6.0;
    dxdt(T1, X1, Y6);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]*93.0+Y4[i]*244.0-Y5[i]*200.0+Y6[i]*13.0)/900.0;
    }
    T1 = T + h*1.0/6.0;
    dxdt(T1, X1, Y7);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]*180.0-Y3[i]*795.0+Y4[i]*1408.0-Y5[i]*1070.0+Y6[i]*67.0+Y7[i]*270.0)/90.0;
    }
    T1 = T + h*2.0/3.0;
    dxdt(T1, X1, Y8);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(-Y0[i]*455.0+Y3[i]*115.0-Y4[i]*3904.0+Y5[i]*3110.0-Y6[i]*171.0+Y7[i]*1530.0-Y8[i]*45.0)/540.0;
    }
    T1 = T + h*1.0/3.0;
    dxdt(T1, X1, Y9);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]*2383.0-Y3[i]*8525.0+Y4[i]*17984.0-Y5[i]*15050.0+Y6[i]*2133.0+Y7[i]*2250.0+Y8[i]*1125.0+Y9[i]*1800.0)/4100.0;
    }
    T1 = T + h;
    dxdt(T1, X1, Y10);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(Y0[i]*60.0-Y5[i]*600.0-Y6[i]*60.0+(Y8[i] -Y7[i] +2.0*Y9[i])*300.0)/4100.0;
    }
    T1 = T;
    dxdt(T1, X1, Y11);

    ; i != N ; i++)
    {
        X1[i] = X[i] + h*(-Y0[i]*1777.0-Y3[i]*8525.0+Y4[i]*17984.0-Y5[i]*14450.0+Y6[i]*2193.0+Y7[i]*2550.0+Y8[i]*825.0+Y9[i]*1200.0+Y11[i]*4100.0)/4100.0;
    }
    T1 = T + h;
    dxdt(T1, X1, Y12);

    err = 0.0;
    ; i != X.size(); i++)
    {
        X[i] += h*(Y5[i]*272.0+(Y6[i]+Y7[i])*216.0+(Y8[i]+Y9[i])*27.0+(Y11[i]+Y12[i])*41.0)/840.0;
        err += fabs((Y0[i]+Y10[i]-Y11[i]-Y12[i])*h*41.0/840.0);
    }
    T += h;
}

定步长的龙格库塔7(8)阶C++程序(RKF78)的更多相关文章

  1. MATLAB常微分方程数值解——欧拉法、改进的欧拉法与四阶龙格库塔方法

    MATLAB常微分方程数值解 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1.一阶常微分方程初值问题 2.欧拉法 3.改进的欧拉法 4.四阶龙格库塔 ...

  2. 用python面向对象的方法实现欧拉算法和龙格库塔算法

    #!/bin/python3 # -*-coding:utf-8 -*- import math import numpy as np #定义一个欧拉算法的类,从而实现不同步长的引用 class Eu ...

  3. 【C/C++】龙格库塔+亚当姆斯求解数值微分初值问题

    /* 解数值微分初值问题: 龙格-库塔法求前k个初值 + 亚当姆斯法 */ #include<bits/stdc++.h> using namespace std; double f(do ...

  4. 龙格-库塔法解常微分方程(c++)

    用龙格库塔法计算 #include <iostream> #include<iomanip> #include <cmath> using namespace st ...

  5. MATLAB学习笔记(七)——MATLAB解方程与函数极值

    (一)线性方程组求解 包含n个未知数,由n个方程构成的线性方程组为: 其矩阵表示形式为: 其中 一.直接求解法 1.左除法 x=A\b; 如果A是奇异的,或者接近奇异的.MATLAB会发出警告信息的. ...

  6. 软件推荐-国内参数优化软件:1stOpt - First Optimizationg

    首页:http://www.7d-soft.com/index.htm 4.0新功能 (预定2010年8月6日): 1:支持复数拟合.复数方程组计算: 2:支持微分方程拟合求解: 3:通用全局优化求解 ...

  7. 相机IMU融合四部曲(二):误差状态四元数详细解读

    相机IMU融合四部曲(二):误差状态四元数详细解读 极品巧克力 前言 上一篇文章,<D-LG-EKF详细解读>中,讲了理论上的SE3上相机和IMU融合的思想.但是,还没有涉及到实际的操作, ...

  8. MATLAB数学实验总结

    L1 MATLAB 基础知识 P6 表1-3 数据显示格式 format rat format long P20 表2-5 常用的矩阵函数 zeros(m,n) %零阵 eye(n) %单位阵 one ...

  9. 多重网格法简介(Multi Grid)

    原文链接 多重网格法是一种用于求解方程组的方法,可用于插值.解微分方程等. 从专业角度讲多重网格法实际上是一种多分辨率的算法,由于直接在高分辨率(用于求解的间隔小)上进行求解时对于低频部分收敛较慢,与 ...

随机推荐

  1. ASP.NET验证控件

    在此过程中房间的收费制度时,.为了验证文本框是否为空.用户存在.合法等等.我们都要单独写代码.学习了ASP.NET的验证控件,省了非常多事. ASP.NET能够轻松实现对用户输入的验证. 让我们好好回 ...

  2. CodeIgniter入门——HelloWorld

    原文:CodeIgniter入门--HelloWorld CodeIgniter(CI)是一套给PHP网站开发者使用的应用程序开发框架和工具包. 初次接触,来一个HelloWorld~~~ ^_^ 准 ...

  3. Node.js新手教程——怎样实现文件上传功能

    作者:zhanhailiang 日期:2014-11-16 本文将介绍怎样使用Node.js实现文件上传功能. 1. 初始化项目信息:npm init [root@~/wade/nodejs/node ...

  4. zoj 3203 Light Bulb,三分之二的基本问题

    Light Bulb Time Limit: 1 Second      Memory Limit: 32768 KB Compared to wildleopard's wealthiness, h ...

  5. Android经常使用的布局类整理(一)

    Android经常使用的布局类整理 近期又回头做了一下android的项目,发觉越来越不从心,非常多东西都忘了,简单的页面布局也非常多写不出来,首先还是先整理一下一些会混淆的概念先 layout_wi ...

  6. .NET中使用Redis(二)

    很久以前写了一篇文章 .NET中使用Redis 介绍了如何安装Redis服务端,以及如何在.NET中调用Redis读取数据.本文简单介绍如何设计NoSQL数据库,以及如何使用Redis来存储对象. 和 ...

  7. 十天学Linux内核之第三天---内存管理方式

    原文:十天学Linux内核之第三天---内存管理方式 昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今 ...

  8. SQL Server编程系列(1):SMO介绍

    原文:SQL Server编程系列(1):SMO介绍 续篇:SQL Server编程系列(2):SMO常用对象的有关操作 最近在项目中用到了有关SQL Server管理任务方面的编程实现,有了一些自己 ...

  9. poj 2449 Remmarguts&#39; Date 【SPFA+Astar】【古典】

    称号:poj 2449 Remmarguts' Date 意甲冠军:给定一个图,乞讨k短路. 算法:SPFA求最短路 + AStar 以下引用大牛的分析: 首先,为了说话方便,列出一些术语: 在启示式 ...

  10. Android 阅读Manifest在文件Application 在与其他节点meta-data定义自己的数据

    介绍 Android提供meta-date使用键值在实现自己的自定义配置的形式. 通常用作信道标识.它可以用在<application>,<activity>,<acti ...