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

Side by Side Diff: webrtc/video/video_quality_test.cc

Issue 2687073002: Revert of Added VP8 simulcast tests. Fixed analyzer to correctly infer timestamps. (Closed)
Patch Set: rebase Created 3 years, 10 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 | « webrtc/video/full_stack_tests.cc ('k') | webrtc/video/video_receive_stream.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) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 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 #include "webrtc/video/video_quality_test.h" 10 #include "webrtc/video/video_quality_test.h"
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after
126 public rtc::VideoSinkInterface<VideoFrame>, 126 public rtc::VideoSinkInterface<VideoFrame>,
127 public EncodedFrameObserver { 127 public EncodedFrameObserver {
128 public: 128 public:
129 VideoAnalyzer(test::LayerFilteringTransport* transport, 129 VideoAnalyzer(test::LayerFilteringTransport* transport,
130 const std::string& test_label, 130 const std::string& test_label,
131 double avg_psnr_threshold, 131 double avg_psnr_threshold,
132 double avg_ssim_threshold, 132 double avg_ssim_threshold,
133 int duration_frames, 133 int duration_frames,
134 FILE* graph_data_output_file, 134 FILE* graph_data_output_file,
135 const std::string& graph_title, 135 const std::string& graph_title,
136 uint32_t ssrc_to_analyze, 136 uint32_t ssrc_to_analyze)
137 uint32_t selected_width,
138 uint32_t selected_height)
139 : transport_(transport), 137 : transport_(transport),
140 receiver_(nullptr), 138 receiver_(nullptr),
141 send_stream_(nullptr), 139 send_stream_(nullptr),
142 receive_stream_(nullptr), 140 receive_stream_(nullptr),
143 captured_frame_forwarder_(this), 141 captured_frame_forwarder_(this),
144 test_label_(test_label), 142 test_label_(test_label),
145 graph_data_output_file_(graph_data_output_file), 143 graph_data_output_file_(graph_data_output_file),
146 graph_title_(graph_title), 144 graph_title_(graph_title),
147 ssrc_to_analyze_(ssrc_to_analyze), 145 ssrc_to_analyze_(ssrc_to_analyze),
148 selected_width_(selected_width),
149 selected_height_(selected_height),
150 pre_encode_proxy_(this), 146 pre_encode_proxy_(this),
151 encode_timing_proxy_(this), 147 encode_timing_proxy_(this),
152 frames_to_process_(duration_frames), 148 frames_to_process_(duration_frames),
153 frames_recorded_(0), 149 frames_recorded_(0),
154 frames_processed_(0), 150 frames_processed_(0),
155 dropped_frames_(0), 151 dropped_frames_(0),
156 dropped_frames_before_first_encode_(0), 152 dropped_frames_before_first_encode_(0),
157 dropped_frames_before_rendering_(0), 153 dropped_frames_before_rendering_(0),
158 last_render_time_(0), 154 last_render_time_(0),
159 rtp_timestamp_delta_(0), 155 rtp_timestamp_delta_(0),
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
223 const PacketTime& packet_time) override { 219 const PacketTime& packet_time) override {
224 // Ignore timestamps of RTCP packets. They're not synchronized with 220 // Ignore timestamps of RTCP packets. They're not synchronized with
225 // RTP packet timestamps and so they would confuse wrap_handler_. 221 // RTP packet timestamps and so they would confuse wrap_handler_.
226 if (RtpHeaderParser::IsRtcp(packet, length)) { 222 if (RtpHeaderParser::IsRtcp(packet, length)) {
227 return receiver_->DeliverPacket(media_type, packet, length, packet_time); 223 return receiver_->DeliverPacket(media_type, packet, length, packet_time);
228 } 224 }
229 225
230 RtpUtility::RtpHeaderParser parser(packet, length); 226 RtpUtility::RtpHeaderParser parser(packet, length);
231 RTPHeader header; 227 RTPHeader header;
232 parser.Parse(&header); 228 parser.Parse(&header);
233 if (!IsFlexfec(header.payloadType) && header.ssrc != ssrc_to_analyze_) { 229 if (!IsFlexfec(header.payloadType)) {
234 // Ignore FlexFEC timestamps, to avoid collisions with media timestamps. 230 // Ignore FlexFEC timestamps, to avoid collisions with media timestamps.
235 // (FlexFEC and media are sent on different SSRCs, which have different 231 // (FlexFEC and media are sent on different SSRCs, which have different
236 // timestamps spaces.) 232 // timestamps spaces.)
237 // Also ignore packets from wrong SSRC.
238 rtc::CritScope lock(&crit_); 233 rtc::CritScope lock(&crit_);
239 int64_t timestamp = 234 int64_t timestamp =
240 wrap_handler_.Unwrap(header.timestamp - rtp_timestamp_delta_); 235 wrap_handler_.Unwrap(header.timestamp - rtp_timestamp_delta_);
241 recv_times_[timestamp] = 236 recv_times_[timestamp] =
242 Clock::GetRealTimeClock()->CurrentNtpInMilliseconds(); 237 Clock::GetRealTimeClock()->CurrentNtpInMilliseconds();
243 } 238 }
244 239
245 return receiver_->DeliverPacket(media_type, packet, length, packet_time); 240 return receiver_->DeliverPacket(media_type, packet, length, packet_time);
246 } 241 }
247 242
248 void MeasuredEncodeTiming(int64_t ntp_time_ms, int encode_time_ms) { 243 void MeasuredEncodeTiming(int64_t ntp_time_ms, int encode_time_ms) {
249 rtc::CritScope crit(&comparison_lock_); 244 rtc::CritScope crit(&comparison_lock_);
250 samples_encode_time_ms_[ntp_time_ms] = encode_time_ms; 245 samples_encode_time_ms_[ntp_time_ms] = encode_time_ms;
251 } 246 }
252 247
253 void PreEncodeOnFrame(const VideoFrame& video_frame) { 248 void PreEncodeOnFrame(const VideoFrame& video_frame) {
254 rtc::CritScope lock(&crit_); 249 rtc::CritScope lock(&crit_);
255 if (!first_encoded_timestamp_) { 250 if (!first_send_timestamp_ && rtp_timestamp_delta_ == 0) {
256 while (frames_.front().timestamp() != video_frame.timestamp()) { 251 while (frames_.front().timestamp() != video_frame.timestamp()) {
257 ++dropped_frames_before_first_encode_; 252 ++dropped_frames_before_first_encode_;
258 frames_.pop_front(); 253 frames_.pop_front();
259 RTC_CHECK(!frames_.empty()); 254 RTC_CHECK(!frames_.empty());
260 } 255 }
261 first_encoded_timestamp_ = 256 first_send_timestamp_ = rtc::Optional<uint32_t>(video_frame.timestamp());
262 rtc::Optional<uint32_t>(video_frame.timestamp());
263 } 257 }
264 } 258 }
265 259
266 void PostEncodeFrameCallback(const EncodedFrame& encoded_frame) {
267 rtc::CritScope lock(&crit_);
268 if (!first_sent_timestamp_ &&
269 encoded_frame.encoded_width_ == selected_width_ &&
270 encoded_frame.encoded_height_ == selected_height_) {
271 first_sent_timestamp_ = rtc::Optional<uint32_t>(encoded_frame.timestamp_);
272 }
273 }
274
275 bool SendRtp(const uint8_t* packet, 260 bool SendRtp(const uint8_t* packet,
276 size_t length, 261 size_t length,
277 const PacketOptions& options) override { 262 const PacketOptions& options) override {
278 RtpUtility::RtpHeaderParser parser(packet, length); 263 RtpUtility::RtpHeaderParser parser(packet, length);
279 RTPHeader header; 264 RTPHeader header;
280 parser.Parse(&header); 265 parser.Parse(&header);
281 266
282 int64_t current_time = 267 int64_t current_time =
283 Clock::GetRealTimeClock()->CurrentNtpInMilliseconds(); 268 Clock::GetRealTimeClock()->CurrentNtpInMilliseconds();
284 bool result = transport_->SendRtp(packet, length, options); 269 bool result = transport_->SendRtp(packet, length, options);
285 { 270 {
286 rtc::CritScope lock(&crit_); 271 rtc::CritScope lock(&crit_);
287 if (rtp_timestamp_delta_ == 0 && header.ssrc == ssrc_to_analyze_) { 272
288 rtp_timestamp_delta_ = header.timestamp - *first_sent_timestamp_; 273 if (rtp_timestamp_delta_ == 0) {
274 rtp_timestamp_delta_ = header.timestamp - *first_send_timestamp_;
275 first_send_timestamp_ = rtc::Optional<uint32_t>();
289 } 276 }
290 277 if (!IsFlexfec(header.payloadType)) {
291 if (!IsFlexfec(header.payloadType) && header.ssrc == ssrc_to_analyze_) {
292 // Ignore FlexFEC timestamps, to avoid collisions with media timestamps. 278 // Ignore FlexFEC timestamps, to avoid collisions with media timestamps.
293 // (FlexFEC and media are sent on different SSRCs, which have different 279 // (FlexFEC and media are sent on different SSRCs, which have different
294 // timestamps spaces.) 280 // timestamps spaces.)
295 // Also ignore packets from wrong SSRC.
296 int64_t timestamp = 281 int64_t timestamp =
297 wrap_handler_.Unwrap(header.timestamp - rtp_timestamp_delta_); 282 wrap_handler_.Unwrap(header.timestamp - rtp_timestamp_delta_);
298 send_times_[timestamp] = current_time; 283 send_times_[timestamp] = current_time;
299 if (!transport_->DiscardedLastPacket() && 284 if (!transport_->DiscardedLastPacket() &&
300 header.ssrc == ssrc_to_analyze_) { 285 header.ssrc == ssrc_to_analyze_) {
301 encoded_frame_sizes_[timestamp] += 286 encoded_frame_sizes_[timestamp] +=
302 length - (header.headerLength + header.paddingLength); 287 length - (header.headerLength + header.paddingLength);
303 } 288 }
304 } 289 }
305 } 290 }
(...skipping 177 matching lines...) Expand 10 before | Expand all | Expand 10 after
483 468
484 // This class receives the send-side OnEncodeTiming and is provided to not 469 // This class receives the send-side OnEncodeTiming and is provided to not
485 // conflict with the receiver-side pre_decode_callback. 470 // conflict with the receiver-side pre_decode_callback.
486 class OnEncodeTimingProxy : public EncodedFrameObserver { 471 class OnEncodeTimingProxy : public EncodedFrameObserver {
487 public: 472 public:
488 explicit OnEncodeTimingProxy(VideoAnalyzer* parent) : parent_(parent) {} 473 explicit OnEncodeTimingProxy(VideoAnalyzer* parent) : parent_(parent) {}
489 474
490 void OnEncodeTiming(int64_t ntp_time_ms, int encode_time_ms) override { 475 void OnEncodeTiming(int64_t ntp_time_ms, int encode_time_ms) override {
491 parent_->MeasuredEncodeTiming(ntp_time_ms, encode_time_ms); 476 parent_->MeasuredEncodeTiming(ntp_time_ms, encode_time_ms);
492 } 477 }
493 void EncodedFrameCallback(const EncodedFrame& frame) override { 478 void EncodedFrameCallback(const EncodedFrame& frame) override {}
494 parent_->PostEncodeFrameCallback(frame);
495 }
496 479
497 private: 480 private:
498 VideoAnalyzer* const parent_; 481 VideoAnalyzer* const parent_;
499 }; 482 };
500 483
501 // This class receives the send-side OnFrame callback and is provided to not 484 // This class receives the send-side OnFrame callback and is provided to not
502 // conflict with the receiver-side renderer callback. 485 // conflict with the receiver-side renderer callback.
503 class PreEncodeProxy : public rtc::VideoSinkInterface<VideoFrame> { 486 class PreEncodeProxy : public rtc::VideoSinkInterface<VideoFrame> {
504 public: 487 public:
505 explicit PreEncodeProxy(VideoAnalyzer* parent) : parent_(parent) {} 488 explicit PreEncodeProxy(VideoAnalyzer* parent) : parent_(parent) {}
(...skipping 289 matching lines...) Expand 10 before | Expand all | Expand 10 after
795 // forwards the captured frames to the VideoSendStream. 778 // forwards the captured frames to the VideoSendStream.
796 class CapturedFrameForwarder : public rtc::VideoSinkInterface<VideoFrame>, 779 class CapturedFrameForwarder : public rtc::VideoSinkInterface<VideoFrame>,
797 public rtc::VideoSourceInterface<VideoFrame> { 780 public rtc::VideoSourceInterface<VideoFrame> {
798 public: 781 public:
799 explicit CapturedFrameForwarder(VideoAnalyzer* analyzer) 782 explicit CapturedFrameForwarder(VideoAnalyzer* analyzer)
800 : analyzer_(analyzer), send_stream_input_(nullptr) {} 783 : analyzer_(analyzer), send_stream_input_(nullptr) {}
801 784
802 private: 785 private:
803 void OnFrame(const VideoFrame& video_frame) override { 786 void OnFrame(const VideoFrame& video_frame) override {
804 VideoFrame copy = video_frame; 787 VideoFrame copy = video_frame;
805 // Frames from the capturer does not have a rtp timestamp.
806 // Create one so it can be used for comparison.
807 RTC_DCHECK_EQ(0, video_frame.timestamp());
808 copy.set_timestamp(copy.ntp_time_ms() * 90); 788 copy.set_timestamp(copy.ntp_time_ms() * 90);
809 analyzer_->AddCapturedFrameForComparison(copy); 789
790 analyzer_->AddCapturedFrameForComparison(video_frame);
810 rtc::CritScope lock(&crit_); 791 rtc::CritScope lock(&crit_);
811 if (send_stream_input_) 792 if (send_stream_input_)
812 send_stream_input_->OnFrame(video_frame); 793 send_stream_input_->OnFrame(video_frame);
813 } 794 }
814 795
815 // Called when |send_stream_.SetSource()| is called. 796 // Called when |send_stream_.SetSource()| is called.
816 void AddOrUpdateSink(rtc::VideoSinkInterface<VideoFrame>* sink, 797 void AddOrUpdateSink(rtc::VideoSinkInterface<VideoFrame>* sink,
817 const rtc::VideoSinkWants& wants) override { 798 const rtc::VideoSinkWants& wants) override {
818 rtc::CritScope lock(&crit_); 799 rtc::CritScope lock(&crit_);
819 RTC_DCHECK(!send_stream_input_ || send_stream_input_ == sink); 800 RTC_DCHECK(!send_stream_input_ || send_stream_input_ == sink);
820 send_stream_input_ = sink; 801 send_stream_input_ = sink;
821 } 802 }
822 803
823 // Called by |send_stream_| when |send_stream_.SetSource()| is called. 804 // Called by |send_stream_| when |send_stream_.SetSource()| is called.
824 void RemoveSink(rtc::VideoSinkInterface<VideoFrame>* sink) override { 805 void RemoveSink(rtc::VideoSinkInterface<VideoFrame>* sink) override {
825 rtc::CritScope lock(&crit_); 806 rtc::CritScope lock(&crit_);
826 RTC_DCHECK(sink == send_stream_input_); 807 RTC_DCHECK(sink == send_stream_input_);
827 send_stream_input_ = nullptr; 808 send_stream_input_ = nullptr;
828 } 809 }
829 810
830 VideoAnalyzer* const analyzer_; 811 VideoAnalyzer* const analyzer_;
831 rtc::CriticalSection crit_; 812 rtc::CriticalSection crit_;
832 rtc::VideoSinkInterface<VideoFrame>* send_stream_input_ GUARDED_BY(crit_); 813 rtc::VideoSinkInterface<VideoFrame>* send_stream_input_ GUARDED_BY(crit_);
833 }; 814 };
834 815
835 void AddCapturedFrameForComparison(const VideoFrame& video_frame) { 816 void AddCapturedFrameForComparison(const VideoFrame& video_frame) {
836 rtc::CritScope lock(&crit_); 817 rtc::CritScope lock(&crit_);
837 frames_.push_back(video_frame); 818 RTC_DCHECK_EQ(0, video_frame.timestamp());
819 // Frames from the capturer does not have a rtp timestamp. Create one so it
820 // can be used for comparison.
821 VideoFrame copy = video_frame;
822 copy.set_timestamp(copy.ntp_time_ms() * 90);
823 frames_.push_back(copy);
838 } 824 }
839 825
840 VideoSendStream* send_stream_; 826 VideoSendStream* send_stream_;
841 VideoReceiveStream* receive_stream_; 827 VideoReceiveStream* receive_stream_;
842 CapturedFrameForwarder captured_frame_forwarder_; 828 CapturedFrameForwarder captured_frame_forwarder_;
843 const std::string test_label_; 829 const std::string test_label_;
844 FILE* const graph_data_output_file_; 830 FILE* const graph_data_output_file_;
845 const std::string graph_title_; 831 const std::string graph_title_;
846 const uint32_t ssrc_to_analyze_; 832 const uint32_t ssrc_to_analyze_;
847 const uint32_t selected_width_;
848 const uint32_t selected_height_;
849 PreEncodeProxy pre_encode_proxy_; 833 PreEncodeProxy pre_encode_proxy_;
850 OnEncodeTimingProxy encode_timing_proxy_; 834 OnEncodeTimingProxy encode_timing_proxy_;
851 std::vector<Sample> samples_ GUARDED_BY(comparison_lock_); 835 std::vector<Sample> samples_ GUARDED_BY(comparison_lock_);
852 std::map<int64_t, int> samples_encode_time_ms_ GUARDED_BY(comparison_lock_); 836 std::map<int64_t, int> samples_encode_time_ms_ GUARDED_BY(comparison_lock_);
853 test::Statistics sender_time_ GUARDED_BY(comparison_lock_); 837 test::Statistics sender_time_ GUARDED_BY(comparison_lock_);
854 test::Statistics receiver_time_ GUARDED_BY(comparison_lock_); 838 test::Statistics receiver_time_ GUARDED_BY(comparison_lock_);
855 test::Statistics psnr_ GUARDED_BY(comparison_lock_); 839 test::Statistics psnr_ GUARDED_BY(comparison_lock_);
856 test::Statistics ssim_ GUARDED_BY(comparison_lock_); 840 test::Statistics ssim_ GUARDED_BY(comparison_lock_);
857 test::Statistics end_to_end_ GUARDED_BY(comparison_lock_); 841 test::Statistics end_to_end_ GUARDED_BY(comparison_lock_);
858 test::Statistics rendered_delta_ GUARDED_BY(comparison_lock_); 842 test::Statistics rendered_delta_ GUARDED_BY(comparison_lock_);
(...skipping 14 matching lines...) Expand all
873 int64_t last_render_time_; 857 int64_t last_render_time_;
874 uint32_t rtp_timestamp_delta_; 858 uint32_t rtp_timestamp_delta_;
875 859
876 rtc::CriticalSection crit_; 860 rtc::CriticalSection crit_;
877 std::deque<VideoFrame> frames_ GUARDED_BY(crit_); 861 std::deque<VideoFrame> frames_ GUARDED_BY(crit_);
878 rtc::Optional<VideoFrame> last_rendered_frame_ GUARDED_BY(crit_); 862 rtc::Optional<VideoFrame> last_rendered_frame_ GUARDED_BY(crit_);
879 rtc::TimestampWrapAroundHandler wrap_handler_ GUARDED_BY(crit_); 863 rtc::TimestampWrapAroundHandler wrap_handler_ GUARDED_BY(crit_);
880 std::map<int64_t, int64_t> send_times_ GUARDED_BY(crit_); 864 std::map<int64_t, int64_t> send_times_ GUARDED_BY(crit_);
881 std::map<int64_t, int64_t> recv_times_ GUARDED_BY(crit_); 865 std::map<int64_t, int64_t> recv_times_ GUARDED_BY(crit_);
882 std::map<int64_t, size_t> encoded_frame_sizes_ GUARDED_BY(crit_); 866 std::map<int64_t, size_t> encoded_frame_sizes_ GUARDED_BY(crit_);
883 rtc::Optional<uint32_t> first_encoded_timestamp_ GUARDED_BY(crit_); 867 rtc::Optional<uint32_t> first_send_timestamp_ GUARDED_BY(crit_);
884 rtc::Optional<uint32_t> first_sent_timestamp_ GUARDED_BY(crit_);
885 const double avg_psnr_threshold_; 868 const double avg_psnr_threshold_;
886 const double avg_ssim_threshold_; 869 const double avg_ssim_threshold_;
887 870
888 rtc::CriticalSection comparison_lock_; 871 rtc::CriticalSection comparison_lock_;
889 std::vector<rtc::PlatformThread*> comparison_thread_pool_; 872 std::vector<rtc::PlatformThread*> comparison_thread_pool_;
890 rtc::PlatformThread stats_polling_thread_; 873 rtc::PlatformThread stats_polling_thread_;
891 rtc::Event comparison_available_event_; 874 rtc::Event comparison_available_event_;
892 std::deque<FrameComparison> comparisons_ GUARDED_BY(comparison_lock_); 875 std::deque<FrameComparison> comparisons_ GUARDED_BY(comparison_lock_);
893 rtc::Event done_; 876 rtc::Event done_;
894 }; 877 };
(...skipping 427 matching lines...) Expand 10 before | Expand all | Expand 10 after
1322 : params_.ss.num_spatial_layers - 1; 1305 : params_.ss.num_spatial_layers - 1;
1323 bool disable_quality_check = 1306 bool disable_quality_check =
1324 selected_stream.width != params_.video.width || 1307 selected_stream.width != params_.video.width ||
1325 selected_stream.height != params_.video.height || 1308 selected_stream.height != params_.video.height ||
1326 (!params_.ss.spatial_layers.empty() && 1309 (!params_.ss.spatial_layers.empty() &&
1327 params_.ss.spatial_layers[selected_sl].scaling_factor_num != 1310 params_.ss.spatial_layers[selected_sl].scaling_factor_num !=
1328 params_.ss.spatial_layers[selected_sl].scaling_factor_den); 1311 params_.ss.spatial_layers[selected_sl].scaling_factor_den);
1329 if (disable_quality_check) { 1312 if (disable_quality_check) {
1330 fprintf(stderr, 1313 fprintf(stderr,
1331 "Warning: Calculating PSNR and SSIM for downsized resolution " 1314 "Warning: Calculating PSNR and SSIM for downsized resolution "
1332 "not implemented yet! Skipping PSNR and SSIM calculations!\n"); 1315 "not implemented yet! Skipping PSNR and SSIM calculations!");
1333 } 1316 }
1334 1317
1335 VideoAnalyzer analyzer( 1318 VideoAnalyzer analyzer(
1336 &send_transport, params_.analyzer.test_label, 1319 &send_transport, params_.analyzer.test_label,
1337 disable_quality_check ? -1.1 : params_.analyzer.avg_psnr_threshold, 1320 disable_quality_check ? -1.1 : params_.analyzer.avg_psnr_threshold,
1338 disable_quality_check ? -1.1 : params_.analyzer.avg_ssim_threshold, 1321 disable_quality_check ? -1.1 : params_.analyzer.avg_ssim_threshold,
1339 params_.analyzer.test_durations_secs * params_.video.fps, 1322 params_.analyzer.test_durations_secs * params_.video.fps,
1340 graph_data_output_file, graph_title, 1323 graph_data_output_file, graph_title,
1341 kVideoSendSsrcs[params_.ss.selected_stream], 1324 kVideoSendSsrcs[params_.ss.selected_stream]);
1342 static_cast<uint32_t>(selected_stream.width),
1343 static_cast<uint32_t>(selected_stream.height));
1344 1325
1345 analyzer.SetReceiver(receiver_call_->Receiver()); 1326 analyzer.SetReceiver(receiver_call_->Receiver());
1346 send_transport.SetReceiver(&analyzer); 1327 send_transport.SetReceiver(&analyzer);
1347 recv_transport.SetReceiver(sender_call_->Receiver()); 1328 recv_transport.SetReceiver(sender_call_->Receiver());
1348 1329
1349 SetupVideo(&analyzer, &recv_transport); 1330 SetupVideo(&analyzer, &recv_transport);
1350 video_receive_configs_[params_.ss.selected_stream].renderer = &analyzer; 1331 video_receive_configs_[params_.ss.selected_stream].renderer = &analyzer;
1351 video_send_config_.pre_encode_callback = analyzer.pre_encode_proxy(); 1332 video_send_config_.pre_encode_callback = analyzer.pre_encode_proxy();
1352 for (auto& config : video_receive_configs_) 1333 for (auto& config : video_receive_configs_)
1353 config.pre_decode_callback = &analyzer; 1334 config.pre_decode_callback = &analyzer;
(...skipping 235 matching lines...) Expand 10 before | Expand all | Expand 10 after
1589 std::ostringstream str; 1570 std::ostringstream str;
1590 str << receive_logs_++; 1571 str << receive_logs_++;
1591 std::string path = 1572 std::string path =
1592 params_.video.encoded_frame_base_path + "." + str.str() + ".recv.ivf"; 1573 params_.video.encoded_frame_base_path + "." + str.str() + ".recv.ivf";
1593 stream->EnableEncodedFrameRecording(rtc::CreatePlatformFile(path), 1574 stream->EnableEncodedFrameRecording(rtc::CreatePlatformFile(path),
1594 10000000); 1575 10000000);
1595 } 1576 }
1596 } 1577 }
1597 1578
1598 } // namespace webrtc 1579 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/video/full_stack_tests.cc ('k') | webrtc/video/video_receive_stream.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698