Krita Source Code Documentation
Loading...
Searching...
No Matches
KisWaveletNoiseReduction Class Reference

#include <kis_wavelet_noise_reduction.h>

+ Inheritance diagram for KisWaveletNoiseReduction:

Public Member Functions

KisConfigWidgetcreateConfigurationWidget (QWidget *parent, const KisPaintDeviceSP dev, bool useForMasks) const override
 
 KisWaveletNoiseReduction ()
 
void processImpl (KisPaintDeviceSP device, const QRect &applyRect, const KisFilterConfigurationSP config, KoUpdater *progressUpdater) const override
 
 ~KisWaveletNoiseReduction () override
 
- Public Member Functions inherited from KisFilter
virtual QRect changedRect (const QRect &rect, const KisFilterConfigurationSP config, int lod) const
 
virtual bool configurationAllowedForMask (KisFilterConfigurationSP config) const
 
virtual void fixLoadedFilterConfigurationForMasks (KisFilterConfigurationSP config) const
 
 KisFilter (const KoID &id, const KoID &category, const QString &entry)
 
virtual QRect neededRect (const QRect &rect, const KisFilterConfigurationSP config, int lod) const
 
virtual bool needsTransparentPixels (const KisFilterConfigurationSP config, const KoColorSpace *cs) const
 
void process (const KisPaintDeviceSP src, KisPaintDeviceSP dst, KisSelectionSP selection, const QRect &applyRect, const KisFilterConfigurationSP config, KoUpdater *progressUpdater=0) const
 
void process (KisPaintDeviceSP device, const QRect &applyRect, const KisFilterConfigurationSP config, KoUpdater *progressUpdater=0) const
 
virtual bool supportsLevelOfDetail (const KisFilterConfigurationSP config, int lod) const
 
 ~KisFilter () override
 
- Public Member Functions inherited from KisBaseProcessor
KisBookmarkedConfigurationManagerbookmarkManager ()
 
const KisBookmarkedConfigurationManagerbookmarkManager () const
 
ColorSpaceIndependence colorSpaceIndependence () const
 
virtual KisFilterConfigurationSP factoryConfiguration (KisResourcesInterfaceSP resourcesInterface) const
 
QString id () const
 
 KisBaseProcessor (const KoID &id, const KoID &category, const QString &entry)
 
KoID menuCategory () const
 
QString menuEntry () const
 
QString name () const
 
 Private ()
 
QKeySequence shortcut () const
 
bool showConfigurationWidget ()
 If true, the filter wants to show a configuration widget.
 
bool supportsAdjustmentLayers () const
 This filter can be used in adjustment layers.
 
bool supportsPainting () const
 
bool supportsThreading () const
 
virtual ~KisBaseProcessor ()
 
- Public Member Functions inherited from Private
 Private (KisCanvas2 *c)
 
- Public Member Functions inherited from KisShared
bool deref ()
 
bool ref ()
 
int refCount ()
 
QAtomicInt * sharedWeakReference ()
 

Static Public Member Functions

static KoID id ()
 

Private Member Functions

KisFilterConfigurationSP defaultConfiguration (KisResourcesInterfaceSP resourcesInterface) const override
 

Additional Inherited Members

- Public Attributes inherited from KisBaseProcessor
KisBookmarkedConfigurationManagerbookmarkManager
 
KoID category
 
ColorSpaceIndependence colorSpaceIndependence
 
QString entry
 
KoID id
 
QKeySequence shortcut
 
bool showConfigurationWidget
 
bool supportsAdjustmentLayers
 
bool supportsPainting
 
bool supportsThreading
 
- Public Attributes inherited from Private
KisCanvas2canvas
 
int displayedFrame
 
int intendedFrame
 
- Protected Member Functions inherited from KisFilter
QString configEntryGroup () const
 
void setSupportsLevelOfDetail (bool value)
 
- Protected Member Functions inherited from KisBaseProcessor
void init (const QString &configEntryGroup)
 
