All Cadabra functionality can be used directly from C++ programs without using the Python frontend.
A sample program can be found in c++lib/simple.cc:
#include "cadabra2++/Parser.hh"
#include "cadabra2++/Storage.hh"
#include "cadabra2++/DisplayTerminal.hh"
#include "cadabra2++/algorithms/substitute.hh"
#include "cadabra2++/algorithms/evaluate.hh"
#include "cadabra2++/TerminalStream.hh"
#include "cadabra2++/properties/PartialDerivative.hh"
#include "cadabra2++/properties/Coordinate.hh"
#include <iostream>
#include <sstream>
{
ev.apply_generic();
ss << ex << std::endl;
}
{
auto rl = kernel.
ex_from_string(
"F_{m n} = \\partial_{m}{A_{n}} - \\partial_{n}{A_{m}}");
ss << ex << std::endl;
ss << rl << std::endl;
subs.apply_generic();
ss << ex << std::endl;
}
int main(
int argc,
char **argv)
{
}
Definition: Coordinate.hh:8
void inject_property(property *prop, std::shared_ptr< Ex > pattern, std::shared_ptr< Ex > property_arguments)
Inject a property into the system and attach it to the given pattern.
Definition: Kernel.cc:107
std::shared_ptr< Ex > ex_from_string(const std::string &)
Create an Ex expression object from a string, which will be parsed.
Definition: Kernel.cc:122
Definition: PartialDerivative.hh:9
Definition: TerminalStream.hh:8
Definition: evaluate.hh:95
Generic substitution algorithm.
Definition: substitute.hh:14
void test2()
Definition: simple.cc:46
void test1()
Definition: simple.cc:18