摘要
当使用高分辨率的图像作为图像处理算法的输入时会降低算法运行速度,将算法并行化可提升执行效率,但手动将串行程序转换为并行程序则较为繁琐,并且现有自动并行翻译工具性能不稳定,同时翻译后的程序是单一并行模式。面向基于面片的三维多视角立体视觉(PMVS)算法,提出一种从C到CUDA的自动两级并行翻译方法。使用ANTLR自动解析源C代码,通过分析数据依赖关系和循环数组私有化来识别可并行化的循环结构,将算法翻译成CPU多线程和GPU两级并行结构的代码。在算法执行过程中,将输入图像在CPU和GPU上分别进行处理,降低了算法总执行时间。实验结果表明,该方法的计算加速比随着输入图像分辨率的增加逐渐提高,最高约达到32,相比于PPCG和OpenACC自动并行翻译方法提升明显。
Currently,the calculation speed of the image processing algorithm is very slow when high-resolution images are used as input data.Although parallelizing the algorithm can improve its execution efficiency,the manual conversion of serial programs to parallel programs is tedious.Moreover,current automatic parallel translation tools are not scalable,and the translated program is in single parallel mode.To solve this problem,this study proposes an automatic two-level parallel translation method from C to CUDA for the Patch-based Multiple View Stereo(PMVS)algorithm,using Another Tool for Language Recognition(ANTLR)to automatically parse the source C code and identify the parallelizable loop structures by analyzing data dependencies and loop array privatization.Additionally,the loop structure of the algorithm is translated into a two-level parallel structure that includes CPU multithreading and the GPU.When the algorithm is executed,the input image is divided into two parts:one part is processed by the CPU’s multithreaded code,and the other part is processed by the GPU code,thereby reducing the total execution time of the algorithm.The experimental results show that an increase in the input image resolutions gradually improves the performance of the proposed method,and the maximum speedup ratio can reach approximately 32.Moreover,the proposed method has a significantly higher speed compared with the automatic Polyhedral Parallel Code Generation(PPCG)and OpenACC translation methods.
作者
刘金硕
黄朔
邓娟
LIU Jinshuo;HUANG Shuo;DENG Juan(Key Laboratory of Aerospace Information Security and Trusted Computing,Ministry of Education,School of Cyber Science and Engineering,Wuhan University,Wuhan 430072,China;School of Computer Science,Wuhan University,Wuhan 430072,China)
出处
《计算机工程》
CAS
CSCD
北大核心
2022年第12期16-23,共8页
Computer Engineering
基金
国家自然科学基金(61672393,U1936107)。