/** * @file init.c * @brief Register native routines and initialize * cholmod_common struct used in mixed effect models * @author Wayne Zhang */ #include "common.h" #include "cpglmm.h" #include "bcplm.h" #include "mh.h" #include /** utitlity macro in registering native routines */ #define CALLDEF(name, n) {#name, (DL_FUNC) &name, n} /** function that registers native routines */ static R_CallMethodDef CallEntries[] = { CALLDEF(cpglmm_optimize, 1), CALLDEF(cpglmm_update_mu, 1), CALLDEF(cpglmm_update_u, 1), CALLDEF(cpglmm_update_L, 1), CALLDEF(cpglmm_update_dev, 2), CALLDEF(cpglmm_setPars, 2), CALLDEF(bcplm_mcmc, 1), CALLDEF(bcplm_update_mu, 1), CALLDEF(bcplm_post_p, 2), CALLDEF(bcplm_post_phi, 2), CALLDEF(bcplm_post_betak, 2), CALLDEF(bcplm_post_uk, 2), CALLDEF(bcplm_metrop_rw, 7), CALLDEF(mer_ST_initialize, 3), CALLDEF(mer_create_L, 1), CALLDEF(mer_postVar, 2), CALLDEF(mer_update_projection, 1), CALLDEF(cpglmm_ghq, 1), CALLDEF(cpglmm_update_RX, 1), CALLDEF(cpglmm_update_ranef, 1), CALLDEF(cpglmm_ST_chol, 1), CALLDEF(cpglmm_ST_getPars, 1), {NULL, NULL, 0} }; /** cholmod_common struct local to the cplm package */ cholmod_common c; /** This is the CHOLMOD error handler from lme4*/ void attribute_hidden cplm_R_cholmod_error(int status, const char *file, int line, const char *message) { if(status < 0) { #ifdef Failure_in_matching_Matrix /* This fails unexpectedly with * function 'cholmod_l_defaults' not provided by package 'Matrix' * from ../tests/lmer-1.R 's (l.68) lmer(y ~ habitat + (1|habitat*lagoon) */ M_cholmod_defaults(&c);/* <--- restore defaults, * as we will not be able to .. */ c.final_ll = 1; /* LL' form of simplicial factorization */ #endif error(_("Cholmod error '%s' at file:%s, line %d"), message, file, line); } else warning("Cholmod warning '%s' at file:%s, line %d", message, file, line); } /** Initializer for cplm, called upon loading the package. * * Initialize CHOLMOD and require the LL' form of the factorization. * Install the symbols to be used by functions in the package. */ #ifdef HAVE_VISIBILITY_ATTRIBUTE __attribute__ ((visibility ("default"))) #endif void R_init_cplm(DllInfo *dll) { R_registerRoutines(dll, NULL, CallEntries, NULL, NULL); R_useDynamicSymbols(dll, FALSE); M_R_cholmod_start(&c); c.final_ll = 1; /* LL' form of simplicial factorization */ /* need own error handler, that resets final_ll (after *_defaults()) : */ c.error_handler = cplm_R_cholmod_error; } /** Finalizer for cplm called upon unloading the package. * */ void R_unload_cplm(DllInfo *dll){ M_cholmod_finish(&c); }