⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 splitmesh3.cpp

📁 FreeFem++可以生成高质量的有限元网格。可以用于流体力学
💻 CPP
字号:
// $Id: splitmesh3.cpp,v 1.2 2008/04/29 20:01:24 hecht Exp $#include  <iostream>#include  <cfloat>using namespace std;#include "error.hpp"#include "AFunction.hpp"using namespace std;  #include "rgraph.hpp"#include "RNM.hpp"#include <fem.hpp>#include <cmath>  using namespace  Fem2D;Mesh * SplitMesh3(Fem2D::Mesh * const & pTh){  assert(pTh);  const Mesh & Th(*pTh);  // le maillage d'origne a decoupe  using  Fem2D::Triangle;  using  Fem2D::Vertex;  using  Fem2D::R2;  using  Fem2D::BoundaryEdge;  using  Fem2D::Mesh; // using  Fem2D::R;  int nbv=Th.nv; // nombre de sommet   int nbt=Th.nt; // nombre de triangles  int neb=Th.neb; // nombre d'aretes fontiere  // allocation des nouveaux items du maillage    Vertex * v= new Vertex[nbv+nbt];  Triangle *t= new Triangle[nbt*3];  BoundaryEdge *b= new BoundaryEdge[neb];  // generation des nouveaus sommets   Vertex *vv=v;  // copie des anciens sommets (remarque il n'y a pas operateur de copy des sommets)  for (int i=0;i<nbv;i++)   {     Vertex & V=Th(i);     vv->x=V.x;     vv->y=V.y;     vv->lab = V.lab;     vv++;         }  // generation des points barycentre de trianngles   for (int k=0;k<nbt;k++)    {      Triangle & K=Th[k];      R2 G= ( (R2) K[0] + K[1] + K[2] )  / 3.;      vv->x=G.x;      vv->y=G.y;      vv->lab = 0;      vv++;    }     //  generation des triangles   Triangle *tt= t;   int nberr=0;     for (int i=0;i<nbt;i++)    {      int i0=Th(i,0), i1=Th(i,1),i2=Th(i,2);      int ii = nbv + i; // numero du       // les 3 triangles par triangles origines       (*tt++).set(v,ii,i1,i2,Th[i].lab);      (*tt++).set(v,i0,ii,i2,Th[i].lab);      (*tt++).set(v,i0,i1,ii,Th[i].lab);    }    // les arete frontieres qui n'ont pas change  BoundaryEdge * bb=b;  for (int i=0;i<neb;i++)    {              int i1=Th(Th.bedges[i][0]);      int i2=Th(Th.bedges[i][1]);      int lab=Th.bedges[i].lab;           *bb++ = BoundaryEdge(v,i1,i2,lab);       }  //  generation de la class Mesh a partir des 3 tableaux : v,t,b  {    Mesh * m = new Mesh(nbv+nbt,nbt*3,neb,v,t,b);    R2 Pn,Px;    m->BoundingBox(Pn,Px);    m->quadtree=new Fem2D::FQuadTree(m,Pn,Px,m->nv);    m->decrement();    return m;  }}//  truc pour que la fonction // Init::Init() soit appele a moment du chargement dynamique// du fichier //  class Init { public:  Init();};static Init init;  //  une variable globale qui serat construite  au chargement dynamique Init::Init(){  // le constructeur qui ajoute la fonction "splitmesh3"  a freefem++   if (verbosity)    cout << " lood: Split3  " << endl;  Global.Add("splitmesh3","(",new OneOperator1_<Mesh *,Mesh *>(SplitMesh3));  // utilisation   // mesh Th,Th3;  //  ... construction du maillage Th ici   //   Th3=splitmesh3(Th);  /*  example complet : splitmesh3.edp      load "splitmesh3"      mesh Th=square(5,5);      mesh Th3=splitmesh3(Th);      plot(Th3,wait=1);  */}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -