38#include "../../traits/tapeTraits.hpp"
39#include "commonReaderWriterBase.hpp"
59 template<
typename T_Type>
64 using Tape =
typename Type::Tape;
66 using Real =
typename Type::Real;
72 std::vector<Identifier>
const& out,
bool ifJacobians)
93 for (
size_t argCount = 0; argCount < nJacobians; argCount++) {
94 std::string labelText =
"";
96 labelText = std::to_string(rhsJacobians[curJacobianPos + argCount]);
98 Base::createEdge(rhsIdentifiers[curJacobianPos + argCount], curLhsIdentifier, labelText);
123 template<
typename T_Type>
128 using Tape =
typename Type::Tape;
130 using Real =
typename Type::Real;
135 std::vector<Identifier>
const& out)
136 :
Base(true, name, in, out) {};
147 Identifier const*
const rhsIdentifiers,
size_t const& curPassiveValuePos,
148 Real const*
const passiveValues,
size_t& curConstantPos,
Real const*
const constantValues,
150 CODI_UNUSED(primalValue, curPassiveValuePos, passiveValues, curConstantPos, constantValues, stmtEvalHandle);
161 std::string mathRep =
170 Base::createEdge(rhsIdentifiers[curRhsIdentifiersPos + argCount], curLhsIdentifier);
#define CODI_Unlikely
Declare unlikely evaluation of an execution path.
Definition config.h:399
#define CODI_Likely
Declare likely evaluation of an execution path.
Definition config.h:397
#define CODI_DD(Type, Default)
Abbreviation for CODI_DECLARE_DEFAULT.
Definition macros.hpp:94
uint8_t ArgumentSize
Type for the number of arguments in statements.
Definition config.h:117
size_t constexpr StatementInputTag
Tag for statements that are inputs. Used in linear index management context.
Definition config.h:123
CoDiPack - Code Differentiation Package.
Definition codi.hpp:91
void CODI_UNUSED(Args const &...)
Disable unused warnings for an arbitrary number of arguments.
Definition macros.hpp:46
This base class is used to modify the math representation of a statement.
Definition commonReaderWriterBase.hpp:231
std::vector< Identifier > identifierExtensions
Definition commonReaderWriterBase.hpp:243
std::string formatNodeLabel(Identifier const &identifier)
Return a string with the current identifier type and the identifier value.
Definition commonReaderWriterBase.hpp:316
void createNode(Identifier const &identifier, std::string const &label)
Creates a new node for a given Identifier and label.
Definition commonReaderWriterBase.hpp:309
void createEdge(Identifier const &from, Identifier const &to, std::string const &label="")
Return a string that creates an edge between two nodes in the .dot language.
Definition commonReaderWriterBase.hpp:372
std::string modifyMathRep(std::string const &mathRep, Identifier const &lhsIdentifier, Identifier const *const rhsIdentifiers, size_t const &nActiveValues)
Replaces all general identifiers in the math representation with the input, output or temporary annot...
Definition commonReaderWriterBase.hpp:344
void placeUnusedRhsNodes(Identifier const *const rhsIdentifiers, Config::ArgumentSize const &nArguments)
Ensure that all the nodes on the rhs have been placed in the .dot file before creating edges to them.
Definition commonReaderWriterBase.hpp:359
Generates a graphical .dot file for a Jacobian tape.
Definition graphWriters.hpp:60
void writeStatement(Identifier const &curLhsIdentifier, size_t &curJacobianPos, Real const *const rhsJacobians, Identifier const *const rhsIdentifiers, Config::ArgumentSize const &nJacobians)
Called for each statement. The method writes the current statement to the file. This overload is used...
Definition graphWriters.hpp:79
typename Type::Real Real
See TapeWriterInterface.
Definition graphWriters.hpp:66
typename Type::Tape Tape
See TapeWriterInterface.
Definition graphWriters.hpp:64
JacobianGraphTapeWriter(std::string const &name, std::vector< Identifier > const &in, std::vector< Identifier > const &out, bool ifJacobians)
Constructor.
Definition graphWriters.hpp:71
T_Type Type
See TapeWriterInterface.
Definition graphWriters.hpp:61
bool printJacobians
Flag that enables the jacobians on the edges in the graph.
Definition graphWriters.hpp:68
typename Type::Identifier Identifier
See TapeWriterInterface.
Definition graphWriters.hpp:65
Generates a graphical .dot file for a primal value tape. The writer adds the math representation of s...
Definition graphWriters.hpp:124
typename Type::Tape Tape
See TapeWriterInterface.
Definition graphWriters.hpp:128
T_Type Type
See TapeWriterInterface.
Definition graphWriters.hpp:125
typename Type::Identifier Identifier
See TapeWriterInterface.
Definition graphWriters.hpp:129
void writeStatement(WriteInfo const &info, Identifier const &curLhsIdentifier, Real const &primalValue, Config::ArgumentSize const &nPassiveValues, size_t const &curRhsIdentifiersPos, Identifier const *const rhsIdentifiers, size_t const &curPassiveValuePos, Real const *const passiveValues, size_t &curConstantPos, Real const *const constantValues, EvalHandle stmtEvalHandle)
Called for each statement. The method writes the current statement to the file. This overload is used...
Definition graphWriters.hpp:145
typename Tape::EvalHandle EvalHandle
See TapeWriterInterface.
Definition graphWriters.hpp:131
PrimalGraphTapeWriter(std::string const &name, std::vector< Identifier > const &in, std::vector< Identifier > const &out)
Constructor.
Definition graphWriters.hpp:134
typename Type::Real Real
See TapeWriterInterface.
Definition graphWriters.hpp:130
This class is used during the writing process of a primal value tape. The WriteInfo is returned by co...
Definition tapeReaderWriterInterface.hpp:69
size_t numberOfActiveArguments
Number of active arguments.
Definition tapeReaderWriterInterface.hpp:70
std::string mathRepresentation
Definition tapeReaderWriterInterface.hpp:73