From 7865ee6c889d5704efb688aa1b536f72da8abb04 Mon Sep 17 00:00:00 2001 From: Hagen Wierstorf Date: Wed, 23 Oct 2024 11:42:12 +0200 Subject: [PATCH] Remove support for Python 3.8 (#73) * Remove support for Python 3.8 * Fix linting * Fix test for Python 3.9 * Use non-muteable defaults --- .github/workflows/test.yml | 2 +- audplot/core/api.py | 43 ++++++++++++++++++++------------------ pyproject.toml | 1 - 3 files changed, 24 insertions(+), 22 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index b2d3021..3f5af1b 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -13,7 +13,7 @@ jobs: strategy: matrix: os: [ ubuntu-latest, windows-latest, macos-latest ] - python-version: [ '3.8', '3.9', '3.10', '3.11', '3.12' ] + python-version: [ '3.9', '3.10', '3.11', '3.12' ] steps: - uses: actions/checkout@v4 diff --git a/audplot/core/api.py b/audplot/core/api.py index 5715598..933bfd2 100644 --- a/audplot/core/api.py +++ b/audplot/core/api.py @@ -1,5 +1,8 @@ +from __future__ import annotations + +from collections.abc import Callable +from collections.abc import Sequence import math -import typing import warnings import matplotlib @@ -92,11 +95,11 @@ def cepstrum( def confusion_matrix( - truth: typing.Union[typing.Sequence, pd.Series], - prediction: typing.Union[typing.Sequence, pd.Series], + truth: Sequence | pd.Series, + prediction: Sequence | pd.Series, *, - labels: typing.Sequence = None, - label_aliases: typing.Dict = None, + labels: Sequence = None, + label_aliases: dict = None, percentage: bool = False, show_both: bool = False, ax: matplotlib.axes.Axes = None, @@ -235,15 +238,15 @@ def combine_string(x, y): def detection_error_tradeoff( - x: typing.Union[typing.Sequence, pd.Series], - y: typing.Union[typing.Sequence, pd.Series], + x: Sequence | pd.Series, + y: Sequence | pd.Series, *, error_rates: bool = False, - xlim: typing.Sequence = [0.001, 0.5], - ylim: typing.Sequence = [0.001, 0.5], + xlim: Sequence = (0.001, 0.5), + ylim: Sequence = (0.001, 0.5), label: str = None, ax: matplotlib.axes.Axes = None, -) -> typing.Callable: +) -> Callable: r"""Detection error tradeoff curve. A `detection error tradeoff (DET)`_ curve @@ -360,8 +363,8 @@ def detection_error_tradeoff( def distribution( - truth: typing.Union[typing.Sequence, pd.Series], - prediction: typing.Union[typing.Sequence, pd.Series], + truth: Sequence | pd.Series, + prediction: Sequence | pd.Series, *, ax: matplotlib.axes.Axes = None, ): @@ -411,7 +414,7 @@ def distribution( def human_format( - number: typing.Union[int, float], + number: int | float, ) -> str: r"""Display large or small numbers in a human readable way. @@ -501,8 +504,8 @@ def human_format( def scatter( - truth: typing.Union[typing.Sequence, pd.Series], - prediction: typing.Union[typing.Sequence, pd.Series], + truth: Sequence | pd.Series, + prediction: Sequence | pd.Series, *, fit: bool = False, order: int = 1, @@ -552,8 +555,8 @@ def scatter( def series( - truth: typing.Union[typing.Sequence, pd.Series], - prediction: typing.Union[typing.Sequence, pd.Series], + truth: Sequence | pd.Series, + prediction: Sequence | pd.Series, *, ax: matplotlib.axes.Axes = None, ): @@ -720,10 +723,10 @@ def waveform( x: np.ndarray, *, text: str = None, - color: typing.Union[str, typing.Sequence[float]] = "#E13B41", - background: typing.Union[str, typing.Sequence[float]] = "#FFFFFF00", + color: str | Sequence[float] = "#E13B41", + background: str | Sequence[float] = "#FFFFFF00", linewidth: float = 1.5, - ylim: typing.Sequence[float] = (-1, 1), + ylim: Sequence[float] = (-1, 1), ax: matplotlib.axes.Axes = None, ): r"""Plot waveform of a mono signal. diff --git a/pyproject.toml b/pyproject.toml index 079e5f2..0dc5059 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -21,7 +21,6 @@ classifiers = [ 'Operating System :: OS Independent', 'Programming Language :: Python', 'Programming Language :: Python :: 3', - 'Programming Language :: Python :: 3.8', 'Programming Language :: Python :: 3.9', 'Programming Language :: Python :: 3.10', 'Programming Language :: Python :: 3.11',