求解常微分方程初值问题之Runge_Kutta_Fehlberg法

2024-06-06 15:38

本文主要是介绍求解常微分方程初值问题之Runge_Kutta_Fehlberg法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

//用Runge_Kutta_Fehlberg法求解微分方程
#include <iostream>
#include <math.h>
#include <iomanip>
#include <fstream>

using namespace std;

class rkf
{
private:
 int flag;
 double eps, error, f, h, hnew, x, xf, y, yold;
 double k1, k2, k3, k4, k5, k6;

public:
 rkf()
 {
  flag = 0;
 }
 double func(double z, double t)
 {
  f = t * t - t * t * t;
  return f;
 }
 void step_adjust();
 double cash_karp(double, double, double);
};

void main()
{
 rkf fehlberg;
 fehlberg.step_adjust();
}

void rkf::step_adjust()
{
 cout << "\n输入x0:";
 cin >> x;
 cout << "\n输入y0:";
 cin >> y;
 cout << "\n输入xf:";
 cin >> xf;
 cout << "\n输入eps:";
 cin >> eps;
 h = xf - x;
 eps = fabs(eps);
 ofstream fout("Fehlberg.txt");
 fout.precision(4);
 cout.precision(4);
 do
 {
  yold = y;
  y = cash_karp(x, yold, h);
  if (error > eps)
  {
   do
   {
    hnew = h * pow(eps / error, 0.25);
    y = cash_karp(x, yold, hnew);
    h = hnew;
   }while (error > eps);
  }
  else
  {
   do
   {
    hnew = h * pow(eps / error, 0.2);
    y = cash_karp(x, yold, hnew);
    if (error < eps)
    {
     h = hnew;
    }
    else
    {
     y = cash_karp(x, yold, h);
     break;
    }
   }while (error < eps);
  }
  if ((x + h) >= xf)
  {
   h = xf - x;
   y = cash_karp(x, yold, h);
   flag = 1;
  }
  cout << (x + h) << setw(10) << y << setw(15) << error << endl;
  fout << (x + h) << setw(10) << y << setw(15) << error << endl;
  x += h;
 }while (flag == 0);
 fout.close();
}

double rkf::cash_karp(double p, double q, double r)
{
 k1 = r * func(p, q);
 k2 = r * func((p + r / 5), (q + k1 / 5));
 k3 = r * func((p + 3 * r / 10), (q + 3 * k1 / 40 + 9 * k2 / 40));
 k4 = r * func((p + 3 * r / 5), (q + 3 * k1 / 10 - 9 * k2 / 10 + 6 * k3 / 5));
 k5 = r * func((p + r), (q - 11 * k1 / 54 + 5 * k2 / 2 - 70 * k3 / 27 + 35 * k4 / 27));
 k6 = r * func((p + 7 * r / 8), (q + 1631 * k1 / 55296 + 175 * k2 / 512 + 575 * k3 / 13824 + 44275 * k4 / 110592 + 253 * k5 / 4096));
 q += 37 * k1 / 378 + 250 * k3 / 621 + 125 * k4 / 594 + 512 * k6 / 1771;
 error = fabs(k1 * (2825.0 / 27648 - 37.0 / 378) + k3 * (18575.0 / 48384 - 250.0 / 621) + k4 * (13525.0 / 55296 - 125.0 / 594) + (k5 * 277 / 14336) + k6 * (1.0 / 4 - 512.0 / 1771));
 return q;
}

这篇关于求解常微分方程初值问题之Runge_Kutta_Fehlberg法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036526

相关文章

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

2024 年高教社杯全国大学生数学建模竞赛题目——2024 年高教社杯全国大学生数学建模竞赛题目的求解

2024 年高教社杯全国大学生数学建模竞赛题目 (请先阅读“ 全国大学生数学建模竞赛论文格式规范 ”) 2024 年高教社杯全国大学生数学建模竞赛题目 随着城市化进程的加快、机动车的快速普及, 以及人们活动范围的不断扩大,城市道 路交通拥堵问题日渐严重,即使在一些非中心城市,道路交通拥堵问题也成为影响地方经 济发展和百姓幸福感的一个“痛点”,是相关部门的棘手难题之一。 考虑一个拥有知名景区

