/*
* cl_newwavelet_denoise_handler.h - CL wavelet denoise handler
*
* Copyright (c) 2015 Intel Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Author: Wei Zong <wei.zong@intel.com>
*/
#ifndef XCAM_CL_NEWWAVELET_DENOISE_HANLDER_H
#define XCAM_CL_NEWWAVELET_DENOISE_HANLDER_H
#include <xcam_std.h>
#include <ocl/cl_image_handler.h>
#include <base/xcam_3a_result.h>
namespace XCam {
enum CLWaveletFilterBank {
CL_WAVELET_HAAR_ANALYSIS = 0,
CL_WAVELET_HAAR_SYNTHESIS = 1,
};
enum CLWaveletSubband {
CL_WAVELET_SUBBAND_LL = 0,
CL_WAVELET_SUBBAND_HL,
CL_WAVELET_SUBBAND_LH,
CL_WAVELET_SUBBAND_HH,
};
/*------------------------
Wavelet decomposition
frequency block
__ width__
___________________
| | | |
| | | |
| LL | HL |height
| | | |
|_________|_________| |
| | |
| | |
| LH | HH |
| | |
|_________|_________|
--------------------------*/
typedef struct _CLCLWaveletDecompBuffer {
int32_t width;
int32_t height;
uint32_t channel;
int32_t layer;
float noise_variance[3];
SmartPtr<CLImage> ll;
SmartPtr<CLImage> hl[3];
SmartPtr<CLImage> lh[3];
SmartPtr<CLImage> hh[3];
} CLWaveletDecompBuffer;
class CLNewWaveletDenoiseImageHandler;
class CLWaveletNoiseEstimateKernel
: public CLImageKernel
{
public:
explicit CLWaveletNoiseEstimateKernel (
const SmartPtr<CLContext> &context,
const char *name,
SmartPtr<CLNewWaveletDenoiseImageHandler> &handler,
uint32_t channel, uint32_t subband, uint32_t layer);
SmartPtr<CLImage> get_input_buffer ();
SmartPtr<CLImage> get_output_buffer ();
XCamReturn estimate_noise_variance (const VideoBufferInfo & video_info, SmartPtr<CLImage> image, float* noise_var);
protected:
virtual XCamReturn prepare_arguments (
CLArgList &args, CLWorkSize &work_size);
private:
uint32_t _decomposition_levels;
uint32_t _channel;
uint32_t _subband;
uint32_t _current_layer;
float _analog_gain;
SmartPtr<CLNewWaveletDenoiseImageHandler> _handler;
};
class CLWaveletThresholdingKernel
: public CLImageKernel
{
public:
explicit CLWaveletThresholdingKernel (
const SmartPtr<CLContext> &context,
const char *name,
SmartPtr<CLNewWaveletDenoiseImageHandler> &handler,
uint32_t channel, uint32_t layer);
protected:
virtual XCamReturn prepare_arguments (
CLArgList &args, CLWorkSize &work_size);
private:
uint32_t _decomposition_levels;
uint32_t _channel;
uint32_t _current_layer;
SmartPtr<CLNewWaveletDenoiseImageHandler> _handler;
};
class CLWaveletTransformKernel
: public CLImageKernel
{
public:
explicit CLWaveletTransformKernel (
const SmartPtr<CLContext> &context,
const char *name,
SmartPtr<CLNewWaveletDenoiseImageHandler> &handler,
CLWaveletFilterBank fb,
uint32_t channel,
uint32_t layer,
bool bayes_shrink);
SmartPtr<CLWaveletDecompBuffer> get_decomp_buffer (uint32_t channel, int layer);
protected:
virtual XCamReturn prepare_arguments (
CLArgList &args, CLWorkSize &work_size);
private:
CLWaveletFilterBank _filter_bank;
uint32_t _decomposition_levels;
uint32_t _channel;
uint32_t _current_layer;
bool _bayes_shrink;
SmartPtr<CLNewWaveletDenoiseImageHandler> _handler;
};
class CLNewWaveletDenoiseImageHandler
: public CLImageHandler
{
typedef std::list<SmartPtr<CLWaveletDecompBuffer>> CLWaveletDecompBufferList;
public:
explicit CLNewWaveletDenoiseImageHandler (
const SmartPtr<CLContext> &context, const char *name, uint32_t channel);
bool set_denoise_config (const XCam3aResultWaveletNoiseReduction& config);
XCam3aResultWaveletNoiseReduction& get_denoise_config () {
return _config;
};
SmartPtr<CLWaveletDecompBuffer> get_decomp_buffer (uint32_t channel, int layer);
void set_estimated_noise_variation (float* noise_var);
void get_estimated_noise_variation (float* noise_var);
void dump_coeff (SmartPtr<CLImage> image, uint32_t channel, uint32_t layer, uint32_t subband);
protected:
virtual XCamReturn prepare_output_buf (SmartPtr<VideoBuffer> &input, SmartPtr<VideoBuffer> &output);
private:
uint32_t _channel;
XCam3aResultWaveletNoiseReduction _config;
CLWaveletDecompBufferList _decompBufferList;
float _noise_variance[3];
};
SmartPtr<CLImageHandler>
create_cl_newwavelet_denoise_image_handler (
const SmartPtr<CLContext> &context, uint32_t channel, bool bayes_shrink);
};
#endif //XCAM_CL_NEWWAVELET_DENOISE_HANLDER_H