* Change estimchrom estim hue final * Itcw observer checkbox * 8 spectral colors * 11 spectral colors * 6 spectral colors * Small change to correction green * Fixed various bad behavior - settings itcwb_deltaspec * 4 spectral colors green * 3 green spectral colors * 3 spectral colors green * 5 spectral colors red green * 3 spectral colors red green * 3 spectral colrs green red * Chnage slider choice deltaE - to size color patch * display more info in console * Display more info in console - comment code * Clean - comment code * 8 spectral colors green red * 8 spectral colors blue * 8 spectral colors blue * 3 spectral colors * 6 spectral colors * 4 spectal colors * 2 spectral colors * Eliminate high Y - increse temp iteration - recenter selection inside patch * compatibility 5.9 * Modify dislay and place selected dats in patch * Dispaly in console hue chroma image selection * First optimization * optimization code - clean unused variables * Remove sorted in chroma order - some others changes * 5.9 compatibility * Clean and optimize code * Clean code - more display info in console * More info in console - set itcwb_minsize in option * Display patch chroma in GUI * Change some default settings * Minsize patch GUI * Display GUI patch size * Chroma patch variations * Display in GUI min and max dats found in patch * Some adjustments * Remove too low datas in patch * Various improvment - ponderate * Clean code colortemp comment spectral datas * Comment code - correc gren * Comment and refine code * Fixed bug in improcoordinator * fixes a malfunction of AWB bias in improcoordinator * Various improvments - clean code * 2 improvments green and find patch * Allows parametrind ponder and Ypurple in options * Update autowb - filter on magenta purple * Clean and optimize code * Read colors in GUI * Denoise median 5x5 image datas before Itcwb * Change to GUI * Replace median5x5 by 2 median3x3 - clean GUI code * Work around to recalculate wbauto * Remove work around - change params->wb related change * Disabled low_sampling 5.9 * First try for compatibility Low sampling 5.9 * Re-enable WB autogrey * Change reference image to autogrey if camera settings probably out * Clean code aand adjust settings camera out * Format astylert rawimagesource.cc - various small adjustments * Small correction * Small green correction * Change default settings - correction to autowb bias in improccoordinator * Save provisory work * Save provisory work 2 * Try to find good tempitc with iterate when temptitc very different 5000K * Change 2 default settings * Work around awb temp bias * Limit work around bias - small other changes * 3 spectral colors deep blue * 4 spectral color deep blue * 4 color spectral yellow * 5 spectral colors neutral red-magenta * 5 spectral color neutral red magenta * Change threshold tempitc * 5.9 compatibility * Work around bad claculation Planck's formula * Fixed bad behavior when using blackbody spectal * 6 spectral color - checkbutton remove 2 passes * Fixed various bugs * Format rawimagesource.cc * Various improvment before to find the good selection * First new optimization (perhaps?) * Display GUI patc deltaE * Various optimzation and tooltip * Default observer 2°- Simplify GUI - improve display GUI - remove too low numbers datas * 4 spectral colors - change 2 settings * Change calculation threshold 2 passes * 6 spectral colors magenta * 13 spectral colors * Improvment GUI display * remove checkbutton no_purple * 2 spectral colors - remove in GUI low sampling 5.9 * Change default setting display in console * Change behavior when temp near stdA * 4 spectral colors - settings Itcwb_tempstdA * Gamut control on image histogram * Clean code and format rawimagesource.cc * Comment and format colortemp.cc * Remove unused fileds from GUI - change tooltips * Add tooltips * Various changes * Change settings when camera temperature is out * improvment extra and tooltip * Small change when using auto grey as start reference * Remove itcwb_fgreen from GUI * Various change - and 'unsatisfactory' test to take into account Custom * Change second temp when < 4000 - replace automatic by automatic and refinement * Neutralize 'Use custom tempertaure and green' * Green refinement * Clean code - small changes * Other clean code * Added forgotten itcw_green in procparams.cc * Fixed a bug dispaly deltaE * Change threshold settings - change code for Custom * various change in case of using camera settings * Change way to estimate range green * clean code and message in console * Clean and optimize * Disable 2 passes if custom * Improve GUI 2 passes * Increase sampling and number of temperature above 9400K * Hide AWB temperature bais and green refinement when Custom temerature ans green * marks out the code with past time markers * Improve time processing with spectral colors temp calculations * Replace in console msec by nsec * Scan temp 5.9 * Change max temp and behavior if temp > 15000k * Refine temp near 14000K * Increase sampling temperature 132 to 167 * Increase sampling temperature * Set in preference choice for itcwb_custom * White point calculated with observer instead of table * More on whitepoint calculation - informations * Clean and format code with astyle colortemp.cc rawimagesource.cc improccoordinator.cc * Small change tooltip * Improve update auto-wb * Remove 'use custom temperature and tin' - simplify sampling to 2 choice * Small change to rand AWB bias - green refinement - tooltips * slightly modify the parameters upstream of the algo - do not use camera in some cases * Mixed initial green * Refine init green and temp when no camera * Refine temp and green in do not use camera settings * Change tint threshold and various improvments (tooltips, wrong values..) * Refinment and clean code * Improve mode No use camera settings * Init nocam * Refine use no camera settings * Small change * 5.9 compatibility - and format * Refine sampling temperature around 7000 - 8000K * Format astylert rawimagesource colortemp * 5.9 settings * 5.9 settings 2 * Various change - 5.9 - format * Improve pre and post algorithm * Fixed correction temp > 8000K * Fixed bad behavior Tppat.minchroma * Change sampling choices and tooltip * Change name wp wp2 wip to wb wb2 iwb to avoid misunderstood * Small Change settings - limit display studgood to 0.0001 * Improvment display GUI temp * Change default sampling * Change ACESP0 to JDCmax * Improve GUI abstract profile * Allows dispaly in console xy values thanks to Reffort * Remove bruce rgb in wp and abstract * Change wp abstract and save itcwb with dispaly cellxy * Change prim = 13 improccoordinator iplab2rgb * remove display datas in console - fixed wrong display Y xyY * Fixed ifferences in GUI maxhist minhist * Change limits x y in function sampling * fixed a dizziness * Change after algorithm rule when temp > 6000K * Harmonize limx limy for oldsampling 5.9 * Added Cam xyz matrix to sampling - thanks to Reffort * Display in console xyz matrix * Forgotten instruction when mix camera and autowb grey * Change rgbloc with Camera matrix Dcraw when no input profile * Change rep to repref in rgbxyz * Remove message in console * 5.9 compat * 5.9 compat 2 * 5.9 compat 3 * 5.9 compat 4 * 5.9 compat 5 format * 5.9 compta 6 * Improve code * Diasble itcwb_sampling in GUI * Comment code * Clean and comment code * 5 spectral colors * 9 spectral colors * 2 spectral colors * Various improvments * 5 spectral colors * 5 spectral colors * First changes review lawrence37 * Second changes review Lawrence37 * 3rd changes review Lawrence37 * 4th changes review Lawrence37 * Change windows and appimage yml * Re-enable Rtv4_Bruce in procparams.cc * test for 5.9 compatibility * Try to fixed crash * Slightly improve the management of 5.9 * test for 5.9 compatibility by passing parameters via the GUI * Forgotten parameter * Change ref_spec limit and remove pac_start for itcwb_sampling * Puts back the old Planck formula - the same as in dev * Revert "test for 5.9 compatibility by passing parameters via the GUI" This reverts commit d6b5a8feda31b93a5574cee6ebf4d3e9d58bbcfb. * Switch to new ITCWB only when changing WB method Prevents sudden changing of the white balance if ITCWB is selected and the image is reopened. * Fix spelling in comment * Suggested change from Lawrence37 to whitebalance - small change to improcoordinator * tempbias Set_sentive(false) if itcwb_smapling - clean whitebalance * Another clean whitebalance.cc --------- Co-authored-by: Lawrence Lee <45837045+Lawrence37@users.noreply.github.com>
318 lines
19 KiB
C++
318 lines
19 KiB
C++
/*
|
|
* This file is part of RawTherapee.
|
|
*
|
|
* Copyright (c) 2004-2010 Gabor Horvath <hgabor@rawtherapee.com>
|
|
*
|
|
* RawTherapee is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* RawTherapee is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with RawTherapee. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
#pragma once
|
|
|
|
#include <array>
|
|
#include <iostream>
|
|
#include <memory>
|
|
|
|
#include "array2D.h"
|
|
#include "colortemp.h"
|
|
#include "dnggainmap.h"
|
|
#include "iimage.h"
|
|
#include "imagesource.h"
|
|
#include "procparams.h"
|
|
|
|
#define HR_SCALE 2
|
|
|
|
namespace rtengine
|
|
{
|
|
class PixelsMap;
|
|
class RawImage;
|
|
class DiagonalCurve;
|
|
class RetinextransmissionCurve;
|
|
class RetinexgaintransmissionCurve;
|
|
|
|
class RawImageSource final : public ImageSource
|
|
{
|
|
private:
|
|
static DiagonalCurve *phaseOneIccCurve;
|
|
static DiagonalCurve *phaseOneIccCurveInv;
|
|
static LUTf invGrad; // for fast_demosaic
|
|
static LUTf initInvGrad ();
|
|
static void colorSpaceConversion_ (Imagefloat* im, const procparams::ColorManagementParams& cmp, const ColorTemp &wb, double pre_mul[3], cmsHPROFILE embedded, cmsHPROFILE camprofile, double cam[3][3], const std::string &camName);
|
|
int defTransform (int tran);
|
|
|
|
protected:
|
|
MyMutex getImageMutex; // locks getImage
|
|
|
|
int W, H;
|
|
ColorTemp camera_wb;
|
|
ProgressListener* plistener;
|
|
float scale_mul[4]; // multiplier for each color
|
|
float c_black[4]; // copy of cblack Dcraw for black level
|
|
float c_white[4];
|
|
float cblacksom[4];
|
|
float ref_pre_mul[4];
|
|
double refwb_red;
|
|
double refwb_green;
|
|
double refwb_blue;
|
|
double rgb_cam[3][3];
|
|
double cam_rgb[3][3];
|
|
double xyz_cam[3][3];
|
|
double cam_xyz[3][3];
|
|
bool fuji;
|
|
bool d1x;
|
|
int border;
|
|
float chmax[4], hlmax[4], clmax[4];
|
|
double initialGain; // initial gain calculated after scale_colors
|
|
double camInitialGain;
|
|
double defGain;
|
|
cmsHPROFILE camProfile;
|
|
bool rgbSourceModified;
|
|
|
|
RawImage* ri; // Copy of raw pixels, NOT corrected for initial gain, blackpoint etc.
|
|
RawImage* riFrames[6] = {nullptr};
|
|
unsigned int currFrame = 0;
|
|
unsigned int numFrames = 0;
|
|
int flatFieldAutoClipValue = 0;
|
|
array2D<float> rawData; // holds preprocessed pixel values, rowData[i][j] corresponds to the ith row and jth column
|
|
array2D<float> *rawDataFrames[6] = {nullptr};
|
|
array2D<float> *rawDataBuffer[5] = {nullptr};
|
|
|
|
// the interpolated green plane:
|
|
array2D<float> green;
|
|
array2D<float> greenloc;
|
|
// the interpolated red plane:
|
|
array2D<float> red;
|
|
array2D<float> redloc;
|
|
// the interpolated blue plane:
|
|
array2D<float> blue;
|
|
array2D<float> blueloc;
|
|
array2D<float>* greenCache;
|
|
// the interpolated red plane:
|
|
array2D<float>* redCache;
|
|
// the interpolated blue plane:
|
|
array2D<float>* blueCache;
|
|
bool rawDirty;
|
|
float psRedBrightness[4];
|
|
float psGreenBrightness[4];
|
|
float psBlueBrightness[4];
|
|
|
|
std::vector<double> histMatchingCache;
|
|
const std::unique_ptr<procparams::ColorManagementParams> histMatchingParams;
|
|
|
|
void processFalseColorCorrectionThread(Imagefloat* im, array2D<float> &rbconv_Y, array2D<float> &rbconv_I, array2D<float> &rbconv_Q, array2D<float> &rbout_I, array2D<float> &rbout_Q, const int row_from, const int row_to);
|
|
void hlRecovery(const std::string &method, float* red, float* green, float* blue, int width, float* hlmax);
|
|
void transformRect(const PreviewProps &pp, int tran, int &sx1, int &sy1, int &width, int &height, int &fw);
|
|
void transformPosition(int x, int y, int tran, int& tx, int& ty);
|
|
void ItcWB(bool extra, double &tempref, double &greenref, double &tempitc, double &greenitc, float &temp0, float &delta, int &bia, int &dread, int &kcam, int &nocam, float &studgood, float &minchrom, int &kmin, float &minhist, float &maxhist, array2D<float> &redloc, array2D<float> &greenloc, array2D<float> &blueloc, int bfw, int bfh, double &avg_rm, double &avg_gm, double &avg_bm, const procparams::ColorManagementParams &cmp, const procparams::RAWParams &raw, const procparams::WBParams & wbpar, const procparams::ToneCurveParams &hrp);
|
|
|
|
unsigned FC(int row, int col) const;
|
|
inline void getRowStartEnd (int x, int &start, int &end);
|
|
static void getProfilePreprocParams(cmsHPROFILE in, float& gammafac, float& lineFac, float& lineSum);
|
|
|
|
public:
|
|
RawImageSource ();
|
|
~RawImageSource () override;
|
|
|
|
int load(const Glib::ustring &fname) override { return load(fname, false); }
|
|
int load(const Glib::ustring &fname, bool firstFrameOnly);
|
|
void preprocess (const procparams::RAWParams &raw, const procparams::LensProfParams &lensProf, const procparams::CoarseTransformParams& coarse, bool prepareDenoise = true) override;
|
|
void demosaic (const procparams::RAWParams &raw, bool autoContrast, double &contrastThreshold, bool cache = false) override;
|
|
void retinex (const procparams::ColorManagementParams& cmp, const procparams::RetinexParams &deh, const procparams::ToneCurveParams& Tc, LUTf & cdcurve, LUTf & mapcurve, const RetinextransmissionCurve & dehatransmissionCurve, const RetinexgaintransmissionCurve & dehagaintransmissionCurve, multi_array2D<float, 4> &conversionBuffer, bool dehacontlutili, bool mapcontlutili, bool useHsl, float &minCD, float &maxCD, float &mini, float &maxi, float &Tmean, float &Tsigma, float &Tmin, float &Tmax, LUTu &histLRETI) override;
|
|
void retinexPrepareCurves (const procparams::RetinexParams &retinexParams, LUTf &cdcurve, LUTf &mapcurve, RetinextransmissionCurve &retinextransmissionCurve, RetinexgaintransmissionCurve &retinexgaintransmissionCurve, bool &retinexcontlutili, bool &mapcontlutili, bool &useHsl, LUTu & lhist16RETI, LUTu & histLRETI) override;
|
|
void retinexPrepareBuffers (const procparams::ColorManagementParams& cmp, const procparams::RetinexParams &retinexParams, multi_array2D<float, 4> &conversionBuffer, LUTu &lhist16RETI) override;
|
|
void flush () override;
|
|
void HLRecovery_Global (const procparams::ToneCurveParams &hrp) override;
|
|
void refinement(int PassCount);
|
|
void setBorder(unsigned int rawBorder) override {border = rawBorder;}
|
|
bool isRGBSourceModified() const override
|
|
{
|
|
return rgbSourceModified; // tracks whether cached rgb output of demosaic has been modified
|
|
}
|
|
|
|
void processFlatField(const procparams::RAWParams &raw, const RawImage *riFlatFile, array2D<float> &rawData, const float black[4]);
|
|
void copyOriginalPixels(const procparams::RAWParams &raw, RawImage *ri, const RawImage *riDark, RawImage *riFlatFile, array2D<float> &rawData );
|
|
void scaleColors (int winx, int winy, int winw, int winh, const procparams::RAWParams &raw, array2D<float> &rawData); // raw for cblack
|
|
void WBauto(bool extra, double &tempref, double &greenref, array2D<float> &redloc, array2D<float> &greenloc, array2D<float> &blueloc, int bfw, int bfh, double &avg_rm, double &avg_gm, double &avg_bm, double &tempitc, double &greenitc, float &temp0, float &delta, int &bia, int &dread, int &kcam, int &nocam, float &studgood, float &minchrom, int &kmin, float &minhist, float &maxhist, bool &twotimes, const procparams::WBParams & wbpar, int begx, int begy, int yEn, int xEn, int cx, int cy, const procparams::ColorManagementParams &cmp, const procparams::RAWParams &raw, const procparams::ToneCurveParams &hrp) override;
|
|
void getAutoWBMultipliersitc(bool extra, double &tempref, double &greenref, double &tempitc, double &greenitc, float &temp0, float &delta, int &bia, int &dread, int &kcam, int &nocam, float &studgood, float &minchrom, int &kmin, float &minhist, float &maxhist, int begx, int begy, int yEn, int xEn, int cx, int cy, int bf_h, int bf_w, double &rm, double &gm, double &bm, const procparams::WBParams & wbpar, const procparams::ColorManagementParams &cmp, const procparams::RAWParams &raw, const procparams::ToneCurveParams &hrp) override;
|
|
void getrgbloc(int begx, int begy, int yEn, int xEn, int cx, int cy, int bf_h, int bf_w, const procparams::WBParams & wbpar) override;
|
|
|
|
void getWBMults (const ColorTemp &ctemp, const procparams::RAWParams &raw, std::array<float, 4>& scale_mul, float &autoGainComp, float &rm, float &gm, float &bm) const override;
|
|
void getImage (const ColorTemp &ctemp, int tran, Imagefloat* image, const PreviewProps &pp, const procparams::ToneCurveParams &hrp, const procparams::RAWParams &raw, int opposed) override;
|
|
eSensorType getSensorType () const override;
|
|
bool isMono () const override;
|
|
ColorTemp getWB () const override
|
|
{
|
|
return camera_wb;
|
|
}
|
|
void getAutoWBMultipliers (double &rm, double &gm, double &bm) override;
|
|
ColorTemp getSpotWB (std::vector<Coord2D> &red, std::vector<Coord2D> &green, std::vector<Coord2D> &blue, int tran, double equal, StandardObserver observer) override;
|
|
bool isWBProviderReady () override
|
|
{
|
|
return rawData;
|
|
}
|
|
|
|
double getDefGain () const override
|
|
{
|
|
return defGain;
|
|
}
|
|
|
|
void getFullSize (int& w, int& h, int tr = TR_NONE) override;
|
|
void getSize (const PreviewProps &pp, int& w, int& h) override;
|
|
int getRotateDegree() const override;
|
|
|
|
ImageMatrices* getImageMatrices () override
|
|
{
|
|
return &imatrices;
|
|
}
|
|
bool isRAW() const override
|
|
{
|
|
return true;
|
|
}
|
|
|
|
bool isGainMapSupported() const override;
|
|
|
|
void setProgressListener (ProgressListener* pl) override
|
|
{
|
|
plistener = pl;
|
|
}
|
|
void getAutoExpHistogram (LUTu & histogram, int& histcompr) override;
|
|
void getRAWHistogram (LUTu & histRedRaw, LUTu & histGreenRaw, LUTu & histBlueRaw) override;
|
|
void getAutoMatchedToneCurve(const procparams::ColorManagementParams &cp, StandardObserver observer, std::vector<double> &outCurve) override;
|
|
DCPProfile *getDCP(const procparams::ColorManagementParams &cmp, DCPProfileApplyState &as) override;
|
|
|
|
void convertColorSpace(Imagefloat* image, const procparams::ColorManagementParams &cmp, const ColorTemp &wb) override;
|
|
static bool findInputProfile(Glib::ustring inProfile, cmsHPROFILE embedded, std::string camName, DCPProfile **dcpProf, cmsHPROFILE& in);
|
|
static void colorSpaceConversion(Imagefloat* im, const procparams::ColorManagementParams& cmp, const ColorTemp &wb, double pre_mul[3], cmsHPROFILE embedded, cmsHPROFILE camprofile, double cam[3][3], const std::string &camName)
|
|
{
|
|
colorSpaceConversion_(im, cmp, wb, pre_mul, embedded, camprofile, cam, camName);
|
|
}
|
|
static void inverse33(const double (*coeff)[3], double (*icoeff)[3]);
|
|
|
|
void MSR(float** luminance, float **originalLuminance, float **exLuminance, const LUTf& mapcurve, bool mapcontlutili, int width, int height, const procparams::RetinexParams &deh, const RetinextransmissionCurve & dehatransmissionCurve, const RetinexgaintransmissionCurve & dehagaintransmissionCurve, float &minCD, float &maxCD, float &mini, float &maxi, float &Tmean, float &Tsigma, float &Tmin, float &Tmax);
|
|
void HLRecovery_inpaint (float** red, float** green, float** blue, int blur);
|
|
void highlight_recovery_opposed(float scale_mul[3], const ColorTemp &wb, float gainth);
|
|
static void HLRecovery_Luminance (float* rin, float* gin, float* bin, float* rout, float* gout, float* bout, int width, float maxval);
|
|
static void HLRecovery_CIELab (float* rin, float* gin, float* bin, float* rout, float* gout, float* bout, int width, float maxval, double cam[3][3], double icam[3][3]);
|
|
static void HLRecovery_blend (float* rin, float* gin, float* bin, int width, float maxval, float* hlmax);
|
|
static void init ();
|
|
static void cleanup ();
|
|
void setCurrentFrame(unsigned int frameNum) override {
|
|
if (numFrames == 2 && frameNum == 2) { // special case for averaging of two frames
|
|
currFrame = frameNum;
|
|
ri = riFrames[0];
|
|
} else {
|
|
currFrame = std::min(numFrames - 1, frameNum);
|
|
ri = riFrames[currFrame];
|
|
}
|
|
}
|
|
int getFrameCount() override {return numFrames;}
|
|
int getFlatFieldAutoClipValue() override {return flatFieldAutoClipValue;}
|
|
|
|
class GreenEqulibrateThreshold {
|
|
public:
|
|
explicit GreenEqulibrateThreshold(float thresh): thresh_(thresh) {}
|
|
virtual ~GreenEqulibrateThreshold() {}
|
|
virtual float operator()(int row, int column) const { return thresh_; }
|
|
protected:
|
|
const float thresh_;
|
|
};
|
|
|
|
class CFALineDenoiseRowBlender {
|
|
public:
|
|
virtual ~CFALineDenoiseRowBlender() {}
|
|
virtual float operator()(int row) const { return 1.f; }
|
|
};
|
|
|
|
protected:
|
|
typedef unsigned short ushort;
|
|
void processFalseColorCorrection(Imagefloat* i, const int steps);
|
|
inline void convert_row_to_YIQ(const float* const r, const float* const g, const float* const b, float* Y, float* I, float* Q, const int W);
|
|
inline void convert_row_to_RGB(float* r, float* g, float* b, const float* const Y, const float* const I, const float* const Q, const int W);
|
|
inline void convert_to_RGB(float &r, float &g, float &b, const float Y, const float I, const float Q);
|
|
|
|
inline void interpolate_row_g (float* agh, float* agv, int i);
|
|
inline void interpolate_row_rb (float* ar, float* ab, float* pg, float* cg, float* ng, int i);
|
|
inline void interpolate_row_rb_mul_pp (const array2D<float> &rawData, float* ar, float* ab, float* pg, float* cg, float* ng, int i, float r_mul, float g_mul, float b_mul, int x1, int width, int skip);
|
|
|
|
float* CA_correct_RT(
|
|
bool autoCA,
|
|
size_t autoIterations,
|
|
double cared,
|
|
double cablue,
|
|
bool avoidColourshift,
|
|
array2D<float> &rawData,
|
|
double* fitParamsTransfer,
|
|
bool fitParamsIn,
|
|
bool fitParamsOut,
|
|
float* buffer,
|
|
bool freeBuffer,
|
|
size_t chunkSize = 1,
|
|
bool measure = false
|
|
);
|
|
void ddct8x8s(int isgn, float a[8][8]);
|
|
|
|
int interpolateBadPixelsBayer(const PixelsMap &bitmapBads, array2D<float> &rawData);
|
|
int interpolateBadPixelsNColours(const PixelsMap &bitmapBads, int colours);
|
|
int interpolateBadPixelsXtrans(const PixelsMap &bitmapBads);
|
|
int findHotDeadPixels(PixelsMap &bpMap, float thresh, bool findHotPixels, bool findDeadPixels) const;
|
|
int findZeroPixels(PixelsMap &bpMap) const;
|
|
void cfa_linedn (float linenoiselevel, bool horizontal, bool vertical, const CFALineDenoiseRowBlender &rowblender);//Emil's line denoise
|
|
|
|
void green_equilibrate_global(array2D<float> &rawData);
|
|
void green_equilibrate (const GreenEqulibrateThreshold &greenthresh, array2D<float> &rawData);//Emil's green equilibration
|
|
|
|
void nodemosaic(bool bw);
|
|
void eahd_demosaic();
|
|
void hphd_demosaic();
|
|
void vng4_demosaic(const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue);
|
|
void igv_interpolate(int winw, int winh);
|
|
void lmmse_interpolate_omp(int winw, int winh, const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue, int iterations);
|
|
void amaze_demosaic_RT(int winx, int winy, int winw, int winh, const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue, size_t chunkSize = 1, bool measure = false);//Emil's code for AMaZE
|
|
void dual_demosaic_RT(bool isBayer, const procparams::RAWParams &raw, int winw, int winh, const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue, double &contrast, bool autoContrast = false);
|
|
void fast_demosaic();//Emil's code for fast demosaicing
|
|
void dcb_demosaic(int iterations, bool dcb_enhance);
|
|
void ahd_demosaic();
|
|
void rcd_demosaic(size_t chunkSize = 1, bool measure = false);
|
|
void border_interpolate(int winw, int winh, int lborders, const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue);
|
|
void dcb_initTileLimits(int &colMin, int &rowMin, int &colMax, int &rowMax, int x0, int y0, int border);
|
|
void fill_raw(float (*cache)[3], int x0, int y0, float** rawData);
|
|
void fill_border(float (*cache)[3], int border, int x0, int y0);
|
|
void copy_to_buffer(float (*image2)[2], float (*image)[3]);
|
|
void dcb_hid(float (*image)[3], int x0, int y0);
|
|
void dcb_color(float (*image)[3], int x0, int y0);
|
|
void dcb_hid2(float (*image)[3], int x0, int y0);
|
|
void dcb_map(float (*image)[3], uint8_t *map, int x0, int y0);
|
|
void dcb_correction(float (*image)[3], uint8_t *map, int x0, int y0);
|
|
void dcb_pp(float (*image)[3], int x0, int y0);
|
|
void dcb_correction2(float (*image)[3], uint8_t *map, int x0, int y0);
|
|
void restore_from_buffer(float (*image)[3], float (*image2)[2]);
|
|
void dcb_refinement(float (*image)[3], uint8_t *map, int x0, int y0);
|
|
void dcb_color_full(float (*image)[3], int x0, int y0, float (*chroma)[2]);
|
|
void cielab(const float (*rgb)[3], float* l, float* a, float *b, const int width, const int height, const int labWidth, const float xyz_cam[3][3]);
|
|
void xtransborder_interpolate (int border, array2D<float> &red, array2D<float> &green, array2D<float> &blue);
|
|
void xtrans_interpolate (const int passes, const bool useCieLab, size_t chunkSize = 1, bool measure = false);
|
|
void fast_xtrans_interpolate (const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue);
|
|
void fast_xtrans_interpolate_blend (const float* const * blend, const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue);
|
|
void pixelshift(int winx, int winy, int winw, int winh, const procparams::RAWParams &rawParams, unsigned int frame, const std::string &make, const std::string &model, float rawWpCorrection);
|
|
void bayer_bilinear_demosaic(const float *const * blend, const array2D<float> &rawData, array2D<float> &red, array2D<float> &green, array2D<float> &blue);
|
|
void hflip (Imagefloat* im);
|
|
void vflip (Imagefloat* im);
|
|
void getRawValues(int x, int y, int rotate, int &R, int &G, int &B) override;
|
|
void captureSharpening(const procparams::CaptureSharpeningParams &sharpeningParams, bool showMask, double &conrastThreshold, double &radius) override;
|
|
void applyDngGainMap(const float black[4], const std::vector<GainMap> &gainMaps);
|
|
public:
|
|
void wbMul2Camera(double &rm, double &gm, double &bm) override;
|
|
void wbCamera2Mul(double &rm, double &gm, double &bm) override;
|
|
};
|
|
|
|
}
|