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


C++ TileIndex::is_null方法代码示例

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


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

示例1: find_child_overlapping_time

TileIndex Channel::find_child_overlapping_time(TileIndex ti, double t, int desired_level) const {
  assert(!ti.is_null());
  // Start at root tile and move downwards

  while (ti.level > desired_level) {
    // Select correct child
    TileIndex child = t < ti.left_child().end_time() ? ti.left_child() : ti.right_child();
    
    if (child.is_null() || !tile_exists(child)) break;
    ti = child;
  }

  return ti;
}
开发者ID:TannerTaphorn,项目名称:datastore,代码行数:14,代码来源:Channel.cpp

示例2: read_bottommost_tiles_in_range

void Channel::read_bottommost_tiles_in_range(Range times,
                                             bool (*callback)(const Tile &t, Range times)) const {
  ChannelInfo info;
  bool success = read_info(info);
  if (!success) return;
  if (!info.times.intersects(times)) return;

  double time = times.min;
  TileIndex ti = TileIndex::null();
  while (time < times.max) {
    if (ti.is_null()) {
      ti = find_lowest_child_overlapping_time(info.nonnegative_root_tile_index, times.min);
    } else {
      ti = find_lowest_successive_tile(info.nonnegative_root_tile_index, ti);
    }
    if (ti.is_null() || ti.start_time() >= times.max) break;

    Tile t;
    assert(read_tile(ti, t));
    if (!(*callback)(t, times)) break;
  }
}
开发者ID:TannerTaphorn,项目名称:datastore,代码行数:22,代码来源:Channel.cpp

示例3: read_data

void Channel::read_data(std::vector<DataSample<double> > &data, double begin, double end) const {
  double time = begin;
  data.clear();

  Locker lock(*this);  // Lock self and hold lock until exiting this method

  ChannelInfo info;
  bool success = read_info(info);
  if (!success) {
    // Channel doesn't yet exist;  no data
    if (verbosity) log_f("read_data: can't read info");
    return;
  }
  bool first_tile = true;

  while (time < end) {
    TileIndex ti = find_lowest_child_overlapping_time(info.nonnegative_root_tile_index, time);
    if (ti.is_null()) {
      // No tiles; no more data
      if (verbosity) log_f("read_data: can't read tile");
      return;
    }

    Tile tile;
    assert(read_tile(ti, tile));
    unsigned i = 0;
    if (first_tile) {
      // Skip any samples before requested time
      for (; i < tile.double_samples.size() && tile.double_samples[i].time < begin; i++);
    }

    for (; i < tile.double_samples.size() && tile.double_samples[i].time < end; i++) {
      data.push_back(tile.double_samples[i]);
    }
    time = ti.end_time();
  }
}
开发者ID:TannerTaphorn,项目名称:datastore,代码行数:37,代码来源:Channel.cpp


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