Arm command Optimization-coding for neon-Part 5: rearranging Vectors

Source: Internet
Author: User

Introduction

When writing code for neon, you may find that sometimes, the data in your registers are not quite in the correct format for your algorithm. you may need to rearrange the elements in your vectors so that subsequent arithmetic can add the correct parts together,
Or perhaps the data passed to your function is in a strange format, and must be reordered before your speedy SIMD code can handle it.

This reordering operation is calledPermutation. Permutation instructions rearrange individual elements, selected from single or multiple registers, to form a new vector.

Before we begin

Before you dive into using the permutation instructions provided by neon, consider whether you really need to use them. permutation instructions are similar to move instructions, in that they often represent CPU cycles consumed preparing data, rather than Processing
It. Your code is not speed optimal until it uses the fewest number of cycles to complete a task; move and permute instructions are often good areas to target optimization.

Alternatives

How do you avoid unnecessary permutes? There are a number of options:

  • Rearrange your input data.It often costs nothing to store your data in a more appropriate format, avoiding the need to permute on load and store. However, consider Data Locality,
    And its effect on Cache performance before changing your data structures.
  • Redesign your algorithm.A different algorithm may be available that uses a similar number of processing steps, but can handle data in a different format.
  • Modify the previous processing stage.A small change to an earlier processing stage, adjusting the way in which data is stored to memory, may reduce or eliminate the need for permutation operations.
  • Use interleaving loads and stores.As we 've seen previusly, load
    And store instructions have the ability To interleave and deinterleave. Even if this doesn't completely eliminate the need to permute, it can reduce the number of additional instructions you need.
  • Combine approaches.Using more than one of these techniques can be still be more efficient than additional Permutation instructions.

If you have considered all of these, but none put your data in a more suitable format, try using the permutation instructions.

Instructions

Neon provides a range of permutation instructions, from basic reversals to arbitrary vector reconstruction. simple permutations can be achieved using instructions that take a single cycle to issue, whereas the more complex operations use multiple cycles, and
May require additional registers to be set up. As always, benchmark or
Profile your code regularly, and check your processor's Technical Reference Manual (Cortex-A8, Cortex-A9)
For performance details.

Vmov and vswp: Move and swap

Vmov and vswp are the simplest permute instructions, copying the contents of an entire register to another, or swapping the values in a pair of registers.

Although you may not regard them as permute instructions, they can be used to change the values in the two d registers that make up a Q register. For example,VSWP d0, d1SWAps
The most and least-significant 64-bits of Q0.

Vrev: reverse

Vrev reverses the order of 8, 16 or 32-bit elements within a vector. There are three variants:

  • Vrev16Reverses each pair of 8-bit sub-elements making up 16-bit elements within a vector.
  • Vrev32Reverses the four 8-bit or two 16-bit sub-elements making up 32-bit elements within a vector.
  • Vrev64Reverses eight 8-bit, four 16-bit or two 32-bit elements in a vector.

Use vrev to reverse the endianness of data, rearrange color components or exchange channels of audio samples.

Vext: Extract

Vext extracts a new vector of bytes from a pair of existing vectors. the bytes in the new vector are from the top of the first operand, and the bottom of the second operand. this allows you to produce a new vector containing elements that straddle a pair
Existing vectors.

Vext can be used to implement a moving window on data from two vectors, useful in FIR filters. for permutation, it can also be used to simulate a byte-wise rotate operation, when using the same vector for both input operands.

Vtrn: transpose

Vtrn transposes 8, 16 or 32-bit elements between a pair of vectors. It treats the elements of the vectors as 2x2 matrices, and transposes each matrix.

Use multiple vtrn instructions to transpose larger matrices. For example, a 4x4 matrix consisting of 16-bit elements can be transposed using three vtrn instructions.

This is the same operation completed MED by vld4 and vst4 after
Loading, or before storing, vectors. As they require fewer instructions, try to use these structured memory access features in preference to a sequence of vtrn instructions, where possible.

Vzip and vuzp: Zip and unzip

Vzip interleaves the 8, 16 or 32-bit elements of a pair of vectors. the operation is the same as that stored med by vst2 before storing, so use vst2 rather than vzip if you need to zip data immediately before writing back to memory.

Vuzp is the inverse of vzip, deinterleaving the 8, 16, or 32-bit elements of a pair of vectors. The operation is the same as that stored med by vld2 after loading from memory.

Vtbl, vtbx: Table and table extend

Vtbl constructs a new vector from a table of vectors and an index vector. It is a byte-wise table lookup operation.

The table consists of one to four adjacent D registers. each byte in the index vector is used to index a byte in the table of vectors. the indexed value is inserted into the result vector at the position corresponding to the location of the original index in
The Index Vector.

Vtbl and vtbx differ in the way that out-of-range indexes are handled. if an index exceeds the length of the table, vtbl inserts zero at the corresponding position in the result vector, but vtbx leaves the value in the result vector unchanged.

If you use a single source vector as the table, vtbl allows you to implement an arbitrary permutation of a vector, at the expense of setting up an index register. if the operation is used in a loop, and the type of permutation doesn't change, you can initialize
The index register outside the loop, and remove the setup overhead.

Others

Although there are other methods to achieve permute-like operations, such as using load and store instructions to operate on single vector elements, the repeated memory accesses that these require makes them significantly slower, and so they are not recommended.

Conclusion

It is wise to consider carefully whether your code really needs to permute your data. However, when your requires it, permute instructions provide an efficient method to get your data into the right format.

The topic for the next post in the coding for Neon series has not been decided, so if you have ideas for neon-related topics that you wowould like me to cover, please suggest them in the comments below.

Martyn is a staff software engineer in the processor division,And has been at arm for almost 10 years. He works on improving software performance and experience on arm platforms.
He's interested in software optimization using assembly language and SIMD, FIG in the areas of graphics and multimedia.

 

From:

Http://blogs.arm.com/software-enablement/684-coding-for-neon-part-5-rearranging-vectors/

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.