Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
#include "DataFormats/SiPixelCluster/interface/SiPixelCluster.h"
#include <cassert>
#include <cstdio>
#include <iostream>

typedef SiPixelCluster::PixelPos PiPos;
typedef SiPixelCluster::Pixel Pixel;
#define MAXSPAN 255

template <int N>
inline bool verify(PiPos const (&pos)[N], bool ox, bool oy) {
  bool ok = true;
  SiPixelCluster clus;
  for (auto p : pos)
    clus.add(p, 2);
  printf("\nclus  %d  %d,%d %d,%d %s %s\n\n",
         clus.size(),
         clus.minPixelRow(),
         clus.maxPixelRow(),
         clus.minPixelCol(),
         clus.maxPixelCol(),
         clus.overflowCol() ? "overflowY " : " ",
         clus.overflowRow() ? " overflowX" : "");

  auto cxmin = clus.minPixelRow();
  auto cymin = clus.minPixelCol();
  ok &= (ox == clus.overflowRow()) && (clus.overflowCol() == oy);

  // verify new constructor
  unsigned short adc[16]{2};
  unsigned short x[16];
  unsigned short y[16];
  unsigned short xmin = 16000;
  unsigned short ymin = 16000;
  unsigned int isize = 0;
  for (auto p : pos) {
    xmin = std::min(xmin, (unsigned short)(p.row()));
    ymin = std::min(ymin, (unsigned short)(p.col()));
    x[isize] = p.row();
    y[isize++] = p.col();
  }
  printf("pos  %d  %d,%d\n", isize, xmin, ymin);
  SiPixelCluster clus2(isize, adc, x, y, xmin, ymin);
  printf("clus2 %d  %d,%d %d,%d %s %s\n\n",
         clus2.size(),
         clus2.minPixelRow(),
         clus2.maxPixelRow(),
         clus2.minPixelCol(),
         clus2.maxPixelCol(),
         clus2.overflowCol() ? "overflowY " : " ",
         clus2.overflowRow() ? " overflowX" : "");

  ok &= (clus.size() == clus2.size());
  ok &= (clus.pixelOffset() == clus2.pixelOffset());
  for (int i = 0; i != clus.size(); ++i) {
    auto const p = clus.pixel(i);
    auto const p2 = clus2.pixel(i);
    ok &= (pos[i].row() - cxmin > MAXSPAN) ? p.x == MAXSPAN + cxmin : p.x == pos[i].row();
    ok &= (pos[i].col() - cymin > MAXSPAN) ? p.y == MAXSPAN + cymin : p.y == pos[i].col();
    printf("%d,%d %d,%d %d,%d\n", pos[i].row(), pos[i].col(), p.x, p.y, p2.x, p2.y);
  }

  return ok;
}

int main() {
  std::cout << "size " << sizeof(SiPixelCluster) << std::endl;

  bool ok = true;

  PiPos const normal[] = {{3, 3}, {3, 4}, {3, 5}, {5, 4}, {4, 7}, {5, 5}};
  PiPos const bigX[] = {{3, 3}, {3, 60}, {3, 5}, {161, 4}, {162, 62}, {262, 5}};
  PiPos const bigY[] = {{3, 3}, {3, 100}, {3, 5}, {61, 264}, {62, 102}, {45, 65}};
  PiPos const ylarge[] = {{3, 352}, {3, 352}, {3, 400}, {20, 400}, {40, 363}, {62, 350}};
  PiPos const huge[] = {{3, 3}, {3, 332}, {3, 400}, {201, 400}, {262, 323}, {122, 350}};

  ok &= verify(normal, false, false);
  assert(ok);
  ok &= verify(bigX, true, false);
  assert(ok);
  ok &= verify(bigY, false, true);
  assert(ok);
  ok &= verify(ylarge, false, false);
  assert(ok);
  ok &= verify(huge, true, true);
  assert(ok);

  return ok ? 0 : 1;
}