当前位置: 首页>>代码示例>>C++>>正文


C++ SegmentList::at方法代码示例

本文整理汇总了C++中SegmentList::at方法的典型用法代码示例。如果您正苦于以下问题:C++ SegmentList::at方法的具体用法?C++ SegmentList::at怎么用?C++ SegmentList::at使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SegmentList的用法示例。


在下文中一共展示了SegmentList::at方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: watershed

SegmentList WaterShedDecomposer::watershed(ImageGray const & gradient,
                                           ImageColor const & image) const {
   SegmentList segments;
   std::unique_ptr<int[]> labels(new int[image.area()]);
   for (int i=0; i<image.area(); ++i) labels[i] = -1;

   int offsets[]{-image.width(), -1, 1, image.width()};

   QList<GradPixelRef> queue;
   for (int i=0; i<gradient.area(); ++i) {
      queue << GradPixelRef{gradient.at(i).l, i};
   }
   std::sort(queue.begin(), queue.end(), lessThan);

   int label;
   int lastLabel = -1;
   int i, j;
   QList<int> neighLbls;
   Pixel * pixel;
   Segment * segment;
   foreach (GradPixelRef const & gradPix, queue) {
      i = gradPix.index;
      pixel = new Pixel(Position(i%image.width(), i/image.width()), image.at(i));

      // gather neighbours
      neighLbls.clear();
      for (int o=0; o<4; ++o) {
         j = i + offsets[o];
         if (image.areNeighbours(i, j) && labels[j] > -1 && !neighLbls.contains(labels[j])) {
            neighLbls << labels[j];
         }
      }

      // treat pixel according to neighbour count
      switch (neighLbls.size()) {
      case 0: // new marker
         labels[i] = ++lastLabel;
         segment = new Segment();
         segment->addPixel(pixel);
         segments << segment;
         break;
      case 1: // add to basin
         label = neighLbls.first();
         labels[i] = label;
         segments.at(label)->addPixel(pixel);
         break;
      default: // new watershed
         // add pixel the segment of the nearest neighbour in color
         double distMin = std::numeric_limits<double>::max();
         double dist;
         int jMin = 0;
         for (int o=0; o<4; ++o) {
            j = i + offsets[o];
            if (image.areNeighbours(i, j) && labels[j] > -1) {
               dist = (image.at(i)-image.at(j)).magnitudeSquared();
               if (dist < distMin) {
                  distMin = dist;
                  jMin = j;
               }
            }
         }
         labels[i] = labels[jMin];
         segments.at(labels[jMin])->addPixel(pixel);

         // beneighbour the segments
         for (int k=0; k<neighLbls.count()-1; ++k) {
            for (int l=k+1; l<neighLbls.count(); ++l) {
               segments.at(neighLbls.at(k))->addNeighbour(segments.at(neighLbls.at(l)));
               segments.at(neighLbls.at(l))->addNeighbour(segments.at(neighLbls.at(k)));
            }
         }
         break;
      }
   }
开发者ID:Svensational,项目名称:tidy,代码行数:74,代码来源:watersheddecomposer.cpp


注:本文中的SegmentList::at方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。