博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
斯特芬森加速迭代法(Steffensen)-埃特金方法(Aitken) 一元非线性方程求根 C语言实现
阅读量:4156 次
发布时间:2019-05-26

本文共 918 字,大约阅读时间需要 3 分钟。

斯特芬森加速迭代法(Steffensen)/埃特金方法(Aitken) 一元非线性方程求根 C语言实现

标签:计算方法实验

斯特芬森加速迭代法(Steffensen)/埃特金方法(Aitken)较迭代法的优点:1.迭代法收敛-->加速收敛2.迭代法不收敛-->收敛
/*    方程f(x) = x^3 - 3 * x - 1 = 0有三个实根x1 = 1.8793, x2 = -0.34727, x3 = -1.53209.    本实验采用下面两种计算格式,求的根x1或x2或x3.*/#include 
#include
double f1(double x){ //迭代函数f1(x) return (3.0 * x + 1) / (x * x);}double f2(double x){ //迭代函数f2(x) return 1.0 / (x * x - 3);}double Steffensen(double x){ return x -((f1(x) - x) * (f1(x) - x) / (f1(f1(x)) - 2.0 * f1(x) + x));}int main(){ double x1, d; double x0 = 0.5; //迭代初值 double eps = 0.0001; //求解精度 int k = 0; //迭代次数 do{ k++; x1 = Steffensen(x0); ///迭代函数 printf("%d %f\n", k, x1); d = fabs(x1 - x0); x0 = x1; }while(d >= eps); printf("the root of f(x) = 0 is x = %f, k = %d\n", x1, k); return 0;}

f1(x):

f1
f1(x)Steffensen加速后:
f1s
f2(x):
f2
f2(x)Steffensen加速后:
f2s

你可能感兴趣的文章
Firefly- toybrick RK3399 音频codec
查看>>
alsa 库相关资料
查看>>
使用alsa库播放录制音频
查看>>
patch补丁文件格式
查看>>
RK3399 ffmpeg编译
查看>>
jz2440 内核编译问题
查看>>
rk3399 内核编译报错
查看>>
编译驱动Makefile解析
查看>>
设备树jz2440开发环境镜像说明
查看>>
uboot-1-分析之编译体验
查看>>
rk3399源码,uboot,内核编译
查看>>
uboot-2,3分析之源码
查看>>
Linux-insmod/rmmod/lsmod驱动模块相关命令
查看>>
libfrelocation R_AARCH64_ADR_PREL_PG_HI21 against symbol which may bind externally can not be used
查看>>
芯片资料中的pad和pin的区别
查看>>
gzip bzip2 区别
查看>>
proc目录下的进程目录
查看>>
mount -a
查看>>
【Hi35**】制作根文件系统
查看>>
GV7704中文资料 hd-vlc
查看>>