R/systemfitPanel.R

Defines functions .systemfitPanel

.systemfitPanel <- function( formula, inst, data, pooled ) {


  if (inherits( data, "pdata.frame" )) {
       # current panel data format from pkg plm
       index <- index( data )
       eqnVar  <- names( index )[1]
       timeVar <- names( index )[2]
       
       # pdata.frames do not necessarily carry the index variables as columns.
       # attach index vars to data, if not in data (pdata.frame(..., drop.index = TRUE))
       if (! (eqnVar %in% colnames(data))) {
         data <- cbind(data, index)
       }
    } else {
      if (inherits( data, "plm.dim" )) {
        # deprecated panel data format from pkg plm
        eqnVar  <- names( data )[1]
        timeVar <- names( data )[2]
      } else {
        stop( "argument 'data' must be of class 'pdata.frame'",
              " (created with 'pdata.frame')" )
        }
   }
   
   result <- list()
  
   data[[ eqnVar ]] <- gsub( " |_", ".", data[[ eqnVar ]] )
   eqnLabels <- levels( as.factor( data[[ eqnVar ]] ) )
   nEqn <- length( eqnLabels )
   timeLabels <- levels( as.factor( data[[ timeVar ]] ) )
   nRegressors <- ncol( model.matrix( formula, data ) )
   eqnSystem <- list()

   wideData <- data.frame( time = timeLabels )
   rownames( wideData ) <- make.names( timeLabels )
   for( eqnNo in 1:nEqn ) {
      eqn <- eqnLabels[ eqnNo ]
      endogVar <- formula[2]
      exogVar <- formula[3]
      eqnData <- data[ data[[ eqnVar ]] == eqn, ]
      for( var in all.vars( formula ) ) {
         newVar <- paste( eqn, var, sep = "_" )
         newVar <- make.names( newVar )
         wideData[[ newVar ]] <- NA
         wideData[ make.names( eqnData[ , timeVar ] ), newVar ] <-
            eqnData[ , var ]
         endogVar <- gsub( paste0( "\\b", var, "\\b" ), newVar, endogVar )
         exogVar <- gsub( paste0( "\\b", var, "\\b" ), newVar, exogVar )
      }
      eqnSystem[[ eqnNo ]] <- as.formula( paste( endogVar, "~", exogVar ) )
   }
   names( eqnSystem ) <- eqnLabels
   #reshape( data, idvar=timevar, timevar=eqnVar,direction="wide")

   if( is.null( inst ) ) {
      instSystem <- NULL
   } else {   
      instSystem <- list()
      for( eqnNo in 1:nEqn ) {
         eqn <- eqnLabels[ eqnNo ]
         instVar <- inst[2]
         eqnData <- data[ data[[ eqnVar ]] == eqn, ]
         for( var in all.vars( inst ) ) {
            newVar <- paste( eqn, var, sep = "_" )
            newVar <- make.names( newVar )
            wideData[[ newVar ]] <- NA
            wideData[ make.names( eqnData[ , timeVar ] ), newVar ] <-
               eqnData[ , var ]
            instVar <- gsub( paste0( "\\b", var, "\\b" ), newVar, instVar )
         }
         instSystem[[ eqnNo ]] <- as.formula( paste( "~", instVar ) )
      }
      names( instSystem ) <- eqnLabels
   }
   
   restrict.regMat <- NULL
   if( pooled ) {
      for( eqnNo in 1:nEqn ) {
         restrict.regMat <- rbind( restrict.regMat, diag( 1, nRegressors ) )
      }
   }

   result$eqnSystem <- eqnSystem
   result$instSystem <- instSystem
   result$wideData  <- wideData
   result$restrict.regMat <- restrict.regMat

   return( result )
}

Try the systemfit package in your browser

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

systemfit documentation built on March 31, 2023, 3:07 p.m.