37 #include "MaxTemplate.hpp"
38 #include "QualityMetric.hpp"
39 #include "PatchData.hpp"
66 int num_elements=patch.num_elements();
67 MsqMeshEntity* elems=patch.get_element_array(err);
MSQ_ERRZERO(err);
69 for (index=0; index<num_elements; index++){
72 obj_bool = currentQM->evaluate_element(patch, &elems[index],
88 int num_vertices=patch.num_vertices();
89 MsqVertex* vertices=patch.get_vertex_array(err);
MSQ_ERRZERO(err);
91 for (index=0; index<num_vertices;index++){
94 obj_bool=currentQM->evaluate_vertex(patch, &vertices[index],
107 MSQ_SETERR(err)(
"Make sure MetricType is initialised in concrete "
121 MSQ_SETERR(err)(
"The MaxTemplate is not sufficient for methods requiring\n"
122 " gradient information. If you neeed to try this anyway, \n"
123 " set the gradient type to numerical.\n",
void set_gradient_type(GRADIENT_TYPE grad)
Set gradType to either NUMERICAL_GRADIENT or ANALYTICAL_GRADIENT.
#define MSQ_ERRZERO(err)
Return zero/NULL on error.
void set_quality_metric(QualityMetric *qm)
Set the value of qMetric.
virtual bool compute_analytical_gradient(PatchData &patch, Vector3D *const &grad, double &OF_val, MsqError &err, size_t array_size)
virtual bool concrete_evaluate(PatchData &patch, double &fval, MsqError &err)
every differentiable function should have an analytical gradient implemented.
QualityMetric * get_quality_metric()
NVec< 3, double > Vector3D
#define MSQ_CHKERR(err)
Mesquite's Error Checking macro.
#define MSQ_SETERR(err)
Macro to set error - use err.clear() to clear.
void set_negate_flag(int neg)
Set the value of ObjectiveFunction's negateFlag. Unless composite, concrete ObjectiveFunctions should...
object is in an invalid state
MaxTemplate(QualityMetric *)