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

时间:2017-04-27 03:28:06

标签: c++ opencv machine-learning ffmpeg computer-vision

我想从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);   
}

1 个答案:

答案 0 :(得分:0)

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

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;

}