A platform for high-performance distributed tool and library development written in C++. It can be deployed in two different cluster modes: standalone or distributed. API for v0.5.0, released on June 13, 2018.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
SimplePhysicalNodeFactory.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * *
3  * Copyright 2018 Rice University *
4  * *
5  * Licensed under the Apache License, Version 2.0 (the "License"); *
6  * you may not use this file except in compliance with the License. *
7  * You may obtain a copy of the License at *
8  * *
9  * http://www.apache.org/licenses/LICENSE-2.0 *
10  * *
11  * Unless required by applicable law or agreed to in writing, software *
12  * distributed under the License is distributed on an "AS IS" BASIS, *
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
14  * See the License for the specific language governing permissions and *
15  * limitations under the License. *
16  * *
17  *****************************************************************************/
19 
20 #ifndef PDB_SIMPLEPHYSICALNODE_FACTORY_H
21 #define PDB_SIMPLEPHYSICALNODE_FACTORY_H
22 
23 namespace pdb {
24 
26 typedef std::shared_ptr<SimplePhysicalNodeFactory> SimplePhysicalNodeFactoryPtr;
27 
32 public:
33 
34  SimplePhysicalNodeFactory(const string &jobId,
36  const ConfigurationPtr &conf);
37 
49 
50 
51 private:
52 
58  std::vector<AbstractPhysicalNodePtr> generateAnalyzerGraph(std::vector<AtomicComputationPtr> sources) override;
59 
66 
71  std::map<std::string, AbstractPhysicalNodePtr> nodes;
72 
73 
77  std::string jobId;
78 
83 
84 };
85 
86 }
87 
88 
89 #endif //PDB_SIMPLEPHYSICALNODE_FACTORY_H
SimplePhysicalNodeFactory(const string &jobId, const Handle< ComputePlan > &computePlan, const ConfigurationPtr &conf)
std::shared_ptr< SimplePhysicalNodeFactory > SimplePhysicalNodeFactoryPtr
shared_ptr< Configuration > ConfigurationPtr
Definition: Configuration.h:89
std::shared_ptr< struct AtomicComputation > AtomicComputationPtr
std::shared_ptr< AbstractPhysicalNode > AbstractPhysicalNodePtr
AbstractPhysicalNodePtr createAnalyzerNode(AtomicComputationPtr tcapNode)
void generateConsumerNode(AbstractPhysicalNodePtr source, AtomicComputationPtr node)
std::vector< AbstractPhysicalNodePtr > generateAnalyzerGraph(std::vector< AtomicComputationPtr > sources) override
std::map< std::string, AbstractPhysicalNodePtr > nodes