数值计算方法的意义内容与方法.ppt_第1页
数值计算方法的意义内容与方法.ppt_第2页
数值计算方法的意义内容与方法.ppt_第3页
数值计算方法的意义内容与方法.ppt_第4页
数值计算方法的意义内容与方法.ppt_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数 值 计 算 方 法 陈研 Tel:62732959 新学科综合楼 4-201 中国农业大学资源和环境学院 2005年9月 1 1 数值计算方法的意义、内容与方法数值计算方法的意义、内容与方法 软件的核心就是算法。软件的核心就是算法。 20 20 世纪最伟大的科学技术发明世纪最伟大的科学技术发明-计算机计算机 计算机是对人脑的模拟,它强化了人的思维智能;计算机是对人脑的模拟,它强化了人的思维智能; 计算机的发展和应用,已不仅仅是一种科学技术计算机的发展和应用,已不仅仅是一种科学技术 现象,而且成了一种政治、军事、经济和社会现象;现象,而且成了一种政治、军事、经济和社会现象; 没有软件的支持,超级计算机只是一堆废铁而已;没有软件的支持,超级计算机只是一堆废铁而已; 算法犹如乐谱,算法犹如乐谱, 软件犹如软件犹如CDCD盘片,盘片, 而硬件如同而硬件如同CDCD唱机。唱机。 算法的研究和应用正是本课程的主题算法的研究和应用正是本课程的主题 ! 现代科学研究的三大支柱 理论研究 科学实验 科学计算 计算数学 2121世纪信息社会的两个主要特征:世纪信息社会的两个主要特征: “计算机无处不在计算机无处不在” “数学无处不在数学无处不在” 2121世纪信息社会对科技人才的要求世纪信息社会对科技人才的要求 : -会会“用数学用数学”解决实际问题解决实际问题 -会用计算机进行科学计算会用计算机进行科学计算 建立数学模型选取计算方法 编写上机程序 计算得出结果 科学计算解题过程科学计算解题过程 一、计算数学的产生和早期发展 计算数学是数学的一个古老的分支,虽然数学不仅仅 是计算,但推动数学产生和发展的最直接原因还是 计算问题计算问题。 二、二十世纪计算数学的发展 数值代数 最优化计算 数值逼近 计算几何 概率统计计算 蒙特卡罗方法 微分方程的数值解法 微分方程的反演问题 数值计算的主要内容 数值代数:方程求根、线性方程组求解、 特征值和特征向量的计算、 非线性方程组的求解; 数值逼近:插值、数值微分和积分、 最小二乘法; 微分方程数值解: 常微分方程数值解; 偏微分方程数值解: 差分法 有限元法 有限体积法 否则 S1 输入 S4 输出计算的结果 输入 D=a11a22-a12a21 D=0 开始 输出 x1, x2 结 束 No 输出无解信息 Yes 二、算法的优劣 计算量小 存贮量少 逻辑结构简单 例:用行列式解法求解线性方程组: n阶方程组,要计算n + 1个n阶行列式的值, 总共需要做n! (n - 1) (n + 1) 次乘法运算。 n=20 需要运 算多少次? n=100? 一、 误差的背景介绍 1. 来源与分类 从实际问题中抽象出数学模型 模型误差 33 数值计算中的误差数值计算中的误差 例1:质量为m的物体,在重力作用下,自由下落, 其下落距离s 与时间t 的关系是: (1.1) 其中 g 为重力加速度。 通过测量得到模型中参数的值 观测误差 求近似解 方法误差 (截断误差) 机器字长有限 舍入误差 用计算机、计算器和笔算,都只能用有限位小数 来代替无穷小数或用位数较少的小数来代替位数较多 的有限小数,如: = 3.1415926 x = 8.12345 四舍五入后 在数值计算方法中,主要研究截断误差截断误差和舍入误差舍入误差 (包括初始数据的误差)对计算结果的影响! 二、绝对误差、相对误差和有效数字 1绝对误差与绝对误差限 例 2:若用以厘米为最小刻度的尺去量桌子的长, 大约为1.45米,求1.45米的绝对误差。 1.45米的 绝对误差=?不知道! 定义1:设x是准确值,x*为x的一个近似值,称 是近似值x的绝对误差绝对误差,简称为误差误差。 (1.5) 但实际问题往往可以估计出 不超过某个正数,即, ,则称 为绝对误差限,有了绝对误差限 就可以知道x范围为 即x落在 内。在应用上,常常采用下列 写法来刻划x*的精度。 2相对误差和相对误差限 (1.6) 定义2:设x是准确值,x*是近似值,称 满足 为近似值x的相对误差相对误差,相应地,若正数 , 则称 为x的相对误差限相对误差限。 3有效数字 则说x*近似表示x准确到小数后第n位,并从这第n位起 直到最左边的非零数字之间的一切数字都称为有效数字有效数字, 并把有效数字的位数称为有效位数有效位数。 定义3:如果 (1.7) 由上述定义 有效数位为3位 有效数位为5位 有效数位为4位 误差的传播与积累 例3:蝴蝶效应 纽约的一只蝴蝶翅膀一拍,风和日丽的北 京就刮起台风来了?! NYBJ 以上是一个病态问题 4 4 数值计算中应该注意的一些原则数值计算中应该注意的一些原则 1要使用数值稳定的算法 例4:求 (n = 0, 1, 2, , 8)的值。 解:由于 初值 递推公式 (1.8) 注意此公式精确成 立 按 (1.8) 式就可以逐步算出 What happened ?! 不稳定的算法 ! 由递推公式(1.8)可看出,In-1的误差扩大了5倍后传给In, 因而初值I0的误差对以后各步计算结果的影响,随着n的增大 愈来愈严重。这就造成I4的计算结果严重失真。 这就是误差传播所引起的危害这就是误差传播所引起的危害 ! ! 改变公式: 将公式 变为 不妨设I9 I10,于是由 可求得I9 0.017,按公式(1.9)可逐次求得 (1.9) I8 0.019 I7 0.021 I6 0.024 I8 0.028 I4 0.034 I3 0.043 I2 0.058 I1 0.088 I0 0.182 稳定的算法 ! 在我们今后的讨论中,误差将不可回避, 算法的稳定性会是一个非常重要的话题。 2要避免两个相似数相减 在数值计算中,两个相近的数作减法时有效数字会损失。 (1.10) 的值。当x = 1000,y 的准确值为0.01580 1、直接相减 2、将(1.10)改写为 则 y = 0.01581 例5: 求 类似地 2. 绝对值太小的数不宜作除数 例6: 如分母变为0.0011,也即分母只有0.0001的变化时 3. 避免大数吃小数 例7:用单精度计算 的根 。 精确解为 算法1:利用求根公式 在计算机内,109存为0.11010,1存为0.1101。做加法时, 两加数的指数先向大指数对齐,再将浮点部分相加。即1 的指数部分须变为1010,则:1 = 0.0000000001 1010,取 单精度时就成为: 109+1=0.100000001010+0.00000000 1010=0.10000000 1010 算法2:先解出 注:注:求和时从小到大相加,可使和的误差减小。 例8:按从小到大、以及从大到小的顺序分别计算 4. 先化简再计算,减少步骤,避免误差积累。 一般来说,计算机处理下列运算的速度为 1 + 2 + 3 + + 40 + 109 再利用 5.算法的递推性 计算机上使用的算法常采用递推化的形式,递推 化的基本思想是把一个复杂的计算过程归结为简单过程 的多次重复。这种重复在程序上表现为循环。递推化的 优点是简化结构和节省计算量。 多项式求值:给定的x 求下列n 次多项多的值。 解:1. 用一般算法,即直接求和法; 2. 逐项求和法; 3. 秦九韶方法; 例9:用秦和韶方法求多项式 在x

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论