blob: 252880a83f4872e789a2237eccc87b9f9907ca75 [file] [log] [blame]
/*
* Copyright 2025 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#ifndef RTC_TOOLS_RTC_EVENT_LOG_VISUALIZER_LOG_SCREAM_SIMULATION_H_
#define RTC_TOOLS_RTC_EVENT_LOG_VISUALIZER_LOG_SCREAM_SIMULATION_H_
#include <cstdint>
#include <optional>
#include <vector>
#include "api/candidate.h"
#include "api/environment/environment.h"
#include "api/transport/network_types.h"
#include "api/units/data_rate.h"
#include "api/units/data_size.h"
#include "api/units/time_delta.h"
#include "api/units/timestamp.h"
#include "logging/rtc_event_log/events/logged_rtp_rtcp.h"
#include "logging/rtc_event_log/events/rtc_event_ice_candidate_pair_config.h"
#include "logging/rtc_event_log/rtc_event_log_parser.h"
#include "modules/congestion_controller/rtp/transport_feedback_adapter.h"
#include "modules/congestion_controller/scream/scream_v2.h"
#include "rtc_base/bitrate_tracker.h"
namespace webrtc {
class LogScreamSimulation {
public:
// State of Scream at the time when a feedback report has been processed.
struct State {
enum SendWindowUsage {
kBelowRefWindow,
kAboveRefWindow,
kAboveScreamMax,
};
Timestamp time;
DataRate target_rate = DataRate::Zero();
DataRate pacing_rate = DataRate::Zero();
DataRate send_rate = DataRate::Zero();
DataSize ref_window = DataSize::Zero();
DataSize ref_window_i = DataSize::Zero();
DataSize max_allowed_ref_window = DataSize::Zero();
DataSize max_data_in_flight = DataSize::Zero();
// Data in flight after last packet was sent before the state was captured.
DataSize data_in_flight = DataSize::Zero();
// How the send window have been utilized. Based on data in flight when the
// last packet was sent before the state was captured.
SendWindowUsage send_window_usage = kBelowRefWindow;
TimeDelta smoothed_rtt = TimeDelta::Zero();
TimeDelta queue_delay = TimeDelta::Zero();
TimeDelta queue_delay_min_avg = TimeDelta::Zero();
TimeDelta latency_difference_avg = TimeDelta::Zero();
double queue_delay_dev_norm = 0;
double ref_window_scale_factor_due_to_avg_min_delay = 0.0;
double ref_window_scale_factor_due_to_latency_difference = 0.0;
double ref_window_scale_factor_close_to_ref_window_i = 0.0;
double ref_window_combined_increase_scale_factor = 0.0;
double l4s_alpha = 0.0;
double l4s_alpha_v = 0.0;
};
struct Config {
TimeDelta rate_window = TimeDelta::Millis(100);
};
LogScreamSimulation(const Config& config, const Environment& env);
~LogScreamSimulation() = default;
void ProcessEventsInLog(const ParsedRtcEventLog& parsed_log_);
const std::vector<State>& updates() const { return state_; }
private:
void ProcessUntil(Timestamp to_time);
void OnPacketSent(const LoggedPacketInfo& packet);
void OnTransportFeedback(const LoggedRtcpPacketTransportFeedback& feedback);
void OnCongestionControlFeedback(
const LoggedRtcpCongestionControlFeedback& feedback);
void OnIceConfig(const LoggedIceCandidatePairConfig& candidate);
void LogState(const TransportPacketsFeedback& msg);
const Environment env_;
std::optional<ScreamV2> scream_;
Timestamp current_time_ = Timestamp::MinusInfinity();
Timestamp last_process_ = Timestamp::MinusInfinity();
TransportFeedbackAdapter transport_feedback_;
BitrateTracker send_rate_tracker_;
State::SendWindowUsage send_window_usage_ = State::kBelowRefWindow;
DataSize data_in_flight_ = DataSize::Zero();
// With RFC 8888, transport sequence numbers are not stored per packet.
// Instead, we generate one.
int64_t next_ccfb_packet_id_ = 0;
std::optional<IceCandidateType> local_candidate_type_;
std::optional<IceCandidateType> remote_candidate_type_;
std::vector<State> state_;
};
} // namespace webrtc
#endif // RTC_TOOLS_RTC_EVENT_LOG_VISUALIZER_LOG_SCREAM_SIMULATION_H_