Re: More Anomalous Behaviour with Indexed Variables
- To: mathgroup at smc.vnet.net
- Subject: [mg3317] Re: [mg3256] More Anomalous Behaviour with Indexed Variables
- From: Mark James <mrj at cs.usyd.edu.au>
- Date: Mon, 26 Feb 1996 02:55:27 -0500
- Organization: The University of Sydney
- Sender: owner-wri-mathgroup at wolfram.com
Jens-Peer Kuska wrote: > Hi Mark, > > at first > I think that it is really dangerous to use sutch side > effect, because there is *no* guarantie that NDSolve evaluate > the differential equations in the same order as given. NDSolve > has to do a lot of things bevore it can start with the numerical > solution. That's true, but the benefits are too hard to resist. It has sped my code up by a factor of three. I hope it will still work in 3.0. Even better, I'd like to see a parameter for NDSolve where one can specify a function to be called at the beginning of every integration step. > at second > don't talk about efficient solutions, Mathematica is a interpreter > and will be allways 100 or more times slower than a compiled > code. You can still using Mathematica via MathLink for dawing and post processing. True too. I have considered doing this, though it would involve buying a C compiler, choosing an algorithm, finding appropriate code on the net, purchasing an MMA version that has Mathlink, and working out how to make Mathlink work. I will have to do this eventually when my simulations get larger. Your solution using list indexing rather than function definitions will not work, as initializing f results in f[[1]] being replaced by 0 when the equations are initially evaluated by NDSolve. Updates in f[[1]] will never be used. TracePrint displays this: (* PARAMETER IS: f[[1]] *) Clear[ f, calc ]; f={0.}; calc[ v_Real ] := ( f[[1]] = Sqrt[v]; 0 ); TracePrint[ NDSolve[ {dummy'[t]==calc[p[t]], dummy[0]==0, p'[t] == -p[t] + f[[1]], p[0]==0 }, {dummy,p}, {t,0,1}, Compiled->False ] , TraceDepth->1 ] Frans Martens has send me a solution that works, both on this simple example and my realworld system. For the example system it involves simply replacing f[1] by f[1.] in the defintion of calc. Apparently NDSolve coerces all function indices to reals. All my integration variable and equation parameters are now indexed by reals. Thanks for taking the time to have a look at this. -- Mark ==== [MESSAGE SEPARATOR] ====