$extrastylesheet
tree_base.h
Go to the documentation of this file.
00001 // The libMesh Finite Element Library.
00002 // Copyright (C) 2002-2014 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
00003 
00004 // This library is free software; you can redistribute it and/or
00005 // modify it under the terms of the GNU Lesser General Public
00006 // License as published by the Free Software Foundation; either
00007 // version 2.1 of the License, or (at your option) any later version.
00008 
00009 // This library is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // Lesser General Public License for more details.
00013 
00014 // You should have received a copy of the GNU Lesser General Public
00015 // License along with this library; if not, write to the Free Software
00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00017 
00018 
00019 
00020 #ifndef LIBMESH_TREE_BASE_H
00021 #define LIBMESH_TREE_BASE_H
00022 
00023 // Local includes
00024 #include "libmesh/reference_counted_object.h"
00025 
00026 // C++ includes
00027 #include <set>
00028 
00029 namespace libMesh
00030 {
00031 
00032 
00033 // Forward Declarations
00034 class TreeBase;
00035 class MeshBase;
00036 class Point;
00037 class Elem;
00038 
00039 
00040 namespace Trees
00041 {
00051 enum BuildType {NODES=0,
00052                 ELEMENTS,
00053                 LOCAL_ELEMENTS,
00054                 INVALID_BUILD_TYPE };
00055 }
00056 
00061 class TreeBase : public ReferenceCountedObject<TreeBase>
00062 {
00063 protected:
00067   explicit
00068   TreeBase (const MeshBase& m);
00069 
00070 public:
00074   virtual ~TreeBase() {}
00075 
00079   virtual void print_nodes(std::ostream& out=libMesh::out) const = 0;
00080 
00084   virtual void print_elements(std::ostream& out=libMesh::out) const = 0;
00085 
00089   virtual unsigned int n_active_bins() const = 0;
00090 
00096   virtual const Elem* find_element(const Point& p,
00097                                    const std::set<subdomain_id_type>
00098                                    *allowed_subdomains = NULL,
00099                                    Real relative_tol = TOLERANCE) const = 0;
00100 
00101 protected:
00102 
00107   const MeshBase& mesh;
00108 };
00109 
00110 // ------------------------------------------------------------
00111 // TreeBase class inline methods
00112 
00113 // constructor
00114 inline
00115 TreeBase::TreeBase (const MeshBase& m) :
00116   mesh(m)
00117 {
00118 }
00119 
00120 } // namespace libMesh
00121 
00122 
00123 #endif // LIBMESH_TREE_BASE_H