|  | ATLAS Offline Software
    | 
 
 
 
#include <SbPolyhedron.h>
|  | 
|  | SbPolyhedronSphere (double rmin, double rmax, double phi, double dphi, double the, double dthe) | 
|  | 
| virtual | ~SbPolyhedronSphere () | 
|  | 
| virtual SbPolyhedron & | operator= (const SbPolyhedron &from) | 
|  | 
| int | GetNoVertices () const | 
|  | 
| int | GetNoFacets () const | 
|  | 
| SbPolyhedron & | Transform (const HEPVis::SbRotation &rot, const SbVec3d &trans) | 
|  | 
| bool | GetNextVertexIndex (int &index, int &edgeFlag) const | 
|  | 
| HVPoint3D | GetVertex (int index) const | 
|  | 
| const HVPoint3D & | GetVertexFast (int index) const | 
|  | 
| bool | GetNextVertex (HVPoint3D &vertex, int &edgeFlag) const | 
|  | 
| bool | GetNextVertex (HVPoint3D &vertex, int &edgeFlag, HVNormal3D &normal) const | 
|  | 
| bool | GetNextEdgeIndeces (int &i1, int &i2, int &edgeFlag, int &iface1, int &iface2) const | 
|  | 
| bool | GetNextEdgeIndeces (int &i1, int &i2, int &edgeFlag) const | 
|  | 
| bool | GetNextEdge (HVPoint3D &p1, HVPoint3D &p2, int &edgeFlag) const | 
|  | 
| bool | GetNextEdge (HVPoint3D &p1, HVPoint3D &p2, int &edgeFlag, int &iface1, int &iface2) const | 
|  | 
| void | GetFacet (int iFace, int &n, int *iNodes, int *edgeFlags=0, int *iFaces=0) const | 
|  | 
| void | GetFacet (int iFace, int &n, HVPoint3D *nodes, int *edgeFlags=0, HVNormal3D *normals=0) const | 
|  | 
| bool | GetNextFacet (int &n, HVPoint3D *nodes, int *edgeFlags=0, HVNormal3D *normals=0) const | 
|  | 
| HVNormal3D | GetNormal (int iFace) const | 
|  | 
| HVNormal3D | GetUnitNormal (int iFace) const | 
|  | 
| bool | GetNextNormal (HVNormal3D &normal) const | 
|  | 
| bool | GetNextUnitNormal (HVNormal3D &normal) const | 
|  | 
| SbPolyhedron | add (const SbPolyhedron &p) const | 
|  | 
| SbPolyhedron | subtract (const SbPolyhedron &p) const | 
|  | 
| SbPolyhedron | intersect (const SbPolyhedron &p) const | 
|  | 
| double | GetSurfaceArea () const | 
|  | 
| double | GetVolume () const | 
|  | 
|  | 
| void | AllocateMemory (int Nvert, int Nface) | 
|  | 
| int | FindNeighbour (int iFace, int iNode, int iOrder) const | 
|  | 
| HVNormal3D | FindNodeNormal (int iFace, int iNode) const | 
|  | 
| void | CreatePrism () | 
|  | 
| void | RotateEdge (int k1, int k2, double r1, double r2, int v1, int v2, int vEdge, bool ifWholeCircle, int ns, int &kface) | 
|  | 
| void | SetSideFacets (int ii[4], int vv[4], int *kk, double *r, double dphi, int ns, int &kface) | 
|  | 
| void | RotateAroundZ (int nstep, double phi, double dphi, int np1, int np2, const double *z, double *r, int nodeVis, int edgeVis) | 
|  | 
| void | SetReferences () | 
|  | 
| void | InvertFacets () | 
|  | 
Definition at line 512 of file SbPolyhedron.h.
 
◆ SbPolyhedronSphere()
      
        
          | SbPolyhedronSphere::SbPolyhedronSphere | ( | double | rmin, | 
        
          |  |  | double | rmax, | 
        
          |  |  | double | phi, | 
        
          |  |  | double | dphi, | 
        
          |  |  | double | the, | 
        
          |  |  | double | dthe | 
        
          |  | ) |  |  | 
      
 