void setColorSpaceIndependence (ColorSpaceIndependence v)
 
void setShortcut (const QKeySequence &shortcut)
 
void setShowConfigurationWidget (bool v)
 
void setSupportsAdjustmentLayers (bool v)
 
void setSupportsPainting (bool v)
 
void setSupportsThreading (bool v)
 
- Protected Member Functions inherited from KisShared
 KisShared ()
 
 ~KisShared ()
 

Detailed Description

Author
Cyrille Berger

Definition at line 20 of file kis_wavelet_noise_reduction.h.

Constructor & Destructor Documentation

◆ KisWaveletNoiseReduction()

KisWaveletNoiseReduction::KisWaveletNoiseReduction ( )

Definition at line 25 of file kis_wavelet_noise_reduction.cpp.

26 : KisFilter(id(), FiltersCategoryEnhanceId, i18n("&Wavelet Noise Reducer..."))
27{
30}
KisFilter(const KoID &id, const KoID &category, const QString &entry)
Definition kis_filter.cc:22
const KoID FiltersCategoryEnhanceId("enhance_filters", ki18nc("The category of enhancement filters, like sharpen. Verb.", "Enhance"))
void setSupportsThreading(bool v)
void setSupportsPainting(bool v)

References KisBaseProcessor::setSupportsPainting(), and KisBaseProcessor::setSupportsThreading().

◆ ~KisWaveletNoiseReduction()

KisWaveletNoiseReduction::~KisWaveletNoiseReduction ( )
override

Definition at line 33 of file kis_wavelet_noise_reduction.cpp.

34{
35}

Member Function Documentation

◆ createConfigurationWidget()

KisConfigWidget * KisWaveletNoiseReduction::createConfigurationWidget ( QWidget * parent,
const KisPaintDeviceSP dev,
bool useForMasks ) const
overridevirtual

Create the configuration widget for this processor.

Parameters
parentthe Qt owner widget of this widget
devthe paintdevice this filter will act on
useForMasksshown if the filer is going to be used in a mask. Some filters may provide limited options when applied as a mask (e.g. Gaussian Blur)

Reimplemented from KisBaseProcessor.

Definition at line 37 of file kis_wavelet_noise_reduction.cpp.

38{
40 param.push_back(KisDoubleWidgetParam(0.0, 256.0, BEST_WAVELET_THRESHOLD_VALUE, i18n("Threshold"), "threshold"));
41 return new KisMultiDoubleFilterWidget(id().id(), parent, id().id(), param);
42}
std::vector< KisDoubleWidgetParam > vKisDoubleWidgetParam
#define BEST_WAVELET_THRESHOLD_VALUE

References BEST_WAVELET_THRESHOLD_VALUE.

◆ defaultConfiguration()

KisFilterConfigurationSP KisWaveletNoiseReduction::defaultConfiguration ( KisResourcesInterfaceSP resourcesInterface) const
overrideprivatevirtual

Return the configuration set as the default by the user or the default configuration from the filter writer as returned by factoryConfiguration.

This configuration is used by default for the configuration widget and given to the process function if there is no configuration widget.

Returns
the default configuration of this widget

Reimplemented from KisBaseProcessor.

Definition at line 44 of file kis_wavelet_noise_reduction.cpp.

45{
46 KisFilterConfigurationSP config = factoryConfiguration(resourcesInterface);
47 config->setProperty("threshold", BEST_WAVELET_THRESHOLD_VALUE);
48 return config;
49}
virtual KisFilterConfigurationSP factoryConfiguration(KisResourcesInterfaceSP resourcesInterface) const

References BEST_WAVELET_THRESHOLD_VALUE, and KisBaseProcessor::factoryConfiguration().

◆ id()

static KoID KisWaveletNoiseReduction::id ( )
inlinestatic

Definition at line 36 of file kis_wavelet_noise_reduction.h.

