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

Implement ODE solvers #75

Closed
ViralBShah opened this issue Jun 22, 2011 · 37 comments
Closed

Implement ODE solvers #75

ViralBShah opened this issue Jun 22, 2011 · 37 comments
Labels
help wanted Indicates that a maintainer wants help on an issue or pull request

Comments

@ViralBShah
Copy link
Member

A quick and easy way to get ode23 and ode45 like in MATLAB is:

http://www.netlib.org/ode/rksuite/

The state of the art is SUNDIALS, but it is no longer maintained. The lead developer went to develop video games! It is widely used in the national labs, and can give us ode15s.

https://computation.llnl.gov/casc/sundials/main.html

The long term strategy may simply be to implement these solvers in julia itself. The design of the Matlab ODE suite is described in:

http://www.mathworks.com/help/pdf_doc/otherdocs/ode_suite.pdf

@ViralBShah
Copy link
Member Author

Move ode23 and ode45 from examples/ to j/ in commit 8475705. Can close this one once we have a basic ode15s implementation.

@rgbrown
Copy link

rgbrown commented Oct 10, 2012

Just a comment -- since your initial post there has been a new release of SUNDIALS (in March this year -- the first in 3 years). Worth giving it another look?

@vtjnash
Copy link
Member

vtjnash commented Feb 1, 2013

@ViralBShah can we close this, as something for an eventual package contribution (or move it to a special place for issues pertaining to desirable packages)?

@ViralBShah
Copy link
Member Author

I think we can close this. This will certainly be a package.

@stevengj
Copy link
Member

There doesn't seem to be a package for this yet, and the ODE code mentioned above seems to have disappeared from Julia.

ODE solvers are bread and butter for numerics; this really needs to be done. It is especially important because this is an area where Julia can really shine: small systems of ODEs are difficult to vectorize, so in other dynamic languages you are basically forced to drop down to C if you need it to be fast.

@stevengj stevengj reopened this Mar 11, 2013
@aviks
Copy link
Member

aviks commented Mar 11, 2013

The ODE code in extras is now in a package: https://github.com/vtjnash/ODE.jl

@pao
Copy link
Member

pao commented Mar 11, 2013

As there is definitely a package, going to reclose this.

@pao pao closed this as completed Mar 11, 2013
@stevengj
Copy link
Member

Sorry, got fooled by the 0.1 package listing, which is missing ODE.jl.

Are there any benchmarks (accuracy vs. number of function evaluations) of how this compares with existing ODE packages (e.g. Matlab, GSL, SUNDIALS...)? i.e. Do we have a competitive implementation or something half-baked?

@pao
Copy link
Member

pao commented Mar 11, 2013

I don't think so. Viral ported some of them from Octave; I added a few others from lecture notes from a dynamics simulation course I took. I think all we know is that they don't work particularly well in general (well, except for RK4). A good testsuite with appropriate problems would be a good place to start. Rewriting the whole thing is not out of the question; Julia's changed a lot in the past year or so.

@ViralBShah
Copy link
Member Author

What is the way to go forward here? In the past, I have used rksuite from netlib to get ode23 and ode45 capabilities similar to matlab, and sundials for stiff and multi-step solvers. I am not sure how actively sundials is maintained now, though. If GSL's ODE solvers are maintained, and they are considered to be good, that could be a way forward.

In any case, a good testsuite would certainly help. There are lots of ODE testsuites out there, which we could pick from, rather than develop one from scratch.

@ViralBShah
Copy link
Member Author

ode23 comes from Cleve's textbook, and ode45 is ported from octave. We need a serious effort for ODE stuff - this was just some fun stuff we put along the way, and it is all half-baked.

@pao
Copy link
Member

pao commented Mar 12, 2013

https://github.com/tshort/Sundials.jl exists now, too.

@ViralBShah
Copy link
Member Author

Sweet!

@stevengj
Copy link
Member

We should really have a solid (production-quality, not textbook quality) implementation of (at least) ode45 in Base, supporting arbitrary normed vector spaces (any type supporting +, -, * by Real, and norm), similar to quadgk, in addition to any external package.

An external package (especially one whose README says, "Some of these solvers are known to be produce incorrect results" — apparently not production quality!) is not really sufficient. And wrappers around C libraries (though valuable!) will never support arbitrary types (not to mention BigFloat and other general numeric types).

@stevengj stevengj reopened this Jul 22, 2013
@vellamike
Copy link

