Confusion on event function
    조회 수: 3 (최근 30일)
  
       이전 댓글 표시
    
Hi all, I want to incorporate an event into my ode45 code. The event is that every time the value y reaches 1 (initial condition 0) it should stop integrating and must restart from zero. I will share the code I have written below. Looks fine, but I am not able to understand how it works. Actually where did I set the event in this code? (I was just imitating a code given in the documentation). If it works for N=1, I need to generalise it for large number of systems. Will that be possible?
N=1;                                                                     
m=0.3;                                          
   %Initial values                                                                      
  ystart=zeros(N,1);
options = odeset('Events',@SpikeEvents,'RelTol',1e-5,'AbsTol',1e-4);
%ODE solver
[t,y,te,ye,ie]=ode45(@ELIF,tspan,ystart,options);
%Plotting
plot(t,y)
xlabel('time')
ylabel('voltage')
title('Leaky IF with spike reset')
%Defining event
%Defining event
function [value,isterminal,direction] = SpikeEvents(t,y)
value = y(1);
isterminal = 1;   % Stop the integration
direction = 1;   
end
%Defining the system of equations
function dydt=ELIF(t,y,m)
N=1;
m=0.3;
dydt=zeros(N,1);
for i=1:N
    dydt(i)=-y(i)+m; %The model equation       
end
end
댓글 수: 0
채택된 답변
  Walter Roberson
      
      
 2018년 10월 26일
        Event functions cannot reset the integration by themselves. Instead what you need to do is configure the event function to signal termination, and then you need to loop, something like
K = 1;
start_time = tspan(1);
end_time = tspan(2);
time_tolerance = 1e-3;
y0 = ystart;
while true
  [t{K}, y{K}, te{K}, ye{K}, ie{K}]=ode45(@ELIF, [start_time end_time], ystart, options);
  ended_at = t{K}(end);
  if end_time - ended_at <= time_tolerance
    break;
  end
  start_time = ended_at;
  y0 = y{K}(end,:);
  y0(1) = 0;   %restart integration from 0
  K = K + 1;
end
Then the overall path would be found be concatenating together all of the t{:} and y{:}, except omitting the overlap time point.
댓글 수: 6
  Steven Lord
    
      
 2018년 10월 26일
				The standard simple example I point people to when trying to explain ODE solver events is the ballode example. It's similar to the one Walter posted, though it grows the arrays of output in its for loop rather than using cell arrays.
추가 답변 (1개)
  Vipin  Padinjarath
 2018년 10월 30일
        댓글 수: 12
  Walter Roberson
      
      
 2018년 12월 8일
				
      편집: Walter Roberson
      
      
 2018년 12월 12일
  
			y-1
if you want to test all of the y values at the same time which is what I have interpreted your question about simultaneous systems to be .
참고 항목
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