Definition at line 1649 of file SbPolyhedron.cxx.
 1670   if (dphi <= 0. || dphi > 2*
M_PI) {
 
 1672       << 
"SbPolyhedronSphere: wrong delta phi = " << dphi
 
 1677   if (the < 0. || the > 
M_PI) {
 
 1679       << 
"SbPolyhedronSphere: wrong theta = " << the
 
 1684   if (dthe <= 0. || dthe > 
M_PI) {
 
 1686       << 
"SbPolyhedronSphere: wrong delta theta = " << dthe
 
 1691   if ( (the+dthe >= 
M_PI) && (the+dthe < 
M_PI + 2*DBL_EPSILON) )
 
 1694   if (the+dthe > 
M_PI) {
 
 1696       << 
"SbPolyhedronSphere: wrong theta + delta theta = " 
 1697       << the << 
" " << dthe
 
 1702   if (rmin < 0. || rmin >= rmax) {
 
 1704       << 
"SbPolyhedronSphere: error in radiuses" 
 1705       << 
" rmin=" << rmin << 
" rmax=" << rmax
 
 1714   if (np1 <= 1) np1 = 2;
 
 1718   zz = 
new double[np1+np2];
 
 1719   rr = 
new double[np1+np2];
 
 1721   double a = dthe/(np1-1);
 
 1723   for (
int i=0; 
i<np1; 
i++) {
 
 1724     cosa  = 
cos(the+
i*
a);
 
 1725     sina  = 
sin(the+
i*
a);
 
 1729       zz[
i+np1] = rmin*cosa;
 
 1730       rr[
i+np1] = rmin*sina;
 
 
 
 
◆ ~SbPolyhedronSphere()
  
  | 
        
          | SbPolyhedronSphere::~SbPolyhedronSphere | ( |  | ) |  |  | virtual | 
 
 
◆ add()
◆ AllocateMemory()
  
  | 
        
          | void SbPolyhedron::AllocateMemory | ( | int | Nvert, |  
          |  |  | int | Nface |  
          |  | ) |  |  |  | protectedinherited | 
 
 
◆ CreatePrism()
  
  | 
        
          | void SbPolyhedron::CreatePrism | ( |  | ) |  |  | protectedinherited | 
 
Definition at line 286 of file SbPolyhedron.cxx.
  299   m_pF[2] = 
SbFacet(5,TOP,   8,BACK,  4,BOTTOM, 1,FRONT);
 
  301   m_pF[4] = 
SbFacet(7,TOP,   6,FRONT, 2,BOTTOM, 3,BACK);
 
 
 
 
◆ FindNeighbour()
  
  | 
        
          | int SbPolyhedron::FindNeighbour | ( | int | iFace, |  
          |  |  | int | iNode, |  
          |  |  | int | iOrder |  
          |  | ) |  | const |  | protectedinherited | 
 
Definition at line 189 of file SbPolyhedron.cxx.
  200   for (
i=0; 
i<4; 
i++) {
 
  201     if (iNode == 
iabs(
m_pF[iFace].m_edge[
i].
v)) 
break;
 
  205       << 
"SbPolyhedron::FindNeighbour: face " << iFace
 
  206       << 
" has no node " << iNode
 
  212     if (
m_pF[iFace].m_edge[
i].
v == 0) 
i = 2;
 
 
 
 
◆ FindNodeNormal()
  
  | 
        
          | HVNormal3D SbPolyhedron::FindNodeNormal | ( | int | iFace, |  
          |  |  | int | iNode |  
          |  | ) |  | const |  | protectedinherited | 
 
Definition at line 217 of file SbPolyhedron.cxx.
  228   int          k = iFace, iOrder = 1;
 
  232     if (
k == iFace) 
break;
 
  236       if (iOrder < 0) 
break;
 
 
 
 
◆ GetFacet() [1/2]
  
  | 
        
          | void SbPolyhedron::GetFacet | ( | int | iFace, |  
          |  |  | int & | n, |  
          |  |  | HVPoint3D * | nodes, |  
          |  |  | int * | edgeFlags = 0, |  
          |  |  | HVNormal3D * | normals = 0 |  
          |  | ) |  | const |  | inherited | 
 
 
◆ GetFacet() [2/2]
  
  | 
        
          | void SbPolyhedron::GetFacet | ( | int | iFace, |  
          |  |  | int & | n, |  
          |  |  | int * | iNodes, |  
          |  |  | int * | edgeFlags = 0, |  
          |  |  | int * | iFaces = 0 |  
          |  | ) |  | const |  | inherited | 
 
Definition at line 1117 of file SbPolyhedron.cxx.
 1128   if (iFace < 1 || iFace > 
m_nface) {
 
 1130       << 
"SbPolyhedron::GetFacet: irrelevant index " << iFace
 
 1135     for (
i=0; 
i<4; 
i++) {
 
 1141         if (edgeFlags != 0) edgeFlags[
i] = 1;
 
 1144         if (edgeFlags != 0) edgeFlags[
i] = -1;
 
 
 
 
◆ GetNextEdge() [1/2]
◆ GetNextEdge() [2/2]
  
  | 
        
          | bool SbPolyhedron::GetNextEdge | ( | HVPoint3D & | p1, |  
          |  |  | HVPoint3D & | p2, |  
          |  |  | int & | edgeFlag, |  
          |  |  | int & | iface1, |  
          |  |  | int & | iface2 |  
          |  | ) |  | const |  | inherited | 
 
 
◆ GetNextEdgeIndeces() [1/2]
  
  | 
        
          | bool SbPolyhedron::GetNextEdgeIndeces | ( | int & | i1, |  
          |  |  | int & | i2, |  
          |  |  | int & | edgeFlag |  
          |  | ) |  | const |  | inherited | 
 
 
◆ GetNextEdgeIndeces() [2/2]
  
  | 
        
          | bool SbPolyhedron::GetNextEdgeIndeces | ( | int & | i1, |  
          |  |  | int & | i2, |  
          |  |  | int & | edgeFlag, |  
          |  |  | int & | iface1, |  
          |  |  | int & | iface2 |  
          |  | ) |  | const |  | inherited | 
 
Definition at line 1007 of file SbPolyhedron.cxx.
 1020   static int iFace    = 1;
 
 1021   static int iQVertex = 0;
 
 1022   static int iOrder   = 1;
 
 1023   int  k1, k2, kflag, kface1, kface2;
 
 1025   if (iFace == 1 && iQVertex == 0) {
 
 1029     if (
iabs(k1) > 
iabs(k2)) iOrder = -1;
 
 1038     if (iQVertex >= 3 || 
m_pF[iFace].m_edge[iQVertex+1].
v == 0) {
 
 1040       k2 = 
iabs(
m_pF[iFace].m_edge[iQVertex].
v);
 
 1044       k2 = 
iabs(
m_pF[iFace].m_edge[iQVertex].
v);
 
 1046   } 
while (iOrder*k1 > iOrder*k2);
 
 1048   i1 = k1; i2 = k2; edgeFlag = (kflag > 0) ? 1 : 0;
 
 1049   iface1 = kface1; iface2 = kface2;
 
 1052     iFace  = 1; iOrder = 1;
 
 
 
 
◆ GetNextFacet()
  
  | 
        
          | bool SbPolyhedron::GetNextFacet | ( | int & | n, |  
          |  |  | HVPoint3D * | nodes, |  
          |  |  | int * | edgeFlags = 0, |  
          |  |  | HVNormal3D * | normals = 0 |  
          |  | ) |  | const |  | inherited | 
 
Definition at line 1173 of file SbPolyhedron.cxx.
 1185   static int iFace = 1;
 
 1187   if (edgeFlags == 0) {
 
 1189   }
else if (normals == 0) {
 
 1192     GetFacet(iFace, 
n, nodes, edgeFlags, normals);
 
 
 
 
◆ GetNextNormal()
  
  | 
        
          | bool SbPolyhedron::GetNextNormal | ( | HVNormal3D & | normal | ) | const |  | inherited | 
 
 
◆ GetNextUnitNormal()
  
  | 
        
          | bool SbPolyhedron::GetNextUnitNormal | ( | HVNormal3D & | normal | ) | const |  | inherited | 
 
 
◆ GetNextVertex() [1/2]
  
  | 
        
          | bool SbPolyhedron::GetNextVertex | ( | HVPoint3D & | vertex, |  
          |  |  | int & | edgeFlag |  
          |  | ) |  | const |  | inherited | 
 
 
◆ GetNextVertex() [2/2]
  
  | 
        
          | bool SbPolyhedron::GetNextVertex | ( | HVPoint3D & | vertex, |  
          |  |  | int & | edgeFlag, |  
          |  |  | HVNormal3D & | normal |  
          |  | ) |  | const |  | inherited | 
 
Definition at line 975 of file SbPolyhedron.cxx.
  988   static int iFace = 1;
 
  989   static int iNode = 0;
 
  991   if (
m_nface == 0) 
return false;  
 
  994   if (
k > 0) { edgeFlag = 1; } 
else { edgeFlag = -1; 
k = -
k; }
 
  997   if (iNode >= 3 || 
m_pF[iFace].m_edge[iNode+1].
v == 0) {
 
  999     if (++iFace > 
m_nface) iFace = 1;
 
 
 
 
◆ GetNextVertexIndex()
  
  | 
        
          | bool SbPolyhedron::GetNextVertexIndex | ( | int & | index, |  
          |  |  | int & | edgeFlag |  
          |  | ) |  | const |  | inherited | 
 
Definition at line 902 of file SbPolyhedron.cxx.
  912   static int iFace = 1;
 
  913   static int iQVertex = 0;
 
  916   edgeFlag = (vIndex > 0) ? 1 : 0;
 
  919   if (iQVertex >= 3 || 
m_pF[iFace].m_edge[iQVertex+1].
v == 0) {
 
  921     if (++iFace > 
m_nface) iFace = 1;
 
 
 
 
◆ GetNoFacets()
  
  | 
        
          | int SbPolyhedron::GetNoFacets | ( |  | ) | const |  | inlineinherited | 
 
 
◆ GetNormal()
  
  | 
        
          | HVNormal3D SbPolyhedron::GetNormal | ( | int | iFace | ) | const |  | inherited | 
 
Definition at line 1203 of file SbPolyhedron.cxx.
 1213   if (iFace < 1 || iFace > 
m_nface) {
 
 1215       << 
"SbPolyhedron::GetNormal: irrelevant index " << iFace
 
 1224   if (i3 == 0) i3 = i0;
 
 
 
 
◆ GetNoVertices()
  
  | 
        
          | int SbPolyhedron::GetNoVertices | ( |  | ) | const |  | inlineinherited | 
 
 
◆ GetNumberOfRotationSteps()
  
  | 
        
          | static int SbPolyhedron::GetNumberOfRotationSteps | ( |  | ) |  |  | inlinestaticinherited | 
 
 
◆ GetSurfaceArea()
  
  | 
        
          | double SbPolyhedron::GetSurfaceArea | ( |  | ) | const |  | inherited | 
 
 
◆ GetUnitNormal()
  
  | 
        
          | HVNormal3D SbPolyhedron::GetUnitNormal | ( | int | iFace | ) | const |  | inherited | 
 
Definition at line 1228 of file SbPolyhedron.cxx.
 1238   if (iFace < 1 || iFace > 
m_nface) {
 
 1240       << 
"SbPolyhedron::GetUnitNormal: irrelevant index " << iFace
 
 1249   if (i3 == 0) i3 = i0;
 
 
 
 
◆ GetVertex()
  
  | 
        
          | HVPoint3D SbPolyhedron::GetVertex | ( | int | index | ) | const |  | inherited | 
 
 
◆ GetVertexFast()
◆ GetVolume()
  
  | 
        
          | double SbPolyhedron::GetVolume | ( |  | ) | const |  | inherited | 
 
 
◆ intersect()
◆ InvertFacets()
  
  | 
        
          | void SbPolyhedron::InvertFacets | ( |  | ) |  |  | protectedinherited | 
 
 
◆ operator=()
◆ ResetNumberOfRotationSteps()
  
  | 
        
          | static void SbPolyhedron::ResetNumberOfRotationSteps | ( |  | ) |  |  | inlinestaticinherited | 
 
 
◆ RotateAroundZ()
  
  | 
        
          | void SbPolyhedron::RotateAroundZ | ( | int | nstep, |  
          |  |  | double | phi, |  
          |  |  | double | dphi, |  
          |  |  | int | np1, |  
          |  |  | int | np2, |  
          |  |  | const double * | z, |  
          |  |  | double * | r, |  
          |  |  | int | nodeVis, |  
          |  |  | int | edgeVis |  
          |  | ) |  |  |  | protectedinherited | 
 
Definition at line 438 of file SbPolyhedron.cxx.
  464   static double wholeCircle   = 2*
M_PI;
 
  468   bool ifWholeCircle = (fabs(dphi-wholeCircle) < 
perMillion) ?
 
  470   double   delPhi  = ifWholeCircle ? wholeCircle : dphi;
 
  471   int        nSphi    = (nstep > 0) ?
 
  473   if (nSphi == 0) nSphi = 1;
 
  474   int        nVphi    = ifWholeCircle ? nSphi : nSphi+1;
 
  475   bool ifClosed = np1 > 0 ? false : 
true;
 
  479   int absNp1 = 
iabs(np1);
 
  480   int absNp2 = 
iabs(np2);
 
  482   int i1end = absNp1-1;
 
  484   int i2end = absNp1+absNp2-1;
 
  487   for(
i=i1beg; 
i<=i2end; 
i++) {
 
  492   for (
i=i1beg; 
i<=i1end; 
i++) {
 
  493     j += (
r[
i] == 0.) ? 1 : nVphi;
 
  496   bool ifSide1 = 
false;                           
 
  497   bool ifSide2 = 
false;
 
  499   if (
r[i2beg] != 
r[i1beg] || 
z[i2beg] != 
z[i1beg]) {
 
  500     j += (
r[i2beg] == 0.) ? 1 : nVphi;
 
  504   for(
i=i2beg+1; 
i<i2end; 
i++) {
 
  505     j += (
r[
i] == 0.) ? 1 : nVphi;
 
  508   if (
r[i2end] != 
r[i1end] || 
z[i2end] != 
z[i1end]) {
 
  509     if (absNp2 > 1) j += (
r[i2end] == 0.) ? 1 : nVphi;
 
  515   k = ifClosed ? absNp1*nSphi : (absNp1-1)*nSphi;       
 
  518     for(
i=i2beg; 
i<i2end; 
i++) {
 
  519       if (
r[
i] > 0. || 
r[
i+1] > 0.)       
k += nSphi;
 
  523       if (
r[i2end] > 0. || 
r[i2beg] > 0.) 
k += nSphi;
 
  528     if (ifSide1 && (
r[i1beg] > 0. || 
r[i2beg] > 0.)) 
k += nSphi;
 
  529     if (ifSide2 && (
r[i1end] > 0. || 
r[i2end] > 0.)) 
k += nSphi;
 
  532   if (!ifWholeCircle) {                                 
 
  533     k += ifClosed ? 2*absNp1 : 2*(absNp1-1);
 
  543   kk = 
new int[absNp1+absNp2];
 
  546   for(
i=i1beg; 
i<=i1end; 
i++) {
 
  559   for(
i=i2beg+1; 
i<i2end; 
i++) {
 
  574   double cosPhi, sinPhi;
 
  576   for(j=0; j<nVphi; j++) {
 
  577     cosPhi = 
cos(
phi+j*delPhi/nSphi);
 
  578     sinPhi = 
sin(
phi+j*delPhi/nSphi);
 
  579     for(
i=i1beg; 
i<=i2end; 
i++) {
 
  589   v2 = ifClosed ? nodeVis : 1;
 
  590   for(
i=i1beg; 
i<i1end; 
i++) {
 
  592     if (!ifClosed && 
i == i1end-1) {
 
  595       v2 = (
r[
i] == 
r[
i+1] && 
r[
i+1] == 
r[
i+2]) ? -1 : nodeVis;
 
  598                edgeVis, ifWholeCircle, nSphi, 
k);
 
  602                edgeVis, ifWholeCircle, nSphi, 
k);
 
  608     v2 = ifClosed ? nodeVis : 1;
 
  609     for(
i=i2beg; 
i<i2end; 
i++) {
 
  611       if (!ifClosed && 
i==i2end-1) {
 
  614         v2 = (
r[
i] == 
r[
i+1] && 
r[
i+1] == 
r[
i+2]) ? -1 :  nodeVis;
 
  617                  edgeVis, ifWholeCircle, nSphi, 
k);
 
  621                  edgeVis, ifWholeCircle, nSphi, 
k);
 
  630                  -1, ifWholeCircle, nSphi, 
k);
 
  634                  -1, ifWholeCircle, nSphi, 
k);
 
  640   if (!ifWholeCircle) {
 
  645       for (
i=i1beg; 
i<=i1end; 
i++) {
 
  647         ii[3] = (
i == i1end) ? i1beg : 
i+1;
 
  648         ii[1] = (absNp2 == 1) ? i2beg : ii[0]+absNp1;
 
  649         ii[2] = (absNp2 == 1) ? i2beg : ii[3]+absNp1;
 
  657       for (
i=i1beg; 
i<i1end; 
i++) {
 
  660         ii[1] = (absNp2 == 1) ? i2beg : ii[0]+absNp1;
 
  661         ii[2] = (absNp2 == 1) ? i2beg : ii[3]+absNp1;
 
  662         vv[0] = (
i == i1beg)   ? 1 : -1;
 
  664         vv[2] = (
i == i1end-1) ? 1 : -1;
 
  675       << 
"Polyhedron::RotateAroundZ: number of generated faces (" 
  676       << 
k-1 << 
") is not equal to the number of allocated faces (" 
 
 
 
◆ RotateEdge()
  
  | 
        
          | void SbPolyhedron::RotateEdge | ( | int | k1, |  
          |  |  | int | k2, |  
          |  |  | double | r1, |  
          |  |  | double | r2, |  
          |  |  | int | v1, |  
          |  |  | int | v2, |  
          |  |  | int | vEdge, |  
          |  |  | bool | ifWholeCircle, |  
          |  |  | int | ns, |  
          |  |  | int & | kface |  
          |  | ) |  |  |  | protectedinherited | 
 
Definition at line 306 of file SbPolyhedron.cxx.
  328   if (r1 == 0. && r2 == 0) 
return;
 
  333   int ii1 = ifWholeCircle ? i1 : i1+
ns;
 
  334   int ii2 = ifWholeCircle ? i2 : i2+
ns;
 
  335   int vv  = ifWholeCircle ? vEdge : 1;
 
  340     }
else if (r2 == 0.) {
 
  343       m_pF[kface++]   = 
SbFacet(i1,0,    
v2*i2,0, (i2+1),0, v1*(i1+1),0);
 
  348       for (i2++,
i=1; 
i<
ns-1; i2++,
i++) {
 
  349         m_pF[kface++] = 
SbFacet(vEdge*i1,0, 
v2*i2,0, vEdge*(i2+1),0);
 
  352     }
else if (r2 == 0.) {
 
  354       for (i1++,
i=1; 
i<
ns-1; i1++,
i++) {
 
  355         m_pF[kface++] = 
SbFacet(vEdge*i1,0, vEdge*i2,0, v1*(i1+1),0);
 
  360       for (i1++,i2++,
i=1; 
i<
ns-1; i1++,i2++,
i++) {
 
  361         m_pF[kface++] = 
SbFacet(vEdge*i1,0, 
v2*i2,0, vEdge*(i2+1),0,v1*(i1+1),0);
 
 
 
 
◆ SetNumberOfRotationSteps()
  
  | 
        
          | void SbPolyhedron::SetNumberOfRotationSteps | ( | int | n | ) |  |  | staticinherited | 
 
Definition at line 245 of file SbPolyhedron.cxx.
  258       << 
"SbPolyhedron::SetNumberOfRotationSteps: attempt to set the\n" 
  259       << 
"number of steps per circle < " << nMin << 
"; forced to " << nMin
 
 
 
 
◆ SetReferences()
  
  | 
        
          | void SbPolyhedron::SetReferences | ( |  | ) |  |  | protectedinherited | 
 
Definition at line 682 of file SbPolyhedron.cxx.
  694   struct edgeListMember {
 
  695     edgeListMember *
next;
 
  699   } *edgeList, *freeList, **headList;
 
  704   edgeList = 
new edgeListMember[2*
m_nface];
 
  705   headList = 
new edgeListMember*[
m_nvert];
 
  713     edgeList[
i].next = &edgeList[
i+1];
 
  715   edgeList[2*
m_nface-1].next = 0;
 
  719   int iface, iedge, nedge, i1, i2, k1, k2;
 
  720   edgeListMember *prev, *
cur;
 
  722   for(iface=1; iface<=
m_nface; iface++) {
 
  724     for (iedge=0; iedge<nedge; iedge++) {
 
  726       i2 = (iedge < nedge-1) ? iedge+1 : 0;
 
  729       k1 = (i1 < i2) ? i1 : i2;          
 
  730       k2 = (i1 > i2) ? i1 : i2;          
 
  735         headList[k1] = freeList;
 
  736         freeList = freeList->next;
 
  746         headList[k1] = 
cur->next;
 
  747         cur->next = freeList;
 
  755             << 
"Polyhedron::SetReferences: different edge visibility " 
  756             << iface << 
"/" << iedge << 
"/" 
  758             << 
cur->iface << 
"/" << 
cur->iedge << 
"/" 
  770           prev->next = freeList;
 
  771           freeList = freeList->next;
 
  781           prev->next = 
cur->next;
 
  782           cur->next = freeList;
 
  790                 << 
"Polyhedron::SetReferences: different edge visibility " 
  791                 << iface << 
"/" << iedge << 
"/" 
  793                 << 
cur->iface << 
"/" << 
cur->iedge << 
"/" 
  806     if (headList[
i] != 0) {
 
  808         << 
"Polyhedron::SetReferences: List " << 
i << 
" is not empty" 
 
 
 
◆ SetSideFacets()
  
  | 
        
          | void SbPolyhedron::SetSideFacets | ( | int | ii[4], |  
          |  |  | int | vv[4], |  
          |  |  | int * | kk, |  
          |  |  | double * | r, |  
          |  |  | double | dphi, |  
          |  |  | int | ns, |  
          |  |  | int & | kface |  
          |  | ) |  |  |  | protectedinherited | 
 
Definition at line 368 of file SbPolyhedron.cxx.
  390     for (
int i=0; 
i<4; 
i++) {
 
  392       k2 = (
i == 3) ? ii[0] : ii[
i+1];
 
  393       if (
r[k1] == 0. && 
r[k2] == 0.) 
vv[
i] = -1;
 
  397   if (ii[1] == ii[2]) {
 
  402     if (
r[ii[0]] != 0.) k1 += 
ns;
 
  403     if (
r[ii[2]] != 0.) k2 += 
ns;
 
  404     if (
r[ii[3]] != 0.) k3 += 
ns;
 
  406   }
else if (
kk[ii[0]] == 
kk[ii[1]]) {
 
  411     if (
r[ii[0]] != 0.) k1 += 
ns;
 
  412     if (
r[ii[2]] != 0.) k2 += 
ns;
 
  413     if (
r[ii[3]] != 0.) k3 += 
ns;
 
  415   }
else if (
kk[ii[2]] == 
kk[ii[3]]) {
 
  420     if (
r[ii[0]] != 0.) k1 += 
ns;
 
  421     if (
r[ii[1]] != 0.) k2 += 
ns;
 
  422     if (
r[ii[2]] != 0.) k3 += 
ns;
 
  430     if (
r[ii[0]] != 0.) k1 += 
ns;
 
  431     if (
r[ii[1]] != 0.) k2 += 
ns;
 
  432     if (
r[ii[2]] != 0.) k3 += 
ns;
 
  433     if (
r[ii[3]] != 0.) k4 += 
ns;
 
 
 
 
◆ subtract()
◆ Transform()
◆ m_nface
  
  | 
        
          | int SbPolyhedron::m_nface |  | protectedinherited | 
 
 
◆ m_nvert
  
  | 
        
          | int SbPolyhedron::m_nvert |  | protectedinherited | 
 
 
◆ m_pF
◆ m_pV
◆ s_numberOfRotationSteps
The documentation for this class was generated from the following files:
 
HVNormal3D FindNodeNormal(int iFace, int iNode) const
static int s_numberOfRotationSteps
struct SbFacet::@64 m_edge[4]
Scalar phi() const
phi method
bool GetNextVertexIndex(int &index, int &edgeFlag) const
bool GetNextEdgeIndeces(int &i1, int &i2, int &edgeFlag, int &iface1, int &iface2) const
void GetFacet(int iFace, int &n, int *iNodes, int *edgeFlags=0, int *iFaces=0) const
#define DEFAULT_NUMBER_OF_STEPS
virtual SbPolyhedron & operator=(const SbPolyhedron &from)
HVNormal3D GetNormal(int iFace) const
bool GetNextNormal(HVNormal3D &normal) const
void AllocateMemory(int Nvert, int Nface)
static int GetNumberOfRotationSteps()
@ RIGHT
the drift radius is positive (see Trk::AtaStraightLine)
HVNormal3D GetUnitNormal(int iFace) const
void SetSideFacets(int ii[4], int vv[4], int *kk, double *r, double dphi, int ns, int &kface)
def dot(G, fn, nodesToHighlight=[])
void RotateAroundZ(int nstep, double phi, double dphi, int np1, int np2, const double *z, double *r, int nodeVis, int edgeVis)
int FindNeighbour(int iFace, int iNode, int iOrder) const
void RotateEdge(int k1, int k2, double r1, double r2, int v1, int v2, int vEdge, bool ifWholeCircle, int ns, int &kface)
@ LEFT
the drift radius is negative (see Trk::AtaStraightLine)
const boost::regex rr(r_r)