当前位置: 首页 > wzjs >正文

360建筑网官网下载平台网站优化方法

360建筑网官网下载平台,网站优化方法,网站地图无法生成,网站建设费用的会计分录纯概念的一节 5.1.1 共享内存 (Shared Memory) SMEM, 共享内存实际上是可受用户控制的一级缓存。每个SM中,一级缓存和共享内存共享一个64KB的内存段 。 相较于二级缓存和全局内存,共享内存和一级缓存在物理上更接近SM。因此,共享内存相较于全…

纯概念的一节
5.1.1 共享内存
(Shared Memory) SMEM, 共享内存实际上是可受用户控制的一级缓存。每个SM中,一级缓存和共享内存共享一个64KB的内存段 。
相较于二级缓存和全局内存,共享内存和一级缓存在物理上更接近SM。因此,共享内存相较于全局内存而言,延迟要低大约20~30倍,而带宽高其大约10倍。
当每个线程块开始执行时,会分配给它一定数量的共享内存。这个共享内存的地址空
间被线程块中所有的线程共享。它的内容和创建时所在的线程块具有相同生命周期。共享内存被SM中的所有常驻线程块划分,因此,共享内存是限制设备并行性的关键资源。一个核函数使用的共享内存越多,处于并发活跃状态的线程块就越少。

在设备上启动的核函数配置一级缓存和共享内存的大小:

cudaError_t cudaDeviceSetCacheConfig(cudaFuncCache cacheConfig);
/* cacheConfig支持的参数
cudaFuncCachePreferNone   --  no prefer (default)
cudaFuncCachePreferShared --  48KB SMEM 16KB L1 cache
cudaFuncCachePreferL1 --  48KB l1 and  16KB SMEM
cudaFuncCachePreferEqual -- 32KB L1 Cache and 32KB SMEM
*/

那种模式更好:
·当核函数使用较多的共享内存时,倾向于更多的共享内存
·当核函数使用更多的寄存器时,倾向于更多的一级缓存

编译的时候加上 -Xptxas -v 可以知道核函数用了多少资源:
以上一篇转置问题代码为例:

nvcc transpose.cu -Xptxas -v -o transpose.exe

输出(部分):

ptxas info    : Used 9 registers, used 0 barriers, 344 bytes cmem[0]
ptxas info    : Compiling entry function '_Z19tranposediagonalRowPfS_ii' for 'sm_52'
ptxas info    : Function properties for _Z19tranposediagonalRowPfS_ii0 bytes stack frame, 0 bytes spill stores, 0 bytes spill loads

当内核使用的寄存器数量超过了硬件限制所允许的数量时,应该为寄存器溢出配置一个更大的一级缓存。

5.1.2 分配
共享内存用 shared 修饰符进行声明。
如果在核函数中进行声明,那么这个变量的作用域就局限在该内核中。如果在文件的任何核函数外进行声明,那么这个变量的作用域对所有核函数来说都是全局的。

5.1.3 共享内存存储体
为了获得高内存带宽,共享内存被分为32个同样大小的内存模型,它们被称为存储体,每个存储体可以存储8个字节大小的数据 (计算能力2.x为4位),它们可以被同时访问。有32个存储体是因为在一个线程束中有32个线程。

5.1.4 同步
同步是所有并行计算语言的重要机制。共享内存可以同时被线程块中的多个线程访问。当不同步的多个线程修改同一个共享内存地址时,将导致线程内的冲突。

同步的两个基本方法:
·障碍 – 所有调用的线程等待其余调用的线程到达障碍点
·内存栅栏 – 所有调用的线程必须等到全部内存修改对其余调用线程可见时才能继续执行

5.1.4.1 显示障碍
在CUDA中,障碍只能在同一线程块的线程间执行。核函数中,以下函数来指定障碍点

void __syncthreads();

要求块中的线程必须等待直到所有线程都到达该点。__syncthreads还确保在障碍点之前,被这些线程访问的所有全局和共享内存对同一块中的所有线程都可见。
下面的代码可能会导致块中的线程无限期地等待对方,因为块中的所有线程没有达到相同的障碍点。

if (threadId % 2 == 0){__syncthreads();
} else{__syncthreads();
}

如果一个CUDA核函数要求跨线程块全局同步,那么通过在同步点分割核函数并执行多个内核启动可能会达到预期的效果。

5.1.4.2 内存栅栏
内存栅栏的功能可确保栅栏前的任何内存写操作对栅栏后的其他线程都是可见的。根据所需范围,有3种内存栅栏:块、网格或系统。

void __threadfence_block();

5.1.4.3 Volatile修饰符
在全局或共享内存中使用volatile修饰符声明一个变量,可以防止编译器优化,编译器优化可能会将数据暂时缓存在寄存器或本地内存中。当使用volatile修饰符时,编译器假定任何其他线程在任何时间都可以更改或使用该变量的值。因此,这个变量的任何引用都会直接被编译到全局内存读指令或全局内存写指令中,它们都会忽略缓存.

5.1.4.4 存储体冲突
在共享内存中当多个地址请求落在相同的内存存储体中时,就会发生存储体冲突,这会导致请求被重复执行。
最优的并行访问模式:
在这里插入图片描述
随机访问模式:
每个线程访问不同的存储体,所以也没有存储体冲突。
在这里插入图片描述
几个线程访问同一存储体。对于这样一个请求,会产生两种可能的行为:
·如果线程访问同一个存储体中相同的地址,广播访问无冲突
·如果线程访问同一个存储体中不同的地址,会发生存储体冲突
在这里插入图片描述

http://www.dtcms.com/wzjs/19527.html

相关文章:

  • 跟男友做网站百度大搜是什么
  • 专门做批发的网站客户引流推广方案
  • 网站建设谁家好深圳全网营销哪里好
  • 如何做视频解析网站seo推广优势
  • 重庆做网站的网站接广告
  • 两个公司的网站建设浙江seo
  • wordpress做的网站效果sem竞价推广是什么
  • photoshop手机版深圳seo推广培训
  • 网站的漂浮广告怎么做国外推广渠道平台
  • 做网站怎么买域名网络营销的优化和推广方式
  • 网站设计素材网站郑州网络推广公司排名
  • 啊里云服务器怎么做网站win7优化大师免安装版
  • 国外网站顶部菜单设计怎么开发自己的小程序
  • 网站建设公司工作流程百度排名点击器
  • 弄个微信小程序多少钱大连seo顾问
  • 建设有一个网站需要什么个人网页设计作品模板
  • 网站后台如何添加附件新手运营从哪开始学
  • 本地安装网站快手刷粉网站推广
  • 医疗器械外贸网站建设营销平台有哪些
  • 佛山市公司网站制作嘉兴关键词优化报价
  • 没有备案的网站 公司服务器 查到会怎么样东莞网络推广培训
  • 做国内网站阿里云怎么样百度开店怎么收费
  • php网站后台源码百度站长平台
  • 闵行网络推广公司搜索引擎优化seo的英文全称是
  • 网站建设应当注意百度新闻首页
  • 建站公司联系电话企业培训考试平台官网
  • 网站营销的重要价值文员短期电脑培训
  • 工装公司排名前十苏州企业网站关键词优化
  • 网站如何做传输网盘网站seo优化方案策划书
  • 医药类网站建设评价saascrm国内免费pdf