ref: 6a950fee925c341352b6b0d2aef87293ac66f69c
dir: /vp9/simple_encode.h/
#include <memory> #include <vector> enum FrameType { kKeyFrame = 0, kInterFrame, kAlternateReference, }; struct EncodeFrameResult { int show_idx; FrameType frame_type; size_t coding_data_bit_size; size_t coding_data_byte_size; // The EncodeFrame will allocate a buffer, write the coding data into the // buffer and give the ownership of the buffer to coding_data std::unique_ptr<unsigned char[]> coding_data; double psnr; uint64_t sse; int quantize_index; }; class SimpleEncode { public: SimpleEncode(int frame_width, int frame_height, int frame_rate_num, int frame_rate_den, int target_bitrate, int num_frames, const char *infile_path); ~SimpleEncode(); SimpleEncode(SimpleEncode &&) = delete; SimpleEncode &operator=(SimpleEncode &&) = delete; // Make encoder compute the first pass stats and store it internally for // future encode void ComputeFirstPassStats(); // Output the first pass stats std::vector<std::vector<double>> ObserveFirstPassStats(); // Initialize the encoder for actual encoding // This funtion should be called after ComputeFirstPassStats() void StartEncode(); // Free the encoder // This funtion should be called after StartEncode() or EncodeFrame() void EndEncode(); // Encode a frame // This funtion should be called after StartEncode() before EndEncode() void EncodeFrame(EncodeFrameResult *encode_frame_result); // Encode a frame with a specific quantize index // This funtion should be called after StartEncode() before EndEncode() void EncodeFrameWithQuantizeIndex(EncodeFrameResult *encode_frame_result, int quantize_index); // Get the number of coding frames for the video. The coding frames include // show frame and no show frame. // This funtion should be called after ComputeFirstPassStats() int GetCodingFrameNum(); private: class impl; int frame_width; int frame_height; int frame_rate_num; int frame_rate_den; int target_bitrate; int num_frames; FILE *file; std::unique_ptr<impl> pimpl; };