Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

@require_declaration docs #1129

Merged
merged 8 commits into from
Nov 20, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions HISTORY.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,22 @@
StructuralIdentifiability has with Julia 1.10.5 and 1.11.
- A tutorial on making interactive plot displays using Makie has been added.
- The BifurcationKit extension has been updated to v.4.
- There is a new DSL option `@require_declaration` that will turn off automatic inferring for species, parameters, and variables in the DSL. For example, the following will now error:
```julia
rn = @reaction_network begin
@require_declaration
(k1, k2), A <--> B
end
```
When this flag is set, all symbolics must be explicitly declared.
```julia
rn = @reaction_network begin
@species A(t) B(t)
@parameters k1 k2
@require_declaration
(k1, k2), A <--> B
end
```

## Catalyst 14.4.1
- Support for user-defined functions on the RHS when providing coupled equations
Expand Down
13 changes: 13 additions & 0 deletions docs/src/faqs.md
Original file line number Diff line number Diff line change
Expand Up @@ -309,3 +309,16 @@ end
In some cases, it may be necessary or desirable to register functions with
Symbolics.jl before their use in Catalyst, see the discussion
[here](https://symbolics.juliasymbolics.org/stable/manual/functions/).

## How can I turn off automatic inferring of species and parameters when using the DSL?
This option can be set using the `@require_declaration` option inside `@reaction_network`. In this case all the species, parameters, and variables in the system must be pre-declared using one of the `@species`, `@parameters`, or `@variables` macros. For more information about what is inferred automatically and not, please see the section on [`@require_declaration`](@dsl_advanced_options_require_dec).

```@example faq9
using Catalyst
rn = @reaction_network begin
@require_declaration
@species A(t) B(t)
@parameters k1 k2
(k1, k2), A <--> B
end
```
32 changes: 31 additions & 1 deletion docs/src/model_creation/dsl_advanced.md
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@ ModelingToolkit.getdescription(two_state_system.kA)

### [Designating constant-valued/fixed species parameters](@id dsl_advanced_options_constant_species)

Catalyst enables the designation of parameters as `constantspecies`. These parameters can be used as species in reactions, however, their values are not changed by the reaction and remain constant throughout the simulation (unless changed by e.g. the [occurrence of an event]@ref constraint_equations_events). Practically, this is done by setting the parameter's `isconstantspecies` metadata to `true`. Here, we create a simple reaction where the species `X` is converted to `Xᴾ` at rate `k`. By designating `X` as a constant species parameter, we ensure that its quantity is unchanged by the occurrence of the reaction.
Catalyst enables the designation of parameters as `constantspecies`. These parameters can be used as species in reactions, however, their values are not changed by the reaction and remain constant throughout the simulation (unless changed by e.g. the [occurrence of an event](@ref constraint_equations_events). Practically, this is done by setting the parameter's `isconstantspecies` metadata to `true`. Here, we create a simple reaction where the species `X` is converted to `Xᴾ` at rate `k`. By designating `X` as a constant species parameter, we ensure that its quantity is unchanged by the occurrence of the reaction.
```@example dsl_advanced_constant_species
using Catalyst # hide
rn = @reaction_network begin
Expand Down Expand Up @@ -272,6 +272,36 @@ sol = solve(oprob)
plot(sol)
```

### [Turning off species, parameter, and variable inferring](@id dsl_advanced_options_require_dec)
vyudu marked this conversation as resolved.
Show resolved Hide resolved
In some cases it may be desirable for Catalyst to not infer species and parameters from the DSL, as in the case of reaction networks with very many variables, or as a sanity check that variable names are written correctly. To turn off inferring, simply add the `@require_declaration` macro to one of the lines of the `@reaction_network` declaration. Having this macro means that every single variable, species, or parameter will have to be explicitly declared using the `@variable`, `@species`, or `@parameter` macro. In the case that the DSL parser encounters an undeclared symbolic in this case, it will error with an `UndeclaredSymbolicError` and print the reaction or equation that the undeclared symbolic was found in.
vyudu marked this conversation as resolved.
Show resolved Hide resolved

```@example dsl_advanced_no_infer
using Catalyst
# The following case will throw an UndeclaredSymbolicError.
rn = @reaction_network begin
@require_declaration
(k1, k2), A <--> B
end
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To keep Documenter.jl from failing the build you probably need to catch the error here. (Otherwise just don't make this dynamic and manually paste in the output.)

```
In order to avoid an error in this case all the relevant species and parameters will have to be declared.
```
# The following case will not error.
t = default_t()
rn = @reaction_network begin
@require_declaration
@species A(t) B(t)
@parameters k1 k2
(k1, k2), A <--> B
end
```

The following cases in which the DSL would normally infer variables will all throw errors if `@require_declaration` is set and the variables are not explicitly declared.
- Inferring a species in a reaction, as in the example above
vyudu marked this conversation as resolved.
Show resolved Hide resolved
- Inferring a parameter in a reaction rate expression, as in the reaction line `k*n, A --> B`
vyudu marked this conversation as resolved.
Show resolved Hide resolved
- Inferring a parameter in the stoichiometry of a species, as in the reaction line `k, n*A --> B`
- Inferring a differential variable on the LHS of a coupled differential equation, as in `A` in `@equations D(A) ~ A^2`
- Inferring an [observable](@dsl_advanced_options_observables) that is declared using `@observables`

## [Naming reaction networks](@id dsl_advanced_options_naming)
Each reaction network model has a name. It can be accessed using the `nameof` function. By default, some generic name is used:
```@example dsl_advanced_names
Expand Down
Loading