计算机的错误计算(二十五)

摘要  介绍(不)停机问题。给了一个算式,当计算机的输出为0时,一般需要提高计算精度继续计算,一直到获得非0值或有效数字。但是,由于事先不清楚算式的准确值是否为0或不为0,因此往往陷入两难境地:如果一直是0,则不知该继续计算还是不计算?若继续计算,万一准确值是0,那么就是无用的计算了;若不计算,那万一准确值不是0,那岂不是没计算出准确值吗?所以,当输出一直是0时,究竟该停机还是不停机?

       给定一个算式。假设在某个精度下,计算机的输出为0. 从计算机的错误计算(二十一)中知,真实值也许不为0. 对此情形,给出一种解决方案:不停增加计算精度直到出现非0结果。

       那么问题来了:计算精度要到多少?只是不停增大吗?如果真的为0,那不是一直也计算不出来?那就停机不用计算了?计算还是不计算呢?停机还是不停机呢?这就是(不)停机问题

       比如,在计算机的错误计算(二十四)中,当有效位数从默认的10位,到13位,再到15位,计算机的输出均是0. 3次计算均为0,您还会增加精度进行计算吗?也许还会。然后第4次计算:增加到16位,可是结果仍然是0. 这时,怎么办?很大概率,您想,肯定是0了。我不计算了。这样就错了。只要再计算一次,就是非0结果了。

       人类的数值计算模式就是固定位数的计算模式(请参考计算机的错误计算(十二))。在计算前,总是假设一个位数,然后所有中间计算与最终结果均保留该位数位数字。对于结果为0的算式的计算,实在是一个挑战。你不知道该不该继续计算。若不停计算,而算式真的为0呢?若到某一个精度不计算了,也许算式真的不为0?不管哪种情形,您的决定均是错的。前者称为遇到不停机问题;后者称为停机问题。总之,不知该停机还是不停机。

       再看一个简单案例。已知

 a=123456+0.1^{2000}-123456,\\ b=123456-123456..

       首先,计算机既不知道它们的关系,也不会预先知道它们的正确结果。其次,若有效位数小于6+2000+1=2007位,则它们的输出相同:均为0. 

       假设要计算 a 的值。当有效位数取10,结果为0;提高计算精度,设有效位数为100,结果仍为0;再设有效位数为200,输出还是0;狠狠心,增大到1000,结果还为0. 到这时,你计算不?继续?再狠狠心,豁出去了,机器的风扇在呼呼地吹,内存几乎爆掉,提高到2000!运行24小时1分后,结果终于出现了:0. 请问,您是否崩溃了?还是舒了一口气?哦,就是0!!!定了,就是0.  不算了。这就是结果了。停机了。

       过了几天,看到另外一个软件(您能举个例子吗?),在上面试了试,哎呀,原来不是0(什么心情?).  以后遇到这种情形,我要不停地算,直到非0结果!

       又过了几天,遇到一个式子,是 b. 当有效位数取10,结果为0;提高计算精度,设有效位数为100,结果仍为0;再设有效位数为200,输出还为0;好吧,既然为0,我要吸取上次教训,不停地算,直到非0结果的出现。然后设置好循环迭代后,机器开启了不停计算模式:风扇在呼呼地吹,内存在不停地与硬盘交换数据,硬盘的可用空间在不停地缩小,终于到公元3000年,停机了!但是,结果还没出来。停机是因为硬盘没可用空间了。这就是不停机问题。

       停机还是不停机?什么时候停机?这是个艰难的决策。

       各位看官,您怎么想?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/43239.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java15】继承

继承是面向对象三大特征之一,也是软件代码服用的重要手段。 Java只允许单继承,即每个子类只有一个直接父类。 C中的多继承被Java舍弃了,原因是多继承一方面难以准确表述类之间的关系,另一方面很容易造成代码错误。总结起来就两个…

双系统ubuntu20.04扩容

windows端 打开磁盘管理器,选择需要的盘点击压缩卷 点击未分配的盘,新建简单卷,一致点击下一步即可,记住分配的大小容量 ubuntu端 lsblk 查看所有的磁盘,可以看到新增为nvme0n1p4、nvme1n1p2 win分配的格式为NTFS&a…

【Excel】 批量跳转图片

目录标题 1. CtrlA全选图片 → 右键 → 大小和属性2. 取消 锁定纵横比 → 跳转高度宽度 → 关闭窗口3. 最后一图拉到最后一单元格 → Alt吸附边框![](https://i-blog.csdnimg.cn/direct/d56ac1f41af54d54bb8c68339b558dd1.png)4. CtrlA全选图片 → 对齐 → 左对齐 → 纵向分布!…

全网最适合入门的面向对象编程教程:11 类和对象的Python实现-子类调用父类方法-模拟串口传感器和主机

全网最适合入门的面向对象编程教程:11 类和对象的 Python 实现-子类调用父类方法-模拟串口传感器和主机 摘要: 本节课,我们主要讲解了在 Python 类的继承中子类如何进行初始化、调用父类的属性和方法,同时讲解了模拟串口传感器和…

OpenHarmony 入门——单元测试UnitTest快速入门

引言 OpenHarmony 的单元测试(UnitTest)是一个关键的软件开发过程,它确保代码的各个部分能够按预期工作,OpenHarmony的测试框架中提供了很多种的单元测试,今天简单介绍下UnitTest 类型的TDD测试。 OpenHarmony 的TDD …

Nacos 国际化

项目需要,后端异常信息需要进行国际化处理。所有想有没有方便易用的可选项。 1、国际化配置调整,不需要重启系统 2、可支持添加不同或自定义语言包(就是配置的资源文件) 参考: Nacos实现SpringBoot国际化的增强_spr…

LeetCode热题100刷题9:25. K 个一组翻转链表、101. 对称二叉树、543. 二叉树的直径、102. 二叉树的层序遍历

25. K 个一组翻转链表 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr) {}* ListNode(int x, ListNode *next) : val(x), nex…

