Loading [MathJax]/extensions/TeX/AMSmath.js
Radium Engine  1.5.28
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args > Class Template Reference

Node that deliver a std::function<R( Args... )}}> More...

#include <Dataflow/Core/Sources/FunctionSource.hpp>

+ Inheritance diagram for Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >:
+ Collaboration diagram for Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >:

Public Types

using function_type = std::function<R( Args... )>
 
- Public Types inherited from Ra::Dataflow::Core::Node
using PortIndex = Ra::Core::Utils::Index
 
template<typename Port >
using PortCollection = std::vector<Port>
 
template<typename Port >
using PortPtr = std::shared_ptr<Port>
 
template<typename Port >
using PortRawPtr = Port*
 
template<typename Type >
using PortInPtr = PortPtr<PortIn<Type>>
 
template<typename Type >
using PortInRawPtr = PortIn<Type>*
 
template<typename Type >
using PortOutPtr = PortPtr<PortOut<Type>>
 
template<typename Type >
using PortOutRawPtr = PortOut<Type>*
 
using PortBasePtr = PortPtr<PortBase>
 
using PortBaseRawPtr = PortRawPtr<PortBase>
 
using PortBaseCollection = PortCollection<PortBasePtr>
 
using PortBaseInPtr = PortPtr<PortBaseIn>
 
using PortBaseInRawPtr = PortRawPtr<PortBaseIn>
 
using PortBaseInCollection = PortCollection<PortBaseInPtr>
 
using PortBaseOutPtr = PortPtr<PortBaseOut>
 
using PortBaseOutRawPtr = PortRawPtr<PortBaseOut>
 
using PortBaseOutCollection = PortCollection<PortBaseOutPtr>
 
template<typename Port >
using IndexAndPort = std::pair<PortIndex, Port>
 
template<typename T >
using ParamHandle = Ra::Core::VariableSet::VariableHandle<T>
 

Public Member Functions

 FunctionSourceNode (const std::string &name)
 
bool execute () override
 Executes the node.
 
void set_data (function_type data)
 Set the function to be delivered by the node.
 
function_typedata () const
 Get the delivered data.
 
- Public Member Functions inherited from Ra::Dataflow::Core::Node
virtual ~Node ()=default
 make Node a base abstract class
 
bool operator== (const Node &node)
 Two nodes are considered equal if there model and instance names are the same.
 
void add_metadata (const nlohmann::json &data)
 Add a metadata to the node to store application specific information.
 
const nlohmann::json & metadata ()
 Give access to extra json data stored on the node.
 
bool is_initialized () const
 
Ra::Core::VariableSetparameters ()
 Return node's parameters.
 
Ra::Core::VariableSetinput_variables ()
 Return a variable set of input ports default value reference, if any.
 
bool is_output ()
 Node is output if none of the output ports is linked.
 
bool is_input ()
 Node is input if all input ports have default values and not linked.
 
 Node (const Node &)=delete
 
Nodeoperator= (const Node &)=delete
 
virtual void init ()
 Initializes the node content.
 
virtual bool compile ()
 Compile the node to check its validity.
 
virtual void destroy ()
 Delete the node's content.
 
auto port_by_name (const std::string &type, const std::string &name) const -> IndexAndPort< PortBaseRawPtr >
 Get a port by its name.
 
auto input_by_name (const std::string &name) const -> IndexAndPort< PortBaseInRawPtr >
 Convenience alias to port_by_name("in", name)
 
auto output_by_name (const std::string &name) const -> IndexAndPort< PortBaseOutRawPtr >
 Convenience alias to port_by_name("out", name)
 
PortBaseRawPtr port_by_index (const std::string &type, PortIndex index) const
 Get a port by its index.
 
auto input_by_index (PortIndex index) const
 Convenience alias to port_by_index("in", index)
 
auto output_by_index (PortIndex index) const
 Convenience alias to port_by_index("out", index)
 
template<typename T >
auto input_by_index (PortIndex index) const
 Convenience alias with typed port.
 
template<typename T >
auto output_by_index (PortIndex index) const
 Convenience alias with typed port.
 
const PortBaseInCollectioninputs () const
 Gets the in ports of the node.
 
const PortBaseOutCollectionoutputs () const
 Gets the out ports of the node.
 
const std::stringmodel_name () const
 Gets the model (type/class) name of the node.
 
const std::stringdisplay_name () const
 Gets the display name of the node (e.g. for gui), no need to be unique in a graph.
 
void set_display_name (const std::string &name)
 Set the display name.
 
const std::stringinstance_name () const
 Gets the instance name of the node.
 
void set_instance_name (const std::string &name)
 Sets the instance name the node (unused?) instance name must be unique in a graph.
 
void toJson (nlohmann::json &data) const
 Serialize the content of the node.
 
bool fromJson (const nlohmann::json &data)
 Unserialized the content of the node.
 

Static Public Member Functions

static const std::stringnode_typename ()
 

Protected Member Functions

 FunctionSourceNode (const std::string &instanceName, const std::string &typeName)
 
bool fromJsonInternal (const nlohmann::json &data) override
 Internal json representation of the Node.
 
void toJsonInternal (nlohmann::json &data) const override
 Internal json representation of the Node.
 
 RA_NODE_PORT_IN (function_type, from)
 
 RA_NODE_PORT_OUT (function_type, to)
 
- Protected Member Functions inherited from Ra::Dataflow::Core::Node
 Node (const std::string &instance, const std::string &typeName)
 Construct the base node given its name and type.
 
