Skip to content

Commit

Permalink
Merge pull request #53 from tkoolen/periodic-callback
Browse files Browse the repository at this point in the history
Add PeriodicCallback docs
  • Loading branch information
ChrisRackauckas authored Oct 17, 2017
2 parents 5311c27 + 747876c commit 36f2b36
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 5 deletions.
1 change: 1 addition & 0 deletions REQUIRE
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
julia 0.5
DiffEqProblemLibrary
2 changes: 1 addition & 1 deletion docs/make.jl
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ makedocs(modules=[DiffEqPDEBase,DiffEqProblemLibrary],
"models/physical.md",
"models/financial.md",
"models/biological.md",
"models/eternal_modeling.md"
"models/external_modeling.md"
]
])

Expand Down
19 changes: 15 additions & 4 deletions docs/src/features/callback_library.md
Original file line number Diff line number Diff line change
Expand Up @@ -212,11 +212,11 @@ StepsizeLimiter(dtFE;safety_factor=9//10,max_step=false,cached_dtcache=0.0)
solver is set to `adaptive=false`.
- `cached_dtcache`: Should be set to match the type for time when not using
Float64 values.

## SavingCallback

The saving callback lets you define a function `save_func(t, u, integrator)` which
returns quantities of interest that shall be saved.
returns quantities of interest that shall be saved.

### Constructor

Expand All @@ -227,11 +227,22 @@ SavingCallback(save_func, saved_values::SavedValues;
tdir=1)
```
- `save_func(t, u, integrator)` returns the quantities which shall be saved.
- `saved_values::SavedValues` contains vectors `t::Vector{tType}`,
`saveval::Vector{savevalType}` of the saved quantities. Here,
- `saved_values::SavedValues` contains vectors `t::Vector{tType}`,
`saveval::Vector{savevalType}` of the saved quantities. Here,
`save_func(t, u, integrator)::savevalType`.
- `saveat` Mimicks `saveat` in `solve` for ODEs.
- `save_everystep` Mimicks `save_everystep` in `solve` for ODEs.
- `tdir` should be `sign(tspan[end]-tspan[1])`. It defaults to `1` and should
be adapted if `tspan[1] > tspan[end]`.

## PeriodicCallback

`PeriodicCallback` can be used when a function should be called periodically in terms of integration time (as opposed to wall time), i.e. at `t = tspan[1]`, `t = tspan[1] + Δt`, `t = tspan[1] + 2Δt`, and so on. This callback can, for example, be used to model a digital controller for an analog system, running at a fixed rate.

### Constructor

```julia
PeriodicCallback(f, Δt::Number; kwargs...)
```

where `f` is the function to be called periodically, `Δt` is the period, and `kwargs` are keyword arguments accepted by the `DiscreteCallback` constructor (see the [DiscreteCallback](@ref) section).

0 comments on commit 36f2b36

Please sign in to comment.