ATLAS Offline Software
Public Member Functions | Private Member Functions | Private Attributes | List of all members
PolygonTriangulator::Polygon Class Reference
Collaboration diagram for PolygonTriangulator::Polygon:

Public Member Functions

 Polygon (const std::vector< double > &x, const std::vector< double > &y)
 
 ~Polygon ()
 
void partition2Monotone ()
 
void searchMonotones ()
 
void triangulation ()
 
const Trianglestriangles ()
 
internal_poltrig::PointbaseMappoints ()
 
internal_poltrig::LineMapedges ()
 

Private Member Functions

void set_contour (const std::vector< double > &x, const std::vector< double > &y)
 
void initializate ()
 
unsigned int prev (const unsigned int &i)
 
unsigned int next (const unsigned int &i)
 
void handleStartVertex (const unsigned int &)
 
void handleEndVertex (const unsigned int &)
 
void handleSplitVertex (const unsigned int &)
 
void handleMergeVertex (const unsigned int &)
 
void handleRegularVertexUp (const unsigned int &)
 
void handleRegularVertexDown (const unsigned int &)
 
void addDiagonal (const unsigned int &i, const unsigned int &j)
 
double angleCosb (double *A, double *B, double *C)
 
unsigned int selectNextEdge (internal_poltrig::Linebase *edge)
 
void triangulateMonotone (internal_poltrig::Monopoly &mpoly)
 
void init_vertices_and_lines ()
 

Private Attributes

long int m_l_id
 
internal_poltrig::PQueue m_qpoints
 
internal_poltrig::EdgeBST m_edgebst
 
internal_poltrig::Monopolys m_mpolys
 
Triangles m_triangles
 
internal_poltrig::AdjEdgeMap m_startAdjEdgeMap
 
internal_poltrig::LineMap m_diagonals
 
unsigned int m_ncontours
 
std::vector< unsigned int > m_nVertices
 
internal_poltrig::PointbaseMap m_points
 
internal_poltrig::LineMap m_edges
 
double m_xmin
 
double m_xmax
 
double m_ymin
 
double m_ymax
 

Detailed Description

Definition at line 1418 of file PolygonTriangulator.cxx.

Constructor & Destructor Documentation

◆ Polygon()

PolygonTriangulator::Polygon::Polygon ( const std::vector< double > &  x,
const std::vector< double > &  y 
)

Definition at line 1552 of file PolygonTriangulator.cxx.

1553 {
1554  m_l_id = 0;
1555  m_ncontours=0;
1556 
1557  m_xmin = m_ymin = std::numeric_limits<double>::infinity();
1558  m_xmax = m_ymax = - std::numeric_limits<double>::infinity();
1559 
1560 
1561  set_contour(x,y);
1563  initializate();
1564 }

◆ ~Polygon()

PolygonTriangulator::Polygon::~Polygon ( )

Definition at line 1569 of file PolygonTriangulator.cxx.

1570 {
1571  //clear all dynamic allocated memory
1573  for(; itp!=m_points.end(); ++itp)
1574  {
1575  delete itp->second;
1576  }
1577 
1579  for(; itl!=m_edges.end(); ++itl)
1580  {
1581  delete itl->second;
1582  }
1583 
1584 }

Member Function Documentation

◆ addDiagonal()

void PolygonTriangulator::Polygon::addDiagonal ( const unsigned int &  i,
const unsigned int &  j 
)
private

Definition at line 1679 of file PolygonTriangulator.cxx.

1680 {
1683  m_edges[diag->id()]=diag;
1684 
1685  m_startAdjEdgeMap[i].insert(diag->id());
1686  m_startAdjEdgeMap[j].insert(diag->id());
1687 
1688  m_diagonals[diag->id()]=diag;
1689 
1690 }

◆ angleCosb()

double PolygonTriangulator::Polygon::angleCosb ( double *  A,
double *  B,
double *  C 
)
private

Definition at line 1847 of file PolygonTriangulator.cxx.

1848 {
1849  double dxab = pa[0] - pb[0];
1850  double dyab = pa[1] - pb[1];
1851 
1852  double dxcb = pc[0] - pb[0];
1853  double dycb = pc[1] - pb[1];
1854 
1855  double dxab2 = dxab * dxab;
1856  double dyab2 = dyab * dyab;
1857  double dxcb2 = dxcb * dxcb;
1858  double dycb2 = dycb * dycb;
1859  double ab = dxab2 + dyab2;
1860  double cb = dxcb2 + dycb2;
1861 
1862  double cosb = dxab * dxcb + dyab * dycb;
1863  double denom = sqrt( ab * cb);
1864 
1865  cosb/=denom;
1866 
1867  return cosb;
1868 }

◆ edges()

internal_poltrig::LineMap& PolygonTriangulator::Polygon::edges ( )
inline

Definition at line 1434 of file PolygonTriangulator.cxx.

1434 { return m_edges; }

◆ handleEndVertex()

void PolygonTriangulator::Polygon::handleEndVertex ( const unsigned int &  i)
private

Definition at line 1709 of file PolygonTriangulator.cxx.

1710 {
1711  double y=m_points[i]->y;
1713 
1714  unsigned int previ=prev(i);
1715  internal_poltrig::Linebase* edge=m_edges[previ];
1716  unsigned int helper=m_edges[previ]->helper();
1717 
1718 
1720  m_edgebst.Delete(edge->keyValue());
1721 
1722 }

◆ handleMergeVertex()

void PolygonTriangulator::Polygon::handleMergeVertex ( const unsigned int &  i)
private

Definition at line 1748 of file PolygonTriangulator.cxx.

1749 {
1750  double x=m_points[i]->x, y=m_points[i]->y;
1752 
1753  unsigned int previ=prev(i);
1754  unsigned int helper=m_edges[previ]->helper();
1756  m_edgebst.Delete(m_edges[previ]->keyValue());
1757 
1759  m_edgebst.FindMaxSmallerThan(x, leftnode);
1760  internal_poltrig::Linebase* leftedge=leftnode->data();
1761 
1762  helper=leftedge->helper();
1764 
1765  leftedge->setHelper(i);
1766 }

◆ handleRegularVertexDown()

void PolygonTriangulator::Polygon::handleRegularVertexDown ( const unsigned int &  i)
private

Definition at line 1771 of file PolygonTriangulator.cxx.

1772 {
1773  double y=m_points[i]->y;
1775 
1776  unsigned int previ=prev(i);
1777  unsigned int helper=m_edges[previ]->helper();
1779 
1780  m_edgebst.Delete(m_edges[previ]->keyValue());
1781  m_edges[i]->setHelper(i);
1782  m_edges[i]->setKeyValue(y);
1784 
1785 }

◆ handleRegularVertexUp()

void PolygonTriangulator::Polygon::handleRegularVertexUp ( const unsigned int &  i)
private

Definition at line 1790 of file PolygonTriangulator.cxx.

1791 {
1792  double x=m_points[i]->x, y=m_points[i]->y;
1794 
1796  m_edgebst.FindMaxSmallerThan(x, leftnode);
1797 
1798  internal_poltrig::Linebase* leftedge=leftnode->data();
1799 
1800  unsigned int helper=leftedge->helper();
1802  leftedge->setHelper(i);
1803 
1804 }

◆ handleSplitVertex()

void PolygonTriangulator::Polygon::handleSplitVertex ( const unsigned int &  i)
private

Definition at line 1727 of file PolygonTriangulator.cxx.

1728 {
1729  double x=m_points[i]->x, y=m_points[i]->y;
1731 
1733  m_edgebst.FindMaxSmallerThan(x, leftnode);
1734  internal_poltrig::Linebase* leftedge=leftnode->data();
1735 
1736  unsigned int helper=leftedge->helper();
1737  addDiagonal(i, helper);
1738 
1739  leftedge->setHelper(i);
1740  m_edges[i]->setHelper(i);
1741  m_edges[i]->setKeyValue(y);
1743 }

◆ handleStartVertex()

void PolygonTriangulator::Polygon::handleStartVertex ( const unsigned int &  i)
private

Definition at line 1695 of file PolygonTriangulator.cxx.

1696 {
1697  double y=m_points[i]->y;
1699 
1700  m_edges[i]->setHelper(i);
1701  m_edges[i]->setKeyValue(y);
1703 
1704 }

◆ init_vertices_and_lines()

void PolygonTriangulator::Polygon::init_vertices_and_lines ( )
private

Definition at line 1488 of file PolygonTriangulator.cxx.

