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

Public Member Functions

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
 
vec_basic get_args () const override
 Returns the list of arguments.
 
 Intersection (const set_set &in)
 
RCP< const Setset_intersection (const RCP< const Set > &o) const override
 
RCP< const Setset_union (const RCP< const Set > &o) const override
 
RCP< const Setset_complement (const RCP< const Set > &o) const override
 
RCP< const Booleancontains (const RCP< const Basic > &a) const override
 
const set_setget_container () const
 
RCP< const Setcreate (const set_set &in) const
 
- Public Member Functions inherited from SymEngine::Set
bool is_subset (const RCP< const Set > &o) const
 
bool is_proper_subset (const RCP< const Set > &o) const
 
bool is_superset (const RCP< const Set > &o) const
 
bool is_proper_superset (const RCP< const Set > &o) 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 Member Functions

static bool is_canonical (const set_set &in)
 
- Static Public Member Functions inherited from SymEngine::Basic
static RCP< const Basicloads (const std::string &)
 Creates an instance of a serialized string.
 

Static Public Attributes

static const TypeID type_code_id = SYMENGINE_INTERSECTION
 

Private Attributes

set_set container_
 

Additional Inherited Members

- Data Fields inherited from SymEngine::Basic
TypeID type_code_
 

Detailed Description

Definition at line 395 of file sets.h.

Constructor & Destructor Documentation

◆ Intersection()

SymEngine::Intersection::Intersection ( const set_set in)

Definition at line 1290 of file sets.cpp.

1291 : container_(in){SYMENGINE_ASSIGN_TYPEID()
1292 SYMENGINE_ASSERT(Intersection::is_canonical(in))}

Member Function Documentation

◆ __eq__()

bool SymEngine::Intersection::__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 1302 of file sets.cpp.

1303{
1304 if (is_a<Intersection>(o)) {
1305 const Intersection &other = down_cast<const Intersection &>(o);
1306 return unified_eq(container_, other.container_);
1307 }
1308 return false;
1309}
void hash_combine(hash_t &seed, const T &v)
Definition basic-inl.h:95

◆ __hash__()

hash_t SymEngine::Intersection::__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 1294 of file sets.cpp.

1295{
1296 hash_t seed = SYMENGINE_INTERSECTION;
1297 for (const auto &a : container_)
1298 hash_combine<Basic>(seed, *a);
1299 return seed;
1300}
Basic()
Constructor.
Definition basic.h:120

◆ accept() [1/2]

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

Implements SymEngine::Basic.

◆ accept() [2/2]

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

Implements SymEngine::Basic.

◆ compare()

int SymEngine::Intersection::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 1318 of file sets.cpp.

1319{
1320 SYMENGINE_ASSERT(is_a<Intersection>(o))
1321 const Intersection &other = down_cast<const Intersection &>(o);
1322 return unified_compare(container_, other.container_);
1323}
int unified_compare(const T &a, const T &b)
Definition dict.h:205

◆ contains()

RCP< const Boolean > SymEngine::Intersection::contains ( const RCP< const Basic > &  a) const
overridevirtual

Implements SymEngine::Set.

Definition at line 1361 of file sets.cpp.

1362{
1363 for (auto &a : container_) {
1364 auto contain = a->contains(o);
1365 if (eq(*contain, *boolTrue)) {
1366 return boolean(true);
1367 }
1368 if (is_a<Contains>(*contain))
1369 throw NotImplementedError("Not implemented");
1370 }
1371 return boolean(false);
1372}
bool eq(const Basic &a, const Basic &b)
Checks equality for a and b
Definition basic-inl.h:21

◆ create()

RCP< const Set > SymEngine::Intersection::create ( const set_set in) const

Definition at line 1374 of file sets.cpp.

1375{
1376 return SymEngine::set_intersection(in);
1377}

◆ get_args()

vec_basic SymEngine::Intersection::get_args ( ) const
overridevirtual

Returns the list of arguments.

Implements SymEngine::Set.

Definition at line 1379 of file sets.cpp.

1380{
1381 vec_basic v(container_.begin(), container_.end());
1382 return v;
1383}
T begin(T... args)
T end(T... args)

◆ get_container()

const set_set & SymEngine::Intersection::get_container ( ) const
inline

Definition at line 414 of file sets.h.

415 {
416 return this->container_;
417 }

◆ is_canonical()

bool SymEngine::Intersection::is_canonical ( const set_set in)
static

Definition at line 1311 of file sets.cpp.

1312{
1313 if (in.size() <= 1)
1314 return false;
1315 return true;
1316}

◆ set_complement()

RCP< const Set > SymEngine::Intersection::set_complement ( const RCP< const Set > &  o) const
overridevirtual

Implements SymEngine::Set.

Definition at line 1352 of file sets.cpp.

1353{
1354 set_set container;
1355 for (auto &a : container_) {
1356 container.insert(a->set_complement(o));
1357 }
1358 return SymEngine::set_intersection(container);
1359}
T insert(T... args)

◆ set_intersection()

RCP< const Set > SymEngine::Intersection::set_intersection ( const RCP< const Set > &  o) const
overridevirtual

Implements SymEngine::Set.

Definition at line 1334 of file sets.cpp.

1335{
1336 set_set container(container_);
1337 for (auto iter = container.begin(); iter != container.end(); ++iter) {
1338 auto temp = o->set_intersection(*iter);
1339 // If we are able to do intersection with `*iter`, we replace `*iter`
1340 // with the result of intersection.
1341 auto un = SymEngine::make_set_intersection({o, *iter});
1342 if (not eq(*temp, *un)) {
1343 iter = container.erase(iter);
1344 container.insert(temp);
1345 return SymEngine::set_intersection(container);
1346 }
1347 }
1348 container.insert(o);
1349 return SymEngine::make_set_intersection(container);
1350}

◆ set_union()

RCP< const Set > SymEngine::Intersection::set_union ( const RCP< const Set > &  o) const
overridevirtual

Implements SymEngine::Set.

Definition at line 1325 of file sets.cpp.

1326{
1327 set_set container;
1328 for (auto &a : container_) {
1329 container.insert(a->set_union(o));
1330 }
1331 return SymEngine::set_intersection(container);
1332}

Field Documentation

◆ container_

set_set SymEngine::Intersection::container_
private

Definition at line 398 of file sets.h.

◆ type_code_id

const TypeID SymEngine::Intersection::type_code_id = SYMENGINE_INTERSECTION
static

Type_code_id shared by all instances

Definition at line 401 of file sets.h.


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