Skip to content
Snippets Groups Projects
Gmsh.tab.cpp 374 KiB
Newer Older
            List_Read((yyvsp[(3) - (6)].l), i, &d);
            Surface *s = FindSurface((int)d);
            if(s){
              s->Method = MESH_TRANSFINITE;
              s->Recombine_Dir = (yyvsp[(5) - (6)].i);
              List_Reset(s->TrsfPoints);
              for(int j = 0; j < k; j++){
                double p;
                List_Read((yyvsp[(4) - (6)].l), j, &p);
                Vertex *v = FindPoint((int)fabs(p));
                if(v)
                  List_Add(s->TrsfPoints, &v);
                else
                  yymsg(0, "Unknown point %d", (int)fabs(p));
              }
            }
            else{
              GFace *gf = GModel::current()->getFaceByTag((int)d);
              if(gf){
                gf->meshAttributes.Method = MESH_TRANSFINITE;
                gf->meshAttributes.transfiniteArrangement = (yyvsp[(5) - (6)].i);
                for(int j = 0; j < k; j++){
                  double p;
                  List_Read((yyvsp[(4) - (6)].l), j, &p);
                  GVertex *gv = GModel::current()->getVertexByTag((int)fabs(p));
                  if(gv)
                    gf->meshAttributes.corners.push_back(gv);
                  else
                    yymsg(0, "Unknown point %d", (int)fabs(p));
                }
              }
              else
                yymsg(0, "Unknown surface %d", (int)d);
            }
          List_Delete((yyvsp[(3) - (6)].l));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        }
      List_Delete((yyvsp[(4) - (6)].l));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3232 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
      yymsg(1, "Elliptic Surface is deprecated: use Transfinite instead (with smoothing)");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      List_Delete((yyvsp[(7) - (8)].l));
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3237 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
      int k = List_Nbr((yyvsp[(4) - (5)].l));
      if(k != 0 && k != 6 && k != 8){
        yymsg(0, "Wrong definition of Transfinite Volume: "
              "%d points instead of 6 or 8", k);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
        if(!(yyvsp[(3) - (5)].l)){
          List_T *tmp = Tree2List(GModel::current()->getGEOInternals()->Volumes);
          if(List_Nbr(tmp)){
            for(int i = 0; i < List_Nbr(tmp); i++){
              Volume *v;
              List_Read(tmp, i, &v);
              v->Method = MESH_TRANSFINITE;
              List_Reset(v->TrsfPoints);
            }
          }
          else{
            for(GModel::riter it = GModel::current()->firstRegion(); 
                it != GModel::current()->lastRegion(); it++){
              (*it)->meshAttributes.Method = MESH_TRANSFINITE;
            }
          }
          List_Delete(tmp);
        }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        else{
          for(int i = 0; i < List_Nbr((yyvsp[(3) - (5)].l)); i++){
            double d;
            List_Read((yyvsp[(3) - (5)].l), i, &d);
            Volume *v = FindVolume((int)d);
            if(v){
              v->Method = MESH_TRANSFINITE;
              List_Reset(v->TrsfPoints);
              for(int i = 0; i < k; i++){
                double p;
                List_Read((yyvsp[(4) - (5)].l), i, &p);
                Vertex *vert = FindPoint((int)fabs(p));
                if(vert)
                  List_Add(v->TrsfPoints, &vert);
                else
                  yymsg(0, "Unknown point %d", (int)fabs(p));
              }
            }
            else{
              GRegion *gr = GModel::current()->getRegionByTag((int)d);
              if(gr){
                gr->meshAttributes.Method = MESH_TRANSFINITE;
                for(int i = 0; i < k; i++){
                  double p;
                  List_Read((yyvsp[(4) - (5)].l), i, &p);
                  GVertex *gv = GModel::current()->getVertexByTag((int)fabs(p));
                  if(gv)
                    gr->meshAttributes.corners.push_back(gv);
                  else
                    yymsg(0, "Unknown point %d", (int)fabs(p));
                }
              }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
              else
                yymsg(0, "Unknown volume %d", (int)d);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
            }
          }
          List_Delete((yyvsp[(3) - (5)].l));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        }
      List_Delete((yyvsp[(4) - (5)].l));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3304 "Gmsh.y"
    {
      if(!(yyvsp[(2) - (3)].l)){
  	  List_T *tmp = Tree2List(GModel::current()->getGEOInternals()->Volumes);
        if(List_Nbr(tmp)){
          for(int i = 0; i < List_Nbr(tmp); i++){
            Volume *v;
            List_Read(tmp, i, &v);
            v->QuadTri = TRANSFINITE_QUADTRI_1;
          }
        }
        else{
          for(GModel::riter it = GModel::current()->firstRegion(); 
              it != GModel::current()->lastRegion(); it++)
            (*it)->meshAttributes.QuadTri = TRANSFINITE_QUADTRI_1;
        }
        List_Delete(tmp);
      }
      else{
        for(int i = 0; i < List_Nbr((yyvsp[(2) - (3)].l)); i++){
          double d;
          List_Read((yyvsp[(2) - (3)].l), i, &d);
          Volume *v = FindVolume((int)d);
          if(v)
            v->QuadTri = TRANSFINITE_QUADTRI_1;
          else{
            GRegion *gr = GModel::current()->getRegionByTag((int)d);
            if(gr)
              gr->meshAttributes.QuadTri = TRANSFINITE_QUADTRI_1;
            else
              yymsg(1, "Unknown region %d", (int)d);
          }
        }
        List_Delete((yyvsp[(2) - (3)].l));
      }
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3340 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
	List_T *tmp = Tree2List(GModel::current()->getGEOInternals()->Surfaces);
        if(List_Nbr(tmp)){
          for(int i = 0; i < List_Nbr(tmp); i++){
            Surface *s;
            List_Read(tmp, i, &s);
            s->Recombine = 1;
            s->RecombineAngle = (yyvsp[(4) - (5)].i);
          }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        else{
          for(GModel::fiter it = GModel::current()->firstFace(); 
              it != GModel::current()->lastFace(); it++){
            (*it)->meshAttributes.recombine = 1;
            (*it)->meshAttributes.recombineAngle = (yyvsp[(4) - (5)].i);
          }
        }
        List_Delete(tmp);
      }
      else{
        for(int i = 0; i < List_Nbr((yyvsp[(3) - (5)].l)); i++){
          double d;
          List_Read((yyvsp[(3) - (5)].l), i, &d);
          Surface *s = FindSurface((int)d);
          if(s){
            s->Recombine = 1;
            s->RecombineAngle = (yyvsp[(4) - (5)].i);
          }
          else{
            GFace *gf = GModel::current()->getFaceByTag((int)d);
            if(gf){
              gf->meshAttributes.recombine = 1;
              gf->meshAttributes.recombineAngle = (yyvsp[(4) - (5)].i);
            }
            else
              yymsg(1, "Unknown surface %d", (int)d);
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3383 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
      for(int i = 0; i < List_Nbr((yyvsp[(3) - (6)].l)); i++){
	double d;
	List_Read((yyvsp[(3) - (6)].l), i, &d);
	int j = (int)d;
	Surface *s = FindSurface(j);
	if(s){
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          s->TransfiniteSmoothing = (int)(yyvsp[(5) - (6)].d);
        }
        else{
	  GFace *gf = GModel::current()->getFaceByTag(j);
	  if(gf)
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
            gf->meshAttributes.transfiniteSmoothing = (int)(yyvsp[(5) - (6)].d);
          else
	    yymsg(1, "Unknown surface %d", (int)(yyvsp[(5) - (6)].d));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
      List_Delete((yyvsp[(3) - (6)].l));
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3408 "Gmsh.y"
      if(List_Nbr((yyvsp[(5) - (6)].l)) != List_Nbr((yyvsp[(3) - (6)].l))){
	yymsg(0, "Number of master (%d) different from number of slave (%d) lines",
              List_Nbr((yyvsp[(5) - (6)].l)), List_Nbr((yyvsp[(3) - (6)].l)));
      else{
        for(int i = 0; i < List_Nbr((yyvsp[(3) - (6)].l)); i++){
          double d_master, d_slave;
          List_Read((yyvsp[(5) - (6)].l), i, &d_master);
          List_Read((yyvsp[(3) - (6)].l), i, &d_slave);
          int j_master = (int)d_master;
          int j_slave  = (int)d_slave;
          Curve *c_slave = FindCurve(abs(j_slave));
          if(c_slave){
            c_slave->meshMaster = j_master;	  
          }
          else{
            GEdge *ge = GModel::current()->getEdgeByTag(abs(j_slave));
            if(ge) ge->setMeshMaster(j_master);
            else yymsg(0, "Unknown line %d", j_slave);
          }
        }
      }
      List_Delete((yyvsp[(3) - (6)].l));
      List_Delete((yyvsp[(5) - (6)].l));
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3436 "Gmsh.y"
      if (List_Nbr((yyvsp[(5) - (12)].l)) != List_Nbr((yyvsp[(10) - (12)].l))){
	yymsg(0, "Number of master surface edges (%d) different from number of "
              "slave (%d) edges", List_Nbr((yyvsp[(10) - (12)].l)), List_Nbr((yyvsp[(5) - (12)].l)));
        int j_master = (int)(yyvsp[(8) - (12)].d);
        int j_slave = (int)(yyvsp[(3) - (12)].d);
        Surface *s_slave = FindSurface(abs(j_slave));
        if(s_slave){
          s_slave->meshMaster = j_master;
          for (int i = 0; i < List_Nbr((yyvsp[(5) - (12)].l)); i++){
            double dm, ds;
            List_Read((yyvsp[(5) - (12)].l), i, &ds);
            List_Read((yyvsp[(10) - (12)].l), i, &dm);	  
            s_slave->edgeCounterparts[(int)ds] = (int)dm;
          }
        }
        else{
          GFace *gf = GModel::current()->getFaceByTag(abs(j_slave));
          if(gf){
            gf->setMeshMaster(j_master);
            for (int i = 0; i < List_Nbr((yyvsp[(5) - (12)].l)); i++){
              double dm, ds;
              List_Read((yyvsp[(5) - (12)].l), i, &ds);
              List_Read((yyvsp[(10) - (12)].l), i, &dm);
              gf->edgeCounterparts[(int)ds] = (int)dm;
            }
          }
          else yymsg(0, "Unknown surface %d", j_slave);
        }
      List_Delete((yyvsp[(5) - (12)].l));
      List_Delete((yyvsp[(10) - (12)].l));
/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3479 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    { 
      Surface *s = FindSurface((int)(yyvsp[(8) - (10)].d));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      if(s){
	setSurfaceEmbeddedPoints(s, (yyvsp[(3) - (10)].l));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
      else{
        GFace *gf = GModel::current()->getFaceByTag((int)(yyvsp[(8) - (10)].d));
        if(gf){
          for(int i = 0; i < List_Nbr((yyvsp[(3) - (10)].l)); i++){
            int iPoint;
            List_Read((yyvsp[(3) - (10)].l), i, &iPoint);
            GVertex *gv = GModel::current()->getVertexByTag(iPoint);
            if(gv)
              gf->addEmbeddedVertex(gv);
            else
              yymsg(0, "Unknown point %d", iPoint);
          }
        }
        else
          yymsg(0, "Unknown surface %d", (int)(yyvsp[(8) - (10)].d));
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3502 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
      Surface *s = FindSurface((int)(yyvsp[(8) - (10)].d));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      if(s){
	setSurfaceEmbeddedCurves(s, (yyvsp[(3) - (10)].l));
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
      else{
        GFace *gf = GModel::current()->getFaceByTag((int)(yyvsp[(8) - (10)].d));
        if(gf){
          for(int i = 0; i < List_Nbr((yyvsp[(3) - (10)].l)); i++){
            int iCurve;
            List_Read((yyvsp[(3) - (10)].l), i, &iCurve);
            GEdge *ge = GModel::current()->getEdgeByTag(iCurve);
            if(ge)
              gf->addEmbeddedEdge(ge);
            else
              yymsg(0, "Unknown line %d", iCurve);
          }
        }
        else
          yymsg(0, "Unknown surface %d", (int)(yyvsp[(8) - (10)].d));
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3525 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3528 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    {
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3537 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    { 
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3541 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    { 
      if(!strcmp((yyvsp[(2) - (3)].c), "Geometry"))
        ReplaceAllDuplicates();
      else if(!strcmp((yyvsp[(2) - (3)].c), "Mesh"))
        GModel::current()->removeDuplicateMeshVertices(CTX::instance()->geom.tolerance);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else
        yymsg(0, "Unknown coherence command");
      Free((yyvsp[(2) - (3)].c));
    ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3551 "Gmsh.y"
    { 
      if(List_Nbr((yyvsp[(4) - (6)].l)) >= 2){
        double d;
        List_Read((yyvsp[(4) - (6)].l), 0, &d);
        Vertex *target = FindPoint((int)d);
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        if(!target)
          yymsg(0, "Could not find Point %d", (int)d);
        else{
          double x = target->Pos.X, y = target->Pos.Y, z = target->Pos.Z;
          for(int i = 1; i < List_Nbr((yyvsp[(4) - (6)].l)); i++){
            List_Read((yyvsp[(4) - (6)].l), i, &d);
            Vertex *source = FindPoint((int)d);
            if(!source) yymsg(0, "Could not find Point %d", (int)d);
            if(target && source){
              source->Typ = target->Typ;
              source->Pos.X = x;
              source->Pos.Y = y;
              source->Pos.Z = z;
              source->boundaryLayerIndex = target->boundaryLayerIndex;
            }
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          ExtrudeParams::normalsCoherence.push_back(SPoint3(x, y, z));
        }
      }
      else
        yymsg(0, "Need at least two points to merge");
      ReplaceAllDuplicates();
      List_Delete((yyvsp[(4) - (6)].l));
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3588 "Gmsh.y"
Matti Pellika's avatar
 
Matti Pellika committed
    {
Matti Pellika's avatar
 
Matti Pellika committed
    
    List_T *temp = ListOfDouble2ListOfInt((yyvsp[(7) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    std::vector<int> domain;
    
Christophe Geuzaine's avatar
Christophe Geuzaine committed
    for (int i = 0; i < List_Nbr(temp); i++){
Matti Pellika's avatar
 
Matti Pellika committed
      int item = 0;
      List_Read(temp, i, &item);
      domain.push_back(item);
    }
    List_Delete((yyvsp[(7) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete(temp);
    
    List_T *temp2 = ListOfDouble2ListOfInt((yyvsp[(9) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    std::vector<int> subdomain;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
    for (int i = 0; i < List_Nbr(temp2); i++){
Matti Pellika's avatar
 
Matti Pellika committed
      int item = 0;
      List_Read(temp2, i, &item);
      subdomain.push_back(item);
    }
    List_Delete((yyvsp[(9) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete(temp2);
    
    std::string fileName = "";
    fileName = (yyvsp[(3) - (11)].c);
    
Matti Pellika's avatar
 
Matti Pellika committed
    #if defined(HAVE_KBIPACK)
Matti Pellika's avatar
 
Matti Pellika committed
    Homology* homology = new Homology(GModel::current(), domain, subdomain);
    homology->setFileName(fileName);
    homology->computeRanks();
Matti Pellika's avatar
 
Matti Pellika committed
    delete homology;
    #else
Christophe Geuzaine's avatar
pp  
Christophe Geuzaine committed
    yymsg(0, "Gmsh needs to be configured with option Kbipack to use homology computation");
Matti Pellika's avatar
 
Matti Pellika committed
    #endif
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3625 "Gmsh.y"
Matti Pellika's avatar
 
Matti Pellika committed
    {
Matti Pellika's avatar
 
Matti Pellika committed
    List_T *temp = ListOfDouble2ListOfInt((yyvsp[(7) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    std::vector<int> domain;
    
Christophe Geuzaine's avatar
Christophe Geuzaine committed
    for (int i = 0; i < List_Nbr(temp); i++){
Matti Pellika's avatar
 
Matti Pellika committed
      int item = 0;
      List_Read(temp, i, &item);
      domain.push_back(item);
    }
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete((yyvsp[(7) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete(temp);
    
Matti Pellika's avatar
 
Matti Pellika committed
    List_T *temp2 = ListOfDouble2ListOfInt((yyvsp[(9) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    std::vector<int> subdomain;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
    for (int i = 0; i < List_Nbr(temp2); i++){
Matti Pellika's avatar
 
Matti Pellika committed
      int item = 0;
      List_Read(temp2, i, &item);
      subdomain.push_back(item);
    }
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete((yyvsp[(9) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete(temp2);
    
    std::string fileName = "";
    fileName = (yyvsp[(3) - (11)].c);
Matti Pellika's avatar
 
Matti Pellika committed
    
Matti Pellika's avatar
 
Matti Pellika committed
    #if defined(HAVE_KBIPACK)
Matti Pellika's avatar
 
Matti Pellika committed
    Homology* homology = new Homology(GModel::current(), domain, subdomain);
    homology->setFileName(fileName);
    homology->findGenerators();  
Matti Pellika's avatar
 
Matti Pellika committed
    delete homology;
Matti Pellika's avatar
 
Matti Pellika committed
    #else
Christophe Geuzaine's avatar
pp  
Christophe Geuzaine committed
    yymsg(0, "Gmsh needs to be configured with option Kbipack to use homology computation");
Matti Pellika's avatar
 
Matti Pellika committed
    #endif
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3661 "Gmsh.y"
Matti Pellika's avatar
 
Matti Pellika committed
    {
Matti Pellika's avatar
 
Matti Pellika committed
    List_T *temp = ListOfDouble2ListOfInt((yyvsp[(7) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    std::vector<int> domain;
    
Christophe Geuzaine's avatar
Christophe Geuzaine committed
    for (int i = 0; i < List_Nbr(temp); i++){
Matti Pellika's avatar
 
Matti Pellika committed
      int item = 0;
      List_Read(temp, i, &item);
      domain.push_back(item);
    }
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete((yyvsp[(7) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete(temp);
    
Matti Pellika's avatar
 
Matti Pellika committed
    List_T *temp2 = ListOfDouble2ListOfInt((yyvsp[(9) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    std::vector<int> subdomain;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
    for (int i = 0; i < List_Nbr(temp2); i++){
Matti Pellika's avatar
 
Matti Pellika committed
      int item = 0;
      List_Read(temp2, i, &item);
      subdomain.push_back(item);
    }
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete((yyvsp[(9) - (11)].l));
Matti Pellika's avatar
 
Matti Pellika committed
    List_Delete(temp2);
    
    std::string fileName = "";
    fileName = (yyvsp[(3) - (11)].c);
Matti Pellika's avatar
 
Matti Pellika committed
    
Matti Pellika's avatar
 
Matti Pellika committed
    #if defined(HAVE_KBIPACK)
Matti Pellika's avatar
 
Matti Pellika committed
    Homology* homology = new Homology(GModel::current(), domain, subdomain);
    homology->setFileName(fileName);
    homology->findDualGenerators();
Matti Pellika's avatar
 
Matti Pellika committed
    delete homology;
Matti Pellika's avatar
 
Matti Pellika committed
    #else
Christophe Geuzaine's avatar
pp  
Christophe Geuzaine committed
    yymsg(0, "Gmsh needs to be configured with option Kbipack to use homology computation");
Matti Pellika's avatar
 
Matti Pellika committed
    #endif
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3696 "Gmsh.y"
    {
    List_T *temp = ListOfDouble2ListOfInt((yyvsp[(7) - (11)].l));
    std::vector<int> domain;
    
    for (int i = 0; i < List_Nbr(temp); i++){
      int item = 0;
      List_Read(temp, i, &item);
      domain.push_back(item);
    }
    List_Delete((yyvsp[(7) - (11)].l));
    List_Delete(temp);
    
    List_T *temp2 = ListOfDouble2ListOfInt((yyvsp[(9) - (11)].l));
    std::vector<int> subdomain;
    for (int i = 0; i < List_Nbr(temp2); i++){
      int item = 0;
      List_Read(temp2, i, &item);
      subdomain.push_back(item);
    }
    List_Delete((yyvsp[(9) - (11)].l));
    List_Delete(temp2);
    
    std::string fileName = "";
    fileName = (yyvsp[(3) - (11)].c);
    
    #if defined(HAVE_KBIPACK)
    Homology* homology = new Homology(GModel::current(), domain, subdomain);
    homology->setFileName(fileName);
    homology->findHomSequence();
    delete homology;
    #else
Christophe Geuzaine's avatar
pp  
Christophe Geuzaine committed
    yymsg(0, "Gmsh needs to be configured with option Kbipack to use homology computation");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3735 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (1)].d);           ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3736 "Gmsh.y"
    { (yyval.d) = (yyvsp[(2) - (3)].d);           ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3737 "Gmsh.y"
    { (yyval.d) = -(yyvsp[(2) - (2)].d);          ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3738 "Gmsh.y"
    { (yyval.d) = (yyvsp[(2) - (2)].d);           ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3739 "Gmsh.y"
    { (yyval.d) = !(yyvsp[(2) - (2)].d);          ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3740 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) - (yyvsp[(3) - (3)].d);      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3741 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) + (yyvsp[(3) - (3)].d);      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3742 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) * (yyvsp[(3) - (3)].d);      ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3744 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    { 
      if(!(yyvsp[(3) - (3)].d))
	yymsg(0, "Division by zero in '%g / %g'", (yyvsp[(1) - (3)].d), (yyvsp[(3) - (3)].d));
	(yyval.d) = (yyvsp[(1) - (3)].d) / (yyvsp[(3) - (3)].d);     
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    ;}
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3750 "Gmsh.y"
    { (yyval.d) = (int)(yyvsp[(1) - (3)].d) % (int)(yyvsp[(3) - (3)].d);  ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3751 "Gmsh.y"
    { (yyval.d) = pow((yyvsp[(1) - (3)].d), (yyvsp[(3) - (3)].d));  ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3752 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) < (yyvsp[(3) - (3)].d);      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3753 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) > (yyvsp[(3) - (3)].d);      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3754 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) <= (yyvsp[(3) - (3)].d);     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3755 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) >= (yyvsp[(3) - (3)].d);     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3756 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) == (yyvsp[(3) - (3)].d);     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3757 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) != (yyvsp[(3) - (3)].d);     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3758 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) && (yyvsp[(3) - (3)].d);     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3759 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (3)].d) || (yyvsp[(3) - (3)].d);     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3760 "Gmsh.y"
    { (yyval.d) = (yyvsp[(1) - (5)].d) ? (yyvsp[(3) - (5)].d) : (yyvsp[(5) - (5)].d); ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3761 "Gmsh.y"
    { (yyval.d) = exp((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3762 "Gmsh.y"
    { (yyval.d) = log((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3763 "Gmsh.y"
    { (yyval.d) = log10((yyvsp[(3) - (4)].d));    ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3764 "Gmsh.y"
    { (yyval.d) = sqrt((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3765 "Gmsh.y"
    { (yyval.d) = sin((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;
/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3766 "Gmsh.y"
    { (yyval.d) = asin((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3767 "Gmsh.y"
    { (yyval.d) = cos((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3768 "Gmsh.y"
    { (yyval.d) = acos((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;
/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3769 "Gmsh.y"
    { (yyval.d) = tan((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3770 "Gmsh.y"
    { (yyval.d) = atan((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3771 "Gmsh.y"
    { (yyval.d) = atan2((yyvsp[(3) - (6)].d), (yyvsp[(5) - (6)].d));;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3772 "Gmsh.y"
    { (yyval.d) = sinh((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3773 "Gmsh.y"
    { (yyval.d) = cosh((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3774 "Gmsh.y"
    { (yyval.d) = tanh((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3775 "Gmsh.y"
    { (yyval.d) = fabs((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3776 "Gmsh.y"
    { (yyval.d) = floor((yyvsp[(3) - (4)].d));    ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3777 "Gmsh.y"
    { (yyval.d) = ceil((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3778 "Gmsh.y"
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    { (yyval.d) = fmod((yyvsp[(3) - (6)].d), (yyvsp[(5) - (6)].d)); ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;
/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3779 "Gmsh.y"
    { (yyval.d) = fmod((yyvsp[(3) - (6)].d), (yyvsp[(5) - (6)].d)); ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3780 "Gmsh.y"
    { (yyval.d) = sqrt((yyvsp[(3) - (6)].d) * (yyvsp[(3) - (6)].d) + (yyvsp[(5) - (6)].d) * (yyvsp[(5) - (6)].d)); ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3781 "Gmsh.y"
    { (yyval.d) = (yyvsp[(3) - (4)].d) * (double)rand() / (double)RAND_MAX; ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3783 "Gmsh.y"
    { (yyval.d) = exp((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3784 "Gmsh.y"
    { (yyval.d) = log((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3785 "Gmsh.y"
    { (yyval.d) = log10((yyvsp[(3) - (4)].d));    ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3786 "Gmsh.y"
    { (yyval.d) = sqrt((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3787 "Gmsh.y"
    { (yyval.d) = sin((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3788 "Gmsh.y"
    { (yyval.d) = asin((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3789 "Gmsh.y"
    { (yyval.d) = cos((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3790 "Gmsh.y"
    { (yyval.d) = acos((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3791 "Gmsh.y"
    { (yyval.d) = tan((yyvsp[(3) - (4)].d));      ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3792 "Gmsh.y"
    { (yyval.d) = atan((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3793 "Gmsh.y"
    { (yyval.d) = atan2((yyvsp[(3) - (6)].d), (yyvsp[(5) - (6)].d));;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3794 "Gmsh.y"
    { (yyval.d) = sinh((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3795 "Gmsh.y"
    { (yyval.d) = cosh((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3796 "Gmsh.y"
    { (yyval.d) = tanh((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;

/* Line 1464 of yacc.c  */
Gaetan Bricteux's avatar
Gaetan Bricteux committed
#line 3797 "Gmsh.y"
    { (yyval.d) = fabs((yyvsp[(3) - (4)].d));     ;}
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    break;