1489 {
1490  int sid,eid;
1491  int num=0;
1492 
1494 
1495  for(unsigned j=0; j<m_ncontours; ++j)
1496  {
1497  for(unsigned i=1; i<=m_nVertices[j]; ++i)//fixme: 0-based?
1498  {
1499  sid=num+i;
1500  eid=(i==m_nVertices[j])?num+1:num+i+1;
1503  m_edges[m_l_id]=line;
1504  }
1505  num+=m_nVertices[j];
1506  }
1507 
1508  int sum=0;
1509  for(unsigned int i=0; i<m_ncontours; ++i)
1510  {
1511  sum+= m_nVertices[i];
1512  m_nVertices[i]=sum;
1513  }
1514 
1515 }

◆ initializate()

void PolygonTriangulator::Polygon::initializate ( )
private

Definition at line 1635 of file PolygonTriangulator.cxx.

1636 {
1638  for(; it!=m_points.end(); ++it)
1639  {
1640  int id=it->first;
1641  int idp=prev(id);
1642  int idn=next(id);
1643  internal_poltrig::Pointbase p=*m_points[id], pnext=*m_points[idn], pprev=*m_points[idp];
1644 
1645  if( p > pnext && pprev > p )
1647  else if (p > pprev && pnext > p)
1649  else
1650  {
1651  double pa[2], pb[2], pc[2];
1652 
1653  pa[0]=m_points[idp]->x;
1654  pa[1]=m_points[idp]->y;
1655 
1656  pb[0]=m_points[id]->x;
1657  pb[1]=m_points[id]->y;
1658 
1659  pc[0]=m_points[idn]->x;
1660  pc[1]=m_points[idn]->y;
1661 
1662  double area=internal_poltrig::orient2d(pa,pb,pc);
1663 
1664  if( pprev > p && pnext > p ) m_points[id]->type=(area >0) ? internal_poltrig::END: internal_poltrig::MERGE ;
1665  if( pprev < p && pnext < p ) m_points[id]->type=(area >0) ? internal_poltrig::START : internal_poltrig::SPLIT;
1666 
1667  }
1668 
1669  m_qpoints.push(*(it->second));
1670 
1671  m_startAdjEdgeMap[id].insert(id);
1672 
1673  }
1674 }

◆ next()

unsigned int PolygonTriangulator::Polygon::next ( const unsigned int &  i)
private

Definition at line 1608 of file PolygonTriangulator.cxx.

1609 {
1610  unsigned int j(0),prevLoop(0),currentLoop(0);
1611 
1612  while ( i > m_nVertices[currentLoop] )
1613  {
1614  prevLoop=currentLoop;
1615  ++currentLoop;
1616  }
1617 
1618  if( i < m_nVertices[currentLoop] ) j=i+1;
1619  else if ( i==m_nVertices[currentLoop] )
1620  {
1621  if( currentLoop==0) j=1;
1622  else j=m_nVertices[prevLoop]+1;
1623  }
1624 
1625  return j;
1626 }

◆ partition2Monotone()

void PolygonTriangulator::Polygon::partition2Monotone ( )

Definition at line 1809 of file PolygonTriangulator.cxx.

1810 {
1811 
1812  if(m_qpoints.top().type!=internal_poltrig::START)
1813  {
1814  std::cout<<"Please check your input polygon:\n1)orientations?\n2)duplicated points?\n";
1815  exit(1);
1816  }
1817 
1818  while(!m_qpoints.empty())
1819  {
1821  m_qpoints.pop();
1822  unsigned int id=vertex.id;
1823 
1824  switch(vertex.type)
1825  {
1826  case internal_poltrig::START: handleStartVertex(id); break;
1827  case internal_poltrig::END: handleEndVertex(id); break;
1828  case internal_poltrig::MERGE: handleMergeVertex(id); break;
1829  case internal_poltrig::SPLIT: handleSplitVertex(id); break;
1832  default:
1833  std::cout<<"No duplicated points please!\n";
1834  exit(1); break;
1835  }
1836  }
1837 }

◆ points()

internal_poltrig::PointbaseMap& PolygonTriangulator::Polygon::points ( )
inline

Definition at line 1433 of file PolygonTriangulator.cxx.

1433 { return m_points; }

◆ prev()

unsigned int PolygonTriangulator::Polygon::prev ( const unsigned int &  i)
private

Definition at line 1589 of file PolygonTriangulator.cxx.

1590 {
1591  unsigned int j(0),prevLoop(0),currentLoop(0);
1592 
1593  while ( i > m_nVertices[currentLoop] )
1594  {
1595  prevLoop=currentLoop;
1596  ++currentLoop;
1597  }
1598 
1599  if( i==1 || (i==m_nVertices[prevLoop]+1) ) j=m_nVertices[currentLoop];
1600  else if( i <= m_nVertices[currentLoop] ) j=i-1;
1601 
1602  return j;
1603 }

◆ searchMonotones()

void PolygonTriangulator::Polygon::searchMonotones ( )

Definition at line 1916 of file PolygonTriangulator.cxx.

1917 {
1919 
1920  while( edges.size() > m_diagonals.size() )
1921  {
1924  internal_poltrig::Pointbase* startp=it->second->endPoint(0);
1927 
1928  poly.push_back(startp->id);
1929 
1930  for(;;)
1931  {
1932  endp=next->endPoint(1);
1933  if(next->type()!=internal_poltrig::INSERT)
1934  {
1935  edges.erase(next->id());
1936  m_startAdjEdgeMap[next->endPoint(0)->id].erase(next->id());
1937  }
1938  if(endp==startp) break;
1939  poly.push_back(endp->id);
1940 
1941  unsigned int nexte=selectNextEdge(next);
1942 
1943  if(nexte==0)
1944  {
1945  std::cout<<"Please check your input polygon:\n";
1946  std::cout<<"1)orientations?\n2)with duplicated points?\n3)is a simple one?\n";
1947  exit(1);
1948  }
1949  //assert( nexte > 0);
1950  next=edges[nexte];
1951  if(next->endPoint(0) !=endp ) next->reverse();
1952  }
1953 
1954  m_mpolys.push_back(poly);
1955  }
1956 }

◆ selectNextEdge()

unsigned int PolygonTriangulator::Polygon::selectNextEdge ( internal_poltrig::Linebase edge)
private

Definition at line 1874 of file PolygonTriangulator.cxx.

1875 {
1876 
1877  unsigned int eid= edge->endPoint(1)->id;
1878  std::set<unsigned int> edges=m_startAdjEdgeMap[eid];
1879  assert(!edges.empty());
1880 
1881  unsigned int nexte=0;
1882  if( edges.size() == 1 ) nexte=*(edges.begin());
1883  else if( edges.size() > 1 )
1884  {
1885  unsigned int nexte_ccw(0), nexte_cw(0);
1886  double max=-2.0,min=2.0;
1887 
1888 
1890  for(; it!=edges.end(); ++it)
1891  {
1892  if(*it==edge->id()) continue;
1893  double A[2], B[2], C[2];
1894  A[0]=edge->endPoint(0)->x; A[1]=edge->endPoint(0)->y;
1895  B[0]=edge->endPoint(1)->x; B[1]=edge->endPoint(1)->y;
1896 
1897  if(edge->endPoint(1)!=m_edges[*it]->endPoint(0)) m_edges[*it]->reverse();
1898  C[0]=m_edges[*it]->endPoint(1)->x; C[1]=m_edges[*it]->endPoint(1)->y;
1899 
1900  double area=internal_poltrig::orient2d(A, B, C);
1901  double cosb=angleCosb(A, B, C);
1902 
1903  if( area > 0 && max < cosb ) { nexte_ccw=*it; max=cosb; }
1904  else if( min > cosb ) { nexte_cw=*it; min=cosb; }
1905  }
1906 
1907  nexte = (nexte_ccw!=0) ? nexte_ccw : nexte_cw;
1908  }
1909 
1910  return nexte;
1911 }

◆ set_contour()

void PolygonTriangulator::Polygon::set_contour ( const std::vector< double > &  x,
const std::vector< double > &  y 
)
private

Definition at line 1521 of file PolygonTriangulator.cxx.

1522 {
1523  assert(x.size()==y.size());
1524 
1525  m_nVertices.push_back( x.size() );
1526  unsigned int i = m_points.size()+1/*1*/;//fixme: get rid of the +1 ?
1527  double xx,yy;
1529  for (unsigned int j = 0; j < m_nVertices[m_ncontours]; ++j, ++i)
1530  {
1531  xx=x.at(j);
1532  yy=y.at(j);
1535  if(xx > m_xmax ) m_xmax=xx;
1536  if(xx < m_xmin ) m_xmin=xx;
1537  if(yy > m_ymax ) m_ymax=yy;
1538  if(yy < m_ymin ) m_ymin=yy;
1539  m_points[i]=point;
1540  }
1541 
1542  ++m_ncontours;
1543 
1544 }

◆ triangles()

const Triangles* PolygonTriangulator::Polygon::triangles ( )
inline

Definition at line 1431 of file PolygonTriangulator.cxx.

1431 { return &m_triangles; }

◆ triangulateMonotone()

void PolygonTriangulator::Polygon::triangulateMonotone ( internal_poltrig::Monopoly mpoly)
private

Definition at line 1962 of file PolygonTriangulator.cxx.

1963 {
1964  internal_poltrig::PQueue qvertex;
1965  internal_poltrig::Monopoly::iterator it=mpoly.begin(), itnext;
1966  for(; itnext=it, it!=mpoly.end(); ++it)
1967  {
1968  ++itnext;
1969  if(itnext==mpoly.end()) itnext=mpoly.begin();
1970  internal_poltrig::Pointbase point=*m_points[*it], pointnext=*m_points[*itnext];
1971  point.left=(point > pointnext)? true:false;
1972  qvertex.push(point);
1973  }
1974 
1975  std::stack<internal_poltrig::Pointbase> spoint;
1976  for(int i=0; i<2; ++i) { spoint.push(qvertex.top()); qvertex.pop(); }
1977 
1978  while ( qvertex.size() > 1 )
1979  {
1980  internal_poltrig::Pointbase topQueuePoint=qvertex.top();
1981  internal_poltrig::Pointbase topStackPoint=spoint.top();
1982 
1983  if(topQueuePoint.left!=topStackPoint.left)
1984  {
1985  while ( spoint.size() > 1 )
1986  {
1987  internal_poltrig::Pointbase p1=spoint.top();
1988  spoint.pop();
1989  internal_poltrig::Pointbase p2=spoint.top();
1990  Triangle v(3);
1991  v[0]=topQueuePoint.id;
1992  v[1]=p1.id;
1993  v[2]=p2.id;
1994  sort(v.begin(),v.end());//TK
1995  m_triangles.push_back(v);
1996 
1997  }
1998  spoint.pop();
1999  spoint.push(topStackPoint);
2000  spoint.push(topQueuePoint);
2001  }
2002  else
2003  {
2004  while( spoint.size() > 1 )
2005  {
2006  internal_poltrig::Pointbase stack1Point=spoint.top();
2007  spoint.pop();
2008  internal_poltrig::Pointbase stack2Point=spoint.top();
2009  spoint.push(stack1Point);
2010  double pa[2], pb[2], pc[2];
2011  pa[0]=topQueuePoint.x; pa[1]=topQueuePoint.y;
2012  pb[0]=stack2Point.x; pb[1]=stack2Point.y;
2013  pc[0]=stack1Point.x; pc[1]=stack1Point.y;
2014 
2015  double area=internal_poltrig::orient2d(pa,pb,pc);
2016  bool left=stack1Point.left;
2017  if( (area > 0 && left) || (area < 0 && !left ) )
2018  {
2019  Triangle v(3);
2020  v[0]=topQueuePoint.id;
2021  v[1]=stack2Point.id;
2022  v[2]=stack1Point.id;
2023  sort(v.begin(),v.end());//TK
2024  m_triangles.push_back(v);
2025  spoint.pop();
2026  } else break;
2027  }
2028 
2029  spoint.push(topQueuePoint);
2030 
2031  }
2032 
2033  qvertex.pop();
2034 
2035  }
2036 
2037  internal_poltrig::Pointbase lastQueuePoint=qvertex.top();
2038  while( spoint.size() !=1 )
2039  {
2040  internal_poltrig::Pointbase topPoint=spoint.top();
2041  spoint.pop();
2042  internal_poltrig::Pointbase top2Point=spoint.top();
2043 
2044  Triangle v(3);
2045  v[0]=lastQueuePoint.id;
2046  v[1]=topPoint.id;
2047  v[2]=top2Point.id;
2048  sort(v.begin(),v.end());//TK
2049  m_triangles.push_back(v);
2050  }
2051 }

◆ triangulation()

void PolygonTriangulator::Polygon::triangulation ( )

Definition at line 2056 of file PolygonTriangulator.cxx.

2057 {
2059  searchMonotones();
2061  for(; it!=m_mpolys.end(); ++it)
2063 }

Member Data Documentation

◆ m_diagonals

internal_poltrig::LineMap PolygonTriangulator::Polygon::m_diagonals
private

Definition at line 1475 of file PolygonTriangulator.cxx.

◆ m_edgebst

