计算方法的稳定性 | 误差来源之舍入误差 | 数值计算基本原则

本文主要是介绍计算方法的稳定性 | 误差来源之舍入误差 | 数值计算基本原则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

计算方法的稳定性

在实际数值计算过程中,由于不可避免地存在和不断产生各种误差,因此计算结果不是绝对精确的。如果误差使得计算结果和实际情况有较大差别或者出现错误的结果,则数值 计算便失去了价值和意义。因此,分析数值计算过程中误差的来源和传递规律,设法控制和减小误差。

1.误差的来源

来源:固有误差(模型误差、观测误差)和计算误差(截断误差、舍入误差)

舍入误差

设s是r进制数,p是r进制正负整数或零,则形如
x = s × r p x=s\times r^p x=s×rp
并满足
− 1 < s < 1 -1<s<1 1<s<1
的数x,称为r进制浮点数,且s和p分别称为浮点数的尾数和阶数。

任何一种计算机只能用有限的位数来表示浮点数的尾数和阶数。设
− m ≤ p ≤ M -m\leq p\leq M mpM
其中 m , M m,M m,M为正整数,它们主要由计算机用多少位数来表示阶数而决定。如果尾数的小数尾数为t(t一般比m,M的位数大若干倍),则计算机的数系由一切阶数满足 − 1 < s < 1 -1<s<1 1<s<1的t位r进制浮点数的集合F组成。可见,在计算机数系中,数的个数有限,数系中的每一个数都是有理数,且阶数相等的数以相等的距离分布在数轴的某一段上。

由于计算机数系是有限集,不仅无理数 e , π e,\pi e,π等不属于计算机数系,而且一些有理数(如 1 / 3 1/3 1/3)也属于计算机数系,因此常常用计算机数系中和它们接近的数来表示它们。同时,在利用计算机进行计算时,由于字长限制,参与计算的数的长度也是有限的,而由此产生的误差,称为舍入误差

例1

浮点数F的集合可以用以下4个参数来描述:
{ F } ≡ { β , t , L , U } \{F\}\equiv \{\beta,t,L,U\} {F}{β,t,L,U}
其中, β \beta β为基数,t是精度参数,整数L与U是阶码E(范围)的下限和上限 [ L , U ] [L,U] [L,U]

这样,F中的每一个浮点数x的值可表示为:
x = ± ( d 1 β + d 2 β 2 + ⋯ + d t β t ) ⋅ β E x=\pm(\frac{d_1}{\beta}+\frac{d_2}{\beta^2}+\cdots+\frac{d_t}{\beta^t})·\beta^E x=±(βd1+β2d2++βtdt)βE
式中的整数 d 1 , ⋯ , d t d_1,\cdots,d_t d1,dt满足 0 ≤ d t ≤ β − 1 , ( i = 1 , ⋯ , t ) 0\leq d_t\leq \beta-1,(i=1,\cdots,t) 0dtβ1,(i=1,,t),同时又 L ≤ E ≤ U L\leq E\leq U LEU(E是整数)。

如果对F中每个非零的x,有 d 1 ≠ 0 d_1\neq 0 d1=0,则称浮点数系F为规格化浮点数系。括号中的部分 f = ( d 1 / β + d 2 / β 2 + ⋯ + d t / β t ) f=(d_1/\beta+d_2/\beta^2+\cdots +d_t/\beta^t) f=(d1/β+d2/β2++dt/βt)称为尾数。我们知道,一个实数常用【整数+小数点+尾数】的形式表示,它们在计算机中对应的浮点数 [ β t ⋅ f ] [\beta^t·f] [βtf]则常用某种整数表示方式(例如以原码、反码或补码的形式)存储。

例2:求十进制数系与计算机采用的二进制数系之间的差别

:以在许多算法中常被选作步长的十进制0.1为例。在 β = 2 \beta=2 β=2或者为2的幂的浮点数系中,10个0.1的步长并不刚好等于一个1.0的步长。事实上,当把 1 10 \frac{1}{10} 101转换成为以 1 2 \frac{1}{2} 21为底的幂的有限项展开式时,有:
1 10 = 0 2 1 + 0 2 2 + 0 2 3 + 1 2 4 + 1 2 5 + 0 2 6 + 0 2 7 + ⋯ \frac{1}{10}=\frac{0}{2^1}+\frac{0}{2^2}+\frac{0}{2^3}+\frac{1}{2^4}+\frac{1}{2^5}+\frac{0}{2^6}+\frac{0}{2^7}+\cdots 101=210+220+230+241+251+260+270+
用下标表示数基,如果 β = 2 \beta=2 β=2,则有:
( 0.1 ) = ( 0.000110011001100 ⋯ ) z (0.1)=(0.000110011001100\cdots)_z (0.1)=(0.000110011001100)z
如果 β = 8 \beta=8 β=8,则
( 0.1 ) = ( 0.063146314 ⋯ ) s (0.1)=(0.063146314\cdots)_s (0.1)=(0.063146314)s
由于字长限制,等号右边的值只能取7位。很明显,当把10个这样的数相加时,其结果并不正好是1.0。这就是舍入误差造成的。所以,在计算机上进行的浮点运算(四则运算)只能是近似计算。

观测误差和数据的舍入误差虽然来源不同,但对计算结果的影响完全一样。在数值计算中涉及的误差一般指舍入误差(包含初始数据误差)和截断误差。

2 计算方法的稳定性

计算方法的稳定性是指数值计算中是否稳定的问题。在数值计算过程中,数值解是逐步计算出来的。由于计算机的字长有限,每一步计算都有误差存在,且前一步的舍入误差必然要影响下一步的近似解。如果运算序列的舍入误差不增长。误差的积累或传递对计算结果的影响是可控的,则该算法是数值稳定的,否则是数值不稳定的。

3. 数值计算的基本原则

评价一个数值计算方法优劣的标准:

  • 计算时间复杂度(运算次数或计算时间),包括收敛性问题
  • 计算空间复杂度(占用计算机存储空间)
  • 计算结果精确度(包括稳定性问题)

构造和选择一个好的计算方法:

  1. 避免两个相近的数相减

在数值计算过程中,两个相近的数相减,会严重损失有效数字,从而使相对误差变大。

如果两个相近的数相减,常采用变换的公式进行计算。如果计算公式不能改变,则采用增加有效数字位数的方法。

  1. 避免使用绝对值很小的数作分母

  2. 两个相差很大的数进行运算时,防止大数“吃掉”小数

  3. 简化计算步骤,减少运算次数

这篇关于计算方法的稳定性 | 误差来源之舍入误差 | 数值计算基本原则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系