#include <ListofIntersectionTriangles.h>
|
| ListofIntersectionTriangles (int n=256, int m=16) |
|
| ~ListofIntersectionTriangles () |
|
IntersectionTriangles & | operator[] (int i) |
|
| operator int & () |
|
void | Init () |
|
int | NewItem (Triangle *tt, double d0, double d1, double d2) |
|
int | NewItem (R2, const Metric &) |
|
void | SplitEdge (Mesh &, const R2 &, const R2 &, int nbegin=0) |
|
double | Length () |
|
long | NewPoints (BamgVertex *, long &nbv, long maxnbv) |
|
void | ReShape () |
|
◆ ListofIntersectionTriangles()
bamg::ListofIntersectionTriangles::ListofIntersectionTriangles |
( |
int |
n = 256 , |
|
|
int |
m = 16 |
|
) |
| |
◆ ~ListofIntersectionTriangles()
bamg::ListofIntersectionTriangles::~ListofIntersectionTriangles |
( |
| ) |
|
◆ operator[]()
◆ operator int &()
bamg::ListofIntersectionTriangles::operator int & |
( |
| ) |
|
|
inline |
◆ Init()
void bamg::ListofIntersectionTriangles::Init |
( |
void |
| ) |
|
◆ NewItem() [1/2]
int bamg::ListofIntersectionTriangles::NewItem |
( |
Triangle * |
tt, |
|
|
double |
d0, |
|
|
double |
d1, |
|
|
double |
d2 |
|
) |
| |
Definition at line 77 of file ListofIntersectionTriangles.cpp.
82 if ( d0) x = (*tt)[0].r * d0;
83 if ( d1) x = x + (*tt)[1].r * d1;
84 if ( d2) x = x + (*tt)[2].r * d2;
95 if ((v=(*tt)(0))) m0 = v->m;
96 if ((v=(*tt)(1))) m1 = v->m;
97 if ((v=(*tt)(2))) m2 = v->m;
◆ NewItem() [2/2]
int bamg::ListofIntersectionTriangles::NewItem |
( |
R2 |
A, |
|
|
const Metric & |
mm |
|
) |
| |
◆ SplitEdge()
void bamg::ListofIntersectionTriangles::SplitEdge |
( |
Mesh & |
Bh, |
|
|
const R2 & |
A, |
|
|
const R2 & |
B, |
|
|
int |
nbegin = 0 |
|
) |
| |
Definition at line 190 of file ListofIntersectionTriangles.cpp.
193 Triangle *tbegin, *t;
195 long long deta[3], deti,detj;
202 I2 a = Bh.R2ToI2(A) ,b= Bh.R2ToI2(B);
213 t=tbegin = Bh.TriangleFindFromCoord(a,deta);
215 ilast=
NewItem(t,
double(deta[0])/t->det,
double(deta[1])/t->det,
double(deta[2])/t->det);
223 BamgVertex & v0 = *edge.EdgeVertex(0), & v1 = *edge.EdgeVertex(1);
224 NewItem(A,Metric(ba,v0,bb,v1));
227 if (
det(v0.i,v1.i,b)>=0) {
229 BamgVertex & v0 = *edge.EdgeVertex(0), & v1 = *edge.EdgeVertex(1);
230 NewItem(A,Metric(ba,v0,bb,v1));
237 k=(*t)(0) ? (( (*t)(1) ? ( (*t)(2) ? -1 : 2) : 1 )) : 0;
252 AdjacentTriangle tadj =t->Adj(ocut);
258 BamgVertex & v0 = *edge.EdgeVertex(0), & v1 = *edge.EdgeVertex(1);
259 NewItem(A,Metric(ba,v0,bb,v1));
268 if (
det(vi,vj,b)>=0) {
272 NewItem(B,Metric(ba,*edge.EdgeVertex(0),bb,*edge.EdgeVertex(1)));
280 double dij = detj-deti;
281 if (i+j+k != 0 + 1 +2){
287 ilast=
NewItem(t,ba[0],ba[1],ba[2]); }
342 if (dt[0]) ocut=0,k++;
343 if (dt[1]) ocut=1,k++;
344 if (dt[2]) ocut=2,k++;
358 long long detbij =
bamg::det((*t)[i],(*t)[j],b);
365 NewItem(t,dt[0]/dd,dt[1]/dd,dt[2]/dd);
370 double dij = detj-deti;
374 ilast=
NewItem(t, ba[0],ba[1],ba[2]);
376 AdjacentTriangle ta =t->Adj(ocut);
382 NewItem(B,Metric(ba,*edge.EdgeVertex(0),bb,*edge.EdgeVertex(1)));
◆ Length()
double bamg::ListofIntersectionTriangles::Length |
( |
| ) |
|
◆ NewPoints()
long bamg::ListofIntersectionTriangles::NewPoints |
( |
BamgVertex * |
vertices, |
|
|
long & |
nbv, |
|
|
long |
maxnbv |
|
) |
| |
Definition at line 119 of file ListofIntersectionTriangles.cpp.
126 const long nbvold=nbv;
131 int nbi=
Max(2,(
int) (s+0.5));
136 SegInterpolation* SegI=NULL;
139 for (
int k=1;k<nbi;k++){
159 C = SegI ? SegI->F(si): x * cx + y *cy;
170 else return nbv-nbvold;
◆ ReShape()
void bamg::ListofIntersectionTriangles::ReShape |
( |
| ) |
|
◆ MaxSize
int bamg::ListofIntersectionTriangles::MaxSize |
◆ Size
int bamg::ListofIntersectionTriangles::Size |
◆ len
double bamg::ListofIntersectionTriangles::len |
◆ state
int bamg::ListofIntersectionTriangles::state |
◆ lIntTria
◆ NbSeg
int bamg::ListofIntersectionTriangles::NbSeg |
◆ MaxNbSeg
int bamg::ListofIntersectionTriangles::MaxNbSeg |
◆ lSegsI
The documentation for this class was generated from the following files: