Skip to content

Commit

Permalink
move symbolic details to Symbolics docs
Browse files Browse the repository at this point in the history
  • Loading branch information
ArnoStrouwen committed Oct 5, 2024
1 parent 7d7316e commit 90567a0
Show file tree
Hide file tree
Showing 3 changed files with 3 additions and 75 deletions.
1 change: 0 additions & 1 deletion docs/pages.jl
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ pages = [
"Basic Examples" => Any["examples/higher_order.md",
"examples/spring_mass.md",
"examples/modelingtoolkitize_index_reduction.md",
"examples/parsing.md",
"examples/remake.md"],
"Advanced Examples" => Any["examples/tearing_parallelism.md",
"examples/sparse_jacobians.md",
Expand Down
33 changes: 0 additions & 33 deletions docs/src/examples/parsing.md

This file was deleted.

44 changes: 3 additions & 41 deletions docs/src/tutorials/programmatically_generating.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,51 +59,13 @@ plot(sol)
As you can see, generating an ODESystem is as simple as creating an array of equations
and passing it to the `ODESystem` constructor.

## Understanding the Difference Between the Julia Variable and the Symbolic Variable

In the most basic usage of ModelingToolkit and Symbolics, the name of the Julia variable
and the symbolic variable are the same. For example, when we do:

```@example scripting
@variables a
```

the name of the symbolic variable is `a` and same with the Julia variable. However, we can
de-couple these by setting `a` to a new symbolic variable, for example:

```@example scripting
b = only(@variables(a))
```

Now the Julia variable `b` refers to the variable named `a`. However, the downside of this current
approach is that it requires that the user writing the script knows the name `a` that they want to
place to the variable. But what if for example we needed to get the variable's name from a file?

To do this, one can interpolate a symbol into the `@variables` macro using `$`. For example:

```@example scripting
a = :c
b = only(@variables($a))
```

In this example, `@variables($a)` created a variable named `c`, and set this variable to `b`.

Variables are not the only thing with names. For example, when you build a system, it knows its name
that name is used in the namespacing. In the standard usage, again the Julia variable and the
symbolic name are made the same via:

```@example scripting
@named fol_model = ODESystem(eqs, t)
```

However, one can decouple these two properties by noting that `@named` is simply shorthand for the
following:
`@named` automatically gives a name to the `ODESystem`, and is shorthand for

```@example scripting
fol_model = ODESystem(eqs, t; name = :fol_model)
fol_model = ODESystem(eqs, t; name = :fol_model) # @named fol_model = ODESystem(eqs, t)
```

Thus if we had read a name from a file and wish to populate an `ODESystem` with said name, we could do:
Thus, if we had read a name from a file and wish to populate an `ODESystem` with said name, we could do:

```@example scripting
namesym = :name_from_file
Expand Down

0 comments on commit 90567a0

Please sign in to comment.