当前位置: 首页 > news >正文

渭南市网站建设_网站建设公司_Java_seo优化

各大网站收录入口,如意影院,全国中小企业网站,做网络推广一般是什么专业算法简介geohash是实现空间索引的一种算法,其他实现空间索引的算法有:R树和其变种GIST树、四叉树、网格索引等算法基本原理geohash算法将地球理解为一个二维平面#xff0c;将平面递归分解成更小的子块#xff0c;每个子块在一定经纬度范围内拥有相同的编码#xff0c;这种方…算法简介geohash是实现空间索引的一种算法,其他实现空间索引的算法有:R树和其变种GIST树、四叉树、网格索引等算法基本原理geohash算法将地球理解为一个二维平面将平面递归分解成更小的子块每个子块在一定经纬度范围内拥有相同的编码这种方式简单粗暴可以满足对小规模的数据进行经纬度的检索通过对经纬度的分割,将地球分割成无数的小正方形,每个区域,就是个geohash编码Geohash其实就是将整个地图或者某个分割所得的区域进行一次划分由于采用的是base32编码方式即Geohash中的每一个字母或者数字(如wx4g0e中的w)都是由5bits组成(2^5 32base32)这5bits可以有32中不同的组合(0~31)这样我们可以将整个地图区域分为32个区域通过00000 ~ 11111来标识这32个区域。第一次对地图划分后的情况如下图所示(每个区域中的编号对应于该区域所对应的编码)如图:算法实现(php)以经纬度值(118.6197800000,24.88849)进行算法说明对纬度24.88849进行逼近编码 (地球纬度区间是[-90,90])纬度区间[-90,90]进行二分为[-90,0],[0,90],命名为左右区间,坐标属于右区间记为1,左区间为0,24.88849为右区间,记为1对所在区间进行再次划分[0,90]二分为[0,45],[45,90],24.88849属于左区间,左区间记为0以下是php的纬度区间算法函数:/*** param float $num经度或纬度* param string $str递归字符串* param int $i 递归次数* param int $max_separate_num递归总次数* param array $data 区间值* return string*/function separate( $num  24.999,$str,$i1,$max_separate_num20,$data  array(min  -90, max  90)){$count    ($data[max] - $data[min]) / 2;$limit_0  array(min  $data[min],max  $data[min]  $count);$limit_1  array(min  $data[min]  $count,max  $data[max]);//    var_dump($limit_0,$limit_1);$str.$num  $limit_1[min]?1:0;if($i$max_separate_num){return $str;}else{return separate($num,$str,$i1,$max_separate_num,$num  $limit_1[min]?$limit_1:$limit_0);}}由此,纬度24.88849可得字符串为10100011011001011001经度118.6197800000,经度分为东经和西经,区间为[-180,180],由此可得字符串11010100010110100001组合2个字符串,偶数放经度位,奇数放纬度位,php代码实现/*** param $latitude_str 纬度* param $longitude_str 经度*/function combination($latitude_str, $longitude_str){$str  ;for ($i  0; $i 经度$str . $longitude_str{$i};if(isset($latitude_str{$i})){$str .  $latitude_str{$i};}}return $str;}每隔5位取出一串,转为10进制,最后使用[0-9][b-z]去掉a, i, l, o这32个字符进行编码.php代码实现function geohash_encode($str){$arr      [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, b, c, d, e, f, g, h, j, k, m, n, p, q, r, s, t, u, v, w, x, y, z];$str_arr  str_split($str, 5);//按5位分割字符串$str      ;//    var_dump($str_arr);die;foreach ($str_arr as $va) {$decimal  bindec($va);$str.$arr[$decimal];}return $str;}这样,就得到了一串wskme6b3字符串了,该字符串就表示了一个区域geohash算法使用:根据附录精度,传入经纬度生成geohash编码,存入数据库,例如:当需要查询附近某个区域块点时,只需要,就可以查出该区域块所有数据select * from dm_gps where geohash like wskme% (记得加索引)用法补充:当碰到需要渲染一整个地图,而数据量大的时候怎么办?总不可能把几千万的点全部查出来渲染吧?可以新增一个大区域块统计表,将精度更小的数据进行分组并且统计总数,例如:gps_id无用字段,请忽略查出精度为2的数据:当地图放大时:可相应的查出:level3,level4.....等等数据精度bug一:如图:当查询红点所在区域时,数据库只能查询到该区域块右下角的点,而找不到离他更近的上面的绿点该bug可通过查询周围8个区域块进行再次比对,或者增加精度到厘米级别,就可忽略该bug附录:geohash精度php扩展php已经实现了对geohash的扩展,其他补充等有时间,将会把geohash解码算法发出来本文为仙士可原创文章,转载无需和我联系,但请注明来自仙士可博客www.php20.cn
http://www.ihoyoo.com/news/136317.html

相关文章:

  • 合肥设网站长沙市做网站公司
  • 站长工具高清有吗百度西安分公司地址
  • 戴尔电脑网站建设方案范文建设工程检测预约网站
  • 微网站开发用什么软件侧边栏jquery网站后台
  • 深圳外包网站各大网站网络推广的收费
  • 电商网站建设 网站定制开发网站开发需要自己写代码吗
  • 重庆永川网站建设价格直播软件哪个最好用
  • 做两个阿里网站淘宝网页版登陆
  • 无锡网站策划公司做行业门户网站注意什么
  • 国内高端品牌网站建设做物流哪个网站推广效果好
  • 深圳宝安商城网站建设公司教育网站开发价钱
  • 株洲网站制作个人网站开发的背景
  • 网站开发属于软件吗校园网站制作模板
  • app客户端网站建设方案北京网站制作net2006
  • 旅游网站开发目标网站建设与网站开发
  • 广德网站建设网站建设作品
  • jquery网站后台山东百度推广总代理
  • 企业微站系统做海报推荐网站
  • 百度搜索不到公司网站深圳公共资源交易中心官网
  • 做网站优化的价格企业网站 免费 php
  • 湖南住房与城乡建设部网站手机网站修改
  • 如何制作企业的网站微信报名小程序怎么制作
  • 动漫网站源码做营销网站制作
  • 北京网站建设 招聘信息建设官方网站登录
  • 网站建设有那些内容有哪些静态网站
  • 台州网站专业制作建设工程用地批准手续在哪个网站
  • 南昌旅游集团网站建设安丘网站开发
  • 如何建手机销售网站青岛互联网公司排名
  • 营销型网站建设课程培训现场黄浦区网站建设
  • 如何做购物网站的后台网站建设与管理收获