Graph Framework
|
Class representing a straight node. More...
#include <node.hpp>
Public Member Functions | |
straight_node (shared_leaf< T, SAFE_MATH > a, const std::string s) | |
Construct a straight node. | |
virtual backend::buffer< T > | evaluate () |
Evaluate method. | |
virtual void | compile_preamble (std::ostringstream &stream, jit::register_map ®isters, jit::visiter_map &visited, jit::register_usage &usage, jit::texture1d_list &textures1d, jit::texture2d_list &textures2d, int &avail_const_mem) |
Compile preamble. | |
virtual shared_leaf< T, SAFE_MATH > | compile (std::ostringstream &stream, jit::register_map ®isters, jit::register_map &indices, const jit::register_usage &usage) |
Compile the node. | |
shared_leaf< T, SAFE_MATH > | get_arg () |
Get the argument. | |
virtual bool | is_all_variables () const |
Test if node acts like a variable. | |
virtual shared_leaf< T, SAFE_MATH > | get_power_exponent () const |
Get the exponent of a power. | |
![]() | |
leaf_node (const std::string s, const size_t count, const bool pseudo) | |
Construct a basic node. | |
virtual | ~leaf_node () |
Destructor. | |
virtual std::shared_ptr< leaf_node > | reduce ()=0 |
Reduction method. | |
virtual std::shared_ptr< leaf_node< T, SAFE_MATH > > | df (std::shared_ptr< leaf_node< T, SAFE_MATH > > x)=0 |
Transform node to derivative. | |
virtual bool | is_match (std::shared_ptr< leaf_node< T, SAFE_MATH > > x) |
Querey if the nodes match. | |
bool | is_power_base_match (std::shared_ptr< leaf_node< T, SAFE_MATH > > x) |
Check if the base of the powers match. | |
virtual void | set (const T d) |
Set the value of variable data. | |
virtual void | set (const size_t index, const T d) |
Set the value of variable data. | |
virtual void | set (const std::vector< T > &d) |
Set the value of variable data. | |
virtual void | set (const backend::buffer< T > &d) |
Set the value of variable data. | |
virtual void | to_latex () const =0 |
Convert the node to latex. | |
virtual std::shared_ptr< leaf_node< T, SAFE_MATH > > | to_vizgraph (std::stringstream &stream, jit::register_map ®isters)=0 |
Convert the node to vizgraph. | |
virtual bool | is_constant () const |
Test if node is a constant. | |
virtual bool | has_constant_zero () const |
Test the constant node has a zero. | |
bool | is_normal () |
Test if the result is normal. | |
virtual bool | is_power_like () const |
Test if the node acts like a power of variable. | |
virtual std::shared_ptr< leaf_node< T, SAFE_MATH > > | get_power_base () |
Get the base of a power. | |
size_t | get_hash () const |
Get the hash for the node. | |
size_t | get_complexity () const |
Get the number of nodes in the subgraph. | |
virtual bool | has_pseudo () const |
Query if the node contains pseudo variables. | |
virtual std::shared_ptr< leaf_node< T, SAFE_MATH > > | remove_pseudo () |
Remove pseudo variable nodes. | |
virtual void | endline (std::ostringstream &stream, const jit::register_usage &usage) const final |
End a line in the kernel source. | |
Protected Attributes | |
shared_leaf< T, SAFE_MATH > | arg |
Argument. | |
![]() | |
const size_t | hash |
Hash for node. | |
const size_t | complexity |
Graph complexity. | |
std::map< size_t, std::shared_ptr< leaf_node< T, SAFE_MATH > > > | df_cache |
Cache derivative terms. | |
const bool | contains_pseudo |
Node contains pseudo variables. | |
Additional Inherited Members | |
![]() | |
typedef T | base |
Type def to retrieve the backend type. | |
![]() | |
static thread_local caches_t | caches |
A per thread instance of the cache structure. | |
Class representing a straight node.
T | Base type of the calculation. |
SAFE_MATH | Use Safe Math operations. |
This ensures that the base leaf type has the common type between the two template arguments.
|
inline |
Construct a straight node.
[in] | a | Argument. |
[in] | s | Node string to hash. |
|
inlinevirtual |
Compile the node.
[in,out] | stream | String buffer stream. |
[in,out] | registers | List of defined registers. |
[in,out] | indices | List of defined indices. |
[in] | usage | List of register usage count. |
Implements graph::leaf_node< T, SAFE_MATH >.
Reimplemented in graph::sqrt_node< T, SAFE_MATH >, graph::exp_node< T, SAFE_MATH >, graph::log_node< T, SAFE_MATH >, graph::erfi_node< T, SAFE_MATH >, graph::piecewise_1D_node< T, SAFE_MATH >, graph::random_node< T, SAFE_MATH >, graph::sine_node< T, SAFE_MATH >, and graph::cosine_node< T, SAFE_MATH >.
|
inlinevirtual |
Compile preamble.
[in,out] | stream | String buffer stream. |
[in,out] | registers | List of defined registers. |
[in,out] | visited | List of visited nodes. |
[in,out] | usage | List of register usage count. |
[in,out] | textures1d | List of 1D textures. |
[in,out] | textures2d | List of 2D textures. |
[in,out] | avail_const_mem | Available constant memory. |
Reimplemented from graph::leaf_node< T, SAFE_MATH >.
Reimplemented in graph::piecewise_1D_node< T, SAFE_MATH >, and graph::random_node< T, SAFE_MATH >.
|
inlinevirtual |
Evaluate method.
Implements graph::leaf_node< T, SAFE_MATH >.
Reimplemented in graph::sqrt_node< T, SAFE_MATH >, graph::exp_node< T, SAFE_MATH >, graph::log_node< T, SAFE_MATH >, graph::erfi_node< T, SAFE_MATH >, graph::piecewise_1D_node< T, SAFE_MATH >, graph::random_node< T, SAFE_MATH >, graph::sine_node< T, SAFE_MATH >, and graph::cosine_node< T, SAFE_MATH >.
|
inlinevirtual |
Get the exponent of a power.
Implements graph::leaf_node< T, SAFE_MATH >.
Reimplemented in graph::sqrt_node< T, SAFE_MATH >, graph::pseudo_variable_node< T, SAFE_MATH >, graph::piecewise_1D_node< T, SAFE_MATH >, and graph::random_node< T, SAFE_MATH >.
|
inlinevirtual |
Test if node acts like a variable.
Implements graph::leaf_node< T, SAFE_MATH >.
Reimplemented in graph::pseudo_variable_node< T, SAFE_MATH >, graph::piecewise_1D_node< T, SAFE_MATH >, and graph::random_node< T, SAFE_MATH >.