From 7521277860b377e3e9ec7b6d5a62c4c2c14d694f Mon Sep 17 00:00:00 2001 From: xengineering Date: Sun, 8 Sep 2024 12:46:20 +0200 Subject: Use list[tuple[datetime, Decimal]] consistently This type is useful for finance-py in general. It is often required to handle money in datetime context. Using this type consistently makes the code easier to read and maintain. --- finance/flow.py | 4 ++-- finance/test_flow.py | 19 +++++++------------ finance/visualize.py | 6 +++--- 3 files changed, 12 insertions(+), 17 deletions(-) (limited to 'finance') diff --git a/finance/flow.py b/finance/flow.py index 4cf68db..c6b28c0 100644 --- a/finance/flow.py +++ b/finance/flow.py @@ -46,7 +46,7 @@ def monthly_candidates(start: datetime) -> Generator[datetime, None, None]: def simulate( start: datetime, end: datetime, flows: tuple[Flow, ...] -) -> tuple[list[datetime], list[Decimal]]: +) -> list[tuple[datetime, Decimal]]: dates: list[datetime] = [] values: list[Decimal] = [] @@ -63,4 +63,4 @@ def simulate( value += flow.integrate(start, date) values.append(value) - return (dates, values) + return [(date, values[index]) for index, date in enumerate(dates)] diff --git a/finance/test_flow.py b/finance/test_flow.py index db1b695..91d189b 100644 --- a/finance/test_flow.py +++ b/finance/test_flow.py @@ -31,22 +31,17 @@ def test_flow_integration() -> None: def test_simulate() -> None: flows = (Flow(amount=Decimal(100.0), since=None, until=None),) - dates, values = simulate( + simulated = simulate( start=datetime(2024, 1, 1), end=datetime(2024, 4, 1), flows=flows, ) - assert dates == [ - datetime(2024, 1, 1), - datetime(2024, 2, 1), - datetime(2024, 3, 1), - datetime(2024, 4, 1), + expected = [ + (datetime(2024, 1, 1), Decimal(100.0)), + (datetime(2024, 2, 1), Decimal(200.0)), + (datetime(2024, 3, 1), Decimal(300.0)), + (datetime(2024, 4, 1), Decimal(400.0)), ] - assert values == [ - Decimal(100.0), - Decimal(200.0), - Decimal(300.0), - Decimal(400.0), - ] + assert simulated == expected diff --git a/finance/visualize.py b/finance/visualize.py index c7a7c60..66943c7 100644 --- a/finance/visualize.py +++ b/finance/visualize.py @@ -5,12 +5,12 @@ import matplotlib.pyplot def display( - simulated: tuple[list[datetime], list[Decimal]], + simulated: list[tuple[datetime, Decimal]], measured: list[tuple[datetime, Decimal]], ) -> None: matplotlib.pyplot.plot( - list(simulated[0]), # type: ignore - [float(i) for i in simulated[1]], + [i[0] for i in simulated], # type: ignore + [float(i[1]) for i in simulated], label="Simulated", ) matplotlib.pyplot.plot( -- cgit v1.2.3-70-g09d2