internal_poltrig::EdgeBST PolygonTriangulator::Polygon::m_edgebst
private

Definition at line 1469 of file PolygonTriangulator.cxx.

◆ m_edges

internal_poltrig::LineMap PolygonTriangulator::Polygon::m_edges
private

Definition at line 1482 of file PolygonTriangulator.cxx.

◆ m_l_id

long int PolygonTriangulator::Polygon::m_l_id
private

Definition at line 1438 of file PolygonTriangulator.cxx.

◆ m_mpolys

internal_poltrig::Monopolys PolygonTriangulator::Polygon::m_mpolys
private

Definition at line 1470 of file PolygonTriangulator.cxx.

◆ m_ncontours

unsigned int PolygonTriangulator::Polygon::m_ncontours
private

Definition at line 1479 of file PolygonTriangulator.cxx.

◆ m_nVertices

std::vector<unsigned int> PolygonTriangulator::Polygon::m_nVertices
private

Definition at line 1480 of file PolygonTriangulator.cxx.

◆ m_points

internal_poltrig::PointbaseMap PolygonTriangulator::Polygon::m_points
private

Definition at line 1481 of file PolygonTriangulator.cxx.

◆ m_qpoints

internal_poltrig::PQueue PolygonTriangulator::Polygon::m_qpoints
private

Definition at line 1468 of file PolygonTriangulator.cxx.

◆ m_startAdjEdgeMap

internal_poltrig::AdjEdgeMap PolygonTriangulator::Polygon::m_startAdjEdgeMap
private

Definition at line 1474 of file PolygonTriangulator.cxx.

◆ m_triangles

Triangles PolygonTriangulator::Polygon::m_triangles
private

Definition at line 1471 of file PolygonTriangulator.cxx.

◆ m_xmax

double PolygonTriangulator::Polygon::m_xmax
private

Definition at line 1483 of file PolygonTriangulator.cxx.

◆ m_xmin

double PolygonTriangulator::Polygon::m_xmin
private

Definition at line 1483 of file PolygonTriangulator.cxx.

◆ m_ymax

double PolygonTriangulator::Polygon::m_ymax
private

Definition at line 1483 of file PolygonTriangulator.cxx.

◆ m_ymin

double PolygonTriangulator::Polygon::m_ymin
private

Definition at line 1483 of file PolygonTriangulator.cxx.


