- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试采用我的代码来利用 MPI 共享内存。
为了让事情尽可能简单,假设我只有两个核心。核心A需要核心b的size_b数组,核心b需要核心a的size_a数组
在核心 A 上执行时,我可以执行以下操作吗?
call MPI_WIN_ALLOCATE_SHARED(size_a_in_BYTES, disp_unit, MPI_INFO_NULL, comm_shm, ptr, win_a, mpierr)
call C_F_pointer(ptr, fptr, (/size_a/))
和核心B
call MPI_WIN_ALLOCATE_SHARED(size_b_in_BYTES, disp_unit, MPI_INFO_NULL, comm_shm, ptr, win_b, mpierr)
call C_F_pointer(ptr, fptrb, (/size_b/))
现在假设我之后通过 MPI_SEND/RECV win_a 和 win_b 分别与核心 B 和核心 a 进行通信。现在的逻辑是按以下方式进行两个查询
核心A:
call MPI_WIN_SHARED_QUERY( win_b
& , rank_of_core_B
& , size_b
& , disp_unit
& , ptr_buf
& , mpierr )
call C_F_pointer(ptr_buf, fptr_query_A, (/size_b/))
核心B反之亦然
假设我知道在 Core B 中将我的指针 fptrb
指向一个数组,即
fptrb = GIVEN_ARRAY_OF_SIZEB
然后我是否能够通过访问 fptr_query_A
来检索 CORE a 中的内存
fptr_recv = fptr_query_A
其中 fptr_recv
是在核心 A 中声明的指针,与 fptr_query_A
我问这个是因为手册中并不清楚例程 MPI_WIN_ALLOCATE_SHARED
除了是 comm_shm 的集体之外,是否必须对所有共享内存核心具有相同的 win 和大小
请在回答时,我认为我的一些困惑源于以下
1) 当调用 MPI_WIN_ALLOCATE_SHARED
时,我是否将本地内存从调用处理器分配给共享环境,即共享通信组。
1.a) 如果是,则意味着每个处理器都声明了它想要共享的内容,并且从接收者(想要访问共享内存的处理器)的审查点,它调用了 MPI_WIN_SHARED_QUERY
知道处理器在内存中的哪个位置存储了它的可共享数据?
最后,如果后两点总体上有效,我不确定我是否理解如何执行 MPI_WIN_SHARED_QUERY
调用。
我的理解是 MPI_WIN_SHARED_QUERY( win, rank, size,disp_unit, baseptr)
win
是我们想要检索数据的任何核心的窗口,对于大小和等级。那么从本质上讲,这是否意味着我总是需要传达胜利和大小才能做出决定?
最佳答案
同时我已经能够自己回答这个问题,答案是
1) When calling MPI_WIN_ALLOCATE_SHARED am I allocating a local memory from the calling processor to the shared environment i.e. the shared communication group.
是的,每个 Rank 将分配一个单独的缓冲区,该缓冲区具有各自的大小,供共享通信器组中的所有其他 Rank 访问。即使 rank 不需要分配共享缓冲区,它也应该调用零大小的函数。
If yes, It then means that each processor declares what it wants to share and from the receiver's (the processor that wants to access shared memory) point of review, it make a call to MPI_WIN_SHARED_QUERY to know where in memory a processor has stored its shareable data?
我是这么理解的
My understanding is MPI_WIN_SHARED_QUERY( win, rank, size,disp_unit, baseptr) that win is the window of whatever core we want to retrieve the data, similarly for the size and rank. So essentially does that mean I always need to communicate the win and size in order to make that call?
由于所有 MPI 等级都必须调用 MPI_WIN_ALLOCATE_SHARED
,因此每个等级都将拥有自己的 MPI 句柄 win
。因此,您使用此句柄调用 MPI_WIN_SHARED_QUERY
以获得指向由 MPI 等级 rank
分配的共享缓冲区的指针。此函数还查询列的共享内存的大小。
关于fortran - Fortran 中具有不同窗口大小的 MPI 共享内存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55479776/
https://github.com/mattdiamond/Recorderjs/blob/master/recorder.js中的代码 我不明白 JavaScript 语法,比如 (functio
在 iOS 7 及更早版本中,如果我们想在应用程序中找到 topMostWindow,我们通常使用以下代码行 [[[UIApplication sharedApplication] windows]
我已经尝试解决这个问题很长一段时间了:我无法访问窗口的 url,因为它位于另一个域上..有一些解决方案吗? function login() { var cb = window.ope
是否可以将 FFMPEG 视频流传递到 C# 窗口?现在它在新窗口中作为新进程打开,我只是想将它传递给我自己的 SessionWindow。 此时我像这样执行ffplay: public void E
我有一个名为 x 的矩阵看起来像这样: pTime Close 1 1275087600 1.2268 2 1275264000 1.2264 3 1275264300 1.2
在编译时,发生搜索,grep搜索等,Emacs会在单独的窗口中创建一个新的缓冲区来显示结果,有没有自动跳转到那个窗口的方法?这很有用,因为我可以使用 n 和 p 而不是 M-g n 和 M-g p 移
我有一个启动 PowerShell 脚本的批处理文件。 批处理文件: START Powershell -executionpolicy RemoteSigned -noexit -file "MyS
我有一个基于菜单栏的应用程序,单击图标时会显示一个窗口。在 Mac OS X Lion 上一切正常,但由于某种原因,在 Snow Leopard 和早期版本的 Mac OS X 上会出现错误。任何时候
在 macOS 中,如何在 Xcode 和/或 Interface Builder 中创建带有“集成标题栏和工具栏”的窗口? 这是“宽标题栏”类型的窗口,已添加到 OS X 10.10 Yosemit
在浏览器 (Chrome) 中 JavaScript: var DataModler = { Data: { Something: 'value' }, Process: functi
我有 3 个 html 页面。第 1 页链接到第 2 页,第 2 页链接到第 3 页(为了简单起见)。 我希望页面 2 中的链接打开页面 3 并关闭页面 1(选项卡 1)。 据我了解,您无法使用 Ja
当点击“创建节点”按钮时,如何打开一个新的框架或窗口?我希望新框架包含一个文本字段和下拉菜单,以便用户可以选择一个选项。 Create node Search node
我有一个用户控件,用于编辑应用程序中的某些对象。 我最近遇到一个实例,我想弹出一个新的对话框(窗口)来托管此用户控件。 如何实例化新窗口并将需要设置的任何属性从窗口传递到用户控件? 感谢您的宝贵时间。
我有一个Observable,它发出许多对象,我想使用window或buffer操作对这些对象进行分组。但是,我不想指定count参数来确定窗口中应包含多少个对象,而是希望能够使用自定义条件。 例如,
我有以下代码,它打开一个新的 JavaFX 阶段(我们称之为窗口)。 openAlertBox.setOnAction(e -> { AlertBox alert = AlertBox
我要添加一个“在新窗口中打开”上下文菜单项,该菜单项将以新的UIScene打开我的应用程序文档之一。当然,我只想在实际上支持多个场景的设备上显示该菜单项。 目前,我只是在检查设备是否是使用旧设备的iP
我正在尝试创建一个 AIR 应用程序来记录应用程序的使用情况,使用 AIR 从系统获取信息的唯一简单方法是使用命令行工具和抓取 标准输出 . 我知道像 这样的工具顶部 和 ps 对于 OS X,但它们
所以我有这个简单的 turtle 螺旋制作器,我想知道是否有一种方法可以打印出由该程序创建的我的设计副本。 代码: import turtle x= float(input("Angle: ")) y
我正在编写一个 C# WPF 程序,它将文本消息发送到另一个程序的窗口。我有一个宏程序作为我的键盘驱动程序 (Logitech g15) 的一部分,它已经这样做了,尽管它不会将击键直接发送到进程,而是
我尝试使用以下代码通过 UDP 发送,但得到了奇怪的结果。 if((sendto(newSocket, sendBuf, totalLength, 0, (SOCKADDR *)&sendAd
我是一名优秀的程序员,十分优秀!