Loading...
Searching...
No Matches
SymEngine::HadamardProduct Class Reference
+ Inheritance diagram for SymEngine::HadamardProduct:
+ Collaboration diagram for SymEngine::HadamardProduct:

Public Member Functions

 HadamardProduct (const vec_basic &factors)
 
void accept (Visitor &v) const override
 
void accept (EvalRealDoubleVisitorFinal &v) const override
 
hash_t __hash__ () const override
 
bool __eq__ (const Basic &o) const override
 Test equality.
 
int compare (const Basic &o) const override
 
bool is_canonical (const vec_basic &factors) const
 
vec_basic get_args () const override
 Returns the list of arguments.
 
const vec_basicget_factors () const
 
- Public Member Functions inherited from SymEngine::Basic
TypeID get_type_code () const
 
 Basic ()
 Constructor.
 
 Basic (const Basic &)=delete
 Delete the copy constructor and assignment.
 
Basicoperator= (const Basic &)=delete
 Assignment operator in continuation with above.
 
 Basic (Basic &&)=delete
 Delete the move constructor and assignment.
 
Basicoperator= (Basic &&)=delete
 Assignment operator in continuation with above.
 
hash_t hash () const
 
bool __neq__ (const Basic &o) const
 true if this is not equal to o.
 
int __cmp__ (const Basic &o) const
 Comparison operator.
 
std::string __str__ () const
 
std::string dumps () const
 Returns a string of the instance serialized.
 
RCP< const Basicsubs (const map_basic_basic &subs_dict) const
 Substitutes 'subs_dict' into 'self'.
 
RCP< const Basicxreplace (const map_basic_basic &subs_dict) const
 
virtual RCP< const Basicexpand_as_exp () const
 expands the special function in terms of exp function
 
RCP< const Basicdiff (const RCP< const Symbol > &x, bool cache=true) const
 
- Public Member Functions inherited from SymEngine::EnableRCPFromThis< Basic >
RCP< Basicrcp_from_this ()
 Get RCP<T> pointer to self (it will cast the pointer to T)
 
RCP< const Basicrcp_from_this () const
 Get RCP<const T> pointer to self (it will cast the pointer to const T)
 
RCP< const T2 > rcp_from_this_cast () const
 Get RCP<T2> pointer to self (it will cast the pointer to T2)
 
unsigned int use_count () const
 

Static Public Attributes

static const TypeID type_code_id = SYMENGINE_HADAMARDPRODUCT
 

Private Attributes

vec_basic factors_
 

Additional Inherited Members

- Static Public Member Functions inherited from SymEngine::Basic
static RCP< const Basicloads (const std::string &)
 Creates an instance of a serialized string.
 
- Data Fields inherited from SymEngine::Basic
TypeID type_code_
 

Detailed Description

Definition at line 10 of file hadamard_product.h.

Constructor & Destructor Documentation

◆ HadamardProduct()

SymEngine::HadamardProduct::HadamardProduct ( const vec_basic factors)
inline

Definition at line 16 of file hadamard_product.h.

16 : factors_(factors)
17 {
18 SYMENGINE_ASSIGN_TYPEID();
19 SYMENGINE_ASSERT(is_canonical(factors));
20 }

Member Function Documentation

◆ __eq__()

bool SymEngine::HadamardProduct::__eq__ ( const Basic o) const
overridevirtual

Test equality.

A virtual function for testing the equality of two Basic objects

Deprecated:
Use eq(const Basic &a, const Basic &b) non-member method
Parameters
oa constant reference to object to test against
Returns
True if this is equal to o

Implements SymEngine::Basic.

Definition at line 22 of file hadamard_product.cpp.

23{
25 const HadamardProduct &other = down_cast<const HadamardProduct &>(o);
26 return unified_eq(factors_, other.factors_);
27 }
28 return false;
29}
void hash_combine(hash_t &seed, const T &v)
Definition basic-inl.h:95

◆ __hash__()

hash_t SymEngine::HadamardProduct::__hash__ ( ) const
overridevirtual

Calculates the hash of the given SymEngine class. Use Basic.hash() which gives a cached version of the hash.

Returns
64-bit integer value for the hash

Implements SymEngine::Basic.

Definition at line 13 of file hadamard_product.cpp.

14{
15 hash_t seed = SYMENGINE_HADAMARDPRODUCT;
16 for (const auto &a : factors_) {
17 hash_combine<Basic>(seed, *a);
18 }
19 return seed;
20}

◆ accept() [1/2]

void SymEngine::HadamardProduct::accept ( EvalRealDoubleVisitorFinal v) const
overridevirtual

Implements SymEngine::Basic.

◆ accept() [2/2]

void SymEngine::HadamardProduct::accept ( Visitor v) const
overridevirtual

Implements SymEngine::Basic.

◆ compare()

int SymEngine::HadamardProduct::compare ( const Basic o) const
overridevirtual

Returns -1, 0, 1 for this < o, this == o, this > o. This method is used when you want to sort things like x+y+z into canonical order. This function assumes that o is the same type as this. Use __cmp__ if you want general comparison.

Implements SymEngine::Basic.

Definition at line 31 of file hadamard_product.cpp.

32{
33 SYMENGINE_ASSERT(is_a<HadamardProduct>(o));
34 const HadamardProduct &other = down_cast<const HadamardProduct &>(o);
35 return unified_compare(factors_, other.factors_);
36}
int unified_compare(const T &a, const T &b)
Definition dict.h:205

◆ get_args()

vec_basic SymEngine::HadamardProduct::get_args ( ) const
inlineoverridevirtual

Returns the list of arguments.

Implements SymEngine::Basic.

Definition at line 27 of file hadamard_product.h.

28 {
29 return vec_basic(factors_.begin(), factors_.end());
30 }
T begin(T... args)
T end(T... args)

◆ get_factors()

const vec_basic & SymEngine::HadamardProduct::get_factors ( ) const
inline

Definition at line 31 of file hadamard_product.h.

32 {
33 return factors_;
34 }

◆ is_canonical()

bool SymEngine::HadamardProduct::is_canonical ( const vec_basic factors) const

Definition at line 38 of file hadamard_product.cpp.

39{
40 if (factors.size() < 2) {
41 return false;
42 }
43 size_t num_diag = 0;
44 size_t num_dense = 0;
45 size_t num_ident = 0;
46 for (auto factor : factors) {
48 return false;
49 } else if (is_a<DiagonalMatrix>(*factor)) {
50 num_diag++;
52 num_dense++;
53 } else if (is_a<IdentityMatrix>(*factor)) {
54 num_ident++;
55 }
56 }
57 if (num_diag > 1 || num_ident > 1 || num_dense > 1) {
58 return false;
59 }
60 if (num_diag == 1 && num_dense == 1) {
61 return false;
62 }
63 return true;
64}
int factor(const Ptr< RCP< const Integer > > &f, const Integer &n, double B1)
Definition ntheory.cpp:370

Field Documentation

◆ factors_

vec_basic SymEngine::HadamardProduct::factors_
private

Definition at line 13 of file hadamard_product.h.

◆ type_code_id

const TypeID SymEngine::HadamardProduct::type_code_id = SYMENGINE_HADAMARDPRODUCT
static

Type_code_id shared by all instances

Definition at line 22 of file hadamard_product.h.


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