基于SA模拟退火算法的多车辆TSP问题求解matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述        基于SA模拟退火算法的多车辆TSP问题求解matlab仿真,三个车辆分别搜索其对应的最短路径,仿真后得到路线规划图和SA收敛曲线。 2.测试软件版本以及运行结果展示 MATLAB2022A版本运行 (完整程序运行后无水印)

OpenGL/GLUT实践:流体模拟——数值解法求解Navier-Stokes方程模拟二维流体(电子科技大学信软图形与动画Ⅱ实验)

源码见GitHub:A-UESTCer-s-Code 文章目录 1 实现效果2 实现过程2.1 流体模拟实现2.1.1 网格结构2.1.2 数据结构2.1.3 程序结构1) 更新速度场2) 更新密度值 2.1.4 实现效果 2.2 颜色设置2.2.1 颜色绘制2.2.2 颜色交互2.2.3 实现效果 2.3 障碍设置2.3.1 障碍定义2.3.2 障碍边界条件判定2.3.3 障碍实现2.3.

JD 1147:Jugs(一种用最少步骤求解的方法)

OJ题目:click here~~ 题目分析:九度上这道没有要求最少步数,只要得到最后结果即可AC , bfs , dfs都行。最少步骤的方法肯定也能AC啦,分析如下。 输入的三个数:a,b,n;> 由题不定方程ax+by=n必定有解> 如果b=n,则fill B即可,否则用试探法求出这样的两组解(a1,b1)及(a2,b2),其中a1 >0,b1<0;a1是满足方程的最小正整数;a2

深度学习中的可微编程:从微分方程到物理模拟

引言 可微编程(Differentiable Programming)是深度学习领域的一个新兴概念,旨在将传统编程中的数学模型(如微分方程)与深度学习模型结合,构建出更加灵活、可解释的模型。这一技术为物理模拟、科学计算等领域带来了新的可能性,使得深度学习不仅能够进行预测,还能融入复杂的物理规律进行精确模拟。本篇博文将探讨可微编程的基本原理、常见应用场景,特别是在物理模拟中的实践,以及未来的发展方

【2024全国大学生数学建模竞赛】B题 模型建立与求解(含代码与论文)

目录 1问题重述1.1问题背景1.2研究意义1.3具体问题 2总体分析3模型假设4符号说明(等四问全部更新完再写)5模型的建立与求解5.1问题一模型的建立与求解5.1.1问题的具体分析5.1.2模型的准备 目前B题第一问的详细求解过程以及对应论文部分已经完成! - 晚上7-8点之前第二问完成 - 明天中文之前全部写完 按照提交论文的格式进行撰写!完整版请看文章最后!

Java 快速求解x的x次幂结果为10

1.问题描述 如果x的x次幂结果为10(如图所示),你能计算出x的近似值吗? 显然,这个值是介于2和3之间的一个数字。 可以使用牛顿迭代公式进行求解,因为是逼近算法可以大大减少运算次数 public static void main(String[] args) {int i = 0;double x1 = 2.5;while (true) {i++;//x^x - 10 = 0//这一步

最值求解 | 管理类联考数学专项

日期内容2024.9.5新建2024.9.6曦曦求最值完结 实数求最值至少至多抽屉原理工程问题线性规划一次性绝对值求最值 参考: b站跟着曦曦老师玩转【最值】

2024数学建模国赛A题详细思路:基于空间几何运动学和优化模型matlab求解

2024数学建模国赛A题“板凳龙”闹元宵 2024高教社杯数学建模竞赛A题B题C题D题E题完整成品文章和全部问题的解题代码完整版本更新如下:https://www.yuque.com/u42168770/qv6z0d/rytbc1nelty1mu4o % 定义常量L_head = 3.41; % 龙头长度(米)L_body = 2.20; % 龙身长度(米)spiral_pitch =