powblk
subroutine powblk(flag,nevprt,t,xd,x,nx,z,nz,tvec,ntvec,
& rpar,nrpar,ipar,nipar,u,nu,y,ny)
c Copyright INRIA
c Scicos block simulator
c rpar(1) is power
c
double precision t,xd(*),x(*),z(*),tvec(*),rpar(*),u(*),y(*)
integer flag,nevprt,nx,nz,ntvec,nrpar,ipar(*)
integer nipar,nu,ny
c
c
if (nrpar.eq.1) then
do 15 i=1,nu
if(u(i).lt.0.d0) then
if (flag.ge.4) return
flag=-2
return
elseif(u(i).eq.0.d0.and.rpar(1).le.0) then
if (flag.ge.4) return
flag=-2
return
endif
y(i)=u(i)**rpar(1)
15 continue
else
do 25 i=1,nu
if(ipar(1).le.0.and.u(i).eq.0.0d0) then
if (flag.ge.4) return
flag=-2
return
endif
y(i)=u(i)**ipar(1)
25 continue
endif
end