#ifndef PROCESSOR_H #define PROCESSOR_H #include #include extern "C" { #include #include #include } #include "fsutils.h" enum class ProcessingMode { Filter, Interpolate, }; enum class ProcessorType { Libplacebo, RealESRGAN, RIFE, }; struct LibplaceboConfig { StringType shader_path; }; struct RealESRGANConfig { bool tta_mode; StringType model_name; }; struct RIFEConfig { bool tta_mode; bool tta_temporal_mode; bool uhd_mode; int num_threads; StringType model_name; }; // Unified filter configuration struct ProcessorConfig { ProcessorType processor_type; int width; int height; int scaling_factor; int frm_rate_mul; float scn_det_thresh; std::variant config; }; class Processor { public: virtual ~Processor() = default; virtual int init(AVCodecContext *dec_ctx, AVCodecContext *enc_ctx, AVBufferRef *hw_ctx) = 0; virtual int flush(std::vector &_) { return 0; } virtual ProcessingMode get_processing_mode() const = 0; virtual ProcessorType get_processor_type() const = 0; virtual void get_output_dimensions( const ProcessorConfig &proc_cfg, int in_width, int in_height, int &width, int &height ) const = 0; }; // Abstract base class for filters class Filter : public Processor { public: ProcessingMode get_processing_mode() const override { return ProcessingMode::Filter; } virtual int filter(AVFrame *in_frame, AVFrame **out_frame) = 0; }; // Abstract base class for interpolators class Interpolator : public Processor { public: ProcessingMode get_processing_mode() const override { return ProcessingMode::Interpolate; } virtual int interpolate(AVFrame *prev_frame, AVFrame *in_frame, AVFrame **out_frame, float time_step) = 0; }; #endif // PROCESSOR_H