// GNU C++ SIMD Within A Register (SWAR) example for x86 // Uses GCC vector extensions (works with g++) // // Compile with: // g++ -O2 -msse2 simd_gnu.cpp -o simd_gnu #include <iostream> // Define a 128-bit vector containing four 32-bit integers typedef float v4sf __attribute__((vector_size(16))); int main() { v4sf a = {1.0, 2.1, 3.2, 4.3}; v4sf b = {10, 20, 30, 40}; // SIMD addition happens in one instruction v4sf c = a + b; std::cout << "Results:\n"; for (int i = 0; i < 4; i++) { std::cout << a[i] << " + " << b[i] << " = " << c[i] << "\n"; } return 0; }