template<typename PortType >
auto port_by_name (const PortCollection< PortPtr< PortType > > &ports, const std::string &name) const -> IndexAndPort< PortRawPtr< PortType > >
 Gets the Port By Name.
 
template<typename PortType >
auto port_base (const PortCollection< PortPtr< PortType > > &ports, PortIndex idx) const -> PortRawPtr< PortType >
 Gets the PortBase In or Out by its index.
 
template<typename T , typename PortType >
auto port (const PortCollection< PortPtr< PortType > > &ports, PortIndex index) const
 Gets a port in a collection by its index.
 
template<typename PortType >
PortIndex add_port (PortCollection< PortPtr< PortType > > &, PortPtr< PortType > port)
 Adds a port to port collection.
 
PortIndex add_input (PortBaseInPtr in)
 Convenience alias to add_port(inputs(), in)
 
PortIndex add_output (PortBaseOutPtr out)
 Convenience alias to add_port(outputs(), out)
 
template<typename T , typename... U>
auto add_input (U &&... u)
 Adds a typed input port.
 
template<typename T , typename... U>
auto add_output (U &&... u)
 Adds a typed output port.
 
template<typename T >
auto input_port (PortIndex index)
 Gets a typed (input/output) port.
 
template<typename T >
auto output_port (PortIndex index)
 Gets a typed (input/output) port.
 
void remove_input (PortIndex index)
 Remove the given port from the managed (input/output) ports.
 
void remove_output (PortIndex index)
 Remove the given port from the managed (input/output) ports.
 
template<typename T >
auto add_parameter (const std::string &name, const T &value)
 
template<typename T >
bool remove_parameter (const std::string &name)
 
template<typename T >
bool remove_parameter (ParamHandle< T > &handle)
 

Additional Inherited Members

- Protected Attributes inherited from Ra::Dataflow::Core::Node
bool m_initialized { false }
 Flag that checks if the node is already initialized.
 
std::string m_model_name
 The type name of the node. Initialized once at construction.
 
std::string m_instance_name
 The instance name of the node.
 
std::string m_display_name { "" }
 Node's name if needed for display.
 
PortCollection< PortPtr< PortBaseIn > > m_inputs
 The in ports of the node (own by the node)
 
PortCollection< PortPtr< PortBaseOut > > m_outputs
 The out ports of the node (own by the node)
 
Ra::Core::VariableSet m_parameters
 The editable parameters of the node.
 
Ra::Core::VariableSet m_input_variables
 
nlohmann::json m_metadata
 Additional data on the node, added by application or gui or ...
 

Detailed Description

template<class R, class... Args>
class Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >

Node that deliver a std::function<R( Args... )}}>

Template Parameters
Rreturn type of the function
Typeof the function arguments

Definition at line 20 of file FunctionSource.hpp.

Member Typedef Documentation

◆ function_type

template<class R , class... Args>
using Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::function_type = std::function<R( Args... )>

Definition at line 24 of file FunctionSource.hpp.

Constructor & Destructor Documentation

◆ FunctionSourceNode() [1/2]

template<class R , class... Args>
Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::FunctionSourceNode ( const std::string & name)
inlineexplicit

Definition at line 26 of file FunctionSource.hpp.

◆ FunctionSourceNode() [2/2]

template<class R , class... Args>
Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::FunctionSourceNode ( const std::string & instanceName,
const std::string & typeName )
protected

Definition at line 61 of file FunctionSource.hpp.

Member Function Documentation

◆ data()

template<class R , class... Args>
FunctionSourceNode< R, Args... >::function_type * Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::data ( ) const

Get the delivered data.

Returns
The non owning pointer (alias) to the delivered data.

Definition at line 81 of file FunctionSource.hpp.

+ Here is the call graph for this function:

◆ execute()

template<class R , class... Args>
bool Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::execute ( )
overridevirtual

Executes the node.

Execute the node function on the input ports (to be fetched) and write the results to the output ports.

Returns
the execution status.

Implements Ra::Dataflow::Core::Node.

Definition at line 69 of file FunctionSource.hpp.

◆ fromJsonInternal()

template<class R , class... Args>
bool Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::fromJsonInternal ( const nlohmann::json & data)
inlineoverrideprotectedvirtual

Internal json representation of the Node.

Default implementation warn about unsupported deserialization. Effective deserialzation must be implemented by inheriting classes. Be careful with template specialization and function member overriding in derived classes.

Reimplemented from Ra::Dataflow::Core::Node.

Definition at line 45 of file FunctionSource.hpp.

+ Here is the call graph for this function:

◆ node_typename()

template<class R , class... Args>
const std::string & Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::node_typename ( )
static

Definition at line 86 of file FunctionSource.hpp.

◆ set_data()

template<class R , class... Args>
void Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::set_data ( function_type data)

Set the function to be delivered by the node.

Parameters
data

Definition at line 74 of file FunctionSource.hpp.

+ Here is the call graph for this function:

◆ toJsonInternal()

template<class R , class... Args>
void Ra::Dataflow::Core::Sources::FunctionSourceNode< R, Args >::toJsonInternal ( nlohmann::json & data) const
inlineoverrideprotectedvirtual

Internal json representation of the Node.

Default implementation warn about unsupported deserialization. Effective deserialzation must be implemented by inheriting classes. Be careful with template specialization and function member overriding in derived classes.

Reimplemented from Ra::Dataflow::Core::Node.

Definition at line 48 of file FunctionSource.hpp.

+ Here is the call graph for this function:

The documentation for this class was generated from the following file: