GiNaC 1.8.8
|
This class holds an indexed expression. More...
#include <indexed.h>
Public Member Functions | |
indexed (const ex &b) | |
Construct indexed object with no index. | |
indexed (const ex &b, const ex &i1) | |
Construct indexed object with one index. | |
indexed (const ex &b, const ex &i1, const ex &i2) | |
Construct indexed object with two indices. | |
indexed (const ex &b, const ex &i1, const ex &i2, const ex &i3) | |
Construct indexed object with three indices. | |
indexed (const ex &b, const ex &i1, const ex &i2, const ex &i3, const ex &i4) | |
Construct indexed object with four indices. | |
indexed (const ex &b, const symmetry &symm, const ex &i1, const ex &i2) | |
Construct indexed object with two indices and a specified symmetry. | |
indexed (const ex &b, const symmetry &symm, const ex &i1, const ex &i2, const ex &i3) | |
Construct indexed object with three indices and a specified symmetry. | |
indexed (const ex &b, const symmetry &symm, const ex &i1, const ex &i2, const ex &i3, const ex &i4) | |
Construct indexed object with four indices and a specified symmetry. | |
indexed (const ex &b, const exvector &iv) | |
Construct indexed object with a specified vector of indices. | |
indexed (const ex &b, const symmetry &symm, const exvector &iv) | |
Construct indexed object with a specified vector of indices and symmetry. | |
indexed (const symmetry &symm, const exprseq &es) | |
indexed (const symmetry &symm, const exvector &v) | |
indexed (const symmetry &symm, exvector &&v) | |
unsigned | precedence () const override |
Return relative operator precedence (for parenthezing output). | |
bool | info (unsigned inf) const override |
Information about the object. | |
ex | eval () const override |
Perform automatic non-interruptive term rewriting rules. | |
ex | real_part () const override |
ex | imag_part () const override |
exvector | get_free_indices () const override |
Return a vector containing the free indices of an expression. | |
void | archive (archive_node &n) const override |
Save (a.k.a. | |
void | read_archive (const archive_node &n, lst &syms) override |
Read (a.k.a. | |
bool | all_index_values_are (unsigned inf) const |
Check whether all index values have a certain property. | |
exvector | get_indices () const |
Return a vector containing the object's indices. | |
exvector | get_dummy_indices () const |
Return a vector containing the dummy indices of the object, if any. | |
exvector | get_dummy_indices (const indexed &other) const |
Return a vector containing the dummy indices in the contraction with another indexed object. | |
bool | has_dummy_index_for (const ex &i) const |
Check whether the object has an index that forms a dummy index pair with a given index. | |
ex | get_symmetry () const |
Return symmetry properties. | |
Public Member Functions inherited from GiNaC::container< C > | |
container (STLT const &s) | |
container (STLT &&v) | |
container (exvector::const_iterator b, exvector::const_iterator e) | |
container (std::initializer_list< ex > il) | |
size_t | nops () const override |
Number of operands/members. | |
ex | op (size_t i) const override |
Return operand/member at position i. | |
ex & | let_op (size_t i) override |
Return modifiable operand/member at position i. | |
ex | subs (const exmap &m, unsigned options=0) const override |
Substitute a set of objects by arbitrary expressions. | |
container & | prepend (const ex &b) |
Add element at front. | |
container & | append (const ex &b) |
Add element at back. | |
container & | remove_first () |
Remove first element. | |
container & | remove_last () |
Remove last element. | |
container & | remove_all () |
Remove all elements. | |
container & | sort () |
Sort elements. | |
container & | unique () |
Remove adjacent duplicate elements. | |
const_iterator | begin () const |
const_iterator | end () const |
const_reverse_iterator | rbegin () const |
const_reverse_iterator | rend () const |
Public Member Functions inherited from GiNaC::basic | |
virtual | ~basic () |
basic destructor, virtual because class ex will delete objects of derived classes via a basic*. | |
basic (const basic &other) | |
const basic & | operator= (const basic &other) |
basic assignment operator: the other object might be of a derived class. | |
virtual basic * | duplicate () const |
Create a clone of this object on the heap. | |
virtual ex | evalf () const |
Evaluate object numerically. | |
virtual ex | evalm () const |
Evaluate sums, products and integer powers of matrices. | |
virtual ex | eval_integ () const |
Evaluate integrals, if result is known. | |
virtual ex | eval_indexed (const basic &i) const |
Perform automatic symbolic evaluations on indexed expression that contains this object as the base expression. | |
virtual void | print (const print_context &c, unsigned level=0) const |
Output to stream. | |
virtual void | dbgprint () const |
Little wrapper around print to be called within a debugger. | |
virtual void | dbgprinttree () const |
Little wrapper around printtree to be called within a debugger. | |
virtual ex | operator[] (const ex &index) const |
virtual ex | operator[] (size_t i) const |
virtual ex & | operator[] (const ex &index) |
virtual ex & | operator[] (size_t i) |
virtual bool | has (const ex &other, unsigned options=0) const |
Test for occurrence of a pattern. | |
virtual bool | match (const ex &pattern, exmap &repls) const |
Check whether the expression matches a given pattern. | |
virtual ex | map (map_function &f) const |
Construct new expression by applying the specified function to all sub-expressions (one level only, not recursively). | |
virtual void | accept (GiNaC::visitor &v) const |
virtual bool | is_polynomial (const ex &var) const |
Check whether this is a polynomial in the given variables. | |
virtual int | degree (const ex &s) const |
Return degree of highest power in object s. | |
virtual int | ldegree (const ex &s) const |
Return degree of lowest power in object s. | |
virtual ex | coeff (const ex &s, int n=1) const |
Return coefficient of degree n in object s. | |
virtual ex | collect (const ex &s, bool distributed=false) const |
Sort expanded expression in terms of powers of some object(s). | |
virtual ex | series (const relational &r, int order, unsigned options=0) const |
Default implementation of ex::series(). | |
virtual ex | normal (exmap &repl, exmap &rev_lookup, lst &modifier) const |
Default implementation of ex::normal(). | |
virtual ex | to_rational (exmap &repl) const |
Default implementation of ex::to_rational(). | |
virtual ex | to_polynomial (exmap &repl) const |
virtual numeric | integer_content () const |
virtual ex | smod (const numeric &xi) const |
Apply symmetric modular homomorphism to an expanded multivariate polynomial. | |
virtual numeric | max_coefficient () const |
Implementation ex::max_coefficient(). | |
virtual ex | add_indexed (const ex &self, const ex &other) const |
Add two indexed expressions. | |
virtual ex | scalar_mul_indexed (const ex &self, const numeric &other) const |
Multiply an indexed expression with a scalar. | |
virtual bool | contract_with (exvector::iterator self, exvector::iterator other, exvector &v) const |
Try to contract two indexed expressions that appear in the same product. | |
template<class T > | |
void | print_dispatch (const print_context &c, unsigned level) const |
Like print(), but dispatch to the specified class. | |
void | print_dispatch (const registered_class_info &ri, const print_context &c, unsigned level) const |
Like print(), but dispatch to the specified class. | |
ex | subs_one_level (const exmap &m, unsigned options) const |
Helper function for subs(). | |
ex | diff (const symbol &s, unsigned nth=1) const |
Default interface of nth derivative ex::diff(s, n). | |
int | compare (const basic &other) const |
Compare objects syntactically to establish canonical ordering. | |
bool | is_equal (const basic &other) const |
Test for syntactic equality. | |
const basic & | hold () const |
Stop further evaluation. | |
unsigned | gethash () const |
const basic & | setflag (unsigned f) const |
Set some status_flags. | |
const basic & | clearflag (unsigned f) const |
Clear some status_flags. | |
Public Member Functions inherited from GiNaC::refcounted | |
refcounted () noexcept | |
unsigned int | add_reference () noexcept |
unsigned int | remove_reference () noexcept |
unsigned int | get_refcount () const noexcept |
void | set_refcount (unsigned int r) noexcept |
Protected Member Functions | |
ex | derivative (const symbol &s) const override |
Implementation of ex::diff() for an indexed object always returns 0. | |
ex | thiscontainer (const exvector &v) const override |
ex | thiscontainer (exvector &&v) const override |
unsigned | return_type () const override |
return_type_t | return_type_tinfo () const override |
ex | expand (unsigned options=0) const override |
Expand expression, i.e. | |
void | printindices (const print_context &c, unsigned level) const |
void | print_indexed (const print_context &c, const char *openbrace, const char *closebrace, unsigned level) const |
void | do_print (const print_context &c, unsigned level) const |
void | do_print_latex (const print_latex &c, unsigned level) const |
void | do_print_tree (const print_tree &c, unsigned level) const |
void | validate () const |
Check whether all indices are of class idx and validate the symmetry tree. | |
Protected Member Functions inherited from GiNaC::container< C > | |
ex | conjugate () const override |
bool | is_equal_same_type (const basic &other) const override |
Returns true if two objects of same type are equal. | |
virtual ex | thiscontainer (const STLT &v) const |
Similar to duplicate(), but with a preset sequence. | |
virtual ex | thiscontainer (STLT &&v) const |
Similar to duplicate(), but with a preset sequence (which gets pilfered). | |
virtual void | printseq (const print_context &c, char openbracket, char delim, char closebracket, unsigned this_precedence, unsigned upper_precedence=0) const |
Print sequence of contained elements. | |
void | do_print (const print_context &c, unsigned level) const |
void | do_print_tree (const print_tree &c, unsigned level) const |
void | do_print_python (const print_python &c, unsigned level) const |
void | do_print_python_repr (const print_python_repr &c, unsigned level) const |
STLT | subschildren (const exmap &m, unsigned options=0) const |
Protected Member Functions inherited from GiNaC::basic | |
basic () | |
virtual ex | eval_ncmul (const exvector &v) const |
virtual bool | match_same_type (const basic &other) const |
Returns true if the attributes of two objects are similar enough for a match. | |
virtual int | compare_same_type (const basic &other) const |
Returns order relation between two objects of same type. | |
virtual unsigned | calchash () const |
Compute the hash value of an object and if it makes sense to store it in the objects status_flags, do so. | |
void | ensure_if_modifiable () const |
Ensure the object may be modified without hurting others, throws if this is not the case. | |
void | do_print (const print_context &c, unsigned level) const |
Default output to stream. | |
void | do_print_tree (const print_tree &c, unsigned level) const |
Tree output to stream. | |
void | do_print_python_repr (const print_python_repr &c, unsigned level) const |
Python parsable output to stream. | |
Protected Member Functions inherited from GiNaC::container_storage< C > | |
container_storage () | |
container_storage (size_t n, const ex &e) | |
container_storage (std::initializer_list< ex > il) | |
template<class In > | |
container_storage (In b, In e) | |
void | reserve (size_t) |
~container_storage () | |
void | reserve (size_t n) |
void | reserve (std::vector< ex > &v, size_t n) |
Protected Attributes | |
ex | symtree |
Index symmetry (tree of symmetry objects) | |
Protected Attributes inherited from GiNaC::basic | |
unsigned | flags |
of type status_flags | |
unsigned | hashvalue |
hash value | |
Protected Attributes inherited from GiNaC::container_storage< C > | |
STLT | seq |
Friends | |
ex | simplify_indexed (const ex &e, exvector &free_indices, exvector &dummy_indices, const scalar_products &sp) |
Simplify indexed expression, return list of free indices. | |
ex | simplify_indexed_product (const ex &e, exvector &free_indices, exvector &dummy_indices, const scalar_products &sp) |
Simplify product of indexed expressions (commutative, noncommutative and simple squares), return list of free indices. | |
bool | reposition_dummy_indices (ex &e, exvector &variant_dummy_indices, exvector &moved_indices) |
Raise/lower dummy indices in a single indexed objects to canonicalize their variance. | |
Additional Inherited Members | |
Public Types inherited from GiNaC::container< C > | |
typedef STLT::const_iterator | const_iterator |
typedef STLT::const_reverse_iterator | const_reverse_iterator |
Protected Types inherited from GiNaC::container< C > | |
typedef container_storage< C >::STLT | STLT |
Protected Types inherited from GiNaC::container_storage< C > | |
typedef C< ex > | STLT |
Static Protected Member Functions inherited from GiNaC::container< C > | |
static unsigned | get_default_flags () |
Specialization of container::get_default_flags() for lst. | |
static char | get_open_delim () |
Specialization of container::get_open_delim() for lst. | |
static char | get_close_delim () |
Specialization of container::get_close_delim() for lst. | |
Static Protected Member Functions inherited from GiNaC::container_storage< C > | |
static void | reserve (STLT &, size_t) |
This class holds an indexed expression.
It consists of a 'base' expression (the expression being indexed) which can be accessed as op(0), and n (n >= 0) indices (all of class idx), accessible as op(1)..op(n).
GiNaC::indexed::indexed | ( | const ex & | b | ) |
Construct indexed object with no index.
b | Base expression |
Definition at line 65 of file indexed.cpp.
References GiNaC::not_symmetric(), and validate().
Construct indexed object with one index.
The index must be of class idx.
b | Base expression |
i1 | The index |
Definition at line 70 of file indexed.cpp.
References validate().
Construct indexed object with two indices.
The indices must be of class idx.
b | Base expression |
i1 | First index |
i2 | Second index |
Definition at line 75 of file indexed.cpp.
References validate().
Construct indexed object with three indices.
The indices must be of class idx.
b | Base expression |
i1 | First index |
i2 | Second index |
i3 | Third index |
Definition at line 80 of file indexed.cpp.
References validate().
GiNaC::indexed::indexed | ( | const ex & | b, |
const ex & | i1, | ||
const ex & | i2, | ||
const ex & | i3, | ||
const ex & | i4 | ||
) |
Construct indexed object with four indices.
The indices must be of class idx.
b | Base expression |
i1 | First index |
i2 | Second index |
i3 | Third index |
i4 | Fourth index |
Definition at line 85 of file indexed.cpp.
References validate().
Construct indexed object with two indices and a specified symmetry.
The indices must be of class idx.
b | Base expression |
symm | Symmetry of indices |
i1 | First index |
i2 | Second index |
Definition at line 90 of file indexed.cpp.
References validate().
GiNaC::indexed::indexed | ( | const ex & | b, |
const symmetry & | symm, | ||
const ex & | i1, | ||
const ex & | i2, | ||
const ex & | i3 | ||
) |
Construct indexed object with three indices and a specified symmetry.
The indices must be of class idx.
b | Base expression |
symm | Symmetry of indices |
i1 | First index |
i2 | Second index |
i3 | Third index |
Definition at line 95 of file indexed.cpp.
References validate().
GiNaC::indexed::indexed | ( | const ex & | b, |
const symmetry & | symm, | ||
const ex & | i1, | ||
const ex & | i2, | ||
const ex & | i3, | ||
const ex & | i4 | ||
) |
Construct indexed object with four indices and a specified symmetry.
The indices must be of class idx.
b | Base expression |
symm | Symmetry of indices |
i1 | First index |
i2 | Second index |
i3 | Third index |
i4 | Fourth index |
Definition at line 100 of file indexed.cpp.
References validate().
Construct indexed object with a specified vector of indices.
The indices must be of class idx.
b | Base expression |
iv | Vector of indices |
Definition at line 105 of file indexed.cpp.
References GiNaC::container_storage< C >::seq, and validate().
Construct indexed object with a specified vector of indices and symmetry.
The indices must be of class idx.
b | Base expression |
symm | Symmetry of indices |
iv | Vector of indices |
Definition at line 111 of file indexed.cpp.
References GiNaC::container_storage< C >::seq, and validate().
Definition at line 117 of file indexed.cpp.
Definition at line 121 of file indexed.cpp.
Definition at line 125 of file indexed.cpp.
|
inlineoverridevirtual |
Return relative operator precedence (for parenthezing output).
Reimplemented from GiNaC::container< C >.
Definition at line 136 of file indexed.h.
Referenced by print_indexed().
|
overridevirtual |
Information about the object.
Reimplemented from GiNaC::container< C >.
Definition at line 240 of file indexed.cpp.
References GiNaC::info_flags::has_indices, GiNaC::info_flags::indexed, and GiNaC::container_storage< C >::seq.
Referenced by imag_part(), and real_part().
|
overridevirtual |
Perform automatic non-interruptive term rewriting rules.
Reimplemented from GiNaC::basic.
Definition at line 264 of file indexed.cpp.
References GiNaC::_ex0, GiNaC::canonicalize(), GINAC_ASSERT, GiNaC::ex::is_zero(), GiNaC::ex::nops(), GiNaC::ex::op(), GiNaC::container_storage< C >::seq, symtree, and thiscontainer().
|
overridevirtual |
Reimplemented from GiNaC::container< C >.
Definition at line 300 of file indexed.cpp.
References info(), GiNaC::container< C >::op(), and GiNaC::info_flags::real.
|
overridevirtual |
Reimplemented from GiNaC::container< C >.
Definition at line 307 of file indexed.cpp.
References info(), GiNaC::container< C >::op(), and GiNaC::info_flags::real.
|
overridevirtual |
Return a vector containing the free indices of an expression.
Reimplemented from GiNaC::basic.
Definition at line 458 of file indexed.cpp.
References GiNaC::find_free_and_dummy(), and GiNaC::container_storage< C >::seq.
Referenced by get_dummy_indices().
|
overridevirtual |
Save (a.k.a.
serialize) indexed object into archive.
Reimplemented from GiNaC::container< C >.
Definition at line 156 of file indexed.cpp.
|
overridevirtual |
Read (a.k.a.
deserialize) indexed object from archive.
Reimplemented from GiNaC::container< C >.
Definition at line 133 of file indexed.cpp.
References n, GiNaC::not_symmetric(), GiNaC::container_storage< C >::seq, GiNaC::sy_anti(), GiNaC::sy_symm(), GiNaC::symm(), symtree, and validate().
Implementation of ex::diff() for an indexed object always returns 0.
Reimplemented from GiNaC::basic.
Definition at line 389 of file indexed.cpp.
References GiNaC::_ex0.
Definition at line 319 of file indexed.cpp.
References symtree.
|
overrideprotectedvirtual |
Reimplemented from GiNaC::basic.
Definition at line 324 of file indexed.cpp.
References GiNaC::return_types::commutative, GiNaC::container< C >::op(), and GiNaC::ex::return_type().
|
inlineoverrideprotectedvirtual |
Reimplemented from GiNaC::basic.
Definition at line 152 of file indexed.h.
References GiNaC::container< C >::op(), and GiNaC::ex::return_type_tinfo().
|
overrideprotectedvirtual |
Expand expression, i.e.
multiply it out and return the result as a new expression.
Reimplemented from GiNaC::basic.
Definition at line 332 of file indexed.cpp.
References GiNaC::_ex0, GiNaC::are_ex_trivially_equal(), GiNaC::ex::expand(), GiNaC::expand_options::expand_indexed, GINAC_ASSERT, GiNaC::ex::nops(), GiNaC::ex::op(), options, GiNaC::container_storage< C >::seq, and thiscontainer().
bool GiNaC::indexed::all_index_values_are | ( | unsigned | inf | ) | const |
Check whether all index values have a certain property.
Definition at line 247 of file indexed.cpp.
References GiNaC::container_storage< C >::seq.
exvector GiNaC::indexed::get_indices | ( | ) | const |
Return a vector containing the object's indices.
Definition at line 424 of file indexed.cpp.
References GINAC_ASSERT, and GiNaC::container_storage< C >::seq.
exvector GiNaC::indexed::get_dummy_indices | ( | ) | const |
Return a vector containing the dummy indices of the object, if any.
Definition at line 430 of file indexed.cpp.
References GiNaC::find_free_and_dummy(), and GiNaC::container_storage< C >::seq.
Return a vector containing the dummy indices in the contraction with another indexed object.
This is symmetric: a.get_dummy_indices(b) == b.get_dummy_indices(a)
Definition at line 437 of file indexed.cpp.
References GiNaC::find_dummy_indices(), and get_free_indices().
bool GiNaC::indexed::has_dummy_index_for | ( | const ex & | i | ) | const |
Check whether the object has an index that forms a dummy index pair with a given index.
Definition at line 447 of file indexed.cpp.
References GiNaC::is_dummy_pair(), and GiNaC::container_storage< C >::seq.
|
inline |
Return symmetry properties.
Definition at line 180 of file indexed.h.
References symtree.
Referenced by GiNaC::clifford::get_metric().
|
protected |
Definition at line 166 of file indexed.cpp.
References c, and GiNaC::container_storage< C >::seq.
Referenced by GiNaC::clifford::do_print_dflt(), GiNaC::clifford::do_print_tree(), do_print_tree(), and print_indexed().
|
protected |
Definition at line 208 of file indexed.cpp.
References c, precedence(), printindices(), and GiNaC::container_storage< C >::seq.
Referenced by do_print(), and do_print_latex().
|
protected |
Definition at line 220 of file indexed.cpp.
References c, and print_indexed().
|
protected |
Definition at line 225 of file indexed.cpp.
References c, and print_indexed().
|
protected |
Definition at line 230 of file indexed.cpp.
References c, GiNaC::basic::flags, GiNaC::basic::hashvalue, GiNaC::ex::print(), printindices(), GiNaC::container_storage< C >::seq, and symtree.
|
protected |
Check whether all indices are of class idx and validate the symmetry tree.
This function is used internally to make sure that all constructed indexed objects really carry indices and not some other classes.
Definition at line 369 of file indexed.cpp.
References GINAC_ASSERT, GiNaC::ex::is_zero(), GiNaC::container_storage< C >::seq, symtree, and validate().
Referenced by indexed(), indexed(), indexed(), indexed(), indexed(), indexed(), indexed(), indexed(), indexed(), indexed(), read_archive(), and validate().
|
friend |
Simplify indexed expression, return list of free indices.
Definition at line 1045 of file indexed.cpp.
Referenced by GiNaC::clifford::get_metric(), and GiNaC::clifford::same_metric().
|
friend |
Simplify product of indexed expressions (commutative, noncommutative and simple squares), return list of free indices.
Definition at line 780 of file indexed.cpp.
|
friend |
Raise/lower dummy indices in a single indexed objects to canonicalize their variance.
e | Object to work on |
variant_dummy_indices | The set of indices that might need repositioning (will be changed by this function) |
moved_indices | The set of indices that have been repositioned (will be changed by this function) |
Definition at line 619 of file indexed.cpp.
|
protected |
Index symmetry (tree of symmetry objects)
Definition at line 192 of file indexed.h.
Referenced by archive(), GiNaC::clifford::do_print_tree(), do_print_tree(), eval(), get_symmetry(), read_archive(), thiscontainer(), thiscontainer(), and validate().