编码域中的DCT系数和运动矢量提取

DCT coefficient and motion vector extraction in encoded domain

本文关键字:运动 提取 DCT 编码      更新时间:2023-10-16

我想从MPEG 4视频中提取DCT系数和运动向量而不解码。我已经搜索了答案,但没有发现任何有用的东西。

请友好地分享任何想法,执行此任务或代码的可能性。

一些我能够使用ffmpeg读取编码代码的代码。

void CFfmpegmethods::VideoRead(){
    //cout << "this is video read" << endl;
    const char *url = "H:/Sanduni_projects/ad_2.mp4";
    AVFormatContext *s = NULL;
    int ret = avformat_open_input(&s, url, NULL, NULL);
    if (ret < 0)
        //abort();
    AVDictionary *options = NULL;
    av_dict_set(&options, "video_size", "640x480", 0);
    av_dict_set(&options, "pixel_format", "rgb24", 0);
    if (avformat_open_input(&s, url, NULL, &options) < 0){
        //abort();
    }
    av_dict_free(&options);
    AVDictionaryEntry *e;
    if (e = av_dict_get(options, "", NULL, AV_DICT_IGNORE_SUFFIX)) {
        fprintf(stderr, "Option %s not recognized by the demuxer.n", e->key);
        //abort();
    }
    avformat_close_input(&s);   
}

我能够如下提取运动向量。在这里,我使用坐标生成一个数组。那是向量的初始和目的地位置。

static int MV_generation(const AVPacket *pkt)
{
    double x_src_val = 0;
    double y_src_val = 0;
    double x_dst_val = 0;
    double y_dst_val = 0;
int ret = avcodec_send_packet(video_dec_ctx, pkt);
while (ret >= 0){
    ret = avcodec_receive_frame(video_dec_ctx, frame);
    if (ret == AVERROR(EAGAIN) || ret == AVERROR_EOF) {
        break;
    }
    if (ret >= 0) {
        AVFrameSideData *sd;
        sd = av_frame_get_side_data(frame, AV_FRAME_DATA_MOTION_VECTORS);
        if (sd) {
            const AVMotionVector *mvs = (const AVMotionVector *)sd->data;
            int size_sd = sd->size;
            }
        av_frame_unref(frame);
    }
}
return 0;

}