我对以下问题有疑问:
假设我们有一张 9*7 的图片(x 方向上 7 个像素,y 方向上 9 个像素),假设 4*4 线程块和每个 warp 8 个线程,有多少个 warp 将具有控制散度?
块和经线将如何组织在这里?对于 x 或水平方向,我可以假设每行 2 个块。类似地,对于垂直方向,每列 3 个块。但是,经线将如何组织?有人可以指出扭曲的线程ID,以及发生控制分歧的情况(线程ID等)。
谢谢
假设我们有一张 9*7 的图片(x 方向上 7 个像素,y 方向上 9 个像素),假设 4*4 线程块和每个 warp 8 个线程,有多少个 warp 将具有控制散度?
块和经线将如何组织在这里?对于 x 或水平方向,我可以假设每行 2 个块。类似地,对于垂直方向,每列 3 个块。但是,经线将如何组织?
我会坚持你的例子,并尝试提供线程 ID、块 ID、warp ID 的模式。请记住,这种布局实际上在 CUDA 硬件上是不可能的。
Image Global Thread IDs Block IDs Local Thread IDs
□□□□□□□ | 00 01 02 03 04 05 06 | 00 00 00 00 00 00 00 | 00 01 02 03 04 05 06
□□□□□□□ | 07 08 09 10 11 12 13 | 00 00 00 00 00 00 00 | 07 08 09 10 11 12 13
□□□□□□□ | 14 15 16 17 18 19 20 | 00 00 01 01 01 01 01 | 14 15 00 01 02 03 04
□□□□□□□ | 21 22 23 24 25 26 27 | 01 01 01 01 01 01 01 | 05 06 07 08 09 10 11
□□□□□□□ | 28 29 30 31 32 33 34 | 01 01 01 01 02 02 02 | 12 13 14 15 00 01 02
□□□□□□□ | 35 36 37 38 39 40 41 | 02 02 02 02 02 02 02 | 03 04 05 06 07 08 09
□□□□□□□ | 42 43 44 45 46 47 48 | 02 02 02 02 02 02 03 | 10 11 12 13 14 15 00
□□□□□□□ | 49 50 51 52 53 54 55 | 03 03 03 03 03 03 03 | 01 02 03 04 05 06 07
□□□□□□□ | 56 57 58 59 60 61 62 | 03 03 03 03 03 03 03 | 08 09 10 11 12 13 14
----------------------------------------------------------------------------
Image Global Warp IDs Block IDs Local Warp IDs
□□□□□□□ | 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00
□□□□□□□ | 00 01 01 01 01 01 01 | 00 00 00 00 00 00 00 | 00 01 01 01 01 01 01
□□□□□□□ | 01 01 02 02 02 02 02 | 00 00 01 01 01 01 01 | 01 01 00 00 00 00 00
□□□□□□□ | 02 02 02 03 03 03 03 | 01 01 01 01 01 01 01 | 00 00 00 01 01 01 01
□□□□□□□ | 03 03 03 03 04 04 04 | 01 01 01 01 02 02 02 | 01 01 01 01 00 00 00
□□□□□□□ | 04 04 04 04 04 05 05 | 02 02 02 02 02 02 02 | 00 00 00 00 00 01 01
□□□□□□□ | 05 05 05 05 05 05 06 | 02 02 02 02 02 02 03 | 01 01 01 01 01 01 00
□□□□□□□ | 06 06 06 06 06 06 06 | 03 03 03 03 03 03 03 | 00 00 00 00 00 00 00
□□□□□□□ | 07 07 07 07 07 07 07 | 03 03 03 03 03 03 03 | 01 01 01 01 01 01 01
----------------------------------------------------------------------------
以及发生控制分歧的情况(线程ID等)
如上所述,分歧是代码的属性而不是线程布局,没有代码就无法回答这个问题。