40void dt_iop_flip_and_zoom_8(
const uint8_t *in, int32_t iw, int32_t ih, uint8_t *out, int32_t ow, int32_t oh,
45 const struct dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
46 const int32_t in_stride);
50 const struct dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
51 const int32_t in_stride);
53int dt_iop_clip_and_zoom_cl(
int devid, cl_mem dev_out, cl_mem dev_in,
57int dt_iop_clip_and_zoom_roi_cl(
int devid, cl_mem dev_out, cl_mem dev_in,
64 const int32_t out_stride,
const int32_t in_stride,
65 const uint32_t filters);
69 const int32_t out_stride,
const int32_t in_stride,
70 const uint32_t filters);
74 const dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
75 const int32_t in_stride,
const uint8_t (*
const xtrans)[6]);
79 const dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
80 const int32_t in_stride,
const uint8_t (*
const xtrans)[6]);
85 const int32_t out_stride,
86 const int32_t in_stride);
90 const struct dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
91 const int32_t in_stride,
const uint32_t filters);
98 const int32_t out_stride,
const int32_t in_stride,
99 const uint8_t (*
const xtrans)[6]);
103 int32_t ibh, uint8_t *o, int32_t ox, int32_t oy, int32_t ow, int32_t oh,
104 int32_t obw, int32_t obh);
117 const float x4[4] = { x * x * x, x * x, x, 1.0f };
118 return a[3] * x4[3] + a[2] * x4[2] + a[1] * x4[1] + a[0] * x4[0];
123static inline void dt_iop_estimate_exp(
const float *
const x,
const float *
const y,
const int num,
float *coeff)
128 const float x0 = x[num - 1], y0 = y[num - 1];
136 for(
int k = 0; k < num - 1; k++)
138 const float yy = y[k] / y0, xx = x[k] / x0;
139 if(yy > 0.0f && xx > 0.0f)
141 const float gg = logf(y[k] / y0) / logf(x[k] / x0);
150 coeff[0] = 1.0f / x0;
158#pragma omp declare simd
162 return coeff[1] * powf(x * coeff[0], coeff[2]);
168#pragma omp declare simd uniform(width, height) aligned(ivoid, ovoid:64)
174 const float *
const __restrict__ in = (
const float *
const)ivoid;
175 float *
const __restrict__ out = (
float *
const)ovoid;
178#pragma omp parallel for simd default(none) aligned(out, in:64)\
179 dt_omp_firstprivate(height, width, out, in) \
187static inline int FC(
const size_t row,
const size_t col,
const uint32_t filters)
189 return filters >> (((row << 1 & 14) + (col & 1)) << 1) & 3;
199 const uint8_t (*
const xtrans)[6])
205 int irow = row + 600;
206 int icol = col + 600;
207 assert(irow >= 0 && icol >= 0);
215 return xtrans[irow % 6][icol % 6];
220#pragma omp declare simd
222static inline int fcol(
const int row,
const int col,
const uint32_t filters,
const uint8_t (*
const xtrans)[6])
225 return FCxtrans(row, col, NULL, xtrans);
227 return FC(row, col, filters);
int width
Definition bilateral.h:1
int height
Definition bilateral.h:1
dt_image_orientation_t
Definition common/image.h:123
void dt_iop_clip_and_zoom_8(const uint8_t *i, int32_t ix, int32_t iy, int32_t iw, int32_t ih, int32_t ibw, int32_t ibh, uint8_t *o, int32_t ox, int32_t oy, int32_t ow, int32_t oh, int32_t obw, int32_t obh)
Definition imageop_math.c:93
void dt_iop_clip_and_zoom_demosaic_passthrough_monochrome_f(float *out, const float *const in, const struct dt_iop_roi_t *const roi_out, const struct dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride)
void dt_iop_clip_and_zoom(float *out, const float *const in, const struct dt_iop_roi_t *const roi_out, const struct dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride)
void dt_iop_clip_and_zoom_mosaic_half_size_f(float *const out, const float *const in, const dt_iop_roi_t *const roi_out, const dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride, const uint32_t filters)
Definition imageop_math.c:244
void dt_iop_clip_and_zoom_demosaic_third_size_xtrans_f(float *out, const float *const in, const struct dt_iop_roi_t *const roi_out, const struct dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride, const uint8_t(*const xtrans)[6])
static int FC(const size_t row, const size_t col, const uint32_t filters)
Definition imageop_math.h:187
static void dt_iop_alpha_copy(const void *const ivoid, void *const ovoid, const size_t width, const size_t height)
Definition imageop_math.h:170
static float dt_iop_eval_cubic(const float *const a, const float x)
Definition imageop_math.h:114
void dt_iop_YCbCr_to_RGB(const dt_aligned_pixel_t yuv, dt_aligned_pixel_t rgb)
Definition imageop_math.c:903
void dt_iop_RGB_to_YCbCr(const dt_aligned_pixel_t rgb, dt_aligned_pixel_t yuv)
Definition imageop_math.c:896
void dt_iop_flip_and_zoom_8(const uint8_t *in, int32_t iw, int32_t ih, uint8_t *out, int32_t ow, int32_t oh, const dt_image_orientation_t orientation, uint32_t *width, uint32_t *height)
Definition imageop_math.c:28
static int FCxtrans(const int row, const int col, const dt_iop_roi_t *const roi, const uint8_t(*const xtrans)[6])
Definition imageop_math.h:198
void dt_iop_clip_and_zoom_mosaic_half_size(uint16_t *const out, const uint16_t *const in, const dt_iop_roi_t *const roi_out, const dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride, const uint32_t filters)
Definition imageop_math.c:172
static void dt_iop_estimate_exp(const float *const x, const float *const y, const int num, float *coeff)
Definition imageop_math.h:123
void dt_iop_estimate_cubic(const float x[4], const float y[4], float a[4])
Definition imageop_math.c:987
static int fcol(const int row, const int col, const uint32_t filters, const uint8_t(*const xtrans)[6])
Definition imageop_math.h:222
void dt_iop_clip_and_zoom_demosaic_half_size_f(float *out, const float *const in, const struct dt_iop_roi_t *const roi_out, const struct dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride, const uint32_t filters)
static float dt_iop_eval_exp(const float *const coeff, const float x)
Definition imageop_math.h:160
void dt_iop_clip_and_zoom_mosaic_third_size_xtrans(uint16_t *const out, const uint16_t *const in, const dt_iop_roi_t *const roi_out, const dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride, const uint8_t(*const xtrans)[6])
Definition imageop_math.c:436
void dt_iop_clip_and_zoom_roi(float *out, const float *const in, const struct dt_iop_roi_t *const roi_out, const struct dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride)
void dt_iop_clip_and_zoom_mosaic_third_size_xtrans_f(float *const out, const float *const in, const dt_iop_roi_t *const roi_out, const dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride, const uint8_t(*const xtrans)[6])
Definition imageop_math.c:480
int x
Definition imageop.h:33
int y
Definition imageop.h:33