2014-02-27 03:45:46 +00:00
|
|
|
# Objective function for the GMM method
|
|
|
|
#
|
|
|
|
# Author: Francois Pelletier
|
|
|
|
#
|
|
|
|
# LGPL-3.0
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
#' Objective function for the GMM method
|
2014-02-28 04:05:30 +00:00
|
|
|
#' @param param Vector of parameters to optimize
|
2014-02-27 03:45:46 +00:00
|
|
|
#' @param conditions.vector Vector of moment conditions
|
|
|
|
#' @param ... Parameters of the vector of moment conditions
|
|
|
|
#' @param W Weighting matrix
|
2014-02-28 04:05:30 +00:00
|
|
|
#' @param R Linear constraint matrix of coefficients
|
|
|
|
#' @param r Linear constraint constants
|
2014-02-27 03:45:46 +00:00
|
|
|
#' @return A scalar value
|
|
|
|
#'
|
|
|
|
#' @author François Pelletier
|
2014-02-28 04:05:30 +00:00
|
|
|
objective.GMM <- function(param.lagrangian,conditions.vector,num.param,...,
|
|
|
|
W=diag(length(conditions.vector)),R=0,r=0)
|
2014-02-27 03:45:46 +00:00
|
|
|
{
|
2014-02-28 04:05:30 +00:00
|
|
|
param <- param.lagrangian[1:num.param]
|
|
|
|
lagrangian <- param.lagrangian[num.param+1:length(param.lagrangian)]
|
|
|
|
colMeans(conditions.vector(param,...)) %*% ginv(W) %*% colMeans(conditions.vector(param,...))+ abs(t(R %*% param - r) %*% lagrangian)
|
2014-02-27 03:45:46 +00:00
|
|
|
}
|