- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
好的,让我们考虑一个 64 位的数字,它的位组成一个 8x8 的表。
例如
0 1 1 0 1 0 1 0 0 1 1 0 1 0 1 1 0 1 1 1 1 0 1 0 0 1 1 0 1 0 1 0 1 1 1 0 1 0 1 0 0 1 1 0 1 0 1 0 0 1 1 0 1 1 1 0 0 1 1 0 1 0 1 0
写成
a b c d e f g h
----------------
0 1 1 0 1 0 1 0
0 1 1 0 1 0 1 1
0 1 1 1 1 0 1 0
0 1 1 0 1 0 1 0
1 1 1 0 1 0 1 0
0 1 1 0 1 0 1 0
0 1 1 0 1 1 1 0
0 1 1 0 1 0 1 0
现在,如果我们只想隔离例如d 列(00100000
)(或任何行/对角线)?
这可以做到吗?如果可以,怎么做?
提示:
(a) 我在这里的主要目标——虽然最初没有提到——是原始速度。我正在寻找最快的算法,因为“检索”功能正在执行数百万次每秒。
(b) 这更接近我的意思:https://www.chessprogramming.org/Kindergarten_Bitboards
最佳答案
这是一个只有 4 个主要步骤的解决方案:
const uint64_t column_mask = 0x8080808080808080ull;
const uint64_t magic = 0x2040810204081ull;
int get_col(uint64_t board, int col) {
uint64_t column = (board << col) & column_mask;
column *= magic;
return (column >> 56) & 0xff;
}
它是这样工作的:
选择魔数(Magic Number)以仅复制所需的位,并让其余的位落入未使用的位置/溢出该数字。这个过程看起来像这样(数字是位“ID”,而不是数字本身):
original column: ...1.......2.......3.......4.......5.......6.......7.......8....
aligned column: 1.......2.......3.......4.......5.......6.......7.......8.......
multiplied: 123456782345678.345678..45678...5678....678.....78......8.......
shifted to right:........................................................12345678
如果你添加 const
关键字,汇编实际上变得非常好:
get_col:
.LFB7:
.cfi_startproc
movl %esi, %ecx
movabsq $-9187201950435737472, %rax
salq %cl, %rdi
andq %rax, %rdi
movabsq $567382630219905, %rax
imulq %rax, %rdi
shrq $56, %rdi
movl %edi, %eax
ret
无分支,无外部数据,每次计算大约 0.4ns。
编辑:使用 NPE 的解决方案作为基线大约需要 6 分之一的时间(下一个最快的)
关于c++ - "Isolate"来自 64 位数字的特定行/列/对角线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14537831/
来自文档: Isolation.DEFAULT Use the default isolation level of the underlying datastore. 对于其他隔离级别,我们可以在
@Transactional(isolation = Isolation.SERIALIZABLE) 我在我的 spring 项目中的几个方法上有这个注释。如果由于“序列化访问问题”而出现异常,如果我
到目前为止我发现的“隔离”的解释。 实验#1:http://izs.me/v8-docs/classv8_1_1Isolate.html “Isolate 表示 V8 引擎的一个孤立实例。V8 分离株
我是单元测试和 Typemock 的新手。我想选择 typemock,因为我有很多遗留代码和很多依赖项。我知道 Isolator Basic 是免费版本,但他们也提供了 Isolator Comple
定义指令时,通常为它们提供一个独立的作用域,并且原型(prototype)上不会从任何父作用域继承。我一直很困惑这个术语应该是“隔离范围”还是“隔离范围”。 似乎大多数 AngularJS 官方文档都
$ pip install --no-build-isolation --editable . Usage: pip install [options] [package-index-opt
我有一个使用 mssql 的航类预订程序 ,对于预订航类,我想确定我应该使用隔离级别还是锁? (这是一个示例代码,我的问题是这种情况的隔离级别不做保留) 我的数据库有一个库存表,如: Inventor
我一直在玩 Dart Isolates并且在使用 isolate.pause(); 时遇到了问题功能。 import 'dart:io'; import 'dart:isolate'; main(){
隔离示例 flutter !不起作用。新的隔离不会运行。但是如果我删除入口点函数的 async。它工作正常。那么,如何在 flutter 中的新隔离中进行等待操作。 最佳答案 可能存在 Dart 2
当应用程序被杀死时,使用 flutter isolate 包的 Flutter isolates 不会显示通知。 尝试将 isolate 包与 dart:isolate 一起使用,但不起作用。 imp
据我了解,Dart 隔离就像 Akka Actor 。 然而,我想不通的是,如果 dart:isolate用途与 Akka 类似做。两者之间有根本区别吗? 是 dart:isolate一个 Actor
正如你们中的一些人所知道的,在 .net 中模拟静态方法通常是不可能的。 通过模拟,我的意思是用另一个具有相同签名的方法替换类中的方法,通常用于测试目的。 用于模拟方法的两种主要方法是将其声明为虚拟方
我有一个生成散列密码的应用程序,生成它需要时间。我认为为了提高性能,我会让散列密码生成器在一个单独的核心中工作。我的计算机支持 3 个核心处理器,我认为使用 dart:isolate 来计算其他处理器
我正在尝试在Dart Web应用程序中使用隔离,但是我似乎无法使错误回调参数起作用。 我有一个非常基本的代码正在Dartium中运行。 import "dart:isolate"; void main
我正在试验 Dart 并使用新的 streamSpawnFunction 创建一个新的隔离。 我在 Dartium 中运行我的代码,但我注意到如果在隔离中发生某种不可恢复的错误,我不会在控制台上收到任
我的问题的背景:我正在开发一个 Flutter 应用程序,它每隔几个小时执行一次重复的后台事件,并在有任何更新时通知用户。 目前,我已经创建了一个能够执行后台事件的隔离功能(但目前尚未安排),并且我正
我需要在 V8 中有数千个隔离物。但是当我有一些空闲 RAM 时,我遇到了奇怪的内存问题,但是 v8 抛出了 OOM 错误消息。 例如, 在这种特殊情况下,您可以看到当 V8 抛出此错误时我们仍然有一
我有大约 10k 个长时间运行的任务需要按顺序计算。为此,我决定使用 Isolates。问题是我应该每次都为每个单独的任务创建 spawn Isolate 还是应该为所有任务的执行只创建一个 Isol
Moles是微软创建的隔离框架。 Moles 的一个很酷的特性是它可以“模拟”静态/非虚拟方法和密封类(这对于像 Moq 这样的框架是不可能的)。下面是 Moles 可以做什么的快速演示: Asser
谁能解释一下垃圾收集的孤立岛的概念吗? 最佳答案 对象 A 引用对象 B。对象 B 引用对象 A。对象 A 和对象 B 都没有被任何其他对象引用。那是一座孤岛。 基本上,隔离岛是一组相互引用但不被应用
我是一名优秀的程序员,十分优秀!