Model fit¶
Rather than fitting a model
\[\min_z l(A z + b) + r(z),\]
via a specific choice of a loss function, \(l\), and regularization function, \(r\), such as for a support vector machine or logistic regression, the following routines accept function wrappers for the proximal maps said functions and execute an Alternating Direction Method of Multipliers.
Note
While sometimes functional, this implementation is still very much a work-in-progress.
C++ API¶
-
Int
ModelFit
(std::function<void(Matrix<Real>&, Real)> lossProx, std::function<void(Matrix<Real>&, Real)> regProx, const Matrix<Real> &A, const Matrix<Real> &b, Matrix<Real> &w, Real rho, Int maxIter = 1000, bool inv = true, bool progress = true, )¶
-
Int
ModelFit
(std::function<void(DistMatrix<Real>&, Real)> lossProx, std::function<void(DistMatrix<Real>&, Real)> regProx, const ElementalMatrix<Real> &A, const ElementalMatrix<Real> &b, ElementalMatrix<Real> &w, Real rho, Int maxIter = 1000, bool inv = true, bool progress = true, )¶
C API¶
-
ElError
ElModelFit_s
(void (*lossProx)(ElMatrix_s,float), void (*regProx)(ElMatrix_s,float), ElConstMatrix_s A, ElConstMatrix_s b, ElMatrix_s w, float rho, ElInt* numIts)¶
-
ElError
ElModelFit_d
(void (*lossProx)(ElMatrix_d,double), void (*regProx)(ElMatrix_d,double), ElConstMatrix_d A, ElConstMatrix_d b, ElMatrix_d w, double rho, ElInt* numIts)¶