The documentation for this class was generated from the following file:
xAOD::iterator
JetConstituentVector::iterator iterator
Definition: JetConstituentVector.cxx:68
internal_poltrig::Pointbase
Definition: PolygonTriangulator.cxx:1208
PolygonTriangulator::Polygon::m_l_id
long int m_l_id
Definition: PolygonTriangulator.cxx:1438
internal_poltrig::LineMap
std::map< unsigned int, Linebase * > LineMap
Definition: PolygonTriangulator.cxx:119
internal_poltrig::START
@ START
Definition: PolygonTriangulator.cxx:112
TruthTest.itp
itp
Definition: TruthTest.py:46
PolygonTriangulator::Polygon::next
unsigned int next(const unsigned int &i)
Definition: PolygonTriangulator.cxx:1608
checkFileSG.line
line
Definition: checkFileSG.py:75
python.PerfMonSerializer.p
def p
Definition: PerfMonSerializer.py:743
max
#define max(a, b)
Definition: cfImp.cxx:41
internal_poltrig::REGULAR_DOWN
@ REGULAR_DOWN
Definition: PolygonTriangulator.cxx:112
PolygonTriangulator::Polygon::m_triangles
Triangles m_triangles
Definition: PolygonTriangulator.cxx:1471
keylayer_zslicemap.pb
pb
Definition: keylayer_zslicemap.py:188
PlotCalibFromCool.yy
yy
Definition: PlotCalibFromCool.py:714
internal_poltrig::SplayTree::Delete
void Delete(const KeyType &keys)
Definition: PolygonTriangulator.cxx:824
internal_poltrig::Linebase::helper
unsigned int helper()
Definition: PolygonTriangulator.cxx:1268
internal_poltrig::Pointbase::x
double x
Definition: PolygonTriangulator.cxx:1235
PolygonTriangulator::Polygon::m_qpoints
internal_poltrig::PQueue m_qpoints
Definition: PolygonTriangulator.cxx:1468
PolygonTriangulator::Polygon::m_xmin
double m_xmin
Definition: PolygonTriangulator.cxx:1483
DMTest::C
C_v1 C
Definition: C.h:26
PolygonTriangulator::Polygon::m_edgebst
internal_poltrig::EdgeBST m_edgebst
Definition: PolygonTriangulator.cxx:1469
PolygonTriangulator::Polygon::handleMergeVertex
void handleMergeVertex(const unsigned int &)
Definition: PolygonTriangulator.cxx:1748
skel.it
it
Definition: skel.GENtoEVGEN.py:423
PolygonTriangulator::Polygon::set_contour
void set_contour(const std::vector< double > &x, const std::vector< double > &y)
Definition: PolygonTriangulator.cxx:1521
PolygonTriangulator::Polygon::m_edges
internal_poltrig::LineMap m_edges
Definition: PolygonTriangulator.cxx:1482
internal_poltrig::PQueue
std::priority_queue< Pointbase > PQueue
Definition: PolygonTriangulator.cxx:120
PolygonTriangulator::Polygon::handleStartVertex
void handleStartVertex(const unsigned int &)
Definition: PolygonTriangulator.cxx:1695
internal_poltrig::orient2d
REAL orient2d(REAL *pa, REAL *pb, REAL *pc)
Definition: PolygonTriangulator.cxx:571
PolygonTriangulator::Polygon::triangulateMonotone
void triangulateMonotone(internal_poltrig::Monopoly &mpoly)
Definition: PolygonTriangulator.cxx:1962
PolygonTriangulator::Polygon::m_startAdjEdgeMap
internal_poltrig::AdjEdgeMap m_startAdjEdgeMap
Definition: PolygonTriangulator.cxx:1474
x
#define x
internal_poltrig::Linebase::endPoint
Pointbase * endPoint(const int &i) const
Definition: PolygonTriangulator.cxx:1257
PolygonTriangulator::Polygon::handleEndVertex
void handleEndVertex(const unsigned int &)
Definition: PolygonTriangulator.cxx:1709
internal_poltrig::Type
Type
Definition: PolygonTriangulator.cxx:112
std::sort
void sort(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end)
Specialization of sort for DataVector/List.
Definition: DVL_algorithms.h:554
internal_poltrig::SplayTree::InOrder
void InOrder(void(*Visit)(BTreeNode< T, KeyType > *u))
Definition: PolygonTriangulator.cxx:688
internal_poltrig::SplayTree::Insert
void Insert(const T &x)
Definition: PolygonTriangulator.cxx:747
PolygonTriangulator::Polygon::m_xmax
double m_xmax
Definition: PolygonTriangulator.cxx:1483
runBeamSpotCalibration.helper
helper
Definition: runBeamSpotCalibration.py:112
dqt_zlumi_alleff_HIST.A
A
Definition: dqt_zlumi_alleff_HIST.py:110
PolygonTriangulator::Polygon::init_vertices_and_lines
void init_vertices_and_lines()
Definition: PolygonTriangulator.cxx:1488
internal_poltrig::INSERT
@ INSERT
Definition: PolygonTriangulator.cxx:112
internal_poltrig::SplayTree::FindMaxSmallerThan
void FindMaxSmallerThan(const KeyType &keys, BTreeNode< T, KeyType > *&res)
Definition: PolygonTriangulator.cxx:949
PolygonTriangulator::Polygon::m_mpolys
internal_poltrig::Monopolys m_mpolys
Definition: PolygonTriangulator.cxx:1470
PolygonTriangulator::Polygon::partition2Monotone
void partition2Monotone()
Definition: PolygonTriangulator.cxx:1809
PolygonTriangulator::Polygon::angleCosb
double angleCosb(double *A, double *B, double *C)
Definition: PolygonTriangulator.cxx:1847
RunTileMonitoring.keyValue
keyValue
Definition: RunTileMonitoring.py:150
convertTimingResiduals.sum
sum
Definition: convertTimingResiduals.py:55
PolygonTriangulator::Polygon::m_points
internal_poltrig::PointbaseMap m_points
Definition: PolygonTriangulator.cxx:1481
lumiFormat.i
int i
Definition: lumiFormat.py:92
internal_poltrig::MERGE
@ MERGE
Definition: PolygonTriangulator.cxx:112
internal_poltrig::UpdateKey
void UpdateKey(BTreeNode< Linebase *, double > *node, double y)
Definition: PolygonTriangulator.cxx:1322
PolygonTriangulator::Polygon::selectNextEdge
unsigned int selectNextEdge(internal_poltrig::Linebase *edge)
Definition: PolygonTriangulator.cxx:1874
PolygonTriangulator::Polygon::searchMonotones
void searchMonotones()
Definition: PolygonTriangulator.cxx:1916
internal_poltrig::END
@ END
Definition: PolygonTriangulator.cxx:112
internal_poltrig::BTreeNode::data
T & data()
Definition: PolygonTriangulator.cxx:643
PolygonTriangulator::Polygon::initializate
void initializate()
Definition: PolygonTriangulator.cxx:1635
PolygonTriangulator::Polygon::handleSplitVertex
void handleSplitVertex(const unsigned int &)
Definition: PolygonTriangulator.cxx:1727
calibdata.exit
exit
Definition: calibdata.py:236
internal_poltrig::Linebase::id
unsigned int id() const
Definition: PolygonTriangulator.cxx:1254
compute_lumi.denom
denom
Definition: compute_lumi.py:76
min
#define min(a, b)
Definition: cfImp.cxx:40
trigbs_pickEvents.num
num
Definition: trigbs_pickEvents.py:76
PolygonTriangulator::Polygon::prev
unsigned int prev(const unsigned int &i)
Definition: PolygonTriangulator.cxx:1589
PolygonTriangulator::Polygon::m_ymax
double m_ymax
Definition: PolygonTriangulator.cxx:1483
id
SG::auxid_t id
Definition: Control/AthContainers/Root/debug.cxx:194
internal_poltrig::INPUT
@ INPUT
Definition: PolygonTriangulator.cxx:112
dqt_zlumi_alleff_HIST.B
B
Definition: dqt_zlumi_alleff_HIST.py:110
internal_poltrig::Pointbase::left
bool left
Definition: PolygonTriangulator.cxx:1237
internal_poltrig::SPLIT
@ SPLIT
Definition: PolygonTriangulator.cxx:112
PolygonTriangulator::Polygon::edges
internal_poltrig::LineMap & edges()
Definition: PolygonTriangulator.cxx:1434
internal_poltrig::Linebase
Definition: PolygonTriangulator.cxx:1245
internal_poltrig::Pointbase::y
double y
Definition: PolygonTriangulator.cxx:1235
PolygonTriangulator::Polygon::addDiagonal
void addDiagonal(const unsigned int &i, const unsigned int &j)
Definition: PolygonTriangulator.cxx:1679
python.PyAthena.v
v
Definition: PyAthena.py:157
internal_poltrig::Monopoly
std::list< unsigned int > Monopoly
Definition: PolygonTriangulator.cxx:122
Trk::vertex
@ vertex
Definition: MeasurementType.h:21
y
#define y
internal_poltrig::BTreeNode
Definition: PolygonTriangulator.cxx:636
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
PolygonTriangulator::Polygon::m_ncontours
unsigned int m_ncontours
Definition: PolygonTriangulator.cxx:1479
PolygonTriangulator::Polygon::m_ymin
double m_ymin
Definition: PolygonTriangulator.cxx:1483
internal_poltrig::REGULAR_UP
@ REGULAR_UP
Definition: PolygonTriangulator.cxx:112
area
double area(double R)
Definition: ConvertStaveServices.cxx:42
internal_poltrig::Linebase::keyValue
double keyValue() const
Definition: PolygonTriangulator.cxx:1259
PolygonTriangulator::Polygon::m_nVertices
std::vector< unsigned int > m_nVertices
Definition: PolygonTriangulator.cxx:1480
PolygonTriangulator::Polygon::m_diagonals
internal_poltrig::LineMap m_diagonals
Definition: PolygonTriangulator.cxx:1475
internal_poltrig::Linebase::setHelper
void setHelper(const unsigned int &i)
Definition: PolygonTriangulator.cxx:1267
PolygonTriangulator::Triangle
std::vector< unsigned > Triangle
Definition: PolygonTriangulator.h:35
python.SystemOfUnits.pc
float pc
Definition: SystemOfUnits.py:99
internal_poltrig::Pointbase::id
unsigned int id
Definition: PolygonTriangulator.cxx:1234
PolygonTriangulator::Polygon::handleRegularVertexDown
void handleRegularVertexDown(const unsigned int &)
Definition: PolygonTriangulator.cxx:1771
PolygonTriangulator::Polygon::handleRegularVertexUp
void handleRegularVertexUp(const unsigned int &)
Definition: PolygonTriangulator.cxx:1790