|
shards
Version of the Day
|
00001 /* 00002 //@HEADER 00003 // ************************************************************************ 00004 // 00005 // Shards : Shared Discretization Tools 00006 // Copyright 2008, 2011 Sandia Corporation 00007 // 00008 // Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation, 00009 // the U.S. Government retains certain rights in this software. 00010 // 00011 // Redistribution and use in source and binary forms, with or without 00012 // modification, are permitted provided that the following conditions are 00013 // met: 00014 // 00015 // 1. Redistributions of source code must retain the above copyright 00016 // notice, this list of conditions and the following disclaimer. 00017 // 00018 // 2. Redistributions in binary form must reproduce the above copyright 00019 // notice, this list of conditions and the following disclaimer in the 00020 // documentation and/or other materials provided with the distribution. 00021 // 00022 // 3. Neither the name of the Corporation nor the names of the 00023 // contributors may be used to endorse or promote products derived from 00024 // this software without specific prior written permission. 00025 // 00026 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY 00027 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00028 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00029 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE 00030 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00031 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00032 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00033 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00034 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00035 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00036 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00037 // 00038 // Questions? Contact Carter Edwards (hcedwar@sandia.gov), 00039 // Pavel Bochev (pbboche@sandia.gov), or 00040 // Denis Ridzal (dridzal@sandia.gov). 00041 // 00042 // ************************************************************************ 00043 //@HEADER 00044 */ 00045 00046 //#define HAVE_SHARDS_DEBUG 00047 00048 #include <stdexcept> 00049 #include <sstream> 00050 #include <Shards_CellTopology.hpp> 00051 #include <Shards_BasicTopologies.hpp> 00052 #include <iostream> 00053 00054 namespace shards { 00055 00056 typedef CellTopologyData_Subcell Subcell ; 00057 00058 class CellTopologyManagedData : public CellTopologyData 00059 { 00060 public: 00062 CellTopologyManagedData( const std::string & name ); 00063 00065 CellTopologyManagedData( const std::string & name , const unsigned nodeCount ); 00066 00068 CellTopologyManagedData( 00069 const std::string & name, 00070 const unsigned vertexCount, 00071 const unsigned nodeCount, 00072 const std::vector< const CellTopologyData * > & edges , 00073 const std::vector< unsigned > & edge_node_map , 00074 const CellTopologyData * base ); 00075 00077 CellTopologyManagedData( 00078 const std::string & name, 00079 const unsigned vertexCount, 00080 const unsigned nodeCount, 00081 const std::vector< const CellTopologyData * > & edges , 00082 const std::vector< unsigned > & edge_node_map , 00083 const std::vector< const CellTopologyData * > & faces , 00084 const std::vector< unsigned > & face_node_map , 00085 const CellTopologyData * base ); 00086 00087 private: 00088 CellTopologyManagedData(); 00089 CellTopologyManagedData( const CellTopologyManagedData & ); 00090 CellTopologyManagedData & operator = ( const CellTopologyManagedData & ); 00091 00092 private: 00093 const std::string m_name ; 00094 std::vector< Subcell > m_subcell ; 00095 std::vector< unsigned > m_node_map ; 00096 }; 00097 00098 CellTopologyManagedData * 00099 createCellTopology( 00100 const std::string & name ); 00101 00102 CellTopologyManagedData * 00103 createCellTopology( 00104 const std::string & name, 00105 const unsigned node_count ); 00106 00107 CellTopologyManagedData * 00108 createCellTopology( 00109 const std::string & name, 00110 const unsigned vertex_count , 00111 const unsigned node_count, 00112 const std::vector< const CellTopologyData * > & edges , 00113 const std::vector< unsigned > & edge_node_map , 00114 const CellTopologyData * base ); 00115 00116 CellTopologyManagedData * 00117 createCellTopology( const std::string & name, 00118 const unsigned vertex_count, 00119 const unsigned node_count, 00120 const std::vector< const CellTopologyData * > & edges , 00121 const std::vector< unsigned > & edge_node_map , 00122 const std::vector< const CellTopologyData * > & faces , 00123 const std::vector< unsigned > & face_node_map , 00124 const CellTopologyData * base); 00125 00126 00127 } // namespace shards