필터 지우기
필터 지우기

VideoWriter Error: No frames were written to this file

조회 수: 5 (최근 30일)
Enzo Yacometti
Enzo Yacometti 2023년 1월 19일
댓글: Walter Roberson 2023년 3월 15일
Hello everyone,
I have this code that is supposed to write frames on a video and save it:
function rgb_array = renderDrivingEnv(time, action, xy_pos, xy_dot, xy_dotdot, ...
yaw, lane_dist, lane_curvature, lane_curvature_derivate, heading_angle, inert_angle, engine_info, rewards, scene_info, folder, baseFileName, saveVideo, impaired, testing, invert_y_and_yaw, train_gail)
% Define global variables.
global currentTimeEditField steerEditField accelEditField accelLable decelEditField decelLable rewEditField totRewEditField impLable impEditField belLable belEditField...
totRewLable rewLable egoVehicle scenario cgVel currentStepEditField writerObj hLineOffset hLineLateralDev hLineSteering hLineYaw gearEditField kmHEditField...
labLable labEditField hLineImp hPanelPlotImp;
% inizialize output
rgb_array = 0;
%% Create and set Figure Properties.
figureName = 'Simulation Rendering';
hFigure = findobj('Type','Figure','Name',figureName);
if isempty(hFigure)
% import scenario parameters
egoVehicle = evalin("base", "egoVehicle");
scenario = evalin("base", "scenario");
sampleTime = evalin("base", "sampleTime");
%% Save scenario plot
fullFileName = fullfile(folder, baseFileName);
fig = figure('doublebuffer','off','Visible','Off');
ax = axes('Parent',fig);
plot(scenario,'Parent', ax);
saveas(fig,fullFileName, 'png');
%% Initialize rendering window
screenSize = double(get(groot,'ScreenSize'));
hFigure = figure('Name',figureName);
hFigure.Position = [screenSize(3)*0.17 screenSize(4)*0.15 screenSize(3)*0.7 screenSize(4)*0.7];
hFigure.NumberTitle = 'off';
hFigure.MenuBar = 'none';
hFigure.ToolBar = 'none';
train_gail_is = train_gail
invert_y_and_yaw_is = invert_y_and_yaw
openRenderView(hFigure, egoVehicle, scenario);
updateSceneInfo(scene_info);
%% Set up the movie structure.
% Create a VideoWriter object to write the video out to a new, different file.
profile = 'MPEG-4';
% if isempty(writerObj)
file_name = fullFileName
writerObj = VideoWriter(fullFileName, profile);
writerObj.Quality = 30;
writerObj.FrameRate = 1/sampleTime;
% end
open(writerObj);
% Need to change from the default renderer to zbuffer to get it to work right.
% openGL doesn't work and Painters is way too slow.
set(gcf, 'renderer', 'zbuffer');
end
totalframes=VID.NumberOfFrames
%% Save rendering video
if saveVideo
close(hFigure);
close(writerObj);
return;
end
% Update current simulation time.
currentTimeEditField.String = strcat(num2str(time(2),'%.2f'),'s');
currentStepEditField.String = time(2)/time(1);
% Update Engine Info
if train_gail
gearEditField.String = strcat(num2str(engine_info(1),'%d'));
else
gearEditField.String = strcat(num2str(engine_info(2),'%d'));
end
kmHEditField.String = strcat(num2str(xy_dot(1)*3.6,'%.f Km/h'));
% Update current action.
if train_gail
steerEditField.String = strcat(num2str(action(1),'%.2f'));
else
steerEditField.String = strcat(num2str(deg2rad(action(1)),'%.2f'));
end
%% Update observation information .
updateObsInfo(xy_pos, xy_dot,xy_dotdot, yaw, lane_dist, heading_angle, lane_curvature, lane_curvature_derivate, engine_info);
% Some data collected had Y coordinate and yaw angle inverted
if invert_y_and_yaw
egoVehicle.Position = [xy_pos(1) -xy_pos(2) 0];
egoVehicle.Yaw = -rad2deg(yaw(1));
else
egoVehicle.Position = [xy_pos(1) xy_pos(2) 0];
egoVehicle.Yaw = rad2deg(yaw(1));
end
if train_gail
egoVehicle.Yaw = rad2deg(inert_angle(3));
end
if testing
egoVehicle.Mesh = driving.scenario.truckMesh;
else
egoVehicle.Mesh = driving.scenario.carMesh;
end
%% Update plots.
% Ego View
updatePlots(scenario);
% Write this frame out to a new video file.
% pause for frame processing...
pause(0.1)
thisFrame = getframe(hFigure);
writeVideo(writerObj, thisFrame);
end
Where it runs recurrently the file (entering only once in the "isempty" condition to create the figure)
At the end I get:
Warning: No video frames were written to this file. The file may be invalid.
Anyone know how to debug this? The videos are supposed to be long so I'm taking a really long time to debug...
Thanks.
  댓글 수: 1
Walter Roberson
Walter Roberson 2023년 3월 15일
Could you confirm that the save video parameter is false except for the final call?

댓글을 달려면 로그인하십시오.

답변 (1개)

Sachin
Sachin 2023년 3월 15일
Based on my understanding, you are getting warning ‘No frames were written to this file’. Here are some points that might be helpful to you:
  1. Check that fullfile name is correct.
  2. May be debugger reveals some details. Type this in command window: Then run the code again.
dbstop if caught error
3. You can suppress warning to check if warning is causing the issues. Refer the following documentation for suppress - warnings
Thanks
Sachin

카테고리

Help CenterFile Exchange에서 Modeling에 대해 자세히 알아보기

제품


릴리스

R2021b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by