H3 是一个基于十六个分辨率等级的层次化空间索引系统,其核心是将地球表面划分为以六边形为主的网格体系。
1. 核心几何逻辑:为什么是六边形?
在球面铺满网格时,通常有三种正多边形可选:三角形、正方形、六边形。H3 选择六边形基于以下关键特性:
-
距离一致性(Uniform Adjacency): 六边形中心到所有相邻单元格(6 个)中心的距离是完全相等的。相比之下,正方形有 4 个边邻居和 4 个角邻居(距离不同),这会导致路径分析和缓冲区计算产生方向性偏差。
-
拓扑结构简单: 六边形只有"边相邻",不存在正方形那种模糊的"点相邻"概念,非常适合处理扩散模拟、覆盖半径等算法。
-
最佳采样效率: 六边形是最接近圆形的等效多边形,在空间采样中具有更高的效率。
2. 球面投影与五边形(Pentagons)
由于无法在球面上仅用正六边形进行无缝铺满(欧拉示性数限制),H3 引入了以下设计:
-
二十面体投影: H3 使用正二十面体作为基础,将其投影到球体上。
-
12 个五边形: 为了闭合球面,在二十面体的 12 个顶点处,必须存在 12 个五边形。
-
每一级分辨率都有且仅有 12 个五边形。
-
五边形的面积比同级六边形约小 20%。
-
在进行拓扑运算(如查找邻居)时,五边形只有 5 个邻居。
-
3. 分级结构:孔径 7 (Aperture 7)
H3 的层级递进采用的是 Aperture 7 模式,这意味着:
-
数量关系: 每个父级单元格粗略对应 7 个 子级单元格。
-
面积比例: 每一级分辨率的单元格面积约为上一级的 1/7。
-
旋转特性: 由于几何上的重合限制,子级网格相对于父级网格会产生约 19.1\^\\circ 的角度偏转。这种旋转在奇数级和偶数级之间交替发生。
4. 全球分辨率参数表
以下是 H3 网格在不同分辨率下的物理参数(平均值):
| 分辨率 | 平均面积 (km2) | 平均边长 (km) | 全球总单元格数 |
|---|---|---|---|
| 0 | 4,250,546.85 | 1,107.71 | 122 |
| 2 | 86,745.85 | 158.24 | 5,882 |
| 5 | 252.90 | 8.54 | 2,016,842 |
| 7 | 5.16 | 1.22 | 98,825,162 |
| 8 | 0.737 | 0.46 | 691,776,122 |
| 9 | 0.105 | 0.17 | 4,842,432,842 |
| 12 | 0.000307 | 0.0094 | 1,660,954,464,122 |
5. 索引结构 (Bit Layout)
H3 索引是一个 64 位(uint64) 的整数,这种结构使其在数据库检索中极快。
-
模式位 (Mode): 区分普通单元格、单向边或顶点。
-
分辨率位 (Resolution): 标识当前层级(0-15)。
-
基础单元格 (Base Cell): 标识全球最初的 122 个基础单元格。
-
路径位 (Child Path): 每 3 位代表一层子级的方向选择(0-6)。通过按位右移操作,可以瞬间获取父级索引。
6. 网格特性总结
-
非绝对均匀: 受投影影响,同一个分辨率下的六边形边长和面积并非绝对相等,靠近顶点处会有轻微变形。
-
层次嵌套: 子级中心点并不一定完全落在父级中心点上(除非是中心那个子 Cell),但空间覆盖上具有极强的包含关系。
-
计算友好: 相比经纬度下的矩形围栏计算,H3 的 64 位整数匹配和邻居步进(Grid Disk)在工程上具有极高的性能优势。
维智 Android 定位 SDK是一套面向 Android 移动端应用的简单易用定位服务接口,为开发者提供融合定位能力。通过使用维智定位 SDK,开发者可以在不直接依赖底层 NLP 实现质量的前提下,为应用快速集成 极速、智能、精准、高效 的定位功能。