Is there any progress on this?

@ViralBShah
Copy link
Member Author

I really would like to see Sundials.jl and a good ode45 from ODE.jl in Base. No progress on this front yet, but the packages are quite usable.

@glesica
Copy link

glesica commented Mar 3, 2014

I'm interested in putting some effort into this. I'm an MS student in CS. I'm definitely not a domain expert (although I'm not completely ignorant either), but since I can almost certainly integrate (hehe) anything I do here into my thesis work (DEM simulation in Julia) I've got some time to pour into it.

My first instinct would be to port the ODE code from SciPy (http://docs.scipy.org/doc/scipy/reference/tutorial/integrate.html) since I've worked with it before. This group might want to go in a different direction and that would be fine too. Any suggestions or nuggets of wisdom?

@ivarne
Copy link
Member

ivarne commented Mar 3, 2014

I would read up on the issues in https://github.com/JuliaLang/ode.jl, especially SciML/ODE.jl#7, where API discussions take place right now. The current sentiment is to remove things from Base and have a set of default packages that will be installed with Julia, so I do not think a ODE solver belongs in a shrinked core.

@ivarne
Copy link
Member

ivarne commented Mar 3, 2014

And of course also the GSOC issue SciML/ODE.jl#18. Whether you are interested in that or not, all the advise will be perfect for someone wanting to get into the project.

@ViralBShah
Copy link
Member Author

What we need is to clean up the APIs in ODE.jl, and Sundials.jl, document them, have good tests, etc. If we can do some of this, it would be nice to then have some of the pure julia ODEs in base. It would not be a whole lot of code.

@stevengj
Copy link
Member

stevengj commented Mar 5, 2014

@ViralBShah, regarding putting this in Base, one problem is that some of the ODE.jl code is derived from Octave, as I understand it, and thus is GPLed.

Regarding unifying the API, it might also be nice to use the same API in @jiahao's GSL package.

@StefanKarpinski
Copy link
Member

I don't really understand why we should have any ODE code in Base. This strikes me as a legacy of Matlab that doesn't really make much sense. Honestly, a lot of the linear algebra stuff that's in Base right now should probably not be.

@tknopp
Copy link
Contributor

tknopp commented Mar 5, 2014

Sounds like a great candidate for a "default package" (#1906, #5155)

@jtravs
Copy link
Contributor

jtravs commented Mar 5, 2014

One way around the licensing issue is to derive codes from the solvers at:
http://www.unige.ch/~hairer/software.html

In particular the MATLAB ode45 is very similar to the dopri5 code at:
http://www.unige.ch/~hairer/prog/nonstiff/dopri5.f
and this is the same set of coefficients used in ODE.jl (the Dormand and Prince pair).
These solvers are BSD licensed, are of very high quality, are theoretically explained in detail in the books by the authors:
Hairer, Norsett and Wanner (1993): Solving Ordinary Differential Equations. Nonstiff Problems. 2nd edition. Springer Series in Comput. Math., vol. 8.

What is particularly nice about dopri5 is the dense output. i.e. if the ODE solver takes a natural step from t0 to t1 based on the error control, dense output is efficiently available anywhere between t0 and t1.

@stevengj
Copy link
Member

stevengj commented Mar 5, 2014

@jtravs, I like the idea of porting dopri5.

@StefanKarpinski, I feel like an adaptive non-stiff ODE solver is one of the basic building blocks of numerical methods, along with dense linear algebra, smooth quadrature, special functions, and FFTs. Furthermore, unlike (e.g.) iterative solvers or multidimensional integration, there is pretty much one "default" way to integrate non-stiff ODEs that 99% of people use (adaptive 5th-order Runge-Kutta) and which continues to be a well-regarded method by experts. This, to me, makes ode45 a good candidate to go into Base (once an implementation stabilizes).

@StefanKarpinski
Copy link
Member

Ok, I guess. I'm biased by what I use, which is never ODEs. For what it's worth, I also think that FFTs could really be in a package, as could smooth quadrature, and special functions. Dense linear algebra, on the other hand, I use all the time, even when I'm not doing something obviously numerical.

@acroy
Copy link
Contributor

acroy commented Mar 5, 2014

@jtravs, @stevengj : I think the implementations based on embedded RK pairs (Dormand-Prince et al) are all fairly similar. You can also find one in Numerical Recipes Chap 17.2 (including dense output), which might not be suitable license-wise. But Hairer is of course an excellent resource for all kind of solvers.

Just as an info: The current code in ODE.jl was based on an implementation for Octave (the latest version can be found here), which supported only Dormand-Prince and Fehlberg 4(5) pairs. Meanwhile our code is able to handle other pairs (Cash-Karp 4(5) and Bogacki–Shampine 2(3)) and has support for both reltol and abstol.

@stevengj
Copy link
Member

stevengj commented Mar 5, 2014

Unfortunately, if you started with the Octave code, it is still a derived work and hence still GPL no matter how many improvements you make.

@acroy
Copy link
Contributor

acroy commented Mar 6, 2014

Yeah, I had a chat about that with @pao (who ported the code to Julia). I guess what I was trying to say is that DOPRI5 would duplicate to some extent functionality we already have (to me dense output is a very nice, but independent feature), which happens to be GPLed.

If you want to have a swiss-knife non-stiff solver in Base I would rather suggest to look into DOP853 by Hairer, which uses a different RK pair and is also recommended by NR for production work (Chapter 17.2.4).

@jtravs
Copy link
Contributor

jtravs commented Mar 6, 2014

Well I've used both DOPRI5 and DOP853 extensively, and while the literature always seems to promote the latter, I usually find DOPRI5 is significantly more efficient for my problems and target tolerances. I think the second point is critical though, for high tolerances DOP853 wins.

Given that the fortran codes are almost identical between them, I don't think it is hard to have julia versions of both within the same framework - as you were previously suggesting for other RK coefficients.

BTW, dense output is not really independent - the beauty of DOPRI5 is that it has a very fortunate, high accuracy and very efficient dense output developed by Shampine (for Matlab I think), included. Other dense output routines often need further function evaluations.

BTW2: I was only noting these codes here, so that they can be considered in case a decision to rework ODE.jl was taken - I haven't got time to do it, so clearly my influence is minimal!!

@pao
Copy link
Member

pao commented Mar 6, 2014

Yeah, I had a chat about that with @pao (who ported the code to Julia).

To clarify: I believe @ViralBShah did the initial port of ode45 from Octave. I refactored it afterwards. Not that it changes the licensing question, just don't want to take credit for his work.

@acroy
Copy link
Contributor

acroy commented Mar 6, 2014

@ViralBShah, @pao: Sorry! Obviously I mixed that up ...

@Nicksol
Copy link

Nicksol commented Mar 15, 2014

There are disscusions developing ODE solver as GSOC project in SciML/ODE.jl#18 .I have posted some ideas and looking forward for comments.

@mauro3
Copy link
Contributor

mauro3 commented Dec 2, 2014

This issue should probably be closed as there is https://github.com/JuliaLang/ODE.jl (and a few other independent ODE packages), where this discussion should take place.

@ivarne
Copy link
Member

ivarne commented Dec 2, 2014

Yes I think you are right. There is no simple and obviously right algorithm for a ODE solver, so we will need packages for advanced usage anyway. Adding too much functionality in Base will also potentially be a problem for memory constrained systems, so there has been numerous suggestions that we should split up and load more things "on demand" (hopefully from a cached precompilled package).

@ivarne ivarne closed this as completed Dec 2, 2014
@acroy
Copy link
Contributor

acroy commented Jan 31, 2015

@11718pauld : The discussion has partly been continued in SciML/ODE.jl#18 and I think RADAU was mentioned there as well.

StefanKarpinski pushed a commit that referenced this issue Feb 8, 2018
tests pass locally on v0.6.1
cmcaine pushed a commit to cmcaine/julia that referenced this issue Sep 24, 2020
Generate static exercise README templates
LilithHafner pushed a commit to LilithHafner/julia that referenced this issue Oct 11, 2021
Keno pushed a commit that referenced this issue Oct 9, 2023
Don't recurse into Base.Threads. Fixes #74
inkydragon pushed a commit that referenced this issue Dec 15, 2024
Stdlib: SHA
URL: https://github.com/JuliaCrypto/SHA.jl.git
Stdlib branch: master
Julia branch: master
Old commit: aaf2df6
New commit: 8fa221d
Julia version: 1.12.0-DEV
SHA version: 0.7.0(Does not match)
Bump invoked by: @inkydragon
Powered by:
[BumpStdlibs.jl](https://github.com/JuliaLang/BumpStdlibs.jl)

Diff:
JuliaCrypto/SHA.jl@aaf2df6...8fa221d

```
$ git log --oneline aaf2df6..8fa221d
8fa221d ci: update doctest config (#120)
346b359 ci: Update ci config (#115)
aba9014 Fix type mismatch for `shake/digest!` and setup x86 ci (#117)
0b76d04 Merge pull request #114 from JuliaCrypto/dependabot/github_actions/codecov/codecov-action-5
5094d9d Update .github/workflows/CI.yml
45596b1 Bump codecov/codecov-action from 4 to 5
230ab51 test: remove outdate tests (#113)
7f25aa8 rm: Duplicated const alias (#111)
aa72f73 [SHA3] Fix padding special-case (#108)
3a01401 Delete Manifest.toml (#109)
da351bb Remvoe all getproperty funcs (#99)
4eee84f Bump codecov/codecov-action from 3 to 4 (#104)
15f7dbc Bump codecov/codecov-action from 1 to 3 (#102)
860e6b9 Bump actions/checkout from 2 to 4 (#103)
8e5f0ea Add dependabot to auto update github actions (#100)
4ab324c Merge pull request #98 from fork4jl/sha512-t
a658829 SHA-512: add ref to NIST standard
11a4c73 Apply suggestions from code review
969f867 Merge pull request #97 from fingolfin/mh/Vector
b1401fb SHA-512: add NIST test
4d7091b SHA-512: add to docs
09fef9a SHA-512: test SHA-512/224, SHA-512/256
7201b74 SHA-512: impl SHA-512/224, SHA-512/256
4ab85ad Array -> Vector
8ef91b6 fixed bug in padding for shake, addes testcases for full code coverage (#95)
88e1c83 Remove non-existent property (#75)
068f85d shake128,shake256: fixed typo in export declarations (#93)
176baaa SHA3 xof shake128 and shake256  (#92)
e1af7dd Hardcode doc edit backlink
```

Co-authored-by: Dilum Aluthge <[email protected]>
stevengj pushed a commit that referenced this issue Jan 2, 2025
Stdlib: SHA
URL: https://github.com/JuliaCrypto/SHA.jl.git
Stdlib branch: master
Julia branch: master
Old commit: aaf2df6
New commit: 8fa221d
Julia version: 1.12.0-DEV
SHA version: 0.7.0(Does not match)
Bump invoked by: @inkydragon
Powered by:
[BumpStdlibs.jl](https://github.com/JuliaLang/BumpStdlibs.jl)

Diff:
JuliaCrypto/SHA.jl@aaf2df6...8fa221d

```
$ git log --oneline aaf2df6..8fa221d
8fa221d ci: update doctest config (#120)
346b359 ci: Update ci config (#115)
aba9014 Fix type mismatch for `shake/digest!` and setup x86 ci (#117)
0b76d04 Merge pull request #114 from JuliaCrypto/dependabot/github_actions/codecov/codecov-action-5
5094d9d Update .github/workflows/CI.yml
45596b1 Bump codecov/codecov-action from 4 to 5
230ab51 test: remove outdate tests (#113)
7f25aa8 rm: Duplicated const alias (#111)
aa72f73 [SHA3] Fix padding special-case (#108)
3a01401 Delete Manifest.toml (#109)
da351bb Remvoe all getproperty funcs (#99)
4eee84f Bump codecov/codecov-action from 3 to 4 (#104)
15f7dbc Bump codecov/codecov-action from 1 to 3 (#102)
860e6b9 Bump actions/checkout from 2 to 4 (#103)
8e5f0ea Add dependabot to auto update github actions (#100)
4ab324c Merge pull request #98 from fork4jl/sha512-t
a658829 SHA-512: add ref to NIST standard
11a4c73 Apply suggestions from code review
969f867 Merge pull request #97 from fingolfin/mh/Vector
b1401fb SHA-512: add NIST test
4d7091b SHA-512: add to docs
09fef9a SHA-512: test SHA-512/224, SHA-512/256
7201b74 SHA-512: impl SHA-512/224, SHA-512/256
4ab85ad Array -> Vector
8ef91b6 fixed bug in padding for shake, addes testcases for full code coverage (#95)
88e1c83 Remove non-existent property (#75)
068f85d shake128,shake256: fixed typo in export declarations (#93)
176baaa SHA3 xof shake128 and shake256  (#92)
e1af7dd Hardcode doc edit backlink
```

Co-authored-by: Dilum Aluthge <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Indicates that a maintainer wants help on an issue or pull request
Projects
None yet
Development

No branches or pull requests