#include <topology.hh>
Public Member Functions | |
Quad (Edge &edg0, Edge &edg1, Edge &edg2, Edge &edg3, const Attribute attrib=Attribute()) | |
Quad (const Quad &quad, uint i) | |
virtual | ~Quad () |
Destructor. | |
virtual Quad * | child (uint i, bool mode=0) |
virtual const Quad * | child (uint i) const |
Edge * | edge (uint i) const |
Vertex * | vertex (uint i) const |
int | numVertices () const |
int | numEdges () const |
Z2 | rho (int i) const |
bool | regular () const |
Quad * | clone (Edge &edg0, Edge &edg1, Edge &edg2, Edge &edg3) const |
void | setStrategy (const QuadSubdivision *strategy=0) |
const QuadSubdivision * | getStrategy () const |
int | operator== (const Connector &cntr) const |
Comparison operator. | |
const Key & | key () const |
Returns the key of the connector. | |
const Attribute & | attrib () const |
Returns the attribute of the connector. | |
void | setAttrib (uint attrb) |
int | related (const Connector &conn) const |
Protected Member Functions | |
virtual std::ostream & | info (std::ostream &os) const |
Returns information in an output stream. | |
Quad (Edge &edg0, Edge &edg1, Edge &edg2, Edge &edg3, const Attribute attrib, const Key &key, const Z2 rho[]) | |
Constructor used by clone() | |
Scan< Quad > * | children_ () const |
Scanner over the children. | |
void | edgeAssertion_ () const |
Assert, that the vertices of the four edges match properly. | |
Protected Attributes | |
concepts::Joiner< Quad *, 1 > * | chld_ |
List of Pointers to the children. | |
bool | regular_ |
Regular Cell, deleting of children possible. | |
Edge * | edg_ [4] |
Array of the edges. | |
Z2 | rho_ [4] |
Array of the orientation flags for the edges. | |
const QuadSubdivision * | subdivStrategy_ |
Subdivision strategy for the quadrilateral. | |
Key | key_ |
Unique key of the connector. | |
Attribute | attrib_ |
Attribute. | |
Static Protected Attributes | |
static std::map< Key, Z2 > | rhoTriv_ |
orientation of trivial edges (with idential vertices) | |
static uint | cnt_ |
Friends | |
class | QuadSubdiv4 |
class | QuadSubdiv2H |
class | QuadSubdiv2V |
A quadrilateral in the topology. Implements the abstract methods from the parent classes to query the children, the vertices and the edges of the quadrilateral.
Every edge can have two different orientations in the quadrilateral, this orientation is stored in the array rho.
Definition at line 272 of file topology.hh.
concepts::Quad::Quad | ( | Edge & | edg0, |
Edge & | edg1, | ||
Edge & | edg2, | ||
Edge & | edg3, | ||
const Attribute | attrib = Attribute() |
||
) |
Constructor. Creates a quadrilateral out of four edges. The edges must form a quadrilateral: the 1st and the 2nd edge, the 2nd and the 3rd edge, the 3rd and the 4th edge and the 4th and the 1st edge must have a common vertex. The edges can have an arbitrary orientation. The orientation is detected and stored in rho_.
edg0 | 1st edge. |
edg1 | 2nd edge. |
edg2 | 3rd edge. |
edg3 | 4th edge. |
attrib | Attribute of the edge |
Creating of intermediate cells through coalescing of two of the four childs (only for subdivision in four quadrilaterials)
New cell is not regular, children are not deleted in its destructor
|
inlineinherited |
Returns the attribute of the connector.
Definition at line 108 of file connector.hh.
Implements concepts::Connector2.
Returns a child.
If children are created, four new children are created (with the same attributes as this one). All edges of the quadrilateral are refined and four new edges introduced.
i | Index of the child to be returned. |
mode | mode = 1: No children are created mode = 0: If no childs exist, four new children are created. setStrategy() is called before creating the children. |
Implements concepts::Connector2.
Scanner over the children.
Definition at line 388 of file topology.hh.
Returns the pointer of a new Quad with the same attribute, the same key and the same rho but NO children and sibling
Definition at line 396 of file topology.hh.
Returns a 1D component: edge. A 2D element consists of 1D and 0D elements, the edges can be queried here.
i | Index of the edge |
Implements concepts::Connector2.
Definition at line 316 of file topology.hh.
|
inline |
Returns the subdivision strategy of this quad.
If you want to find check against another strategy use
quad.getStrategy() == QuadSubdiv2V::instance()
Definition at line 361 of file topology.hh.
|
protectedvirtual |
Returns information in an output stream.
Reimplemented from concepts::Connector.
|
inlineinherited |
Returns the key of the connector.
Definition at line 105 of file connector.hh.
|
inline |
Definition at line 323 of file topology.hh.
|
inline |
Definition at line 319 of file topology.hh.
Comparison operator.
Definition at line 102 of file connector.hh.
|
inline |
Definition at line 336 of file topology.hh.
Checks if this connector is related to conn
. It is being checked if one of the two is an ancestor of the other.
conn | Other connector |
conn
is an ancestor of this connectorconn
is a descendant of this connectorReturns the orientation of an edge.
rho = 0 : Edge is oriented counter-clockwise in the quadrilateral. rho = 1 : Edge is oriented clockwise in the quadrilateral.
i | Index of the edge. |
Definition at line 334 of file topology.hh.
Definition at line 111 of file connector.hh.
void concepts::Quad::setStrategy | ( | const QuadSubdivision * | strategy = 0 | ) |
Sets the subdivision strategy of this quad.
If the parameter is set to 0 (or if the method is called without parameter) the strategy is set to the default (if not already set). The default subdivision strategy is subdivision into 4 children.
strategy | Pointer to an instance of a subdivision strategy. |
StrategyChange | if the change is not allowed (the change is not allowed if there are children present) |
Returns a 0D component: vertex A 2D element consists of 1D and 0D elements, the vertices can be queried here.
i | Index of the vertex |
Implements concepts::Connector2.
Definition at line 317 of file topology.hh.
|
friend |
Definition at line 274 of file topology.hh.
|
friend |
Definition at line 275 of file topology.hh.
|
friend |
Definition at line 273 of file topology.hh.
|
protectedinherited |
Definition at line 132 of file connector.hh.
|
protected |
List of Pointers to the children.
Definition at line 370 of file topology.hh.
|
staticprotectedinherited |
Counter for the connectors. This counter is used to create the unique key of the connector.
Definition at line 263 of file connector.hh.
|
protected |
Array of the edges.
Definition at line 376 of file topology.hh.
|
protectedinherited |
Unique key of the connector.
Definition at line 129 of file connector.hh.
|
protected |
Regular Cell, deleting of children possible.
Definition at line 373 of file topology.hh.
|
protected |
Array of the orientation flags for the edges.
Definition at line 379 of file topology.hh.
orientation of trivial edges (with idential vertices)
Definition at line 382 of file topology.hh.
|
protected |
Subdivision strategy for the quadrilateral.
Definition at line 385 of file topology.hh.