mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
docs/design/part-qos.txt: Fix indexes in formulas to make more sense.
Original commit message from CVS: * docs/design/part-qos.txt: Fix indexes in formulas to make more sense.
This commit is contained in:
parent
6af1d4c999
commit
090f3f4adc
2 changed files with 21 additions and 16 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2006-05-16 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
|
* docs/design/part-qos.txt:
|
||||||
|
Fix indexes in formulas to make more sense.
|
||||||
|
|
||||||
2006-05-15 Wim Taymans <wim@fluendo.com>
|
2006-05-15 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
* libs/gst/base/gstbasesink.c: (gst_base_sink_get_position):
|
* libs/gst/base/gstbasesink.c: (gst_base_sink_get_position):
|
||||||
|
|
|
@ -89,7 +89,7 @@ the upstream element is given as:
|
||||||
For values 0.0 < DR1 <= 1.0 the upstream element is producing faster than
|
For values 0.0 < DR1 <= 1.0 the upstream element is producing faster than
|
||||||
real-time. If DR1 is exactly 1.0, the element is running at a perfect speed.
|
real-time. If DR1 is exactly 1.0, the element is running at a perfect speed.
|
||||||
|
|
||||||
Values DR1 > 1.0 means that the upstream element cannot produce buffers of
|
Values DR1 > 1.0 mean that the upstream element cannot produce buffers of
|
||||||
duration D1 in real-time. It is exactly DR1 that tells the amount of speedup
|
duration D1 in real-time. It is exactly DR1 that tells the amount of speedup
|
||||||
we require from upstream to regain real-time performance.
|
we require from upstream to regain real-time performance.
|
||||||
|
|
||||||
|
@ -125,38 +125,38 @@ This will effectively result in frame drops.
|
||||||
The element can even do a better estimation of the next valid timestamp it
|
The element can even do a better estimation of the next valid timestamp it
|
||||||
should output.
|
should output.
|
||||||
|
|
||||||
Indeed, given the element generate a buffer with timestamp B1 that arrived
|
Indeed, given the element generated a buffer with timestamp B0 that arrived
|
||||||
in time in the sink but then received a QoS message stating B2 arrived J2
|
in time in the sink but then received a QoS message stating B1 arrived J1
|
||||||
too late. This means generating B2 took (B2 - J2) - B1 = T1 - T0 = PT1, as
|
too late. This means generating B1 took (B1 - J1) - B0 = T1 - T0 = PT1, as
|
||||||
given in (3). Given the buffer B2 had a duration D2 and assuming that
|
given in (3). Given the buffer B1 had a duration D1 and assuming that
|
||||||
generating a new buffer B3 will take the same amount of processing time,
|
generating a new buffer B2 will take the same amount of processing time,
|
||||||
a better estimation for B3 would then be:
|
a better estimation for B2 would then be:
|
||||||
|
|
||||||
B3 = T1 + D3 * DR2
|
B2 = T1 + D2 * DR1
|
||||||
|
|
||||||
expanding gives:
|
expanding gives:
|
||||||
|
|
||||||
B3 = (B2 - J2) + D3 * (B2 - J2 - B1)
|
B2 = (B1 - J1) + D2 * (B1 - J1 - B0)
|
||||||
--------------
|
--------------
|
||||||
D2
|
D1
|
||||||
|
|
||||||
assuming the durations of the frames are equal and thus D2 = D3:
|
assuming the durations of the frames are equal and thus D1 = D2:
|
||||||
|
|
||||||
B3 = (B2 - J2) + (B2 - J2 - B1)
|
B2 = (B1 - J1) + (B1 - J1 - B0)
|
||||||
|
|
||||||
B3 = 2 * (B2 - J2) - B1
|
B2 = 2 * (B1 - J1) - B0
|
||||||
|
|
||||||
also:
|
also:
|
||||||
|
|
||||||
B1 = B2 - D2
|
B0 = B1 - D1
|
||||||
|
|
||||||
so:
|
so:
|
||||||
|
|
||||||
B3 = 2 * (B2 - J2) - (B2 - D2)
|
B2 = 2 * (B1 - J1) - (B1 - D1)
|
||||||
|
|
||||||
Which yields a more accurate prediction for the next buffer given as:
|
Which yields a more accurate prediction for the next buffer given as:
|
||||||
|
|
||||||
B3 = B2 - 2 * J2 + D2 (5)
|
B2 = B1 - 2 * J1 + D1 (5)
|
||||||
|
|
||||||
|
|
||||||
Long term correction
|
Long term correction
|
||||||
|
|
Loading…
Reference in a new issue