可分离滤波器设计高斯滤波 CUDA程序优化, 实验记录
环境:RTX2060 ,1920X1080p ,循环10次, kernal_size=8
一 、测试前128个线程拷贝到dst数据的性能 ,只测试行卷积, block=(128+2r)X1
1. 使用中间128个线程拷贝 : (36.37+37.11+36.32)/3 = 36.6 GB
2. 改为前128个线程拷贝出数据: (38.89+39.53+39.74)/3 = 39.39GB
实验结果:使用前128个线程拷贝会快10.7%
二 、 测试const 变量对性能的影响 ,只测试行卷积 block =(128+2r)X1
1. radius 为局部变量(函数传入) 40.1 GB
2. radius 为__constant__ 变量 , 40.2GB
实验结果 __constant__ 和 局部变量 的性能实际上差不多
三、 测试block 线程数对性能的影响, 只测试行卷积
1. block = (64+2r)X1 37.10GB
2. block = (128+2r)X1 40.33GB
3. block = (256+2r)X1 37.75GB
4. block = (512+2r)X1 28.31GB
5. block = (128)X1 37.3GB
6. block=(320+2r)X1 34.26GB
7. block=320X1 39GB
8.block=160X1 38.57GB
9.block=(160+2r)X1 39.04GB
10 block=(640+2r)X1 30.34GB
11 block=640X1 27.96GB
实验结果 : block并不是越大越好, 选择 block = (128+2r)X1 可能好一点吧~
四、列卷积时候, 测试连续copy 和 跳步copy性能,只测试列卷积,行卷积注释掉
1. 跳步copy :45.11GB
2. 行连续copy:36.98GB
3 列连续copy:47.31GB
下图分别是1,2,3的拷贝过程示意图
实验结果: 使用第三种拷贝方式会加速4.9%
五、 使用单列拷贝 ,只测试列卷积
1. block=(128+2r)X1 18.89GB
实验结果: 使用单列进行计算会很慢
六 、 测试IMUL对性能的影响
1. 无IMUL 28.30GB
2. IMUL 28.38GB
实验结果 IMUL对实验结果无影响
七 、测试float4 对性能的影响,只测试行卷积
1. 无float4
2. float4
八 、列卷积时候, 测试连续计算 和 跳步计算性能,行卷积没有注释
连续计算 23.7GB
跳步计算 28.7 GB
实验结果: 跳步计算要快一些
可分离滤波器设计高斯滤波 CUDA程序优化, 实验记录的更多相关文章
- opencv 源码分析 CUDA可分离滤波器设计 ( 发现OpenCV的cuda真TM慢 )
1. 主函数 void SeparableLinearFilter::apply(InputArray _src, OutputArray _dst, Stream& _stream) { G ...
- 学习 opencv---(7) 线性邻域滤波专场:方框滤波,均值滤波,高斯滤波
本篇文章中,我们一起仔细探讨了OpenCV图像处理技术中比较热门的图像滤波操作.图像滤波系列文章浅墨准备花两次更新的时间来讲,此为上篇,为大家剖析了"方框滤波","均值滤 ...
- 滤波器——BoxBlur均值滤波及其快速实现
个人博客地址:滤波器--BoxBlur均值滤波及其快速实现 动机:卷积核.滤波器.卷积.相关 在数字图像处理的语境里,图像一般是二维或三维的矩阵,卷积核(kernel)和滤波器(filter)通常指代 ...
- matlab做gaussian高斯滤波
原文链接:https://blog.csdn.net/humanking7/article/details/46826105 核心提示 在Matlab中高斯滤波非常方便,主要涉及到下面两个函数: 函数 ...
- CUDA性能优化----warp深度解析
本文转自:http://blog.163.com/wujiaxing009@126/blog/static/71988399201701224540201/ 1.引言 CUDA性能优化----sp, ...
- SIFT四部曲之——高斯滤波
本文为原创作品,未经本人同意,禁止转载 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing/ 或 ...
- 一步步做程序优化-讲一个用于OpenACC优化的程序(转载)
一步步做程序优化[1]讲一个用于OpenACC优化的程序 分析下A,B,C为三个矩阵,A为m*n维,B为n*k维,C为m*k维,用A和B来计算C,计算方法是:C = alpha*A*B + beta* ...
- Java 程序优化 (读书笔记)
--From : JAVA程序性能优化 (葛一鸣,清华大学出版社,2012/10第一版) 1. java性能调优概述 1.1 性能概述 程序性能: 执行速度,内存分配,启动时间, 负载承受能力. 性能 ...
- Atitit 图像处理 平滑 也称 模糊, 归一化块滤波、高斯滤波、中值滤波、双边滤波)
Atitit 图像处理 平滑 也称 模糊, 归一化块滤波.高斯滤波.中值滤波.双边滤波) 是一项简单且使用频率很高的图像处理方法 用途 去噪 去雾 各种线性滤波器对图像进行平滑处理,相关OpenC ...
随机推荐
- 获取当前服务的IP和端口号
package com.movitech.product.datahub.util; import org.slf4j.Logger; import org.slf4j.LoggerFactory; ...
- Win7下安装VS2017、安装Qt5.10.1以及在VS2017添加qt插件
一.安装VS2017 1.下载VS2017 进入vs下载官网https://www.visualstudio.com/zh-hans/downloads/,选择所需要的vs版本,进行在线安装. 2.安 ...
- 如何SpringBoot项目改为外置Tomcat启动
正常情况下,我们开发 SpringBoot 项目,由于内置了Tomcat,所以项目可以直接启动,部署到服务器的时候,直接打成 jar 包,就可以运行了 (使用内置 Tomcat 的话,可以在 appl ...
- 011 @Retryable的使用
一:概述 在调用第三方接口或者使用mq时,会出现网络抖动,连接超时等网络异常,所以需要重试. 为了使处理更加健壮并且不太容易出现故障,后续的尝试操作,有时候会帮助失败的操作最后执行成功. 例如,由于网 ...
- meta name="location" 标签的使用
在进行一些操作的时候,我们可能会用到这个标签来什么,地理位置,不错的网站优化标签. <meta name="location" content="province= ...
- 【原创】MongoDB安装配置详解(标注两个坑)
1.下载安装 3.4正式版([坑]不要最新版,有可能进度卡在这个位置不动,等了半个小时也没什么反映,) http://downloads.mongodb.org/win32/mongodb-win32 ...
- [python语法]python中如何判断一个集合是另一个集合的子集?
问:python中如何判断一个集合是另一个集合的子集? 答:用issubset()方法 语法: A.issubset(B) 返回: True 如果A是B的子集. False 如果A不是B的子集. 样例 ...
- PAT 甲级 1077 Kuchiguse (20 分)(简单,找最大相同后缀)
1077 Kuchiguse (20 分) The Japanese language is notorious for its sentence ending particles. Person ...
- vue强制刷新组件 ----组件重置到初始状态
把一个组件重置到初始状态是一个常见的需求,推荐的做法有两种,一种是父组件重置子组件的 prop,另一种是子组件暴露一个重置的方法供父组件调用.但有些时候,子组件既没有提供重置的方法,也没提供 prop ...
- android基础---->SharedPreferences的使用
SharedPreferences 还支持多种不同的数据类型存储,如果存储的数据类型是整型,那么读取出来的数据也是整型的,存储的数据是一个字符串,读取出来的数据仍然是字符串.这样你应该就能明显地感觉到 ...