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

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

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

Powered by Google App Engine
This is Rietveld 408576698