Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv
Commits
944f7bac
Commit
944f7bac
authored
Nov 21, 2013
by
Anna Kogan
Committed by
siddharth
Dec 04, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
After-merge corrections
parent
573e8184
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
203 additions
and
200 deletions
+203
-200
photo.hpp
modules/photo/include/opencv2/photo.hpp
+203
-200
No files found.
modules/photo/include/opencv2/photo.hpp
View file @
944f7bac
...
...
@@ -52,281 +52,284 @@
namespace
cv
{
//! the inpainting algorithm
enum
{
INPAINT_NS
=
0
,
// Navier-Stokes algorithm
INPAINT_TELEA
=
1
// A. Telea algorithm
};
//! the inpainting algorithm
enum
{
INPAINT_NS
=
0
,
// Navier-Stokes algorithm
INPAINT_TELEA
=
1
// A. Telea algorithm
};
enum
{
NORMAL_CLONE
=
1
,
MIXED_CLONE
=
2
,
MONOCHROME_TRANSFER
=
3
};
enum
{
NORMAL_CLONE
=
1
,
MIXED_CLONE
=
2
,
MONOCHROME_TRANSFER
=
3
};
enum
{
RECURS_FILTER
=
1
,
NORMCONV_FILTER
=
2
};
enum
{
RECURS_FILTER
=
1
,
NORMCONV_FILTER
=
2
};
//! restores the damaged image areas using one of the available intpainting algorithms
CV_EXPORTS_W
void
inpaint
(
InputArray
src
,
InputArray
inpaintMask
,
OutputArray
dst
,
double
inpaintRadius
,
int
flags
);
//! restores the damaged image areas using one of the available intpainting algorithms
CV_EXPORTS_W
void
inpaint
(
InputArray
src
,
InputArray
inpaintMask
,
OutputArray
dst
,
double
inpaintRadius
,
int
flags
);
CV_EXPORTS_W
void
fastNlMeansDenoising
(
InputArray
src
,
OutputArray
dst
,
float
h
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoising
(
InputArray
src
,
OutputArray
dst
,
float
h
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoisingColored
(
InputArray
src
,
OutputArray
dst
,
float
h
=
3
,
float
hColor
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoisingColored
(
InputArray
src
,
OutputArray
dst
,
float
h
=
3
,
float
hColor
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoisingMulti
(
InputArrayOfArrays
srcImgs
,
OutputArray
dst
,
int
imgToDenoiseIndex
,
int
temporalWindowSize
,
float
h
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoisingMulti
(
InputArrayOfArrays
srcImgs
,
OutputArray
dst
,
int
imgToDenoiseIndex
,
int
temporalWindowSize
,
float
h
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoisingColoredMulti
(
InputArrayOfArrays
srcImgs
,
OutputArray
dst
,
int
imgToDenoiseIndex
,
int
temporalWindowSize
,
float
h
=
3
,
float
hColor
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
CV_EXPORTS_W
void
fastNlMeansDenoisingColoredMulti
(
InputArrayOfArrays
srcImgs
,
OutputArray
dst
,
int
imgToDenoiseIndex
,
int
temporalWindowSize
,
float
h
=
3
,
float
hColor
=
3
,
int
templateWindowSize
=
7
,
int
searchWindowSize
=
21
);
enum
{
LDR_SIZE
=
256
};
enum
{
LDR_SIZE
=
256
};
class
CV_EXPORTS_W
Tonemap
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArray
src
,
OutputArray
dst
)
=
0
;
class
CV_EXPORTS_W
Tonemap
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArray
src
,
OutputArray
dst
)
=
0
;
CV_WRAP
virtual
float
getGamma
()
const
=
0
;
CV_WRAP
virtual
void
setGamma
(
float
gamma
)
=
0
;
};
CV_WRAP
virtual
float
getGamma
()
const
=
0
;
CV_WRAP
virtual
void
setGamma
(
float
gamma
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
Tonemap
>
createTonemap
(
float
gamma
=
1.0
f
);
CV_EXPORTS_W
Ptr
<
Tonemap
>
createTonemap
(
float
gamma
=
1.0
f
);
// "Adaptive Logarithmic Mapping For Displaying HighContrast Scenes", Drago et al., 2003
// "Adaptive Logarithmic Mapping For Displaying HighContrast Scenes", Drago et al., 2003
class
CV_EXPORTS_W
TonemapDrago
:
public
Tonemap
{
public
:
class
CV_EXPORTS_W
TonemapDrago
:
public
Tonemap
{
public
:
CV_WRAP
virtual
float
getSaturation
()
const
=
0
;
CV_WRAP
virtual
void
setSaturation
(
float
saturation
)
=
0
;
CV_WRAP
virtual
float
getSaturation
()
const
=
0
;
CV_WRAP
virtual
void
setSaturation
(
float
saturation
)
=
0
;
CV_WRAP
virtual
float
getBias
()
const
=
0
;
CV_WRAP
virtual
void
setBias
(
float
bias
)
=
0
;
};
CV_WRAP
virtual
float
getBias
()
const
=
0
;
CV_WRAP
virtual
void
setBias
(
float
bias
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
TonemapDrago
>
createTonemapDrago
(
float
gamma
=
1.0
f
,
float
saturation
=
1.0
f
,
float
bias
=
0.85
f
);
CV_EXPORTS_W
Ptr
<
TonemapDrago
>
createTonemapDrago
(
float
gamma
=
1.0
f
,
float
saturation
=
1.0
f
,
float
bias
=
0.85
f
);
// "Fast Bilateral Filtering for the Display of High-Dynamic-Range Images", Durand, Dorsey, 2002
// "Fast Bilateral Filtering for the Display of High-Dynamic-Range Images", Durand, Dorsey, 2002
class
CV_EXPORTS_W
TonemapDurand
:
public
Tonemap
{
public
:
class
CV_EXPORTS_W
TonemapDurand
:
public
Tonemap
{
public
:
CV_WRAP
virtual
float
getSaturation
()
const
=
0
;
CV_WRAP
virtual
void
setSaturation
(
float
saturation
)
=
0
;
CV_WRAP
virtual
float
getSaturation
()
const
=
0
;
CV_WRAP
virtual
void
setSaturation
(
float
saturation
)
=
0
;
CV_WRAP
virtual
float
getContrast
()
const
=
0
;
CV_WRAP
virtual
void
setContrast
(
float
contrast
)
=
0
;
CV_WRAP
virtual
float
getContrast
()
const
=
0
;
CV_WRAP
virtual
void
setContrast
(
float
contrast
)
=
0
;
CV_WRAP
virtual
float
getSigmaSpace
()
const
=
0
;
CV_WRAP
virtual
void
setSigmaSpace
(
float
sigma_space
)
=
0
;
CV_WRAP
virtual
float
getSigmaSpace
()
const
=
0
;
CV_WRAP
virtual
void
setSigmaSpace
(
float
sigma_space
)
=
0
;
CV_WRAP
virtual
float
getSigmaColor
()
const
=
0
;
CV_WRAP
virtual
void
setSigmaColor
(
float
sigma_color
)
=
0
;
};
CV_WRAP
virtual
float
getSigmaColor
()
const
=
0
;
CV_WRAP
virtual
void
setSigmaColor
(
float
sigma_color
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
TonemapDurand
>
createTonemapDurand
(
float
gamma
=
1.0
f
,
float
contrast
=
4.0
f
,
float
saturation
=
1.0
f
,
float
sigma_space
=
2.0
f
,
float
sigma_color
=
2.0
f
);
CV_EXPORTS_W
Ptr
<
TonemapDurand
>
createTonemapDurand
(
float
gamma
=
1.0
f
,
float
contrast
=
4.0
f
,
float
saturation
=
1.0
f
,
float
sigma_space
=
2.0
f
,
float
sigma_color
=
2.0
f
);
// "Dynamic Range Reduction Inspired by Photoreceptor Physiology", Reinhard, Devlin, 2005
// "Dynamic Range Reduction Inspired by Photoreceptor Physiology", Reinhard, Devlin, 2005
class
CV_EXPORTS_W
TonemapReinhard
:
public
Tonemap
{
public
:
CV_WRAP
virtual
float
getIntensity
()
const
=
0
;
CV_WRAP
virtual
void
setIntensity
(
float
intensity
)
=
0
;
class
CV_EXPORTS_W
TonemapReinhard
:
public
Tonemap
{
public
:
CV_WRAP
virtual
float
getIntensity
()
const
=
0
;
CV_WRAP
virtual
void
setIntensity
(
float
intensity
)
=
0
;
CV_WRAP
virtual
float
getLightAdaptation
()
const
=
0
;
CV_WRAP
virtual
void
setLightAdaptation
(
float
light_adapt
)
=
0
;
CV_WRAP
virtual
float
getLightAdaptation
()
const
=
0
;
CV_WRAP
virtual
void
setLightAdaptation
(
float
light_adapt
)
=
0
;
CV_WRAP
virtual
float
getColorAdaptation
()
const
=
0
;
CV_WRAP
virtual
void
setColorAdaptation
(
float
color_adapt
)
=
0
;
};
CV_WRAP
virtual
float
getColorAdaptation
()
const
=
0
;
CV_WRAP
virtual
void
setColorAdaptation
(
float
color_adapt
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
TonemapReinhard
>
createTonemapReinhard
(
float
gamma
=
1.0
f
,
float
intensity
=
0.0
f
,
float
light_adapt
=
1.0
f
,
float
color_adapt
=
0.0
f
);
CV_EXPORTS_W
Ptr
<
TonemapReinhard
>
createTonemapReinhard
(
float
gamma
=
1.0
f
,
float
intensity
=
0.0
f
,
float
light_adapt
=
1.0
f
,
float
color_adapt
=
0.0
f
);
// "Perceptual Framework for Contrast Processing of High Dynamic Range Images", Mantiuk et al., 2006
// "Perceptual Framework for Contrast Processing of High Dynamic Range Images", Mantiuk et al., 2006
class
CV_EXPORTS_W
TonemapMantiuk
:
public
Tonemap
{
public
:
CV_WRAP
virtual
float
getScale
()
const
=
0
;
CV_WRAP
virtual
void
setScale
(
float
scale
)
=
0
;
class
CV_EXPORTS_W
TonemapMantiuk
:
public
Tonemap
{
public
:
CV_WRAP
virtual
float
getScale
()
const
=
0
;
CV_WRAP
virtual
void
setScale
(
float
scale
)
=
0
;
CV_WRAP
virtual
float
getSaturation
()
const
=
0
;
CV_WRAP
virtual
void
setSaturation
(
float
saturation
)
=
0
;
};
CV_WRAP
virtual
float
getSaturation
()
const
=
0
;
CV_WRAP
virtual
void
setSaturation
(
float
saturation
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
TonemapMantiuk
>
createTonemapMantiuk
(
float
gamma
=
1.0
f
,
float
scale
=
0.7
f
,
float
saturation
=
1.0
f
);
CV_EXPORTS_W
Ptr
<
TonemapMantiuk
>
createTonemapMantiuk
(
float
gamma
=
1.0
f
,
float
scale
=
0.7
f
,
float
saturation
=
1.0
f
);
class
CV_EXPORTS_W
AlignExposures
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
std
::
vector
<
Mat
>&
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
};
class
CV_EXPORTS_W
AlignExposures
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
std
::
vector
<
Mat
>&
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
};
// "Fast, Robust Image Registration for Compositing High Dynamic Range Photographs from Handheld Exposures", Ward, 2003
// "Fast, Robust Image Registration for Compositing High Dynamic Range Photographs from Handheld Exposures", Ward, 2003
class
CV_EXPORTS_W
AlignMTB
:
public
AlignExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
std
::
vector
<
Mat
>&
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
class
CV_EXPORTS_W
AlignMTB
:
public
AlignExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
std
::
vector
<
Mat
>&
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
std
::
vector
<
Mat
>&
dst
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
std
::
vector
<
Mat
>&
dst
)
=
0
;
CV_WRAP
virtual
Point
calculateShift
(
InputArray
img0
,
InputArray
img1
)
=
0
;
CV_WRAP
virtual
void
shiftMat
(
InputArray
src
,
OutputArray
dst
,
const
Point
shift
)
=
0
;
CV_WRAP
virtual
void
computeBitmaps
(
InputArray
img
,
OutputArray
tb
,
OutputArray
eb
)
=
0
;
CV_WRAP
virtual
Point
calculateShift
(
InputArray
img0
,
InputArray
img1
)
=
0
;
CV_WRAP
virtual
void
shiftMat
(
InputArray
src
,
OutputArray
dst
,
const
Point
shift
)
=
0
;
CV_WRAP
virtual
void
computeBitmaps
(
InputArray
img
,
OutputArray
tb
,
OutputArray
eb
)
=
0
;
CV_WRAP
virtual
int
getMaxBits
()
const
=
0
;
CV_WRAP
virtual
void
setMaxBits
(
int
max_bits
)
=
0
;
CV_WRAP
virtual
int
getMaxBits
()
const
=
0
;
CV_WRAP
virtual
void
setMaxBits
(
int
max_bits
)
=
0
;
CV_WRAP
virtual
int
getExcludeRange
()
const
=
0
;
CV_WRAP
virtual
void
setExcludeRange
(
int
exclude_range
)
=
0
;
CV_WRAP
virtual
int
getExcludeRange
()
const
=
0
;
CV_WRAP
virtual
void
setExcludeRange
(
int
exclude_range
)
=
0
;
CV_WRAP
virtual
bool
getCut
()
const
=
0
;
CV_WRAP
virtual
void
setCut
(
bool
value
)
=
0
;
};
CV_WRAP
virtual
bool
getCut
()
const
=
0
;
CV_WRAP
virtual
void
setCut
(
bool
value
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
AlignMTB
>
createAlignMTB
(
int
max_bits
=
6
,
int
exclude_range
=
4
,
bool
cut
=
true
);
CV_EXPORTS_W
Ptr
<
AlignMTB
>
createAlignMTB
(
int
max_bits
=
6
,
int
exclude_range
=
4
,
bool
cut
=
true
);
class
CV_EXPORTS_W
CalibrateCRF
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
)
=
0
;
};
class
CV_EXPORTS_W
CalibrateCRF
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
)
=
0
;
};
// "Recovering High Dynamic Range Radiance Maps from Photographs", Debevec, Malik, 1997
// "Recovering High Dynamic Range Radiance Maps from Photographs", Debevec, Malik, 1997
class
CV_EXPORTS_W
CalibrateDebevec
:
public
CalibrateCRF
{
public
:
CV_WRAP
virtual
float
getLambda
()
const
=
0
;
CV_WRAP
virtual
void
setLambda
(
float
lambda
)
=
0
;
class
CV_EXPORTS_W
CalibrateDebevec
:
public
CalibrateCRF
{
public
:
CV_WRAP
virtual
float
getLambda
()
const
=
0
;
CV_WRAP
virtual
void
setLambda
(
float
lambda
)
=
0
;
CV_WRAP
virtual
int
getSamples
()
const
=
0
;
CV_WRAP
virtual
void
setSamples
(
int
samples
)
=
0
;
CV_WRAP
virtual
int
getSamples
()
const
=
0
;
CV_WRAP
virtual
void
setSamples
(
int
samples
)
=
0
;
CV_WRAP
virtual
bool
getRandom
()
const
=
0
;
CV_WRAP
virtual
void
setRandom
(
bool
random
)
=
0
;
};
CV_WRAP
virtual
bool
getRandom
()
const
=
0
;
CV_WRAP
virtual
void
setRandom
(
bool
random
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
CalibrateDebevec
>
createCalibrateDebevec
(
int
samples
=
70
,
float
lambda
=
10.0
f
,
bool
random
=
false
);
CV_EXPORTS_W
Ptr
<
CalibrateDebevec
>
createCalibrateDebevec
(
int
samples
=
70
,
float
lambda
=
10.0
f
,
bool
random
=
false
);
// "Dynamic range improvement through multiple exposures", Robertson et al., 1999
// "Dynamic range improvement through multiple exposures", Robertson et al., 1999
class
CV_EXPORTS_W
CalibrateRobertson
:
public
CalibrateCRF
{
public
:
CV_WRAP
virtual
int
getMaxIter
()
const
=
0
;
CV_WRAP
virtual
void
setMaxIter
(
int
max_iter
)
=
0
;
class
CV_EXPORTS_W
CalibrateRobertson
:
public
CalibrateCRF
{
public
:
CV_WRAP
virtual
int
getMaxIter
()
const
=
0
;
CV_WRAP
virtual
void
setMaxIter
(
int
max_iter
)
=
0
;
CV_WRAP
virtual
float
getThreshold
()
const
=
0
;
CV_WRAP
virtual
void
setThreshold
(
float
threshold
)
=
0
;
CV_WRAP
virtual
float
getThreshold
()
const
=
0
;
CV_WRAP
virtual
void
setThreshold
(
float
threshold
)
=
0
;
CV_WRAP
virtual
Mat
getRadiance
()
const
=
0
;
}
;
CV_WRAP
virtual
Mat
getRadiance
()
const
=
0
;
};
CV_EXPORTS_W
Ptr
<
CalibrateRobertson
>
createCalibrateRobertson
(
int
max_iter
=
30
,
float
threshold
=
0.01
f
);
CV_EXPORTS_W
Ptr
<
CalibrateRobertson
>
createCalibrateRobertson
(
int
max_iter
=
30
,
float
threshold
=
0.01
f
);
class
CV_EXPORTS_W
MergeExposures
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
};
class
CV_EXPORTS_W
MergeExposures
:
public
Algorithm
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
};
// "Recovering High Dynamic Range Radiance Maps from Photographs", Debevec, Malik, 1997
// "Recovering High Dynamic Range Radiance Maps from Photographs", Debevec, Malik, 1997
class
CV_EXPORTS_W
MergeDebevec
:
public
MergeExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
)
=
0
;
};
class
CV_EXPORTS_W
MergeDebevec
:
public
MergeExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
MergeDebevec
>
createMergeDebevec
();
CV_EXPORTS_W
Ptr
<
MergeDebevec
>
createMergeDebevec
();
// "Exposure Fusion", Mertens et al., 2007
// "Exposure Fusion", Mertens et al., 2007
class
CV_EXPORTS_W
MergeMertens
:
public
MergeExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
)
=
0
;
class
CV_EXPORTS_W
MergeMertens
:
public
MergeExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
)
=
0
;
CV_WRAP
virtual
float
getContrastWeight
()
const
=
0
;
CV_WRAP
virtual
void
setContrastWeight
(
float
contrast_weiht
)
=
0
;
CV_WRAP
virtual
float
getContrast
Weight
()
const
=
0
;
CV_WRAP
virtual
void
setContrastWeight
(
float
contrast_wei
ht
)
=
0
;
CV_WRAP
virtual
float
getSaturation
Weight
()
const
=
0
;
CV_WRAP
virtual
void
setSaturationWeight
(
float
saturation_weig
ht
)
=
0
;
CV_WRAP
virtual
float
getSaturationWeight
()
const
=
0
;
CV_WRAP
virtual
void
setSaturationWeight
(
float
saturation_weight
)
=
0
;
CV_WRAP
virtual
float
getExposureWeight
()
const
=
0
;
CV_WRAP
virtual
void
setExposureWeight
(
float
exposure_weight
)
=
0
;
};
CV_WRAP
virtual
float
getExposureWeight
()
const
=
0
;
CV_WRAP
virtual
void
setExposureWeight
(
float
exposure_weight
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
MergeMertens
>
createMergeMertens
(
float
contrast_weight
=
1.0
f
,
float
saturation_weight
=
1.0
f
,
float
exposure_weight
=
0.0
f
);
CV_EXPORTS_W
Ptr
<
MergeMertens
>
createMergeMertens
(
float
contrast_weight
=
1.0
f
,
float
saturation_weight
=
1.0
f
,
float
exposure_weight
=
0.0
f
);
// "Dynamic range improvement through multiple exposures", Robertson et al., 1999
// "Dynamic range improvement through multiple exposures", Robertson et al., 1999
class
CV_EXPORTS_W
MergeRobertson
:
public
MergeExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
)
=
0
;
};
class
CV_EXPORTS_W
MergeRobertson
:
public
MergeExposures
{
public
:
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
,
InputArray
response
)
=
0
;
CV_WRAP
virtual
void
process
(
InputArrayOfArrays
src
,
OutputArray
dst
,
InputArray
times
)
=
0
;
};
CV_EXPORTS_W
Ptr
<
MergeRobertson
>
createMergeRobertson
();
CV_EXPORTS_W
Ptr
<
MergeRobertson
>
createMergeRobertson
(
);
CV_EXPORTS_W
void
decolor
(
InputArray
src
,
OutputArray
grayscale
,
OutputArray
color_boost
);
CV_EXPORTS_W
void
decolor
(
InputArray
src
,
OutputArray
grayscale
,
OutputArray
color_boost
);
CV_EXPORTS_W
void
seamlessClone
(
InputArray
src
,
InputArray
dst
,
InputArray
mask
,
Point
p
,
OutputArray
blend
,
int
flags
);
CV_EXPORTS_W
void
seamlessClone
(
InputArray
src
,
InputArray
dst
,
InputArray
mask
,
Point
p
,
OutputArray
blend
,
int
flags
);
CV_EXPORTS_W
void
colorChange
(
InputArray
src
,
InputArray
mask
,
OutputArray
dst
,
float
red_mul
=
1.0
,
float
green_mul
=
1.0
,
float
blue_mul
=
1.0
);
CV_EXPORTS_W
void
colorChange
(
InputArray
src
,
InputArray
mask
,
OutputArray
dst
,
float
red_mul
=
1.0
,
float
green_mul
=
1.0
,
float
blue_mul
=
1.0
);
CV_EXPORTS_W
void
illuminationChange
(
InputArray
src
,
InputArray
mask
,
OutputArray
dst
,
float
alpha
=
0.2
,
float
beta
=
0.4
);
CV_EXPORTS_W
void
illuminationChange
(
InputArray
src
,
InputArray
mask
,
OutputArray
dst
,
float
alpha
=
0.2
,
float
beta
=
0.4
);
CV_EXPORTS_W
void
textureFlattening
(
InputArray
src
,
InputArray
mask
,
OutputArray
dst
,
double
low_threshold
,
double
high_threshold
,
int
kernel_size
);
CV_EXPORTS_W
void
textureFlattening
(
InputArray
src
,
InputArray
mask
,
OutputArray
dst
,
double
low_threshold
=
30
,
double
high_threshold
=
45
,
int
kernel_size
=
3
);
CV_EXPORTS_W
void
edgePreservingFilter
(
InputArray
src
,
OutputArray
dst
,
int
flags
=
1
,
float
sigma_s
=
60
,
float
sigma_r
=
0.4
);
CV_EXPORTS_W
void
edgePreservingFilter
(
InputArray
src
,
OutputArray
dst
,
int
flags
=
1
,
float
sigma_s
=
60
,
float
sigma_r
=
0.4
);
CV_EXPORTS_W
void
detailEnhance
(
InputArray
src
,
OutputArray
dst
,
float
sigma_s
=
10
,
float
sigma_r
=
0.15
);
CV_EXPORTS_W
void
detailEnhance
(
InputArray
src
,
OutputArray
dst
,
float
sigma_s
=
10
,
float
sigma_r
=
0.15
);
CV_EXPORTS_W
void
pencilSketch
(
InputArray
src
,
OutputArray
dst1
,
OutputArray
dst2
,
float
sigma_s
=
60
,
float
sigma_r
=
0.07
,
float
shade_factor
=
0.02
);
CV_EXPORTS_W
void
pencilSketch
(
InputArray
src
,
OutputArray
dst1
,
OutputArray
dst2
,
float
sigma_s
=
60
,
float
sigma_r
=
0.07
,
float
shade_factor
=
0.02
);
CV_EXPORTS_W
void
stylization
(
InputArray
src
,
OutputArray
dst
,
float
sigma_s
=
60
,
float
sigma_r
=
0.45
);
CV_EXPORTS_W
void
stylization
(
InputArray
src
,
OutputArray
dst
,
float
sigma_s
=
60
,
float
sigma_r
=
0.45
);
CV_EXPORTS_W
void
edgeEnhance
(
InputArray
src
,
OutputArray
dst
,
float
sigma_s
=
60
,
float
sigma_r
=
0.45
);
}
// cv
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment