|
shun-iwasawa |
82a8f5 |
/*
|
|
shun-iwasawa |
82a8f5 |
* AltiVec optimizations for libjpeg-turbo
|
|
shun-iwasawa |
82a8f5 |
*
|
|
shun-iwasawa |
82a8f5 |
* Copyright (C) 2014, D. R. Commander. All Rights Reserved.
|
|
shun-iwasawa |
82a8f5 |
*
|
|
shun-iwasawa |
82a8f5 |
* This software is provided 'as-is', without any express or implied
|
|
shun-iwasawa |
82a8f5 |
* warranty. In no event will the authors be held liable for any damages
|
|
shun-iwasawa |
82a8f5 |
* arising from the use of this software.
|
|
shun-iwasawa |
82a8f5 |
*
|
|
shun-iwasawa |
82a8f5 |
* Permission is granted to anyone to use this software for any purpose,
|
|
shun-iwasawa |
82a8f5 |
* including commercial applications, and to alter it and redistribute it
|
|
shun-iwasawa |
82a8f5 |
* freely, subject to the following restrictions:
|
|
shun-iwasawa |
82a8f5 |
*
|
|
shun-iwasawa |
82a8f5 |
* 1. The origin of this software must not be misrepresented; you must not
|
|
shun-iwasawa |
82a8f5 |
* claim that you wrote the original software. If you use this software
|
|
shun-iwasawa |
82a8f5 |
* in a product, an acknowledgment in the product documentation would be
|
|
shun-iwasawa |
82a8f5 |
* appreciated but is not required.
|
|
shun-iwasawa |
82a8f5 |
* 2. Altered source versions must be plainly marked as such, and must not be
|
|
shun-iwasawa |
82a8f5 |
* misrepresented as being the original software.
|
|
shun-iwasawa |
82a8f5 |
* 3. This notice may not be removed or altered from any source distribution.
|
|
shun-iwasawa |
82a8f5 |
*/
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
/* RGB --> GRAYSCALE CONVERSION */
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#include "jsimd_altivec.h"
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define F_0_114 7471 /* FIX(0.11400) */
|
|
shun-iwasawa |
82a8f5 |
#define F_0_250 16384 /* FIX(0.25000) */
|
|
shun-iwasawa |
82a8f5 |
#define F_0_299 19595 /* FIX(0.29900) */
|
|
shun-iwasawa |
82a8f5 |
#define F_0_587 38470 /* FIX(0.58700) */
|
|
shun-iwasawa |
82a8f5 |
#define F_0_337 (F_0_587 - F_0_250) /* FIX(0.58700) - FIX(0.25000) */
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define SCALEBITS 16
|
|
shun-iwasawa |
82a8f5 |
#define ONE_HALF (1 << (SCALEBITS - 1))
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX0 \
|
|
shun-iwasawa |
82a8f5 |
{ 0, 1, 3, 4, 6, 7, 9, 10, 2, 1, 5, 4, 8, 7, 11, 10 }
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX1 \
|
|
shun-iwasawa |
82a8f5 |
{ 12, 13, 15, 16, 18, 19, 21, 22, 14, 13, 17, 16, 20, 19, 23, 22 }
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX2 \
|
|
shun-iwasawa |
82a8f5 |
{ 8, 9, 11, 12, 14, 15, 17, 18, 10, 9, 13, 12, 16, 15, 19, 18 }
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX3 \
|
|
shun-iwasawa |
82a8f5 |
{ 4, 5, 7, 8, 10, 11, 13, 14, 6, 5, 9, 8, 12, 11, 15, 14 }
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGB_PIXELSIZE EXT_RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#define jsimd_rgb_gray_convert_altivec jsimd_extrgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX0
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX1
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX2
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX3
|
|
shun-iwasawa |
82a8f5 |
#undef jsimd_rgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGB_PIXELSIZE EXT_RGBX_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX \
|
|
shun-iwasawa |
82a8f5 |
{ 0, 1, 4, 5, 8, 9, 12, 13, 2, 1, 6, 5, 10, 9, 14, 13 }
|
|
shun-iwasawa |
82a8f5 |
#define jsimd_rgb_gray_convert_altivec jsimd_extrgbx_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX
|
|
shun-iwasawa |
82a8f5 |
#undef jsimd_rgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGB_PIXELSIZE EXT_BGR_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX0 \
|
|
shun-iwasawa |
82a8f5 |
{ 2, 1, 5, 4, 8, 7, 11, 10, 0, 1, 3, 4, 6, 7, 9, 10 }
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX1 \
|
|
shun-iwasawa |
82a8f5 |
{ 14, 13, 17, 16, 20, 19, 23, 22, 12, 13, 15, 16, 18, 19, 21, 22 }
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX2 \
|
|
shun-iwasawa |
82a8f5 |
{ 10, 9, 13, 12, 16, 15, 19, 18, 8, 9, 11, 12, 14, 15, 17, 18 }
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX3 \
|
|
shun-iwasawa |
82a8f5 |
{ 6, 5, 9, 8, 12, 11, 15, 14, 4, 5, 7, 8, 10, 11, 13, 14 }
|
|
shun-iwasawa |
82a8f5 |
#define jsimd_rgb_gray_convert_altivec jsimd_extbgr_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX0
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX1
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX2
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX3
|
|
shun-iwasawa |
82a8f5 |
#undef jsimd_rgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGB_PIXELSIZE EXT_BGRX_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX \
|
|
shun-iwasawa |
82a8f5 |
{ 2, 1, 6, 5, 10, 9, 14, 13, 0, 1, 4, 5, 8, 9, 12, 13 }
|
|
shun-iwasawa |
82a8f5 |
#define jsimd_rgb_gray_convert_altivec jsimd_extbgrx_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX
|
|
shun-iwasawa |
82a8f5 |
#undef jsimd_rgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGB_PIXELSIZE EXT_XBGR_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX \
|
|
shun-iwasawa |
82a8f5 |
{ 3, 2, 7, 6, 11, 10, 15, 14, 1, 2, 5, 6, 9, 10, 13, 14 }
|
|
shun-iwasawa |
82a8f5 |
#define jsimd_rgb_gray_convert_altivec jsimd_extxbgr_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX
|
|
shun-iwasawa |
82a8f5 |
#undef jsimd_rgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
|
|
shun-iwasawa |
82a8f5 |
#define RGB_PIXELSIZE EXT_XRGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#define RGBG_INDEX \
|
|
shun-iwasawa |
82a8f5 |
{ 1, 2, 5, 6, 9, 10, 13, 14, 3, 2, 7, 6, 11, 10, 15, 14 }
|
|
shun-iwasawa |
82a8f5 |
#define jsimd_rgb_gray_convert_altivec jsimd_extxrgb_gray_convert_altivec
|
|
shun-iwasawa |
82a8f5 |
#include "jcgryext-altivec.c"
|
|
shun-iwasawa |
82a8f5 |
#undef RGB_PIXELSIZE
|
|
shun-iwasawa |
82a8f5 |
#undef RGBG_INDEX
|
|
shun-iwasawa |
82a8f5 |
#undef jsimd_rgb_gray_convert_altivec
|