source: src/Filling/Preparators/ShapeVolumeFillerPreparator.cpp@ 40fe06

FitPartialCharges_GlobalError
Last change on this file since 40fe06 was 6801f4, checked in by Frederik Heber <heber@…>, 11 years ago

Added FillVolumeAction for filling a Shape's volume.

  • added ShapeFillerPreparator for preparing the volume filler.
  • FIX: MeshAdaptor should include Mesh.hpp.
  • added regression tests for FillVolume for all present shapes.
  • all but cylinder fail because of missing implementation, are marked as XFAIL for the moment, except everywhere and nowhere of FillVolume which say they fail explicitly. (this is not an implementation problem, for these shapes filling makes no sense.) We explicitly check for the currently failing shape types and let the Action fail (cause this works also in disable-debug).
  • Property mode set to 100644
File size: 1.7 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2014 Frederik Heber. All rights reserved.
5 *
6 *
7 * This file is part of MoleCuilder.
8 *
9 * MoleCuilder is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * MoleCuilder is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
21 */
22
23/*
24 * ShapeVolumeFillerPreparator.cpp
25 *
26 * Created on: Sep 3, 2014
27 * Author: heber
28 */
29
30// include config.h
31#ifdef HAVE_CONFIG_H
32#include <config.h>
33#endif
34
35#include "CodePatterns/MemDebug.hpp"
36
37#include "ShapeVolumeFillerPreparator.hpp"
38
39#include <boost/bind.hpp>
40#include <boost/function.hpp>
41
42#include "Filling/Mesh/Mesh.hpp"
43#include "Filling/Mesh/MeshAdaptor.hpp"
44#include "Shapes/Shape.hpp"
45
46ShapeVolumeFillerPreparator::ShapeVolumeFillerPreparator(molecule *_filler) :
47 BaseFillerPreparator(_filler)
48{}
49
50ShapeVolumeFillerPreparator::~ShapeVolumeFillerPreparator()
51{}
52
53void ShapeVolumeFillerPreparator::addShapeMesh(
54 const Shape &_shape,
55 const unsigned int _nodes)
56{
57
58 MeshAdaptor::function_t fct =
59 boost::bind(&Shape::getHomogeneousPointsInVolume,
60 boost::cref(_shape),
61 _nodes);
62 mesh = new MeshAdaptor(fct);
63}
64
Note: See TracBrowser for help on using the repository browser.