Skip to content
Snippets Groups Projects
test-fromvertexcount.cc 2.44 KiB
Newer Older
Christian Engwer's avatar
Christian Engwer committed
// -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
// vi: set et ts=4 sw=2 sts=2:
#if HAVE_CONFIG_H
#include "config.h"
#endif

#include <string>
#include <iostream>
#include <vector>

// Also test the deprecated version
#include <dune/common/deprecated.hh>
#include <dune/geometry/type.hh>

#include <dune/geometry/utility/typefromvertexcount.hh>
Christian Engwer's avatar
Christian Engwer committed

std::string convBase(unsigned long v, long base)
{
  const char* digits = "0123456789abcdef";
  std::string result;
  if((base < 2) || (base > 16)) {
    result = "Error: base out of range.";
  }
  else {
    do {
      result = digits[v % base] + result;
      v /= base;
    }
    while(v);
  }
  return result;
}

void guessTopologyId(unsigned int dim, unsigned int vertices,
                     unsigned int v, unsigned int id, unsigned int d,
                     std::vector<unsigned int> & ids)
{
  if (d == dim)
  {
    if (v == vertices)
      ids.push_back(id);
    return;
  }
  // try simplex
  guessTopologyId(dim,vertices,v+1,id,d+1,ids);
  // try cube
  guessTopologyId(dim,vertices,v*2,id+(1<<d),d+1,ids);
}

unsigned int guessTopologyId(unsigned int dim, unsigned int vertices)
{
  std::vector<unsigned int> ids;
  if (dim == 0 || dim == 1)
    return 0;
  if (vertices < dim+1 || vertices > 1u<<dim)
Christian Engwer's avatar
Christian Engwer committed
    DUNE_THROW(Dune::Exception, "IMPOSSIBLE");
  guessTopologyId(dim,vertices,2,1,1,ids);
  if (ids.size() == 0)
    DUNE_THROW(Dune::Exception, "Impossible setting");
  if (ids.size() > 1)
    DUNE_THROW(Dune::Exception, "Too many options");
  return ids[0];
}

void testGuess(unsigned int dim, unsigned int vertices)
{
  std::cout << "check dim: " << dim
            << " vertices: " << vertices
            << std::endl;
Christian Engwer's avatar
Christian Engwer committed
  unsigned int id = guessTopologyId(dim, vertices);
  Dune::GeometryType gt = Dune::geometryTypeFromVertexCount(dim, vertices);
  if (Dune::GeometryType(id,dim) != gt)
    DUNE_THROW(Dune::Exception, "Failed to guess the geometry type from the number of vertices.");

  DUNE_NO_DEPRECATED_BEGIN
  Dune::GeometryType gt2;
  gt2.makeFromVertices(dim, vertices);
  if (gt != gt2)
    DUNE_THROW(Dune::Exception, "geometryTypeFromVertexCount and makeFromVertices return different type");
  DUNE_NO_DEPRECATED_END
Christian Engwer's avatar
Christian Engwer committed
}

int main()
  std::vector<std::vector<int>> configurations = { {1}, {2}, {3,4}, {4,5,6,8} };
Christian Engwer's avatar
Christian Engwer committed
        testGuess(d,v);
}
catch (Dune::Exception & e)
{
  std::cout << "Error: " << e.what() << std::endl;
  return 1;