📄 movingband2d.c
字号:
for (i=1 ; i<MB->StartIndexTr ; i++) if (MB->StartNumTr < Geo_GetGeoElement(i)->Num) MB->StartNumTr = Geo_GetGeoElement(i)->Num ; (MB->StartNumTr)++; Msg(DEBUG2, "StartNumTr %d StartIndexTr %d\n",MB->StartNumTr, MB->StartIndexTr); GetDP_End ;}int Different_Sense_MB2D(int nth1, int nth2, int ntr1, int ntr2, int closed1, int closed2, double x1[], double y1[], double x2[], double y2[]){ int i,itry2,itry4; double xm,ym, dist1, mindist2,dist2; int imindist, Different; GetDP_Begin("Different_Sense_MB2D"); xm = (x1[0]+x1[1])/2.; ym = (y1[0]+y1[1])/2.; imindist = 0; mindist2 = SQU(xm-x2[0]) + SQU(ym-y2[0]); for (i = 1 ; i < nth2 ; i++ ) if ((dist2 = SQU(xm-x2[i]) + SQU(ym-y2[i])) < mindist2) { imindist = i; mindist2 = dist2; } if (closed2) itry2 = (imindist+1) % (nth2-1); else itry2 = MIN(imindist+1,nth2); if (closed2) itry4 = (imindist-1+nth2-1) % (nth2-1); else itry4 = MAX(imindist-1,0); dist1 = SQU(x1[2]-x2[itry2]) + SQU(y1[2]-y2[itry2]); dist2 = SQU(x1[2]-x2[itry4]) + SQU(y1[2]-y2[itry4]); if (dist1 < dist2) Different = 0; else Different = 1; GetDP_Return (Different) ;} void Mesh_MB2D(int nth1, int nth2, int ntr1, int ntr2, int closed1, int closed2, double x1[], double y1[], double x2[], double y2[], double * area_moving_band, int b1_p1[], int b1_p2[], int b1_p3[], int b2_p1[], int b2_p2[], int b2_p3[]){ int i, itry1,itry2,itry3,itry4, idum,n1,n2; double xm,ym, dist1, mindist2,dist2, area_tr1,area_tr2; int imindist, d2; int Delauny_1234_MB(double, double, double, double, double, double, double, double, double *, double * ); GetDP_Begin("Mesh_MB2D"); xm = (x1[0]+x1[1])/2.; ym = (y1[0]+y1[1])/2.; imindist = 0; mindist2 = SQU(xm-x2[0]) + SQU(ym-y2[0]); for (i = 1 ; i < nth2 ; i++ ) if ((dist2 = SQU(xm-x2[i]) + SQU(ym-y2[i])) < mindist2) { imindist = i; mindist2 = dist2; } if (closed2) itry2 = (imindist+1) % (nth2-1); else itry2 = MIN(imindist+1,nth2); if (closed2) itry4 = (imindist-1+nth2-1) % (nth2-1); else itry4 = MAX(imindist-1,0); dist1 = SQU(x1[2]-x2[itry2]) + SQU(y1[2]-y2[itry2]); dist2 = SQU(x1[2]-x2[itry4]) + SQU(y1[2]-y2[itry4]); if (dist1 < dist2) d2 = 1; else d2 = -1; printf("+++++++++++++++++++++++++++++++++++++++++++++++++ %d \n",d2); /* b1_t2[0] = imindist; printf("imindist = %d\n",imindist); printf("x =%f y= %f\n", x2[imindist],y2[imindist]); */ *area_moving_band = fabs( (x2[imindist]-x1[0])*(y1[1]-y1[0])-(x1[1]-x1[0])*(y2[imindist]-y1[0]) )/2.; itry1 = 1; itry3 = 2 ; itry2 = imindist ; if (closed2) itry4 = (imindist + d2) % (nth2-1); else itry4 = imindist + d2; n1 = 0; n2 = 0; b1_p1[n1] = 0; b1_p2[n1] = 1; b1_p3[n1] = itry2; n1++; /* for (i = 0 ; i < nth1 + nth2 - 3 ; i++ ){ */ for (i = 1 ; i < ntr1 + ntr2 ; i++ ){ /* printf("i %d ,itry1 %d ,itry2 %d ,itry3 %d ,itry4 %d\n", i,itry1,itry2,itry3,itry4); scanf("%d",&idum); */ if ( (Delauny_1234_MB (x1[itry1], y1[itry1], x2[itry2], y2[itry2], x1[itry3], y1[itry3], x2[itry4], y2[itry4], &area_tr1, &area_tr2) == 1) && itry1 < nth1 && itry1 ){ if(itry1==0){printf("hallo %d\n",i); scanf("%d",&idum);} b1_p1[n1] = itry1; b1_p2[n1] = itry3; b1_p3[n1] = itry2; itry1++; itry3++; if (closed1) {itry1 = itry1 % (nth1-1); itry3 = itry3 % (nth1-1) ;} *area_moving_band += area_tr1; n1++; } else{ b2_p1[n2] = itry2; b2_p2[n2] = itry4; b2_p3[n2] = itry1; itry2+=d2; itry4+=d2; if (closed2) { itry2 = (nth2-1+itry2) % (nth2-1); itry4 = (nth2-1+itry4) % (nth2-1) ; } *area_moving_band += area_tr2; n2++; } } if(n1 != ntr1 || n2 != ntr2){ /* if(n1 != nth1-1 || n2 != nth2-1){ */ Msg(GERROR, "Meshing of 2D moving band failed!!! (%d != %d || %d != %d)", n1, ntr1, n2, ntr2); } GetDP_End ;} void Mesh_MovingBand2D (struct Group * Group_P) { struct MovingBand2D * MB ; struct Geo_Element Geo_Element ; struct GeoData * GeoData ; int i, *n ; int * NumNodes1, * NumNodes2; int *b1_p1, *b1_p2, *b1_p3, *b2_p1, *b2_p2, *b2_p3; int NbrGeo, index; GetDP_Begin("Mesh_MovingBand2D"); MB = Group_P->MovingBand2D ; if (!MB->ExtendedList1) Init_MovingBand2D(Group_P) ; NumNodes1 = MB->NumNodes1; NumNodes2 = MB->NumNodes2; b1_p1 = MB->b1_p1; b1_p2 = MB->b1_p2; b1_p3 = MB->b1_p3; b2_p1 = MB->b2_p1; b2_p2 = MB->b2_p2; b2_p3 = MB->b2_p3; Geo_GetNodesCoordinates (MB->NbrNodes1, NumNodes1, MB->x1, MB->y1, MB->z1) ; Geo_GetNodesCoordinates (MB->NbrNodes2, NumNodes2, MB->x2, MB->y2, MB->z2) ; Mesh_MB2D(MB->NbrNodes1, MB->NbrNodes2, MB->ntr1, MB->ntr2, MB->Closed1, MB->Closed2, MB->x1, MB->y1, MB->x2, MB->y2, &MB->Area, b1_p1, b1_p2, b1_p3, b2_p1, b2_p2, b2_p3); GeoData = Current.GeoData ; Geo_Element.NbrEdges = Geo_Element.NbrFacets = 0 ; Geo_Element.NumEdges = Geo_Element.NumFacets = NULL ; Geo_Element.Region = MB->PhysNum ; Geo_Element.NbrNodes = 3 ; Geo_Element.Type = TRIANGLE ; NbrGeo = Geo_GetNbrGeoElements(); for (i = 0 ; i < MB->ntr1 ; i++){ if ((index = MB->StartIndexTr+i) < NbrGeo) { n = (int *)(((struct Geo_Element *)List_Pointer(GeoData->Elements, index))->NumNodes) ; n[0] = NumNodes1[b1_p1[i]] ; n[1] = NumNodes1[b1_p2[i]] ; n[2] = NumNodes2[b1_p3[i]] ; } else { Geo_Element.Num = MB->StartNumTr + i ; Geo_Element.NumNodes = n = (int *)Malloc(3 * sizeof(int)) ; n[0] = NumNodes1[b1_p1[i]] ; n[1] = NumNodes1[b1_p2[i]] ; n[2] = NumNodes2[b1_p3[i]] ; List_Put(GeoData->Elements, index, &Geo_Element) ; } /* printf("Tr1 %d : %d %d %d \n",MB->StartNumTr+i, n[0], n[1], n[2]);*/ } for (i = 0 ; i < MB->ntr2 ; i++){ Geo_Element.Num = MB->StartNumTr + MB->ntr1 +i ; if ((index = MB->StartIndexTr+MB->ntr1+i) < NbrGeo) { n = (int *)(((struct Geo_Element *)List_Pointer(GeoData->Elements, index))->NumNodes) ; n[0] = NumNodes2[b2_p1[i]] ; n[1] = NumNodes2[b2_p2[i]] ; n[2] = NumNodes1[b2_p3[i]] ; } else { Geo_Element.Num = MB->StartNumTr + MB->ntr1 + i ; Geo_Element.NumNodes = n = (int *)Malloc(3 * sizeof(int)) ; n[0] = NumNodes2[b2_p1[i]] ; n[1] = NumNodes2[b2_p2[i]] ; n[2] = NumNodes1[b2_p3[i]] ; List_Put(GeoData->Elements, index, &Geo_Element) ; } /* printf("Tr2 %d : %d %d %d \n",MB->StartNumTr+MB->ntr1+i, n[0], n[1], n[2]); */ } Msg(DEBUG2, "Moving band meshed (area = %e)\n", MB->Area); GetDP_End ;}int Delauny_1234_MB (double x1, double y1, double x2, double y2, double x3, double y3, double x4, double y4, double * area1, double * area2) { double Det1, Det2, t1, t2; Det1 = (x3-x1)*(y2-y1)-(x2-x1)*(y3-y1); Det2 = (x4-x1)*(y2-y1)-(x2-x1)*(y4-y1); if( !Det1 || !Det2 ) { Msg(GERROR, "colinear points in Delauny_1234 !!!!" " x1 %e y1 %e x2 %e y2 %e x3 %e y3 %e x4 %e y4 %e", x1, y1, x2, y2, x3, y3, x4, y4); } t1 = ( (x3-x1)*(x3-x2)+(y3-y1)*(y3-y2) ) / Det1 ; t2 = ( (x4-x1)*(x4-x2)+(y4-y1)*(y4-y2) ) / Det2 ; if ( fabs(t1) < fabs(t2) ){ *area1 = fabs(Det1)/2.; return (1); } else{ *area2 = fabs(Det2)/2.; return (2); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -