Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F90569276
test_interpolate.cc
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sat, Nov 2, 20:54
Size
4 KB
Mime Type
text/x-c
Expires
Mon, Nov 4, 20:54 (2 d)
Engine
blob
Format
Raw Data
Handle
22058920
Attached To
rAKA akantu
test_interpolate.cc
View Options
/**
* @file test_interpolate.cc
*
* @author Aurelia Isabel Cuba Ramos <aurelia.cubaramos@epfl.ch>
*
*
* @brief test the interpolation function of the igfem elements
*
* @section LICENSE
*
* Copyright (©) 2010-2012, 2014 EPFL (Ecole Polytechnique Fédérale de Lausanne)
* Laboratory (LSMS - Laboratoire de Simulation en Mécanique des Solides)
*
*/
/* -------------------------------------------------------------------------- */
#include "aka_common.hh"
#include "shape_igfem.hh"
#include "integrator_gauss_igfem.hh"
#include "fe_engine.hh"
#include "mesh.hh"
#include "mesh_io.hh"
#include "mesh_io_msh.hh"
#include "dumper_paraview.hh"
#include "dumper_nodal_field.hh"
/* -------------------------------------------------------------------------- */
#include <cstdlib>
#include <fstream>
#include <iostream>
/* -------------------------------------------------------------------------- */
using namespace akantu;
int main(int argc, char *argv[]) {
initialize(argc, argv);
const ElementType type_igfem = _igfem_triangle_5;
const ElementType type_regular = _triangle_3;
/// debug::setDebugLevel(dblTest);
UInt dim = ElementClass<type_igfem>::getSpatialDimension();
// create a mesh that containes one IGFEM triangle 4
UInt nb_elements_igfem = 1;
UInt nb_elements_regular = 1;
UInt nb_nodes = 5;
Mesh mesh(dim);
std::cout << "Generating mesh..." << std::endl;
Array<Real> & nodes = const_cast<Array<Real> &>(mesh.getNodes());
nodes.resize(nb_nodes);
mesh.addConnectivityType(type_regular);
mesh.addConnectivityType(type_igfem);
Array<UInt> & connectivity_igfem = const_cast<Array<UInt> &>(mesh.getConnectivity(type_igfem));
connectivity_igfem.resize(nb_elements_igfem);
Array<UInt> & connectivity_regular = const_cast<Array<UInt> &>(mesh.getConnectivity(type_regular));
connectivity_regular.resize(nb_elements_regular);
// set the nodal coordinates
nodes.storage()[0] = 0.;
nodes.storage()[1] = 0.;
nodes.storage()[2] = 1.;
nodes.storage()[3] = 0.;
nodes.storage()[4] = 0.;
nodes.storage()[5] = 1.;
nodes.storage()[6] = 0.5;
nodes.storage()[7] = 0.;
nodes.storage()[8] = 0.5;
nodes.storage()[9] = 0.5;
nodes.storage()[10] = -1.;
nodes.storage()[11] = 0.;
// set the element connectivity
// first element
connectivity_igfem[0] = 1;
connectivity_igfem[1] = 2;
connectivity_igfem[2] = 0;
connectivity_igfem[3] = 4;
connectivity_igfem[4] = 3;
// second element
connectivity_regular[0] = 0;
connectivity_regular[1] = 2;
connectivity_regular[2] = 5;
// FEEngine *fem = new FEEngineTemplate<IntegratorGauss,ShapeLagrange,_ek_igfem>(mesh, dim, "my_fem");
// std::stringstream outfilename; outfilename << "out_" << type_igfem << ".txt";
// std::ofstream my_file(outfilename.str().c_str());
// fem->initShapeFunctions();
// std::cout << *fem << std::endl;
// Array<Real> const_val(fem->getMesh().getNbNodes(), 2, "const_val");
// UInt nb_quadrature_points = fem->getNbQuadraturePoints(type_igfem) * nb_elements_igfem;
// Array<Real> val_on_quad(nb_quadrature_points, 2, "val_on_quad");
// for (UInt i = 0; i < const_val.getSize(); ++i) {
// const_val.storage()[i * 2 + 0] = 1.;
// const_val.storage()[i * 2 + 1] = 2.;
// }
// const_val.storage()[0] = 1.;
// const_val.storage()[1] = 2.;
// const_val.storage()[2] = 1.;
// const_val.storage()[3] = 2.;
// const_val.storage()[4] = 1.;
// const_val.storage()[5] = 2.;
// const_val.storage()[6] = 0.;
// const_val.storage()[7] = 0.;
// const_val.storage()[8] = 0.;
// const_val.storage()[9] = 0.;
// const_val.storage()[10] = 0.;
// const_val.storage()[11] = 0.;
// fem->interpolateOnQuadraturePoints(const_val, val_on_quad, 2, type_igfem);
// my_file << const_val << std::endl;
// my_file << val_on_quad << std::endl;
// DumperParaview dumper_regular("mesh");
DumperParaview dumper_igfem("mesh_igfem");
dumper_igfem.registerMesh(mesh, dim, _not_ghost, _ek_igfem);
DumperParaview dumper_regular("mesh_regular");
dumper_regular.registerMesh(mesh, dim, _not_ghost, _ek_regular);
// dumper_regular.registerField("displacement", new dumper::NodalField<Real,false>(const_val, 0, 0));
dumper_igfem.dump();
dumper_regular.dump();
// dumper_regular.dump();
// // interpolate coordinates
// Array<Real> coord_on_quad(nb_quadrature_points, mesh.getSpatialDimension(), "coord_on_quad");
// fem->interpolateOnQuadraturePoints(mesh.getNodes(),
// coord_on_quad,
// mesh.getSpatialDimension(),
// type);
// my_file << mesh.getNodes() << std::endl;
// my_file << coord_on_quad << std::endl;
// delete fem;
finalize();
return EXIT_SUCCESS;
}
Event Timeline
Log In to Comment