Automatic Vectorization of Interleaved Data Revisited

Author:

Anderson Andrew1,Malik Avinash2,Gregg David1

Affiliation:

1. Lero, Trinity College Dublin, Dublin, Ireland

2. University of Auckland, Auckland, New Zealand

Abstract

Automatically exploiting short vector instructions sets (SSE, AVX, NEON) is a critically important task for optimizing compilers. Vector instructions typically work best on data that is contiguous in memory, and operating on non-contiguous data requires additional work to gather and scatter the data. There are several varieties of non-contiguous access, including interleaved data access. An existing approach used by GCC generates extremely efficient code for loops with power-of-2 interleaving factors (strides). In this paper we propose a generalization of this approach that produces similar code for any compile-time constant interleaving factor. In addition, we propose several novel program transformations, which were made possible by our generalized representation of the problem. Experiments show that our approach achieves significant speedups for both power-of-2 and non--power-of-2 interleaving factors. Our vectorization approach results in mean speedups over scalar code of 1.77x on Intel SSE and 2.53x on Intel AVX2 in real-world benchmarking on a selection of BLAS Level 1 routines. On the same benchmark programs, GCC 5.0 achieves mean improvements of 1.43x on Intel SSE and 1.30x on Intel AVX2. In synthetic benchmarking on Intel SSE, our maximum improvement on data movement is over 4x for gathering operations and over 6x for scattering operations versus scalar code.

Funder

Irish Software Engineering Research Centre

Science Foundation Ireland

Publisher

Association for Computing Machinery (ACM)

Subject

Hardware and Architecture,Information Systems,Software

Cited by 16 articles. 订阅此论文施引文献 订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献

1. Autovesk: Automatic Vectorized Code Generation from Unstructured Static Kernels Using Graph Transformations;ACM Transactions on Architecture and Code Optimization;2023-12-15

2. Loner: utilizing the CPU vector datapath to process scalar integer data;Proceedings of the 31st ACM SIGPLAN International Conference on Compiler Construction;2022-03-18

3. Evaluation of Compilers’ Capability of Automatic Vectorization Based on Source Code Analysis;Scientific Programming;2021-11-30

4. Flynn’s Reconciliation;ACM Transactions on Architecture and Code Optimization;2021-06

5. PostSLP: Cross-Region Vectorization of Fully or Partially Vectorized Code;Languages and Compilers for Parallel Computing;2021

同舟云学术

1.学者识别学者识别

2.学术分析学术分析

3.人才评估人才评估

"同舟云学术"是以全球学者为主线,采集、加工和组织学术论文而形成的新型学术文献查询和分析系统,可以对全球学者进行文献检索和人才价值评估。用户可以通过关注某些学科领域的顶尖人物而持续追踪该领域的学科进展和研究前沿。经过近期的数据扩容,当前同舟云学术共收录了国内外主流学术期刊6万余种,收集的期刊论文及会议论文总量共计约1.5亿篇,并以每天添加12000余篇中外论文的速度递增。我们也可以为用户提供个性化、定制化的学者数据。欢迎来电咨询!咨询电话:010-8811{复制后删除}0370

www.globalauthorid.com

TOP

Copyright © 2019-2024 北京同舟云网络信息技术有限公司
京公网安备11010802033243号  京ICP备18003416号-3