Add FrameSelector utility class, used for ACD frame selection.

This CL adds a class that in a follow-up CL will be wired up to the
automatic corruption detection mechanism. The current implementation
picks a new frame about one second after the previously instrumented
frame. This leads to problem where we never instrument frames that
follow quickly upon keyframes.

This new implementation sets a target timespan after an instrumented
frame. A new cutoff time will be randomly placed within that span,
allowing at least some samples to happen both early and late providing
better temporal coverage.

In addition, we allow the span (and thus inderctly the interval) to be
set differently for low and higher overhead frames. Running the ACD
processing on a frame that is already available in main memory is
cheap, but doing it on a texture-backed frame that requires a download
from GPU to main memory is significantly more expensive. Sampling
with longer intervals mitigates some of this overhead.

Bug: webrtc:358039777
Change-Id: I346f1e4d74166aeb3ed8458adfb698b5265344dd
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/435442
Reviewed-by: Sergey Silkin <ssilkin@webrtc.org>
Commit-Queue: Erik Språng <sprang@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#46533}
4 files changed
tree: 7b69cba4740a72d18338f72a24895e9c53e7ee6e
  1. agents/
  2. api/
  3. audio/
  4. build_overrides/
  5. call/
  6. common_audio/
  7. common_video/
  8. data/
  9. docs/
  10. examples/
  11. experiments/
  12. g3doc/
  13. infra/
  14. logging/
  15. media/
  16. modules/
  17. net/
  18. p2p/
  19. pc/
  20. resources/
  21. rtc_base/
  22. rtc_tools/
  23. sdk/
  24. stats/
  25. system_wrappers/
  26. test/
  27. tools_webrtc/
  28. video/
  29. .clang-format
  30. .clang-tidy
  31. .git-blame-ignore-revs
  32. .gitignore
  33. .gn
  34. .mailmap
  35. .rustfmt.toml
  36. .style.yapf
  37. .vpython3
  38. AUTHORS
  39. BUILD.gn
  40. CODE_OF_CONDUCT.md
  41. codereview.settings
  42. DEPS
  43. DIR_METADATA
  44. ENG_REVIEW_OWNERS
  45. GEMINI.md
  46. LICENSE
  47. license_template.txt
  48. native-api.md
  49. OWNERS
  50. OWNERS_INFRA
  51. PATENTS
  52. PRESUBMIT.py
  53. presubmit_test.py
  54. presubmit_test_mocks.py
  55. pylintrc
  56. pylintrc_old_style
  57. README.chromium
  58. README.md
  59. WATCHLISTS
  60. webrtc.gni
  61. webrtc_lib_link_test.cc
  62. whitespace.txt
README.md

WebRTC is a free, open software project that provides browsers and mobile applications with Real-Time Communications (RTC) capabilities via simple APIs. The WebRTC components have been optimized to best serve this purpose.

Our mission: To enable rich, high-quality RTC applications to be developed for the browser, mobile platforms, and IoT devices, and allow them all to communicate via a common set of protocols.

The WebRTC initiative is a project supported by Google, Mozilla and Opera, amongst others.

Development

See here for instructions on how to get started developing with the native code.

Authoritative list of directories that contain the native API header files.

More info