123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- /**
- * \file fmm_node.hpp
- * \author Dhairya Malhotra, dhairya.malhotra@gmail.com
- * \date 12-11-2010
- * \brief This file contains the definition of the FMM_Node class.
- */
- #ifndef _PVFMM_FMM_NODE_HPP_
- #define _PVFMM_FMM_NODE_HPP_
- #include <mpi.h>
- #include <iostream>
- #include <pvfmm_common.hpp>
- #include <mpi_node.hpp>
- #include <fmm_pts.hpp>
- namespace pvfmm{
- /**
- * \brief Base class for node of FMM_Tree.
- */
- template <class Node>
- class FMM_Node: public Node{
- public:
- typedef Node Node_t; //Type of base node class (MPI_Node / Cheb_Node)
- typedef typename Node_t::Real_t Real_t;
- /**
- * \brief Base class for node data. Contains initialization data for the node.
- */
- class NodeData: public Node_t::NodeData{
- public:
- Vector<Real_t> src_coord; //Point sources.
- Vector<Real_t> src_value;
- Vector<Real_t> surf_coord; //Surface sources.
- Vector<Real_t> surf_value;
- Vector<Real_t> trg_coord; //Target coordinates.
- Vector<Real_t> trg_value;
- };
- /**
- * \brief Constructor.
- */
- FMM_Node(){
- Node_t();
- fmm_data=NULL;
- }
- /**
- * /brief Virtual destructor.
- */
- virtual ~FMM_Node();
- /**
- * \brief Initialize the node with relevant data.
- */
- virtual void Initialize(TreeNode* parent_, int path2node_, TreeNode::NodeData*) ;
- /**
- * \brief Returns list of coordinate and value vectors which need to be
- * sorted and partitioned across MPI processes and the scatter index is
- * saved.
- */
- virtual void NodeDataVec(std::vector<Vector<Real_t>*>& coord,
- std::vector<Vector<Real_t>*>& value,
- std::vector<Vector<size_t>*>& scatter){
- Node::NodeDataVec(coord, value, scatter);
- coord .push_back(&src_coord );
- value .push_back(&src_value );
- scatter.push_back(&src_scatter);
- coord .push_back(&surf_coord );
- value .push_back(&surf_value );
- scatter.push_back(&surf_scatter);
- coord .push_back(&trg_coord );
- value .push_back(&trg_value );
- scatter.push_back(&trg_scatter);
- }
- /**
- * \brief Clear node data.
- */
- virtual void ClearData();
- /**
- * \brief Clear FMM specific node (multipole and local expansion) data
- */
- void ClearFMMData();
- /**
- * \brief Returns reference to fmm_data.
- */
- FMM_Data<Real_t>*& FMMData(){return fmm_data;}
- /**
- * \brief Allocate a new object of the same type (as the derived class) and
- * return a pointer to it type cast as (TreeNode*).
- */
- virtual TreeNode* NewNode(TreeNode* n_=NULL);
- /**
- * \brief Evaluates and returns the subdivision condition for this node.
- * 'true' if node requires further subdivision.
- */
- virtual bool SubdivCond();
- /**
- * \brief Create child nodes and Initialize them.
- */
- virtual void Subdivide() ;
- /**
- * \brief Truncates the tree i.e. makes this a leaf node.
- */
- virtual void Truncate() ;
- /**
- * \brief Pack node for transmission using MPI.
- */
- virtual PackedData Pack(bool ghost=false, void* buff_ptr=NULL, size_t offset=0);
- /**
- * \brief Unpack node.
- */
- virtual void Unpack(PackedData p0, bool own_data=true);
- /**
- * \brief Pack the multipole expansion data to be transmitted to another
- * process. This is done during the reduction step at the end of the local
- * upward pass.
- */
- virtual PackedData PackMultipole(void* buff_ptr=NULL);
- /**
- * \brief Add to the multipole expansion of this node during reduction step.
- */
- virtual void AddMultipole(PackedData data);
- /**
- * \brief Initialize the multipole expansion with data from another process.
- * Used during broadcast step.
- */
- virtual void InitMultipole(PackedData data, bool own_data=true);
- Vector<Real_t> src_coord; //Point sources.
- Vector<Real_t> src_value;
- Vector<size_t> src_scatter;
- Vector<Real_t> surf_coord; //Surface sources.
- Vector<Real_t> surf_value; //Normal and src strength.
- Vector<size_t> surf_scatter;
- Vector<Real_t> trg_coord; //Target coordinates.
- Vector<Real_t> trg_value;
- Vector<size_t> trg_scatter;
- std::vector<std::vector<FMM_Node*> > interac_list;
- size_t node_id; //For translating node pointer to index.
- private:
- FMM_Data<Real_t>* fmm_data; //FMM specific data.
- Vector<char> pkd_data; //Temporary variable for storing packed data.
- };
- }//end namespace
- #include <fmm_node.txx>
- #endif //_PVFMM_FMM_NODE_HPP_
|