Я использую код, почти точно https://github.com/FFmpeg/FFmpeg/blob/m ... w_decode.c, но я не передаю декодированные данные на хост, я оставляю их включенными устройство для последующего использования с кодом cuda (моей целью будет использование данных RGB 8–12 бит на канал).
Интересная часть:
— AV_PIX_FMT_CUDA, что переводится как: «Аппаратное ускорение через CUDA. data содержат указатели CUdeviceptr точно так же, как для кадров системной памяти».).
К сожалению это ничего не говорит о формате пикселей. Я полагаю, что это YUV, но у меня нет более подробной информации.
Я понимаю, что у меня есть два массива: кадр->данные[0] и кадр->данные[1] .
содержит данные, соответствующие Y или одному из каналов RGB, и имеет высоту тона. Когда я сохранил это изображение как черно-белое, я распознал его, за исключением того, что оно одноканальное.
Я использую код, почти точно https://github.com/FFmpeg/FFmpeg/blob/master/doc/examples/hw_decode.c, но я не передаю декодированные данные на хост, я оставляю их включенными устройство для последующего использования с кодом cuda (моей целью будет использование данных RGB 8–12 бит на канал). Интересная часть: [code]//after decoding/encoding status = avcodec_receive_frame(avctx, frame); if (status != AVERROR(EAGAIN) && status != AVERROR_EOF) LogMessage(L"frame timestamp: %i\n", (int)frame->best_effort_timestamp); if (status == AVERROR(EAGAIN) || status == AVERROR_EOF) { av_frame_free(&frame); return 0; } if (status < 0) { LogMessage(L"Error while decoding\n"); goto finish; } { auto descr = AVPixelFormatMap[(AVPixelFormat)frame->format]; std::wstring dsdescr(descr.begin(), descr.end()); LogMessage(L"Pixelformat: %s", dsdescr.c_str());
cudaPitchedPtr CUdeviceptr0{}; // !! hypothetical usage of cudaPitchedPtr !! CUdeviceptr0.ptr = frame->data[0]; CUdeviceptr0.pitch = frame->linesize[0]; //2048 == pitch ? CUdeviceptr0.ysize = frame->height; //1080 CUdeviceptr0.xsize = frame->width; //1920 cudaPitchedPtr CUdeviceptr1{}; CUdeviceptr1.ptr = frame->data[1]; CUdeviceptr1.pitch = frame->linesize[1]; CUdeviceptr1.ysize = frame->height; CUdeviceptr1.xsize = frame->width; } [/code] Мне не удалось найти способ получить формат данных ([code](AVPixelFormat)frame->formatЗначение [/code] — AV_PIX_FMT_CUDA, что переводится как: «Аппаратное ускорение через CUDA. data[i] содержат указатели CUdeviceptr точно так же, как для кадров системной памяти».). К сожалению это ничего не говорит о формате пикселей. Я полагаю, что это YUV, но у меня нет более подробной информации. Я понимаю, что у меня есть два массива: кадр->данные[0] и кадр->данные[1] . [list] [*]Что такое каждый? [/list] [list] [code]frame->data[0][/code] содержит данные, соответствующие Y или одному из каналов RGB, и имеет высоту тона. Когда я сохранил это изображение как черно-белое, я распознал его, за исключением того, что оно одноканальное. [*][code]frame->data[1][/code] установлен, но не содержит данных. Следовательно, это не часть содержимого изображения. [*][code]frame->data[2][/code] имеет значение NULL. [/list] [b]Похоже, что U и V находятся где-то еще.[/b] Я хотел бы перевести данные в собственную структуру cuda, например: [code]cudaPitchedPtr CUdeviceptr{}; CUdeviceptr.ptr = frame->data[0]; CUdeviceptr.ysize = frame->height; CUdeviceptr.xsize = frame->width; [/code] Это нормально, но неполно, поскольку ширина == 1920 высота == 1080 (я думаю, только Y от YUV). [list] [*][b]Если это Y YUV, где данные U и V?[/b]
[*]Как узнать [b]подробнее[/b] о формат данных (RGB, BGR, YUV, 8/10/12 бит на канал, 444, 422, 420 и т. д.) ?
Я использую код, почти точно но я не передаю декодированные данные на хост, я оставляю их включенными устройство для последующего использования с кодом cuda (моей целью будет использование данных RGB 8–12 бит на канал).
Интересная часть:
//after...
Я использую код, почти точно но я не передаю декодированные данные на хост, я оставляю их включенными устройство для последующего использования с кодом cuda (моей целью будет использование данных RGB 8–12 бит на канал).
Интересная часть:
//after...
Версия FFmpeg.AutoGen: 7.0
Далее аналогично файлу Program.cs в каталоге «FFmpeg.AutoGen.Example».
var sourceSize = vsd.FrameSize;
var sourcePixelFormat = AVPixelFormat.AV_PIX_FMT_CUDA;
var destinationSize = sourceSize;
var destinationPixelFormat =...
Я пытался сделать повторную выборку с FFMPEG, но я все время обнаруживал проблемы в своем коде. /> Поэтому я поместил код повторной выборки вручную, потому что я знаю, что стерео. av_opt_set_sample_fmt(swr_ctx, in_sample_fmt , codec_ctx->sample_fmt,...