- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
随着最近有关并行计算的大肆宣传,我一直在思考并行性、数字运算、集群等问题......
我开始阅读Learn You Some Erlang 。随着越来越多的人(包括我自己)学习,Erlang 以一种非常令人印象深刻、优雅的方式处理并发。
然后作者断言Erlang是not ideal for number crunching 。我可以理解像 Erlang 这样的语言会比 C 慢,但是并发模型似乎非常适合图像处理或矩阵乘法之类的事情,尽管作者明确表示不适合。
事情真的有那么糟糕吗? Erlang 的优势是否存在克服其局部速度劣势的临界点?正在采取什么措施来解决速度问题?
需要明确的是:我并不是想发起一场辩论;我只是想发起一场辩论。我只是想知道。
最佳答案
将并行性仅仅视为原始数字处理能力是错误的。 Erlang 比 GPU 或经典 super 计算机更接近集群计算机的工作方式。
在现代 GPU 和老式 super 计算机中,性能主要取决于矢量化算术、专用计算硬件以及处理单元之间的低延迟通信。由于通信延迟很低并且每个单独的计算单元都非常快,因此理想的使用模式是将数据加载到机器的 RAM 中并让它立即处理所有数据。此处理可能涉及节点之间传递的大量数据,如图像处理或 3D 中所发生的情况,其中需要执行大量 CPU 密集型任务来将数据从输入形式转换为输出形式。当您经常需要访问磁盘、网络或其他一些慢速 I/O channel 来获取数据时,这种类型的机器并不是一个好的选择。这会闲置至少一个昂贵的专用处理器,并且可能还会阻塞数据处理管道,因此其他任何事情也无法完成。
如果您的程序需要大量使用慢速 I/O channel ,更好的机器类型是具有许多廉价独立处理器的机器,例如集群。你可以在一台机器上运行 Erlang,在这种情况下,你会在该机器中得到类似于集群的东西,或者你可以轻松地在实际的硬件集群上运行它,在这种情况下,你有一个集群的集群。在这里,通信开销仍然使处理单元闲置,但由于每个计算硬件上都有许多处理单元运行,Erlang 可以立即切换到其他进程之一。如果碰巧有一整台机器坐在那里等待 I/O,硬件集群中的其他节点仍然可以独立运行。仅当通信开销如此之高以至于每个节点都在等待其他节点或一般 I/O 时,此模型才会崩溃,在这种情况下,您要么需要更快的 I/O 要么需要更多节点,而 Erlang 自然地利用了这两者的。
通信和控制系统是 Erlang 的理想应用,因为每个单独的处理任务只需要很少的 CPU,并且只是偶尔需要与其他处理节点通信。大多数时候,每个进程都是独立运行的,每个进程只占用一小部分 CPU 资源。这里最重要的是能够有效地处理数千个此类问题。
绝对需要经典 super 计算机的经典案例是天气预报。在这里,您将大气分成多个立方体,并进行物理模拟以了解每个立方体中发生的情况,但您不能使用集群,因为空气在每个立方体之间移动,因此每个立方体不断与其 6 个相邻的邻居进行通信。 (空气不会穿过立方体的边缘或角落,是无限细的,因此它不会与其他 20 个相邻的立方体通信。)在集群上运行它,无论是在其上运行 Erlang 还是其他系统,并且它立即变成 I/O 绑定(bind)。
关于performance - Erlang 的并行性何时克服了其在数值计算方面的弱点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1308527/
我正在开发一个 Java 脚本,为此我需要正则表达式来检查文本框中输入的文本是否应该是字母和数值的组合。 我尝试了 Java 脚本的 NaN 函数,但字符串的最小长度和最大长度应为 4,并以字母作为第
我给出了两个长方体,其中只有一个轴对齐(另外两个不需要对齐)和顶点坐标(在全局坐标系中),我知道它们相交。我正在寻找一种可以计算路口体积的算法。 为了检查交点,我使用了分离轴定理。 最佳答案 可以通过
我有一个类似这样的对象的 json 列表 [{ "something": "bla", "id": 2 }, { "something": "yes", "id": 1
这是一篇很长的文章,但请留在我身边... 我有一个字典,它将“PO”保存为Key,将“SO”保存为项目(在某些情况下,某个“PO”可能有多个“SO”) . 工作表中的我的 Excel 数据,字典在其中
我的问题是是否有办法使用 terms include在 numeric field在 elasticsearch aggregation . 我在 Elasticsearch 中对多个字段使用通用查询
我有一个 perl 代码片段 use JSON::XS; $a = {"john" => "123", "mary" => "456"}; print encode_json($a),"\n"; 输出
我想对 python 进行一个条件测试,以检查给定输入数字的值是否等于或小于 9,并且大于或等于 0。 number =input( "Please enter a number! :" ) Plea
我有一个这样的对象: var rock = { 5: 0.5, 0: 0.8, 10: 0.3, 2: 1.0, } 我有一个像 4.3 这样的数字,我需要前后数字的索引和值。在这个例子中我会
对于 iOS 中的 Objective-C: 如果我有一个字符串,如何读取单个字符的 unicode 数值? 例如,如果我的字符串是:“Δ”,unicode 字符是 U+0394,那么我如何读取该字符
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我有这样的数组 var arrayVal_Int = ["21", "53", "92", "79"]; var arrayVal_Alpha = ["John", "Christine", "L
就像标题暗示我需要做这样的事情...... $i++;//we all know this. $value = 'a'; increment($value);// i need this functi
我有一个文件,其中包含一些不同值的概率,例如: 1 0.1 2 0.05 3 0.05 4 0.2 5 0.4 6 0.2 我想使用此分布生成随机数。是否存在处理此问题的现有模块?自己编写代码相当简单
因此,我在从使用 RCPP 创建的函数返回值时遇到了一些问题。它只返回 NumericVector 的第一个值。问题是当我在自身内部调用函数并将 NumericVector 传递回 out 变量时。任
我有下面的数字 vector 模板类(用于数值计算的 vector )。我正在尝试使编写 D=A+B+C 成为可能,其中所有变量都是 Vector 对象。 A、B 和 C 不应修改。我的想法是使用 V
本文实例讲述了mysql常用函数。分享给大家供大家参考,具体如下: 本文内容: mysql函数的介绍 聚集函数 avg count max
我正在尝试使用 python(无关)为我的公司自动化一些事情,这就是我的问题。首先,我正在从邮箱中的特定文件夹创建数据框。(到这里没问题)” RangeIndex: 36 entries, 0 to
我在让 Angular ng-if 工作时遇到了一些麻烦。我希望我的 DOM 元素之一在 $scope.week = 1 时消失。 在我的 Controller 中我设置了 $scope.week =
我正在阅读 Ingersoll、Morton 和 Farris 撰写的 Taming Text,但我不明白 solr 的数字 trie 实现如何帮助搜索文本?我对 solr.TrieField fie
这个问题已经有答案了: What is the difference between client-side and server-side programming? (3 个回答) 已关闭 9 年前
我是一名优秀的程序员,十分优秀!