[OctDev] A Bug in Octave-OdePkg

Wang Long mr.wang.long at gmail.com
Wed Oct 8 03:23:17 BST 2008


On Tue, 2008-10-07 at 23:01 +0200, Thomas Treichl wrote:
> Wang Long schrieb:
> > Hi,
> > 
> > When I was running this in octave:
> > 
> > 	t_in = [0 0.05 0.13 0.19];
> > 	[t_out, y] = ode45 (@(t,x) x, t_in, 1);
> > 
> > I got t_out=[0.00000   0.05000   0.10000   0.15000   0.19000]. While the
> > length of t_in is 4, I found that of t_out is 5 instead of 4. However
> > the length of t_in and t_out should be identical. This bug also exists
> > in ode23, ode54, ode78, etc.
> > 
> > I'm using octave on Ubuntu, and the file "ode45.m" belongs to the
> > package "octave-odepkg" version 0.6.0-1.
> > 
> > Any ideas? Thank you all.
> > 
> > Regards,
> > Wang Long
> 
> Hi Wang,
> 
> please change line number 406 (file ode45.m) originally from
> 
>    vstepsize = vslot(1,vcntloop-1) - vslot(1,vcntloop-2);
> 
> into
> 
>    vstepsize = vslot(vcntloop) - vslot(vcntloop-1);
> 
> Does this fix the ode45 problem for the 0.6.0 release of the package? At least 
> it seems to fix the problem for the latest sources and the next package that 
> will become available.
> 
>    Thomas

Hi Thomas,

Thank you very much in helping me with this problem! The solution in
your email solved the problem I mentioned before, but when I tried some
other t_in's, for example,
  t_in_2=[0.00 0.10 0.23 0.38 0.63 1.21 1.97];
  t_in_3=[0.00 0.03 0.05 0.11 0.17 0.25 0.38 0.47 0.68 0.91 1.38 1.98];
it seems that the same problem comes out again in the 0.6.0 release of
odepkg :(  

I examined the improper t_out's, and found that every element in them is
identical to t_in's, respectively, except those at ``t_out(end-1)'',
which is created by ode45. Therefore, can we simply make ode45 check the
length of t_out, and delete certain elements of t_out (and ``y'', of
course) if the length of t_out is larger than t_in?

Thanks!

Regards,
Wang Long





More information about the Ubuntu-motu mailing list