Ansel 0.0
A darktable fork - bloat + design vision
Loading...
Searching...
No Matches
interpolation.h
Go to the documentation of this file.
1/*
2 This file is part of darktable,
3 Copyright (C) 2012 Edouard Gomez.
4 Copyright (C) 2012 Richard Wonka.
5 Copyright (C) 2013 Simon Spannagel.
6 Copyright (C) 2014, 2016, 2019 Tobias Ellinghaus.
7 Copyright (C) 2014-2015 Ulrich Pegelow.
8 Copyright (C) 2016 Roman Lebedev.
9 Copyright (C) 2017 luzpaz.
10 Copyright (C) 2020-2021 Pascal Obry.
11 Copyright (C) 2021 Hanno Schwalm.
12 Copyright (C) 2022 Martin Bařinka.
13 Copyright (C) 2024 Aurélien PIERRE.
14
15 darktable is free software: you can redistribute it and/or modify
16 it under the terms of the GNU General Public License as published by
17 the Free Software Foundation, either version 3 of the License, or
18 (at your option) any later version.
19
20 darktable is distributed in the hope that it will be useful,
21 but WITHOUT ANY WARRANTY; without even the implied warranty of
22 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 GNU General Public License for more details.
24
25 You should have received a copy of the GNU General Public License
26 along with darktable. If not, see <http://www.gnu.org/licenses/>.
27*/
28
29#pragma once
30
31#include "common/opencl.h"
33
34G_BEGIN_DECLS
35
50
52typedef float (*dt_interpolation_func)(float *taps,
53 size_t num_taps,
54 float width,
55 float first_tap,
56 float interval);
57
66
87float dt_interpolation_compute_sample(const struct dt_interpolation *itor, const float *in, const float x,
88 const float y, const int width, const int height,
89 const int samplestride, const int linestride);
90
110void dt_interpolation_compute_pixel4c(const struct dt_interpolation *itor, const float *in, float *out,
111 const float x, const float y, const int width, const int height,
112 const int linestride);
113
119
141void dt_interpolation_resample(const struct dt_interpolation *itor, float *out,
142 const dt_iop_roi_t *const roi_out,
143 const float *const in, const dt_iop_roi_t *const roi_in);
144
145void dt_interpolation_resample_roi(const struct dt_interpolation *itor, float *out,
146 const dt_iop_roi_t *const roi_out,
147 const float *const in, const dt_iop_roi_t *const roi_in);
148
149#ifdef HAVE_OPENCL
150typedef struct dt_interpolation_cl_global_t
151{
152 int kernel_interpolation_resample;
153} dt_interpolation_cl_global_t;
154
155dt_interpolation_cl_global_t *dt_interpolation_init_cl_global(void);
156
157void dt_interpolation_free_cl_global(dt_interpolation_cl_global_t *g);
158
159
182int dt_interpolation_resample_cl(const struct dt_interpolation *itor, int devid, cl_mem dev_out,
183 const dt_iop_roi_t *const roi_out, cl_mem dev_in,
184 const dt_iop_roi_t *const roi_in);
185
186int dt_interpolation_resample_roi_cl(const struct dt_interpolation *itor, int devid, cl_mem dev_out,
187 const dt_iop_roi_t *const roi_out, cl_mem dev_in,
188 const dt_iop_roi_t *const roi_in);
189#endif
190
191void dt_interpolation_resample_1c(const struct dt_interpolation *itor,
192 float *out, const dt_iop_roi_t *const roi_out,
193 const float *const in, const dt_iop_roi_t *const roi_in);
194
196 float *out, const dt_iop_roi_t *const roi_out,
197 const float *const in, const dt_iop_roi_t *const roi_in);
198
199G_END_DECLS
200
201// clang-format off
202// modelines: These editor modelines have been set for all relevant files by tools/update_modelines.py
203// vim: shiftwidth=2 expandtab tabstop=2 cindent
204// kate: tab-indents: off; indent-width 2; replace-tabs on; indent-mode cstyle; remove-trailing-spaces modified;
205// clang-format on
int width
Definition bilateral.h:1
int height
Definition bilateral.h:1
const float g
Definition colorspaces_inline_conversions.h:925
static const dt_colormatrix_t dt_aligned_pixel_t out
Definition colorspaces_inline_conversions.h:184
int type
Definition common/metadata.c:62
const struct dt_interpolation * dt_interpolation_new(enum dt_interpolation_type type)
Definition interpolation.c:647
dt_interpolation_type
Definition interpolation.h:38
@ DT_INTERPOLATION_LANCZOS2
Definition interpolation.h:42
@ DT_INTERPOLATION_BICUBIC
Definition interpolation.h:41
@ DT_INTERPOLATION_BILINEAR
Definition interpolation.h:40
@ DT_INTERPOLATION_DEFAULT
Definition interpolation.h:45
@ DT_INTERPOLATION_LANCZOS3
Definition interpolation.h:43
@ DT_INTERPOLATION_LAST
Definition interpolation.h:44
@ DT_INTERPOLATION_USERPREF
Definition interpolation.h:47
@ DT_INTERPOLATION_DEFAULT_WARP
Definition interpolation.h:46
@ DT_INTERPOLATION_FIRST
Definition interpolation.h:39
@ DT_INTERPOLATION_USERPREF_WARP
Definition interpolation.h:48
void dt_interpolation_resample_roi(const struct dt_interpolation *itor, float *out, const dt_iop_roi_t *const roi_out, const float *const in, const dt_iop_roi_t *const roi_in)
Definition interpolation.c:1090
float dt_interpolation_compute_sample(const struct dt_interpolation *itor, const float *in, const float x, const float y, const int width, const int height, const int samplestride, const int linestride)
Definition interpolation.c:444
void dt_interpolation_resample_roi_1c(const struct dt_interpolation *itor, float *out, const dt_iop_roi_t *const roi_out, const float *const in, const dt_iop_roi_t *const roi_in)
Definition interpolation.c:1481
void dt_interpolation_resample(const struct dt_interpolation *itor, float *out, const dt_iop_roi_t *const roi_out, const float *const in, const dt_iop_roi_t *const roi_in)
Definition interpolation.c:1076
void dt_interpolation_resample_1c(const struct dt_interpolation *itor, float *out, const dt_iop_roi_t *const roi_out, const float *const in, const dt_iop_roi_t *const roi_in)
Definition interpolation.c:1468
float(* dt_interpolation_func)(float *taps, size_t num_taps, float width, float first_tap, float interval)
Definition interpolation.h:52
void dt_interpolation_compute_pixel4c(const struct dt_interpolation *itor, const float *in, float *out, const float x, const float y, const int width, const int height, const int linestride)
Definition interpolation.c:543
static const float x
Definition iop_profile.h:239
Definition interpolation.h:60
dt_interpolation_func maketaps
Definition interpolation.h:64
size_t width
Definition interpolation.h:63
enum dt_interpolation_type id
Definition interpolation.h:61
const char * name
Definition interpolation.h:62
Definition imageop.h:67