From 4355b21137730f6258247c2e0daaab3ba4a14d18 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20H=C3=B6rtnagl?= Date: Mon, 4 Mar 2024 11:45:41 +0100 Subject: [PATCH 1/6] Now using poetry for dependencies --- .gitignore | 1 + .idea/DYCO_Dynamic_Lag_Compensation.iml | 2 +- .idea/misc.xml | 5 +- .idea/workspace.xml | 69 ++- CHANGELOG.md | 12 + LICENSE | 8 +- README.md | 195 ++++--- dyco/analyze.py | 4 +- dyco/cli.py | 4 +- dyco/correction.py | 4 +- dyco/dyco.py | 4 +- dyco/files.py | 4 +- dyco/lag.py | 4 +- dyco/loop.py | 4 +- dyco/plot.py | 4 +- dyco/setup_dyco.py | 4 +- environment.yml | 116 ----- poetry.lock | 661 ++++++++++++++++++++++++ pyproject.toml | 17 + requirements.txt | 82 --- setup.py | 4 +- 21 files changed, 914 insertions(+), 294 deletions(-) create mode 100644 CHANGELOG.md delete mode 100644 environment.yml create mode 100644 poetry.lock create mode 100644 pyproject.toml delete mode 100644 requirements.txt diff --git a/.gitignore b/.gitignore index 46a2c6e..06b2ce1 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ # Custom +.idea/ dist/ _archive/ _raw_photoshop/ diff --git a/.idea/DYCO_Dynamic_Lag_Compensation.iml b/.idea/DYCO_Dynamic_Lag_Compensation.iml index 662eebd..14770dc 100644 --- a/.idea/DYCO_Dynamic_Lag_Compensation.iml +++ b/.idea/DYCO_Dynamic_Lag_Compensation.iml @@ -12,7 +12,7 @@ - + diff --git a/.idea/misc.xml b/.idea/misc.xml index 095ec02..8569286 100644 --- a/.idea/misc.xml +++ b/.idea/misc.xml @@ -1,7 +1,10 @@ + + - + \ No newline at end of file diff --git a/.idea/workspace.xml b/.idea/workspace.xml index 9d7919e..a69c2b3 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -1,7 +1,32 @@ + + - + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - + @@ -44,6 +78,7 @@ + + + + + + + + + + + @@ -371,6 +417,7 @@ + diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..ab7502e --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,12 @@ +# CHANGELOG + +## v1.2.0 | XX Mar 2024 + +- Now using `poetry` for dependency management + +## v1.1.2 | 16 Jun 2021 + +### Release version for publication in JOSS + +- JOSS: https://joss.theoj.org/ +- DYCO open review: openjournals/joss-reviews#2575 diff --git a/LICENSE b/LICENSE index be393bb..4136bd0 100644 --- a/LICENSE +++ b/LICENSE @@ -632,7 +632,7 @@ state the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -645,14 +645,14 @@ the "copyright" line and a pointer to where the full notice is found. GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . Also add information on how to contact you by electronic and paper mail. If the program does terminal interaction, make it output a short notice like this when it starts in an interactive mode: - DYCO Dynamic Lag Compensation Copyright (C) 2020 holukas + DYCO Dynamic Lag Compensation Copyright (C) 2020-2024 Lukas Hörtnagl This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. @@ -664,7 +664,7 @@ might be different; for a GUI interface, you would use an "about box". You should also get your employer (if you work as a programmer) or school, if any, to sign a "copyright disclaimer" for the program, if necessary. For more information on this, and how to apply and follow the GNU GPL, see -. +. The GNU General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you diff --git a/README.md b/README.md index 7dbf05c..f654fd5 100644 --- a/README.md +++ b/README.md @@ -4,32 +4,54 @@ [![DOI](https://zenodo.org/badge/311300577.svg)](https://zenodo.org/badge/latestdoi/311300577) - - # DYCO - Dynamic Lag Compensation -The lag detection between the turbulent departures of measured wind and the scalar of interest is a central step in the calculation of eddy covariance (EC) ecosystem fluxes. In case the covariance maximization fails to detect a clear peak in the covariance function between the wind and the scalar, current flux calculation software can apply a constant default (nominal) time lag to the respective scalar. However, both the detection of clear covariance peaks in a pre-defined time window and the definition of a reliable default time lag is challenging for compounds which are often characterized by low SNR, such as N2O. In addition, the application of one static default time lag may produce inaccurate results in case systematic time shifts are present in the raw data. +The lag detection between the turbulent departures of measured wind and the scalar of interest is a central step in the +calculation of eddy covariance (EC) ecosystem fluxes. In case the covariance maximization fails to detect a clear peak +in the covariance function between the wind and the scalar, current flux calculation software can apply a constant +default (nominal) time lag to the respective scalar. However, both the detection of clear covariance peaks in a +pre-defined time window and the definition of a reliable default time lag is challenging for compounds which are often +characterized by low SNR, such as N2O. In addition, the application of one static default time lag may +produce inaccurate results in case systematic time shifts are present in the raw data. - `DYCO` is meant to assist current flux processing software in the calculation of fluxes for compounds with low SNR. In the context of current flux processing schemes, the unique features offered as part of the `DYCO` package include: +`DYCO` is meant to assist current flux processing software in the calculation of fluxes for compounds with low SNR. In +the context of current flux processing schemes, the unique features offered as part of the `DYCO` package include: -- (i) the dynamic application of progressively smaller time windows during lag search for a *reference* compound (e.g. CO2), +- (i) the dynamic application of progressively smaller time windows during lag search for a *reference* compound (e.g. + CO2), - (ii) the calculation of default time lags on a daily scale for the *reference* compound, - (iii) the application of daily default *reference* time lags to one or more *target* compounds (e.g. N2O) - (iv) the dynamic normalization of time lags across raw data files, -- (v) the automatic correction of systematic time shifts in *target* raw data time series, e.g. due to failed synchronization of instrument clocks, and -- (vi) the application of instantaneous *reference* time lags, calculated from lag-normalized files, to one or more *target* compounds. - -As `DYCO` aims to complement current flux processing schemes, final lag-removed files are produced that can be directly used in current flux calculation software. - +- (v) the automatic correction of systematic time shifts in *target* raw data time series, e.g. due to failed + synchronization of instrument clocks, and +- (vi) the application of instantaneous *reference* time lags, calculated from lag-normalized files, to one or more + *target* compounds. +As `DYCO` aims to complement current flux processing schemes, final lag-removed files are produced that can be directly +used in current flux calculation software. ## Scientific background -In ecosystem research, the EC method is widely used to quantify the biosphere-atmosphere exchange of greenhouse gases (GHGs) and energy (Aubinet et al., 2012; Baldocchi et al., 1988). The raw ecosystem flux (i.e. net exchange) is calculated by the covariance between the turbulent vertical wind component measured by a sonic anemometer and the entity of interest, e.g. CO2, measured by a gas analyzer. Due to the application of two different instruments, wind and gas are not recorded at exactly the same time, resulting in a time lag between the two time series. For the calculation of ecosystem fluxes this time delay has to be quantified and corrected for, otherwise fluxes are systematically biased. Time lags for each averaging interval can be estimated by finding the maximum absolute covariance between the two turbulent time series at different time steps in a pre-defined time window of physically possible time-lags (e.g., McMillen, 1988; Moncrieff et al., 1997). Lag detection works well when processing fluxes for compounds with high signal-to-noise ratio (SNR), which is typically the case for e.g. CO2. In contrast, for compounds with low SNR (e.g., N2O, CH4) the cross-covariance function with the turbulent wind component yields noisier results and calculated fluxes are biased towards larger absolute flux values (Langford et al., 2015), which in turn renders the accurate calculation of yearly ecosystem GHG budgets more difficult and results may be inaccurate. - -One suggestion to adequately calculate fluxes for compounds with low SNR is to first calculate the time lag for a *reference* compound with high SNR (e.g. CO2) and then apply the same time lag to the *target* compound of interest (e.g. N2O), with both compounds being recorded by the same analyzer (Nemitz et al., 2018). `DYCO` follows up on this suggestion by facilitating the dynamic lag-detection between the turbulent wind data and a *reference* compound and the subsequent application of found *reference* time lags to one or more *target* compounds. - - +In ecosystem research, the EC method is widely used to quantify the biosphere-atmosphere exchange of greenhouse gases ( +GHGs) and energy (Aubinet et al., 2012; Baldocchi et al., 1988). The raw ecosystem flux (i.e. net exchange) is +calculated by the covariance between the turbulent vertical wind component measured by a sonic anemometer and the entity +of interest, e.g. CO2, measured by a gas analyzer. Due to the application of two different instruments, wind +and gas are not recorded at exactly the same time, resulting in a time lag between the two time series. For the +calculation of ecosystem fluxes this time delay has to be quantified and corrected for, otherwise fluxes are +systematically biased. Time lags for each averaging interval can be estimated by finding the maximum absolute covariance +between the two turbulent time series at different time steps in a pre-defined time window of physically possible +time-lags (e.g., McMillen, 1988; Moncrieff et al., 1997). Lag detection works well when processing fluxes for compounds +with high signal-to-noise ratio (SNR), which is typically the case for e.g. CO2. In contrast, for compounds +with low SNR (e.g., N2O, CH4) the cross-covariance function with the turbulent wind component +yields noisier results and calculated fluxes are biased towards larger absolute flux values (Langford et al., 2015), +which in turn renders the accurate calculation of yearly ecosystem GHG budgets more difficult and results may be +inaccurate. + +One suggestion to adequately calculate fluxes for compounds with low SNR is to first calculate the time lag for a +*reference* compound with high SNR (e.g. CO2) and then apply the same time lag to the *target* compound of +interest (e.g. N2O), with both compounds being recorded by the same analyzer (Nemitz et al., 2018). `DYCO` +follows up on this suggestion by facilitating the dynamic lag-detection between the turbulent wind data and a +*reference* compound and the subsequent application of found *reference* time lags to one or more *target* compounds. ## Processing chain @@ -39,15 +61,32 @@ One suggestion to adequately calculate fluxes for compounds with low SNR is to f `DYCO` uses eddy covariance raw data files as input and produces lag-compensated raw data files as output. -The full `DYCO` processing chain comprises four phases and several iterations during which *reference* lags are refined iteratively in progressively smaller search windows (Figure 1). Generally, the *reference* lag search is facilitated by prior normalization of default (nominal) time lags across files. This is achieved by compensating *reference* and *target* time series data for daily default *reference* lags, calculated from high-quality *reference* lags available around the respective date (Figure 2). Due to this normalization, *reference* lags fall into a specific, pre-defined and therefore known time range, which in turn allows the application of increasingly narrower time windows during lag search. This approach has the advantage that *reference* lags can be calculated from a *reference* signal that shows clear peaks in the cross-covariance analysis with the wind data and thus yields unambiguous time lags due to its high SNR. In case the lag search failed to detect a clear time delay for the *reference* variable (e.g. during the night), the respective daily default *reference* lag is used instead. *Reference* lags can then be used to compensate *target* variables with low SNR for detected *reference* time delays. - -A description of the different Phases along with output examples can be found in the Wiki: [Processing Chain](https://github.com/holukas/dyco/wiki/Processing-Chain). +The full `DYCO` processing chain comprises four phases and several iterations during which *reference* lags are refined +iteratively in progressively smaller search windows (Figure 1). Generally, the *reference* lag search is facilitated by +prior normalization of default (nominal) time lags across files. This is achieved by compensating *reference* and +*target* time series data for daily default *reference* lags, calculated from high-quality *reference* lags available +around the respective date (Figure 2). Due to this normalization, *reference* lags fall into a specific, pre-defined and +therefore known time range, which in turn allows the application of increasingly narrower time windows during lag +search. This approach has the advantage that *reference* lags can be calculated from a *reference* signal that shows +clear peaks in the cross-covariance analysis with the wind data and thus yields unambiguous time lags due to its high +SNR. In case the lag search failed to detect a clear time delay for the *reference* variable (e.g. during the night), +the respective daily default *reference* lag is used instead. *Reference* lags can then be used to compensate *target* +variables with low SNR for detected *reference* time delays. + +A description of the different Phases along with output examples can be found in the +Wiki: [Processing Chain](https://github.com/holukas/dyco/wiki/Processing-Chain). ![Normalization example](images/fig_PHASE-1_ITERATION-3_TIMESERIES-PLOT_segment_lag_times_iteration.png) -**Figure 2**. *Example showing the normalization of default reference time lags across files. Shown are found instantaneous time lags (red) between turbulent wind data and turbulent CO2 mixing ratios, calculated daily reference default lags (yellow bars), normalization correction (blue arrows) and the daily default reference lag after normalization (green bar). Negative lag values mean that the CO2 signal was lagged behind the wind data, e.g. -400 means that the instantaneous CO2 records arrived 400 records (corresponds to 20s in this example) later at the analyzer than the wind data. Daily default reference lags were calculated as the 3-day median time lag from a selection of high-quality time lags, i.e. when cross-covariance analyses yielded a clear covariance peak. The normalization correction is applied dynamically to shift the CO2 data so that the default time lag is found close to zero across files. Note the systematic shift in time lags starting after 27 Oct 2016.* - - +**Figure 2**. *Example showing the normalization of default reference time lags across files. Shown are found +instantaneous time lags (red) between turbulent wind data and turbulent CO2 mixing ratios, calculated daily +reference default lags (yellow bars), normalization correction (blue arrows) and the daily default reference lag after +normalization (green bar). Negative lag values mean that the CO2 signal was lagged behind the wind data, e.g. +-400 means that the instantaneous CO2 records arrived 400 records (corresponds to 20s in this example) later +at the analyzer than the wind data. Daily default reference lags were calculated as the 3-day median time lag from a +selection of high-quality time lags, i.e. when cross-covariance analyses yielded a clear covariance peak. The +normalization correction is applied dynamically to shift the CO2 data so that the default time lag is found +close to zero across files. Note the systematic shift in time lags starting after 27 Oct 2016.* ## Installation @@ -55,72 +94,110 @@ A description of the different Phases along with output examples can be found in `pip install dyco` - - ## Usage `DYCO` is run from the command line interface (CLI). `usage: dyco.py [-h] [-i INDIR] [-o OUTDIR] [-fnd FILENAMEDATEFORMAT]` - `[-fnp FILENAMEPATTERN] [-flim LIMITNUMFILES] [-fgr FILEGENRES]` - `[-fdur FILEDURATION] [-dtf DATATIMESTAMPFORMAT]` - `[-dres DATANOMINALTIMERES] [-lss LSSEGMENTDURATION]` - `[-lsw LSWINSIZE] [-lsi LSNUMITER] [-lsf {0,1}]` - `[-lsp LSPERCTHRES] [-lt TARGETLAG] [-del {0,1}]` - `var_reference var_lagged var_target [var_target ...]` +`[-fnp FILENAMEPATTERN] [-flim LIMITNUMFILES] [-fgr FILEGENRES]` +`[-fdur FILEDURATION] [-dtf DATATIMESTAMPFORMAT]` +`[-dres DATANOMINALTIMERES] [-lss LSSEGMENTDURATION]` +`[-lsw LSWINSIZE] [-lsi LSNUMITER] [-lsf {0,1}]` +`[-lsp LSPERCTHRES] [-lt TARGETLAG] [-del {0,1}]` +`var_reference var_lagged var_target [var_target ...]` - Example usage with full arguments can be found here: [Example](https://github.com/holukas/dyco/wiki/Example) -- For an overview of arguments see here: [Usage](https://github.com/holukas/dyco/wiki/Usage) -- `DYCO` creates a range of output folders which are described here: [Results Output Folders](https://github.com/holukas/dyco/wiki/Results-Output-Folders) - - +- For an overview of arguments see here: [Usage](https://github.com/holukas/dyco/wiki/Usage) +- `DYCO` creates a range of output folders which are described + here: [Results Output Folders](https://github.com/holukas/dyco/wiki/Results-Output-Folders) ## Documentation Please refer to the [Wiki](https://github.com/holukas/dyco/wiki) for documentation and additional examples. - - ## Real-world examples -The [ICOS](https://www.icos-cp.eu/) Class 1 site [Davos](https://www.swissfluxnet.ethz.ch/index.php/sites/ch-dav-davos/site-info-ch-dav/) (CH-Dav), a subalpine forest ecosystem station in the east of Switzerland, provides one of the longest continuous time series (24 years and running) of ecosystem fluxes globally. Since 2016, measurements of the strong GHG N2O are recorded by a closed-path gas analyzer that also records CO2. To calculate fluxes using the EC method, wind data from the sonic anemometer is combined with instantaneous gas measurements from the gas analyzer. However, the air sampled by the gas analyzer needs a certain amount of time to travel from the tube inlet to the measurement cell in the analyzer and is thus lagged behind the wind signal. The lag between the two signals needs to be compensated for by detecting and then removing the time lag at which the cross-covariance between the turbulent wind and the turbulent gas signal reaches the maximum absolute value. This works generally well when using CO2 (high SNR) but is challenging for N2O (low SNR). Using covariance maximization to search for the lag between wind and N2O mostly fails to accurately detect time lags between the two variables (noisy cross-correlation function), resulting in relatively noisy fluxes. However, since N2O has similar adsorption / desorption characteristics as CO2 it is valid to assume that both compounds need approx. the same time to travel through the tube to the analyzer, i.e. the time lag for both compounds in relation to the wind is similar. Therefore, `DYCO` can be applied (i) to calculate time lags across files for CO2 (*reference* compound), and then (ii) to remove found CO2 time delays from the N2O signal (*target* compound). The lag-compensated files produced by `DYCO` can then be used to calculate N2O fluxes. Since `DYCO` normalizes time lags across files and compensated the N2O signal for instantaneous CO2 lags, the *true* lag between wind and N2O can be found close to zero, which in turn facilitates the application of a small time window for the final lag search during flux calculations. - -Another application example are managed grasslands where the biosphere-atmosphere exchange of N2O is often characterized by sporadic high-emission events (e.g., Hörtnagl et al., 2018; Merbold et al., 2014). While high N2O quantities can be emitted during and after management events such as fertilizer application and ploughing, fluxes in between those events typically remain low and often below the limit-of-detection of the applied analyzer. In this case, calculating N2O fluxes works well during the high-emission periods (high SNR) but is challenging during the rest of the year (low SNR). Here, `DYCO` can be used to first calculate time lags for a *reference* gas measured in the same analyzer (e.g. CO2, CO, CH4) and then remove *reference* time lags from the N2O data. - - +The [ICOS](https://www.icos-cp.eu/) Class 1 +site [Davos](https://www.swissfluxnet.ethz.ch/index.php/sites/ch-dav-davos/site-info-ch-dav/) (CH-Dav), a subalpine +forest ecosystem station in the east of Switzerland, provides one of the longest continuous time series (24 years and +running) of ecosystem fluxes globally. Since 2016, measurements of the strong GHG N2O are recorded by a +closed-path gas analyzer that also records CO2. To calculate fluxes using the EC method, wind data from the +sonic anemometer is combined with instantaneous gas measurements from the gas analyzer. However, the air sampled by the +gas analyzer needs a certain amount of time to travel from the tube inlet to the measurement cell in the analyzer and is +thus lagged behind the wind signal. The lag between the two signals needs to be compensated for by detecting and then +removing the time lag at which the cross-covariance between the turbulent wind and the turbulent gas signal reaches the +maximum absolute value. This works generally well when using CO2 (high SNR) but is challenging for N +2O (low SNR). Using covariance maximization to search for the lag between wind and N2O mostly fails to +accurately detect time lags between the two variables (noisy cross-correlation function), resulting in relatively noisy +fluxes. However, since N2O has similar adsorption / desorption characteristics as CO2 it is valid +to assume that both compounds need approx. the same time to travel through the tube to the analyzer, i.e. the time lag +for both compounds in relation to the wind is similar. Therefore, `DYCO` can be applied (i) to calculate time lags +across files for CO2 (*reference* compound), and then (ii) to remove found CO2 time delays from +the N2O signal (*target* compound). The lag-compensated files produced by `DYCO` can then be used to +calculate N2O fluxes. Since `DYCO` normalizes time lags across files and compensated the N2O +signal for instantaneous CO2 lags, the *true* lag between wind and N2O can be found close to zero, +which in turn facilitates the application of a small time window for the final lag search during flux calculations. + +Another application example are managed grasslands where the biosphere-atmosphere exchange of N2O is often +characterized by sporadic high-emission events (e.g., Hörtnagl et al., 2018; Merbold et al., 2014). While high N +2O quantities can be emitted during and after management events such as fertilizer application and ploughing, +fluxes in between those events typically remain low and often below the limit-of-detection of the applied analyzer. In +this case, calculating N2O fluxes works well during the high-emission periods (high SNR) but is challenging +during the rest of the year (low SNR). Here, `DYCO` can be used to first calculate time lags for a *reference* gas +measured in the same analyzer (e.g. CO2, CO, CH4) and then remove *reference* time lags from the +N2O data. ## Contributing -All contributions in the form of code, bug reports, comments or general feedback are always welcome and greatly appreciated! Credit will always be given. - -- **Pull requests**: If you added new functionality or made the `DYCO` code run faster (always welcome), please create a fork in GitHub, make the contribution public in your repo and then issue a [pull request](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-a-pull-request-from-a-fork). Please include tests in your pull requests. -- **Issues**: If you experience any issue, please use the [issue tracker](https://github.com/holukas/dyco/issues) to submit it as an issue ticket with the label 'bug'. Please also include a minimal code example that produces the issue. -- **Feature request**: If there is a feature that you would like to see in a later version, please use the [issue tracker](https://github.com/holukas/dyco/issues) to submit it as an issue ticket with the label 'feature request'. -- **Contact details**: For direct questions or enquiries the maintainer of this repository can be contacted directly by writing an email with the title "DYCO" to: holukas@ethz.ch - - +All contributions in the form of code, bug reports, comments or general feedback are always welcome and greatly +appreciated! Credit will always be given. + +- **Pull requests**: If you added new functionality or made the `DYCO` code run faster (always welcome), please create a + fork in GitHub, make the contribution public in your repo and then issue + a [pull request](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-a-pull-request-from-a-fork). + Please include tests in your pull requests. +- **Issues**: If you experience any issue, please use the [issue tracker](https://github.com/holukas/dyco/issues) to + submit it as an issue ticket with the label 'bug'. Please also include a minimal code example that produces the issue. +- **Feature request**: If there is a feature that you would like to see in a later version, please use + the [issue tracker](https://github.com/holukas/dyco/issues) to submit it as an issue ticket with the label 'feature + request'. +- **Contact details**: For direct questions or enquiries the maintainer of this repository can be contacted directly by + writing an email with the title "DYCO" to: holukas@ethz.ch ## Acknowledgements -This work was supported by the Swiss National Science Foundation SNF (ICOS CH, grant nos. 20FI21_148992, 20FI20_173691) and the EU project Readiness of ICOS for Necessities of integrated Global Observations RINGO (grant no. 730944). - - +This work was supported by the Swiss National Science Foundation SNF (ICOS CH, grant nos. 20FI21_148992, 20FI20_173691) +and the EU project Readiness of ICOS for Necessities of integrated Global Observations RINGO (grant no. 730944). ## References -Aubinet, M., Vesala, T., Papale, D. (Eds.), 2012. Eddy Covariance: A Practical Guide to Measurement and Data Analysis. Springer Netherlands, Dordrecht. https://doi.org/10.1007/978-94-007-2351-1 +Aubinet, M., Vesala, T., Papale, D. (Eds.), 2012. Eddy Covariance: A Practical Guide to Measurement and Data Analysis. +Springer Netherlands, Dordrecht. https://doi.org/10.1007/978-94-007-2351-1 -Baldocchi, D.D., Hincks, B.B., Meyers, T.P., 1988. Measuring Biosphere-Atmosphere Exchanges of Biologically Related Gases with Micrometeorological Methods. Ecology 69, 1331–1340. https://doi.org/10.2307/1941631 +Baldocchi, D.D., Hincks, B.B., Meyers, T.P., 1988. Measuring Biosphere-Atmosphere Exchanges of Biologically Related +Gases with Micrometeorological Methods. Ecology 69, 1331–1340. https://doi.org/10.2307/1941631 -Hörtnagl, L., Barthel, M., Buchmann, N., Eugster, W., Butterbach-Bahl, K., Díaz-Pinés, E., Zeeman, M., Klumpp, K., Kiese, R., Bahn, M., Hammerle, A., Lu, H., Ladreiter-Knauss, T., Burri, S., Merbold, L., 2018. Greenhouse gas fluxes over managed grasslands in Central Europe. Glob. Change Biol. 24, 1843–1872. https://doi.org/10.1111/gcb.14079 +Hörtnagl, L., Barthel, M., Buchmann, N., Eugster, W., Butterbach-Bahl, K., Díaz-Pinés, E., Zeeman, M., Klumpp, K., +Kiese, R., Bahn, M., Hammerle, A., Lu, H., Ladreiter-Knauss, T., Burri, S., Merbold, L., 2018. Greenhouse gas fluxes +over managed grasslands in Central Europe. Glob. Change Biol. 24, 1843–1872. https://doi.org/10.1111/gcb.14079 -Langford, B., Acton, W., Ammann, C., Valach, A., Nemitz, E., 2015. Eddy-covariance data with low signal-to-noise ratio: time-lag determination, uncertainties and limit of detection. Atmospheric Meas. Tech. 8, 4197–4213. https://doi.org/10.5194/amt-8-4197-2015 +Langford, B., Acton, W., Ammann, C., Valach, A., Nemitz, E., 2015. Eddy-covariance data with low signal-to-noise ratio: +time-lag determination, uncertainties and limit of detection. Atmospheric Meas. Tech. 8, +4197–4213. https://doi.org/10.5194/amt-8-4197-2015 -McMillen, R.T., 1988. An eddy correlation technique with extended applicability to non-simple terrain. Bound.-Layer Meteorol. 43, 231–245. https://doi.org/10.1007/BF00128405 +McMillen, R.T., 1988. An eddy correlation technique with extended applicability to non-simple terrain. Bound.-Layer +Meteorol. 43, 231–245. https://doi.org/10.1007/BF00128405 -Merbold, L., Eugster, W., Stieger, J., Zahniser, M., Nelson, D., Buchmann, N., 2014. Greenhouse gas budget (CO2 , CH4 and N2O) of intensively managed grassland following restoration. Glob. Change Biol. 20, 1913–1928. https://doi.org/10.1111/gcb.12518 +Merbold, L., Eugster, W., Stieger, J., Zahniser, M., Nelson, D., Buchmann, N., 2014. Greenhouse gas budget (CO +2 , CH4 and N2O) of intensively managed grassland following restoration. Glob. Change Biol. +20, 1913–1928. https://doi.org/10.1111/gcb.12518 -Moncrieff, J.B., Massheder, J.M., de Bruin, H., Elbers, J., Friborg, T., Heusinkveld, B., Kabat, P., Scott, S., Soegaard, H., Verhoef, A., 1997. A system to measure surface fluxes of momentum, sensible heat, water vapour and carbon dioxide. J. Hydrol. 188–189, 589–611. https://doi.org/10.1016/S0022-1694(96)03194-0 +Moncrieff, J.B., Massheder, J.M., de Bruin, H., Elbers, J., Friborg, T., Heusinkveld, B., Kabat, P., Scott, S., +Soegaard, H., Verhoef, A., 1997. A system to measure surface fluxes of momentum, sensible heat, water vapour and carbon +dioxide. J. Hydrol. 188–189, 589–611. https://doi.org/10.1016/S0022-1694(96)03194-0 -Nemitz, E., Mammarella, I., Ibrom, A., Aurela, M., Burba, G.G., Dengel, S., Gielen, B., Grelle, A., Heinesch, B., Herbst, M., Hörtnagl, L., Klemedtsson, L., Lindroth, A., Lohila, A., McDermitt, D.K., Meier, P., Merbold, L., Nelson, D., Nicolini, G., Nilsson, M.B., Peltola, O., Rinne, J., Zahniser, M., 2018. Standardisation of eddy-covariance flux measurements of methane and nitrous oxide. Int. Agrophysics 32, 517–549. https://doi.org/10.1515/intag-2017-0042 +Nemitz, E., Mammarella, I., Ibrom, A., Aurela, M., Burba, G.G., Dengel, S., Gielen, B., Grelle, A., Heinesch, B., +Herbst, M., Hörtnagl, L., Klemedtsson, L., Lindroth, A., Lohila, A., McDermitt, D.K., Meier, P., Merbold, L., Nelson, +D., Nicolini, G., Nilsson, M.B., Peltola, O., Rinne, J., Zahniser, M., 2018. Standardisation of eddy-covariance flux +measurements of methane and nitrous oxide. Int. Agrophysics 32, 517–549. https://doi.org/10.1515/intag-2017-0042 diff --git a/dyco/analyze.py b/dyco/analyze.py index 2eb3751..662bf96 100644 --- a/dyco/analyze.py +++ b/dyco/analyze.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/cli.py b/dyco/cli.py index f4bb17e..2b75890 100644 --- a/dyco/cli.py +++ b/dyco/cli.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/correction.py b/dyco/correction.py index 81b685c..7614dde 100644 --- a/dyco/correction.py +++ b/dyco/correction.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/dyco.py b/dyco/dyco.py index 2beabab..2554043 100644 --- a/dyco/dyco.py +++ b/dyco/dyco.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ import os diff --git a/dyco/files.py b/dyco/files.py index 795df11..83563e2 100644 --- a/dyco/files.py +++ b/dyco/files.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/lag.py b/dyco/lag.py index 669b834..bd1ecc0 100644 --- a/dyco/lag.py +++ b/dyco/lag.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/loop.py b/dyco/loop.py index 5b7a8df..ddd60c1 100644 --- a/dyco/loop.py +++ b/dyco/loop.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/plot.py b/dyco/plot.py index 24e1c1e..de1b809 100644 --- a/dyco/plot.py +++ b/dyco/plot.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/dyco/setup_dyco.py b/dyco/setup_dyco.py index 10e5f7c..191464a 100644 --- a/dyco/setup_dyco.py +++ b/dyco/setup_dyco.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ diff --git a/environment.yml b/environment.yml deleted file mode 100644 index 24793bb..0000000 --- a/environment.yml +++ /dev/null @@ -1,116 +0,0 @@ -name: DYCO1 -channels: - - plotly - - conda-forge - - anaconda - - defaults -dependencies: - - astroid=2.4.2=py36_0 - - atomicwrites=1.4.0=py_0 - - attrs=19.3.0=py_0 - - blas=1.0=mkl - - brotlipy=0.7.0=py36h779f372_1000 - - ca-certificates=2020.6.24=0 - - certifi=2020.6.20=py36_0 - - cffi=1.14.0=py36ha419a9e_0 - - colorama=0.4.3=py_0 - - cryptography=2.8=py36hb32ad35_1 - - cycler=0.10.0=py36h009560c_0 - - entrypoints=0.3=py36h9f0ad1d_1001 - - freetype=2.9.1=ha9979f8_1 - - icc_rt=2019.0.0=h0cc432a_1 - - icu=58.2=ha66f8fd_1 - - idna=2.9=py_1 - - importlib-metadata=1.6.0=py36h9f0ad1d_0 - - importlib_metadata=1.6.0=0 - - intel-openmp=2020.0=166 - - isort=4.3.21=py36_0 - - jinja2=2.11.2=pyh9f0ad1d_0 - - jpeg=9b=hb83a4c4_2 - - jsonschema=3.2.0=py36h9f0ad1d_1 - - kiwisolver=1.1.0=py36ha925a31_0 - - lazy-object-proxy=1.4.3=py36he774522_0 - - libpng=1.6.37=h2a8f88b_0 - - markupsafe=1.1.1=py36h68a101e_1 - - matplotlib=3.1.3=py36_0 - - matplotlib-base=3.1.3=py36h64f37c6_0 - - mccabe=0.6.1=py36_1 - - mkl=2020.0=166 - - mkl-service=2.3.0=py36hb782905_0 - - mkl_fft=1.0.15=py36h14836fe_0 - - mkl_random=1.1.0=py36h675688f_0 - - more-itertools=8.4.0=py_0 - - numpy-base=1.18.1=py36hc3f5095_1 - - openssl=1.1.1g=he774522_0 - - packaging=20.4=py_0 - - pandas=1.0.3=py36h47e9c7a_0 - - pip=20.0.2=py36_1 - - plotly=4.8.0=py_0 - - pluggy=0.13.1=py36_0 - - portpicker=1.3.1=py36_0 - - py=1.9.0=py_0 - - pycparser=2.20=py_0 - - pylint=2.5.3=py36_0 - - pyopenssl=19.1.0=py_1 - - pyparsing=2.4.6=py_0 - - pyqt=5.9.2=py36h6538335_2 - - pyrsistent=0.16.0=py36h68a101e_0 - - pysocks=1.7.1=py36h9f0ad1d_1 - - pytest=5.4.3=py36_0 - - python=3.6.10=h9f7ef89_1 - - python-dateutil=2.8.1=py_0 - - python_abi=3.6=1_cp36m - - pytz=2019.3=py_0 - - qt=5.9.7=vc14h73c81de_0 - - retrying=1.3.3=py_2 - - scipy=1.4.1=py36h9439919_0 - - selenium=3.141.0=py36h68a101e_1001 - - setuptools=46.1.3=py36_0 - - sip=4.19.8=py36h6538335_0 - - six=1.14.0=py36_0 - - sqlite=3.31.1=he774522_0 - - toml=0.10.1=py_0 - - toolz=0.10.0=py_0 - - tornado=6.0.4=py36he774522_1 - - typed-ast=1.4.1=py36he774522_0 - - urllib3=1.25.9=py_0 - - vc=14.1=h0510ff6_4 - - vega_datasets=0.8.0=py_0 - - vs2015_runtime=14.16.27012=hf0eaf9b_1 - - wcwidth=0.2.5=py_0 - - wheel=0.34.2=py36_0 - - win_inet_pton=1.1.0=py36_0 - - wincertstore=0.2=py36h7fe50ca_0 - - wrapt=1.11.2=py36he774522_0 - - zipp=3.1.0=py_0 - - zlib=1.2.11=h62dcd97_4 - - pip: - - bleach==3.1.5 - - brotli==1.0.7 - - chardet==3.0.4 - - click==7.1.2 - - dash==1.12.0 - - dash-core-components==1.10.0 - - dash-html-components==1.0.3 - - dash-renderer==1.4.1 - - dash-table==4.7.0 - - docutils==0.16 - - dyco==1.0.2 - - flask==1.1.2 - - flask-compress==1.5.0 - - future==0.18.2 - - itsdangerous==1.1.0 - - keyring==21.2.1 - - numpy==1.18.1 - - pkginfo==1.5.0.1 - - pygments==2.6.1 - - pywin32-ctypes==0.2.0 - - readme-renderer==26.0 - - requests==2.24.0 - - requests-toolbelt==0.9.1 - - rfc3986==1.4.0 - - tqdm==4.47.0 - - twine==3.2.0 - - webencodings==0.5.1 - - werkzeug==1.0.1 -prefix: C:\Users\holukas\Anaconda3\envs\DYCO1 diff --git a/poetry.lock b/poetry.lock new file mode 100644 index 0000000..ef3ab4c --- /dev/null +++ b/poetry.lock @@ -0,0 +1,661 @@ +# This file is automatically @generated by Poetry 1.8.2 and should not be changed by hand. + +[[package]] +name = "contourpy" +version = "1.2.0" +description = "Python library for calculating contours of 2D quadrilateral grids" +optional = false +python-versions = ">=3.9" +files = [ + {file = "contourpy-1.2.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:0274c1cb63625972c0c007ab14dd9ba9e199c36ae1a231ce45d725cbcbfd10a8"}, + {file = "contourpy-1.2.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:ab459a1cbbf18e8698399c595a01f6dcc5c138220ca3ea9e7e6126232d102bb4"}, + {file = "contourpy-1.2.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6fdd887f17c2f4572ce548461e4f96396681212d858cae7bd52ba3310bc6f00f"}, + {file = "contourpy-1.2.0-cp310-cp310-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:5d16edfc3fc09968e09ddffada434b3bf989bf4911535e04eada58469873e28e"}, + {file = "contourpy-1.2.0-cp310-cp310-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:1c203f617abc0dde5792beb586f827021069fb6d403d7f4d5c2b543d87edceb9"}, + {file = "contourpy-1.2.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b69303ceb2e4d4f146bf82fda78891ef7bcd80c41bf16bfca3d0d7eb545448aa"}, + {file = "contourpy-1.2.0-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:884c3f9d42d7218304bc74a8a7693d172685c84bd7ab2bab1ee567b769696df9"}, + {file = "contourpy-1.2.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:4a1b1208102be6e851f20066bf0e7a96b7d48a07c9b0cfe6d0d4545c2f6cadab"}, + {file = "contourpy-1.2.0-cp310-cp310-win32.whl", hash = "sha256:34b9071c040d6fe45d9826cbbe3727d20d83f1b6110d219b83eb0e2a01d79488"}, + {file = "contourpy-1.2.0-cp310-cp310-win_amd64.whl", hash = "sha256:bd2f1ae63998da104f16a8b788f685e55d65760cd1929518fd94cd682bf03e41"}, + {file = "contourpy-1.2.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:dd10c26b4eadae44783c45ad6655220426f971c61d9b239e6f7b16d5cdaaa727"}, + {file = "contourpy-1.2.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:5c6b28956b7b232ae801406e529ad7b350d3f09a4fde958dfdf3c0520cdde0dd"}, + {file = "contourpy-1.2.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:ebeac59e9e1eb4b84940d076d9f9a6cec0064e241818bcb6e32124cc5c3e377a"}, + {file = "contourpy-1.2.0-cp311-cp311-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:139d8d2e1c1dd52d78682f505e980f592ba53c9f73bd6be102233e358b401063"}, + {file = "contourpy-1.2.0-cp311-cp311-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:1e9dc350fb4c58adc64df3e0703ab076f60aac06e67d48b3848c23647ae4310e"}, + {file = "contourpy-1.2.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:18fc2b4ed8e4a8fe849d18dce4bd3c7ea637758c6343a1f2bae1e9bd4c9f4686"}, + {file = "contourpy-1.2.0-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:16a7380e943a6d52472096cb7ad5264ecee36ed60888e2a3d3814991a0107286"}, + {file = "contourpy-1.2.0-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:8d8faf05be5ec8e02a4d86f616fc2a0322ff4a4ce26c0f09d9f7fb5330a35c95"}, + {file = "contourpy-1.2.0-cp311-cp311-win32.whl", hash = "sha256:67b7f17679fa62ec82b7e3e611c43a016b887bd64fb933b3ae8638583006c6d6"}, + {file = "contourpy-1.2.0-cp311-cp311-win_amd64.whl", hash = "sha256:99ad97258985328b4f207a5e777c1b44a83bfe7cf1f87b99f9c11d4ee477c4de"}, + {file = "contourpy-1.2.0-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:575bcaf957a25d1194903a10bc9f316c136c19f24e0985a2b9b5608bdf5dbfe0"}, + {file = "contourpy-1.2.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:9e6c93b5b2dbcedad20a2f18ec22cae47da0d705d454308063421a3b290d9ea4"}, + {file = "contourpy-1.2.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:464b423bc2a009088f19bdf1f232299e8b6917963e2b7e1d277da5041f33a779"}, + {file = "contourpy-1.2.0-cp312-cp312-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:68ce4788b7d93e47f84edd3f1f95acdcd142ae60bc0e5493bfd120683d2d4316"}, + {file = "contourpy-1.2.0-cp312-cp312-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:3d7d1f8871998cdff5d2ff6a087e5e1780139abe2838e85b0b46b7ae6cc25399"}, + {file = "contourpy-1.2.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6e739530c662a8d6d42c37c2ed52a6f0932c2d4a3e8c1f90692ad0ce1274abe0"}, + {file = "contourpy-1.2.0-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:247b9d16535acaa766d03037d8e8fb20866d054d3c7fbf6fd1f993f11fc60ca0"}, + {file = "contourpy-1.2.0-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:461e3ae84cd90b30f8d533f07d87c00379644205b1d33a5ea03381edc4b69431"}, + {file = "contourpy-1.2.0-cp312-cp312-win32.whl", hash = "sha256:1c2559d6cffc94890b0529ea7eeecc20d6fadc1539273aa27faf503eb4656d8f"}, + {file = "contourpy-1.2.0-cp312-cp312-win_amd64.whl", hash = "sha256:491b1917afdd8638a05b611a56d46587d5a632cabead889a5440f7c638bc6ed9"}, + {file = "contourpy-1.2.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:5fd1810973a375ca0e097dee059c407913ba35723b111df75671a1976efa04bc"}, + {file = "contourpy-1.2.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:999c71939aad2780f003979b25ac5b8f2df651dac7b38fb8ce6c46ba5abe6ae9"}, + {file = "contourpy-1.2.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b7caf9b241464c404613512d5594a6e2ff0cc9cb5615c9475cc1d9b514218ae8"}, + {file = "contourpy-1.2.0-cp39-cp39-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:266270c6f6608340f6c9836a0fb9b367be61dde0c9a9a18d5ece97774105ff3e"}, + {file = "contourpy-1.2.0-cp39-cp39-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:dbd50d0a0539ae2e96e537553aff6d02c10ed165ef40c65b0e27e744a0f10af8"}, + {file = "contourpy-1.2.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:11f8d2554e52f459918f7b8e6aa20ec2a3bce35ce95c1f0ef4ba36fbda306df5"}, + {file = "contourpy-1.2.0-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:ce96dd400486e80ac7d195b2d800b03e3e6a787e2a522bfb83755938465a819e"}, + {file = "contourpy-1.2.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:6d3364b999c62f539cd403f8123ae426da946e142312a514162adb2addd8d808"}, + {file = "contourpy-1.2.0-cp39-cp39-win32.whl", hash = "sha256:1c88dfb9e0c77612febebb6ac69d44a8d81e3dc60f993215425b62c1161353f4"}, + {file = "contourpy-1.2.0-cp39-cp39-win_amd64.whl", hash = "sha256:78e6ad33cf2e2e80c5dfaaa0beec3d61face0fb650557100ee36db808bfa6843"}, + {file = "contourpy-1.2.0-pp39-pypy39_pp73-macosx_10_9_x86_64.whl", hash = "sha256:be16975d94c320432657ad2402f6760990cb640c161ae6da1363051805fa8108"}, + {file = "contourpy-1.2.0-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b95a225d4948b26a28c08307a60ac00fb8671b14f2047fc5476613252a129776"}, + {file = "contourpy-1.2.0-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:0d7e03c0f9a4f90dc18d4e77e9ef4ec7b7bbb437f7f675be8e530d65ae6ef956"}, + {file = "contourpy-1.2.0.tar.gz", hash = "sha256:171f311cb758de7da13fc53af221ae47a5877be5a0843a9fe150818c51ed276a"}, +] + +[package.dependencies] +numpy = ">=1.20,<2.0" + +[package.extras] +bokeh = ["bokeh", "selenium"] +docs = ["furo", "sphinx (>=7.2)", "sphinx-copybutton"] +mypy = ["contourpy[bokeh,docs]", "docutils-stubs", "mypy (==1.6.1)", "types-Pillow"] +test = ["Pillow", "contourpy[test-no-images]", "matplotlib"] +test-no-images = ["pytest", "pytest-cov", "pytest-xdist", "wurlitzer"] + +[[package]] +name = "cycler" +version = "0.12.1" +description = "Composable style cycles" +optional = false +python-versions = ">=3.8" +files = [ + {file = "cycler-0.12.1-py3-none-any.whl", hash = "sha256:85cef7cff222d8644161529808465972e51340599459b8ac3ccbac5a854e0d30"}, + {file = "cycler-0.12.1.tar.gz", hash = "sha256:88bb128f02ba341da8ef447245a9e138fae777f6a23943da4540077d3601eb1c"}, +] + +[package.extras] +docs = ["ipython", "matplotlib", "numpydoc", "sphinx"] +tests = ["pytest", "pytest-cov", "pytest-xdist"] + +[[package]] +name = "fonttools" +version = "4.49.0" +description = "Tools to manipulate font files" +optional = false +python-versions = ">=3.8" +files = [ + {file = "fonttools-4.49.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:d970ecca0aac90d399e458f0b7a8a597e08f95de021f17785fb68e2dc0b99717"}, + {file = "fonttools-4.49.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:ac9a745b7609f489faa65e1dc842168c18530874a5f5b742ac3dd79e26bca8bc"}, + {file = "fonttools-4.49.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:0ba0e00620ca28d4ca11fc700806fd69144b463aa3275e1b36e56c7c09915559"}, + {file = "fonttools-4.49.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:cdee3ab220283057e7840d5fb768ad4c2ebe65bdba6f75d5d7bf47f4e0ed7d29"}, + {file = "fonttools-4.49.0-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:ce7033cb61f2bb65d8849658d3786188afd80f53dad8366a7232654804529532"}, + {file = "fonttools-4.49.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:07bc5ea02bb7bc3aa40a1eb0481ce20e8d9b9642a9536cde0218290dd6085828"}, + {file = "fonttools-4.49.0-cp310-cp310-win32.whl", hash = "sha256:86eef6aab7fd7c6c8545f3ebd00fd1d6729ca1f63b0cb4d621bccb7d1d1c852b"}, + {file = "fonttools-4.49.0-cp310-cp310-win_amd64.whl", hash = "sha256:1fac1b7eebfce75ea663e860e7c5b4a8831b858c17acd68263bc156125201abf"}, + {file = "fonttools-4.49.0-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:edc0cce355984bb3c1d1e89d6a661934d39586bb32191ebff98c600f8957c63e"}, + {file = "fonttools-4.49.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:83a0d9336de2cba86d886507dd6e0153df333ac787377325a39a2797ec529814"}, + {file = "fonttools-4.49.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:36c8865bdb5cfeec88f5028e7e592370a0657b676c6f1d84a2108e0564f90e22"}, + {file = "fonttools-4.49.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:33037d9e56e2562c710c8954d0f20d25b8386b397250d65581e544edc9d6b942"}, + {file = "fonttools-4.49.0-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:8fb022d799b96df3eaa27263e9eea306bd3d437cc9aa981820850281a02b6c9a"}, + {file = "fonttools-4.49.0-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:33c584c0ef7dc54f5dd4f84082eabd8d09d1871a3d8ca2986b0c0c98165f8e86"}, + {file = "fonttools-4.49.0-cp311-cp311-win32.whl", hash = "sha256:cbe61b158deb09cffdd8540dc4a948d6e8f4d5b4f3bf5cd7db09bd6a61fee64e"}, + {file = "fonttools-4.49.0-cp311-cp311-win_amd64.whl", hash = "sha256:fc11e5114f3f978d0cea7e9853627935b30d451742eeb4239a81a677bdee6bf6"}, + {file = "fonttools-4.49.0-cp312-cp312-macosx_10_9_universal2.whl", hash = "sha256:d647a0e697e5daa98c87993726da8281c7233d9d4ffe410812a4896c7c57c075"}, + {file = "fonttools-4.49.0-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:f3bbe672df03563d1f3a691ae531f2e31f84061724c319652039e5a70927167e"}, + {file = "fonttools-4.49.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:bebd91041dda0d511b0d303180ed36e31f4f54b106b1259b69fade68413aa7ff"}, + {file = "fonttools-4.49.0-cp312-cp312-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:4145f91531fd43c50f9eb893faa08399816bb0b13c425667c48475c9f3a2b9b5"}, + {file = "fonttools-4.49.0-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:ea329dafb9670ffbdf4dbc3b0e5c264104abcd8441d56de77f06967f032943cb"}, + {file = "fonttools-4.49.0-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:c076a9e548521ecc13d944b1d261ff3d7825048c338722a4bd126d22316087b7"}, + {file = "fonttools-4.49.0-cp312-cp312-win32.whl", hash = "sha256:b607ea1e96768d13be26d2b400d10d3ebd1456343eb5eaddd2f47d1c4bd00880"}, + {file = "fonttools-4.49.0-cp312-cp312-win_amd64.whl", hash = "sha256:a974c49a981e187381b9cc2c07c6b902d0079b88ff01aed34695ec5360767034"}, + {file = "fonttools-4.49.0-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:b85ec0bdd7bdaa5c1946398cbb541e90a6dfc51df76dfa88e0aaa41b335940cb"}, + {file = "fonttools-4.49.0-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:af20acbe198a8a790618ee42db192eb128afcdcc4e96d99993aca0b60d1faeb4"}, + {file = "fonttools-4.49.0-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:4d418b1fee41a1d14931f7ab4b92dc0bc323b490e41d7a333eec82c9f1780c75"}, + {file = "fonttools-4.49.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b44a52b8e6244b6548851b03b2b377a9702b88ddc21dcaf56a15a0393d425cb9"}, + {file = "fonttools-4.49.0-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:7c7125068e04a70739dad11857a4d47626f2b0bd54de39e8622e89701836eabd"}, + {file = "fonttools-4.49.0-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:29e89d0e1a7f18bc30f197cfadcbef5a13d99806447c7e245f5667579a808036"}, + {file = "fonttools-4.49.0-cp38-cp38-win32.whl", hash = "sha256:9d95fa0d22bf4f12d2fb7b07a46070cdfc19ef5a7b1c98bc172bfab5bf0d6844"}, + {file = "fonttools-4.49.0-cp38-cp38-win_amd64.whl", hash = "sha256:768947008b4dc552d02772e5ebd49e71430a466e2373008ce905f953afea755a"}, + {file = "fonttools-4.49.0-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:08877e355d3dde1c11973bb58d4acad1981e6d1140711230a4bfb40b2b937ccc"}, + {file = "fonttools-4.49.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:fdb54b076f25d6b0f0298dc706acee5052de20c83530fa165b60d1f2e9cbe3cb"}, + {file = "fonttools-4.49.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:0af65c720520710cc01c293f9c70bd69684365c6015cc3671db2b7d807fe51f2"}, + {file = "fonttools-4.49.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:1f255ce8ed7556658f6d23f6afd22a6d9bbc3edb9b96c96682124dc487e1bf42"}, + {file = "fonttools-4.49.0-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:d00af0884c0e65f60dfaf9340e26658836b935052fdd0439952ae42e44fdd2be"}, + {file = "fonttools-4.49.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:263832fae27481d48dfafcc43174644b6706639661e242902ceb30553557e16c"}, + {file = "fonttools-4.49.0-cp39-cp39-win32.whl", hash = "sha256:0404faea044577a01bb82d47a8fa4bc7a54067fa7e324785dd65d200d6dd1133"}, + {file = "fonttools-4.49.0-cp39-cp39-win_amd64.whl", hash = "sha256:b050d362df50fc6e38ae3954d8c29bf2da52be384649ee8245fdb5186b620836"}, + {file = "fonttools-4.49.0-py3-none-any.whl", hash = "sha256:af281525e5dd7fa0b39fb1667b8d5ca0e2a9079967e14c4bfe90fd1cd13e0f18"}, + {file = "fonttools-4.49.0.tar.gz", hash = "sha256:ebf46e7f01b7af7861310417d7c49591a85d99146fc23a5ba82fdb28af156321"}, +] + +[package.extras] +all = ["brotli (>=1.0.1)", "brotlicffi (>=0.8.0)", "fs (>=2.2.0,<3)", "lxml (>=4.0)", "lz4 (>=1.7.4.2)", "matplotlib", "munkres", "pycairo", "scipy", "skia-pathops (>=0.5.0)", "sympy", "uharfbuzz (>=0.23.0)", "unicodedata2 (>=15.1.0)", "xattr", "zopfli (>=0.1.4)"] +graphite = ["lz4 (>=1.7.4.2)"] +interpolatable = ["munkres", "pycairo", "scipy"] +lxml = ["lxml (>=4.0)"] +pathops = ["skia-pathops (>=0.5.0)"] +plot = ["matplotlib"] +repacker = ["uharfbuzz (>=0.23.0)"] +symfont = ["sympy"] +type1 = ["xattr"] +ufo = ["fs (>=2.2.0,<3)"] +unicode = ["unicodedata2 (>=15.1.0)"] +woff = ["brotli (>=1.0.1)", "brotlicffi (>=0.8.0)", "zopfli (>=0.1.4)"] + +[[package]] +name = "importlib-resources" +version = "6.1.2" +description = "Read resources from Python packages" +optional = false +python-versions = ">=3.8" +files = [ + {file = "importlib_resources-6.1.2-py3-none-any.whl", hash = "sha256:9a0a862501dc38b68adebc82970140c9e4209fc99601782925178f8386339938"}, + {file = "importlib_resources-6.1.2.tar.gz", hash = "sha256:308abf8474e2dba5f867d279237cd4076482c3de7104a40b41426370e891549b"}, +] + +[package.dependencies] +zipp = {version = ">=3.1.0", markers = "python_version < \"3.10\""} + +[package.extras] +docs = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "rst.linker (>=1.9)", "sphinx (<7.2.5)", "sphinx (>=3.5)", "sphinx-lint"] +testing = ["pytest (>=6)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=2.2)", "pytest-mypy", "pytest-ruff (>=0.2.1)", "zipp (>=3.17)"] + +[[package]] +name = "kiwisolver" +version = "1.4.5" +description = "A fast implementation of the Cassowary constraint solver" +optional = false +python-versions = ">=3.7" +files = [ + {file = "kiwisolver-1.4.5-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:05703cf211d585109fcd72207a31bb170a0f22144d68298dc5e61b3c946518af"}, + {file = "kiwisolver-1.4.5-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:146d14bebb7f1dc4d5fbf74f8a6cb15ac42baadee8912eb84ac0b3b2a3dc6ac3"}, + {file = "kiwisolver-1.4.5-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:6ef7afcd2d281494c0a9101d5c571970708ad911d028137cd558f02b851c08b4"}, + {file = "kiwisolver-1.4.5-cp310-cp310-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:9eaa8b117dc8337728e834b9c6e2611f10c79e38f65157c4c38e9400286f5cb1"}, + {file = "kiwisolver-1.4.5-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:ec20916e7b4cbfb1f12380e46486ec4bcbaa91a9c448b97023fde0d5bbf9e4ff"}, + {file = "kiwisolver-1.4.5-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:39b42c68602539407884cf70d6a480a469b93b81b7701378ba5e2328660c847a"}, + {file = "kiwisolver-1.4.5-cp310-cp310-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:aa12042de0171fad672b6c59df69106d20d5596e4f87b5e8f76df757a7c399aa"}, + {file = "kiwisolver-1.4.5-cp310-cp310-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:2a40773c71d7ccdd3798f6489aaac9eee213d566850a9533f8d26332d626b82c"}, + {file = "kiwisolver-1.4.5-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:19df6e621f6d8b4b9c4d45f40a66839294ff2bb235e64d2178f7522d9170ac5b"}, + {file = "kiwisolver-1.4.5-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:83d78376d0d4fd884e2c114d0621624b73d2aba4e2788182d286309ebdeed770"}, + {file = "kiwisolver-1.4.5-cp310-cp310-musllinux_1_1_ppc64le.whl", hash = "sha256:e391b1f0a8a5a10ab3b9bb6afcfd74f2175f24f8975fb87ecae700d1503cdee0"}, + {file = "kiwisolver-1.4.5-cp310-cp310-musllinux_1_1_s390x.whl", hash = "sha256:852542f9481f4a62dbb5dd99e8ab7aedfeb8fb6342349a181d4036877410f525"}, + {file = "kiwisolver-1.4.5-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:59edc41b24031bc25108e210c0def6f6c2191210492a972d585a06ff246bb79b"}, + {file = "kiwisolver-1.4.5-cp310-cp310-win32.whl", hash = "sha256:a6aa6315319a052b4ee378aa171959c898a6183f15c1e541821c5c59beaa0238"}, + {file = "kiwisolver-1.4.5-cp310-cp310-win_amd64.whl", hash = "sha256:d0ef46024e6a3d79c01ff13801cb19d0cad7fd859b15037aec74315540acc276"}, + {file = "kiwisolver-1.4.5-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:11863aa14a51fd6ec28688d76f1735f8f69ab1fabf388851a595d0721af042f5"}, + {file = "kiwisolver-1.4.5-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:8ab3919a9997ab7ef2fbbed0cc99bb28d3c13e6d4b1ad36e97e482558a91be90"}, + {file = "kiwisolver-1.4.5-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:fcc700eadbbccbf6bc1bcb9dbe0786b4b1cb91ca0dcda336eef5c2beed37b797"}, + {file = "kiwisolver-1.4.5-cp311-cp311-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:dfdd7c0b105af050eb3d64997809dc21da247cf44e63dc73ff0fd20b96be55a9"}, + {file = "kiwisolver-1.4.5-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:76c6a5964640638cdeaa0c359382e5703e9293030fe730018ca06bc2010c4437"}, + {file = "kiwisolver-1.4.5-cp311-cp311-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:bbea0db94288e29afcc4c28afbf3a7ccaf2d7e027489c449cf7e8f83c6346eb9"}, + {file = "kiwisolver-1.4.5-cp311-cp311-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:ceec1a6bc6cab1d6ff5d06592a91a692f90ec7505d6463a88a52cc0eb58545da"}, + {file = "kiwisolver-1.4.5-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:040c1aebeda72197ef477a906782b5ab0d387642e93bda547336b8957c61022e"}, + {file = "kiwisolver-1.4.5-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:f91de7223d4c7b793867797bacd1ee53bfe7359bd70d27b7b58a04efbb9436c8"}, + {file = "kiwisolver-1.4.5-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:faae4860798c31530dd184046a900e652c95513796ef51a12bc086710c2eec4d"}, + {file = "kiwisolver-1.4.5-cp311-cp311-musllinux_1_1_ppc64le.whl", hash = "sha256:b0157420efcb803e71d1b28e2c287518b8808b7cf1ab8af36718fd0a2c453eb0"}, + {file = "kiwisolver-1.4.5-cp311-cp311-musllinux_1_1_s390x.whl", hash = "sha256:06f54715b7737c2fecdbf140d1afb11a33d59508a47bf11bb38ecf21dc9ab79f"}, + {file = "kiwisolver-1.4.5-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:fdb7adb641a0d13bdcd4ef48e062363d8a9ad4a182ac7647ec88f695e719ae9f"}, + {file = "kiwisolver-1.4.5-cp311-cp311-win32.whl", hash = "sha256:bb86433b1cfe686da83ce32a9d3a8dd308e85c76b60896d58f082136f10bffac"}, + {file = "kiwisolver-1.4.5-cp311-cp311-win_amd64.whl", hash = "sha256:6c08e1312a9cf1074d17b17728d3dfce2a5125b2d791527f33ffbe805200a355"}, + {file = "kiwisolver-1.4.5-cp312-cp312-macosx_10_9_universal2.whl", hash = "sha256:32d5cf40c4f7c7b3ca500f8985eb3fb3a7dfc023215e876f207956b5ea26632a"}, + {file = "kiwisolver-1.4.5-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:f846c260f483d1fd217fe5ed7c173fb109efa6b1fc8381c8b7552c5781756192"}, + {file = "kiwisolver-1.4.5-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:5ff5cf3571589b6d13bfbfd6bcd7a3f659e42f96b5fd1c4830c4cf21d4f5ef45"}, + {file = "kiwisolver-1.4.5-cp312-cp312-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:7269d9e5f1084a653d575c7ec012ff57f0c042258bf5db0954bf551c158466e7"}, + {file = "kiwisolver-1.4.5-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:da802a19d6e15dffe4b0c24b38b3af68e6c1a68e6e1d8f30148c83864f3881db"}, + {file = "kiwisolver-1.4.5-cp312-cp312-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:3aba7311af82e335dd1e36ffff68aaca609ca6290c2cb6d821a39aa075d8e3ff"}, + {file = "kiwisolver-1.4.5-cp312-cp312-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:763773d53f07244148ccac5b084da5adb90bfaee39c197554f01b286cf869228"}, + {file = "kiwisolver-1.4.5-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2270953c0d8cdab5d422bee7d2007f043473f9d2999631c86a223c9db56cbd16"}, + {file = "kiwisolver-1.4.5-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:d099e745a512f7e3bbe7249ca835f4d357c586d78d79ae8f1dcd4d8adeb9bda9"}, + {file = "kiwisolver-1.4.5-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:74db36e14a7d1ce0986fa104f7d5637aea5c82ca6326ed0ec5694280942d1162"}, + {file = "kiwisolver-1.4.5-cp312-cp312-musllinux_1_1_ppc64le.whl", hash = "sha256:7e5bab140c309cb3a6ce373a9e71eb7e4873c70c2dda01df6820474f9889d6d4"}, + {file = "kiwisolver-1.4.5-cp312-cp312-musllinux_1_1_s390x.whl", hash = "sha256:0f114aa76dc1b8f636d077979c0ac22e7cd8f3493abbab152f20eb8d3cda71f3"}, + {file = "kiwisolver-1.4.5-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:88a2df29d4724b9237fc0c6eaf2a1adae0cdc0b3e9f4d8e7dc54b16812d2d81a"}, + {file = "kiwisolver-1.4.5-cp312-cp312-win32.whl", hash = "sha256:72d40b33e834371fd330fb1472ca19d9b8327acb79a5821d4008391db8e29f20"}, + {file = "kiwisolver-1.4.5-cp312-cp312-win_amd64.whl", hash = "sha256:2c5674c4e74d939b9d91dda0fae10597ac7521768fec9e399c70a1f27e2ea2d9"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:3a2b053a0ab7a3960c98725cfb0bf5b48ba82f64ec95fe06f1d06c99b552e130"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3cd32d6c13807e5c66a7cbb79f90b553642f296ae4518a60d8d76243b0ad2898"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:59ec7b7c7e1a61061850d53aaf8e93db63dce0c936db1fda2658b70e4a1be709"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:da4cfb373035def307905d05041c1d06d8936452fe89d464743ae7fb8371078b"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.whl", hash = "sha256:2400873bccc260b6ae184b2b8a4fec0e4082d30648eadb7c3d9a13405d861e89"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.whl", hash = "sha256:1b04139c4236a0f3aff534479b58f6f849a8b351e1314826c2d230849ed48985"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:4e66e81a5779b65ac21764c295087de82235597a2293d18d943f8e9e32746265"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:7931d8f1f67c4be9ba1dd9c451fb0eeca1a25b89e4d3f89e828fe12a519b782a"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-musllinux_1_1_ppc64le.whl", hash = "sha256:b3f7e75f3015df442238cca659f8baa5f42ce2a8582727981cbfa15fee0ee205"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-musllinux_1_1_s390x.whl", hash = "sha256:bbf1d63eef84b2e8c89011b7f2235b1e0bf7dacc11cac9431fc6468e99ac77fb"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:4c380469bd3f970ef677bf2bcba2b6b0b4d5c75e7a020fb863ef75084efad66f"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-win32.whl", hash = "sha256:9408acf3270c4b6baad483865191e3e582b638b1654a007c62e3efe96f09a9a3"}, + {file = "kiwisolver-1.4.5-cp37-cp37m-win_amd64.whl", hash = "sha256:5b94529f9b2591b7af5f3e0e730a4e0a41ea174af35a4fd067775f9bdfeee01a"}, + {file = "kiwisolver-1.4.5-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:11c7de8f692fc99816e8ac50d1d1aef4f75126eefc33ac79aac02c099fd3db71"}, + {file = "kiwisolver-1.4.5-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:53abb58632235cd154176ced1ae8f0d29a6657aa1aa9decf50b899b755bc2b93"}, + {file = "kiwisolver-1.4.5-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:88b9f257ca61b838b6f8094a62418421f87ac2a1069f7e896c36a7d86b5d4c29"}, + {file = "kiwisolver-1.4.5-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3195782b26fc03aa9c6913d5bad5aeb864bdc372924c093b0f1cebad603dd712"}, + {file = "kiwisolver-1.4.5-cp38-cp38-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:fc579bf0f502e54926519451b920e875f433aceb4624a3646b3252b5caa9e0b6"}, + {file = "kiwisolver-1.4.5-cp38-cp38-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:5a580c91d686376f0f7c295357595c5a026e6cbc3d77b7c36e290201e7c11ecb"}, + {file = "kiwisolver-1.4.5-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.whl", hash = "sha256:cfe6ab8da05c01ba6fbea630377b5da2cd9bcbc6338510116b01c1bc939a2c18"}, + {file = "kiwisolver-1.4.5-cp38-cp38-manylinux_2_5_x86_64.manylinux1_x86_64.whl", hash = "sha256:d2e5a98f0ec99beb3c10e13b387f8db39106d53993f498b295f0c914328b1333"}, + {file = "kiwisolver-1.4.5-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:a51a263952b1429e429ff236d2f5a21c5125437861baeed77f5e1cc2d2c7c6da"}, + {file = "kiwisolver-1.4.5-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:3edd2fa14e68c9be82c5b16689e8d63d89fe927e56debd6e1dbce7a26a17f81b"}, + {file = "kiwisolver-1.4.5-cp38-cp38-musllinux_1_1_ppc64le.whl", hash = "sha256:74d1b44c6cfc897df648cc9fdaa09bc3e7679926e6f96df05775d4fb3946571c"}, + {file = "kiwisolver-1.4.5-cp38-cp38-musllinux_1_1_s390x.whl", hash = "sha256:76d9289ed3f7501012e05abb8358bbb129149dbd173f1f57a1bf1c22d19ab7cc"}, + {file = "kiwisolver-1.4.5-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:92dea1ffe3714fa8eb6a314d2b3c773208d865a0e0d35e713ec54eea08a66250"}, + {file = "kiwisolver-1.4.5-cp38-cp38-win32.whl", hash = "sha256:5c90ae8c8d32e472be041e76f9d2f2dbff4d0b0be8bd4041770eddb18cf49a4e"}, + {file = "kiwisolver-1.4.5-cp38-cp38-win_amd64.whl", hash = "sha256:c7940c1dc63eb37a67721b10d703247552416f719c4188c54e04334321351ced"}, + {file = "kiwisolver-1.4.5-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:9407b6a5f0d675e8a827ad8742e1d6b49d9c1a1da5d952a67d50ef5f4170b18d"}, + {file = "kiwisolver-1.4.5-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:15568384086b6df3c65353820a4473575dbad192e35010f622c6ce3eebd57af9"}, + {file = "kiwisolver-1.4.5-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:0dc9db8e79f0036e8173c466d21ef18e1befc02de8bf8aa8dc0813a6dc8a7046"}, + {file = "kiwisolver-1.4.5-cp39-cp39-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:cdc8a402aaee9a798b50d8b827d7ecf75edc5fb35ea0f91f213ff927c15f4ff0"}, + {file = "kiwisolver-1.4.5-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:6c3bd3cde54cafb87d74d8db50b909705c62b17c2099b8f2e25b461882e544ff"}, + {file = "kiwisolver-1.4.5-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:955e8513d07a283056b1396e9a57ceddbd272d9252c14f154d450d227606eb54"}, + {file = "kiwisolver-1.4.5-cp39-cp39-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:346f5343b9e3f00b8db8ba359350eb124b98c99efd0b408728ac6ebf38173958"}, + {file = "kiwisolver-1.4.5-cp39-cp39-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:b9098e0049e88c6a24ff64545cdfc50807818ba6c1b739cae221bbbcbc58aad3"}, + {file = "kiwisolver-1.4.5-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:00bd361b903dc4bbf4eb165f24d1acbee754fce22ded24c3d56eec268658a5cf"}, + {file = "kiwisolver-1.4.5-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:7b8b454bac16428b22560d0a1cf0a09875339cab69df61d7805bf48919415901"}, + {file = "kiwisolver-1.4.5-cp39-cp39-musllinux_1_1_ppc64le.whl", hash = "sha256:f1d072c2eb0ad60d4c183f3fb44ac6f73fb7a8f16a2694a91f988275cbf352f9"}, + {file = "kiwisolver-1.4.5-cp39-cp39-musllinux_1_1_s390x.whl", hash = "sha256:31a82d498054cac9f6d0b53d02bb85811185bcb477d4b60144f915f3b3126342"}, + {file = "kiwisolver-1.4.5-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:6512cb89e334e4700febbffaaa52761b65b4f5a3cf33f960213d5656cea36a77"}, + {file = "kiwisolver-1.4.5-cp39-cp39-win32.whl", hash = "sha256:9db8ea4c388fdb0f780fe91346fd438657ea602d58348753d9fb265ce1bca67f"}, + {file = "kiwisolver-1.4.5-cp39-cp39-win_amd64.whl", hash = "sha256:59415f46a37f7f2efeec758353dd2eae1b07640d8ca0f0c42548ec4125492635"}, + {file = "kiwisolver-1.4.5-pp37-pypy37_pp73-macosx_10_9_x86_64.whl", hash = "sha256:5c7b3b3a728dc6faf3fc372ef24f21d1e3cee2ac3e9596691d746e5a536de920"}, + {file = "kiwisolver-1.4.5-pp37-pypy37_pp73-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:620ced262a86244e2be10a676b646f29c34537d0d9cc8eb26c08f53d98013390"}, + {file = "kiwisolver-1.4.5-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:378a214a1e3bbf5ac4a8708304318b4f890da88c9e6a07699c4ae7174c09a68d"}, + {file = "kiwisolver-1.4.5-pp37-pypy37_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:aaf7be1207676ac608a50cd08f102f6742dbfc70e8d60c4db1c6897f62f71523"}, + {file = "kiwisolver-1.4.5-pp37-pypy37_pp73-win_amd64.whl", hash = "sha256:ba55dce0a9b8ff59495ddd050a0225d58bd0983d09f87cfe2b6aec4f2c1234e4"}, + {file = "kiwisolver-1.4.5-pp38-pypy38_pp73-macosx_10_9_x86_64.whl", hash = "sha256:fd32ea360bcbb92d28933fc05ed09bffcb1704ba3fc7942e81db0fd4f81a7892"}, + {file = "kiwisolver-1.4.5-pp38-pypy38_pp73-manylinux_2_12_i686.manylinux2010_i686.whl", hash = "sha256:5e7139af55d1688f8b960ee9ad5adafc4ac17c1c473fe07133ac092310d76544"}, + {file = "kiwisolver-1.4.5-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:dced8146011d2bc2e883f9bd68618b8247387f4bbec46d7392b3c3b032640126"}, + {file = "kiwisolver-1.4.5-pp38-pypy38_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c9bf3325c47b11b2e51bca0824ea217c7cd84491d8ac4eefd1e409705ef092bd"}, + {file = "kiwisolver-1.4.5-pp38-pypy38_pp73-win_amd64.whl", hash = "sha256:5794cf59533bc3f1b1c821f7206a3617999db9fbefc345360aafe2e067514929"}, + {file = "kiwisolver-1.4.5-pp39-pypy39_pp73-macosx_10_9_x86_64.whl", hash = "sha256:e368f200bbc2e4f905b8e71eb38b3c04333bddaa6a2464a6355487b02bb7fb09"}, + {file = "kiwisolver-1.4.5-pp39-pypy39_pp73-manylinux_2_12_i686.manylinux2010_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:e5d706eba36b4c4d5bc6c6377bb6568098765e990cfc21ee16d13963fab7b3e7"}, + {file = "kiwisolver-1.4.5-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:85267bd1aa8880a9c88a8cb71e18d3d64d2751a790e6ca6c27b8ccc724bcd5ad"}, + {file = "kiwisolver-1.4.5-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:210ef2c3a1f03272649aff1ef992df2e724748918c4bc2d5a90352849eb40bea"}, + {file = "kiwisolver-1.4.5-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:11d011a7574eb3b82bcc9c1a1d35c1d7075677fdd15de527d91b46bd35e935ee"}, + {file = "kiwisolver-1.4.5.tar.gz", hash = "sha256:e57e563a57fb22a142da34f38acc2fc1a5c864bc29ca1517a88abc963e60d6ec"}, +] + +[[package]] +name = "matplotlib" +version = "3.8.3" +description = "Python plotting package" +optional = false +python-versions = ">=3.9" +files = [ + {file = "matplotlib-3.8.3-cp310-cp310-macosx_10_12_x86_64.whl", hash = "sha256:cf60138ccc8004f117ab2a2bad513cc4d122e55864b4fe7adf4db20ca68a078f"}, + {file = "matplotlib-3.8.3-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:5f557156f7116be3340cdeef7f128fa99b0d5d287d5f41a16e169819dcf22357"}, + {file = "matplotlib-3.8.3-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f386cf162b059809ecfac3bcc491a9ea17da69fa35c8ded8ad154cd4b933d5ec"}, + {file = "matplotlib-3.8.3-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b3c5f96f57b0369c288bf6f9b5274ba45787f7e0589a34d24bdbaf6d3344632f"}, + {file = "matplotlib-3.8.3-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:83e0f72e2c116ca7e571c57aa29b0fe697d4c6425c4e87c6e994159e0c008635"}, + {file = "matplotlib-3.8.3-cp310-cp310-win_amd64.whl", hash = "sha256:1c5c8290074ba31a41db1dc332dc2b62def469ff33766cbe325d32a3ee291aea"}, + {file = "matplotlib-3.8.3-cp311-cp311-macosx_10_12_x86_64.whl", hash = "sha256:5184e07c7e1d6d1481862ee361905b7059f7fe065fc837f7c3dc11eeb3f2f900"}, + {file = "matplotlib-3.8.3-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:d7e7e0993d0758933b1a241a432b42c2db22dfa37d4108342ab4afb9557cbe3e"}, + {file = "matplotlib-3.8.3-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:04b36ad07eac9740fc76c2aa16edf94e50b297d6eb4c081e3add863de4bb19a7"}, + {file = "matplotlib-3.8.3-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:7c42dae72a62f14982f1474f7e5c9959fc4bc70c9de11cc5244c6e766200ba65"}, + {file = "matplotlib-3.8.3-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:bf5932eee0d428192c40b7eac1399d608f5d995f975cdb9d1e6b48539a5ad8d0"}, + {file = "matplotlib-3.8.3-cp311-cp311-win_amd64.whl", hash = "sha256:40321634e3a05ed02abf7c7b47a50be50b53ef3eaa3a573847431a545585b407"}, + {file = "matplotlib-3.8.3-cp312-cp312-macosx_10_12_x86_64.whl", hash = "sha256:09074f8057917d17ab52c242fdf4916f30e99959c1908958b1fc6032e2d0f6d4"}, + {file = "matplotlib-3.8.3-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:5745f6d0fb5acfabbb2790318db03809a253096e98c91b9a31969df28ee604aa"}, + {file = "matplotlib-3.8.3-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b97653d869a71721b639714b42d87cda4cfee0ee74b47c569e4874c7590c55c5"}, + {file = "matplotlib-3.8.3-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:242489efdb75b690c9c2e70bb5c6550727058c8a614e4c7716f363c27e10bba1"}, + {file = "matplotlib-3.8.3-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:83c0653c64b73926730bd9ea14aa0f50f202ba187c307a881673bad4985967b7"}, + {file = "matplotlib-3.8.3-cp312-cp312-win_amd64.whl", hash = "sha256:ef6c1025a570354297d6c15f7d0f296d95f88bd3850066b7f1e7b4f2f4c13a39"}, + {file = "matplotlib-3.8.3-cp39-cp39-macosx_10_12_x86_64.whl", hash = "sha256:c4af3f7317f8a1009bbb2d0bf23dfaba859eb7dd4ccbd604eba146dccaaaf0a4"}, + {file = "matplotlib-3.8.3-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:4c6e00a65d017d26009bac6808f637b75ceade3e1ff91a138576f6b3065eeeba"}, + {file = "matplotlib-3.8.3-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e7b49ab49a3bea17802df6872f8d44f664ba8f9be0632a60c99b20b6db2165b7"}, + {file = "matplotlib-3.8.3-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6728dde0a3997396b053602dbd907a9bd64ec7d5cf99e728b404083698d3ca01"}, + {file = "matplotlib-3.8.3-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:813925d08fb86aba139f2d31864928d67511f64e5945ca909ad5bc09a96189bb"}, + {file = "matplotlib-3.8.3-cp39-cp39-win_amd64.whl", hash = "sha256:cd3a0c2be76f4e7be03d34a14d49ded6acf22ef61f88da600a18a5cd8b3c5f3c"}, + {file = "matplotlib-3.8.3-pp39-pypy39_pp73-macosx_10_12_x86_64.whl", hash = "sha256:fa93695d5c08544f4a0dfd0965f378e7afc410d8672816aff1e81be1f45dbf2e"}, + {file = "matplotlib-3.8.3-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:e9764df0e8778f06414b9d281a75235c1e85071f64bb5d71564b97c1306a2afc"}, + {file = "matplotlib-3.8.3-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:5e431a09e6fab4012b01fc155db0ce6dccacdbabe8198197f523a4ef4805eb26"}, + {file = "matplotlib-3.8.3.tar.gz", hash = "sha256:7b416239e9ae38be54b028abbf9048aff5054a9aba5416bef0bd17f9162ce161"}, +] + +[package.dependencies] +contourpy = ">=1.0.1" +cycler = ">=0.10" +fonttools = ">=4.22.0" +importlib-resources = {version = ">=3.2.0", markers = "python_version < \"3.10\""} +kiwisolver = ">=1.3.1" +numpy = ">=1.21,<2" +packaging = ">=20.0" +pillow = ">=8" +pyparsing = ">=2.3.1" +python-dateutil = ">=2.7" + +[[package]] +name = "numpy" +version = "1.26.4" +description = "Fundamental package for array computing in Python" +optional = false +python-versions = ">=3.9" +files = [ + {file = "numpy-1.26.4-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:9ff0f4f29c51e2803569d7a51c2304de5554655a60c5d776e35b4a41413830d0"}, + {file = "numpy-1.26.4-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:2e4ee3380d6de9c9ec04745830fd9e2eccb3e6cf790d39d7b98ffd19b0dd754a"}, + {file = "numpy-1.26.4-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:d209d8969599b27ad20994c8e41936ee0964e6da07478d6c35016bc386b66ad4"}, + {file = "numpy-1.26.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:ffa75af20b44f8dba823498024771d5ac50620e6915abac414251bd971b4529f"}, + {file = "numpy-1.26.4-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:62b8e4b1e28009ef2846b4c7852046736bab361f7aeadeb6a5b89ebec3c7055a"}, + {file = "numpy-1.26.4-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:a4abb4f9001ad2858e7ac189089c42178fcce737e4169dc61321660f1a96c7d2"}, + {file = "numpy-1.26.4-cp310-cp310-win32.whl", hash = "sha256:bfe25acf8b437eb2a8b2d49d443800a5f18508cd811fea3181723922a8a82b07"}, + {file = "numpy-1.26.4-cp310-cp310-win_amd64.whl", hash = "sha256:b97fe8060236edf3662adfc2c633f56a08ae30560c56310562cb4f95500022d5"}, + {file = "numpy-1.26.4-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:4c66707fabe114439db9068ee468c26bbdf909cac0fb58686a42a24de1760c71"}, + {file = "numpy-1.26.4-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:edd8b5fe47dab091176d21bb6de568acdd906d1887a4584a15a9a96a1dca06ef"}, + {file = "numpy-1.26.4-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:7ab55401287bfec946ced39700c053796e7cc0e3acbef09993a9ad2adba6ca6e"}, + {file = "numpy-1.26.4-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:666dbfb6ec68962c033a450943ded891bed2d54e6755e35e5835d63f4f6931d5"}, + {file = "numpy-1.26.4-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:96ff0b2ad353d8f990b63294c8986f1ec3cb19d749234014f4e7eb0112ceba5a"}, + {file = "numpy-1.26.4-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:60dedbb91afcbfdc9bc0b1f3f402804070deed7392c23eb7a7f07fa857868e8a"}, + {file = "numpy-1.26.4-cp311-cp311-win32.whl", hash = "sha256:1af303d6b2210eb850fcf03064d364652b7120803a0b872f5211f5234b399f20"}, + {file = "numpy-1.26.4-cp311-cp311-win_amd64.whl", hash = "sha256:cd25bcecc4974d09257ffcd1f098ee778f7834c3ad767fe5db785be9a4aa9cb2"}, + {file = "numpy-1.26.4-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:b3ce300f3644fb06443ee2222c2201dd3a89ea6040541412b8fa189341847218"}, + {file = "numpy-1.26.4-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:03a8c78d01d9781b28a6989f6fa1bb2c4f2d51201cf99d3dd875df6fbd96b23b"}, + {file = "numpy-1.26.4-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:9fad7dcb1aac3c7f0584a5a8133e3a43eeb2fe127f47e3632d43d677c66c102b"}, + {file = "numpy-1.26.4-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:675d61ffbfa78604709862923189bad94014bef562cc35cf61d3a07bba02a7ed"}, + {file = "numpy-1.26.4-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:ab47dbe5cc8210f55aa58e4805fe224dac469cde56b9f731a4c098b91917159a"}, + {file = "numpy-1.26.4-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:1dda2e7b4ec9dd512f84935c5f126c8bd8b9f2fc001e9f54af255e8c5f16b0e0"}, + {file = "numpy-1.26.4-cp312-cp312-win32.whl", hash = "sha256:50193e430acfc1346175fcbdaa28ffec49947a06918b7b92130744e81e640110"}, + {file = "numpy-1.26.4-cp312-cp312-win_amd64.whl", hash = "sha256:08beddf13648eb95f8d867350f6a018a4be2e5ad54c8d8caed89ebca558b2818"}, + {file = "numpy-1.26.4-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:7349ab0fa0c429c82442a27a9673fc802ffdb7c7775fad780226cb234965e53c"}, + {file = "numpy-1.26.4-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:52b8b60467cd7dd1e9ed082188b4e6bb35aa5cdd01777621a1658910745b90be"}, + {file = "numpy-1.26.4-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:d5241e0a80d808d70546c697135da2c613f30e28251ff8307eb72ba696945764"}, + {file = "numpy-1.26.4-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f870204a840a60da0b12273ef34f7051e98c3b5961b61b0c2c1be6dfd64fbcd3"}, + {file = "numpy-1.26.4-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:679b0076f67ecc0138fd2ede3a8fd196dddc2ad3254069bcb9faf9a79b1cebcd"}, + {file = "numpy-1.26.4-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:47711010ad8555514b434df65f7d7b076bb8261df1ca9bb78f53d3b2db02e95c"}, + {file = "numpy-1.26.4-cp39-cp39-win32.whl", hash = "sha256:a354325ee03388678242a4d7ebcd08b5c727033fcff3b2f536aea978e15ee9e6"}, + {file = "numpy-1.26.4-cp39-cp39-win_amd64.whl", hash = "sha256:3373d5d70a5fe74a2c1bb6d2cfd9609ecf686d47a2d7b1d37a8f3b6bf6003aea"}, + {file = "numpy-1.26.4-pp39-pypy39_pp73-macosx_10_9_x86_64.whl", hash = "sha256:afedb719a9dcfc7eaf2287b839d8198e06dcd4cb5d276a3df279231138e83d30"}, + {file = "numpy-1.26.4-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:95a7476c59002f2f6c590b9b7b998306fba6a5aa646b1e22ddfeaf8f78c3a29c"}, + {file = "numpy-1.26.4-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:7e50d0a0cc3189f9cb0aeb3a6a6af18c16f59f004b866cd2be1c14b36134a4a0"}, + {file = "numpy-1.26.4.tar.gz", hash = "sha256:2a02aba9ed12e4ac4eb3ea9421c420301a0c6460d9830d74a9df87efa4912010"}, +] + +[[package]] +name = "packaging" +version = "23.2" +description = "Core utilities for Python packages" +optional = false +python-versions = ">=3.7" +files = [ + {file = "packaging-23.2-py3-none-any.whl", hash = "sha256:8c491190033a9af7e1d931d0b5dacc2ef47509b34dd0de67ed209b5203fc88c7"}, + {file = "packaging-23.2.tar.gz", hash = "sha256:048fb0e9405036518eaaf48a55953c750c11e1a1b68e0dd1a9d62ed0c092cfc5"}, +] + +[[package]] +name = "pandas" +version = "2.2.1" +description = "Powerful data structures for data analysis, time series, and statistics" +optional = false +python-versions = ">=3.9" +files = [ + {file = "pandas-2.2.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:8df8612be9cd1c7797c93e1c5df861b2ddda0b48b08f2c3eaa0702cf88fb5f88"}, + {file = "pandas-2.2.1-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:0f573ab277252ed9aaf38240f3b54cfc90fff8e5cab70411ee1d03f5d51f3944"}, + {file = "pandas-2.2.1-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f02a3a6c83df4026e55b63c1f06476c9aa3ed6af3d89b4f04ea656ccdaaaa359"}, + {file = "pandas-2.2.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c38ce92cb22a4bea4e3929429aa1067a454dcc9c335799af93ba9be21b6beb51"}, + {file = "pandas-2.2.1-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:c2ce852e1cf2509a69e98358e8458775f89599566ac3775e70419b98615f4b06"}, + {file = "pandas-2.2.1-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:53680dc9b2519cbf609c62db3ed7c0b499077c7fefda564e330286e619ff0dd9"}, + {file = "pandas-2.2.1-cp310-cp310-win_amd64.whl", hash = "sha256:94e714a1cca63e4f5939cdce5f29ba8d415d85166be3441165edd427dc9f6bc0"}, + {file = "pandas-2.2.1-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:f821213d48f4ab353d20ebc24e4faf94ba40d76680642fb7ce2ea31a3ad94f9b"}, + {file = "pandas-2.2.1-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:c70e00c2d894cb230e5c15e4b1e1e6b2b478e09cf27cc593a11ef955b9ecc81a"}, + {file = "pandas-2.2.1-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e97fbb5387c69209f134893abc788a6486dbf2f9e511070ca05eed4b930b1b02"}, + {file = "pandas-2.2.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:101d0eb9c5361aa0146f500773395a03839a5e6ecde4d4b6ced88b7e5a1a6403"}, + {file = "pandas-2.2.1-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:7d2ed41c319c9fb4fd454fe25372028dfa417aacb9790f68171b2e3f06eae8cd"}, + {file = "pandas-2.2.1-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:af5d3c00557d657c8773ef9ee702c61dd13b9d7426794c9dfeb1dc4a0bf0ebc7"}, + {file = "pandas-2.2.1-cp311-cp311-win_amd64.whl", hash = "sha256:06cf591dbaefb6da9de8472535b185cba556d0ce2e6ed28e21d919704fef1a9e"}, + {file = "pandas-2.2.1-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:88ecb5c01bb9ca927ebc4098136038519aa5d66b44671861ffab754cae75102c"}, + {file = "pandas-2.2.1-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:04f6ec3baec203c13e3f8b139fb0f9f86cd8c0b94603ae3ae8ce9a422e9f5bee"}, + {file = "pandas-2.2.1-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:a935a90a76c44fe170d01e90a3594beef9e9a6220021acfb26053d01426f7dc2"}, + {file = "pandas-2.2.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c391f594aae2fd9f679d419e9a4d5ba4bce5bb13f6a989195656e7dc4b95c8f0"}, + {file = "pandas-2.2.1-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:9d1265545f579edf3f8f0cb6f89f234f5e44ba725a34d86535b1a1d38decbccc"}, + {file = "pandas-2.2.1-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:11940e9e3056576ac3244baef2fedade891977bcc1cb7e5cc8f8cc7d603edc89"}, + {file = "pandas-2.2.1-cp312-cp312-win_amd64.whl", hash = "sha256:4acf681325ee1c7f950d058b05a820441075b0dd9a2adf5c4835b9bc056bf4fb"}, + {file = "pandas-2.2.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:9bd8a40f47080825af4317d0340c656744f2bfdb6819f818e6ba3cd24c0e1397"}, + {file = "pandas-2.2.1-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:df0c37ebd19e11d089ceba66eba59a168242fc6b7155cba4ffffa6eccdfb8f16"}, + {file = "pandas-2.2.1-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:739cc70eaf17d57608639e74d63387b0d8594ce02f69e7a0b046f117974b3019"}, + {file = "pandas-2.2.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f9d3558d263073ed95e46f4650becff0c5e1ffe0fc3a015de3c79283dfbdb3df"}, + {file = "pandas-2.2.1-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:4aa1d8707812a658debf03824016bf5ea0d516afdea29b7dc14cf687bc4d4ec6"}, + {file = "pandas-2.2.1-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:76f27a809cda87e07f192f001d11adc2b930e93a2b0c4a236fde5429527423be"}, + {file = "pandas-2.2.1-cp39-cp39-win_amd64.whl", hash = "sha256:1ba21b1d5c0e43416218db63037dbe1a01fc101dc6e6024bcad08123e48004ab"}, + {file = "pandas-2.2.1.tar.gz", hash = "sha256:0ab90f87093c13f3e8fa45b48ba9f39181046e8f3317d3aadb2fffbb1b978572"}, +] + +[package.dependencies] +numpy = [ + {version = ">=1.22.4,<2", markers = "python_version < \"3.11\""}, + {version = ">=1.23.2,<2", markers = "python_version == \"3.11\""}, + {version = ">=1.26.0,<2", markers = "python_version >= \"3.12\""}, +] +python-dateutil = ">=2.8.2" +pytz = ">=2020.1" +tzdata = ">=2022.7" + +[package.extras] +all = ["PyQt5 (>=5.15.9)", "SQLAlchemy (>=2.0.0)", "adbc-driver-postgresql (>=0.8.0)", "adbc-driver-sqlite (>=0.8.0)", "beautifulsoup4 (>=4.11.2)", "bottleneck (>=1.3.6)", "dataframe-api-compat (>=0.1.7)", "fastparquet (>=2022.12.0)", "fsspec (>=2022.11.0)", "gcsfs (>=2022.11.0)", "html5lib (>=1.1)", "hypothesis (>=6.46.1)", "jinja2 (>=3.1.2)", "lxml (>=4.9.2)", "matplotlib (>=3.6.3)", "numba (>=0.56.4)", "numexpr (>=2.8.4)", "odfpy (>=1.4.1)", "openpyxl (>=3.1.0)", "pandas-gbq (>=0.19.0)", "psycopg2 (>=2.9.6)", "pyarrow (>=10.0.1)", "pymysql (>=1.0.2)", "pyreadstat (>=1.2.0)", "pytest (>=7.3.2)", "pytest-xdist (>=2.2.0)", "python-calamine (>=0.1.7)", "pyxlsb (>=1.0.10)", "qtpy (>=2.3.0)", "s3fs (>=2022.11.0)", "scipy (>=1.10.0)", "tables (>=3.8.0)", "tabulate (>=0.9.0)", "xarray (>=2022.12.0)", "xlrd (>=2.0.1)", "xlsxwriter (>=3.0.5)", "zstandard (>=0.19.0)"] +aws = ["s3fs (>=2022.11.0)"] +clipboard = ["PyQt5 (>=5.15.9)", "qtpy (>=2.3.0)"] +compression = ["zstandard (>=0.19.0)"] +computation = ["scipy (>=1.10.0)", "xarray (>=2022.12.0)"] +consortium-standard = ["dataframe-api-compat (>=0.1.7)"] +excel = ["odfpy (>=1.4.1)", "openpyxl (>=3.1.0)", "python-calamine (>=0.1.7)", "pyxlsb (>=1.0.10)", "xlrd (>=2.0.1)", "xlsxwriter (>=3.0.5)"] +feather = ["pyarrow (>=10.0.1)"] +fss = ["fsspec (>=2022.11.0)"] +gcp = ["gcsfs (>=2022.11.0)", "pandas-gbq (>=0.19.0)"] +hdf5 = ["tables (>=3.8.0)"] +html = ["beautifulsoup4 (>=4.11.2)", "html5lib (>=1.1)", "lxml (>=4.9.2)"] +mysql = ["SQLAlchemy (>=2.0.0)", "pymysql (>=1.0.2)"] +output-formatting = ["jinja2 (>=3.1.2)", "tabulate (>=0.9.0)"] +parquet = ["pyarrow (>=10.0.1)"] +performance = ["bottleneck (>=1.3.6)", "numba (>=0.56.4)", "numexpr (>=2.8.4)"] +plot = ["matplotlib (>=3.6.3)"] +postgresql = ["SQLAlchemy (>=2.0.0)", "adbc-driver-postgresql (>=0.8.0)", "psycopg2 (>=2.9.6)"] +pyarrow = ["pyarrow (>=10.0.1)"] +spss = ["pyreadstat (>=1.2.0)"] +sql-other = ["SQLAlchemy (>=2.0.0)", "adbc-driver-postgresql (>=0.8.0)", "adbc-driver-sqlite (>=0.8.0)"] +test = ["hypothesis (>=6.46.1)", "pytest (>=7.3.2)", "pytest-xdist (>=2.2.0)"] +xml = ["lxml (>=4.9.2)"] + +[[package]] +name = "pillow" +version = "10.2.0" +description = "Python Imaging Library (Fork)" +optional = false +python-versions = ">=3.8" +files = [ + {file = "pillow-10.2.0-cp310-cp310-macosx_10_10_x86_64.whl", hash = "sha256:7823bdd049099efa16e4246bdf15e5a13dbb18a51b68fa06d6c1d4d8b99a796e"}, + {file = "pillow-10.2.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:83b2021f2ade7d1ed556bc50a399127d7fb245e725aa0113ebd05cfe88aaf588"}, + {file = "pillow-10.2.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6fad5ff2f13d69b7e74ce5b4ecd12cc0ec530fcee76356cac6742785ff71c452"}, + {file = "pillow-10.2.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:da2b52b37dad6d9ec64e653637a096905b258d2fc2b984c41ae7d08b938a67e4"}, + {file = "pillow-10.2.0-cp310-cp310-manylinux_2_28_aarch64.whl", hash = "sha256:47c0995fc4e7f79b5cfcab1fc437ff2890b770440f7696a3ba065ee0fd496563"}, + {file = "pillow-10.2.0-cp310-cp310-manylinux_2_28_x86_64.whl", hash = "sha256:322bdf3c9b556e9ffb18f93462e5f749d3444ce081290352c6070d014c93feb2"}, + {file = "pillow-10.2.0-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:51f1a1bffc50e2e9492e87d8e09a17c5eea8409cda8d3f277eb6edc82813c17c"}, + {file = "pillow-10.2.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:69ffdd6120a4737710a9eee73e1d2e37db89b620f702754b8f6e62594471dee0"}, + {file = "pillow-10.2.0-cp310-cp310-win32.whl", hash = "sha256:c6dafac9e0f2b3c78df97e79af707cdc5ef8e88208d686a4847bab8266870023"}, + {file = "pillow-10.2.0-cp310-cp310-win_amd64.whl", hash = "sha256:aebb6044806f2e16ecc07b2a2637ee1ef67a11840a66752751714a0d924adf72"}, + {file = "pillow-10.2.0-cp310-cp310-win_arm64.whl", hash = "sha256:7049e301399273a0136ff39b84c3678e314f2158f50f517bc50285fb5ec847ad"}, + {file = "pillow-10.2.0-cp311-cp311-macosx_10_10_x86_64.whl", hash = "sha256:35bb52c37f256f662abdfa49d2dfa6ce5d93281d323a9af377a120e89a9eafb5"}, + {file = "pillow-10.2.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:9c23f307202661071d94b5e384e1e1dc7dfb972a28a2310e4ee16103e66ddb67"}, + {file = "pillow-10.2.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:773efe0603db30c281521a7c0214cad7836c03b8ccff897beae9b47c0b657d61"}, + {file = "pillow-10.2.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:11fa2e5984b949b0dd6d7a94d967743d87c577ff0b83392f17cb3990d0d2fd6e"}, + {file = "pillow-10.2.0-cp311-cp311-manylinux_2_28_aarch64.whl", hash = "sha256:716d30ed977be8b37d3ef185fecb9e5a1d62d110dfbdcd1e2a122ab46fddb03f"}, + {file = "pillow-10.2.0-cp311-cp311-manylinux_2_28_x86_64.whl", hash = "sha256:a086c2af425c5f62a65e12fbf385f7c9fcb8f107d0849dba5839461a129cf311"}, + {file = "pillow-10.2.0-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:c8de2789052ed501dd829e9cae8d3dcce7acb4777ea4a479c14521c942d395b1"}, + {file = "pillow-10.2.0-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:609448742444d9290fd687940ac0b57fb35e6fd92bdb65386e08e99af60bf757"}, + {file = "pillow-10.2.0-cp311-cp311-win32.whl", hash = "sha256:823ef7a27cf86df6597fa0671066c1b596f69eba53efa3d1e1cb8b30f3533068"}, + {file = "pillow-10.2.0-cp311-cp311-win_amd64.whl", hash = "sha256:1da3b2703afd040cf65ec97efea81cfba59cdbed9c11d8efc5ab09df9509fc56"}, + {file = "pillow-10.2.0-cp311-cp311-win_arm64.whl", hash = "sha256:edca80cbfb2b68d7b56930b84a0e45ae1694aeba0541f798e908a49d66b837f1"}, + {file = "pillow-10.2.0-cp312-cp312-macosx_10_10_x86_64.whl", hash = "sha256:1b5e1b74d1bd1b78bc3477528919414874748dd363e6272efd5abf7654e68bef"}, + {file = "pillow-10.2.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:0eae2073305f451d8ecacb5474997c08569fb4eb4ac231ffa4ad7d342fdc25ac"}, + {file = "pillow-10.2.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b7c2286c23cd350b80d2fc9d424fc797575fb16f854b831d16fd47ceec078f2c"}, + {file = "pillow-10.2.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:1e23412b5c41e58cec602f1135c57dfcf15482013ce6e5f093a86db69646a5aa"}, + {file = "pillow-10.2.0-cp312-cp312-manylinux_2_28_aarch64.whl", hash = "sha256:52a50aa3fb3acb9cf7213573ef55d31d6eca37f5709c69e6858fe3bc04a5c2a2"}, + {file = "pillow-10.2.0-cp312-cp312-manylinux_2_28_x86_64.whl", hash = "sha256:127cee571038f252a552760076407f9cff79761c3d436a12af6000cd182a9d04"}, + {file = "pillow-10.2.0-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:8d12251f02d69d8310b046e82572ed486685c38f02176bd08baf216746eb947f"}, + {file = "pillow-10.2.0-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:54f1852cd531aa981bc0965b7d609f5f6cc8ce8c41b1139f6ed6b3c54ab82bfb"}, + {file = "pillow-10.2.0-cp312-cp312-win32.whl", hash = "sha256:257d8788df5ca62c980314053197f4d46eefedf4e6175bc9412f14412ec4ea2f"}, + {file = "pillow-10.2.0-cp312-cp312-win_amd64.whl", hash = "sha256:154e939c5f0053a383de4fd3d3da48d9427a7e985f58af8e94d0b3c9fcfcf4f9"}, + {file = "pillow-10.2.0-cp312-cp312-win_arm64.whl", hash = "sha256:f379abd2f1e3dddb2b61bc67977a6b5a0a3f7485538bcc6f39ec76163891ee48"}, + {file = "pillow-10.2.0-cp38-cp38-macosx_10_10_x86_64.whl", hash = "sha256:8373c6c251f7ef8bda6675dd6d2b3a0fcc31edf1201266b5cf608b62a37407f9"}, + {file = "pillow-10.2.0-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:870ea1ada0899fd0b79643990809323b389d4d1d46c192f97342eeb6ee0b8483"}, + {file = "pillow-10.2.0-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b4b6b1e20608493548b1f32bce8cca185bf0480983890403d3b8753e44077129"}, + {file = "pillow-10.2.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3031709084b6e7852d00479fd1d310b07d0ba82765f973b543c8af5061cf990e"}, + {file = "pillow-10.2.0-cp38-cp38-manylinux_2_28_aarch64.whl", hash = "sha256:3ff074fc97dd4e80543a3e91f69d58889baf2002b6be64347ea8cf5533188213"}, + {file = "pillow-10.2.0-cp38-cp38-manylinux_2_28_x86_64.whl", hash = "sha256:cb4c38abeef13c61d6916f264d4845fab99d7b711be96c326b84df9e3e0ff62d"}, + {file = "pillow-10.2.0-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:b1b3020d90c2d8e1dae29cf3ce54f8094f7938460fb5ce8bc5c01450b01fbaf6"}, + {file = "pillow-10.2.0-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:170aeb00224ab3dc54230c797f8404507240dd868cf52066f66a41b33169bdbe"}, + {file = "pillow-10.2.0-cp38-cp38-win32.whl", hash = "sha256:c4225f5220f46b2fde568c74fca27ae9771536c2e29d7c04f4fb62c83275ac4e"}, + {file = "pillow-10.2.0-cp38-cp38-win_amd64.whl", hash = "sha256:0689b5a8c5288bc0504d9fcee48f61a6a586b9b98514d7d29b840143d6734f39"}, + {file = "pillow-10.2.0-cp39-cp39-macosx_10_10_x86_64.whl", hash = "sha256:b792a349405fbc0163190fde0dc7b3fef3c9268292586cf5645598b48e63dc67"}, + {file = "pillow-10.2.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:c570f24be1e468e3f0ce7ef56a89a60f0e05b30a3669a459e419c6eac2c35364"}, + {file = "pillow-10.2.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:d8ecd059fdaf60c1963c58ceb8997b32e9dc1b911f5da5307aab614f1ce5c2fb"}, + {file = "pillow-10.2.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c365fd1703040de1ec284b176d6af5abe21b427cb3a5ff68e0759e1e313a5e7e"}, + {file = "pillow-10.2.0-cp39-cp39-manylinux_2_28_aarch64.whl", hash = "sha256:70c61d4c475835a19b3a5aa42492409878bbca7438554a1f89d20d58a7c75c01"}, + {file = "pillow-10.2.0-cp39-cp39-manylinux_2_28_x86_64.whl", hash = "sha256:b6f491cdf80ae540738859d9766783e3b3c8e5bd37f5dfa0b76abdecc5081f13"}, + {file = "pillow-10.2.0-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:9d189550615b4948f45252d7f005e53c2040cea1af5b60d6f79491a6e147eef7"}, + {file = "pillow-10.2.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:49d9ba1ed0ef3e061088cd1e7538a0759aab559e2e0a80a36f9fd9d8c0c21591"}, + {file = "pillow-10.2.0-cp39-cp39-win32.whl", hash = "sha256:babf5acfede515f176833ed6028754cbcd0d206f7f614ea3447d67c33be12516"}, + {file = "pillow-10.2.0-cp39-cp39-win_amd64.whl", hash = "sha256:0304004f8067386b477d20a518b50f3fa658a28d44e4116970abfcd94fac34a8"}, + {file = "pillow-10.2.0-cp39-cp39-win_arm64.whl", hash = "sha256:0fb3e7fc88a14eacd303e90481ad983fd5b69c761e9e6ef94c983f91025da869"}, + {file = "pillow-10.2.0-pp310-pypy310_pp73-macosx_10_10_x86_64.whl", hash = "sha256:322209c642aabdd6207517e9739c704dc9f9db943015535783239022002f054a"}, + {file = "pillow-10.2.0-pp310-pypy310_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:3eedd52442c0a5ff4f887fab0c1c0bb164d8635b32c894bc1faf4c618dd89df2"}, + {file = "pillow-10.2.0-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:cb28c753fd5eb3dd859b4ee95de66cc62af91bcff5db5f2571d32a520baf1f04"}, + {file = "pillow-10.2.0-pp310-pypy310_pp73-manylinux_2_28_aarch64.whl", hash = "sha256:33870dc4653c5017bf4c8873e5488d8f8d5f8935e2f1fb9a2208c47cdd66efd2"}, + {file = "pillow-10.2.0-pp310-pypy310_pp73-manylinux_2_28_x86_64.whl", hash = "sha256:3c31822339516fb3c82d03f30e22b1d038da87ef27b6a78c9549888f8ceda39a"}, + {file = "pillow-10.2.0-pp310-pypy310_pp73-win_amd64.whl", hash = "sha256:a2b56ba36e05f973d450582fb015594aaa78834fefe8dfb8fcd79b93e64ba4c6"}, + {file = "pillow-10.2.0-pp38-pypy38_pp73-win_amd64.whl", hash = "sha256:d8e6aeb9201e655354b3ad049cb77d19813ad4ece0df1249d3c793de3774f8c7"}, + {file = "pillow-10.2.0-pp39-pypy39_pp73-macosx_10_10_x86_64.whl", hash = "sha256:2247178effb34a77c11c0e8ac355c7a741ceca0a732b27bf11e747bbc950722f"}, + {file = "pillow-10.2.0-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:15587643b9e5eb26c48e49a7b33659790d28f190fc514a322d55da2fb5c2950e"}, + {file = "pillow-10.2.0-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:753cd8f2086b2b80180d9b3010dd4ed147efc167c90d3bf593fe2af21265e5a5"}, + {file = "pillow-10.2.0-pp39-pypy39_pp73-manylinux_2_28_aarch64.whl", hash = "sha256:7c8f97e8e7a9009bcacbe3766a36175056c12f9a44e6e6f2d5caad06dcfbf03b"}, + {file = "pillow-10.2.0-pp39-pypy39_pp73-manylinux_2_28_x86_64.whl", hash = "sha256:d1b35bcd6c5543b9cb547dee3150c93008f8dd0f1fef78fc0cd2b141c5baf58a"}, + {file = "pillow-10.2.0-pp39-pypy39_pp73-win_amd64.whl", hash = "sha256:fe4c15f6c9285dc54ce6553a3ce908ed37c8f3825b5a51a15c91442bb955b868"}, + {file = "pillow-10.2.0.tar.gz", hash = "sha256:e87f0b2c78157e12d7686b27d63c070fd65d994e8ddae6f328e0dcf4a0cd007e"}, +] + +[package.extras] +docs = ["furo", "olefile", "sphinx (>=2.4)", "sphinx-copybutton", "sphinx-inline-tabs", "sphinx-removed-in", "sphinxext-opengraph"] +fpx = ["olefile"] +mic = ["olefile"] +tests = ["check-manifest", "coverage", "defusedxml", "markdown2", "olefile", "packaging", "pyroma", "pytest", "pytest-cov", "pytest-timeout"] +typing = ["typing-extensions"] +xmp = ["defusedxml"] + +[[package]] +name = "pyparsing" +version = "3.1.1" +description = "pyparsing module - Classes and methods to define and execute parsing grammars" +optional = false +python-versions = ">=3.6.8" +files = [ + {file = "pyparsing-3.1.1-py3-none-any.whl", hash = "sha256:32c7c0b711493c72ff18a981d24f28aaf9c1fb7ed5e9667c9e84e3db623bdbfb"}, + {file = "pyparsing-3.1.1.tar.gz", hash = "sha256:ede28a1a32462f5a9705e07aea48001a08f7cf81a021585011deba701581a0db"}, +] + +[package.extras] +diagrams = ["jinja2", "railroad-diagrams"] + +[[package]] +name = "python-dateutil" +version = "2.9.0.post0" +description = "Extensions to the standard Python datetime module" +optional = false +python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,>=2.7" +files = [ + {file = "python-dateutil-2.9.0.post0.tar.gz", hash = "sha256:37dd54208da7e1cd875388217d5e00ebd4179249f90fb72437e91a35459a0ad3"}, + {file = "python_dateutil-2.9.0.post0-py2.py3-none-any.whl", hash = "sha256:a8b2bc7bffae282281c8140a97d3aa9c14da0b136dfe83f850eea9a5f7470427"}, +] + +[package.dependencies] +six = ">=1.5" + +[[package]] +name = "pytz" +version = "2024.1" +description = "World timezone definitions, modern and historical" +optional = false +python-versions = "*" +files = [ + {file = "pytz-2024.1-py2.py3-none-any.whl", hash = "sha256:328171f4e3623139da4983451950b28e95ac706e13f3f2630a879749e7a8b319"}, + {file = "pytz-2024.1.tar.gz", hash = "sha256:2a29735ea9c18baf14b448846bde5a48030ed267578472d8955cd0e7443a9812"}, +] + +[[package]] +name = "scipy" +version = "1.12.0" +description = "Fundamental algorithms for scientific computing in Python" +optional = false +python-versions = ">=3.9" +files = [ + {file = "scipy-1.12.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:78e4402e140879387187f7f25d91cc592b3501a2e51dfb320f48dfb73565f10b"}, + {file = "scipy-1.12.0-cp310-cp310-macosx_12_0_arm64.whl", hash = "sha256:f5f00ebaf8de24d14b8449981a2842d404152774c1a1d880c901bf454cb8e2a1"}, + {file = "scipy-1.12.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e53958531a7c695ff66c2e7bb7b79560ffdc562e2051644c5576c39ff8efb563"}, + {file = "scipy-1.12.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:5e32847e08da8d895ce09d108a494d9eb78974cf6de23063f93306a3e419960c"}, + {file = "scipy-1.12.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:4c1020cad92772bf44b8e4cdabc1df5d87376cb219742549ef69fc9fd86282dd"}, + {file = "scipy-1.12.0-cp310-cp310-win_amd64.whl", hash = "sha256:75ea2a144096b5e39402e2ff53a36fecfd3b960d786b7efd3c180e29c39e53f2"}, + {file = "scipy-1.12.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:408c68423f9de16cb9e602528be4ce0d6312b05001f3de61fe9ec8b1263cad08"}, + {file = "scipy-1.12.0-cp311-cp311-macosx_12_0_arm64.whl", hash = "sha256:5adfad5dbf0163397beb4aca679187d24aec085343755fcdbdeb32b3679f254c"}, + {file = "scipy-1.12.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c3003652496f6e7c387b1cf63f4bb720951cfa18907e998ea551e6de51a04467"}, + {file = "scipy-1.12.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:8b8066bce124ee5531d12a74b617d9ac0ea59245246410e19bca549656d9a40a"}, + {file = "scipy-1.12.0-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:8bee4993817e204d761dba10dbab0774ba5a8612e57e81319ea04d84945375ba"}, + {file = "scipy-1.12.0-cp311-cp311-win_amd64.whl", hash = "sha256:a24024d45ce9a675c1fb8494e8e5244efea1c7a09c60beb1eeb80373d0fecc70"}, + {file = "scipy-1.12.0-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:e7e76cc48638228212c747ada851ef355c2bb5e7f939e10952bc504c11f4e372"}, + {file = "scipy-1.12.0-cp312-cp312-macosx_12_0_arm64.whl", hash = "sha256:f7ce148dffcd64ade37b2df9315541f9adad6efcaa86866ee7dd5db0c8f041c3"}, + {file = "scipy-1.12.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:9c39f92041f490422924dfdb782527a4abddf4707616e07b021de33467f917bc"}, + {file = "scipy-1.12.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a7ebda398f86e56178c2fa94cad15bf457a218a54a35c2a7b4490b9f9cb2676c"}, + {file = "scipy-1.12.0-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:95e5c750d55cf518c398a8240571b0e0782c2d5a703250872f36eaf737751338"}, + {file = "scipy-1.12.0-cp312-cp312-win_amd64.whl", hash = "sha256:e646d8571804a304e1da01040d21577685ce8e2db08ac58e543eaca063453e1c"}, + {file = "scipy-1.12.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:913d6e7956c3a671de3b05ccb66b11bc293f56bfdef040583a7221d9e22a2e35"}, + {file = "scipy-1.12.0-cp39-cp39-macosx_12_0_arm64.whl", hash = "sha256:bba1b0c7256ad75401c73e4b3cf09d1f176e9bd4248f0d3112170fb2ec4db067"}, + {file = "scipy-1.12.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:730badef9b827b368f351eacae2e82da414e13cf8bd5051b4bdfd720271a5371"}, + {file = "scipy-1.12.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6546dc2c11a9df6926afcbdd8a3edec28566e4e785b915e849348c6dd9f3f490"}, + {file = "scipy-1.12.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:196ebad3a4882081f62a5bf4aeb7326aa34b110e533aab23e4374fcccb0890dc"}, + {file = "scipy-1.12.0-cp39-cp39-win_amd64.whl", hash = "sha256:b360f1b6b2f742781299514e99ff560d1fe9bd1bff2712894b52abe528d1fd1e"}, + {file = "scipy-1.12.0.tar.gz", hash = "sha256:4bf5abab8a36d20193c698b0f1fc282c1d083c94723902c447e5d2f1780936a3"}, +] + +[package.dependencies] +numpy = ">=1.22.4,<1.29.0" + +[package.extras] +dev = ["click", "cython-lint (>=0.12.2)", "doit (>=0.36.0)", "mypy", "pycodestyle", "pydevtool", "rich-click", "ruff", "types-psutil", "typing_extensions"] +doc = ["jupytext", "matplotlib (>2)", "myst-nb", "numpydoc", "pooch", "pydata-sphinx-theme (==0.9.0)", "sphinx (!=4.1.0)", "sphinx-design (>=0.2.0)"] +test = ["asv", "gmpy2", "hypothesis", "mpmath", "pooch", "pytest", "pytest-cov", "pytest-timeout", "pytest-xdist", "scikit-umfpack", "threadpoolctl"] + +[[package]] +name = "six" +version = "1.16.0" +description = "Python 2 and 3 compatibility utilities" +optional = false +python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*" +files = [ + {file = "six-1.16.0-py2.py3-none-any.whl", hash = "sha256:8abb2f1d86890a2dfb989f9a77cfcfd3e47c2a354b01111771326f8aa26e0254"}, + {file = "six-1.16.0.tar.gz", hash = "sha256:1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926"}, +] + +[[package]] +name = "tzdata" +version = "2024.1" +description = "Provider of IANA time zone data" +optional = false +python-versions = ">=2" +files = [ + {file = "tzdata-2024.1-py2.py3-none-any.whl", hash = "sha256:9068bc196136463f5245e51efda838afa15aaeca9903f49050dfa2679db4d252"}, + {file = "tzdata-2024.1.tar.gz", hash = "sha256:2674120f8d891909751c38abcdfd386ac0a5a1127954fbc332af6b5ceae07efd"}, +] + +[[package]] +name = "zipp" +version = "3.17.0" +description = "Backport of pathlib-compatible object wrapper for zip files" +optional = false +python-versions = ">=3.8" +files = [ + {file = "zipp-3.17.0-py3-none-any.whl", hash = "sha256:0e923e726174922dce09c53c59ad483ff7bbb8e572e00c7f7c46b88556409f31"}, + {file = "zipp-3.17.0.tar.gz", hash = "sha256:84e64a1c28cf7e91ed2078bb8cc8c259cb19b76942096c8d7b84947690cabaf0"}, +] + +[package.extras] +docs = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "rst.linker (>=1.9)", "sphinx (<7.2.5)", "sphinx (>=3.5)", "sphinx-lint"] +testing = ["big-O", "jaraco.functools", "jaraco.itertools", "more-itertools", "pytest (>=6)", "pytest-black (>=0.3.7)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=2.2)", "pytest-ignore-flaky", "pytest-mypy (>=0.9.1)", "pytest-ruff"] + +[metadata] +lock-version = "2.0" +python-versions = "^3.9" +content-hash = "527a5f40d8b7cb9a0a3b518c75edb514bced606226ace5e9fe6071395b6f8d89" diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 0000000..7c432d5 --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,17 @@ +[tool.poetry] +name = "dyco" +version = "1.1.2" +description = "Dynamic lag compensation" +authors = ["Lukas Hörtnagl "] +readme = "README.md" + +[tool.poetry.dependencies] +python = "^3.9" +pandas = "^2.2.1" +matplotlib = "^3.8.3" +scipy = "^1.12.0" + + +[build-system] +requires = ["poetry-core"] +build-backend = "poetry.core.masonry.api" diff --git a/requirements.txt b/requirements.txt deleted file mode 100644 index 22715b6..0000000 --- a/requirements.txt +++ /dev/null @@ -1,82 +0,0 @@ -astroid==2.4.2 -atomicwrites==1.4.0 -attrs==19.3.0 -bleach==3.1.5 -Brotli==1.0.7 -brotlipy==0.7.0 -certifi==2020.6.20 -cffi==1.14.0 -chardet==3.0.4 -click==7.1.2 -colorama==0.4.3 -cryptography==2.8 -cycler==0.10.0 -dash==1.12.0 -dash-core-components==1.10.0 -dash-html-components==1.0.3 -dash-renderer==1.4.1 -dash-table==4.7.0 -docutils==0.16 -dyco==1.0.2 -entrypoints==0.3 -Flask==1.1.2 -Flask-Compress==1.5.0 -future==0.18.2 -idna==2.9 -importlib-metadata==1.6.0 -isort==4.3.21 -itsdangerous==1.1.0 -Jinja2==2.11.2 -jsonschema==3.2.0 -keyring==21.2.1 -kiwisolver==1.1.0 -lazy-object-proxy==1.4.3 -MarkupSafe==1.1.1 -matplotlib==3.1.3 -mccabe==0.6.1 -mkl-fft==1.0.15 -mkl-random==1.1.0 -mkl-service==2.3.0 -more-itertools==8.4.0 -numpy==1.18.1 -packaging==20.4 -pandas==1.0.3 -pkginfo==1.5.0.1 -plotly==4.8.0 -pluggy==0.13.1 -portpicker==1.3.1 -py==1.9.0 -pycparser==2.20 -Pygments==2.6.1 -pylint==2.5.3 -pyOpenSSL==19.1.0 -pyparsing==2.4.6 -pyrsistent==0.16.0 -PySocks==1.7.1 -pytest==5.4.3 -python-dateutil==2.8.1 -pytz==2019.3 -pywin32-ctypes==0.2.0 -readme-renderer==26.0 -requests==2.24.0 -requests-toolbelt==0.9.1 -retrying==1.3.3 -rfc3986==1.4.0 -scipy==1.4.1 -selenium==3.141.0 -six==1.14.0 -toml==0.10.1 -toolz==0.10.0 -tornado==6.0.4 -tqdm==4.47.0 -twine==3.2.0 -typed-ast==1.4.1 -urllib3==1.25.9 -vega-datasets==0.8.0 -wcwidth==0.2.5 -webencodings==0.5.1 -Werkzeug==1.0.1 -win-inet-pton==1.1.0 -wincertstore==0.2 -wrapt==1.11.2 -zipp==3.1.0 diff --git a/setup.py b/setup.py index 68fd4ce..c5c163d 100644 --- a/setup.py +++ b/setup.py @@ -1,6 +1,6 @@ """ DYCO Dynamic Lag Compensation - Copyright (C) 2020 holukas + Copyright (C) 2020-2024 Lukas Hörtnagl This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,7 +13,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program. If not, see . + along with this program. If not, see . """ import setuptools From 1265446db3e8271558c16c9ef720d2bf558185e3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20H=C3=B6rtnagl?= Date: Mon, 4 Mar 2024 12:44:27 +0100 Subject: [PATCH 2/6] Prepare example with kwargs --- .idea/workspace.xml | 21 +-------- dyco/cli.py | 4 +- dyco/files.py | 4 +- example/{example.py => example_cli.py} | 0 example/example_kwargs.py | 62 ++++++++++++++++++++++++++ 5 files changed, 67 insertions(+), 24 deletions(-) rename example/{example.py => example_cli.py} (100%) create mode 100644 example/example_kwargs.py diff --git a/.idea/workspace.xml b/.idea/workspace.xml index a69c2b3..ebcca21 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -5,27 +5,8 @@ - - - - - - - - - - - - - - - - - - - diff --git a/dyco/cli.py b/dyco/cli.py index 2b75890..f219097 100644 --- a/dyco/cli.py +++ b/dyco/cli.py @@ -43,7 +43,7 @@ def validate_args(args): def get_args(): """Get args from CLI input""" - parser = argparse.ArgumentParser(description="BICO - Conversion of ETH binary files to ASCII", + parser = argparse.ArgumentParser(description="dyco - dynamic lag compensation", formatter_class=argparse.ArgumentDefaultsHelpFormatter) # Positional args @@ -62,7 +62,7 @@ def get_args(): # Optional args parser.add_argument('-i', '--indir', type=Path, - help="Path to the source folder that contains the data files, e.g. 'C:/bico/input'") + help="Path to the source folder that contains the data files, e.g. 'C:/dyco/input'") parser.add_argument('-o', '--outdir', type=Path, help="Path to output folder, e.g. C:/bico/output") parser.add_argument('-fnd', '--filenamedateformat', type=str, default='%Y%m%d%H%M%S', diff --git a/dyco/files.py b/dyco/files.py index 83563e2..5c5011a 100644 --- a/dyco/files.py +++ b/dyco/files.py @@ -47,7 +47,7 @@ def read_segment_lagtimes_file(filepath): # na_values=-9999, encoding='utf-8', delimiter=',', - mangle_dupe_cols=True, + # mangle_dupe_cols=True, # keep_date_col=False, parse_dates=False, # date_parser=parse, @@ -112,7 +112,7 @@ def read_raw_data(filepath, data_timestamp_format): na_values=-9999, encoding='utf-8', delimiter=',', - mangle_dupe_cols=True, + # mangle_dupe_cols=True, keep_date_col=False, parse_dates=parse_dates, date_parser=date_parser, diff --git a/example/example.py b/example/example_cli.py similarity index 100% rename from example/example.py rename to example/example_cli.py diff --git a/example/example_kwargs.py b/example/example_kwargs.py new file mode 100644 index 0000000..3d4bae5 --- /dev/null +++ b/example/example_kwargs.py @@ -0,0 +1,62 @@ +""" +Example settings + +DYCO can be run using keyword arguments. + +For an overview of arguments see here: +https://github.com/holukas/dyco/wiki/Usage +""" + +import os + +from dyco.dyco import DynamicLagCompensation + +cli = r'python "F:\Sync\luhk_work\20 - CODING\27 - VARIOUS\dyco\dyco\dyco.py" ' \ + r'w_ms-1_rot_turb co2_ppb_qcl_turb ' \ + r'co2_ppb_qcl_turb n2o_ppb_qcl ch4_ppb_qcl ' \ + r'-i F:\TMP\das\input_data ' \ + r'-o F:\TMP\das ' \ + r'-fnd %Y%m%d%H%M%S ' \ + r'-fnp *.csv ' \ + r'-flim 0 ' \ + r'-fgr 30T ' \ + r'-fdur 30T ' \ + r'-dtf "%Y-%m-%d %H:%M:%S.%f" ' \ + r'-dres 0.05 ' \ + r'-lss 30T ' \ + r'-lsw 1000 ' \ + r'-lsi 3 ' \ + r'-lsf 1 ' \ + r'-lsp 0.9 ' \ + r'-lt 0 ' \ + r'-del 0' +print(cli) +os.system(cli) + + +def main(args): + """Main function that is called with the given args when the script + is executed from the command line.""" + DynamicLagCompensation(var_reference='w_ms-1_rot_turb', + var_lagged='co2_ppb_qcl_turb', + var_target=['co2_ppb_qcl_turb', 'n2o_ppb_qcl', 'ch4_ppb_qcl'], + indir=r'F:\TMP\das\input_data', + outdir=r'F:\TMP\das', + fnm_date_format='%Y%m%d%H%M%S', + fnm_pattern='*.csv', + files_how_many=0, + file_generation_res='30T', + file_duration='30T', + dat_recs_timestamp_format="%Y-%m-%d %H:%M:%S.%f", + dat_recs_nominal_timeres=0.05, + lgs_segment_dur='30T', + lgs_winsize=1000, + lgs_num_iter=3, + lgs_hist_remove_fringe_bins=True, + lgs_hist_perc_thres=0.9, + target_lag=0, + del_previous_results=True) + + +if __name__ == '__main__': + main() From 3d9f0b2e967791b312b7872545f4c2281351c6c4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20H=C3=B6rtnagl?= Date: Wed, 6 Mar 2024 19:43:28 +0100 Subject: [PATCH 3/6] Refactored code for new package versions --- .idea/inspectionProfiles/Project_Default.xml | 5 + .idea/workspace.xml | 114 +++++++++++-------- dyco/analyze.py | 14 ++- dyco/correction.py | 8 +- dyco/dyco.py | 30 +++-- dyco/files.py | 13 ++- dyco/lag.py | 12 +- dyco/loop.py | 37 ++++-- dyco/plot.py | 8 +- dyco/setup_dyco.py | 7 +- example/example_kwargs.py | 34 +----- 11 files changed, 157 insertions(+), 125 deletions(-) diff --git a/.idea/inspectionProfiles/Project_Default.xml b/.idea/inspectionProfiles/Project_Default.xml index c2836d8..b8bca9a 100644 --- a/.idea/inspectionProfiles/Project_Default.xml +++ b/.idea/inspectionProfiles/Project_Default.xml @@ -99,5 +99,10 @@ + + \ No newline at end of file diff --git a/.idea/workspace.xml b/.idea/workspace.xml index ebcca21..3d100e6 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -5,8 +5,14 @@ + - + + + + + + \ No newline at end of file diff --git a/dyco/analyze.py b/dyco/analyze.py index 662bf96..8b374fd 100644 --- a/dyco/analyze.py +++ b/dyco/analyze.py @@ -99,18 +99,18 @@ def plot_final_instantaneous_lagtimes(outdir, phase, df): # Accepted reference lags ax.plot_date(pd.to_datetime(df.index), df['INSTANTANEOUS_LAG'], - alpha=1, marker='o', ms=6, color='black', lw=0, ls='-', + alpha=1, fmt='o', ms=6, color='black', lw=0, ls='-', label=f'final reference time lag (absolute limit {abs_limit})', markeredgecolor='None', zorder=100) # Found lags in Phase 3 ax.plot_date(pd.to_datetime(df.index), df['PEAK-COVABSMAX_SHIFT'], - alpha=1, marker='o', ms=12, color='#FFC107', lw=0, ls='-', markeredgecolor='None', zorder=99, + alpha=1, fmt='o', ms=12, color='#FFC107', lw=0, ls='-', markeredgecolor='None', zorder=99, label=f'found Phase 3 time lag (search between {lagsearch_start} and {lagsearch_end})') # Marks lags that were outside limit and therefore set to the default lag set_to_default_lags = df.loc[df['SET_TO_DEFAULT'] == True, ['INSTANTANEOUS_LAG']] ax.plot_date(pd.to_datetime(set_to_default_lags.index), set_to_default_lags['INSTANTANEOUS_LAG'], - alpha=1, marker='o', ms=12, color='#8BC34A', lw=0, ls='-', markeredgecolor='None', zorder=99, + alpha=1, fmt='o', ms=12, color='#8BC34A', lw=0, ls='-', markeredgecolor='None', zorder=99, label=f'found Phase 3 time lag was set to default') plot.default_format(ax=ax, label_color='black', fontsize=12, @@ -337,6 +337,8 @@ def make_lut_agg(self, target_lag: int, segment_lagtimes_df: pd.DataFrame): subset = peaks_hq_S[filter_around_this_day] num_vals = len(subset) + # lut_df.loc[this_date, 'median'] = 9 + if num_vals >= 5: # print(f"{this_date} {num_vals} {subset.median()}") lut_df.loc[this_date, 'median'] = subset.median() @@ -360,7 +362,9 @@ def make_lut_agg(self, target_lag: int, segment_lagtimes_df: pd.DataFrame): col='correction') self.logger.warning(f"No correction could be generated from data for dates: {missing_df.index.to_list()}") self.logger.warning(f"Filling missing corrections for dates: {missing_df.index.to_list()}") - lut_df['correction'].fillna(method='ffill', inplace=True, limit=1) + lut_df['correction'] = lut_df['correction'].ffill(limit=1) + lut_df['correction'] = lut_df['correction'].bfill(limit=1) + # lut_df['correction'] = lut_df['correction'].fillna(method='ffill', inplace=False, limit=1) # deprecated try: lut_df['recommended_default_winsize'] = \ @@ -407,7 +411,7 @@ def get_hq_peaks(self, df): """ df.set_index('start', inplace=True) - df.index = pd.to_datetime(df.index) + df.index = pd.to_datetime(df.index, format="mixed") peaks_hq_S = df.loc[df['PEAK-COVABSMAX_SHIFT'] == df['PEAK-AUTO_SHIFT'], 'PEAK-COVABSMAX_SHIFT'] peaks_hq_S.index = peaks_hq_S.index.to_pydatetime() # Convert to DatetimeIndex diff --git a/dyco/correction.py b/dyco/correction.py index 7614dde..8677588 100644 --- a/dyco/correction.py +++ b/dyco/correction.py @@ -86,6 +86,7 @@ def run(self): if not self.phase == 3: this_date = file_info_row['start'].date() + this_date = pd.to_datetime(this_date) shift_correction = self.lut_df.loc[this_date][self.lut_col] else: this_date = file_info_row['start'] @@ -184,7 +185,7 @@ def read_lut_time_lags(self): """Read csv file that contains the look-up table for lag correction""" filepath = self.outdirs[ f'{self.phase}-6_{self.phase_files}_normalization_lookup_table'] / f'LUT_default_agg_time_lags.csv' - parse = lambda x: dt.datetime.strptime(x, '%Y-%m-%d') + # parse = lambda x: dt.datetime.strptime(x, '%Y-%m-%d') # now deprecated df = pd.read_csv(filepath, skiprows=None, header=0, @@ -192,10 +193,11 @@ def read_lut_time_lags(self): # na_values=-9999, encoding='utf-8', delimiter=',', - mangle_dupe_cols=True, + # mangle_dupe_cols=True, # keep_date_col=False, parse_dates=True, - date_parser=parse, + # date_parser=parse, # now deprecated + date_format='%Y-%m-%d', index_col=0, dtype=None, engine='c') diff --git a/dyco/dyco.py b/dyco/dyco.py index 2554043..d7a9c8e 100644 --- a/dyco/dyco.py +++ b/dyco/dyco.py @@ -109,7 +109,7 @@ def _update_args(self, args, prev_phase, prev_phase_files, prev_outdir_files, pr args['lgs_winsize'] = 100 # Small window for instantaneous search in Phase 3 args['lgs_num_iter'] = 1 - args['indir'] = prev_outdir_files / f"{prev_phase}-7_{prev_phase_files}_normalized" + args['indir'] = Path(prev_outdir_files) / f"{prev_phase}-7_{prev_phase_files}_normalized" args['var_lagged'] = f"{args['var_lagged']}_DYCO" # Use normalized signal filename, file_extension = os.path.splitext(args['fnm_pattern']) args['fnm_pattern'] = f"{filename}_DYCO{file_extension}" # Search normalized files @@ -165,13 +165,13 @@ def __init__(self, fnm_date_format: str = '%Y%m%d%H%M%S', fnm_pattern: str = '*.csv', files_how_many: None or int = None, - file_generation_res: str = '30T', - file_duration: str = '30T', + file_generation_res: str = '30min', + file_duration: str = '30min', dat_recs_timestamp_format: None or str = None, dat_recs_nominal_timeres: float = 0.05, - lgs_segment_dur: str = '30T', + lgs_segment_dur: str = '30min', lgs_winsize: int = 1000, - lgs_num_iter: int = 3, + lgs_num_iter: int = 1, lgs_hist_remove_fringe_bins: bool = True, lgs_hist_perc_thres: float = 0.9, target_lag: int = 0, @@ -226,16 +226,16 @@ def __init__(self, Frequency at which new files were generated. This does not relate to the data records but to the file creation time. Examples: - * '30T' means a new file was generated every 30 minutes. - * '1H' means a new file was generated every hour. - * '6H' means a new file was generated every six hours. + * '30min' means a new file was generated every 30 minutes. + * '1h' means a new file was generated every hour. + * '6h' means a new file was generated every six hours. For pandas DateOffset options see: https://pandas.pydata.org/pandas-docs/stable/user_guide/timeseries.html#offset-aliases file_duration: str (pandas DateOffset) Duration of one data file. Example: - * '30T': data file contains data from 30 minutes. + * '30min': data file contains data from 30 minutes. For pandas DateOffset options see: https://pandas.pydata.org/pandas-docs/stable/user_guide/timeseries.html#offset-aliases @@ -246,10 +246,10 @@ def __init__(self, *file_duration*, then the file data is split into segments and the lag time is calculated for each segment separately. Examples: - * '10T': calculates lag times for 10-minute segments. + * '10m': calculates lag times for 10-minute segments. * With the settings - file_duration = '30T' and - lgs_segments_dur = '10T' + file_duration = '30min' and + lgs_segments_dur = '10m' the 30-minute data file is split into three 10-minute segments and the lag time is determined in each of the segments, yielding three lag times. @@ -435,10 +435,8 @@ def setup(self): return logfile_path, files_overview_df def calculate_lags(self): - """ - Calculate covariances and detect covariance peaks to determine lags - for each file segment - """ + """Calculate covariances and detect covariance peaks to determine lags + for each file segment.""" for iteration in range(1, 1 + self.lgs_num_iter): loop_iter = loop.Loop(dyco_instance=self, iteration=iteration) diff --git a/dyco/files.py b/dyco/files.py index 5c5011a..5ec7305 100644 --- a/dyco/files.py +++ b/dyco/files.py @@ -96,12 +96,12 @@ def read_raw_data(filepath, data_timestamp_format): num_missing_header_cols=num_missing_header_cols) if data_timestamp_format: - parse = lambda x: dt.datetime.strptime(x, data_timestamp_format) - date_parser = parse + # parse = lambda x: dt.datetime.strptime(x, data_timestamp_format) # now deprecated + # date_parser = parse # now deprecated parse_dates = True index_col = 0 else: - date_parser = None + # date_parser = None # now deprecated parse_dates = False index_col = None @@ -112,10 +112,11 @@ def read_raw_data(filepath, data_timestamp_format): na_values=-9999, encoding='utf-8', delimiter=',', - # mangle_dupe_cols=True, - keep_date_col=False, + # mangle_dupe_cols=True, # now deprecated + # keep_date_col=False, # now deprecated parse_dates=parse_dates, - date_parser=date_parser, + # date_parser=date_parser, # now deprecated + date_format=data_timestamp_format, index_col=index_col, dtype=None, engine='c', diff --git a/dyco/lag.py b/dyco/lag.py index bd1ecc0..2afdb80 100644 --- a/dyco/lag.py +++ b/dyco/lag.py @@ -148,7 +148,8 @@ def setup_lagsearch_df(lgs_winsize: list, shift_stepsize: int, segment_name): df['shift'] = range(int(lgs_winsize[0]), int(lgs_winsize[1]) + shift_stepsize, shift_stepsize) - df['index'] = np.nan + df['index'] = pd.NaT + # df['index'] = np.nan df['segment_name'] = segment_name df['cov'] = np.nan df['cov_abs'] = np.nan @@ -159,10 +160,9 @@ def setup_lagsearch_df(lgs_winsize: list, shift_stepsize: int, segment_name): @staticmethod def find_auto_peak(cov_df: pd.DataFrame): - """ - Automatically find peaks in covariance time series + """Automatically find peaks in covariance time series. - The found peak is flagged TRUE in cov_df. + The found peak is flagged TRUE in *cov_df*. Peaks are searched automatically using scipy's .find_peaks method. The peak_score is calculated for each peak, the top-scoring peaks @@ -256,7 +256,9 @@ def find_max_cov_peak(segment_df, cov_df, var_lagged, var_reference): shift = int(row['shift']) try: if shift < 0: - index_shifted = str(_segment_df['index'][-shift]) # Note the negative sign + index_shifted = _segment_df['index'].iloc[-shift] # Note the negative sign + # index_shifted = str(_segment_df['index'].iloc[-shift]) # Note the negative sign + # index_shifted = str(_segment_df['index'][-shift]) # Note the negative sign else: index_shifted = pd.NaT scalar_data_shifted = _segment_df[var_lagged].shift(shift) diff --git a/dyco/loop.py b/dyco/loop.py index ddd60c1..b430dbe 100644 --- a/dyco/loop.py +++ b/dyco/loop.py @@ -211,9 +211,20 @@ def plot_segment_lagtimes_ts(segment_lagtimes_df: pd.DataFrame, alpha = .5 iteration_grouped = _df.groupby('iteration') for idx, group_df in iteration_grouped: - ax.plot_date(pd.to_datetime(group_df['start']), group_df['PEAK-COVABSMAX_SHIFT'], - alpha=alpha, marker='o', ms=6, color=colors[int(idx - 1)], lw=0, ls='-', - label=f'found lag times in iteration {int(idx)}', markeredgecolor='None') + try: + # ax.plot_date(pd.to_datetime(group_df['start']), group_df['PEAK-COVABSMAX_SHIFT'], + # alpha=alpha, fmt='o', ms=6, color=colors[int(idx - 1)], lw=0, ls='-', + # label=f'found lag times in iteration {int(idx)}', markeredgecolor='None') + + # Below, "format='mixed'" is used because although all dates have the same format + # (in this case '%Y-%m-%d %H:%M:%S.%f') pandas seems to interpret the timestamp + # '2016-10-24 13:00:00.000000' as '2016-10-24 13:00:00' and therefore raises a ValueError. + ax.plot_date(pd.to_datetime(group_df['start'], format='mixed'), group_df['PEAK-COVABSMAX_SHIFT'], + alpha=alpha, fmt='o', ms=6, color=colors[int(idx - 1)], lw=0, ls='-', + label=f'found lag times in iteration {int(idx)}', markeredgecolor='None') + + except ValueError as e: + print(e) plot.default_format(ax=ax, label_color='black', fontsize=12, txt_xlabel='segment date', txt_ylabel='lag', txt_ylabel_units='[records]') @@ -431,8 +442,13 @@ def store_search_results(self, stor_df: pd.DataFrame, stor_cols: dict, stor_idx: """ # Init columns - for key, col in stor_cols.items(): - stor_df.loc[stor_idx, col] = np.nan + # for key, col in stor_cols.items(): + # stor_df.loc[stor_idx, col] = np.nan + + # # todo remove? + # stor_df['PEAK-COVABSMAX_SHIFT'] = np.nan + # stor_df['PEAK-COVABSMAX_COV'] = np.nan + # stor_df['PEAK-COVABSMAX_TIMESTAMP'] = pd.NaT # Get indices of peaks and instantaneous default lag flag_idx = lag.LagSearch.get_peak_idx(df=flag_df, flag_col=flag_col) @@ -694,7 +710,10 @@ def cov_collection(indir, outdir, logfile_path): for idx, filename in enumerate(filelist): filepath = os.path.join(str(indir), filename) segment_cov_df = files.read_segment_lagtimes_file(filepath=filepath) - cov_collection_df = cov_collection_df.append(segment_cov_df) # Collect for median and quantiles calc + + # todo check if correct: + cov_collection_df = pd.concat([cov_collection_df, segment_cov_df], axis=0, ignore_index=True) # Collect for median and quantiles calc + # cov_collection_df = cov_collection_df.append(segment_cov_df) # Collect for median and quantiles calc # Plot each segment covariance file args = dict(alpha=0.05, c='black', lw=0.5, marker='None', zorder=98) @@ -714,7 +733,11 @@ def q75(x): linestyle = ['-', '--', '--'] colors = ['#f44336', '#2196F3', '#3F51B5'] iter_df = cov_collection_df[cov_collection_df['segment_name'].str.contains('iter')] - _df = iter_df.groupby('shift').agg(f) + + _df = iter_df.copy() + _df = _df.select_dtypes(include=['number']) # Keep numeric columns + # _df = _df._get_numeric_data() + _df = _df.groupby('shift').agg(f) args = dict(alpha=1, lw=1, marker='None', zorder=98) for label_idx, label_name in enumerate(labels): ax1.plot(_df.index, _df['cov'][label_name], diff --git a/dyco/plot.py b/dyco/plot.py index de1b809..3e8fa65 100644 --- a/dyco/plot.py +++ b/dyco/plot.py @@ -97,19 +97,19 @@ def run(self): def _add_lines_cov(self, ax, df, last_iter_phase_1, last_iter_phase_2): props = {'y': df[f'PHASE-1_ITER-{last_iter_phase_1}_PEAK-COVABSMAX_COV'], 'label': f'Phase 1', - 'zorder': 100, 'alpha': 1, 'marker': 's', 'ms': 6, 'lw': 1, 'ls': 'dotted', + 'zorder': 100, 'alpha': 1, 'fmt': 's', 'ms': 6, 'lw': 1, 'ls': 'dotted', 'markeredgecolor': '#80DEEA', 'color': '#80DEEA', 'markerfacecolor': 'white'} ax.plot_date(df.index, **props) props = {'y': df[f'PHASE-2_ITER-{last_iter_phase_1}_PEAK-COVABSMAX_COV'], 'label': f'Phase 2', - 'zorder': 100, 'alpha': 1, 'marker': 's', 'ms': 6, 'lw': 1, 'ls': '--', + 'zorder': 100, 'alpha': 1, 'fmt': 's', 'ms': 6, 'lw': 1, 'ls': '--', 'markeredgecolor': '#F48FB1', 'color': '#F48FB1', 'markerfacecolor': 'white'} ax.plot_date(df.index, **props) props = {'y': df['PHASE-3_INSTANTANEOUS_LAG_COV'], 'label': 'Phase 3', - 'zorder': 100, 'alpha': 1, 'marker': 'o', 'ms': 6, 'lw': 2, 'ls': '-', + 'zorder': 100, 'alpha': 1, 'fmt': 'o', 'ms': 6, 'lw': 2, 'ls': '-', 'markeredgecolor': '#8BC34A', 'color': '#8BC34A', 'markerfacecolor': '#8BC34A'} ax.plot_date(df.index, **props) @@ -260,7 +260,7 @@ def _get_lut_last_iteration(self, outdirs, phase, phase_files): return lut_df def _make_outdir(self): - outdir = self.instance_phase_1.outdir / 'SUMMARY' + outdir = Path(self.instance_phase_1.outdir) / 'SUMMARY' if not Path.is_dir(outdir): print(f"Creating folder {outdir} ...") os.makedirs(outdir) diff --git a/dyco/setup_dyco.py b/dyco/setup_dyco.py index 191464a..ba450ee 100644 --- a/dyco/setup_dyco.py +++ b/dyco/setup_dyco.py @@ -132,7 +132,7 @@ def setup_output_dirs(self): # Create Path to required directories, store keys and full paths in dict for nd in required_dirs: - outdirs[nd] = self.root_dir / nd + outdirs[nd] = Path(self.root_dir) / nd # Delete dirs if needed for key, path in outdirs.items(): @@ -191,7 +191,10 @@ def run(self): self.files_overview_df = self.add_expected() self.files_overview_df = self.add_unexpected() self.files_overview_df = self.calc_expected_values() - self.files_overview_df.loc[:, 'file_available'].fillna(0, inplace=True) + _temp = self.files_overview_df.loc[:, 'file_available'].copy() + _temp = _temp.fillna(0) + self.files_overview_df.loc[:, 'file_available'] = _temp + # self.files_overview_df.loc[:, 'file_available'].fillna(0, inplace=True) self.files_overview_df = self.limit_num_files() self.logger.info(f"Found {int(self.files_overview_df['file_available'].sum())} available files") diff --git a/example/example_kwargs.py b/example/example_kwargs.py index 3d4bae5..42a802f 100644 --- a/example/example_kwargs.py +++ b/example/example_kwargs.py @@ -7,34 +7,10 @@ https://github.com/holukas/dyco/wiki/Usage """ -import os - from dyco.dyco import DynamicLagCompensation -cli = r'python "F:\Sync\luhk_work\20 - CODING\27 - VARIOUS\dyco\dyco\dyco.py" ' \ - r'w_ms-1_rot_turb co2_ppb_qcl_turb ' \ - r'co2_ppb_qcl_turb n2o_ppb_qcl ch4_ppb_qcl ' \ - r'-i F:\TMP\das\input_data ' \ - r'-o F:\TMP\das ' \ - r'-fnd %Y%m%d%H%M%S ' \ - r'-fnp *.csv ' \ - r'-flim 0 ' \ - r'-fgr 30T ' \ - r'-fdur 30T ' \ - r'-dtf "%Y-%m-%d %H:%M:%S.%f" ' \ - r'-dres 0.05 ' \ - r'-lss 30T ' \ - r'-lsw 1000 ' \ - r'-lsi 3 ' \ - r'-lsf 1 ' \ - r'-lsp 0.9 ' \ - r'-lt 0 ' \ - r'-del 0' -print(cli) -os.system(cli) - -def main(args): +def main(): """Main function that is called with the given args when the script is executed from the command line.""" DynamicLagCompensation(var_reference='w_ms-1_rot_turb', @@ -45,12 +21,14 @@ def main(args): fnm_date_format='%Y%m%d%H%M%S', fnm_pattern='*.csv', files_how_many=0, - file_generation_res='30T', - file_duration='30T', + file_generation_res='30min', + file_duration='30min', dat_recs_timestamp_format="%Y-%m-%d %H:%M:%S.%f", dat_recs_nominal_timeres=0.05, - lgs_segment_dur='30T', + lgs_segment_dur='30min', lgs_winsize=1000, + # lgs_winsize=400, + # lgs_num_iter=1, lgs_num_iter=3, lgs_hist_remove_fringe_bins=True, lgs_hist_perc_thres=0.9, From db7001c468cfbf0a13cf1f377eb38451fd224bd9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20H=C3=B6rtnagl?= Date: Wed, 6 Mar 2024 19:45:38 +0100 Subject: [PATCH 4/6] Update CHANGELOG.md --- CHANGELOG.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ab7502e..9998d5c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,8 +1,12 @@ # CHANGELOG -## v1.2.0 | XX Mar 2024 +## v1.2.0 | 6 Mar 2024 +- Refactored code to work with newest package versions +- Several small bugfixes - Now using `poetry` for dependency management +- Now using Python 3.9.18 +- All dependencies were updated to their newest possible versions ## v1.1.2 | 16 Jun 2021 From da84eb1d1328398a459398a94d3d9dd3a7e988ae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20H=C3=B6rtnagl?= Date: Wed, 6 Mar 2024 19:46:05 +0100 Subject: [PATCH 5/6] Update pyproject.toml --- pyproject.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index 7c432d5..d6bcb43 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "dyco" -version = "1.1.2" +version = "1.2.0" description = "Dynamic lag compensation" authors = ["Lukas Hörtnagl "] readme = "README.md" From cc040d1a132d73da19d42241afe953f8eddbb515 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20H=C3=B6rtnagl?= Date: Wed, 6 Mar 2024 19:50:06 +0100 Subject: [PATCH 6/6] Renamed example --- CHANGELOG.md | 4 +++- example/example_kwargs.py | 4 ++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9998d5c..ebecf2c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,8 +5,10 @@ - Refactored code to work with newest package versions - Several small bugfixes - Now using `poetry` for dependency management -- Now using Python 3.9.18 +- Now using Python `3.9.18` - All dependencies were updated to their newest possible versions +- Added example for using the class `DynamicLagCompensation` to run `dyco` directly from + code (`example.example_kwargs.example`) ## v1.1.2 | 16 Jun 2021 diff --git a/example/example_kwargs.py b/example/example_kwargs.py index 42a802f..9f7cc0e 100644 --- a/example/example_kwargs.py +++ b/example/example_kwargs.py @@ -10,7 +10,7 @@ from dyco.dyco import DynamicLagCompensation -def main(): +def example(): """Main function that is called with the given args when the script is executed from the command line.""" DynamicLagCompensation(var_reference='w_ms-1_rot_turb', @@ -37,4 +37,4 @@ def main(): if __name__ == '__main__': - main() + example()