Home | History | Annotate | Download | only in simd
      1 /*
      2  * AltiVec optimizations for libjpeg-turbo
      3  *
      4  * Copyright (C) 2014, D. R. Commander.  All Rights Reserved.
      5  *
      6  * This software is provided 'as-is', without any express or implied
      7  * warranty.  In no event will the authors be held liable for any damages
      8  * arising from the use of this software.
      9  *
     10  * Permission is granted to anyone to use this software for any purpose,
     11  * including commercial applications, and to alter it and redistribute it
     12  * freely, subject to the following restrictions:
     13  *
     14  * 1. The origin of this software must not be misrepresented; you must not
     15  *    claim that you wrote the original software. If you use this software
     16  *    in a product, an acknowledgment in the product documentation would be
     17  *    appreciated but is not required.
     18  * 2. Altered source versions must be plainly marked as such, and must not be
     19  *    misrepresented as being the original software.
     20  * 3. This notice may not be removed or altered from any source distribution.
     21  */
     22 
     23 /* RGB --> YCC CONVERSION */
     24 
     25 #include "jsimd_altivec.h"
     26 
     27 
     28 #define F_0_081 5329                 /* FIX(0.08131) */
     29 #define F_0_114 7471                 /* FIX(0.11400) */
     30 #define F_0_168 11059                /* FIX(0.16874) */
     31 #define F_0_250 16384                /* FIX(0.25000) */
     32 #define F_0_299 19595                /* FIX(0.29900) */
     33 #define F_0_331 21709                /* FIX(0.33126) */
     34 #define F_0_418 27439                /* FIX(0.41869) */
     35 #define F_0_500 32768                /* FIX(0.50000) */
     36 #define F_0_587 38470                /* FIX(0.58700) */
     37 #define F_0_337 (F_0_587 - F_0_250)  /* FIX(0.58700) - FIX(0.25000) */
     38 
     39 #define SCALEBITS 16
     40 #define ONE_HALF (1 << (SCALEBITS - 1))
     41 
     42 
     43 #define RGBG_INDEX0 {0,1,3,4,6,7,9,10,2,1,5,4,8,7,11,10}
     44 #define RGBG_INDEX1 {12,13,15,16,18,19,21,22,14,13,17,16,20,19,23,22}
     45 #define RGBG_INDEX2 {8,9,11,12,14,15,17,18,10,9,13,12,16,15,19,18}
     46 #define RGBG_INDEX3 {4,5,7,8,10,11,13,14,6,5,9,8,12,11,15,14}
     47 #include "jccolext-altivec.c"
     48 #undef RGB_PIXELSIZE
     49 
     50 #define RGB_PIXELSIZE EXT_RGB_PIXELSIZE
     51 #define jsimd_rgb_ycc_convert_altivec jsimd_extrgb_ycc_convert_altivec
     52 #include "jccolext-altivec.c"
     53 #undef RGB_PIXELSIZE
     54 #undef RGBG_INDEX0
     55 #undef RGBG_INDEX1
     56 #undef RGBG_INDEX2
     57 #undef RGBG_INDEX3
     58 #undef jsimd_rgb_ycc_convert_altivec
     59 
     60 #define RGB_PIXELSIZE EXT_RGBX_PIXELSIZE
     61 #define RGBG_INDEX {0,1,4,5,8,9,12,13,2,1,6,5,10,9,14,13}
     62 #define jsimd_rgb_ycc_convert_altivec jsimd_extrgbx_ycc_convert_altivec
     63 #include "jccolext-altivec.c"
     64 #undef RGB_PIXELSIZE
     65 #undef RGBG_INDEX
     66 #undef jsimd_rgb_ycc_convert_altivec
     67 
     68 #define RGB_PIXELSIZE EXT_BGR_PIXELSIZE
     69 #define RGBG_INDEX0 {2,1,5,4,8,7,11,10,0,1,3,4,6,7,9,10}
     70 #define RGBG_INDEX1 {14,13,17,16,20,19,23,22,12,13,15,16,18,19,21,22}
     71 #define RGBG_INDEX2 {10,9,13,12,16,15,19,18,8,9,11,12,14,15,17,18}
     72 #define RGBG_INDEX3 {6,5,9,8,12,11,15,14,4,5,7,8,10,11,13,14}
     73 #define jsimd_rgb_ycc_convert_altivec jsimd_extbgr_ycc_convert_altivec
     74 #include "jccolext-altivec.c"
     75 #undef RGB_PIXELSIZE
     76 #undef RGBG_INDEX0
     77 #undef RGBG_INDEX1
     78 #undef RGBG_INDEX2
     79 #undef RGBG_INDEX3
     80 #undef jsimd_rgb_ycc_convert_altivec
     81 
     82 #define RGB_PIXELSIZE EXT_BGRX_PIXELSIZE
     83 #define RGBG_INDEX {2,1,6,5,10,9,14,13,0,1,4,5,8,9,12,13}
     84 #define jsimd_rgb_ycc_convert_altivec jsimd_extbgrx_ycc_convert_altivec
     85 #include "jccolext-altivec.c"
     86 #undef RGB_PIXELSIZE
     87 #undef RGBG_INDEX
     88 #undef jsimd_rgb_ycc_convert_altivec
     89 
     90 #define RGB_PIXELSIZE EXT_XBGR_PIXELSIZE
     91 #define RGBG_INDEX {3,2,7,6,11,10,15,14,1,2,5,6,9,10,13,14}
     92 #define jsimd_rgb_ycc_convert_altivec jsimd_extxbgr_ycc_convert_altivec
     93 #include "jccolext-altivec.c"
     94 #undef RGB_PIXELSIZE
     95 #undef RGBG_INDEX
     96 #undef jsimd_rgb_ycc_convert_altivec
     97 
     98 #define RGB_PIXELSIZE EXT_XRGB_PIXELSIZE
     99 #define RGBG_INDEX {1,2,5,6,9,10,13,14,3,2,7,6,11,10,15,14}
    100 #define jsimd_rgb_ycc_convert_altivec jsimd_extxrgb_ycc_convert_altivec
    101 #include "jccolext-altivec.c"
    102 #undef RGB_PIXELSIZE
    103 #undef RGBG_INDEX
    104 #undef jsimd_rgb_ycc_convert_altivec
    105