X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=deconvolution_sharpen_effect.h;h=9279abf52f9686ca60bac6c652fa9e5b14db9971;hp=bc0bbd48ee8e07e896624d08b7deb1a41ce0ea69;hb=18fdebc534adc6b7a4c36b290b01d598bcb671bc;hpb=42c35394ef92bb5179fc4879cb55b866fd422d28 diff --git a/deconvolution_sharpen_effect.h b/deconvolution_sharpen_effect.h index bc0bbd4..9279abf 100644 --- a/deconvolution_sharpen_effect.h +++ b/deconvolution_sharpen_effect.h @@ -1,5 +1,5 @@ -#ifndef _DECONVOLUTION_SHARPEN_EFFECT_H -#define _DECONVOLUTION_SHARPEN_EFFECT_H 1 +#ifndef _MOVIT_DECONVOLUTION_SHARPEN_EFFECT_H +#define _MOVIT_DECONVOLUTION_SHARPEN_EFFECT_H 1 // DeconvolutionSharpenEffect is an effect that sharpens by way of deconvolution // (i.e., trying to reverse the blur kernel, as opposed to just boosting high @@ -19,6 +19,10 @@ // // Jain, Anil K.: “Fundamentals of Digital Image Processing”, Prentice Hall, 1988. +#include +#include +#include + #include "effect.h" class DeconvolutionSharpenEffect : public Effect { @@ -27,6 +31,9 @@ public: virtual std::string effect_type_id() const { return "DeconvolutionSharpenEffect"; } std::string output_fragment_shader(); + // Samples a lot of times from its input. + virtual bool needs_texture_bounce() const { return true; } + virtual void inform_input_size(unsigned input_num, unsigned width, unsigned height) { this->width = width; @@ -34,6 +41,7 @@ public: } void set_gl_state(GLuint glsl_program_num, const std::string &prefix, unsigned *sampler_num); + virtual AlphaHandling alpha_handling() const { return INPUT_PREMULTIPLIED_ALPHA_KEEP_BLANK; } private: // Input size. @@ -51,6 +59,13 @@ private: // (ie., blur is assumed to be a 2px circle), correlation = 0.95, and noise = 0.01. // Note that once the radius starts going too far past R, you will get nonsensical results. float circle_radius, gaussian_radius, correlation, noise; + + // The deconvolution kernel, and the parameters last time we did an update. + Eigen::MatrixXf g; + int last_R; + float last_circle_radius, last_gaussian_radius, last_correlation, last_noise; + + void update_deconvolution_kernel(); }; -#endif // !defined(_DECONVOLUTION_SHARPEN_EFFECT_H) +#endif // !defined(_MOVIT_DECONVOLUTION_SHARPEN_EFFECT_H)