0

0

地理空间索引采样器

碧海醫心

碧海醫心

发布时间:2024-12-23 10:39:01

|

1005人浏览过

|

来源于dev.to

转载

我最近做了一个练习,尝试构建一个应用程序,同时假装自己是一个极简主义者。这要求我能够在不使用我久经考验的朋友 postgis 的情况下过滤 gps 点。

我快速浏览了三种最流行的空间数据索引方法:geohash、h3 和 s2。

所有这 3 个工具的工作原理都是将地球分割成形状,当您放大时,这些形状会细分为越来越小的单元。

  • geohash 使用矩形
  • h3 使用六边形
  • s2是狂野的,使用空间填充曲线

探索这些类型的索引如何工作的一个好方法是https://geohash.softeng.co/.当您单击每个单元格时,它会放大并显示更深层次的内容。世界上我最喜欢的地方之一是 geohash ddk6p5

使用这些来“索引”gps 数据就像为您感兴趣的每个级别添加一个文本列一样简单。例如,我可以创建一个如下表:

create table if not exists places (
    id integer primary key autoincrement,
    name text,
    latitude real,
    longitude real,
    geohash_level_2 text,
    geohash_level_4 text
);

insert into places (name,latitude,longitude,geohash_level_2,geohash_level_4)
values('mt shavano', 38.618840, -106.239364, '9w', '9wu7');

insert into places (name,latitude,longitude,geohash_level_2,geohash_level_4)
values('blanca peak', 37.578047, -105.485796, '9w', '9wsv');

insert into places (name,latitude,longitude,geohash_level_2,geohash_level_4)
values('mt princeton', 38.749148, -106.242578, '9w', '9wuk');

insert into places (name,latitude,longitude,geohash_level_2,geohash_level_4)
values('la soufriere', 13.336299, -61.177146, 'dd', 'ddk7');

sqlime 是尝试这些查询的好地方。

然后要查找科罗拉多州南部的地方,我会找到哪个哈希覆盖了地图上的“9w”部分:

樱桃企业网站管理系统3.1 bulid20130614
樱桃企业网站管理系统3.1 bulid20130614

樱桃企业网站管理系统全DIV+CSS模板,多浏览器适应,完美兼容IE6-IE8,火狐,谷歌等符合标准的浏览器,模板样式集中在一个CSS样式中,内容与样式完全分离,方便网站设计人员开发模板与管理。系统较为安全,以设计防注入,敏感字符屏蔽,适合新手自己操作修改。新闻,产品,单页独立关键字设计,提高搜索引擎收录。 后台地址:admin/login.asp 后台账户:admin 密码:admin (

下载
select * from places where geohash_level_2 = '9w';

要查找加勒比海南部的地方,我可以使用:

select * from places where geohash_level_2 = 'dd';

这种方法确实需要预先规划您需要在数据库中保留哪些级别的索引。 否则,它非常适合需要快速查找特定区域或地图视口中找到的对象的简单应用程序。

拥有支持 like 查询的数据库可以帮助减少使用多列的情况。另请注意,h3 单元格编号并不完全重叠,因此“开头为”类型查询不适用于 h3。

最后,这些索引的一个巧妙功能是,单元格数量将成为很棒的实时事件主题。 因此,在上面的示例中,我可以为科罗拉多州南部创建一个名为“9w”的事件主题。然后,随着新地点的添加,我会在每个新地点的“9w”主题中发出一个事件。

以下是每种索引类型的一些示例 javascript (deno) 代码:

请注意,可以在此处查看 geojson 输出:https://geojson.io/

地理哈希

import { geocoordinatetogeohash } from 'npm:geocoordinate-to-geohash'
import { geohashtopolygonfeature } from 'npm:geohash-to-geojson'

import geohash from 'npm:ngeohash'
const lat = 38.618840
const lng = -106.239364
const hash2 = geohash.encode(lat, lng, 2)
console.log('mt shavano hash at level 2', hash2)
const feat2 = geohashtopolygonfeature(hash2)
console.log('mt shavano hash at level 2 bounds', json.stringify(feat2))

// about a city block in size in co (size changes as you head towards poles)
const hash7 = geohash.encode(lat, lng, 7)
console.log('mt shavano hash at level 4', hash7)
const feat7 = geohashtopolygonfeature(hash7)
console.log('mt shavano hash at level 4 bounds', json.stringify(feat7))

h3

import h3 from 'npm:h3-js'
import geojson2h3 from "npm:geojson2h3"

const lat = 38.618840
const lng = -106.239364

// level 2 (~1/3 colorado size)
const h3indexl2 = h3.latlngtocell(lat, lng, 2);
console.log('mt shavano cell at level 2', h3indexl2)
const featurel2 = geojson2h3.h3tofeature(h3indexl2)
console.log('mt shavano cell at level 2 bounds', json.stringify(featurel2))

// level 4 (~city of salida size)
const h3indexl4 = h3.latlngtocell(lat, lng, 4);
console.log('mt shavano cell at level 4', h3indexl4)
const featurel4 = geojson2h3.h3tofeature(h3indexl4)
console.log('mt shavano cell at level 4 bounds', json.stringify(featurel4))

s2

// This might be a better choice : https://www.npmjs.com/package/@radarlabs/s2
import s2 from 'npm:s2-geometry'
const S2 = s2.S2
const lat = 38.618840
const lng = -106.239364

const key2 = S2.latLngToKey(lat, lng, 2)
const id2 = S2.keyToId(key2)
const feature2 = cellCornersToFeatureCollection(lat, lng, 2)
console.log('mt shavano key at level 2', key2)
console.log('mt shavano cell id at level 2', id2)
console.log('mt shavano cell at level 2 corners', JSON.stringify(feature2))

const key4 = S2.latLngToKey(lat, lng, 4)
const id4 = S2.keyToId(key4)
const feature4 = cellCornersToFeatureCollection(lat, lng, 4)
console.log('mt shavano key at level 4', key4)
console.log('mt shavano cell id at level 4', id4)
console.log('mt shavano cell at level 4 corners', JSON.stringify(feature4))

function cellCornersToFeatureCollection(lat, lng, level) {

    const ll = S2.L.LatLng(lat, lng)
    const cell = S2.S2Cell.FromLatLng(ll, level)
    const corners = cell.getCornerLatLngs()
    const coordinates = corners.map((pair) => {
        return [pair.lng, pair.lat]
    })

    return {
        "type": "FeatureCollection",
        "features": [
          {
            "type": "Feature",
            "geometry": {
              "type": "Polygon",
              "coordinates": [coordinates]
            },
            "properties": {}
          }
        ]
      }
}

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

智谱清言 - 免费全能的AI助手
智谱清言 - 免费全能的AI助手

智谱清言 - 免费全能的AI助手

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

377

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2094

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

356

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

419

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

450

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

230

2023.10.19

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

21

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3.8万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.6万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 94人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号