go语言day12 包 init() time包 file包

包 包中的 结构体 及结构体属性 方法 都可以通过设置首字母大小写来实现权限访问,首字母大写任何包中都可以访问,首字母小写只在同包中可以访问。 再导入包go文件时,可以给.go文件取别名。 在导入的包名前加入 _ 意思是调用该包的初始…

普中51单片机:矩阵按键扫描与应用详解(五)

文章目录 引言电路图开发板IO连接矩阵键盘的工作原理行列扫描逐行/逐列扫描 LCD1602代码库代码演示——暴力扫描代码演示——数码管(行列式)代码演示——线翻转法代码演示——LCD1602密码锁 引言 矩阵按键是一种通过行列交叉连接的按键阵列,可以有效地减少单片机I/…

计算机网络 - 万字长文

计算机网络 二、计算机网络2.1 七层模型表格2.2 通俗讲解七层模型2.3 TCP与UDP对比2.4 TCP 三次握手过程==为什么握手是三次,而不是两次或者四次?====三次握手可以携带数据吗?====TCP三次握手失败,服务端会如何处理?====什么是半连接队列?全连接====ISN(Initial Sequence…

基于单片机的太阳能热水器控制系统设计

随着我国经济水平的不断提高,民众对生活质量的追求也在不断进步,对于现代家庭而言,热水器成为了必备的生活电器。目前市面上的电器主要是电热水器、燃气热水器以及太阳能热水器。就能源节约性能而言,太阳能热水器占据了绝对优势&a…

Java | Leetcode Java题解之第223题矩形面积

题目: 题解: class Solution {public int computeArea(int ax1, int ay1, int ax2, int ay2, int bx1, int by1, int bx2, int by2) {int area1 (ax2 - ax1) * (ay2 - ay1), area2 (bx2 - bx1) * (by2 - by1);int overlapWidth Math.min(ax2, bx2) -…

开源高效在线电子表格解决方案:Luckysheet

Luckysheet:体验幸运,掌握高效数据表格编辑!- 精选真开源,释放新价值。 概览 Luckysheet 是一个功能强大、配置简单且完全开源的在线电子表格工具,它类似于我们熟知的 Excel,但更加灵活和易于集成。它是一…

windows环境下部署多个端口Tomcat服务和开机自启动设置保姆级教程

前言 本文主要介绍了 windows环境下,配置多个Tomcat设置不同端口启动服务。其实在思路上Linux上也是适用的,只是 Linux 上没有可视化客户端,会麻烦些,但总体的思路上是一样的。 注:文章中涉及些文字和图片是搬运了其他…

OpenGL3.3_C++_Windows(28)

Demo演示 demo 视差贴图 视差/高度/位移贴图(黑--白):和法线贴图一样视差贴图能够极大提升表面细节,使之具有深度感。第一种思路(置换顶点):对于一个quad ,分成约1000个顶点&#x…

C语言 | Leetcode C语言题解之第223题矩形面积

题目: 题解: int computeArea(int ax1, int ay1, int ax2, int ay2, int bx1, int by1, int bx2, int by2) {int area1 (ax2 - ax1) * (ay2 - ay1), area2 (bx2 - bx1) * (by2 - by1);int overlapWidth fmin(ax2, bx2) - fmax(ax1, bx1), overlapHei…

Visual Studio Code 教程 VsCode安装Live Server以服务形式打开html

搜索Live Server 插件,然后安装 选一个html文件,右键点击 Open with live server,然后就自动弹出来了

使用paddleOCR训练自己的数据集到ONNX推理

一、环境安装 1、安装paddlepaddle; https://www.paddlepaddle.org.cn/ 这里安装2.6.1的话使用onnx会出现swish算子报错的问题 python -m pip install paddlepaddle-gpu2.5.2 -i https://pypi.tuna.tsinghua.edu.cn/simple验证是否成功安装 python import paddl…

Mysql Workbench的使用

本篇内容:对Mysql Workbench的常规使用学习 一、知识储备 1. Workbench 可以做什么 是mysql数据库可视化管理的一款免费工具,除了平常的通过sql语句,进行创建数据库表、增删改查外,还可以利用其进行建模创建数据库表。通过创建…

人工智能的新时代:从模型到应用的转变

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…