-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bump Ratio to 3.0 #438
Bump Ratio to 3.0 #438
Changes from 5 commits
f15745f
838bc79
25d2b39
504f1ff
0a26238
d65d679
3276e55
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -11,7 +11,7 @@ defmodule Membrane.Clock do | |||||
the time passed, in practice the described approach turns out to be more convenient, | ||||||
as it simplifies the first update. | ||||||
|
||||||
Basing on updates, Clock calculates the `t:ratio_t/0` of its time to the reference | ||||||
Basing on updates, Clock calculates the `t:Ratio.t/0` of its time to the reference | ||||||
time. The reference time can be configured with `:time_provider` option. The ratio | ||||||
is broadcasted (see `t:ratio_message_t/0`) to _subscribers_ (see `subscribe/2`) | ||||||
- processes willing to synchronize to the custom clock. Subscribers can adjust | ||||||
|
@@ -34,11 +34,6 @@ defmodule Membrane.Clock do | |||||
|
||||||
@type t :: pid | ||||||
|
||||||
@typedoc """ | ||||||
Ratio of the Clock time to the reference time. | ||||||
""" | ||||||
@type ratio_t :: Ratio.t() | non_neg_integer | ||||||
|
||||||
@typedoc """ | ||||||
Update message received by the Clock. It should contain the time till the next | ||||||
update. | ||||||
|
@@ -48,13 +43,13 @@ defmodule Membrane.Clock do | |||||
milliseconds :: | ||||||
non_neg_integer | ||||||
| Ratio.t() | ||||||
| {numerator :: non_neg_integer, denominator :: pos_integer}} | ||||||
| {numerator :: non_neg_integer, denominator :: pos_integer()}} | ||||||
|
||||||
@typedoc """ | ||||||
Ratio message sent by the Clock to all its subscribers. It contains the ratio | ||||||
of the custom clock time to the reference time. | ||||||
""" | ||||||
@type ratio_message_t :: {:membrane_clock_ratio, clock :: pid, ratio_t} | ||||||
@type ratio_message_t :: {:membrane_clock_ratio, clock :: pid, Ratio.t()} | ||||||
|
||||||
@typedoc """ | ||||||
Options accepted by `start_link/2` and `start/2` functions. | ||||||
|
@@ -200,7 +195,7 @@ defmodule Membrane.Clock do | |||||
defp get_proxy_options(true, _proxy_for), do: %{proxy: true, proxy_for: nil} | ||||||
|
||||||
defp get_proxy_options(_proxy, _proxy_for), | ||||||
do: %{init_time: nil, clock_time: 0, till_next: nil, proxy: false} | ||||||
do: %{init_time: nil, clock_time: Ratio.new(0), till_next: nil, proxy: false} | ||||||
|
||||||
defp handle_unsubscribe(pid, state) do | ||||||
Process.demonitor(state.subscribers[pid].monitor, [:flush]) | ||||||
|
@@ -212,13 +207,13 @@ defmodule Membrane.Clock do | |||||
end | ||||||
|
||||||
defp handle_clock_update(till_next, state) do | ||||||
use Ratio | ||||||
till_next = Ratio.new(till_next) | ||||||
|
||||||
if till_next < 0 do | ||||||
if Ratio.lt?(till_next, 0) do | ||||||
raise "Clock update time cannot be negative, received: #{inspect(till_next)}" | ||||||
end | ||||||
|
||||||
till_next = till_next * Time.millisecond() | ||||||
till_next = Ratio.mult(till_next, Ratio.new(Time.millisecond())) | ||||||
|
||||||
case state.init_time do | ||||||
nil -> %{state | init_time: state.time_provider.(), till_next: till_next} | ||||||
|
@@ -227,10 +222,9 @@ defmodule Membrane.Clock do | |||||
end | ||||||
|
||||||
defp do_handle_clock_update(till_next, state) do | ||||||
use Ratio | ||||||
%{till_next: from_previous, clock_time: clock_time} = state | ||||||
clock_time = clock_time + from_previous | ||||||
ratio = clock_time / (state.time_provider.() - state.init_time) | ||||||
clock_time = Ratio.add(clock_time, from_previous) | ||||||
ratio = Ratio.new(clock_time, state.time_provider.() - state.init_time) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
state = %{state | clock_time: clock_time, till_next: till_next} | ||||||
broadcast_and_update_ratio(ratio, state) | ||||||
end | ||||||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,12 +14,12 @@ defmodule Membrane.Core.Timer do | |
init_time: Time.t(), | ||
clock: Clock.t(), | ||
next_tick_time: Time.t(), | ||
ratio: Clock.ratio_t(), | ||
ratio: Ratio.t(), | ||
timer_ref: reference() | nil | ||
} | ||
|
||
@enforce_keys [:interval, :clock, :init_time, :id] | ||
defstruct @enforce_keys ++ [next_tick_time: 0, ratio: 1, timer_ref: nil] | ||
defstruct @enforce_keys ++ [next_tick_time: 0, ratio: Ratio.new(1), timer_ref: nil] | ||
|
||
@spec start(id_t, interval_t, Clock.t()) :: t | ||
def start(id, interval, clock) do | ||
|
@@ -37,7 +37,7 @@ defmodule Membrane.Core.Timer do | |
:ok | ||
end | ||
|
||
@spec update_ratio(t, Clock.ratio_t()) :: t | ||
@spec update_ratio(t, Ratio.t()) :: t | ||
def update_ratio(timer, ratio) do | ||
%__MODULE__{timer | ratio: ratio} | ||
end | ||
|
@@ -48,7 +48,7 @@ defmodule Membrane.Core.Timer do | |
end | ||
|
||
def tick(timer) do | ||
use Ratio | ||
use Numbers, overload_operators: true | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. let's be consistent and not use that There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||
|
||
%__MODULE__{ | ||
id: id, | ||
|
@@ -62,7 +62,9 @@ defmodule Membrane.Core.Timer do | |
|
||
# Next tick time converted to BEAM clock time | ||
beam_next_tick_time = | ||
(init_time + next_tick_time / ratio) |> Ratio.floor() |> Time.round_to_milliseconds() | ||
(init_time + Ratio.new(next_tick_time, ratio)) | ||
|> Ratio.floor() | ||
|> Time.round_to_milliseconds() | ||
|
||
timer_ref = | ||
Process.send_after(self(), Message.new(:timer_tick, id), beam_next_tick_time, abs: true) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -11,6 +11,8 @@ defmodule Membrane.Time do | |
that do not touch hardware clock, you should use Membrane units for consistency. | ||
""" | ||
|
||
require Ratio | ||
|
||
@compile {:inline, | ||
native_units: 1, native_unit: 0, nanoseconds: 1, nanosecond: 0, second: 0, seconds: 1} | ||
|
||
|
@@ -30,7 +32,7 @@ defmodule Membrane.Time do | |
# Difference between 01.01.1900 (start of NTP epoch) and 01.01.1970 (start of Unix epoch) in seconds | ||
@ntp_unix_epoch_diff 2_208_988_800 | ||
|
||
@two_to_pow_32 Ratio.pow(2, 32) | ||
@two_to_pow_32 Ratio.pow(Ratio.new(2, 1), 32) |> Ratio.trunc() | ||
|
||
@doc """ | ||
Checks whether a value is `Membrane.Time.t`. | ||
|
@@ -260,12 +262,10 @@ defmodule Membrane.Time do | |
end | ||
|
||
# credo:disable-for-next-line Credo.Check.Readability.Specs | ||
def unquote(unit.plural)(number) do | ||
if not Ratio.is_rational?(number) do | ||
raise "Only integers and rationals can be converted with Membrane.Time.#{unquote(unit.plural)}" | ||
end | ||
def unquote(unit.plural)(number) when Ratio.is_rational(number) do | ||
use Numbers, overload_operators: true | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. as above There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done here and also in clock_test.exs |
||
|
||
Ratio.*(number, unquote(unit.duration)) | ||
(number * unquote(unit.duration)) | ||
|> round_rational() | ||
end | ||
|
||
|
@@ -288,7 +288,7 @@ defmodule Membrane.Time do | |
@spec unquote(as_fun_name)(t) :: integer | Ratio.t() | ||
# credo:disable-for-next-line Credo.Check.Readability.Specs | ||
def unquote(as_fun_name)(time) when is_time(time) do | ||
Ratio./(time, unquote(unit.duration)) | ||
Ratio.new(time, unquote(unit.duration)) | ||
end | ||
end) | ||
|
||
|
@@ -298,7 +298,6 @@ defmodule Membrane.Time do | |
end | ||
|
||
defp round_rational(ratio) do | ||
ratio = make_rational(ratio) | ||
trunced = Ratio.trunc(ratio) | ||
|
||
if 2 * sign_of_rational(ratio) * | ||
|
@@ -308,14 +307,6 @@ defmodule Membrane.Time do | |
else: trunced | ||
end | ||
|
||
defp make_rational(number) do | ||
if Ratio.is_rational?(number) do | ||
number | ||
else | ||
%Ratio{numerator: number, denominator: 1} | ||
end | ||
end | ||
|
||
defp sign_of_rational(ratio) do | ||
if ratio.numerator == 0, do: 0, else: Ratio.sign(ratio) | ||
end | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd leave this type
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done