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


C++ bit_vector::calc_hamming_similarity方法代码示例

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


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

示例1: similar_row_one

static void similar_row_one(
    const bit_vector& x,
    const pair<string, bit_vector>& y,
    heap_type& heap) {
  uint64_t match_num = x.calc_hamming_similarity(y.second);
  heap.push(make_pair(match_num, y.first));
}
开发者ID:gintenlabo,项目名称:jubatus_core,代码行数:7,代码来源:bit_index_storage.cpp

示例2: calc_euclidean_distance

float calc_euclidean_distance(
    const lsh_entry& entry,
    const bit_vector& bv,
    float norm) {
  const uint64_t hamm = bv.calc_hamming_similarity(entry.simhash_bv);
  if (hamm == bv.bit_num()) {
    // Avoid NaN caused by arithmetic error
    return std::fabs(norm - entry.norm);
  }
  const float angle = (1 - static_cast<float>(hamm) / bv.bit_num()) * M_PI;
  const float dot = entry.norm * norm * std::cos(angle);
  return std::sqrt(norm * norm + entry.norm * entry.norm - 2 * dot);
}
开发者ID:AutonomicSecurity,项目名称:jubatus,代码行数:13,代码来源:lsh_index_storage.cpp


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