C#,数值计算,求平方根之巴比伦算法(Babylonian algorithm)的源代码

平方根的巴比伦算法。

1 巴比伦算法介绍一

巴比伦算法可能算是最早的用于计算sqrt{S}的算法之一,因为其可以用牛顿法导出,因此在很多地方也被成为牛顿法。其核心思想在于为了计算x的平方根,可以从某个任意的猜测值g开始计算。在真实的运算中,我们往往将g直接设置为x,不过也可以选择其他任何的正数值。那么其计算的迭代过程为:

1.如果猜测值g已经足够接近于正确的平方根,算法结束,函数将g作为结果返回。

2.如果猜测值g不够精确,那么使用gx/g的平均值作为新的猜测值。因为这两个值中的一个小于确切的平方根,另一个则大于确切的平方根,选择平均值有助于你得到一个更接近于正确答案的值。

3.把新的猜测值赋予给变量g,重复第一步的判断。

2 巴比伦算法介绍二

  1. 假设要求a的平方根,先找到一个近似值x0,如a/2;

  2. 被开方数a除以近似值x0;

  3. 求第一步和第二步得到的值的平均数;

  4. 令平均数为新的近似值,返回第二步,循环计算(根据精度要求,进行循环控制)

经过前面四个步骤,可以得到如上公式;

对公式的理解:可以把xn理解为x0,xn+1理解为x1,然后套用公式即可。

3 核心代码

/// <summary>

/// 计算 v 的平方根

/// 据说来自于远古巴比伦时代的算法

/// </summary>

/// <param name="v"></param>

/// <returns></returns>

public static double Sqrt(double v)

{

const double e = 0.000001;

double x = v;

double y = 1.0;

while ((x - y) > e)

{

x = (x + y) / 2;

y = v / x;

}

return x;

}


POWER BY TRUFFER.CN

相关推荐
zhangfeng11339 分钟前
国家超算中心 昆山站 异构加速卡1 显存16GB详细配置, 海光 Z100SM HCU
linux·网络·深度学习·c#
Yvonne爱编码11 分钟前
JAVA EE初阶---DAY 2 计算机网络
java·开发语言·计算机网络·算法·java-ee·php
子豪-中国机器人16 分钟前
Python 阶段性综合强化训练(新版)
开发语言·python·语音识别
z落落18 分钟前
C# WinForm TreeView 树形控件+ListView控件+菜单栏
开发语言·c#
码云数智-园园18 分钟前
码云数智网站SEO设置指南:如何让百度搜索到你的网站
开发语言
赴生-18 分钟前
C++进阶 智能指针
开发语言·c++
chao18984422 分钟前
GNSS软件接收机 MATLAB 实现(GPS L1 CA码)
开发语言·matlab
清水白石00825 分钟前
让对象像函数一样工作:深入理解 Python `__call__` 的作用与实战场景
开发语言·python
workflower28 分钟前
基于机器学习的设备故障预测分析方法
人工智能·算法·机器学习·设计模式·语言模型·自然语言处理·重构
格发许可优化管理系统33 分钟前
Mentor许可证与其他软件许可证的深度比较
java·大数据·运维·c语言·c++·算法