How to stop ode45 when value reach certain value other-than zero

I need to stop the ode when y(2) is 0.2 and here is the function I used for the solver but It doesn't work. Any thing wrong with it ?
function [val, terminate, dir]= stopevents(t,y)
val=(y(2)==0.2)-0.5;
terminate=1;
dir=0;
end

Answers (2)

An event occurs when value(i) is equal to zero.
function [value, terminate, direction] = stopevents(t, y)
value = y(2) - 0.2;
terminate = 1;
direction = 0;
end
The event function must be smooth. It is extremely unlikely, that the integration meets the point y(2)==0.2 exactly. Therefore your event function does not trigger. In addtion:
val = (y(2)==0.2)-0.5;
replies -0.5 or 0.5, but never 0, which would trigger the event.
By the way: Avoid using "dir" as name of a variable, because this shadows an important built-in function.

5 Comments

Thanks for the comment. Like you said it never reached 0.2. But, is there any way/means that might trigger stopping events other than this ?
Just adjust the events function from ballode.m to return ZERO for the value you want to flag an event. Something like this:
function [value,isterminal,direction] = events(t,y)
% Locate the time when height passes through zero in a decreasing direction
% and stop integration.
value = y(1)-your_val; % detect height = 0
isterminal = 1; % stop the integration
direction = -1; % negative direction
Then it should trigger the event, and your ODE-function will know how to refine the solution around that.
HTH
@Dereje: I do not understand your comment. It is unlikely the the integration hits 0.2 exactly, because it proceeds in steps. Uing value = y(2) - 0.2 let the integrator locate the time, where y(2) is exactly 0.2, because it detects that this function changes its sign. But with value=(y(2)==0.2)-0.5 this detection cannot work.
What do you mean by "other than this"? I've posted a working solution.
@Jan y(2)-0.2 is not working that is why I asked you but it works for zero.May be something is wrong with my code. @Bjorn Gustavsson Thanks for the detailed clarification.
@jan: I guess what was meant with y(2) is y(t) for t=2, and not the second component of y

Sign in to comment.

You should be able to use the "events handling", look at the code for ballode.m for an example on how to handle it.
HTH

Categories

Find more on App Building in Help Center and File Exchange

Asked:

on 26 Apr 2018

Commented:

on 27 Apr 2018

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!