6 #include "../../shared/shared.h"
65 _error_(
"First indice provided is not supported yet (user provided " << index1 <<
")");
77 _error_(
"Second indice provided is not supported yet (user provided " << index2 <<
" )");
82 coords1[i]=0.5*(a1+a2) + 0.5*seg_coords[i]*(a2-a1);
83 coords2[i]=0.5*(b1+b2) + 0.5*seg_coords[i]*(b2-b1);
84 coords3[i]=0.5*(c1+c2) + 0.5*seg_coords[i]*(c2-c1);
95 xDelete<double>(seg_coords);
96 xDelete<double>(seg_weights);
117 coords1[i]=0.5*(area_coordinates[0][0]+area_coordinates[1][0]) + 0.5*seg_coords[i]*(area_coordinates[1][0]-area_coordinates[0][0]);
118 coords2[i]=0.5*(area_coordinates[0][1]+area_coordinates[1][1]) + 0.5*seg_coords[i]*(area_coordinates[1][1]-area_coordinates[0][1]);
119 coords3[i]=0.5*(area_coordinates[0][2]+area_coordinates[1][2]) + 0.5*seg_coords[i]*(area_coordinates[1][2]-area_coordinates[0][2]);
130 xDelete<IssmPDouble>(seg_coords);
131 xDelete<IssmPDouble>(seg_weights);
159 xy_list[0][0]=0; xy_list[0][1]=0;
160 xy_list[1][0]=r1; xy_list[1][1]=0;
161 xy_list[2][0]=0; xy_list[2][1]=r2;
164 x = this->
coords1[ig]*xy_list[0][0] + this->
coords2[ig]*xy_list[1][0] + this->
coords3[ig]*xy_list[2][0];
165 y = this->
coords1[ig]*xy_list[0][1] + this->
coords2[ig]*xy_list[1][1] + this->
coords3[ig]*xy_list[2][1];
184 _error_(
"index "<<index<<
" not supported yet");
196 xy_list[0][0]=r1; xy_list[0][1]=0;
197 xy_list[1][0]=0; xy_list[1][1]=1.;
198 xy_list[2][0]=0; xy_list[2][1]=r2;
202 x = gauss1->
coords1[ig]*xy_list[0][0] + gauss1->
coords2[ig]*xy_list[1][0] + gauss1->
coords3[ig]*xy_list[2][0];
203 y = gauss1->
coords1[ig]*xy_list[0][1] + gauss1->
coords2[ig]*xy_list[1][1] + gauss1->
coords3[ig]*xy_list[2][1];
222 _error_(
"index "<<index<<
" not supported yet");
227 xy_list[0][0]=r1; xy_list[0][1]=0;
228 xy_list[1][0]=1.; xy_list[1][1]=0;
229 xy_list[2][0]=0; xy_list[2][1]=1.;
233 x = gauss2->
coords1[ig]*xy_list[0][0] + gauss2->
coords2[ig]*xy_list[1][0] + gauss2->
coords3[ig]*xy_list[2][0];
234 y = gauss2->
coords1[ig]*xy_list[0][1] + gauss2->
coords2[ig]*xy_list[1][1] + gauss2->
coords3[ig]*xy_list[2][1];
253 _error_(
"index "<<index<<
" not supported yet");
313 gauss1=
new GaussTria(index,r1,r2,1,order);
314 gauss2=
new GaussTria(index,r1,r2,0,order);
429 index3=index1; index1=index2; index2=index3;
433 if (index1==0 && index2==1){
438 else if (index1==0 && index2==2){
443 else if (index1==1 && index2==2){
449 _error_(
"The 2 indices provided are not supported yet (user provided " << index1 <<
" and " << index2 <<
")");
462 x1=*(xyz_list+3*0+0); y1=*(xyz_list+3*0+1);
463 x2=*(xyz_list+3*1+0); y2=*(xyz_list+3*1+1);
464 x3=*(xyz_list+3*2+0); y3=*(xyz_list+3*2+1);
466 area=(x2*y3 - y2*x3 + x1*y2 - y1*x2 + x3*y1 - y3*x1)/2;
469 coord1=((x-x3)*(y2-y3)-(x2-x3)*(y-y3))/area;
472 coord2=((x1-x3)*(y-y3)-(x-x3)*(y1-y3))/area;
498 switch(finiteelement){
502 default:
_error_(
"node index should be 0");
510 default:
_error_(
"node index should be in [0 2]");
519 default:
_error_(
"node index should be in [0 3]");
530 default:
_error_(
"node index should be in [0 5]");
542 default:
_error_(
"node index should be in [0 6]");
560 default:
_error_(
"vertex index should be in [0 2]");