- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对创建/设计(但很可能只是想象)三元计算机而不是二进制计算机的想法非常感兴趣。
如果我要这样做,我会使用一个平衡的 base-3 系统,所以一个 trit (trit 是 base-3 就像 bit 是 base-2) 可以是 -1, 0 或 +1。使用 trits 存储数据比使用位存储数据要紧凑大约 36%,就像我们在今天的计算机上所做的那样,但是三元算术会复杂得多,因此无法确定使用三元计算的 ALU 是否比二进制更快或更慢。
但我离题了,这只是一些背景知识,并不完全与问题有关,但它是相关的。 :)
因此,trit 的可能值:
-1是off/false,相当于二进制的0。
0 是未知。二进制中没有等价物。
+1 是on/true,与二进制中的 1 相同。
我的问题是...就计算而言,0 有什么意义?例如,我已经阅读了很多关于逻辑门的文章,并且我了解它们的工作方式以及它们如何协同工作以创建 ALU。二进制与门非常简单,与其他二进制逻辑门结合使用,它们都可以组合使用来执行算术运算,例如创建加法器或执行加法的单元。
我什至无法理解如何使用三元计算来完成这件事。未知数 (0) 如何进入逻辑门并用于执行算术运算?该死,我什至无法理解三元与门会输出什么以及如何使用它们。
例如,我假设对于三元计算机,与门将接受 3 个输入而不是 2 个。我们将输入称为 A、B 和 C。
在二进制与门中,A 和 B 可以是 0 或 1。A 和 B 有四种可能的组合可以输入到与门中。这导致 AND 门只有四个可能的输出。如果 A 和 B 都为 1,则与门输出 1。如果它是 A 和 B 的其他三个组合中的任何一个,则输出 0。(考虑所有可能的 A/B 组合,与门的可能结果:0、0 , 0, 1)
三元与门需要 3 个输入,对吧?所以在三元与门中,A、B 和 C 可以是 -1、0 或 1。这意味着 A/B/C 有 27 种可能的组合。与其列出每种组合的可能结果,我只是为你们把它们加起来。 :)
总之,输出1的组合只有一种,输出0的组合有7种(假设A、B、C全为0则与门输出0),以及有 19 种组合,其中 -1 将是输出。在二进制加法器中,如果门抛出 1,它将被发送到另一个门进行评估,依此类推,直到加法完成。在三进制中...如果门接收到 0,它会做什么?
我知道阅读量很大,所以我会尝试总结一下并在下面列出主要问题:
如何在逻辑门中使用/处理平衡三元系统中的 trit 的 0?
如果一个逻辑门输出 0,并且该门在 ALU 中用于执行算术运算(比方说加法),那么接收 0 的门将如何处理它?基本上,如何使用三元逻辑创建加法器?
最后,我是否正确地假设在三元计算机中逻辑门将接受 3 个输入而不是像二进制计算机那样的 2 个输入,或者逻辑门仍然是二元的?
最佳答案
ALU 设计的一个基本目标是对整数执行算术运算。先做加法(减法),再做乘法和除法。
当以 base 3 编写时,这些操作定义明确。例如
+ | 0 1 2
------------
0 | 0 1 2
1 | 1 2 10
2 | 2 10 11
与二进制算术一样,on 需要计算 sum trit 和 carry。传播进位时,适用下表
+c| 0 1 2
------------
0 | 1 2 10
1 | 2 10 11
2 | 10 11 12
所以您确实需要两个三输入函数(两个输入和一个进位),给出总和位和进位位。 (请注意,二进制 ALU 以相同的方式相加:两位输入和一个进位给出一个和和一个进位。)
这是否可以从基本二元门或三元门实现将取决于技术。
逻辑谓词 AND/OR 没有理由被修改,应该保持二进制。 bool 运算仍然是 bool 值。
此外,如果您枚举两个三元参数(即 9 个输入组合)的所有三元函数,您会找到其中的 19683 个。将此与 16 个二进制函数进行对比。这种困惑是无法控制的。 (别想所有的三元三元函数,7625597484987个。)
关于binary - 三元计算机 : what would the third (unknown) part of a trit be used for?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34257590/
有没有办法在不进行提交/ check out 的情况下应用差异补丁或类似补丁? 我的情况:我工作时经常在计算机之间切换,我的提交历史记录有一堆“switching machines”消息。 我最初的猜
我的自定义引导加载程序中有代码从地址 0x8E00 处的 512 字节缓冲区复制内存。进入高内存,0x100000和更高。这在某些计算机上运行良好,而在其他计算机上崩溃(我假设是三重故障)。此代码在
服务器有没有办法将一些数据无线无缝地推送到客户端,可能是 Windows(电话)、iPhone、Mac 或 Android 设备,没有任何操作系统集成? 如果是这样,最好的设计模式是什么,最好的技术是
我无法理解hadoop的真正本质。 如果我有足够的资源来购买可以处理PB级数据的 super 计算机,那么为什么我需要Hadoop基础架构来管理如此大的数据? 最佳答案 hadoop的全部目的是能够在
我有一个奇怪的问题,或者我可能无法理解Grails i18n机制的工作原理。 我将以下内容插入到index.gsp文件中: LocaleContextHolder.locale:
我正在尝试为我的小弟弟编写一个简单的程序。他经常在他的电脑后面,但他应该为学校学习简单的算术 :D 我想制作以下程序: 他启动了他的电脑 他需要做一些简单的练习并完成 如果他做对了 x 次,他可以继续
有人能告诉我如何在 diff 主机(计算机)上为 MySQL 数据库做一个简单的数据库备份吗?我正在尝试将我的数据库从一台主机(服务器)移动到一台新主机(服务器) 最佳答案 如果您只是需要在服务器之间
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,因
我正在尝试让 Android 应用程序使用 USB 电缆与运行 ubuntu 12.04 lts 的 Linux 计算机进行通信。我正在尝试使用 usbdeviceconnection 类,但是当我通
我刚刚使用 docker-toolbox 1.8.2 安装了 docker在 Windows 10 上。 由于由于this issue我不得不使用这些命令重新创建 docker 镜像 docker-m
如何删除处于 GURU_MEDITATION 错误状态的 VirtualBox 计算机?在 VirtualBox 未运行时删除该目录是否足够? 编辑:发布后,我删除了“在文件管理器中显示”导航到的整个
当我们在 Azure 机器学习服务中将模型部署为 ACIWebService 时,不需要指定任何 deployment_target。 根据AzureML documentation对于 azurem
当我们在 Azure 机器学习服务中将模型部署为 ACIWebService 时,不需要指定任何 deployment_target。 根据AzureML documentation对于 azurem
我遇到的主要问题是当我选择 stay 时会发生什么上hand_one ,然后 hit上hand_two . 而不是让我hit or stay上hand_two再次,它让我回到hit or stay上h
我知道我可以使用 putty 来 ssh 进入每台 Linux 机器并更新 CentOS 服务器...但我希望有人能够为我指明正确的方向,告诉我如何通过 PowerShell 或 Windows 中的
在 MIX 计算机中,一个单词由五个字节和一个符号组成。符号在内存中是如何表示的?是另一个字节,所以每个字真的是六个字节吗? 谢谢。 最佳答案 你的问题不是很清楚。体系结构规范未指定实际实现。它仅指定
我是 Python 的初级程序员,我的电脑有一个奇怪的问题。当我的计算机上有一个 .py 文件(包含一个有效的脚本)并双击它打开时,会发生以下情况:程序打开(它是黑屏 View ),但它会在一秒钟内自
我正在尝试在 Windows 上使用 plink 创建到 Linux 机器的隧道,并让转储文件最终出现在 Windows 机器上。看起来 this answer会工作,是我的问题的基础。但是尝试一下并
我想在 Windows 7 和 10 计算机上执行重启,但我首先需要将 Jenkins 节点暂时离线。在执行重启之前,我需要完成所有正在运行的任务。然后我远程登录到服务器并重新启动计算机。然而,在我重
我正在编写一个简单的程序,从 MySQL 数据库中提取计算机名称,然后将这些名称存储到字符串数组列表中(这部分工作正常)。之后,我编写了一个类和一个方法,将字符串作为参数(这将是计算机名称)并尝试对其
我是一名优秀的程序员,十分优秀!