mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-19 00:27:51 +01:00
Minor changes in videoprocessor and videoprocessor_integrationtests.h
BUG=webrtc:6634 Review-Url: https://codereview.webrtc.org/2708993005 Cr-Commit-Position: refs/heads/master@{#17083}
This commit is contained in:
parent
c438bb1697
commit
ae9ba047c4
3 changed files with 113 additions and 125 deletions
|
@ -44,6 +44,31 @@ std::unique_ptr<VideoBitrateAllocator> CreateBitrateAllocator(
|
||||||
std::move(tl_factory)));
|
std::move(tl_factory)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PrintCodecSettings(const VideoCodec* config) {
|
||||||
|
printf(" Start bitrate : %d kbps\n", config->startBitrate);
|
||||||
|
printf(" Width : %d\n", config->width);
|
||||||
|
printf(" Height : %d\n", config->height);
|
||||||
|
printf(" Codec type : %s\n",
|
||||||
|
CodecTypeToPayloadName(config->codecType).value_or("Unknown"));
|
||||||
|
if (config->codecType == kVideoCodecVP8) {
|
||||||
|
printf(" Denoising : %d\n", config->VP8().denoisingOn);
|
||||||
|
printf(" Error concealment: %d\n", config->VP8().errorConcealmentOn);
|
||||||
|
printf(" Frame dropping : %d\n", config->VP8().frameDroppingOn);
|
||||||
|
printf(" Resilience : %d\n", config->VP8().resilience);
|
||||||
|
} else if (config->codecType == kVideoCodecVP9) {
|
||||||
|
printf(" Denoising : %d\n", config->VP9().denoisingOn);
|
||||||
|
printf(" Frame dropping : %d\n", config->VP9().frameDroppingOn);
|
||||||
|
printf(" Resilience : %d\n", config->VP9().resilience);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int GetElapsedTimeMicroseconds(int64_t start_ns, int64_t stop_ns) {
|
||||||
|
int64_t diff_us = (stop_ns - start_ns) / rtc::kNumNanosecsPerMicrosec;
|
||||||
|
RTC_DCHECK_GE(diff_us, std::numeric_limits<int>::min());
|
||||||
|
RTC_DCHECK_LE(diff_us, std::numeric_limits<int>::max());
|
||||||
|
return static_cast<int>(diff_us);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
const char* ExcludeFrameTypesToStr(ExcludeFrameTypes e) {
|
const char* ExcludeFrameTypesToStr(ExcludeFrameTypes e) {
|
||||||
|
@ -159,30 +184,11 @@ bool VideoProcessorImpl::Init() {
|
||||||
printf(" Total # of frames: %d\n",
|
printf(" Total # of frames: %d\n",
|
||||||
analysis_frame_reader_->NumberOfFrames());
|
analysis_frame_reader_->NumberOfFrames());
|
||||||
printf(" Codec settings:\n");
|
printf(" Codec settings:\n");
|
||||||
printf(" Start bitrate : %d kbps\n",
|
|
||||||
config_.codec_settings->startBitrate);
|
|
||||||
printf(" Width : %d\n", config_.codec_settings->width);
|
|
||||||
printf(" Height : %d\n", config_.codec_settings->height);
|
|
||||||
printf(" Codec type : %s\n",
|
|
||||||
CodecTypeToPayloadName(config_.codec_settings->codecType)
|
|
||||||
.value_or("Unknown"));
|
|
||||||
printf(" Encoder implementation name: %s\n",
|
printf(" Encoder implementation name: %s\n",
|
||||||
encoder_->ImplementationName());
|
encoder_->ImplementationName());
|
||||||
printf(" Decoder implementation name: %s\n",
|
printf(" Decoder implementation name: %s\n",
|
||||||
decoder_->ImplementationName());
|
decoder_->ImplementationName());
|
||||||
if (config_.codec_settings->codecType == kVideoCodecVP8) {
|
PrintCodecSettings(config_.codec_settings);
|
||||||
printf(" Denoising : %d\n",
|
|
||||||
config_.codec_settings->VP8()->denoisingOn);
|
|
||||||
printf(" Error concealment: %d\n",
|
|
||||||
config_.codec_settings->VP8()->errorConcealmentOn);
|
|
||||||
printf(" Frame dropping : %d\n",
|
|
||||||
config_.codec_settings->VP8()->frameDroppingOn);
|
|
||||||
printf(" Resilience : %d\n",
|
|
||||||
config_.codec_settings->VP8()->resilience);
|
|
||||||
} else if (config_.codec_settings->codecType == kVideoCodecVP9) {
|
|
||||||
printf(" Resilience : %d\n",
|
|
||||||
config_.codec_settings->VP9()->resilience);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
initialized_ = true;
|
initialized_ = true;
|
||||||
return true;
|
return true;
|
||||||
|
@ -463,13 +469,5 @@ void VideoProcessorImpl::FrameDecoded(const VideoFrame& image) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int VideoProcessorImpl::GetElapsedTimeMicroseconds(int64_t start,
|
|
||||||
int64_t stop) {
|
|
||||||
int64_t encode_time = (stop - start) / rtc::kNumNanosecsPerMicrosec;
|
|
||||||
RTC_DCHECK_GE(encode_time, std::numeric_limits<int>::min());
|
|
||||||
RTC_DCHECK_LE(encode_time, std::numeric_limits<int>::max());
|
|
||||||
return static_cast<int>(encode_time);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace test
|
} // namespace test
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
|
|
@ -230,10 +230,6 @@ class VideoProcessorImpl : public VideoProcessor {
|
||||||
// Invoked by the callback when a frame has completed decoding.
|
// Invoked by the callback when a frame has completed decoding.
|
||||||
void FrameDecoded(const webrtc::VideoFrame& image);
|
void FrameDecoded(const webrtc::VideoFrame& image);
|
||||||
|
|
||||||
// Used for getting a 32-bit integer representing time
|
|
||||||
// (checks the size is within signed 32-bit bounds before casting it)
|
|
||||||
int GetElapsedTimeMicroseconds(int64_t start, int64_t stop);
|
|
||||||
|
|
||||||
// Updates the encoder with the target bit rate and the frame rate.
|
// Updates the encoder with the target bit rate and the frame rate.
|
||||||
void SetRates(int bit_rate, int frame_rate) override;
|
void SetRates(int bit_rate, int frame_rate) override;
|
||||||
|
|
||||||
|
|
|
@ -53,6 +53,9 @@ namespace test {
|
||||||
// and/or frame rate) for the current tests.
|
// and/or frame rate) for the current tests.
|
||||||
const int kMaxNumRateUpdates = 3;
|
const int kMaxNumRateUpdates = 3;
|
||||||
|
|
||||||
|
// Maximum number of temporal layers to use in tests.
|
||||||
|
const int kMaxNumTemporalLayers = 3;
|
||||||
|
|
||||||
const int kPercTargetvsActualMismatch = 20;
|
const int kPercTargetvsActualMismatch = 20;
|
||||||
const int kBaseKeyFrameInterval = 3000;
|
const int kBaseKeyFrameInterval = 3000;
|
||||||
|
|
||||||
|
@ -157,16 +160,15 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
}
|
}
|
||||||
virtual ~VideoProcessorIntegrationTest() = default;
|
virtual ~VideoProcessorIntegrationTest() = default;
|
||||||
|
|
||||||
void SetUpCodecConfig(const CodecParams& process,
|
void CreateEncoderAndDecoder(bool hw_codec, VideoCodecType codec_type) {
|
||||||
const VisualizationParams* visualization_params) {
|
if (hw_codec) {
|
||||||
if (process.hw_codec) {
|
|
||||||
#if defined(WEBRTC_VIDEOPROCESSOR_INTEGRATIONTEST_HW_CODECS_ENABLED)
|
#if defined(WEBRTC_VIDEOPROCESSOR_INTEGRATIONTEST_HW_CODECS_ENABLED)
|
||||||
#if defined(WEBRTC_ANDROID)
|
#if defined(WEBRTC_ANDROID)
|
||||||
// In general, external codecs should be destroyed by the factories that
|
// In general, external codecs should be destroyed by the factories that
|
||||||
// allocated them. For the particular case of the Android
|
// allocated them. For the particular case of the Android
|
||||||
// MediaCodecVideo{En,De}coderFactory's, however, it turns out that it is
|
// MediaCodecVideo{En,De}coderFactory's, however, it turns out that it is
|
||||||
// fine for the std::unique_ptr to destroy the owned codec directly.
|
// fine for the std::unique_ptr to destroy the owned codec directly.
|
||||||
switch (process.codec_type) {
|
switch (codec_type) {
|
||||||
case kVideoCodecH264:
|
case kVideoCodecH264:
|
||||||
encoder_.reset(external_encoder_factory_->CreateVideoEncoder(
|
encoder_.reset(external_encoder_factory_->CreateVideoEncoder(
|
||||||
cricket::VideoCodec(cricket::kH264CodecName)));
|
cricket::VideoCodec(cricket::kH264CodecName)));
|
||||||
|
@ -190,7 +192,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#elif defined(WEBRTC_IOS)
|
#elif defined(WEBRTC_IOS)
|
||||||
ASSERT_EQ(kVideoCodecH264, process.codec_type)
|
ASSERT_EQ(kVideoCodecH264, codec_type)
|
||||||
<< "iOS HW codecs only support H264.";
|
<< "iOS HW codecs only support H264.";
|
||||||
encoder_.reset(new H264VideoToolboxEncoder(
|
encoder_.reset(new H264VideoToolboxEncoder(
|
||||||
cricket::VideoCodec(cricket::kH264CodecName)));
|
cricket::VideoCodec(cricket::kH264CodecName)));
|
||||||
|
@ -201,12 +203,14 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
#endif // WEBRTC_VIDEOPROCESSOR_INTEGRATIONTEST_HW_CODECS_ENABLED
|
#endif // WEBRTC_VIDEOPROCESSOR_INTEGRATIONTEST_HW_CODECS_ENABLED
|
||||||
RTC_CHECK(encoder_) << "HW encoder not successfully created.";
|
RTC_CHECK(encoder_) << "HW encoder not successfully created.";
|
||||||
RTC_CHECK(decoder_) << "HW decoder not successfully created.";
|
RTC_CHECK(decoder_) << "HW decoder not successfully created.";
|
||||||
} else {
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// SW codecs.
|
// SW codecs.
|
||||||
switch (process.codec_type) {
|
switch (codec_type) {
|
||||||
case kVideoCodecH264:
|
case kVideoCodecH264:
|
||||||
encoder_.reset(H264Encoder::Create(
|
encoder_.reset(
|
||||||
cricket::VideoCodec(cricket::kH264CodecName)));
|
H264Encoder::Create(cricket::VideoCodec(cricket::kH264CodecName)));
|
||||||
decoder_.reset(H264Decoder::Create());
|
decoder_.reset(H264Decoder::Create());
|
||||||
break;
|
break;
|
||||||
case kVideoCodecVP8:
|
case kVideoCodecVP8:
|
||||||
|
@ -223,7 +227,9 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VideoCodingModule::Codec(process.codec_type, &codec_settings_);
|
void SetUpCodecConfig(const CodecParams& process,
|
||||||
|
const VisualizationParams* visualization_params) {
|
||||||
|
CreateEncoderAndDecoder(process.hw_codec, process.codec_type);
|
||||||
|
|
||||||
// Configure input filename.
|
// Configure input filename.
|
||||||
config_.input_filename = test::ResourcePath(process.filename, "yuv");
|
config_.input_filename = test::ResourcePath(process.filename, "yuv");
|
||||||
|
@ -232,6 +238,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
// Generate an output filename in a safe way.
|
// Generate an output filename in a safe way.
|
||||||
config_.output_filename = test::TempFilename(
|
config_.output_filename = test::TempFilename(
|
||||||
test::OutputPath(), "videoprocessor_integrationtest");
|
test::OutputPath(), "videoprocessor_integrationtest");
|
||||||
|
|
||||||
config_.frame_length_in_bytes =
|
config_.frame_length_in_bytes =
|
||||||
CalcBufferSize(kI420, process.width, process.height);
|
CalcBufferSize(kI420, process.width, process.height);
|
||||||
config_.verbose = process.verbose_logging;
|
config_.verbose = process.verbose_logging;
|
||||||
|
@ -242,6 +249,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
packet_loss_probability_;
|
packet_loss_probability_;
|
||||||
|
|
||||||
// Configure codec settings.
|
// Configure codec settings.
|
||||||
|
VideoCodingModule::Codec(process.codec_type, &codec_settings_);
|
||||||
config_.codec_settings = &codec_settings_;
|
config_.codec_settings = &codec_settings_;
|
||||||
config_.codec_settings->startBitrate = start_bitrate_;
|
config_.codec_settings->startBitrate = start_bitrate_;
|
||||||
config_.codec_settings->width = process.width;
|
config_.codec_settings->width = process.width;
|
||||||
|
@ -400,13 +408,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
|
|
||||||
// Verify expected behavior of rate control and print out data.
|
// Verify expected behavior of rate control and print out data.
|
||||||
void VerifyRateControlMetrics(int update_index,
|
void VerifyRateControlMetrics(int update_index,
|
||||||
int max_key_frame_size_mismatch,
|
const RateControlThresholds& rc_expected) {
|
||||||
int max_delta_frame_size_mismatch,
|
|
||||||
int max_encoding_rate_mismatch,
|
|
||||||
int max_time_hit_target,
|
|
||||||
int max_num_dropped_frames,
|
|
||||||
int num_spatial_resizes,
|
|
||||||
int num_key_frames) {
|
|
||||||
int num_dropped_frames = processor_->NumberDroppedFrames();
|
int num_dropped_frames = processor_->NumberDroppedFrames();
|
||||||
int num_resize_actions = processor_->NumberSpatialResizes();
|
int num_resize_actions = processor_->NumberSpatialResizes();
|
||||||
printf(
|
printf(
|
||||||
|
@ -420,7 +422,8 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
" Number of dropped frames: %d, \n"
|
" Number of dropped frames: %d, \n"
|
||||||
" Number of spatial resizes: %d, \n",
|
" Number of spatial resizes: %d, \n",
|
||||||
num_frames_to_hit_target_, num_dropped_frames, num_resize_actions);
|
num_frames_to_hit_target_, num_dropped_frames, num_resize_actions);
|
||||||
EXPECT_LE(perc_encoding_rate_mismatch_, max_encoding_rate_mismatch);
|
EXPECT_LE(perc_encoding_rate_mismatch_,
|
||||||
|
rc_expected.max_encoding_rate_mismatch);
|
||||||
if (num_key_frames_ > 0) {
|
if (num_key_frames_ > 0) {
|
||||||
int perc_key_frame_size_mismatch =
|
int perc_key_frame_size_mismatch =
|
||||||
100 * sum_key_frame_size_mismatch_ / num_key_frames_;
|
100 * sum_key_frame_size_mismatch_ / num_key_frames_;
|
||||||
|
@ -428,7 +431,8 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
" Number of Key frames: %d \n"
|
" Number of Key frames: %d \n"
|
||||||
" Key frame rate mismatch: %d \n",
|
" Key frame rate mismatch: %d \n",
|
||||||
num_key_frames_, perc_key_frame_size_mismatch);
|
num_key_frames_, perc_key_frame_size_mismatch);
|
||||||
EXPECT_LE(perc_key_frame_size_mismatch, max_key_frame_size_mismatch);
|
EXPECT_LE(perc_key_frame_size_mismatch,
|
||||||
|
rc_expected.max_key_frame_size_mismatch);
|
||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
printf("Rates statistics for Layer data \n");
|
printf("Rates statistics for Layer data \n");
|
||||||
|
@ -450,14 +454,16 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
bit_rate_layer_[i], frame_rate_layer_[i], per_frame_bandwidth_[i],
|
bit_rate_layer_[i], frame_rate_layer_[i], per_frame_bandwidth_[i],
|
||||||
encoding_bitrate_[i], perc_frame_size_mismatch,
|
encoding_bitrate_[i], perc_frame_size_mismatch,
|
||||||
perc_encoding_rate_mismatch, num_frames_per_update_[i]);
|
perc_encoding_rate_mismatch, num_frames_per_update_[i]);
|
||||||
EXPECT_LE(perc_frame_size_mismatch, max_delta_frame_size_mismatch);
|
EXPECT_LE(perc_frame_size_mismatch,
|
||||||
EXPECT_LE(perc_encoding_rate_mismatch, max_encoding_rate_mismatch);
|
rc_expected.max_delta_frame_size_mismatch);
|
||||||
|
EXPECT_LE(perc_encoding_rate_mismatch,
|
||||||
|
rc_expected.max_encoding_rate_mismatch);
|
||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
EXPECT_LE(num_frames_to_hit_target_, max_time_hit_target);
|
EXPECT_LE(num_frames_to_hit_target_, rc_expected.max_time_hit_target);
|
||||||
EXPECT_LE(num_dropped_frames, max_num_dropped_frames);
|
EXPECT_LE(num_dropped_frames, rc_expected.max_num_dropped_frames);
|
||||||
EXPECT_EQ(num_resize_actions, num_spatial_resizes);
|
EXPECT_EQ(rc_expected.num_spatial_resizes, num_resize_actions);
|
||||||
EXPECT_EQ(num_key_frames_, num_key_frames);
|
EXPECT_EQ(rc_expected.num_key_frames, num_key_frames_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VerifyQuality(const test::QualityMetricsResult& psnr_result,
|
void VerifyQuality(const test::QualityMetricsResult& psnr_result,
|
||||||
|
@ -470,36 +476,40 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Layer index corresponding to frame number, for up to 3 layers.
|
// Layer index corresponding to frame number, for up to 3 layers.
|
||||||
void LayerIndexForFrame(int frame_number) {
|
int LayerIndexForFrame(int frame_number) {
|
||||||
if (num_temporal_layers_ == 1) {
|
int layer = -1;
|
||||||
layer_ = 0;
|
switch (num_temporal_layers_) {
|
||||||
} else if (num_temporal_layers_ == 2) {
|
case 1:
|
||||||
|
layer = 0;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
// layer 0: 0 2 4 ...
|
// layer 0: 0 2 4 ...
|
||||||
// layer 1: 1 3
|
// layer 1: 1 3
|
||||||
if (frame_number % 2 == 0) {
|
layer = (frame_number % 2 == 0) ? 0 : 1;
|
||||||
layer_ = 0;
|
break;
|
||||||
} else {
|
case 3:
|
||||||
layer_ = 1;
|
|
||||||
}
|
|
||||||
} else if (num_temporal_layers_ == 3) {
|
|
||||||
// layer 0: 0 4 8 ...
|
// layer 0: 0 4 8 ...
|
||||||
// layer 1: 2 6
|
// layer 1: 2 6
|
||||||
// layer 2: 1 3 5 7
|
// layer 2: 1 3 5 7
|
||||||
if (frame_number % 4 == 0) {
|
if (frame_number % 4 == 0) {
|
||||||
layer_ = 0;
|
layer = 0;
|
||||||
} else if ((frame_number + 2) % 4 == 0) {
|
} else if ((frame_number + 2) % 4 == 0) {
|
||||||
layer_ = 1;
|
layer = 1;
|
||||||
} else if ((frame_number + 1) % 2 == 0) {
|
} else if ((frame_number + 1) % 2 == 0) {
|
||||||
layer_ = 2;
|
layer = 2;
|
||||||
}
|
}
|
||||||
} else {
|
break;
|
||||||
RTC_NOTREACHED() << "Max 3 layers are supported.";
|
default:
|
||||||
|
RTC_NOTREACHED();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return layer;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the bitrate and frame rate per layer, for up to 3 layers.
|
// Set the bitrate and frame rate per layer, for up to 3 layers.
|
||||||
void SetLayerRates() {
|
void SetLayerRates() {
|
||||||
RTC_DCHECK_LE(num_temporal_layers_, 3);
|
RTC_DCHECK_LE(num_temporal_layers_, kMaxNumTemporalLayers);
|
||||||
for (int i = 0; i < num_temporal_layers_; i++) {
|
for (int i = 0; i < num_temporal_layers_; i++) {
|
||||||
float bit_rate_ratio =
|
float bit_rate_ratio =
|
||||||
kVp8LayerRateAlloction[num_temporal_layers_ - 1][i];
|
kVp8LayerRateAlloction[num_temporal_layers_ - 1][i];
|
||||||
|
@ -550,7 +560,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
while (processor_->ProcessFrame(frame_number) &&
|
while (processor_->ProcessFrame(frame_number) &&
|
||||||
frame_number < num_frames) {
|
frame_number < num_frames) {
|
||||||
// Get the layer index for the frame |frame_number|.
|
// Get the layer index for the frame |frame_number|.
|
||||||
LayerIndexForFrame(frame_number);
|
layer_ = LayerIndexForFrame(frame_number);
|
||||||
// Get the frame_type.
|
// Get the frame_type.
|
||||||
frame_type = processor_->EncodedFrameType();
|
frame_type = processor_->EncodedFrameType();
|
||||||
// Counter for whole sequence run.
|
// Counter for whole sequence run.
|
||||||
|
@ -563,15 +573,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
// update layers and codec with new rates.
|
// update layers and codec with new rates.
|
||||||
if (frame_number ==
|
if (frame_number ==
|
||||||
rate_profile.frame_index_rate_update[update_index + 1]) {
|
rate_profile.frame_index_rate_update[update_index + 1]) {
|
||||||
VerifyRateControlMetrics(
|
VerifyRateControlMetrics(update_index, rc_thresholds[update_index]);
|
||||||
update_index,
|
|
||||||
rc_thresholds[update_index].max_key_frame_size_mismatch,
|
|
||||||
rc_thresholds[update_index].max_delta_frame_size_mismatch,
|
|
||||||
rc_thresholds[update_index].max_encoding_rate_mismatch,
|
|
||||||
rc_thresholds[update_index].max_time_hit_target,
|
|
||||||
rc_thresholds[update_index].max_num_dropped_frames,
|
|
||||||
rc_thresholds[update_index].num_spatial_resizes,
|
|
||||||
rc_thresholds[update_index].num_key_frames);
|
|
||||||
// Update layer rates and the codec with new rates.
|
// Update layer rates and the codec with new rates.
|
||||||
++update_index;
|
++update_index;
|
||||||
bit_rate_ = rate_profile.target_bit_rate[update_index];
|
bit_rate_ = rate_profile.target_bit_rate[update_index];
|
||||||
|
@ -582,14 +584,7 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
processor_->SetRates(bit_rate_, frame_rate_);
|
processor_->SetRates(bit_rate_, frame_rate_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
VerifyRateControlMetrics(
|
VerifyRateControlMetrics(update_index, rc_thresholds[update_index]);
|
||||||
update_index, rc_thresholds[update_index].max_key_frame_size_mismatch,
|
|
||||||
rc_thresholds[update_index].max_delta_frame_size_mismatch,
|
|
||||||
rc_thresholds[update_index].max_encoding_rate_mismatch,
|
|
||||||
rc_thresholds[update_index].max_time_hit_target,
|
|
||||||
rc_thresholds[update_index].max_num_dropped_frames,
|
|
||||||
rc_thresholds[update_index].num_spatial_resizes,
|
|
||||||
rc_thresholds[update_index].num_key_frames);
|
|
||||||
EXPECT_EQ(num_frames, frame_number);
|
EXPECT_EQ(num_frames, frame_number);
|
||||||
EXPECT_EQ(num_frames + 1, static_cast<int>(stats_.stats_.size()));
|
EXPECT_EQ(num_frames + 1, static_cast<int>(stats_.stats_.size()));
|
||||||
|
|
||||||
|
@ -622,8 +617,8 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
printf("PSNR avg: %f, min: %f\nSSIM avg: %f, min: %f\n",
|
printf("PSNR avg: %f, min: %f\nSSIM avg: %f, min: %f\n",
|
||||||
psnr_result.average, psnr_result.min, ssim_result.average,
|
psnr_result.average, psnr_result.min, ssim_result.average,
|
||||||
ssim_result.min);
|
ssim_result.min);
|
||||||
stats_.PrintSummary();
|
|
||||||
VerifyQuality(psnr_result, ssim_result, quality_thresholds);
|
VerifyQuality(psnr_result, ssim_result, quality_thresholds);
|
||||||
|
stats_.PrintSummary();
|
||||||
|
|
||||||
// Remove analysis file.
|
// Remove analysis file.
|
||||||
if (remove(config_.output_filename.c_str()) < 0) {
|
if (remove(config_.output_filename.c_str()) < 0) {
|
||||||
|
@ -746,14 +741,13 @@ class VideoProcessorIntegrationTest : public testing::Test {
|
||||||
std::unique_ptr<test::FrameWriter> decoded_frame_writer_;
|
std::unique_ptr<test::FrameWriter> decoded_frame_writer_;
|
||||||
|
|
||||||
// Quantities defined/updated for every encoder rate update.
|
// Quantities defined/updated for every encoder rate update.
|
||||||
// Some quantities defined per temporal layer (at most 3 layers in this test).
|
int num_frames_per_update_[kMaxNumTemporalLayers];
|
||||||
int num_frames_per_update_[3];
|
float sum_frame_size_mismatch_[kMaxNumTemporalLayers];
|
||||||
float sum_frame_size_mismatch_[3];
|
float sum_encoded_frame_size_[kMaxNumTemporalLayers];
|
||||||
float sum_encoded_frame_size_[3];
|
float encoding_bitrate_[kMaxNumTemporalLayers];
|
||||||
float encoding_bitrate_[3];
|
float per_frame_bandwidth_[kMaxNumTemporalLayers];
|
||||||
float per_frame_bandwidth_[3];
|
float bit_rate_layer_[kMaxNumTemporalLayers];
|
||||||
float bit_rate_layer_[3];
|
float frame_rate_layer_[kMaxNumTemporalLayers];
|
||||||
float frame_rate_layer_[3];
|
|
||||||
int num_frames_total_;
|
int num_frames_total_;
|
||||||
float sum_encoded_frame_size_total_;
|
float sum_encoded_frame_size_total_;
|
||||||
float encoding_bitrate_total_;
|
float encoding_bitrate_total_;
|
||||||
|
|
Loading…
Reference in a new issue