diff --git a/.github/workflows/BioPortal-submission.json b/.github/workflows/BioPortal-submission.json index 4bc042b..5df24a1 100644 --- a/.github/workflows/BioPortal-submission.json +++ b/.github/workflows/BioPortal-submission.json @@ -1,10 +1,10 @@ { "ontology": "https://data.bioontology.org/ontologies/KISAO", - "pullLocation": "https://raw.githubusercontent.com/SED-ML/KiSAO/2.14/kisao.owl", + "pullLocation": "https://raw.githubusercontent.com/SED-ML/KiSAO/2.34/kisao.owl", "hasOntologyLanguage": "OWL", "description": "The Kinetic Simulation Algorithm Ontology (KiSAO) is an ontology of algorithms for simulating and analyzing biological models, as well as the characteristics of these algorithms, their input parameters, and their outputs. In addition, KiSAO captures relationships among algorithms, their parameters, and their outputs.", - "version": "2.14", - "released": "2021-04-29T02:54:00-00:00", + "version": "2.34", + "released": "2023-05-24T02:54:00-00:00", "status": "production", "homepage": "http://biomodels.net/kisao/", "documentation": "http://biomodels.net/kisao/", diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 8fbb422..ee10671 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -31,8 +31,8 @@ jobs: - name: Install pip and setuptools run: | - python -m pip install --upgrade pip - python -m pip install --upgrade setuptools + python -m pip install --upgrade pip==23.0.0 + python -m pip install --upgrade pip==23.0.0 - name: Install the Python KiSAO package working-directory: libkisao/python @@ -82,7 +82,7 @@ jobs: - name: Upload the coverage report to Codecov if: false - uses: codecov/codecov-action@v1.0.3 + uses: codecov/codecov-action@v2 with: token: ${{ secrets.CODECOV_TOKEN }} flags: unittests @@ -104,7 +104,7 @@ jobs: run: | mainBranch=$(git symbolic-ref refs/remotes/origin/HEAD | cut -d '/' -f 4) mainBranchHeadRevision=$(git rev-parse refs/remotes/origin/${mainBranch}) - echo "::set-output name=mainBranchHeadRevision::$mainBranchHeadRevision" + echo "mainBranchHeadRevision=$mainBranchHeadRevision" >> $GITHUB_OUTPUT determineIfReleaseNeeded: name: Determine if the package should be released @@ -127,13 +127,17 @@ jobs: release="0" if [[ "${{ github.ref }}" =~ ^refs/tags/ ]]; then + echo "First check passed" tag_hash=$(git rev-parse "${{ github.ref }}") + echo "tag_hash: $tag_hash" if [ "$tag_hash" == "${{ needs.getMainBranchHeadRevision.outputs.mainBranchHeadRevision }}" ]; then + echo "Second check passed" release="1" fi fi - echo "::set-output name=release::$release" + echo "release=$release" >> $GITHUB_OUTPUT + echo "release=$release" commitCompiledDocumentation: name: Commit and push compiled documentation to GitHub @@ -148,8 +152,8 @@ jobs: uses: actions/checkout@master with: fetch-depth: 1 - ref: dev - token: ${{ secrets.ADMIN_GITHUB_TOKEN }} +# ref: dev +# token: ${{ secrets.ADMIN_GITHUB_TOKEN }} # Install the requirements for the tests - name: Install Python @@ -167,8 +171,8 @@ jobs: - name: Install pip and setuptools run: | - python -m pip install --upgrade pip - python -m pip install --upgrade setuptools + python -m pip install --upgrade pip==23.0.0 + python -m pip install --upgrade pip==23.0.0 - name: Install the Python KiSAO package working-directory: libkisao/python @@ -220,7 +224,7 @@ jobs: else docsChanged=0 fi - echo "::set-output name=docsChanged::$docsChanged" + echo "docsChanged=$docsChanged" >> $GITHUB_OUTPUT - name: Push the compiled documentation if: startsWith(github.ref, 'refs/tags/') && steps.commit-docs.outputs.docsChanged == '1' @@ -240,8 +244,9 @@ jobs: - name: Checkout repo uses: actions/checkout@master with: - ref: dev - token: ${{ secrets.ADMIN_GITHUB_TOKEN }} + fetch-depth: 1 +# ref: dev +# token: ${{ secrets.ADMIN_GITHUB_TOKEN }} - name: Merge dev branch into deploy branch uses: devmasx/merge-branch@v1.3.1 @@ -256,7 +261,7 @@ jobs: TAG: ${{ github.ref }} run: | version="${TAG/refs\/tags\//}" - echo "::set-output name=version::$version" + echo "version=$version" >> $GITHUB_OUTPUT - name: Create GitHub release uses: "marvinpinto/action-automatic-releases@latest" @@ -337,10 +342,10 @@ jobs: restore-keys: | ${{ runner.os }}-pip- - - name: Install pip and setuptools + - name: Install pip run: | - python -m pip install --upgrade pip - python -m pip install --upgrade setuptools + python -m pip install --upgrade pip==23.0.0 + python -m pip install --upgrade pip==23.0.0 # Create PyPI release - name: Create PyPI release @@ -352,12 +357,8 @@ jobs: # Install pandoc sudo apt-get update -y sudo apt-get install -y --no-install-recommends wget - - wget https://github.com/jgm/pandoc/releases -O /tmp/pandocVersions.html - urlPart=`grep "\.deb" /tmp/pandocVersions.html | head -n 1 | cut -d'/' -f2-7 | cut -d'"' -f1` - wget "https://github.com/$urlPart" -O /tmp/pandoc.deb + wget "https://github.com/jgm/pandoc/releases/download/3.1.3/pandoc-3.1.3-1-amd64.deb" -O /tmp/pandoc.deb sudo dpkg -i /tmp/pandoc.deb - rm /tmp/pandocVersions.html rm /tmp/pandoc.deb # Copy OWL file and LICENSE so it can be bundled into the Python package diff --git a/CHANGELOG.md b/CHANGELOG.md index 1b60651..5714ef8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,22 @@ # Changelog +## 2.34 (OWL 2) +- Added organizational 'DAE solver' (`KISAO_0000699`) for collecting solvers that can solve DAE problems. +- Removed 'has characteristic' some 'differential-algebraic equation problem' from KINSOL and from 'method for solving a system of linear equations'. +- The characteristics 'differential-algebraic equation problem' and ''ordinary differential equation problem' are no longer disjoint (and in fact the former are a complete subset of the latter). + +## 2.33 (OWL 2) +- Reorganized the steady state algorithms: moved flux balance and steady state to 'general steady state method' (`KISAO_0000630`), and others to the 'steady state root-finding method' (`KISAO_0000407`) + +## 2.32 (OWL 2) +- Added algorithm concepts for eQuilibrator. +- Added organizational 'ODE solver' (`KISAO_0000694`) for noting in SED-ML that some solver should be used, but which is not important. +- Added 'parameters for' (`KISAO_0000695`) to indicate that the children parameters of this term are applied when the parent general term is implented as the more-specific value of this term. + +## 2.31 (OWL 2) +- Added concepts for Metabolic Pathway Analysis +- Added top-level algorithm concept for network optimization methods and nested the Metabolic Pathway Analysis methods, flux balance methods, and resource balance analysis under this + ## 2.30 (OWL 2) - Added and unified aggregation functions for SED-ML L1V4 - maximum ignoring NaN (`KISAO_0000828`) diff --git a/kisao.owl b/kisao.owl index 52bc176..174b10e 100644 --- a/kisao.owl +++ b/kisao.owl @@ -1,26 +1,26 @@ + xmlns:skos="http://www.w3.org/2004/02/skos/core#" + xmlns:kisao="http://www.biomodels.net/kisao/KISAO#" + xmlns:protege="http://protege.stanford.edu/plugins/owl/protege#"> + en Artistic License 2.0 - http://identifiers.org/pubmed/22027554 + This is a core version which contains all but deprecated classes. Kinetic Simulation Algorithm Ontology (KiSAO) - 2.30 http://co.mbine.org/standards/kisao - en + http://identifiers.org/pubmed/22027554 + 2.34 The Kinetic Simulation Algorithm Ontology (KiSAO) classifies algorithms available for the simulation and analysis of models in biology, and their characteristics and the parameters required for their use. - This is a core version which contains all but deprecated classes. @@ -117,11 +117,9 @@ - - has characteristic - 'has characteristic' links algorithms to the characteristics, they possess. + 'has characteristic' links algorithms to the characteristics they possess. @@ -319,7 +317,7 @@ - 24JAN2009 + 2009-01-24 NLN weighted stochastic simulation algorithm http://identifiers.org/pubmed/19045316 @@ -544,13 +542,13 @@ dk SBML-SAT SUNDIALS + libRoadRunner http://identifiers.org/biosimulators/bionetgen http://identifiers.org/biosimulators/jsim http://identifiers.org/biosimulators/opencor http://identifiers.org/biosimulators/pysces http://identifiers.org/biosimulators/tellurium http://identifiers.org/biosimulators/vcell - libRoadRunner CVODE citeulike:1832863 http://identifiers.org/doi/10.1145/1089014.1089020 @@ -2547,7 +2545,7 @@ It is an 'embedded Runge-Kutta method' [http://identifiers.org/biomode - + @@ -2713,6 +2711,12 @@ It is an 'embedded Runge-Kutta method' [http://identifiers.org/biomode + + + + + + 2008-07-08 NLN continuous variable @@ -4153,12 +4157,6 @@ Reduced models can be determined in many ways such as using mass conservation la - - - - - - @@ -4395,25 +4393,13 @@ IDA is written in C, but derived from the package DASPK [http://identifiers.org/ - - - - - - - + - - - - - - @@ -4422,8 +4408,8 @@ IDA is written in C, but derived from the package DASPK [http://identifiers.org/ - - + + @@ -4457,11 +4443,11 @@ IDA is written in C, but derived from the package DASPK [http://identifiers.org/ - + - + @@ -4470,12 +4456,6 @@ IDA is written in C, but derived from the package DASPK [http://identifiers.org/ - - - - - - 2011-05-10 AZ Milstein method @@ -7377,6 +7357,12 @@ DASPK is written in Fortran. + + + + + + AZ differential-algebraic equation problem DAE @@ -7433,7 +7419,7 @@ DASPK is written in Fortran. - + @@ -8072,20 +8058,25 @@ DASPK is written in Fortran. - - + + + + + + + 2012-01-17 AZ - true + false Requested by Frank T. Bergmann on Sunday, November 27, 2011 4:45:30 PM. - steady state method - A method looking for a steady state of a dynamic system. + steady state root-finding method + Method for finding the root of a function (f(x) = 0). @@ -8154,7 +8145,7 @@ The solution of the system F(x)=0 can be interpreted as a steady state of a dyna 2012-01-18 AZ - simlified Newton method + simplified Newton method http://identifiers.org/isbn/9783540210993 A 'Newton-type method' [http://identifiers.org/biomodels.kisao/KISAO_0000408] which is characterized by keeping the initial derivative throughout the whole iteration: F'(x[0])deltax[k]=-F(x[k]), x[k+1]=x[k]+deltax[k], k=0,1,... @@ -8727,7 +8718,7 @@ Hierarchical cluster-based partial least squares regression method uses fuzzy C- - + @@ -8754,7 +8745,7 @@ Hierarchical cluster-based partial least squares regression method uses fuzzy C- - + @@ -8963,8 +8954,8 @@ Hierarchical cluster-based partial least squares regression method uses fuzzy C- - + 2012-11-29 AZ Requested by Frank T. Bergmann on Thursday, November 29, 2012 9:51:58 AM. @@ -9263,8 +9254,9 @@ Hierarchical cluster-based partial least squares regression method uses fuzzy C- 2014-04-25 AZ - Requested by Andrzej Kierzek on Thursday, April 24, 2014 12:40:35 PM - Used to simulate systems involving reactions with propensities varying by many orders of magnitude. + Requested by Andrzej Kierzek on Thursday, April 24, 2014 12:40:35 PM + +Used to simulate systems involving reactions with propensities varying by many orders of magnitude. maximal timestep method http://identifiers.org/pubmed/14990466 Hybrid simulation algorithm [http://www.biomodels.net/kisao/KISAO#KISAO_0000352] combining Gibson and Bruck algorithm [http://www.biomodels.net/kisao/KISAO#KISAO_0000027] with the Gillespie tau-leap method [http://www.biomodels.net/kisao/KISAO#KISAO_0000039]. @@ -9308,6 +9300,12 @@ Hierarchical cluster-based partial least squares regression method uses fuzzy C- + + + + + + 2015-04-23 AZ true @@ -10651,8 +10649,8 @@ Levenberg first suggested an improvement to the Newton method in order to make i - + @@ -11589,10 +11587,10 @@ Levenberg first suggested an improvement to the Newton method in order to make i JRK SUNDIALS SciPy + libRoadRunner http://identifiers.org/biosimulators/copasi http://identifiers.org/biosimulators/gillespy2 http://identifiers.org/biosimulators/tellurium - libRoadRunner initial step size Initial time step size. @@ -11860,17 +11858,23 @@ Levenberg first suggested an improvement to the Newton method in order to make i - + - - + + - - + + + + + + + + 2020-10-29 @@ -12350,8 +12354,8 @@ Min sum(|fluxAi - fluxBi|) - + 2020-10-29 JRK http://identifiers.org/biosimulators/cobratoolbox @@ -12592,7 +12596,8 @@ Min sum(|fluxAi - fluxBi|) - + + 2020-10-29 JRK true @@ -12734,8 +12739,8 @@ Min sum(|fluxAi - fluxBi|) - + 2020-10-29 JRK true @@ -13457,8 +13462,14 @@ CVODE is used for ordinary differential equation (ODE) systems. IDA is used for - - 2021--04-27 + + + + + + + + 2021-04-27 JRK true flux balance method @@ -13481,12 +13492,6 @@ CVODE is used for ordinary differential equation (ODE) systems. IDA is used for - - - - - - @@ -13556,8 +13561,8 @@ Example system of equations: - 2012-06-01 JRK + 2012-06-01 true modelling and simulation algorithm parameter value A value of a parameter of an algorithm @@ -13590,8 +13595,9 @@ Example system of equations: 2021-06-01 JRK true - root-finding method - Method for finding the root of a function (f(x) = 0). + general steady state method + root-finding method + A method looking for a steady state of a dynamic system. @@ -13599,9 +13605,9 @@ Example system of equations: - - 2021-06-01 + JRK + 2021-06-01 true iterative root-finding method Iterative method for finding the root of a function (f(x) = 0). @@ -13649,8 +13655,8 @@ This method only involves evaluations of f. This method is suitable for non-stif - 2021-06-04 JRK + 2021-06-04 scaled property @@ -13948,7 +13954,7 @@ This method only involves evaluations of f. This method is suitable for non-stif 2021-06-04 JRK amount rate - rate of a process in extensive/absolute units such as reactions per second. + rate of a process in extensive/absolute units such as reactions per second. @@ -13957,7 +13963,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-04-2021 + 2021-06-04 JRK rate Speed at which a process is occuring such as the temporal rate of a chemical reaction, @@ -14231,7 +14237,14 @@ This method only involves evaluations of f. This method is suitable for non-stif - + + + + + + + + 2021-08-12 JRK http://identifiers.org/biosimulators/rbapy @@ -14540,162 +14553,690 @@ This method only involves evaluations of f. This method is suitable for non-stif - + - - - 06-03-2021 - LPS + + + + + + + + + 2022-03-27 + EN + JRK + WL true - systems property - A systems-level property of an entire model or simulation. + biological state optimization method + A method for computing the optimal state of a biological system according to a particular objective. - + - - + + - + - 06-03-2021 - LPS - concentration control coefficient matrix (unscaled) - The unscaled concentration control coefficient matrix. The dimensions are species by reactions. - - - - - - - - - + - 06-03-2021 - LPS - control coefficient (scaled) - A scaled control coefficient of any dependent element (such as a reaction or a floating species) with respect to an independent element (such as a global parameter or boundary species). + 2022-03-27 + EN + JRK + WL + https://gitlab.com/equilibrator/metabolic-pathway-analysis + Enzyme Cost Minimization + http://identifiers.org/doi:10.1371/journal.pcbi.1005167 + ECM + For a given metabolic network model, the Enzyme Cost Minimization method determines plausible metabolite and enzyme concentrations (which determine thermodynamic forces and enzyme catalytic rates). Fluxes, enzyme kinetic constants, admissible metabolite concentration ranges, and enzyme cost weights (e.g. enzyme molecular masses) are given as input data. The method applies the principle that high enzyme (or enzyme plus metabolite) concentrations must be avoided, and maximizes a weighted sum of enzyme and metabolite concentrations. + + + + https://gitlab.com/equilibrator/metabolic-pathway-analysis + Metabolic Pathway Analysis + + + + + http://identifiers.org/doi:10.1371/journal.pcbi.1005167 + Elad Noor, Avi Flamholz, Arren Bar-Even, Dan Davidi, Ron Milo & Wolfram Liebermeister. The Protein Cost of Metabolic Fluxes: Prediction from Enzymatic Rate Laws and Cost Minimization. PLoS Comput Biol 12 (11): e1005167 (2016). + - + - - + + - + - 06-03-2021 - LPS - control coefficient (unscaled) - An unscaled control coefficient of any dependent element (such as a reaction or a floating species) with respect to an independent element (such as a global parameter or boundary species). - - - - - - - - - + - 06-03-2021 - LPS - elasticity matrix (unscaled) - The unscaled elasticity matrix. The dimensions are reactions by species. + 2022-03-27 + EN + JRK + WL + https://gitlab.com/equilibrator/metabolic-pathway-analysis + Max-min Driving Force method + http://identifiers.org/doi:10.1371/journal.pcbi.1003483 + MDF + For a given metabolic network model, the MDF method determines plausible metabolite concentrations and thermodynamic forces. Flux directions, equilibrium constants (or equivalently, standard Gibbs free energies of reactions) and admissible metabolite concentration ranges are given as input data. The method applies the principle that low thermodynamic forces must be avoided, and maximizes the minimum thermodynamic force across the entire network. + + + + https://gitlab.com/equilibrator/metabolic-pathway-analysis + Metabolic Pathway Analysis + + + + + http://identifiers.org/doi:10.1371/journal.pcbi.1003483 + Elad Noor, Arren Bar-Even, Avi Flamholz, Ed Reznik, Wolfram Liebermeister & Ron Milo. Pathway thermodynamics highlights kinetic obstacles in central metabolism. PLOS Computational Biology 10(2): e1003483 (2014). + - + - - - - - - - - - 06-03-2021 - LPS - elasticity coefficient (unscaled) - An unscaled elasticity coefficient of any reaction with respect to an independent element (such as a global parameter or boundary species). + + + 2022-03-29 + EN + JRK + WL + type of system described - + - - - - - - - - - 06-03-2021 - LPS - elasticity matrix (scaled) - The scaled elasticity matrix. The dimensions are reactions by species. + + + 2022-03-29 + EN + JRK + WL + mathematical system - + - - - - - - - - - 06-03-2021 - LPS - elasticity coefficient (scaled) - A scaled elasticity coefficient of any reaction with respect to an independent element (such as a global parameter or boundary species). + + + 2022-03-29 + EN + JRK + WL + biological system - + - - - 06-03-2021 - LPS - reduced stoichiometry matrix - The reduced stoichiometry matrix. The dimensions are species by reactions. + + + 2022-03-29 + EN + JRK + WL + metabolic system - + - + + + 2022-03-29 + EN + JRK + WL + cellular system + + + + + + + + + 2022-03-29 + EN + JRK + WL + biochemical system + + + + + + + + + + + + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + 2023-05-19 + lps + false + ODE solver + ordinary differential equation solver + An ODE solver is the general category of packages such as CVODE-like methods [http://identifiers.org/biomodels.kisao/KISAO_0000433] or Livermore solvers [http://identifiers.org/biomodels.kisao/KISAO_0000094] that solve systems of ordinary differential equations. + + + + + ordinary differential equation solver + EXACT + + + + + + + + + + + + + + + 2023/05/19 + lps + parameters for + The children parameters of this term are applied when the parent general term is implented as the more-specific value of this term. For example: a 'parameters for' term might be used as a child of an 'ODE Solver' ([http://identifiers.org/biomodels.kisao/KISAO_0000694]), have a value of 'KISAO_0000019' (CVODE)', and have a child term 'use stiff method' of 'true' ([http://identifiers.org/biomodels.kisao/KISAO_0000671]) + + + + + + + + + LPS + steady state root-finding problem + steady state problem + + + + + steady state problem + EXACT + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 2023-06-06 + lps + false + SDE solver + stochastic differential equation solver + An SDE solver is the general category of packages that provide stochastic solutions to a system of differential equations with propensities. + + + + + stochastic differential equation solver + EXACT + + + + + + + + + + + + + + + 12-08-2023 + LPS + particle coordinates + The set of coordinates for all particles of these entities. + + + + + + + + + + + + + + + + + + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + + + + 1 + + + + 2024-03-13 + lps + false + DAE Solver + differential algebraic equation solver + A DAE solver is the general category of packages such as IDA-like methods [http://identifiers.org/biomodels.kisao/KISAO_0000432] that solve systems of differential algebraic equations (DAEs). DAEs are a superset of ODEs that may additionally contain algebraic equations or 'fast' reactions. + + + + + differential algebraic equation solver + EXACT + + + + + + + + + 2021-06-03 + LPS + true + systems property + A systems-level property of an entire model or simulation. + + + + + + + + + + + + + + + 2021-06-03 + LPS + concentration control coefficient matrix (unscaled) + The unscaled concentration control coefficient matrix. The dimensions are species by reactions. + + + + + + + + + + + + + + + 2021-06-03 + LPS + control coefficient (scaled) + A scaled control coefficient of any dependent element (such as a reaction or a floating species) with respect to an independent element (such as a global parameter or boundary species). + + + + + + + + + + + + + + + 2021-06-03 + LPS + control coefficient (unscaled) + An unscaled control coefficient of any dependent element (such as a reaction or a floating species) with respect to an independent element (such as a global parameter or boundary species). + + + + + + + + + + + + + + + 2021-06-03 + LPS + elasticity matrix (unscaled) + The unscaled elasticity matrix. The dimensions are reactions by species. + + + + + + + + + + + + + + + 2021-06-03 + LPS + elasticity coefficient (unscaled) + An unscaled elasticity coefficient of any reaction with respect to an independent element (such as a global parameter or boundary species). + + + + + + + + + + + + + + + 2021-06-03 + LPS + elasticity matrix (scaled) + The scaled elasticity matrix. The dimensions are reactions by species. + + + + + + + + + + + + + + + 2021-06-03 + LPS + elasticity coefficient (scaled) + A scaled elasticity coefficient of any reaction with respect to an independent element (such as a global parameter or boundary species). + + + + + + + + + 2021-06-03 + LPS + reduced stoichiometry matrix + The reduced stoichiometry matrix. The dimensions are species by reactions. + + + + + + + - 06-03-2021 + 2021-06-03 LPS reduced Jacobian matrix The reduced Jacobian matrix. The dimensions are species by species. @@ -14707,7 +15248,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS reduced eigenvalue matrix The reduced eigenvalue matrix of a model. The dimensions are species by two, where the first column is the real part of the eigenvalues, and the second column is the imaginary part of the eigenvalues. @@ -14719,7 +15260,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS stoichiometry matrix full stochiometry matrix @@ -14732,7 +15273,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS Jacobian matrix full Jacobian matrix @@ -14745,7 +15286,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS Eigenvalue matrix full eigenvalue matrix @@ -14764,7 +15305,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS flux control coefficient matrix (unscaled) The unscaled flux control coefficient matrix. The dimensions are reactions by reactions. @@ -14782,7 +15323,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS flux control coefficient matrix (scaled) The scaled flux control coefficient matrix. The dimensions are reactions by reactions. @@ -14794,7 +15335,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS link matrix The link matrix of a model. @@ -14806,7 +15347,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS kernel matrix The Kernel matrix of a model. @@ -14818,7 +15359,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS L0 matrix The L0 matrix of a model. @@ -14830,7 +15371,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS Nr matrix The Nr matrix of a model. @@ -14841,7 +15382,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS true model and simulation property characteristic @@ -14854,7 +15395,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS true intensive property @@ -14868,7 +15409,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS extensive property https://en.wikipedia.org/wiki/Intensive_and_extensive_properties @@ -14881,7 +15422,7 @@ This method only involves evaluations of f. This method is suitable for non-stif - 06-03-2021 + 2021-06-03 LPS true aggregation function @@ -14902,64 +15443,205 @@ This method only involves evaluations of f. This method is suitable for non-stif - + + + + + 2021-06-03 + LPS, MK + standard deviation ignoring NaN + The standard deviation of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS, MK + standard error ignoring NaN + The standard error of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS, MK + maximum ignoring NaN + The maximum value of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS, MK + minimum ignoring NaN + The minimum value of a set of values, ignoring NaN entries. + + + + + + + + + 2021-10-09 + MK + maximum + The maximum of a set of values. If the values contain NaN the maximum is NaN. + + + + + + + + 2021-06-03 + LPS + true + model and simulation property + A variable of a model or simulation. + + + + + + + + + 2021-06-03 + LPS + time + The implied time variable of the model state. + + + + + + + + + + + + + + + + + + + + + 2021-06-03 + LPS + rate of change + rate + The rate of change of one variable with respect to a second variable. + + + + + + + + + + + + + + + 2021-06-03 + LPS + concentration control coefficient matrix (scaled) + The scaled concentration control coefficient matrix. The dimensions are species by reactions. + + + + + - - - 2021-06-03 - LPS, MK - standard deviation ignoring NaN - The standard deviation of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS + amount + The extensive quantity amount. - + - - - 2021-06-03 - LPS, MK - standard error ignoring NaN - The standard error of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS + particle number + The extensive quantity particle number, or, the molar amount of the entity multiplied by Avogadro's number. - + - - - 2021-06-03 - LPS, MK - maximum ignoring NaN - The maximum value of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS + concentration + The intensive quantity concentration, or, the amount of the entity with respect to the entity in which it resides. - + - - - 2021-06-03 - LPS, MK - minimum ignoring NaN - The minimum value of a set of values, ignoring NaN entries. + + + + + + + + + 2021-06-03 + LPS + temperature + The intensive quantity temperature. - - - - - 2021-10-09 - MK - maximum - The maximum of a set of values. If the values contain NaN the maximum is NaN. - - @@ -14970,6 +15652,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The minimum of a set of values. If the values contain NaN the minimum is NaN. + + @@ -14980,6 +15664,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The mean of a set of values. If the values contain NaN the mean is NaN. + + @@ -14990,6 +15676,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The standard deviation of a set of values. If the values contain NaN the standard deviation is NaN. + + @@ -15000,6 +15688,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The standard error of a set of values. If the values contain NaN the standard deviation is NaN. + + @@ -15010,6 +15700,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The sum of a set of values, ignoring Nan entries. + + @@ -15019,6 +15711,7 @@ This method only involves evaluations of f. This method is suitable for non-stif sum The sum of a set of values. If the values contain NaN the sum is NaN. + @@ -15030,6 +15723,8 @@ This method only involves evaluations of f. This method is suitable for non-stif product ignoring NaN The product of a set of values, ignoring Nan entries. + + @@ -15040,6 +15735,8 @@ This method only involves evaluations of f. This method is suitable for non-stif product The product of a set of values. If the values contain NaN the product is NaN. + + @@ -15050,6 +15747,8 @@ This method only involves evaluations of f. This method is suitable for non-stif cumulative sum ignoring NaN The cumulative sum of a set of values, ignoring Nan entries. + + @@ -15060,6 +15759,8 @@ This method only involves evaluations of f. This method is suitable for non-stif cumulative sum The cumulative sum of a set of values. If the values contain NaN the cumulative sum is NaN. + + @@ -15070,6 +15771,8 @@ This method only involves evaluations of f. This method is suitable for non-stif cumulative product ignoring NaN The cumulative product of a set of values, ignoring Nan entries. + + @@ -15081,6 +15784,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The cumulative product of a set of values. If the values contain NaN the cumulative product is NaN. + + @@ -15090,6 +15795,8 @@ This method only involves evaluations of f. This method is suitable for non-stif count ignoring NaN The number of non-zero elements of a set of values, ignoring Nan entries. + + @@ -15100,6 +15807,8 @@ This method only involves evaluations of f. This method is suitable for non-stif count The number of non-zero elements of a set of values. If the values contain NaN the count is NaN. + + @@ -15110,6 +15819,8 @@ This method only involves evaluations of f. This method is suitable for non-stif length ignoring NaN The number of elements of a set of values, ignoring Nan entries. + + @@ -15120,6 +15831,8 @@ This method only involves evaluations of f. This method is suitable for non-stif length The number of elements of a set of values. + + @@ -15130,6 +15843,8 @@ This method only involves evaluations of f. This method is suitable for non-stif median ignoring NaN The median of a set of values, ignoring Nan entries. + + @@ -15141,6 +15856,8 @@ This method only involves evaluations of f. This method is suitable for non-stif The median of a set of values. If the values contain NaN the median is NaN. + + @@ -15150,6 +15867,8 @@ This method only involves evaluations of f. This method is suitable for non-stif variance ignoring NaN The variance of a set of values, ignoring Nan entries. + + @@ -15160,145 +15879,9 @@ This method only involves evaluations of f. This method is suitable for non-stif variance The variance of a set of values. If the values contain NaN the variance is NaN. - - - - - - 06-03-2021 - LPS - true - model and simulation property - A variable of a model or simulation. - - - - - - - - 06-03-2021 - LPS - time - The implied time variable of the model state. - - - - - - - - - - - - - - - - - - - - - 06-03-2021 - LPS - rate of change - rate - The rate of change of one variable with respect to a second variable. - - - - - - - - - - - - - - - 06-03-2021 - LPS - concentration control coefficient matrix (scaled) - The scaled concentration control coefficient matrix. The dimensions are species by reactions. - - - - - - - - - - - - - - - 06-03-2021 - LPS - amount - The extensive quantity amount. - - - - - - - - - - - - - - - 06-03-2021 - LPS - particle number - The extensive quantity particle number, or, the molar amount of the entity multiplied by Avogadro's number. - - - - - - - - - - - - - - - 06-03-2021 - LPS - concentration - The intensive quantity concentration, or, the amount of the entity with respect to the entity in which it resides. - - - - - - - - - - - - 06-03-2021 - LPS - temperature - The intensive quantity temperature. - - - + diff --git a/kisao_full.owl b/kisao_full.owl index 19526ba..62c4a6c 100644 --- a/kisao_full.owl +++ b/kisao_full.owl @@ -19,7 +19,7 @@ Kinetic Simulation Algorithm Ontology (full version, containing deprecated classes) http://co.mbine.org/standards/kisao http://identifiers.org/pubmed/22027554 - 2.30 + 2.34 The Kinetic Simulation Algorithm Ontology (KiSAO) classifies algorithms available for the simulation and analysis of models in biology, and their characteristics and the parameters required for their use. diff --git a/libkisao/python/docs-src/conf.py b/libkisao/python/docs-src/conf.py index 4b8b387..5dc1b1f 100644 --- a/libkisao/python/docs-src/conf.py +++ b/libkisao/python/docs-src/conf.py @@ -42,7 +42,7 @@ 'sphinx.ext.autodoc', 'sphinx.ext.linkcode', 'sphinx.ext.napoleon', - 'sphinxprettysearchresults', +# 'sphinxprettysearchresults', ] # Add any paths that contain templates here, relative to this directory. diff --git a/libkisao/python/docs-src/requirements.txt b/libkisao/python/docs-src/requirements.txt index d9b8975..9b4c13f 100644 --- a/libkisao/python/docs-src/requirements.txt +++ b/libkisao/python/docs-src/requirements.txt @@ -1,2 +1,2 @@ sphinx >= 1.8 -sphinxprettysearchresults +#sphinxprettysearchresults diff --git a/libkisao/python/docs/_static/documentation_options.js b/libkisao/python/docs/_static/documentation_options.js index cbf3a6e..d4201e4 100644 --- a/libkisao/python/docs/_static/documentation_options.js +++ b/libkisao/python/docs/_static/documentation_options.js @@ -1,6 +1,6 @@ var DOCUMENTATION_OPTIONS = { URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'), - VERSION: '2.29', + VERSION: '2.30', LANGUAGE: 'en', COLLAPSE_INDEX: false, BUILDER: 'html', diff --git a/libkisao/python/docs/about.html b/libkisao/python/docs/about.html index 1e5d5cb..6977b28 100644 --- a/libkisao/python/docs/about.html +++ b/libkisao/python/docs/about.html @@ -6,7 +6,7 @@ - 2. About KiSAO — KiSAO 2.29 documentation + 2. About KiSAO — KiSAO 2.30 documentation diff --git a/libkisao/python/docs/genindex.html b/libkisao/python/docs/genindex.html index 2e0caca..e5d8e5c 100644 --- a/libkisao/python/docs/genindex.html +++ b/libkisao/python/docs/genindex.html @@ -5,7 +5,7 @@ - Index — KiSAO 2.29 documentation + Index — KiSAO 2.30 documentation diff --git a/libkisao/python/docs/index.html b/libkisao/python/docs/index.html index 30d0ad9..5eaf391 100644 --- a/libkisao/python/docs/index.html +++ b/libkisao/python/docs/index.html @@ -6,7 +6,7 @@ - KiSAO — KiSAO 2.29 documentation + KiSAO — KiSAO 2.30 documentation diff --git a/libkisao/python/docs/py-modindex.html b/libkisao/python/docs/py-modindex.html index 1177981..4f0e968 100644 --- a/libkisao/python/docs/py-modindex.html +++ b/libkisao/python/docs/py-modindex.html @@ -5,7 +5,7 @@ - Python Module Index — KiSAO 2.29 documentation + Python Module Index — KiSAO 2.30 documentation diff --git a/libkisao/python/docs/search.html b/libkisao/python/docs/search.html index bb098b2..6f9adc9 100644 --- a/libkisao/python/docs/search.html +++ b/libkisao/python/docs/search.html @@ -5,7 +5,7 @@ - Search — KiSAO 2.29 documentation + Search — KiSAO 2.30 documentation diff --git a/libkisao/python/docs/source/kisao.html b/libkisao/python/docs/source/kisao.html index 5cd32ee..312a8e3 100644 --- a/libkisao/python/docs/source/kisao.html +++ b/libkisao/python/docs/source/kisao.html @@ -6,7 +6,7 @@ - 1. kisao package — KiSAO 2.29 documentation + 1. kisao package — KiSAO 2.30 documentation diff --git a/libkisao/python/kisao/_version.py b/libkisao/python/kisao/_version.py index 728f998..4ed8e77 100644 --- a/libkisao/python/kisao/_version.py +++ b/libkisao/python/kisao/_version.py @@ -1 +1 @@ -__version__ = '2.30' +__version__ = '2.34' diff --git a/libkisao/python/kisao/data_model.py b/libkisao/python/kisao/data_model.py index 272e1be..a9ebe44 100644 --- a/libkisao/python/kisao/data_model.py +++ b/libkisao/python/kisao/data_model.py @@ -13,6 +13,7 @@ 'ID_HAS_CHARACTERISTIC_RELATIONSHIP', 'ID_ODE_PROBLEM_CHARACTERISTIC', 'ID_SDE_PROBLEM_CHARACTERISTIC', + 'ID_STEADYSTATE_PROBLEM_CHARACTERISTIC', 'ID_PDE_PROBLEM_CHARACTERISTIC', 'ID_EXACT_SOLUTION_CHARACTERISTIC', 'ID_APPROXIMATE_SOLUTION_CHARACTERISTIC', @@ -34,9 +35,11 @@ ID_HAS_CHARACTERISTIC_RELATIONSHIP = 'KISAO_0000245' # has characteristic -ID_ODE_PROBLEM_CHARACTERISTIC = 'KISAO_0000374' # ordinary differential equation problem ID_SDE_PROBLEM_CHARACTERISTIC = 'KISAO_0000371' # stochastic differential equation problem ID_PDE_PROBLEM_CHARACTERISTIC = 'KISAO_0000372' # partial differential equation problem +ID_DAE_PROBLEM_CHARACTERISTIC = 'KISAO_0000373' # differential algebraic equation problem +ID_ODE_PROBLEM_CHARACTERISTIC = 'KISAO_0000374' # ordinary differential equation problem +ID_STEADYSTATE_PROBLEM_CHARACTERISTIC = 'KISAO_0000696' # steady state root-finding problem ID_EXACT_SOLUTION_CHARACTERISTIC = 'KISAO_0000236' # exact solution ID_APPROXIMATE_SOLUTION_CHARACTERISTIC = 'KISAO_0000237' # approximate solution diff --git a/libkisao/python/kisao/utils.py b/libkisao/python/kisao/utils.py index a065d22..03b88dc 100644 --- a/libkisao/python/kisao/utils.py +++ b/libkisao/python/kisao/utils.py @@ -11,7 +11,9 @@ ID_HAS_CHARACTERISTIC_RELATIONSHIP, ID_ODE_PROBLEM_CHARACTERISTIC, ID_SDE_PROBLEM_CHARACTERISTIC, + ID_STEADYSTATE_PROBLEM_CHARACTERISTIC, ID_PDE_PROBLEM_CHARACTERISTIC, + ID_DAE_PROBLEM_CHARACTERISTIC, ID_EXACT_SOLUTION_CHARACTERISTIC, ID_APPROXIMATE_SOLUTION_CHARACTERISTIC, ID_ALGORITHM, @@ -44,6 +46,7 @@ 'get_rule_based_algorithms', 'get_sde_algorithms', 'get_pde_algorithms', + 'get_dae_algorithms', 'get_flux_balance_algorithms', 'get_logical_simulation_algorithms', 'get_logical_stable_state_search_algorithms', @@ -127,7 +130,7 @@ def get_terms_with_characteristics(parent_ids, characteristic_ids=None): return terms -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_ode_algorithms(): """ Get the terms for ODE integration algorithms:: @@ -139,7 +142,19 @@ def get_ode_algorithms(): return get_terms_with_characteristics([ID_ALGORITHM], [ID_ODE_PROBLEM_CHARACTERISTIC]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) +def get_dae_algorithms(): + """ Get the terms for DAE integration algorithms:: + + 'modelling simulation algorithm' and 'has characteristic' some 'differential algebraic equation problem' + + Returns: + :obj:`set` of :obj:`pronto.Term`: terms + """ + return get_terms_with_characteristics([ID_ALGORITHM], [ID_DAE_PROBLEM_CHARACTERISTIC]) + + +@functools.lru_cache(maxsize=None) def get_gillespie_like_algorithms(exact=True, approximate=False): """ Get the terms for algorithms that execute similar simulations to Gillespie's algorithm (KISAO_0000029). @@ -174,7 +189,7 @@ def get_gillespie_like_algorithms(exact=True, approximate=False): return get_terms_with_characteristics([ID_GILLESPIE_LIKE_ALGORITHM], characteristics) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_tau_leaping_algorithms(): """ Get the terms for tau-leaping algorithms (KISAO_0000039).:: @@ -186,7 +201,7 @@ def get_tau_leaping_algorithms(): return get_terms_with_characteristics([ID_TAU_LEAPING_ALGORITHM]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_rule_based_algorithms(): """ Get the terms for rule-based simulation algorithms (KISAO_0000363).:: @@ -198,7 +213,7 @@ def get_rule_based_algorithms(): return get_terms_with_characteristics([ID_RULE_BASED_ALGORITHM]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_sde_algorithms(): """ Get the terms for rule-based simulation algorithms (KISAO_0000363).:: @@ -210,7 +225,19 @@ def get_sde_algorithms(): return get_terms_with_characteristics([ID_ALGORITHM], [ID_SDE_PROBLEM_CHARACTERISTIC]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) +def get_steadystate_algorithms(): + """ Get the terms for rule-based simulation algorithms (KISAO_0000363).:: + + 'rule-based simulation method' + + Returns: + :obj:`set` of :obj:`pronto.Term`: terms + """ + return get_terms_with_characteristics([ID_ALGORITHM], [ID_STEADYSTATE_PROBLEM_CHARACTERISTIC]) + + +@functools.lru_cache(maxsize=None) def get_pde_algorithms(): """ Get the terms for rule-based simulation algorithms (KISAO_0000363).:: @@ -222,7 +249,7 @@ def get_pde_algorithms(): return get_terms_with_characteristics([ID_ALGORITHM], [ID_PDE_PROBLEM_CHARACTERISTIC]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_flux_balance_algorithms(): """ Get the terms for flux balance algorithms (KISAO_0000622).:: @@ -234,7 +261,7 @@ def get_flux_balance_algorithms(): return get_terms_with_characteristics([ID_FLUX_BALANCE_ALGORITHM]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_logical_simulation_algorithms(): """ Get the terms for logical simulation algorithms (KISAO_0000448).:: @@ -246,7 +273,7 @@ def get_logical_simulation_algorithms(): return get_terms_with_characteristics([ID_LOGICAL_SIMULATION_ALGORITHM]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_logical_stable_state_search_algorithms(): """ Get the terms for algorithms for finding the stable states of logical models (KISAO_0000660).:: @@ -258,7 +285,7 @@ def get_logical_stable_state_search_algorithms(): return get_terms_with_characteristics([ID_LOGICAL_STABLE_STATE_SEARCH_ALGORITHM]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_logical_trap_space_search_algorithms(): """ Get the terms for algorithms for finding the trap spaces of logical models (KISAO_0000661).:: @@ -270,7 +297,7 @@ def get_logical_trap_space_search_algorithms(): return get_terms_with_characteristics([ID_LOGICAL_TRAP_SPACE_SEARCH_ALGORITHM]) -@ functools.lru_cache(maxsize=None) +@functools.lru_cache(maxsize=None) def get_hybrid_algorithms(): """ Get the terms for hybrid algorithms (KISAO_0000352).:: @@ -282,6 +309,16 @@ def get_hybrid_algorithms(): return get_terms_with_characteristics([ID_HYBRID_ALGORITHM]) +@functools.lru_cache(maxsize=None) +def get_parents_and_children_of(term): + """ Get the parents and children of the given term.:: + + Returns: + :obj:`set` of :obj:`pronto.Term`: terms + """ + return get_terms_with_characteristics([ID_HYBRID_ALGORITHM]) + + def get_substitutable_algorithms_for_policy(algorithm, substitution_policy=AlgorithmSubstitutionPolicy.SIMILAR_VARIABLES): """ Get a set of algorithms that an algorithm can be substituted for a given substitution policy. @@ -307,6 +344,7 @@ def get_substitutable_algorithms_for_policy(algorithm, substitution_policy=Algor (True, functools.partial(get_gillespie_like_algorithms, exact=True, approximate=False)), (False, get_tau_leaping_algorithms), (False, get_sde_algorithms), + (False, get_steadystate_algorithms), (False, get_pde_algorithms), (False, get_logical_simulation_algorithms), (True, get_logical_stable_state_search_algorithms), @@ -321,6 +359,7 @@ def get_substitutable_algorithms_for_policy(algorithm, substitution_policy=Algor (True, functools.partial(get_gillespie_like_algorithms, exact=True, approximate=False)), (True, get_tau_leaping_algorithms), (True, get_sde_algorithms), + (True, get_steadystate_algorithms), (True, get_pde_algorithms), (False, get_logical_simulation_algorithms), (True, get_logical_stable_state_search_algorithms), @@ -338,6 +377,7 @@ def get_substitutable_algorithms_for_policy(algorithm, substitution_policy=Algor (True, lambda: get_gillespie_like_algorithms( exact=True, approximate=False) | get_tau_leaping_algorithms()), (True, get_sde_algorithms), + (True, get_steadystate_algorithms), (True, get_pde_algorithms), (True, get_logical_simulation_algorithms), (True, get_logical_stable_state_search_algorithms), @@ -352,6 +392,7 @@ def get_substitutable_algorithms_for_policy(algorithm, substitution_policy=Algor (True, lambda: get_gillespie_like_algorithms( exact=True, approximate=False) | get_tau_leaping_algorithms()), (True, get_sde_algorithms), + (True, get_steadystate_algorithms), (True, get_pde_algorithms), (True, get_flux_balance_algorithms), (True, get_logical_simulation_algorithms), @@ -470,7 +511,7 @@ def get_preferred_substitute_algorithm(algorithm, alt_algorithms, substitution_p )) if alt_algorithm != algorithm: - msg = "'{}' ({}) will be substituted for '{}'' ({}) at substitution policy '{}'.".format( + msg = "'{}' ({}) will be substituted for '{}' ({}) at substitution policy '{}'.".format( alt_algorithm.name, alt_algorithm.id.partition('#')[2], algorithm.name, algorithm.id.partition('#')[2], substitution_policy.name) diff --git a/libkisao/python/tests/test_core.py b/libkisao/python/tests/test_core.py index 4e3192c..df2678a 100644 --- a/libkisao/python/tests/test_core.py +++ b/libkisao/python/tests/test_core.py @@ -67,3 +67,6 @@ def test_get_term_ids(self): self.assertIn('KISAO_0000450', term_ids) self.assertIn('KISAO_0000581', term_ids) self.assertIn('KISAO_0000449', term_ids) + +if __name__ == "__main__": + unittest.main() diff --git a/libkisao/python/tests/test_data_model.py b/libkisao/python/tests/test_data_model.py index 661042e..53b11a4 100644 --- a/libkisao/python/tests/test_data_model.py +++ b/libkisao/python/tests/test_data_model.py @@ -16,3 +16,6 @@ def test(self): ALGORITHM_SUBSTITUTION_POLICY_LEVELS[AlgorithmSubstitutionPolicy.SAME_MATH], ALGORITHM_SUBSTITUTION_POLICY_LEVELS[AlgorithmSubstitutionPolicy.DISTINCT_APPROXIMATIONS], ) + +if __name__ == "__main__": + unittest.main() diff --git a/libkisao/python/tests/test_ontology.py b/libkisao/python/tests/test_ontology.py index fe780fc..22f2120 100644 --- a/libkisao/python/tests/test_ontology.py +++ b/libkisao/python/tests/test_ontology.py @@ -76,3 +76,6 @@ def test_term_names_are_lowercased(self): 'The following terms may have invalid names:\n {}' ).format('\n '.join(sorted(invalid_terms))) warnings.warn(msg) + +if __name__ == "__main__": + unittest.main() diff --git a/libkisao/python/tests/test_utils.py b/libkisao/python/tests/test_utils.py index 7f362f9..1e488ca 100644 --- a/libkisao/python/tests/test_utils.py +++ b/libkisao/python/tests/test_utils.py @@ -44,6 +44,7 @@ def test_sets_of_algorithms_disjoint(self): alg_sets = [ utils.get_ode_algorithms(), utils.get_sde_algorithms(), + utils.get_steadystate_algorithms(), utils.get_pde_algorithms(), utils.get_gillespie_like_algorithms(exact=True, approximate=False), utils.get_gillespie_like_algorithms(exact=False, approximate=True), @@ -72,6 +73,8 @@ def test_ode_algorithms(self): self.assertIn(kisao.get_term('KISAO_0000086'), terms) # Fehlberg method self.assertIn(kisao.get_term('KISAO_0000088'), terms) # LSODA self.assertIn(kisao.get_term('KISAO_0000560'), terms) # LSODA/LSODAR hybrid method + self.assertIn(kisao.get_term('KISAO_0000355'), terms) # DASPK + self.assertIn(kisao.get_term('KISAO_0000283'), terms) # IDA self.assertNotIn(kisao.get_term('KISAO_0000499'), terms) # DFBA @@ -131,13 +134,6 @@ def test_gillespie_like_algorithms(self): (exact_terms | approx_terms).difference(all_terms), set()) - def test_rule_based_algorithms(self): - kisao = Kisao() - terms = utils.get_rule_based_algorithms() - - self.assertIn(kisao.get_term('KISAO_0000263'), terms) # NFSim agent-based simulation method - self.assertIn(kisao.get_term('KISAO_0000362'), terms) # implicit-state Doob-Gillespie algorithm - def test_sde_algorithms(self): kisao = Kisao() odes = utils.get_ode_algorithms() @@ -151,6 +147,40 @@ def test_sde_algorithms(self): self.assertEqual(sdes.intersection(odes), set()) self.assertEqual(sdes.intersection(pdes), set()) + def test_dae_algorithms(self): + kisao = Kisao() + daes = utils.get_dae_algorithms() + odes = utils.get_ode_algorithms() + + self.assertNotIn(kisao.get_term('KISAO_0000019'), daes) # CVODE + self.assertNotIn(kisao.get_term('KISAO_0000030'), daes) # Euler forward + self.assertIn(kisao.get_term('KISAO_0000355'), daes) # DASPK + self.assertIn(kisao.get_term('KISAO_0000283'), daes) # IDA + + self.assertNotIn(kisao.get_term('KISAO_0000499'), daes) # DFBA + + self.assertEqual(daes.intersection(odes), daes) # subset of ODE algorithms + self.assertEqual(daes.intersection(utils.get_gillespie_like_algorithms( + exact=True, approximate=False)), set()) # disjoint from Gillespie-like terms + self.assertEqual(daes.intersection(utils.get_gillespie_like_algorithms( + exact=False, approximate=True)), set()) # disjoint from Gillespie-like terms + + def test_steadystate_algorithms(self): + kisao = Kisao() + terms = utils.get_steadystate_algorithms() + + self.assertIn(kisao.get_term('KISAO_0000407'), terms) # steady state root-finding algorithm + self.assertIn(kisao.get_term('KISAO_0000568'), terms) # NLEQ1 + self.assertIn(kisao.get_term('KISAO_0000569'), terms) # NLEQ2 + self.assertIn(kisao.get_term('KISAO_0000413'), terms) # Exact Newton Method + + self.assertNotIn(kisao.get_term('KISAO_0000499'), terms) # DFBA + + self.assertEqual(terms.intersection(utils.get_hybrid_algorithms()), set()) # disjoint from hybrid terms + self.assertEqual(terms.intersection(utils.get_gillespie_like_algorithms( + exact=True, approximate=False)), set()) # disjoint from Gillespie-like terms + self.assertEqual(terms.intersection(utils.get_ode_algorithms()), set()) # disjoint from ODE terms + def test_pde_algorithms(self): kisao = Kisao() odes = utils.get_ode_algorithms() @@ -398,3 +428,6 @@ def test_get_algorithm_substitution_matrix(self): 'SAME_METHOD') os.remove(filename) + +if __name__ == "__main__": + unittest.main() diff --git a/updating.md b/updating.md new file mode 100644 index 0000000..fd516bc --- /dev/null +++ b/updating.md @@ -0,0 +1,16 @@ +# What needs to be updated when making a new release + +Put new version into: +* libkisao/python/kisao/_version.py +* kisao.owl (i.e. 2.34) +* kisao_full.owl (i.e. 2.34) +* .github/workflows/BioPortal-submission.json + +Summarize changes in: +* CHANGELOG.md + +Then when everything is merged and passes the tests, tag the release: +``` +git tag -a 2.34 -m "version 2.34" +git push origin --tags +```