#include <BamgVertex.h>
|
| operator I2 () const |
|
| operator const R2 & () const |
|
| operator Metric () const |
|
double | operator() (R2 x) const |
|
| BamgVertex () |
|
double | Smoothing (Mesh &, Mesh &, Triangle *&, double=1) |
|
void | MetricFromHessian (const double Hxx, const double Hyx, const double Hyy, const double smin, const double smax, const double s, const double err, BamgOpts *bamgopts) |
|
void | Echo () |
|
int | GetReferenceNumber () const |
|
I2 | GetIntegerCoordinates () const |
|
long | Optim (int=1, int=0) |
|
void | Set (const BamgVertex &rec, const Mesh &, Mesh &) |
|
Definition at line 15 of file BamgVertex.h.
◆ BamgVertex()
bamg::BamgVertex::BamgVertex |
( |
| ) |
|
◆ operator I2()
bamg::BamgVertex::operator I2 |
( |
| ) |
const |
|
inline |
◆ operator const R2 &()
bamg::BamgVertex::operator const R2 & |
( |
| ) |
const |
|
inline |
◆ operator Metric()
bamg::BamgVertex::operator Metric |
( |
| ) |
const |
|
inline |
◆ operator()()
double bamg::BamgVertex::operator() |
( |
R2 |
x | ) |
const |
|
inline |
◆ Smoothing()
double bamg::BamgVertex::Smoothing |
( |
Mesh & |
Th, |
|
|
Mesh & |
BTh, |
|
|
Triangle *& |
tstart, |
|
|
double |
omega = 1 |
|
) |
| |
Definition at line 124 of file BamgVertex.cpp.
130 Triangle* tbegin=
t , *tria =
t , *ttc;
133 R2 P(s->r),PNew(0,0);
137 if (!tria->Hidden(j)){
142 PNew += Q+QP/
Max(lQP,1e-20);
145 ttc = tria->TriangleAdj(j);
146 jc =
NextEdge[tria->NuEdgeTriangleAdj(j)];
150 _error_(
"k>=2000 (Maximum number of iterations reached)");
152 }
while ( tbegin != tria);
154 PNew = PNew/(double)kk;
155 R2 Xmove((PNew-P)*omega);
160 I2 IBTh = BTh.R2ToI2(PNew);
162 tstart=BTh.TriangleFindFromCoord(IBTh,deta,tstart);
168 vP.m= Metric(ba,*edge.EdgeVertex(0),bb,*edge.EdgeVertex(1));
172 double s = deta[0]+deta[1]+deta[2];
176 vP.m = Metric(aa,(*tstart)[0],(*tstart)[1],(*tstart)[2]);
182 vP.i = Th.R2ToI2(PNew);
193 double detold = tria->det;
194 tria->det =
bamg::det( (*tria)[0],(*tria)[1] ,(*tria)[2]);
196 if (tria->det<0) ok =1;
197 else if ( (
double)tria->det < detold/2 ) ok=1;
199 tria->SetUnMarkUnSwap(0);
200 tria->SetUnMarkUnSwap(1);
201 tria->SetUnMarkUnSwap(2);
202 ttc = tria->TriangleAdj(j);
203 jc =
NextEdge[tria->NuEdgeTriangleAdj(j)];
209 }
while ( tbegin != tria);
211 if (ok && loop) vP=vPsave;
◆ MetricFromHessian()
void bamg::BamgVertex::MetricFromHessian |
( |
const double |
Hxx, |
|
|
const double |
Hyx, |
|
|
const double |
Hyy, |
|
|
const double |
smin, |
|
|
const double |
smax, |
|
|
const double |
s, |
|
|
const double |
err, |
|
|
BamgOpts * |
bamgopts |
|
) |
| |
Definition at line 34 of file BamgVertex.cpp.
38 double power=(bamgopts->
power);
39 double anisomax=(bamgopts->
anisomax);
40 double CutOff=bamgopts->
cutoff;
41 double hmin=(bamgopts->
hmin);
42 double hmax=(bamgopts->
hmax);
43 double coef=bamgopts->
coeff;
58 ci= 2.0/9.0 * 1/(err*coef*coef);
68 else if (Metrictype==1){
69 ci= 2.0/9.0 * 1/(err*coef*coef) * 1/
Max(
Abs(s), CutOff*(
Max(
Abs(smin),
Abs(smax))));
78 else if (Metrictype==2){
79 ci= 2.0/9.0 * 1/(err*coef*coef) * 1/(smax-smin);
82 _error_(
"Metrictype " << Metrictype <<
" not supported yet (use 0,1 or 2(default))");
86 Metric Miv(Hxx*ci,Hyx*ci,Hyy*ci);
95 if(power!=1.0) Vp.pow(power);
102 Vp.BoundAniso2(1/(anisomax*anisomax));
◆ Echo()
void bamg::BamgVertex::Echo |
( |
void |
| ) |
|
Definition at line 18 of file BamgVertex.cpp.
21 _printf_(
" integer coordinates i.x: " <<
i.
x <<
", i.y: " <<
i.
y <<
"\n");
22 _printf_(
" Euclidean coordinates r.x: " <<
r.
x <<
", r.y: " <<
r.
y <<
"\n");
◆ GetReferenceNumber()
int bamg::BamgVertex::GetReferenceNumber |
( |
| ) |
const |
◆ GetIntegerCoordinates()
I2 bamg::BamgVertex::GetIntegerCoordinates |
( |
| ) |
const |
|
inline |
◆ Optim()
long bamg::BamgVertex::Optim |
( |
int |
i = 1 , |
|
|
int |
koption = 0 |
|
) |
| |
◆ Set()
◆ ReferenceNumber
long bamg::BamgVertex::ReferenceNumber |
◆ PreviousNumber
long bamg::BamgVertex::PreviousNumber |
◆ IndexInTriangle
short bamg::BamgVertex::IndexInTriangle |
◆ color
long bamg::BamgVertex::color |
◆ MeshVertexHook
◆ GeomEdgeHook
◆ BackgroundVertexHook
BamgVertex* bamg::BamgVertex::BackgroundVertexHook |
◆ BackgroundEdgeHook
◆ @1
The documentation for this class was generated from the following files: