Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(356)

Side by Side Diff: webrtc/modules/video_coding/codecs/test/videoprocessor.h

Issue 2709123004: Step #0: Minor cleanups in VideoProcessor. (Closed)
Patch Set: asapersson comments 1 Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | webrtc/modules/video_coding/codecs/test/videoprocessor.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 233 matching lines...) Expand 10 before | Expand all | Expand 10 after
244 FrameType EncodedFrameType() override; 244 FrameType EncodedFrameType() override;
245 245
246 // Return the number of dropped frames. 246 // Return the number of dropped frames.
247 int NumberDroppedFrames() override; 247 int NumberDroppedFrames() override;
248 248
249 // Return the number of spatial resizes. 249 // Return the number of spatial resizes.
250 int NumberSpatialResizes() override; 250 int NumberSpatialResizes() override;
251 251
252 webrtc::VideoEncoder* const encoder_; 252 webrtc::VideoEncoder* const encoder_;
253 webrtc::VideoDecoder* const decoder_; 253 webrtc::VideoDecoder* const decoder_;
254 std::unique_ptr<VideoBitrateAllocator> bitrate_allocator_; 254 const std::unique_ptr<VideoBitrateAllocator> bitrate_allocator_;
255
256 // Adapters for the codec callbacks.
257 const std::unique_ptr<EncodedImageCallback> encode_callback_;
258 const std::unique_ptr<DecodedImageCallback> decode_callback_;
259
260 PacketManipulator* const packet_manipulator_;
261 const TestConfig& config_;
262
255 // These (mandatory) file manipulators are used for, e.g., objective PSNR and 263 // These (mandatory) file manipulators are used for, e.g., objective PSNR and
256 // SSIM calculations at the end of a test run. 264 // SSIM calculations at the end of a test run.
257 FrameReader* const analysis_frame_reader_; 265 FrameReader* const analysis_frame_reader_;
258 FrameWriter* const analysis_frame_writer_; 266 FrameWriter* const analysis_frame_writer_;
259 PacketManipulator* const packet_manipulator_; 267
260 const TestConfig& config_;
261 Stats* stats_;
262 // These (optional) file writers are used for persistently storing the output 268 // These (optional) file writers are used for persistently storing the output
263 // of the coding pipeline at different stages: pre encode (source), post 269 // of the coding pipeline at different stages: pre encode (source), post
264 // encode (encoded), and post decode (decoded). The purpose is to give the 270 // encode (encoded), and post decode (decoded). The purpose is to give the
265 // experimenter an option to subjectively evaluate the quality of the 271 // experimenter an option to subjectively evaluate the quality of the
266 // encoding, given the test settings. Each frame writer is enabled by being 272 // encoding, given the test settings. Each frame writer is enabled by being
267 // non-null. 273 // non-null.
268 FrameWriter* const source_frame_writer_; 274 FrameWriter* const source_frame_writer_;
269 IvfFileWriter* const encoded_frame_writer_; 275 IvfFileWriter* const encoded_frame_writer_;
270 FrameWriter* const decoded_frame_writer_; 276 FrameWriter* const decoded_frame_writer_;
271 277
272 // Adapters for the codec callbacks.
273 std::unique_ptr<EncodedImageCallback> encode_callback_;
274 std::unique_ptr<DecodedImageCallback> decode_callback_;
275
276 // Keep track of the last successful frame, since we need to write that 278 // Keep track of the last successful frame, since we need to write that
277 // when decoding fails. 279 // when decoding fails.
278 std::unique_ptr<uint8_t[]> last_successful_frame_buffer_; 280 std::unique_ptr<uint8_t[]> last_successful_frame_buffer_;
279 // To keep track of if we have excluded the first key frame from packet loss. 281 // To keep track of if we have excluded the first key frame from packet loss.
280 bool first_key_frame_has_been_excluded_; 282 bool first_key_frame_has_been_excluded_;
281 // To tell the decoder previous frame have been dropped due to packet loss. 283 // To tell the decoder previous frame have been dropped due to packet loss.
282 bool last_frame_missing_; 284 bool last_frame_missing_;
283 // If Init() has executed successfully. 285 // If Init() has executed successfully.
284 bool initialized_; 286 bool initialized_;
285 size_t encoded_frame_size_; 287 size_t encoded_frame_size_;
286 FrameType encoded_frame_type_; 288 FrameType encoded_frame_type_;
287 int prev_time_stamp_; 289 int prev_time_stamp_;
288 int num_dropped_frames_;
289 int num_spatial_resizes_;
290 int last_encoder_frame_width_; 290 int last_encoder_frame_width_;
291 int last_encoder_frame_height_; 291 int last_encoder_frame_height_;
292 292
293 // Statistics. 293 // Statistics.
294 Stats* stats_;
295 int num_dropped_frames_;
296 int num_spatial_resizes_;
294 double bit_rate_factor_; // Multiply frame length with this to get bit rate. 297 double bit_rate_factor_; // Multiply frame length with this to get bit rate.
295 int64_t encode_start_ns_; 298 int64_t encode_start_ns_;
296 int64_t decode_start_ns_; 299 int64_t decode_start_ns_;
297 }; 300 };
298 301
299 } // namespace test 302 } // namespace test
300 } // namespace webrtc 303 } // namespace webrtc
301 304
302 #endif // WEBRTC_MODULES_VIDEO_CODING_CODECS_TEST_VIDEOPROCESSOR_H_ 305 #endif // WEBRTC_MODULES_VIDEO_CODING_CODECS_TEST_VIDEOPROCESSOR_H_
OLDNEW
« no previous file with comments | « no previous file | webrtc/modules/video_coding/codecs/test/videoprocessor.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698