36 {
37 return KoID("waveletnoisereducer", i18n("Wavelet Noise Reducer"));
38 }
Definition KoID.h:30

◆ processImpl()

void KisWaveletNoiseReduction::processImpl ( KisPaintDeviceSP device,
const QRect & applyRect,
const KisFilterConfigurationSP config,
KoUpdater * progressUpdater ) const
overridevirtual

Override this function with the implementation of your filter.

This is a low level function that expects all the conditions for the

Parameters
devicebe met. Use usual process() methods instead.
devicethe paint device to filter
applyRectthe rectangle where the filter is applied
configthe parameters of the filter
progressUpdaterto pass on the progress the filter is making

Implements KisFilter.

Definition at line 51 of file kis_wavelet_noise_reduction.cpp.

56{
57 Q_ASSERT(device);
58
60 const float threshold = config->getDouble("threshold", BEST_WAVELET_THRESHOLD_VALUE);
61
62 KisMathToolbox mathToolbox;
63
64 // dbgFilters << size <<"" << maxrectsize <<"" << srcTopLeft.x() <<"" << srcTopLeft.y();
65
66 // dbgFilters <<"Transforming...";
69
70 try {
71 buff = mathToolbox.initWavelet(device, applyRect);
72 } catch (const std::bad_alloc&) {
73 if (buff) delete buff;
74 return;
75 }
76 try {
77 wav = mathToolbox.fastWaveletTransformation(device, applyRect, buff);
78 } catch (const std::bad_alloc&) {
79 if (wav) delete wav;
80 return;
81 }
82
83 float* const fin = wav->coeffs + wav->depth * pow2(wav->size);
84 float* const begin = wav->coeffs + wav->depth;
85
86 const int size = fin - begin;
87 const int progressOffset = int(std::ceil(std::log2(size / 100)));
88 const int progressMask = (1 << progressOffset) - 1;
89 const int numProgressSteps = size >> progressOffset;
90 int pointsProcessed = 0;
91
92 progressUpdater->setRange(0, numProgressSteps);
93
94 for (float* it = begin; it < fin; it++) {
95 if (*it > threshold) {
96 *it -= threshold;
97 } else if (*it < -threshold) {
98 *it += threshold;
99 } else {
100 *it = 0.;
101 }
102
103 if (!(pointsProcessed & progressMask)) {
104 progressUpdater->setValue(pointsProcessed >> progressOffset);
105 }
106 pointsProcessed++;
107 }
108
109 mathToolbox.fastWaveletUntransformation(device, applyRect, wav, buff);
110
111 delete wav;
112 delete buff;
113}
KisWavelet * initWavelet(KisPaintDeviceSP lay, const QRect &)
void fastWaveletUntransformation(KisPaintDeviceSP dst, const QRect &, KisWavelet *wav, KisWavelet *buff=0)
KisWavelet * fastWaveletTransformation(KisPaintDeviceSP src, const QRect &, KisWavelet *buff=0)
void setValue(int value) override
Definition KoUpdater.cpp:64
void setRange(int minimum, int maximum) override
Definition KoUpdater.cpp:79
#define KIS_SAFE_ASSERT_RECOVER_RETURN(cond)
Definition kis_assert.h:128
T pow2(const T &x)
Definition kis_global.h:166
int size(const Forest< T > &forest)
Definition KisForest.h:1232

References BEST_WAVELET_THRESHOLD_VALUE, KisMathToolbox::KisFloatRepresentation::coeffs, KisMathToolbox::KisFloatRepresentation::depth, KisMathToolbox::fastWaveletTransformation(), KisMathToolbox::fastWaveletUntransformation(), KisMathToolbox::initWavelet(), KIS_SAFE_ASSERT_RECOVER_RETURN, pow2(), KoUpdater::setRange(), KoUpdater::setValue(), and KisMathToolbox::KisFloatRepresentation::size.


The documentation for this class was generated from the following files: