56 const struct dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
57 const int32_t in_stride);
61 const struct dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
62 const int32_t in_stride);
64int dt_iop_clip_and_zoom_cl(
int devid, cl_mem dev_out, cl_mem dev_in,
68int dt_iop_clip_and_zoom_roi_cl(
int devid, cl_mem dev_out, cl_mem dev_in,
75 const int32_t out_stride,
const int32_t in_stride,
76 const uint32_t filters);
80 const int32_t out_stride,
const int32_t in_stride,
81 const uint32_t filters);
85 const dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
86 const int32_t in_stride,
const uint8_t (*
const xtrans)[6]);
90 const dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
91 const int32_t in_stride,
const uint8_t (*
const xtrans)[6]);
96 const int32_t out_stride,
97 const int32_t in_stride);
101 const struct dt_iop_roi_t *
const roi_in,
const int32_t out_stride,
102 const int32_t in_stride,
const uint32_t filters);
109 const int32_t out_stride,
const int32_t in_stride,
110 const uint8_t (*
const xtrans)[6]);
114 int32_t ibh, uint8_t *o, int32_t ox, int32_t oy, int32_t ow, int32_t oh,
115 int32_t obw, int32_t obh);
128 const float x4[4] = {
x *
x *
x,
x *
x,
x, 1.0f };
129 return a[3] * x4[3] +
a[2] * x4[2] +
a[1] * x4[1] +
a[0] * x4[0];
139 const float x0 =
x[num - 1], y0 = y[num - 1];
147 for(
int k = 0; k < num - 1; k++)
149 const float yy = y[k] / y0, xx =
x[k] / x0;
150 if(yy > 0.0f && xx > 0.0f)
152 const float gg = logf(y[k] / y0) / logf(
x[k] / x0);
161 coeff[0] = 1.0f / x0;
169#pragma omp declare simd
179#pragma omp declare simd uniform(width, height) aligned(ivoid, ovoid:64)
185 const float *
const __restrict__ in = (
const float *
const)ivoid;
186 float *
const __restrict__
out = (
float *
const)ovoid;
189#pragma omp parallel for simd default(none) aligned(out, in:64)\
190 dt_omp_firstprivate(height, width, out, in) \
198static inline int FC(
const size_t row,
const size_t col,
const uint32_t filters)
200 return filters >> (((
row << 1 & 14) + (col & 1)) << 1) & 3;
210 const uint8_t (*
const xtrans)[6])
216 int irow =
row + 600;
217 int icol = col + 600;
218 assert(irow >= 0 && icol >= 0);
226 return xtrans[irow % 6][icol % 6];
231#pragma omp declare simd
233static inline int fcol(
const int row,
const int col,
const uint32_t filters,
const uint8_t (*
const xtrans)[6])
238 return FC(
row, col, filters);
int width
Definition bilateral.h:1
int height
Definition bilateral.h:1
const float i
Definition colorspaces_inline_conversions.h:669
const float g
Definition colorspaces_inline_conversions.h:925
const float a
Definition colorspaces_inline_conversions.h:1292
static const dt_colormatrix_t dt_aligned_pixel_t out
Definition colorspaces_inline_conversions.h:184
static const int row
Definition colorspaces_inline_conversions.h:175
static dt_aligned_pixel_t rgb
Definition colorspaces_inline_conversions.h:530
dt_image_orientation_t
Definition common/image.h:169
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:101
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:252
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:198
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:181
static float dt_iop_eval_cubic(const float *const a, const float x)
Definition imageop_math.h:125
void dt_iop_YCbCr_to_RGB(const dt_aligned_pixel_t yuv, dt_aligned_pixel_t rgb)
Definition imageop_math.c:911
void dt_iop_RGB_to_YCbCr(const dt_aligned_pixel_t rgb, dt_aligned_pixel_t yuv)
Definition imageop_math.c:904
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:36
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:209
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:180
static void dt_iop_estimate_exp(const float *const x, const float *const y, const int num, float *coeff)
Definition imageop_math.h:134
void dt_iop_estimate_cubic(const float x[4], const float y[4], float a[4])
Definition imageop_math.c:995
static int fcol(const int row, const int col, const uint32_t filters, const uint8_t(*const xtrans)[6])
Definition imageop_math.h:233
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:171
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:444
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:488
static const float x
Definition iop_profile.h:239
static const float *const const float coeff[3]
Definition iop_profile.h:246
int x
Definition imageop.h:68
int y
Definition imageop.h:68