R/jacobian.band.R

Defines functions jacobian.band

Documented in jacobian.band

## =============================================================================
## jacobian.band  : multidiagonal (banded) jacobian matrix by differencing
## =============================================================================

jacobian.band<- function(y, func, bandup=1, banddown=1, dy=NULL,
       time=0, parms=NULL,  pert=1e-8,  ...)  {

# Reference value of state

  if (!is.numeric(y))
    stop("y-values should be numeric")
  ny <- length(y)
  if (is.null (dy) )
    dy <-  unlist( func(time,y,parms,...))[1:ny]
  if (! is.numeric(dy))
    stop("dy-values should either be NULL or numeric")
  if (length(dy) != ny)
    stop("function should return at least one value for each y")
   
  ynames  <- attr(y,"names")

  refy  <- y
  refdy <- dy

# Perturb the state variables, assume banded structure (only 3*nspec iterations)

  nband  <- bandup+banddown+1
  jacob  <- matrix(nrow=nband,ncol=ny,data=0)
  delt   <- perturb(y,pert)        # perturbation factors
  for ( j in 1:nband) {
    kpert    <- seq(j,ny,nband)          # list of state vars to perturb
    y[kpert] <- y[kpert] + delt[kpert]   # perturbed state vars

    # new rate of change
    dy <-  unlist( func(time,y,parms,...))[1:ny]
    for (k in kpert) {
      iseq <- seq(max(k-bandup,1),min(k+banddown,ny))
      # impact of the selected states on the rate of change of all states
      jacob [iseq-k+bandup+1,k] <- (dy[iseq] -refdy[iseq]      )/delt[k]
    }
    y<-refy
  }
  colnames (jacob) <- ynames
  return(jacob )   # jacobian matrix, banded format

}

Try the rootSolve package in your browser

Any scripts or data that you put into this service are public.

rootSolve documentation built on Sept. 21, 2023, 5:06 p.m.