Title: | Estimating Systems of Simultaneous Equations |
---|---|
Description: | Econometric estimation of simultaneous systems of linear and nonlinear equations using Ordinary Least Squares (OLS), Weighted Least Squares (WLS), Seemingly Unrelated Regressions (SUR), Two-Stage Least Squares (2SLS), Weighted Two-Stage Least Squares (W2SLS), and Three-Stage Least Squares (3SLS) as suggested, e.g., by Zellner (1962) <doi:10.2307/2281644>, Zellner and Theil (1962) <doi:10.2307/1911287>, and Schmidt (1990) <doi:10.1016/0304-4076(90)90127-F>. |
Authors: | Arne Henningsen and Jeff D. Hamann |
Maintainer: | Arne Henningsen <[email protected]> |
License: | GPL (>= 2) |
Version: | 1.1-31 |
Built: | 2025-01-15 02:54:31 UTC |
Source: | https://github.com/r-forge/systemfit |
Extract the estimator for the bread of sandwhiches
(see bread
).
## S3 method for class 'systemfit' bread( x, ... )
## S3 method for class 'systemfit' bread( x, ... )
x |
an object of class |
... |
further arguments (currently ignored). |
Quadratic symmetric matrix,
which is an estimator for the expectation of the negative derivative
of the estimating function (see estfun.systemfit
).
The sandwich package must be loaded before this method can be used.
This method might not be suitable for specific formulas for 3SLS estimations in case of unbalanced systems or different instruments for different equations.
Arne Henningsen
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) inst <- ~ income + farmPrice + trend ## OLS estimation fitols <- systemfit( system, "OLS", data = Kmenta ) ## obtain the bread library( "sandwich" ) bread( fitols ) ## this is only true for OLS models all.equal( bread( fitols ), solve( crossprod( model.matrix( fitols ) ) / 40 ) ) ## 2SLS estimation fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) ## obtain the bread bread( fit2sls ) ## this is only true for 2SLS models all.equal( bread( fit2sls ), solve( crossprod( model.matrix( fit2sls, which = "xHat" ) ) / 40 ) ) ## iterated SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta, maxit = 100 ) ## obtain the bread bread( fitsur ) ## this should be true for SUR and WLS models all.equal( bread( fitsur ), solve( t( model.matrix( fitsur ) ) %*% ( ( solve( fitsur$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fitsur ) ) / 40 ), check.attributes = FALSE ) ## 3SLS estimation fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## obtain the bread bread( fit3sls ) ## this should be true for 3SLS and W2SLS models all.equal( bread( fit3sls ), solve( t( model.matrix( fit3sls, which = "xHat" ) ) %*% ( ( solve( fit3sls$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fit3sls, which = "xHat" ) ) / 40 ), check.attributes = FALSE )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) inst <- ~ income + farmPrice + trend ## OLS estimation fitols <- systemfit( system, "OLS", data = Kmenta ) ## obtain the bread library( "sandwich" ) bread( fitols ) ## this is only true for OLS models all.equal( bread( fitols ), solve( crossprod( model.matrix( fitols ) ) / 40 ) ) ## 2SLS estimation fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) ## obtain the bread bread( fit2sls ) ## this is only true for 2SLS models all.equal( bread( fit2sls ), solve( crossprod( model.matrix( fit2sls, which = "xHat" ) ) / 40 ) ) ## iterated SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta, maxit = 100 ) ## obtain the bread bread( fitsur ) ## this should be true for SUR and WLS models all.equal( bread( fitsur ), solve( t( model.matrix( fitsur ) ) %*% ( ( solve( fitsur$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fitsur ) ) / 40 ), check.attributes = FALSE ) ## 3SLS estimation fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## obtain the bread bread( fit3sls ) ## this should be true for 3SLS and W2SLS models all.equal( bread( fit3sls ), solve( t( model.matrix( fit3sls, which = "xHat" ) ) %*% ( ( solve( fit3sls$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fit3sls, which = "xHat" ) ) / 40 ), check.attributes = FALSE )
These functions extract the coefficients from an object returned by
systemfit
.
## S3 method for class 'systemfit' coef( object, modified.regMat = FALSE, ... ) ## S3 method for class 'systemfit.equation' coef( object, ... ) ## S3 method for class 'summary.systemfit' coef( object, modified.regMat = FALSE, ... ) ## S3 method for class 'summary.systemfit.equation' coef( object, ... )
## S3 method for class 'systemfit' coef( object, modified.regMat = FALSE, ... ) ## S3 method for class 'systemfit.equation' coef( object, ... ) ## S3 method for class 'summary.systemfit' coef( object, modified.regMat = FALSE, ... ) ## S3 method for class 'summary.systemfit.equation' coef( object, ... )
object |
an object of class |
modified.regMat |
logical. If |
... |
other arguments. |
coef.systemfit
returns a vector of all estimated coefficients.
coef.systemfit.equation
returns a vector of the estimated coefficients
of a single equation.
coef.summary.systemfit
returns a matrix of all estimated coefficients,
their standard errors, t-values, and p-values.
coef.summary.systemfit.equation
returns a matrix of the estimated
coefficients of a single equation, their standard errors, t-values,
and p-values.
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## all coefficients coef( fitols ) coef( summary( fitols ) ) ## coefficients of the first equation coef( fitols$eq[[1]] ) coef( summary( fitols$eq[[1]] ) ) ## coefficients of the second equation coef( fitols$eq[[2]] ) coef( summary( fitols$eq[[2]] ) ) ## estimation with restriction by modifying the regressor matrix modReg <- matrix( 0, 7, 6 ) colnames( modReg ) <- c( "demIntercept", "demPrice", "demIncome", "supIntercept", "supPrice2", "supTrend" ) modReg[ 1, "demIntercept" ] <- 1 modReg[ 2, "demPrice" ] <- 1 modReg[ 3, "demIncome" ] <- 1 modReg[ 4, "supIntercept" ] <- 1 modReg[ 5, "supPrice2" ] <- 1 modReg[ 6, "supPrice2" ] <- 1 modReg[ 7, "supTrend" ] <- 1 fitols3 <- systemfit( system, data = Kmenta, restrict.regMat = modReg ) coef( fitols3, modified.regMat = TRUE ) coef( fitols3 )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## all coefficients coef( fitols ) coef( summary( fitols ) ) ## coefficients of the first equation coef( fitols$eq[[1]] ) coef( summary( fitols$eq[[1]] ) ) ## coefficients of the second equation coef( fitols$eq[[2]] ) coef( summary( fitols$eq[[2]] ) ) ## estimation with restriction by modifying the regressor matrix modReg <- matrix( 0, 7, 6 ) colnames( modReg ) <- c( "demIntercept", "demPrice", "demIncome", "supIntercept", "supPrice2", "supTrend" ) modReg[ 1, "demIntercept" ] <- 1 modReg[ 2, "demPrice" ] <- 1 modReg[ 3, "demIncome" ] <- 1 modReg[ 4, "supIntercept" ] <- 1 modReg[ 5, "supPrice2" ] <- 1 modReg[ 6, "supPrice2" ] <- 1 modReg[ 7, "supTrend" ] <- 1 fitols3 <- systemfit( system, data = Kmenta, restrict.regMat = modReg ) coef( fitols3, modified.regMat = TRUE ) coef( fitols3 )
These functions calculate the confidence intervals of the
coefficients from an object returned by systemfit
.
## S3 method for class 'systemfit' confint( object, parm = NULL, level = 0.95, useDfSys = NULL, ... ) ## S3 method for class 'systemfit.equation' confint( object, parm, level = 0.95, useDfSys = NULL, ... )
## S3 method for class 'systemfit' confint( object, parm = NULL, level = 0.95, useDfSys = NULL, ... ) ## S3 method for class 'systemfit.equation' confint( object, parm, level = 0.95, useDfSys = NULL, ... )
object |
an object of class |
parm |
not used yet. |
level |
confidence level. |
useDfSys |
logical. Use the degrees of freedom of the whole system
(in place of the degrees of freedom of the single equation)
to calculate the confidence intervals of the coefficients.
If it not specified ( |
... |
other arguments. |
An object of class confint.systemfit
, which is a matrix
with columns giving lower and upper confidence limits
for each estimated coefficient. These will be labelled as
(1-level)/2 and 1 - (1-level)/2 in % (by default 2.5% and 97.5%).
Arne Henningsen [email protected]
systemfit
,
print.confint.systemfit
, confint
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## confidence intervals of all coefficients confint( fitols ) ## confidence intervals of the coefficients of the first equation confint( fitols$eq[[1]] ) ## confidence intervals of the coefficients of the second equation confint( fitols$eq[[2]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## confidence intervals of all coefficients confint( fitols ) ## confidence intervals of the coefficients of the first equation confint( fitols$eq[[1]] ) ## confidence intervals of the coefficients of the second equation confint( fitols$eq[[2]] )
correlation
returns a vector of the correlations
between the predictions of two equations in a set of equations. The
correlation between the predictions is defined as,
where is the correlation between the predicted values of
equation i and j and
is the cross-equation variance-covariance
matrix between equations i and j.
correlation.systemfit( results, eqni, eqnj )
correlation.systemfit( results, eqni, eqnj )
results |
an object of type |
eqni |
index for equation i |
eqnj |
index for equation j |
correlation
returns a vector of the correlations between the
predicted values in equation i and equation j.
Jeff D. Hamann [email protected]
Greene, W. H. (1993) Econometric Analysis, Second Edition, Macmillan.
Hasenauer, H; Monserud, R and T. Gregoire. (1998) Using Simultansous Regression Techniques with Individual-Tree Growth Models. Forest Science. 44(1):87-95
Kmenta, J. (1997) Elements of Econometrics, Second Edition, University of Michigan Publishing
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform 2SLS on each of the equations in the system fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) print( fit2sls ) print( fit2sls$rcov ) ## perform the 3SLS fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) print( fit3sls ) print( "covariance of residuals used for estimation (from 2sls)" ) print( fit3sls$rcovest ) print( "covariance of residuals" ) print( fit3sls$rcov ) ## examine the correlation between the predicted values ## of suppy and demand by plotting the correlation over ## the value of q r12 <- correlation.systemfit( fit3sls, 1, 2 ) plot( Kmenta$consump, r12, main="correlation between predictions from supply and demand" )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform 2SLS on each of the equations in the system fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) print( fit2sls ) print( fit2sls$rcov ) ## perform the 3SLS fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) print( fit3sls ) print( "covariance of residuals used for estimation (from 2sls)" ) print( fit3sls$rcovest ) print( "covariance of residuals" ) print( fit3sls$rcov ) ## examine the correlation between the predicted values ## of suppy and demand by plotting the correlation over ## the value of q r12 <- correlation.systemfit( fit3sls, 1, 2 ) plot( Kmenta$consump, r12, main="correlation between predictions from supply and demand" )
This function creates a model that can be estimated by systemfit
.
The data, disturbances, and — if not provided by the user —
the coefficients as well as the disturbance covariance matrix
are generated by random numbers.
createSystemfitModel( nEq, nRegEq, nObs, coef = NULL, sigma = NULL )
createSystemfitModel( nEq, nRegEq, nObs, coef = NULL, sigma = NULL )
nEq |
the number of equations. |
nRegEq |
the number of regressors in each equation (without the intercept). |
nObs |
the number of observations. |
coef |
an optional vector of coefficients. |
sigma |
an optional covariance matrix of the disturbance terms. |
createSystemfitModel
returns a list with following elements:
formula |
a list of the model equations
(objects of class |
data |
a |
coef |
a vector of (true) coefficients. |
sigma |
the covariance matrix of the disturbance terms. |
Arne Henningsen [email protected]
## create a model by random numbers systemfitModel <- createSystemfitModel( 3, 4, 100 ) ## estimate this model by "SUR" fitsur <- systemfit( systemfitModel$formula, "SUR", data = systemfitModel$data ) ## compare the "true" and the estimated coefficients cbind( systemfitModel$coef, coef( fitsur ) )
## create a model by random numbers systemfitModel <- createSystemfitModel( 3, 4, 100 ) ## estimate this model by "SUR" fitsur <- systemfit( systemfitModel$formula, "SUR", data = systemfitModel$data ) ## compare the "true" and the estimated coefficients cbind( systemfitModel$coef, coef( fitsur ) )
Extract the gradients of the objective function
with respect to the coefficients
evaluated at each observation
(‘Empirical Estimating Function’,
see estfun
).
## S3 method for class 'systemfit' estfun( x, residFit = TRUE, ... )
## S3 method for class 'systemfit' estfun( x, residFit = TRUE, ... )
x |
an object of class |
residFit |
logical.
If |
... |
further arguments (currently ignored). |
Matrix of gradients of the objective function with respect to the coefficients evaluated at each observation.
The sandwich package must be loaded before this method can be used.
In specific estimations with the 3SLS method,
not all columns of the matrix returned by the estfun
method
sum up to zero,
which indicates that an inappropriate estimating function is returned.
This can be either with argument residFit
set to TRUE
or with this argument set to FALSE
or even in both cases.
This problem depends on the formula used for the 3SLS estimation
and seems to be related to unbalanced systems and
systems where different instruments are used in different equations.
Arne Henningsen
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) inst <- ~ income + farmPrice + trend ## OLS estimation fitols <- systemfit( system, "OLS", data = Kmenta ) ## obtain the estimation function library( "sandwich" ) estfun( fitols ) ## this is only true for OLS models all.equal( estfun( fitols ), unlist( residuals( fitols ) ) * model.matrix( fitols ) ) # each column should sum up to (approximately) zero colSums( estfun( fitols ) ) ## 2SLS estimation fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) ## obtain the estimation function estfun( fit2sls ) ## this is only true for 2SLS models all.equal( estfun( fit2sls ), drop( rep( Kmenta$consump, 2 ) - model.matrix( fit2sls, which = "xHat" ) %*% coef( fit2sls ) ) * model.matrix( fit2sls, which = "xHat" ) ) all.equal( estfun( fit2sls, residFit = FALSE ), unlist( residuals( fit2sls ) ) * model.matrix( fit2sls, which = "xHat" ) ) # each column should sum up to (approximately) zero colSums( estfun( fit2sls ) ) colSums( estfun( fit2sls, residFit = FALSE ) ) ## iterated SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta, maxit = 100 ) ## obtain the estimation function estfun( fitsur ) ## this should be true for SUR and WLS models all.equal( estfun( fitsur ), unlist( residuals( fitsur ) ) * ( ( solve( fitsur$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fitsur ) ), check.attributes = FALSE ) # each column should sum up to (approximately) zero colSums( estfun( fitsur ) ) ## 3SLS estimation fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## obtain the estimation function estfun( fit3sls ) estfun( fit3sls, residFit = FALSE ) ## this should be true for 3SLS and W2SLS models all.equal( estfun( fit3sls ), drop( rep( Kmenta$consump, 2 ) - model.matrix( fit2sls, which = "xHat" ) %*% coef( fit3sls ) ) * ( ( solve( fit3sls$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fit3sls, which = "xHat" ) ), check.attributes = FALSE ) all.equal( estfun( fit3sls, residFit = FALSE ), unlist( residuals( fit3sls ) ) * ( ( solve( fit3sls$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fit3sls, which = "xHat" ) ), check.attributes = FALSE ) # each column should sum up to (approximately) zero colSums( estfun( fit3sls ) ) colSums( estfun( fit3sls, residFit = FALSE ) )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) inst <- ~ income + farmPrice + trend ## OLS estimation fitols <- systemfit( system, "OLS", data = Kmenta ) ## obtain the estimation function library( "sandwich" ) estfun( fitols ) ## this is only true for OLS models all.equal( estfun( fitols ), unlist( residuals( fitols ) ) * model.matrix( fitols ) ) # each column should sum up to (approximately) zero colSums( estfun( fitols ) ) ## 2SLS estimation fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) ## obtain the estimation function estfun( fit2sls ) ## this is only true for 2SLS models all.equal( estfun( fit2sls ), drop( rep( Kmenta$consump, 2 ) - model.matrix( fit2sls, which = "xHat" ) %*% coef( fit2sls ) ) * model.matrix( fit2sls, which = "xHat" ) ) all.equal( estfun( fit2sls, residFit = FALSE ), unlist( residuals( fit2sls ) ) * model.matrix( fit2sls, which = "xHat" ) ) # each column should sum up to (approximately) zero colSums( estfun( fit2sls ) ) colSums( estfun( fit2sls, residFit = FALSE ) ) ## iterated SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta, maxit = 100 ) ## obtain the estimation function estfun( fitsur ) ## this should be true for SUR and WLS models all.equal( estfun( fitsur ), unlist( residuals( fitsur ) ) * ( ( solve( fitsur$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fitsur ) ), check.attributes = FALSE ) # each column should sum up to (approximately) zero colSums( estfun( fitsur ) ) ## 3SLS estimation fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## obtain the estimation function estfun( fit3sls ) estfun( fit3sls, residFit = FALSE ) ## this should be true for 3SLS and W2SLS models all.equal( estfun( fit3sls ), drop( rep( Kmenta$consump, 2 ) - model.matrix( fit2sls, which = "xHat" ) %*% coef( fit3sls ) ) * ( ( solve( fit3sls$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fit3sls, which = "xHat" ) ), check.attributes = FALSE ) all.equal( estfun( fit3sls, residFit = FALSE ), unlist( residuals( fit3sls ) ) * ( ( solve( fit3sls$residCovEst ) %x% diag( nrow( Kmenta ) ) ) %*% model.matrix( fit3sls, which = "xHat" ) ), check.attributes = FALSE ) # each column should sum up to (approximately) zero colSums( estfun( fit3sls ) ) colSums( estfun( fit3sls, residFit = FALSE ) )
These functions extract the fitted values
from an object returned by systemfit
.
## S3 method for class 'systemfit' fitted( object, ... ) ## S3 method for class 'systemfit.equation' fitted( object, na.rm = FALSE, ... )
## S3 method for class 'systemfit' fitted( object, ... ) ## S3 method for class 'systemfit.equation' fitted( object, na.rm = FALSE, ... )
object |
an object of class |
na.rm |
a logical value indicating whether |
... |
other arguments. |
fitted.systemfit
returns a data.frame of all fitted values,
where each column contains the fitted values of one equation.
fitted.systemfit.equation
returns a vector of the fitted values
of a single equation.
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## all fitted values fitted( fitols ) ## fitted values of the first equation fitted( fitols$eq[[1]] ) ## fitted values of the second equation fitted( fitols$eq[[2]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## all fitted values fitted( fitols ) ## fitted values of the first equation fitted( fitols$eq[[1]] ) ## fitted values of the second equation fitted( fitols$eq[[2]] )
This method extracts the model formulae
from fitted objects returned by systemfit
.
## S3 method for class 'systemfit' formula( x, ... ) ## S3 method for class 'systemfit.equation' formula( x, ... )
## S3 method for class 'systemfit' formula( x, ... ) ## S3 method for class 'systemfit.equation' formula( x, ... )
x |
an object of class |
... |
currently not used. |
formula.systemfit.equation
returns the formula
of a single equation of a systemfit
object.
formula.systemfit.equation
returns a list of formulae:
one formula object for each equation
of the systemfit
object.
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform a SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) ## formula of the second equation formula( fitsur$eq[[2]] ) ## all formulae of the system formula( fitsur )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform a SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) ## formula of the second equation formula( fitsur$eq[[2]] ) ## all formulae of the system formula( fitsur )
Panel data on 5 US firms for the years 1935-1954.
data("GrunfeldGreene")
data("GrunfeldGreene")
A data frame containing 20 annual observations on 3 variables for 5 firms.
gross investment.
market value of the firm (at the end of the previous year).
capital stock of the firm (at the end of the previous year).
name of the firm ("General Motors", "Chrysler", "General Electric", "Westinghouse" or "US Steel").
year.
There exist several different versions of this data set,
and this version is considered incorrect
(see https://web.archive.org/web/20170426034143/http://web.stanford.edu/~clint/bench/grunfeld.htm for details).
However, we provide this incorrect version to replicate the results
published in Theil (1971) and Greene (2003).
A correct version of this data set with 5 additional firms
is available in the Ecdat
package
(data set Grunfeld
).
Greene (2003), Appendix F, Data Sets Used in Applications, Table F13.1. https://pages.stern.nyu.edu/~wgreene/Text/econometricanalysis.htm (a subset of this data set is available in Theil (1971), p. 296).
Greene, W.H. (2003). Econometric Analysis, 5th edition. Prentice Hall, Upper Saddle River (NJ).
Grunfeld, Y. (1958). The Determinants of Corporate Investment, Unpublished Ph.D. Dissertation, University of Chicago.
Theil, Henri (1971). Principles of Econometrics, John Wiley & Sons, New York.
## Repeating the OLS and SUR estimations in Greene (2003, pp. 351) data( "GrunfeldGreene" ) if( requireNamespace( 'plm', quietly = TRUE ) ) { library( "plm" ) GGPanel <- pdata.frame( GrunfeldGreene, c( "firm", "year" ) ) formulaGrunfeld <- invest ~ value + capital # OLS greeneOls <- systemfit( formulaGrunfeld, "OLS", data = GGPanel ) summary( greeneOls ) sapply( greeneOls$eq, function(x){return(summary(x)$ssr/20)} ) # sigma^2 # OLS Pooled greeneOlsPooled <- systemfit( formulaGrunfeld, "OLS", data = GGPanel, pooled = TRUE ) summary( greeneOlsPooled ) sum( sapply( greeneOlsPooled$eq, function(x){return(summary(x)$ssr)}) )/97 # sigma^2 # SUR greeneSur <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, methodResidCov = "noDfCor" ) summary( greeneSur ) # SUR Pooled greeneSurPooled <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, pooled = TRUE, methodResidCov = "noDfCor", residCovWeighted = TRUE ) summary( greeneSurPooled ) ## Repeating the OLS and SUR estimations in Theil (1971, pp. 295, 300) GrunfeldTheil <- subset( GrunfeldGreene, firm %in% c( "General Electric", "Westinghouse" ) ) GTPanel <- pdata.frame( GrunfeldTheil, c( "firm", "year" ) ) formulaGrunfeld <- invest ~ value + capital # OLS theilOls <- systemfit( formulaGrunfeld, "OLS", data = GTPanel ) summary( theilOls ) # SUR theilSur <- systemfit( formulaGrunfeld, "SUR", data = GTPanel, methodResidCov = "noDfCor" ) summary( theilSur ) }
## Repeating the OLS and SUR estimations in Greene (2003, pp. 351) data( "GrunfeldGreene" ) if( requireNamespace( 'plm', quietly = TRUE ) ) { library( "plm" ) GGPanel <- pdata.frame( GrunfeldGreene, c( "firm", "year" ) ) formulaGrunfeld <- invest ~ value + capital # OLS greeneOls <- systemfit( formulaGrunfeld, "OLS", data = GGPanel ) summary( greeneOls ) sapply( greeneOls$eq, function(x){return(summary(x)$ssr/20)} ) # sigma^2 # OLS Pooled greeneOlsPooled <- systemfit( formulaGrunfeld, "OLS", data = GGPanel, pooled = TRUE ) summary( greeneOlsPooled ) sum( sapply( greeneOlsPooled$eq, function(x){return(summary(x)$ssr)}) )/97 # sigma^2 # SUR greeneSur <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, methodResidCov = "noDfCor" ) summary( greeneSur ) # SUR Pooled greeneSurPooled <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, pooled = TRUE, methodResidCov = "noDfCor", residCovWeighted = TRUE ) summary( greeneSurPooled ) ## Repeating the OLS and SUR estimations in Theil (1971, pp. 295, 300) GrunfeldTheil <- subset( GrunfeldGreene, firm %in% c( "General Electric", "Westinghouse" ) ) GTPanel <- pdata.frame( GrunfeldTheil, c( "firm", "year" ) ) formulaGrunfeld <- invest ~ value + capital # OLS theilOls <- systemfit( formulaGrunfeld, "OLS", data = GTPanel ) summary( theilOls ) # SUR theilSur <- systemfit( formulaGrunfeld, "SUR", data = GTPanel, methodResidCov = "noDfCor" ) summary( theilSur ) }
hausman.systemfit
returns the Hausman statistic for a specification test.
hausman.systemfit( results2sls, results3sls )
hausman.systemfit( results2sls, results3sls )
results2sls |
result of a 2SLS (limited information) estimation
returned by |
results3sls |
result of a 3SLS (full information) estimation
returned by |
The null hypotheses of the test is that all exogenous variables are uncorrelated with all disturbance terms. Under this hypothesis both the 2SLS and the 3SLS estimator are consistent but only the 3SLS estimator is (asymptotically) efficient. Under the alternative hypothesis the 2SLS estimator is consistent but the 3SLS estimator is inconsistent.
The Hausman test statistic is
where $b_2$ and $V_2$ are the estimated coefficients and their variance covariance matrix of a 2SLS estimation and $b_3$ and $V_3$ are the estimated coefficients and their variance covariance matrix of a 3SLS estimation.
hausman.systemfit
returns a list of the class
htest
that contains following elements:
q |
vector of the differences between the estimated coefficients. |
qVar |
variance covariance matrix of |
statistic |
the Hausman test statistic. |
parameter |
degrees of freedom. |
p.value |
P-value of the test. |
method |
character string describing this test. |
data.name |
name of the data.frame used for estimation. |
Jeff D. Hamann [email protected],
Arne Henningsen [email protected]
Greene, W. H. (1993) Econometric Analysis, Fifth Edition, Macmillan.
Hausman, J. A. (1978) Specification Tests in Econometrics. Econometrica. 46:1251-1271.
Kmenta, J. (1997) Elements of Econometrics, Second Edition, University of Michigan Publishing
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform the estimations fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## perform the Hausman test h <- hausman.systemfit( fit2sls, fit3sls ) print( h )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform the estimations fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## perform the Hausman test h <- hausman.systemfit( fit2sls, fit3sls ) print( h )
Data for Klein's (1950) Model I of the US economy.
data("KleinI")
data("KleinI")
A data frame containing annual observations from 1920 to 1941
Year.
Consumption.
Corporate profits.
Corporate profits of the previous year.
Private wage bill.
Investment.
Capital stock of the previous year.
Gross national product.
Gross national product of the previous year.
Government wage bill.
Government spending.
Taxes.
Sum of private and government wage bill.
time trend measured as years from 1931.
Greene (2003), Appendix F, Data Sets Used in Applications, Table F15.1.
https://pages.stern.nyu.edu/~wgreene/Text/econometricanalysis.htm
Greene, W.H. (2003). Econometric Analysis, 5th edition. Prentice Hall, Upper Saddle River (NJ).
Klein, L. (1950). Economic Fluctuations in the United States, 1921–1941. John Wiley, New York.
## Repeating the estimations of Klein's (1950) Model I ## in Greene (2003, pp. 381 and 412) data( "KleinI" ) eqConsump <- consump ~ corpProf + corpProfLag + wages eqInvest <- invest ~ corpProf + corpProfLag + capitalLag eqPrivWage <- privWage ~ gnp + gnpLag + trend inst <- ~ govExp + taxes + govWage + trend + capitalLag + corpProfLag + gnpLag system <- list( Consumption = eqConsump, Investment = eqInvest, PrivateWages = eqPrivWage ) # OLS kleinOls <- systemfit( system, data = KleinI ) summary( kleinOls ) # 2SLS klein2sls <- systemfit( system, "2SLS", inst = inst, data = KleinI, methodResidCov = "noDfCor" ) summary( klein2sls ) # 3SLS klein3sls <- systemfit( system, "3SLS", inst = inst, data = KleinI, methodResidCov = "noDfCor" ) summary( klein3sls ) # I3SLS kleinI3sls <- systemfit( system, "3SLS", inst = inst, data = KleinI, methodResidCov = "noDfCor", maxit = 500 ) summary( kleinI3sls )
## Repeating the estimations of Klein's (1950) Model I ## in Greene (2003, pp. 381 and 412) data( "KleinI" ) eqConsump <- consump ~ corpProf + corpProfLag + wages eqInvest <- invest ~ corpProf + corpProfLag + capitalLag eqPrivWage <- privWage ~ gnp + gnpLag + trend inst <- ~ govExp + taxes + govWage + trend + capitalLag + corpProfLag + gnpLag system <- list( Consumption = eqConsump, Investment = eqInvest, PrivateWages = eqPrivWage ) # OLS kleinOls <- systemfit( system, data = KleinI ) summary( kleinOls ) # 2SLS klein2sls <- systemfit( system, "2SLS", inst = inst, data = KleinI, methodResidCov = "noDfCor" ) summary( klein2sls ) # 3SLS klein3sls <- systemfit( system, "3SLS", inst = inst, data = KleinI, methodResidCov = "noDfCor" ) summary( klein3sls ) # I3SLS kleinI3sls <- systemfit( system, "3SLS", inst = inst, data = KleinI, methodResidCov = "noDfCor", maxit = 500 ) summary( kleinI3sls )
These are partly contrived data from Kmenta (1986), constructed to illustrate estimation of a simultaneous-equation model.
data("Kmenta")
data("Kmenta")
This data frame contains 20 annual observations of 5 variables:
food consumption per capita.
ratio of food prices to general consumer prices.
disposable income in constant dollars.
ratio of preceding year's prices received by farmers to general consumer prices.
time trend in years.
The exogenous variables income
, farmPrice
,
and trend
are based on real data;
the endogenous variables price
and consump
were generated by simulation.
Kmenta (1986), Table 13-1, p. 687.
Kmenta, J. (1986). Elements of Econometrics, Second Edition, Macmillan, New York.
## Replicating the estimations in Kmenta (1986), p. 712, Tab 13-2 data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## OLS estimation fitOls <- systemfit( system, data = Kmenta ) summary( fitOls ) ## 2SLS estimation fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) summary( fit2sls ) ## 3SLS estimation fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) summary( fit3sls ) ## I3LS estimation fitI3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta, maxit = 250 ) summary( fitI3sls )
## Replicating the estimations in Kmenta (1986), p. 712, Tab 13-2 data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## OLS estimation fitOls <- systemfit( system, data = Kmenta ) summary( fitOls ) ## 2SLS estimation fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) summary( fit2sls ) ## 3SLS estimation fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) summary( fit3sls ) ## I3LS estimation fitI3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta, maxit = 250 ) summary( fitI3sls )
Testing linear hypothesis on the coefficients of a system of equations by an F-test or Wald-test.
## S3 method for class 'systemfit' linearHypothesis( model, hypothesis.matrix, rhs = NULL, test = c( "FT", "F", "Chisq" ), vcov. = NULL, ... )
## S3 method for class 'systemfit' linearHypothesis( model, hypothesis.matrix, rhs = NULL, test = c( "FT", "F", "Chisq" ), vcov. = NULL, ... )
model |
a fitted object of type |
hypothesis.matrix |
matrix (or vector) giving linear combinations
of coefficients by rows,
or a character vector giving the hypothesis in symbolic form
(see documentation of |
rhs |
optional right-hand-side vector for hypothesis, with as many entries as rows in the hypothesis matrix; if omitted, it defaults to a vector of zeroes. |
test |
character string, " |
vcov. |
a function for estimating the covariance matrix
of the regression coefficients or an estimated covariance matrix
(function |
... |
further arguments passed to
|
Theil's statistic for sytems of equations is
where is the number of restrictions,
is the number of equations,
is the number of observations per equation,
is the total number of estimated coefficients, and
is the estimated residual covariance matrix.
Under the null hypothesis,
has an approximate
distribution
with
and
degrees of freedom
(Theil, 1971, p. 314).
The statistic for a Wald test is
Under the null hypothesis, has an approximate
distribution
with
and
degrees of freedom
(Greene, 2003, p. 346).
The statistic for a Wald test is
Asymptotically, has a
distribution with
degrees of freedom
under the null hypothesis
(Greene, 2003, p. 347).
An object of class anova
,
which contains the residual degrees of freedom in the model,
the difference in degrees of freedom,
the test statistic (either F or Wald/Chisq)
and the corresponding p value.
See documentation of linearHypothesis
in package "car".
Arne Henningsen [email protected]
Greene, W. H. (2003) Econometric Analysis, Fifth Edition, Prentice Hall.
Theil, Henri (1971) Principles of Econometrics, John Wiley & Sons, New York.
systemfit
, linearHypothesis
(package "car"),
lrtest.systemfit
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## unconstrained SUR estimation fitsur <- systemfit( system, method = "SUR", data=Kmenta ) # create hypothesis matrix to test whether beta_2 = \beta_6 R1 <- matrix( 0, nrow = 1, ncol = 7 ) R1[ 1, 2 ] <- 1 R1[ 1, 6 ] <- -1 # the same hypothesis in symbolic form restrict1 <- "demand_price - supply_farmPrice = 0" ## perform Theil's F test linearHypothesis( fitsur, R1 ) # rejected linearHypothesis( fitsur, restrict1 ) ## perform Wald test with F statistic linearHypothesis( fitsur, R1, test = "F" ) # rejected linearHypothesis( fitsur, restrict1 ) ## perform Wald-test with chi^2 statistic linearHypothesis( fitsur, R1, test = "Chisq" ) # rejected linearHypothesis( fitsur, restrict1, test = "Chisq" ) # create hypothesis matrix to test whether beta_2 = - \beta_6 R2 <- matrix( 0, nrow = 1, ncol = 7 ) R2[ 1, 2 ] <- 1 R2[ 1, 6 ] <- 1 # the same hypothesis in symbolic form restrict2 <- "demand_price + supply_farmPrice = 0" ## perform Theil's F test linearHypothesis( fitsur, R2 ) # accepted linearHypothesis( fitsur, restrict2 ) ## perform Wald test with F statistic linearHypothesis( fitsur, R2, test = "F" ) # accepted linearHypothesis( fitsur, restrict2 ) ## perform Wald-test with chi^2 statistic linearHypothesis( fitsur, R2, test = "Chisq" ) # accepted linearHypothesis( fitsur, restrict2, test = "Chisq" )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## unconstrained SUR estimation fitsur <- systemfit( system, method = "SUR", data=Kmenta ) # create hypothesis matrix to test whether beta_2 = \beta_6 R1 <- matrix( 0, nrow = 1, ncol = 7 ) R1[ 1, 2 ] <- 1 R1[ 1, 6 ] <- -1 # the same hypothesis in symbolic form restrict1 <- "demand_price - supply_farmPrice = 0" ## perform Theil's F test linearHypothesis( fitsur, R1 ) # rejected linearHypothesis( fitsur, restrict1 ) ## perform Wald test with F statistic linearHypothesis( fitsur, R1, test = "F" ) # rejected linearHypothesis( fitsur, restrict1 ) ## perform Wald-test with chi^2 statistic linearHypothesis( fitsur, R1, test = "Chisq" ) # rejected linearHypothesis( fitsur, restrict1, test = "Chisq" ) # create hypothesis matrix to test whether beta_2 = - \beta_6 R2 <- matrix( 0, nrow = 1, ncol = 7 ) R2[ 1, 2 ] <- 1 R2[ 1, 6 ] <- 1 # the same hypothesis in symbolic form restrict2 <- "demand_price + supply_farmPrice = 0" ## perform Theil's F test linearHypothesis( fitsur, R2 ) # accepted linearHypothesis( fitsur, restrict2 ) ## perform Wald test with F statistic linearHypothesis( fitsur, R2, test = "F" ) # accepted linearHypothesis( fitsur, restrict2 ) ## perform Wald-test with chi^2 statistic linearHypothesis( fitsur, R2, test = "Chisq" ) # accepted linearHypothesis( fitsur, restrict2, test = "Chisq" )
This method calculates the log-likelihood value
of a fitted object returned by systemfit
.
## S3 method for class 'systemfit' logLik( object, residCovDiag = FALSE, ... )
## S3 method for class 'systemfit' logLik( object, residCovDiag = FALSE, ... )
object |
an object of class |
residCovDiag |
logical.
If this argument is set to |
... |
currently not used. |
The residual covariance matrix that is used for calculating the log-likelihood value is calculated based on the actually obtained (final) residuals (not correcting for degrees of freedom). In case of systems of equations with unequal numbers of observations, the calculation of the residual covariance matrix is only based on the residuals/observations that are available in all equations.
A numeric scalar (the log-likelihood value) with 2 attributes:
nobs
(total number of observations in all equations) and
df
(number of free parameters, i.e. coefficients
+ elements of the residual covariance matrix).
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform a SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) ## residuals of all equations logLik( fitsur )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform a SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) ## residuals of all equations logLik( fitsur )
Testing linear hypothesis on the coefficients of a system of equations by a Likelihood Ratio test.
## S3 method for class 'systemfit' lrtest( object, ... )
## S3 method for class 'systemfit' lrtest( object, ... )
object |
a fitted model object of class |
... |
further fitted model objects of class |
lrtest.systemfit
consecutively compares
the fitted model object object
with the models passed in ...
.
The LR-statistic for sytems of equations is
where is the number of observations per equation, and
and
are
the residual covariance matrices calculated by formula "0"
(see
systemfit
)
of the restricted and unrestricted estimation, respectively.
Asymptotically, has a
distribution with
degrees of freedom
under the null hypothesis
(Green, 2003, p. 349).
An object of class anova
,
which contains the log-likelihood value,
degrees of freedom, the difference in degrees of freedom,
likelihood ratio Chi-squared statistic and corresponding p value.
See documentation of lrtest
in package "lmtest".
Arne Henningsen [email protected]
Greene, W. H. (2003) Econometric Analysis, Fifth Edition, Prentice Hall.
systemfit
, lrtest
(package "lmtest"),
linearHypothesis.systemfit
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## unconstrained SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) # create restriction matrix to impose \eqn{beta_2 = \beta_6} R1 <- matrix( 0, nrow = 1, ncol = 7 ) R1[ 1, 2 ] <- 1 R1[ 1, 6 ] <- -1 ## constrained SUR estimation fitsur1 <- systemfit( system, "SUR", data = Kmenta, restrict.matrix = R1 ) ## perform LR-test lrTest1 <- lrtest( fitsur1, fitsur ) print( lrTest1 ) # rejected # create restriction matrix to impose \eqn{beta_2 = - \beta_6} R2 <- matrix( 0, nrow = 1, ncol = 7 ) R2[ 1, 2 ] <- 1 R2[ 1, 6 ] <- 1 ## constrained SUR estimation fitsur2 <- systemfit( system, "SUR", data = Kmenta, restrict.matrix = R2 ) ## perform LR-test lrTest2 <- lrtest( fitsur2, fitsur ) print( lrTest2 ) # accepted
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## unconstrained SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) # create restriction matrix to impose \eqn{beta_2 = \beta_6} R1 <- matrix( 0, nrow = 1, ncol = 7 ) R1[ 1, 2 ] <- 1 R1[ 1, 6 ] <- -1 ## constrained SUR estimation fitsur1 <- systemfit( system, "SUR", data = Kmenta, restrict.matrix = R1 ) ## perform LR-test lrTest1 <- lrtest( fitsur1, fitsur ) print( lrTest1 ) # rejected # create restriction matrix to impose \eqn{beta_2 = - \beta_6} R2 <- matrix( 0, nrow = 1, ncol = 7 ) R2[ 1, 2 ] <- 1 R2[ 1, 6 ] <- 1 ## constrained SUR estimation fitsur2 <- systemfit( system, "SUR", data = Kmenta, restrict.matrix = R2 ) ## perform LR-test lrTest2 <- lrtest( fitsur2, fitsur ) print( lrTest2 ) # accepted
These functions return the data used by systemfit
to estimate a system of equations.
## S3 method for class 'systemfit' model.frame( formula, ... ) ## S3 method for class 'systemfit.equation' model.frame( formula, ... )
## S3 method for class 'systemfit' model.frame( formula, ... ) ## S3 method for class 'systemfit.equation' model.frame( formula, ... )
formula |
an object of class |
... |
currently ignored. |
model.frame.systemfit
returns a simple data frame
(without a 'terms' attribute) that contains all variables
used to estimate the entire system of equations.
model.frame.systemfit.equation
returns a model frame
(data frame with a 'terms' attribute) that contains
all variables used to estimate the respective equation.
Arne Henningsen [email protected]
systemfit
, model.frame
, and
model.matrix.systemfit
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS of the system fitols <- systemfit( system, data = Kmenta ) ## data used to estimate the entire system model.frame( fitols ) ## data used to estimate the first equation model.frame( fitols$eq[[ 1 ]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS of the system fitols <- systemfit( system, data = Kmenta ) ## data used to estimate the entire system model.frame( fitols ) ## data used to estimate the first equation model.frame( fitols$eq[[ 1 ]] )
These functions create design matrices from objects
returned by systemfit
.
## S3 method for class 'systemfit' model.matrix( object, which = "x", ... ) ## S3 method for class 'systemfit.equation' model.matrix( object, which = "x", ... )
## S3 method for class 'systemfit' model.matrix( object, which = "x", ... ) ## S3 method for class 'systemfit.equation' model.matrix( object, which = "x", ... )
object |
an object of class |
which |
character string:
|
... |
currently ignored. |
model.matrix.systemfit
returns a design matrix to estimate
the specified system of equations.
model.matrix.systemfit.equation
returns a design matrix to estimate
the specified formula of the respective equation.
Arne Henningsen [email protected]
systemfit
, model.matrix
, and
model.frame.systemfit
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS of the system fitols <- systemfit( system, data = Kmenta ) ## design matrix of the entire system model.matrix( fitols ) ## design matrix of the first equation model.matrix( fitols$eq[[ 1 ]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS of the system fitols <- systemfit( system, data = Kmenta ) ## design matrix of the entire system model.matrix( fitols ) ## design matrix of the first equation model.matrix( fitols$eq[[ 1 ]] )
Fits a set of structural nonlinear equations using Ordinary Least Squares (OLS), Seemingly Unrelated Regression (SUR), Two-Stage Least Squares (2SLS), Three-Stage Least Squares (3SLS).
nlsystemfit( method="OLS", eqns, startvals, eqnlabels=c(as.character(1:length(eqns))), inst=NULL, data=list(), solvtol=.Machine$double.eps, maxiter=1000, ... )
nlsystemfit( method="OLS", eqns, startvals, eqnlabels=c(as.character(1:length(eqns))), inst=NULL, data=list(), solvtol=.Machine$double.eps, maxiter=1000, ... )
method |
the estimation method, one of "OLS", "SUR", "2SLS", "3SLS". |
eqns |
a list of structural equations to be estimated. |
startvals |
a list of starting values for the coefficients. |
eqnlabels |
an optional list of character vectors of names for the equation labels. |
inst |
one-sided model formula specifying instrumental variables or a list of one-sided model formulas if different instruments should be used for the different equations (only needed for 2SLS, 3SLS and GMM estimations). |
data |
an optional data frame containing the variables in the model. By default the variables are taken from the environment from which nlsystemfit is called. |
solvtol |
tolerance for detecting linear dependencies in the columns
of X in the |
maxiter |
the maximum number of iterations for the |
... |
arguments passed to |
The nlsystemfit function relies on nlm
to perform the
minimization of the objective functions and the qr
set
of functions.
A system of nonlinear equations can be written as:
where are the residuals from the y observations and
the function evaluated at the coefficient estimates.
The objective functions for the methods are:
Method | Instruments | Objective Function | Covariance of
|
OLS | no | |
|
SUR | no | |
|
2SLS | yes | |
|
3SLS | yes | |
|
where, r is a column vector for the residuals for each equation, S is
variance-covariance matrix between the equations
(), X is matrix of the
partial derivates with respect to the coefficients, W is a matrix of the
instrument variables
, Z is a matrix of the
instrument variables, and I is an nxn identity matrix.
The SUR and 3SLS methods requires two solutions. The first solution for the SUR is an OLS solution to obtain the variance-covariance matrix. The 3SLS uses the variance-covatiance from a 2SLS solution, then fits all the equations simultaneously.
The user should be aware that the function is VERY sensative to
the starting values and the nlm function may not converge. The nlm
function will be called with the typsize
argument set the
absolute values of the starting values for the OLS and 2SLS
methods. For the SUR and 3SLS methods, the typsize
argument is
set to the absolute values of the resulting OLS and 2SLS coefficient
estimates from the nlm result structre. In addition, the starting
values for the SUR and 3SLS methods are obtained from the OLS and 2SLS
coefficient estimates to shorten the number of iterations. The number of
iterations reported in the summary are only those used in the last
call to nlm, thus the number of iterations in the OLS portion of the
SUR fit and the 2SLS portion of the 3SLS fit are not included.
nlsystemfit
returns a list of the class nlsystemfit.system
and
contains all results that belong to the whole system.
This list contains one special object: "eq". It is a list and contains
one object for each estimated equation. These objects are of the class
nlsystemfit.equation
and contain the results that belong only to the
regarding equation.
The objects of the class nlsystemfit.system
and
nlsystemfit.equation
have the following components (the elements of
the latter are marked with an asterisk ()):
eq |
a list object that contains a list object for each equation. |
method |
estimation method. |
resids |
an |
g |
number of equations. |
n |
total number of observations. |
k |
total number of coefficients. |
b |
vector of all estimated coefficients. |
se |
estimated standard errors of |
t |
t values for |
p |
p values for |
bcov |
estimated covariance matrix of |
rcov |
estimated residual covariance matrix. |
drcov |
determinant of |
rcovest |
residual covariance matrix used for estimation (only SUR and 3SLS). |
rcor |
estimated residual correlation matrix. |
nlmest |
results from the nlm function call |
solvetol |
tolerance level when inverting a matrix or calculating a determinant. |
## elements of the class nlsystemfit.eq
eq |
a list that contains the results that belong to the individual equations. |
eqnlabel* |
the equation label of the ith equation (from the labels list). |
formula* |
model formula of the ith equation. |
n* |
number of observations of the ith equation. |
k* |
number of coefficients/regressors in the ith equation. |
df* |
degrees of freedom of the ith equation. |
b* |
estimated coefficients of the ith equation. |
se* |
estimated standard errors of |
t* |
t values for |
p* |
p values for |
covb* |
estimated covariance matrix of |
predicted* |
vector of predicted values of the ith equation. |
residuals* |
vector of residuals of the ith equation. |
ssr* |
sum of squared residuals of the ith equation. |
mse* |
estimated variance of the residuals (mean of squared errors) of the ith equation. |
s2* |
estimated variance of the residuals ( |
rmse* |
estimated standard error of the residulas (square root of mse) of the ith equation. |
s* |
estimated standard error of the residuals ( |
r2* |
R-squared (coefficient of determination). |
adjr2* |
adjusted R-squared value. |
Jeff D. Hamann [email protected]
Gallant, R. H. (1987) Nonlinear Equation Estimation, John Wiley and Sons, 610 pp.
SAS Institute (1999) SAS/ETS User's Guide, Version 8, Cary NC: SAS Institute 1546 pp.
library( systemfit ) data( ppine ) hg.formula <- hg ~ exp( h0 + h1*log(tht) + h2*tht^2 + h3*elev + h4*cr) dg.formula <- dg ~ exp( d0 + d1*log(dbh) + d2*hg + d3*cr + d4*ba ) labels <- list( "height.growth", "diameter.growth" ) inst <- ~ tht + dbh + elev + cr + ba start.values <- c(h0=-0.5, h1=0.5, h2=-0.001, h3=0.0001, h4=0.08, d0=-0.5, d1=0.009, d2=0.25, d3=0.005, d4=-0.02 ) model <- list( hg.formula, dg.formula ) model.ols <- nlsystemfit( "OLS", model, start.values, data=ppine, eqnlabels=labels ) print( model.ols ) model.sur <- nlsystemfit( "SUR", model, start.values, data=ppine, eqnlabels=labels ) print( model.sur ) model.2sls <- nlsystemfit( "2SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.2sls ) model.3sls <- nlsystemfit( "3SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.3sls )
library( systemfit ) data( ppine ) hg.formula <- hg ~ exp( h0 + h1*log(tht) + h2*tht^2 + h3*elev + h4*cr) dg.formula <- dg ~ exp( d0 + d1*log(dbh) + d2*hg + d3*cr + d4*ba ) labels <- list( "height.growth", "diameter.growth" ) inst <- ~ tht + dbh + elev + cr + ba start.values <- c(h0=-0.5, h1=0.5, h2=-0.001, h3=0.0001, h4=0.08, d0=-0.5, d1=0.009, d2=0.25, d3=0.005, d4=-0.02 ) model <- list( hg.formula, dg.formula ) model.ols <- nlsystemfit( "OLS", model, start.values, data=ppine, eqnlabels=labels ) print( model.ols ) model.sur <- nlsystemfit( "SUR", model, start.values, data=ppine, eqnlabels=labels ) print( model.sur ) model.2sls <- nlsystemfit( "2SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.2sls ) model.3sls <- nlsystemfit( "3SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.3sls )
A subset of tree growth observations from a Ponderosa pine growth database.
The ppine
data frame has 166 rows and 8 columns.
data(ppine)
data(ppine)
This data frame contains the following columns:
Altitude of the plot, in feet above mean sea level.
Summer moisture index is the ratio of growing season heating degree days to growing season precipitation.
Diameter of the tree at breast height (4.5 feet).
Total stem height for the tree.
Crown ratio code. The scale is from 1 to 9 where a crown class of one represents a crown ratio between 0 and 15 percent. A crown ratio code of 2 represents a crown ratio value between 16 and 25%,...,8=76-85%, 9 >=85%.
Plot basal area at the beginning of the growth period.
Five-year diameter increment.
Five-year height increment.
The exogenous variables are elev
, smi
, dbh
,
tht
, cr
, and ba
; the endogenous variables
dg
and hg
. There are no lagged variables in the dataset
and the observations are for a single remeasurement.
The data was provided by the USDA Forest Service Intermountain Research Station.
William R. Wykoff [email protected] Rocky Mountain Research Station, 1221 South Main Street, Moscow, ID 83843
data(ppine)
data(ppine)
Returns the predicted values, their standard errors and the confidence limits of prediction.
## S3 method for class 'systemfit' predict( object, newdata = NULL, se.fit = FALSE, se.pred = FALSE, interval = "none", level=0.95, useDfSys = NULL, ... ) ## S3 method for class 'systemfit.equation' predict( object, newdata = NULL, se.fit = FALSE, se.pred = FALSE, interval = "none", level=0.95, useDfSys = NULL, ... )
## S3 method for class 'systemfit' predict( object, newdata = NULL, se.fit = FALSE, se.pred = FALSE, interval = "none", level=0.95, useDfSys = NULL, ... ) ## S3 method for class 'systemfit.equation' predict( object, newdata = NULL, se.fit = FALSE, se.pred = FALSE, interval = "none", level=0.95, useDfSys = NULL, ... )
object |
an object of class |
newdata |
An optional data frame in which to look for variables with
which to predict. If it is |
se.fit |
return the standard error of the fitted values? |
se.pred |
return the standard error of prediction? |
interval |
Type of interval calculation ("none", "confidence" or "prediction") |
level |
Tolerance/confidence level. |
useDfSys |
logical. Use the degrees of freedom of the whole system
(in place of the degrees of freedom of the single equation)
to calculate the confidence or prediction intervals.
If it not specified ( |
... |
additional optional arguments. |
The variance of the fitted values
(used to calculate the standard errors of the fitted values
and the "confidence interval") is calculated by
The variances of the predicted values
(used to calculate the standard errors of the predicted values
and the "prediction intervals") is calculated by
predict.systemfit
returns a dataframe that
contains for each equation the predicted values
("<eqnLable>.pred") and if requested
the standard errors of the fitted values ("<eqnLable>.se.fit"),
the standard errors of the prediction ("<eqnLable>.se.pred"),
and the lower ("<eqnLable>.lwr") and upper ("<eqnLable>.upr")
limits of the confidence or prediction interval(s).
predict.systemfit.equation
returns a dataframe that
contains the predicted values ("fit") and if requested
the standard errors of the fitted values ("se.fit"),
the standard errors of the prediction ("se.pred"),
and the lower ("lwr") and upper ("upr")
limits of the confidence or prediction interval(s).
Arne Henningsen [email protected]
Greene, W. H. (2003) Econometric Analysis, Fifth Edition, Macmillan.
Gujarati, D. N. (1995) Basic Econometrics, Third Edition, McGraw-Hill.
Kmenta, J. (1997) Elements of Econometrics, Second Edition, University of Michigan Publishing.
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## OLS estimation fitols <- systemfit( system, data=Kmenta ) ## predicted values and limits predict( fitols ) ## predicted values of the first equation predict( fitols$eq[[1]] ) ## predicted values of the second equation predict( fitols$eq[[2]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## OLS estimation fitols <- systemfit( system, data=Kmenta ) ## predicted values and limits predict( fitols ) ## predicted values of the first equation predict( fitols$eq[[1]] ) ## predicted values of the second equation predict( fitols$eq[[2]] )
This function prints the confidence intervals of the coefficients of the estimated equation system.
## S3 method for class 'confint.systemfit' print( x, digits=3, ... )
## S3 method for class 'confint.systemfit' print( x, digits=3, ... )
x |
an object of type |
digits |
number of digits to print. |
... |
other arguments. |
Arne Henningsen [email protected]
systemfit
, confint.systemfit
and confint.systemfit.equation
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## calculate and print the confidence intervals ## of all coefficients ci <- confint( fitols ) print( ci, digits=4 ) ## calculate and print the confidence intervals ## of the coefficients of the second equation ci2 <- confint( fitols$eq[[2]] ) print( ci2, digits=4 )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## calculate and print the confidence intervals ## of all coefficients ci <- confint( fitols ) print( ci, digits=4 ) ## calculate and print the confidence intervals ## of the coefficients of the second equation ci2 <- confint( fitols$eq[[2]] ) print( ci2, digits=4 )
These functions print a summary of the estimated equation system.
## S3 method for class 'nlsystemfit.system' print( x, digits=6, ... ) ## S3 method for class 'nlsystemfit.equation' print( x, digits=6, ... )
## S3 method for class 'nlsystemfit.system' print( x, digits=6, ... ) ## S3 method for class 'nlsystemfit.equation' print( x, digits=6, ... )
x |
an object of class |
digits |
number of digits to print. |
... |
not used by user. |
Jeff D. Hamann [email protected]
nlsystemfit
, summary.nlsystemfit.system
library( systemfit ) data( ppine ) hg.formula <- hg ~ exp( h0 + h1*log(tht) + h2*tht^2 + h3*elev + h4*cr) dg.formula <- dg ~ exp( d0 + d1*log(dbh) + d2*hg + d3*cr + d4*ba ) labels <- list( "height.growth", "diameter.growth" ) inst <- ~ tht + dbh + elev + cr + ba start.values <- c(h0=-0.5, h1=0.5, h2=-0.001, h3=0.0001, h4=0.08, d0=-0.5, d1=0.009, d2=0.25, d3=0.005, d4=-0.02 ) model <- list( hg.formula, dg.formula ) model.ols <- nlsystemfit( "OLS", model, start.values, data=ppine, eqnlabels=labels ) print( model.ols ) model.3sls <- nlsystemfit( "3SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.3sls )
library( systemfit ) data( ppine ) hg.formula <- hg ~ exp( h0 + h1*log(tht) + h2*tht^2 + h3*elev + h4*cr) dg.formula <- dg ~ exp( d0 + d1*log(dbh) + d2*hg + d3*cr + d4*ba ) labels <- list( "height.growth", "diameter.growth" ) inst <- ~ tht + dbh + elev + cr + ba start.values <- c(h0=-0.5, h1=0.5, h2=-0.001, h3=0.0001, h4=0.08, d0=-0.5, d1=0.009, d2=0.25, d3=0.005, d4=-0.02 ) model <- list( hg.formula, dg.formula ) model.ols <- nlsystemfit( "OLS", model, start.values, data=ppine, eqnlabels=labels ) print( model.ols ) model.3sls <- nlsystemfit( "3SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.3sls )
These functions print a few results of the estimated equation system.
## S3 method for class 'systemfit' print( x, digits = max( 3, getOption("digits") - 1 ), ... ) ## S3 method for class 'systemfit.equation' print( x, digits = max( 3, getOption("digits") - 1 ), ... )
## S3 method for class 'systemfit' print( x, digits = max( 3, getOption("digits") - 1 ), ... ) ## S3 method for class 'systemfit.equation' print( x, digits = max( 3, getOption("digits") - 1 ), ... )
x |
an object of class |
digits |
number of digits to print. |
... |
other arguments. |
Jeff D. Hamann [email protected],
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## results of the whole system print( fitols ) ## results of the first equation print( fitols$eq[[1]] ) ## results of the second equation print( fitols$eq[[2]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## results of the whole system print( fitols ) ## results of the first equation print( fitols$eq[[1]] ) ## results of the second equation print( fitols$eq[[2]] )
These functions extract the residuals
from an object returned by
systemfit
.
## S3 method for class 'systemfit' residuals( object, ... ) ## S3 method for class 'systemfit.equation' residuals( object, na.rm = FALSE, ... )
## S3 method for class 'systemfit' residuals( object, ... ) ## S3 method for class 'systemfit.equation' residuals( object, na.rm = FALSE, ... )
object |
an object of class |
na.rm |
a logical value indicating whether |
... |
other arguments. |
residuals.systemfit
returns a data.frame of residuals,
where each column contains the residuals of one equation.
residuals.systemfit.equation
returns a vector of residuals.
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## residuals of all equations residuals( fitols ) ## residuals of the first equation residuals( fitols$eq[[1]] ) ## residuals of the second equation residuals( fitols$eq[[2]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## residuals of all equations residuals( fitols ) ## residuals of the first equation residuals( fitols$eq[[1]] ) ## residuals of the second equation residuals( fitols$eq[[2]] )
se.ratio.systemfit
returns a vector of the ratios of the
standard errors of the predictions for two equations.
se.ratio.systemfit( resultsi, resultsj, eqni )
se.ratio.systemfit( resultsi, resultsj, eqni )
resultsi |
an object of type |
resultsj |
an object of type |
eqni |
index for equation to obtain the ratio of standard errors. |
se.ratio
returns a vector of the standard errors of the ratios
for the predictions between the predicted values in equation i and
equation j.
Jeff D. Hamann [email protected]
Hasenauer, H; Monserud, R and T. Gregoire. (1998) Using Simultaneous Regression Techniques with Individual-Tree Growth Models. Forest Science. 44(1):87-95
systemfit
and correlation.systemfit
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform 2SLS on each of the equations in the system fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## print the results from the fits print( fit2sls ) print( fit3sls ) print( "covariance of residuals used for estimation (from 2sls)" ) print( fit3sls$residCovEst ) print( "covariance of residuals" ) print( fit3sls$residCov ) ## examine the improvement of 3SLS over 2SLS by computing ## the ratio of the standard errors of the estimates improve.ratio <- se.ratio.systemfit( fit2sls, fit3sls, 2 ) print( "summary values for the ratio in the std. err. for the predictions" ) print( summary( improve.ratio ) )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform 2SLS on each of the equations in the system fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta ) ## print the results from the fits print( fit2sls ) print( fit3sls ) print( "covariance of residuals used for estimation (from 2sls)" ) print( fit3sls$residCovEst ) print( "covariance of residuals" ) print( fit3sls$residCov ) ## examine the improvement of 3SLS over 2SLS by computing ## the ratio of the standard errors of the estimates improve.ratio <- se.ratio.systemfit( fit2sls, fit3sls, 2 ) print( "summary values for the ratio in the std. err. for the predictions" ) print( summary( improve.ratio ) )
These functions print a summary of the estimated equation system.
## S3 method for class 'nlsystemfit.system' summary( object, ... ) ## S3 method for class 'nlsystemfit.equation' summary( object, ... )
## S3 method for class 'nlsystemfit.system' summary( object, ... ) ## S3 method for class 'nlsystemfit.equation' summary( object, ... )
object |
an object of class |
... |
not used by user. |
Jeff D. Hamann [email protected]
nlsystemfit
, print.nlsystemfit.system
library( systemfit ) data( ppine ) hg.formula <- hg ~ exp( h0 + h1*log(tht) + h2*tht^2 + h3*elev + h4*cr) dg.formula <- dg ~ exp( d0 + d1*log(dbh) + d2*hg + d3*cr + d4*ba ) labels <- list( "height.growth", "diameter.growth" ) inst <- ~ tht + dbh + elev + cr + ba start.values <- c(h0=-0.5, h1=0.5, h2=-0.001, h3=0.0001, h4=0.08, d0=-0.5, d1=0.009, d2=0.25, d3=0.005, d4=-0.02 ) model <- list( hg.formula, dg.formula ) model.ols <- nlsystemfit( "OLS", model, start.values, data=ppine, eqnlabels=labels ) print( model.ols ) model.3sls <- nlsystemfit( "3SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.3sls )
library( systemfit ) data( ppine ) hg.formula <- hg ~ exp( h0 + h1*log(tht) + h2*tht^2 + h3*elev + h4*cr) dg.formula <- dg ~ exp( d0 + d1*log(dbh) + d2*hg + d3*cr + d4*ba ) labels <- list( "height.growth", "diameter.growth" ) inst <- ~ tht + dbh + elev + cr + ba start.values <- c(h0=-0.5, h1=0.5, h2=-0.001, h3=0.0001, h4=0.08, d0=-0.5, d1=0.009, d2=0.25, d3=0.005, d4=-0.02 ) model <- list( hg.formula, dg.formula ) model.ols <- nlsystemfit( "OLS", model, start.values, data=ppine, eqnlabels=labels ) print( model.ols ) model.3sls <- nlsystemfit( "3SLS", model, start.values, data=ppine, eqnlabels=labels, inst=inst ) print( model.3sls )
These functions create and print summary results of the estimated equation system.
## S3 method for class 'systemfit' summary( object, useDfSys = NULL, residCov = TRUE, equations = TRUE, ... ) ## S3 method for class 'systemfit.equation' summary( object, useDfSys = NULL, ... ) ## S3 method for class 'summary.systemfit' print( x, digits = max( 3, getOption("digits") - 1 ), residCov = x$printResidCov, equations = x$printEquations, ... ) ## S3 method for class 'summary.systemfit.equation' print( x, digits = max( 3, getOption("digits") - 1 ), ... )
## S3 method for class 'systemfit' summary( object, useDfSys = NULL, residCov = TRUE, equations = TRUE, ... ) ## S3 method for class 'systemfit.equation' summary( object, useDfSys = NULL, ... ) ## S3 method for class 'summary.systemfit' print( x, digits = max( 3, getOption("digits") - 1 ), residCov = x$printResidCov, equations = x$printEquations, ... ) ## S3 method for class 'summary.systemfit.equation' print( x, digits = max( 3, getOption("digits") - 1 ), ... )
object |
an object of class |
x |
an object of class |
useDfSys |
logical. Use the degrees of freedom of the whole system
(in place of the degrees of freedom of the single equation)
to calculate prob values for the t-test of individual coefficients.
If it not specified ( |
digits |
number of digits to print. |
residCov |
logical. If |
equations |
logical. If |
... |
not used by user. |
Applying summary
on an object of class systemfit
returns a list of class summary.systemfit
.
Applying summary
on an object of class
systemfit.equation
returns a list of class
summary.systemfit.equation
.
An object of class summary.systemfit
contains all results that belong to the whole system.
This list contains one special object: eq
.
This is a list and contains objects of class
summary.systemfit.equation
.
These objects contain the results that belong to each of the eatimated equations.
The objects of classes summary.systemfit
and
summary.systemfit.equation
have the following components
(elements that are marked with a are available only in objects of
class
summary.systemfit
;
elements that are marked with a are available only in objects of
class
summary.systemfit.equation
):
method |
estimation method. |
residuals |
residuals. |
coefficients |
a matrix with columns for the estimated coefficients, their standard errors, t-statistic and corresponding (two-sided) p-values. |
df |
degrees of freedom, a 2-vector, where the first element is the number of coefficients and the second element is the number of observations minus the number of coefficients. |
coefCov |
estimated covariance matrix of the coefficients. |
call* |
the matched call of |
ols.r.squared* |
OLS |
mcelroy.r.squared* |
McElroy's |
iter* |
number of iteration steps (only if the estimation is iterated). |
control* |
list of control parameters used for the estimation. |
residCov* |
estimated residual covariance matrix. |
residCovEst* |
residual covariance matrix used for estimation (only SUR and 3SLS). |
residCor* |
correlation matrix of the residuals. |
detResidCov* |
determinant of |
eqnLabel+ |
equation label. |
eqnNo+ |
equation number. |
terms+ |
the 'terms' object used for the respective equation. |
r.squared+ |
|
adj.r.squared+ |
adjusted |
sigma+ |
estimated standard error of the residuals of the respective equation. |
ssr+ |
sum of squared residuals of the respective equation. |
printResidCov* |
argument |
printEquations* |
argument |
Jeff D. Hamann [email protected],
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## results of the system summary( fitols ) ## short results of the system summary( fitols, residCov = FALSE, equations = FALSE ) ## results of the first equation summary( fitols$eq[[1]] ) ## results of the second equation summary( fitols$eq[[2]] )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend inst <- ~ income + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## results of the system summary( fitols ) ## short results of the system summary( fitols, residCov = FALSE, equations = FALSE ) ## results of the first equation summary( fitols$eq[[1]] ) ## results of the second equation summary( fitols$eq[[2]] )
Fits a set of linear structural equations using Ordinary Least Squares (OLS), Weighted Least Squares (WLS), Seemingly Unrelated Regression (SUR), Two-Stage Least Squares (2SLS), Weighted Two-Stage Least Squares (W2SLS) or Three-Stage Least Squares (3SLS).
systemfit( formula, method = "OLS", inst=NULL, data=list(), restrict.matrix = NULL, restrict.rhs = NULL, restrict.regMat = NULL, pooled = FALSE, control = systemfit.control( ... ), ... )
systemfit( formula, method = "OLS", inst=NULL, data=list(), restrict.matrix = NULL, restrict.rhs = NULL, restrict.regMat = NULL, pooled = FALSE, control = systemfit.control( ... ), ... )
formula |
an object of class |
method |
the estimation method, one of "OLS", "WLS", "SUR",
"2SLS", "W2SLS", or "3SLS" (see details);
iterated estimation methods can be specified by setting control parameter
|
inst |
one-sided model formula specifying the instrumental variables (including exogenous explanatory variables) or a list of one-sided model formulas if different instruments should be used for the different equations (only needed for 2SLS, W2SLS, and 3SLS estimations). |
data |
an optional data frame containing the variables in the model. By default the variables are taken from the environment from which systemfit is called. |
restrict.matrix |
an optional j x k matrix to impose linear
restrictions on the coefficients by |
restrict.rhs |
an optional vector with j elements to impose linear
restrictions (see |
restrict.regMat |
an optional matrix to impose restrictions on the coefficients by post-multiplying the regressor matrix with this matrix (see details). |
control |
list of control parameters.
The default is constructed by the function |
pooled |
logical, restrict coefficients to be equal in all equations (only for panel-like data). |
... |
arguments passed to |
The estimation of systems of equations with unequal numbers
of observations has not been thoroughly tested yet.
Currently, systemfit
calculates the residual covariance matrix
only from the residuals/observations that are available
in all equations.
If argument data
is of class pdata.frame
(created with pdata.frame()
and thus, contains panel data in long format),
argument formula
must be a single equation
that is applied to all individuals.
In this case, argument pooled
specifies
whether the coefficients are restricted to be equal for all
individuals.
If argument restrict.regMat
is specified,
the regressor matrix is post-multiplied by this matrix:
restrict.regMat
.
Then, this modified regressor matrix is used for the
estimation of the coefficient vector
.
This means that the coefficients of the original regressors (
),
vector
,
can be represented by
restrict.regMat
.
If
restrict.regMat
is a non-singular quadratic matrix,
there are no restrictions on the coefficients imposed,
but the coefficients are linear combinations of
the original coefficients
.
If
restrict.regMat
has less columns than rows,
linear restrictions are imposed on the coefficients .
However, imposing linear restrictions
by the
restrict.regMat
matrix is less flexible than
by providing the matrix restrict.matrix
and the
vector restrict.rhs
.
The advantage of imposing restrictions on the coefficients
by the matrix restrict.regMat
is that the matrix,
which has to be inverted during the estimation,
gets smaller by this procedure, while it gets larger
if the restrictions are imposed by restrict.matrix
and restrict.rhs
.
In the context of multi-equation models, the term “weighted” in “weighted least squares” (WLS) and “weighted two-stage least squares” (W2SLS) means that the equations might have different weights and not that the observations have different weights.
It is important to realize the limitations on estimating the residuals
covariance matrix imposed by the number of observations
in each equation.
With
equations we estimate
elements using
observations total.
Beck and Katz (1995,1993) discuss the issue and the resulting overconfidence
when the ratio of
is small (e.g. 3).
Even for
the estimate is unstable both numerically
and statistically
and the 95
approximately
,
which is inadequate precision if the covariance matrix will be used
for simulation of asset return paths either for investment or risk
management decisions.
For a starter on models with large cross-sections see Reichlin (2002).
[This paragraph has been provided by Stephen C. Bond – Thanks!]
systemfit
returns a list of the class systemfit
and
contains all results that belong to the whole system.
This list contains one special object: "eq". It is a list and contains
one object for each estimated equation. These objects are of the class
systemfit.equation
and contain the results that belong only to the
regarding equation.
The objects of the class systemfit
and
systemfit.equation
have the following components (the elements of
the latter are marked with an asterisk ()):
call |
the matched call. |
method |
estimation method. |
rank |
total number of linear independent coefficients = number of coefficients minus number of linear restrictions. |
df.residual |
degrees of freedom of the whole system. |
iter |
number of iteration steps. |
coefficients |
vector of all estimated coefficients. |
coefCov |
estimated covariance matrix of |
residCov |
estimated residual covariance matrix. |
residCovEst |
residual covariance matrix used for estimation (only WLS, W2SLS, SUR and 3SLS). |
restrict.matrix |
the restriction matrix. |
restrict.rhs |
the restriction vector. |
restrict.regMat |
matrix used to impose restrictions on the coefficients by post-multiplying the regressor matrix with this matrix. |
control |
list of control parameters used for the estimation. |
panelLike |
logical. Was this an analysis with panel-like data? |
## elements of the class systemfit.eq
eq |
a list that contains the results that belong to the individual equations. |
eqnLabel* |
the label of this equation. |
eqnNo* |
the number of this equation. |
terms* |
the 'terms' object used for the ith equation. |
inst* |
instruments of the ith equation (only 2SLS, W2SLS, and 3SLS). |
termsInst* |
the 'terms' object of the instruments used for the ith equation (only 2SLS, W2SLS, and 3SLS). |
rank* |
number of linear independent coefficients in the ith equation (differs from the number of coefficients only if there are restrictions that are not cross-equation). |
nCoef.sys* |
total number of coefficients in all equations. |
rank.sys* |
total number of linear independent coefficients in all equations. |
df.residual* |
degrees of freedom of the ith equation. |
df.residual.sys* |
degrees of freedom of the whole system. |
coefficients* |
estimated coefficients of the ith equation. |
covb* |
estimated covariance matrix of |
model* |
if requested (the default), the model frame of the ith equation. |
modelInst* |
if requested (the default), the model frame of the instrumental variables of the ith equation (only 2SLS, W2SLS, and 3SLS). |
x* |
if requested, the model matrix of the ith equation. |
y* |
if requested, the response of the ith equation. |
z* |
if requested, the matrix of instrumental variables of the ith equation (only 2SLS, W2SLS, and 3SLS). |
fitted.values* |
vector of fitted values of the ith equation. |
residuals* |
vector of residuals of the ith equation. |
Arne Henningsen [email protected],
Jeff D. Hamann [email protected]
Beck, N.; J.N. Katz (1995) What to do (and not to do) with Time-Series Cross-Section Data, The American Political Science Review, 89, pp. 634-647.
Beck, N.; J.N. Katz; M.R. Alvarez; G. Garrett; P. Lange (1993) Government Partisanship, Labor Organization, and Macroeconomic Performance: a Corrigendum, American Political Science Review, 87, pp. 945-48.
Greene, W. H. (2003) Econometric Analysis, Fifth Edition, Prentice Hall.
Judge, George G.; W. E. Griffiths; R. Carter Hill; Helmut Luetkepohl and Tsoung-Chao Lee (1985) The Theory and Practice of Econometrics, Second Edition, Wiley.
Kmenta, J. (1997) Elements of Econometrics, Second Edition, University of Michigan Publishing.
Reichlin, L. (2002) Factor models in large cross-sections of time series, Working Paper, ECARES and CEPR.
Schmidt, P. (1990) Three-Stage Least Squares with different Instruments for different equations, Journal of Econometrics 43, p. 389-394.
Theil, H. (1971) Principles of Econometrics, Wiley, New York.
lm
and nlsystemfit
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## OLS estimation fitols <- systemfit( system, data=Kmenta ) print( fitols ) ## OLS estimation with 2 restrictions Rrestr <- matrix(0,2,7) Rrestr[1,3] <- 1 Rrestr[1,7] <- -1 Rrestr[2,2] <- -1 Rrestr[2,5] <- 1 qrestr <- c( 0, 0.5 ) fitols2 <- systemfit( system, data = Kmenta, restrict.matrix = Rrestr, restrict.rhs = qrestr ) print( fitols2 ) ## OLS estimation with the same 2 restrictions in symbolic form restrict <- c( "demand_income - supply_trend = 0", "- demand_price + supply_price = 0.5" ) fitols2b <- systemfit( system, data = Kmenta, restrict.matrix = restrict ) print( fitols2b ) # test whether both restricted estimators are identical all.equal( coef( fitols2 ), coef( fitols2b ) ) ## OLS with restrictions on the coefficients by modifying the regressor matrix ## with argument restrict.regMat modReg <- matrix( 0, 7, 6 ) colnames( modReg ) <- c( "demIntercept", "demPrice", "demIncome", "supIntercept", "supPrice2", "supTrend" ) modReg[ 1, "demIntercept" ] <- 1 modReg[ 2, "demPrice" ] <- 1 modReg[ 3, "demIncome" ] <- 1 modReg[ 4, "supIntercept" ] <- 1 modReg[ 5, "supPrice2" ] <- 1 modReg[ 6, "supPrice2" ] <- 1 modReg[ 7, "supTrend" ] <- 1 fitols3 <- systemfit( system, data = Kmenta, restrict.regMat = modReg ) print( fitols3 ) ## iterated SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta, maxit = 100 ) print( fitsur ) ## 2SLS estimation inst <- ~ income + farmPrice + trend fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) print( fit2sls ) ## 2SLS estimation with different instruments in each equation inst1 <- ~ income + farmPrice inst2 <- ~ income + farmPrice + trend instlist <- list( inst1, inst2 ) fit2sls2 <- systemfit( system, "2SLS", inst = instlist, data = Kmenta ) print( fit2sls2 ) ## 3SLS estimation with GMM-3SLS formula inst <- ~ income + farmPrice + trend fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta, method3sls = "GMM" ) print( fit3sls ) ## Examples how to use systemfit() with panel-like data ## Repeating the SUR estimations in Greene (2003, p. 351) data( "GrunfeldGreene" ) if( requireNamespace( 'plm', quietly = TRUE ) ) { library( "plm" ) GGPanel <- pdata.frame( GrunfeldGreene, c( "firm", "year" ) ) formulaGrunfeld <- invest ~ value + capital # SUR greeneSur <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, methodResidCov = "noDfCor" ) summary( greeneSur ) # SUR Pooled greeneSurPooled <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, pooled = TRUE, methodResidCov = "noDfCor", residCovWeighted = TRUE ) summary( greeneSurPooled ) } ## Further examples are in the documentation to the data sets ## 'KleinI' and 'GrunfeldGreene'.
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## OLS estimation fitols <- systemfit( system, data=Kmenta ) print( fitols ) ## OLS estimation with 2 restrictions Rrestr <- matrix(0,2,7) Rrestr[1,3] <- 1 Rrestr[1,7] <- -1 Rrestr[2,2] <- -1 Rrestr[2,5] <- 1 qrestr <- c( 0, 0.5 ) fitols2 <- systemfit( system, data = Kmenta, restrict.matrix = Rrestr, restrict.rhs = qrestr ) print( fitols2 ) ## OLS estimation with the same 2 restrictions in symbolic form restrict <- c( "demand_income - supply_trend = 0", "- demand_price + supply_price = 0.5" ) fitols2b <- systemfit( system, data = Kmenta, restrict.matrix = restrict ) print( fitols2b ) # test whether both restricted estimators are identical all.equal( coef( fitols2 ), coef( fitols2b ) ) ## OLS with restrictions on the coefficients by modifying the regressor matrix ## with argument restrict.regMat modReg <- matrix( 0, 7, 6 ) colnames( modReg ) <- c( "demIntercept", "demPrice", "demIncome", "supIntercept", "supPrice2", "supTrend" ) modReg[ 1, "demIntercept" ] <- 1 modReg[ 2, "demPrice" ] <- 1 modReg[ 3, "demIncome" ] <- 1 modReg[ 4, "supIntercept" ] <- 1 modReg[ 5, "supPrice2" ] <- 1 modReg[ 6, "supPrice2" ] <- 1 modReg[ 7, "supTrend" ] <- 1 fitols3 <- systemfit( system, data = Kmenta, restrict.regMat = modReg ) print( fitols3 ) ## iterated SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta, maxit = 100 ) print( fitsur ) ## 2SLS estimation inst <- ~ income + farmPrice + trend fit2sls <- systemfit( system, "2SLS", inst = inst, data = Kmenta ) print( fit2sls ) ## 2SLS estimation with different instruments in each equation inst1 <- ~ income + farmPrice inst2 <- ~ income + farmPrice + trend instlist <- list( inst1, inst2 ) fit2sls2 <- systemfit( system, "2SLS", inst = instlist, data = Kmenta ) print( fit2sls2 ) ## 3SLS estimation with GMM-3SLS formula inst <- ~ income + farmPrice + trend fit3sls <- systemfit( system, "3SLS", inst = inst, data = Kmenta, method3sls = "GMM" ) print( fit3sls ) ## Examples how to use systemfit() with panel-like data ## Repeating the SUR estimations in Greene (2003, p. 351) data( "GrunfeldGreene" ) if( requireNamespace( 'plm', quietly = TRUE ) ) { library( "plm" ) GGPanel <- pdata.frame( GrunfeldGreene, c( "firm", "year" ) ) formulaGrunfeld <- invest ~ value + capital # SUR greeneSur <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, methodResidCov = "noDfCor" ) summary( greeneSur ) # SUR Pooled greeneSurPooled <- systemfit( formulaGrunfeld, "SUR", data = GGPanel, pooled = TRUE, methodResidCov = "noDfCor", residCovWeighted = TRUE ) summary( greeneSurPooled ) } ## Further examples are in the documentation to the data sets ## 'KleinI' and 'GrunfeldGreene'.
Create a list of control pararameters for function systemfit
.
All control parameters that are not passed to this function
are set to default values.
systemfit.control( maxiter = 1, tol = 1e-5, methodResidCov = "geomean", centerResiduals = FALSE, residCovRestricted = TRUE, residCovWeighted = FALSE, method3sls = "GLS", singleEqSigma = NULL, useMatrix = TRUE, solvetol = .Machine$double.eps, model = TRUE, x = FALSE, y = FALSE, z = FALSE )
systemfit.control( maxiter = 1, tol = 1e-5, methodResidCov = "geomean", centerResiduals = FALSE, residCovRestricted = TRUE, residCovWeighted = FALSE, method3sls = "GLS", singleEqSigma = NULL, useMatrix = TRUE, solvetol = .Machine$double.eps, model = TRUE, x = FALSE, y = FALSE, z = FALSE )
maxiter |
maximum number of iterations for WLS, SUR, W2SLS and 3SLS estimations. |
tol |
tolerance level indicating when to stop the iteration (only WLS, SUR, W2SLS and 3SLS estimations). |
methodResidCov |
method for calculating the estimated residual covariance matrix, one of "noDfCor", "geomean", "max", or "Theil" (see details). |
centerResiduals |
logical. Subtract the means from the residuals of each equation before calculating the estimated residual covariance matrix. |
residCovRestricted |
logical. If 'FALSE' the residual covariance matrix for a WLS, SUR, W2SLS, or 3SLS estimation is obtained from an unrestricted first-step estimation. |
residCovWeighted |
logical. If 'TRUE' the residual covariance matrix for a SUR or 3SLS estimation is obtained from a WLS or W2SLS estimation. |
method3sls |
method for calculating the 3SLS estimator, one of "GLS", "IV", "GMM", "Schmidt", or "EViews" (see details). |
singleEqSigma |
logical. use different |
useMatrix |
logical. Use package |
solvetol |
tolerance level for detecting linear dependencies
when inverting a matrix or calculating a determinant (see
|
model , x , y , z
|
logical. If 'TRUE' the corresponding components of the fit (the model frame, the model matrix, the response, and the matrix of instruments, respectively) are returned. |
If the estimation is iterated
(WLS, SUR, W2SLS or 3SLS estimation with maxiter
>1),
the convergence criterion is
( is the ith coefficient of the gth iteration step).
The method for calculating the estimated covariance matrix of the residuals
() can be one of the following
(see Judge et al., 1985, p. 469):
if methodResidCov='noDfCor':
if methodResidCov='geomean':
if methodResidCov='Theil':
if methodResidCov='max':
If , the formulas 'geomean', 'Theil', and 'max' are equal.
All these three formulas yield unbiased estimators
for the diagonal elements of the residual covariance matrix.
If
, only formula 'Theil' yields an unbiased estimator for the residual
covariance matrix, but it is not neccessarily positive semidefinit. Thus, it is
doubtful whether formula 'Theil' is really superior to formula 'noDfCor'
(Theil, 1971, p. 322).
The methods for calculating the 3SLS estimator lead to identical results if the same instruments are used in all equations. If different instruments are used in the different equations, only the GMM-3SLS estimator ("GMM") and the 3SLS estimator proposed by Schmidt (1990) ("Schmidt") are consistent, whereas "GMM" is efficient relative to "Schmidt" (see Schmidt, 1990).
If residCovWeighted
is TRUE
,
systemfit
does a OLS or 2SLS estimation in a first step.
It uses the residuals from the first-step estimation
to calculate the residual covariance matrix
that is used in a second-step WLS or W2SLS estimation.
Then, it uses the residuals from the second-step estimation
to calculate the residual covariance matrix
that is used in a final SUR or 3SLS estimation.
This three-step method is the default method of command "TSCS"
in the software LIMDEP that carries out "SUR" estimations
in which all coefficient vectors are constrained to be equal
(personal information from W.H. Greene, 2006/02/16).
If no cross-equation restrictions are imposed,
residCovWeighted
has no effect on the estimation results.
A list of the above components.
Arne Henningsen [email protected]
Judge, George G.; W. E. Griffiths; R. Carter Hill; Helmut Luetkepohl and Tsoung-Chao Lee (1985) The Theory and Practice of Econometrics, Second Edition, Wiley.
Schmidt, P. (1990) Three-Stage Least Squares with different Instruments for different equations, Journal of Econometrics 43, p. 389-394.
Theil, H. (1971) Principles of Econometrics, Wiley, New York.
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend eqSystem <- list( demand = eqDemand, supply = eqSupply ) ## SUR estimation: calculation of residual covariance ## matrix without correction for degrees of freedom fitsur <- systemfit( eqSystem, "SUR", data = Kmenta, control = systemfit.control( methodResidCov = "noDfCor" ) ) print( fitsur )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend eqSystem <- list( demand = eqDemand, supply = eqSupply ) ## SUR estimation: calculation of residual covariance ## matrix without correction for degrees of freedom fitsur <- systemfit( eqSystem, "SUR", data = Kmenta, control = systemfit.control( methodResidCov = "noDfCor" ) ) print( fitsur )
This method extracts the model terms
from fitted objects returned by systemfit
.
## S3 method for class 'systemfit' terms( x, ... ) ## S3 method for class 'systemfit.equation' terms( x, ... )
## S3 method for class 'systemfit' terms( x, ... ) ## S3 method for class 'systemfit.equation' terms( x, ... )
x |
an object of class |
... |
currently not used. |
terms.systemfit.equation
returns the model terms
of a single equation of a systemfit
object.
terms.systemfit.equation
returns a list of model terms:
one model term object for each equation
of the systemfit
object.
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform a SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) ## model terms of the second equation terms( fitsur$eq[[ 2 ]] ) ## all model terms of the system terms( fitsur )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform a SUR estimation fitsur <- systemfit( system, "SUR", data = Kmenta ) ## model terms of the second equation terms( fitsur$eq[[ 2 ]] ) ## all model terms of the system terms( fitsur )
These functions extract the variance covariance matrix of the
coefficients from an object returned by
systemfit
.
## S3 method for class 'systemfit' vcov( object, modified.regMat = FALSE, ... ) ## S3 method for class 'systemfit.equation' vcov( object, ... )
## S3 method for class 'systemfit' vcov( object, modified.regMat = FALSE, ... ) ## S3 method for class 'systemfit.equation' vcov( object, ... )
object |
an object of class |
modified.regMat |
logical. If |
... |
other arguments. |
vcov.systemfit
returns the variance covariance matrix
of all estimated coefficients.
Arne Henningsen [email protected]
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## variance covariance matrix of all coefficients vcov( fitols ) ## variance covariance matrix of the coefficients in the first equation vcov( fitols$eq[[1]] ) ## variance covariance matrix of the coefficients in the second equation vcov( fitols$eq[[2]] ) ## estimation with restriction by modifying the regressor matrix modReg <- matrix( 0, 7, 6 ) colnames( modReg ) <- c( "demIntercept", "demPrice", "demIncome", "supIntercept", "supPrice2", "supTrend" ) modReg[ 1, "demIntercept" ] <- 1 modReg[ 2, "demPrice" ] <- 1 modReg[ 3, "demIncome" ] <- 1 modReg[ 4, "supIntercept" ] <- 1 modReg[ 5, "supPrice2" ] <- 1 modReg[ 6, "supPrice2" ] <- 1 modReg[ 7, "supTrend" ] <- 1 fitsur <- systemfit( system, "SUR", data = Kmenta, restrict.regMat = modReg ) vcov( fitsur, modified.regMat = TRUE ) vcov( fitsur )
data( "Kmenta" ) eqDemand <- consump ~ price + income eqSupply <- consump ~ price + farmPrice + trend system <- list( demand = eqDemand, supply = eqSupply ) ## perform OLS on each of the equations in the system fitols <- systemfit( system, data = Kmenta ) ## variance covariance matrix of all coefficients vcov( fitols ) ## variance covariance matrix of the coefficients in the first equation vcov( fitols$eq[[1]] ) ## variance covariance matrix of the coefficients in the second equation vcov( fitols$eq[[2]] ) ## estimation with restriction by modifying the regressor matrix modReg <- matrix( 0, 7, 6 ) colnames( modReg ) <- c( "demIntercept", "demPrice", "demIncome", "supIntercept", "supPrice2", "supTrend" ) modReg[ 1, "demIntercept" ] <- 1 modReg[ 2, "demPrice" ] <- 1 modReg[ 3, "demIncome" ] <- 1 modReg[ 4, "supIntercept" ] <- 1 modReg[ 5, "supPrice2" ] <- 1 modReg[ 6, "supPrice2" ] <- 1 modReg[ 7, "supTrend" ] <- 1 fitsur <- systemfit( system, "SUR", data = Kmenta, restrict.regMat = modReg ) vcov( fitsur, modified.regMat = TRUE ) vcov( fitsur )