论文笔记:Localizing Cell Towers fromCrowdsourced Measurements

news2025/1/12 8:49:02

2015

1 Intro

1.1 motivation

  • opensignal.com 、cellmapper.net  和 opencellid.org 都是提供天线(antenna)位置的网站
    • 他们提供的天线位置相当准确,但至少在大多数情况下不完全正确
    • 这个目标难以实现的原因是蜂窝网络供应商没有义务提供有关天线位置的数据,只有在少数特定国家才知道一些正确的蜂窝网络天线位置
    • 那么这些网站如何知道其余的天线在哪里呢?答案是众包(crowdsourcing)
      • 众包涉及使用大量人群来完成任务或解决问题
      • 将某事外包给一个未定义的人群。
      • 这样的人群通常彼此不认识,就像在线社区或一般公众一样。
      • 当众包过程启动时,发起者向目标人群提出请求。
        • App收集手机连接的天线、接收信号的强度和智能手机的位置等数据
        • 这种数据收集,也称为测量
  • 这篇论文进行的研究是:我们如何基于众包数据估计蜂窝网络天线的位置?

1.2 OpencellID的方法

  • OpenCellID 用来计算蜂窝网络天线位置的算法非常简单。
    • 基于为天线收集的测量数据,将天线的经纬度坐标设置为这些测量的经纬度的平均值
  • 不是一个好方法,因为天线以通常水平方向120度的披萨片形状广播信号。全向天线非常罕见
    • 这意味着 OpenCellID 中的大多数天线被估计位于披萨片形扇区的大约中间,而正确的位置应该是每次测量都在天线120度范围内的某个方向

1.3 了解天线位置的好处

  • 最直接的应用是作为GPS的替代品
    • GPS 为接收到四个以上 GPS 卫星信号的设备提供不到 1 米的定位误差,但需要特殊的硬件技术,这既昂贵又耗能
    • 假设我们知道每个蜂窝网络天线的正确位置,以及每个天线正在向哪些移动设备广播。那么我们可以使用这些信息来定位和跟踪个别设备
    • GPS 的一种经济有效的替代方案
    • 特别是在 GPS 不可用的地方,通过蜂窝网络进行定位可以是一项宝贵的资产
  • 对于个人用户来说,了解蜂窝网络天线位置可以帮助他们在居住地区找到最佳网络提供商
    • 如果用户担心无线电波的辐射,他可以根据追踪蜂窝网络天线位置收集到的无线电发射数据来选择居住区域
  • 社会也可以从移动设备的蜂窝网络天线定位中受益
    • 通过收集连接到数十个移动设备的天线数据,例如在一天或一年中的特定时间,或在下雨或阳光明媚时,可以帮助发展基础设施或文化游览地点。
    • 例如,这样的数据可以证明在许多人经过的路径沿线建新路,或在夏天阳光明媚时许多人经过的地方建游乐园的决策是合理的

1.4 Preliminary

  • 一个“小区”(cell)是由蜂窝网络天线(antenna)覆盖的地理区域​​。
    • 来自这个天线的信号有潜力到达小区内的每个移动设备
  • 天线位于一个小区塔(cell tower)上,或更一般地说是一个基站(base station)
  • 一个小区的覆盖区域为“小区扇区”(cell sector),小区扇区的角度为“小区扇区角度”(cell sector angle),小区扇区的边缘为“小区边缘”(cell edges)。这些组件,连同测量数据,构成了一个小区
    • 小区扇区角度在大多数情况下总是120°。一些蜂窝网络提供商也使用小区扇区角度更小的小区,例如60°。这在例如城市地区可能是有益的。
    • 通常,三个或更多小区共享一个小区塔以覆盖小区塔周围360°角度内的所有内容。
    • 小区塔将有几个指向不同方向的天线
  • 为了避免断开连接并支持高需求,小区和小区塔理论上如下图组织
    • 将小区想象为一个六边形系统
    • 每个六边形至少由三个不同的小区塔覆盖
    • 小区塔或天线的强度可能覆盖超过自己的六边形
      • 这确保了对用户的有效重叠和蜂窝网络的持续连接
  • 实际上,维护六边形系统是困难的
    • 小区塔需要放置在一定高度,且在试图覆盖特定区域时必须考虑建筑物、山脉或其他障碍物
    • 城市地区可能需要多个天线来覆盖有许多障碍物的小区域,而农村地区可能比理论上需要的少

2 方法1:Cell Tower Localization based on Distance (D-CTL)

2.1 小cell angle

  • 假设小区在狭窄的扇区内广播,比如10°而不是120°,来简化我们的问题定义。
    • ——>意味着小区覆盖的区域更集中
  • 还假设接收信号强度(RSS)不可用,并且从小区塔到测量点的最大距离为113。
    • ——>利用小区内测量点之间的距离来估算小区塔的位置

2.2  子步骤1: D-DL(基于距离的方向线)子程序

2.2.1 问题举例

  • 在图4.1a中,显示了一个具有10°小区扇区和20个随机分布的测量点的生成小区
  • 现在假设我们不知道小区塔的位置或小区边缘的角度,如图4.1b所示
  • 我们提出以下问题:当我们只知道测量点的位置时,小区塔位于测量点的哪个方向?
    • 通过观察图形我们可以轻松猜测答案,但我们需要以算法的方式得出答案。

2.2.2 D-DL 算法

2.3 子步骤2 & 子步骤3 :计算扇区 & 查找扇区

  • 我们现在假设我们已经使用了D-DL来计算 l_direction,其端点为 ep1 和 ep2
    • l_direction 提供了关于我们估计小区塔位于测量点的哪个方向的信息。
  • 由于我们对测量点没有比它们的位置更多的信息,因此我们无法知道正确的小区塔是位于 ep1 还是 ep2。
    • 因此,我们为两个端点各自计算估计的小区扇区
  • D-CTL算法的第二和第三个子程序:计算扇区(CS)和查找扇区(FS)
    • CS和FS的目的是计算由 l_direction 的一个端点生成的小区扇区 C_{heuristic},以便每个测量点 m ∈ M 都适合其中
    • FS通过进行多次迭代来计算C_{heuristic}。对于每次迭代,如果每个 m 不适合当前计算的小区扇区,FS 将对 CS 进行新的调用,延长 l_direction,从而计算出新的小区扇区
  • 下边对于CS和FS的介绍,都以小区塔在ep1为例,ep2同理

2.3.1 计算扇区

  • CS以 l_direction 和 α 为输入,其中 α 是小区扇区角度。
  • 它首先围绕 ep1 向两个方向各旋转 l_direction,角度为 α/2
  • 然后,它返回,ep1 作为小区塔位置,以及从旋转 l_direction 得到的两条线作为小区边缘

2.3.2 查找扇区

  • FS 以 M、l_direction、d_{extend}和 α 为输入,其中d_{extend}是一个常数
  • 它首先声明变量C_{heuristic}
  • 然后它调用 CS 来计算初始估计的小区扇区,原始的 ep1 作为小区塔位置,并将其存储在 C_{heuristic}
  • 然后它进行多次迭代。
    • 对于每次迭代:如果 m 不适合C_{heuristic},它将 l_direction 沿着 ep1 以常数长度 d_{extend} 扩展
    • 对 CS 进行新的调用,将新的 l_direction 作为输入
  • 当每个 m 都适合C_{heuristic}时,迭代停止

2.4 步骤4:根据距离选择方向(D-CD)

  • 现在假设我们已经使用了D-DL来计算 l_direction,其端点为 ep1 和 ep2,并且使用了FS来计算两个估计的小区扇区解决方案 Cheuristic1 和 Cheuristic2。
  • 现在我们想选择其中一个作为最终估计的小区扇区解决方案和相应的小区塔位置

2.4.1 假设

  • 在一个小区扇区中,我们离小区塔越远,形成小区边缘的两条线 l1 和 l2 之间的距离就越大
  • 一个完美代表小区指向的线 l 应该与小区塔相交,并在 l1 和 l2 之间,使得从 l 到 l1 的距离和从 l 到 l2 的距离始终相等

  • 这意味着离小区塔较远的测量点可能比靠近它的测量点离 l 更远。
  • 现在考虑 l 的两个端点 lep1 和 lep2,以及我们随机分布的测量点。
    • 设 S1 为更接近 lep1 的测量点子集,S2 为 更接近 lep2 的测量点子集。
    • 我们计算 S1 中测量点到 l 的最小可能距离的平均值 mean1,以及 S2 中测量点到 l 的最小可能距离的平均值 mean2。
    • 如果 mean1 < mean2,则 lep1 是 l 在正确的小区塔位置的端点。
    • 如果 mean2 < mean1,则 lep2 是 l 在正确的小区塔位置的端点。
  • 这个假设对于每个 10 <= α <= 120 都适用。

2.4.2 D-CD 算法

  • 我们没有这样一个完美的方向线 l,所以我们改用 l_direction,其端点为 ep1 和 ep2

2.5 方法1 对应的实验

2.5.1 d_extend(子步骤3每次l_direction增加长度)对于结果的影响

2.5.2 max_distance(每个信号站的最远波及范围)的影响

2.5.3 小区夹角的影响

3 方法2:Cell Tower Localization based on Received Signal Strength (RSS-CTL)

  • 基于属于小区的测量数据中的接收信号强度(RSS)值来估算小区塔的位置

3.1 大cell angle——基于接收信号强度估计基站位置

  • 这一章假设α=120°
  • 假设每个测量都配备了 RSS。我们现在将利用 RSS 而不是测量点之间的距离来估算小区塔位置

3.2 基于RSS 计算direction LIne(RSS-DL)

RSS-DL与D-DL子程序的唯一区别在于,RSS-DL比较的是两个测量点之间的RSS值,而不是距离

3.3 基于RSS 计算扇区& 查找扇区

CS和FS不做修改

3.4 基于RSS 选择方向

和前面的D-CD类似,区别是这里计算S1和S2 RSS的平均值,而不是距离的平均值

3.5 方法2对应的实验

3.5.1 d_extend

3.5.2 max_distance

4 OpenCellId上进行测试

(这里研究的主要是挪威的数据)

4.1 数据结构

  • OpenCellID 数据的结构如下所述。其中包含小区(cell)和测量(measurement)对象
    • 当收集到的测量数据是之前未见过的小区时,会创建一个新的小区对象
    • 每次为小区添加新测量时,小区对象的几个数据字段都会更新

论文给出的opencellId 数据结构我并没有在官网上 找到。。。

4.2 数据梗概

4.2.1 Identification

一个小区通过四个不同的值来识别;mcc(移动国家码)、net(网络运营商码)、area(区域码)和cell(小区码)。这些分别告诉我们哪个国家、哪个蜂窝网络提供商、该国内的哪个区域以及哪个ID属于该小区。

4.2.2 基站的实际位置是否已知

  • OpenCellID通过计算小区测量点的经度和纬度的平均值来估算该小区的小区塔位置
  • 但也有一些例外情况
  • changeable字段告诉我们小区塔位置是否已经使用可用测量数据计算过
    • 为0,则该小区塔的位置是正确的
    • 在这种情况下,OpenCellID已经从某些国家的某些蜂窝网络提供商那里获得了关于正确小区塔位置的数据。这涉及的国家包括俄罗斯、德国和波兰
  • 论文代数据库中的每个小区,检查每个小区的changeable值,并存储changeable值为0的每个小区的mcc值

4.3 过滤数据

4.3.1 GSM

论文选择GSM小区作为测试算法的数据集合

4.3.2 changeable

只考虑changeable为0,也即运营商提供数据的部分

4.4 清洗数据

4.4.1 r_include 验证测量到小区塔的距离

  • 小区塔的广播范围不是无限远的,有些测量距离其所属小区塔太远,不能视为有效
    • 如果测量距离正确的小区塔位置超过 rinclude 的值,我们在运行 D-CTL 和 RSS-CTL 算法时不会包括这个测量
    • 当我们不知道正确的小区塔位置时,我们计算测量的经度和纬度的平均值,并使用这个测量的几何中心作为r_include的原点
  • Macro-cell 是具有最强广播能力的小区类型
    • 标准理论范围是35公里
    • 使用这个距离作为验证测量到其小区塔距离的最大 r_include 值

4.4.2 接收信号强度(RSS)验证

  • 测量的 RSS 要么是 dBm 值,要么是 0 到 31(包含)之间的数字
    • 蜂窝信号的 dBm 值总是负数
      • ——>定义了从负 dBm 值到正数的映射

\

  • RSS 值大于 31 的测量将不被视为有效。当在包含 0 到 31 的 RSS 值的测量的小区上运行 D-CTL 和 RSS-CTL 算法时,论文将这些转换为 dBm 值(2x-113)

4.4.3 小区测量中的接收信号强度值

  • 需要考虑一个小区的所有测量中不同 RSS 值的总数
    • ——阈值设置为3

4.4.4 m_max,m_min

  • 每个小区的测量数量

4.4.5 有效测量标准

  • 与正确的小区塔位置的距离小于或等于 rinclude。
  • RSS 值小于或等于 31

4.4.6 有效小区标准

  • 测量中不同 RSS 值的总数大于或等于 3。
  • 测量总数不少于 mmin 且不超过 mmax。

5 在挪威卑尔根的实验结果

5.1 和OpenCellID相比的结果

其实没有OpenCellID能打。。。

5.2 运行时间

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1240596.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

0基础学习VR全景平台篇第122篇:VR视频剪辑和输出 - PR软件教程

上课&#xff01;全体起立~ 大家好&#xff0c;欢迎观看蛙色官方系列全景摄影课程&#xff01; 开始之前如果没有接触过pr这款软件的话&#xff0c;建议先去看上一篇 认识视频剪辑软件Premiere 大致了解一下pr。 回到正题今天来教大家VR视频的剪辑和输出 我们先双击打开…

5-6求1-20的阶乘和

#include<stdio.h> //求阶乘 int main(){int n;double sum0;//求和&#xff1a;一点一点加int t1;for (n1;n<15;n){tt*n;sumsumt;}printf("结果是&#xff1a;%22.15e \n",sum);return 0; }为啥最后是%22.15e呢&#xff1f; 因为这个求和的结果太大了 所以转…

基于JavaWeb+SSM+Vue家庭记账本微信小程序系统的设计和实现

基于JavaWebSSMVue家庭记账本微信小程序系统的设计和实现 源码获取入口前言主要技术系统设计功能截图Lun文目录订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 前言 1.1选题背景 互联网是人类的基本需求&#xff0c;特别是在现代社会&#xff0c;个人…

MongoDB的常用操作以及python连接MongoDB

一,MongoDB的启动 mongod --dbpath..\data\db mongodb注意同时开两个窗口&#xff0c;不要关&#xff01; 二, MongoDB的简单使用 简单介绍一下mongoDB中一些操作 show dbs: 显示所有数据库 show databases: 显示所有数据库 use xxxx: 使用指定数据库/创建数据库&#xff08…

Jina AI 的 8K 向量模型上线 AWS Marketplace,支持本地部署!

在当前多模态 AI 和大模型技术风头正劲的背景下&#xff0c;Jina AI 始终领跑于创新前沿&#xff0c;技术领先。2023 年 10 月 30 日&#xff0c;Jina AI 隆重推出 jina-embeddings-v2&#xff0c;这是全球首款支持 8192 输入长度的开源向量大模型&#xff0c;其性能媲美 OpenA…

【计算机基础】通过插件plantuml,实现在VScode里面绘制状态机

&#x1f4e2;&#xff1a;如果你也对机器人、人工智能感兴趣&#xff0c;看来我们志同道合✨ &#x1f4e2;&#xff1a;不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 &#x1f4e2;&#xff1a;文章若有幸对你有帮助&#xff0c;可点赞 &#x1f44d;…

frp内网穿透配置以及相关端口、过程解释

介绍 假设现有外网笔记本、云服务器、内网工作站三台设备&#xff0c;希望使用外网笔记本通过云服务器转发&#xff0c;访问内网工作站&#xff1b;这里使用frp进行内网穿透。 云服务器端配置 登录腾讯轻量型云服务器控制台&#xff0c;开放转发端口、bind_port以及deshboad…

【开源】基于JAVA的开放实验室管理系统

项目编号&#xff1a; S 013 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S013&#xff0c;文末获取源码。} 项目编号&#xff1a;S013&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、研究内容2.1 实验室类型模块2.2 实验室模块2.3 实…

黑马React18: ReactRouter

黑马React: ReactRouter Date: November 21, 2023 Sum: React路由基础、路由导航、导航传参、嵌套路由配置 路由快速上手 1. 什么是前端路由 一个路径 path 对应一个组件 component 当我们在浏览器中访问一个 path 的时候&#xff0c;path 对应的组件会在页面中进行渲染 2. …

【开源】基于JAVA的音乐偏好度推荐系统

项目编号&#xff1a; S 012 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S012&#xff0c;文末获取源码。} 项目编号&#xff1a;S012&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、系统设计2.1 功能模块设计2.1.1 音乐档案模块2.1…

基于爬行动物算法优化概率神经网络PNN的分类预测 - 附代码

基于爬行动物算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于爬行动物算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于爬行动物优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神…

SSM之Mybatis框架

1 概述 1.1 什么是Mybayis 它是一款半自动的ORM持久层框架&#xff0c;具有较高的SQL灵活性&#xff0c;支持高级映射(一对一&#xff0c;一对多)&#xff0c;动态SQL&#xff0c;延迟加载和缓存等特性&#xff0c;但它的数据库无关性较低。 1.2 什么是ORM ORM&#xff08;…

黑马点评笔记 redis实现缓存

文章目录 什么是缓存?为什么要使用缓存 如何使用缓存功能实现缓存模型和思路代码实现 缓存更新策略数据库缓存不一致解决方案代码实现 什么是缓存? 缓存(Cache),就是数据交换的缓冲区,俗称的缓存就是缓冲区内的数据,一般从数据库中获取,存储于本地代码(例如: 例1:Static fi…

SpringBoot:kaptcha生成验证码

GitHub项目地址&#xff1a;GitHub - penggle/kaptcha: kaptcha - A kaptcha generation engine. kaptcha介绍 kaptcha官网&#xff08;Google Code Archive - Long-term storage for Google Code Project Hosting.&#xff09;对其介绍如下&#xff0c; kaptcha十分易于安装…

刚刚!OpenAI官宣!Sam Altman回归OpenAI 担任CEO

大家好我是二狗&#xff0c;就在刚刚&#xff01; OpenAI宣布&#xff0c;Sam Altman将重新回到 OpenAI 担任CEO。 并组建由Bret Taylor&#xff08;主席&#xff09;、Larry Summers 和 Adam DAngelo 组成的新的初始董事会。 Sam Altman第一时间做了石锤回应&#xff1a; Sa…

office word 使用笔记

office word 使用笔记 1. 功能1.1 格式快捷键1.2 复选框 2 遇到过的问题2.1 表格标题和表格距离过大 1. 功能 1.1 格式快捷键 复制格式&#xff1a;ctrl shift c 粘贴格式&#xff1a;ctrl shift v 1.2 复选框 方框位置和类型&#xff1a;“插入——高级符号——字体”选…

pikachu靶场Table pikachu.member doesn’t exist:解决

背景&#xff1a; 第一次搭建pikachu靶场&#xff0c;搭建好后访问index.php后&#xff0c;尝试练习&#xff0c;发现界面显示Table pikachu.member doesn t exist&#xff0c;后来找了很多教程&#xff0c;没有解决&#xff0c;后来发现是自己没有进行初始化&#xff0c;给大家…

【JDK源码阅读】什么是 avoid getfield opcode ?

说明&#xff1a;JDK源码版本为 Oracle JDK 8 1. 背景 阅读 java.lang.String 的源码&#xff0c;会发现有些地方注释为/* avoid getfield opcode */&#xff0c;此处的代码是将当前类定义的成员变量引用为本地变量&#xff0c;从字面意思理解&#xff0c;是为了避免使用 get…

千云物流 - 使用k8s负载均衡openelb

openelb的介绍 具体根据官方文档进行安装官方文档,这里作为测试环境的安装使用. OpenELB 是一个开源的云原生负载均衡器实现,可以在基于裸金属服务器、边缘以及虚拟化的 Kubernetes 环境中使用 LoadBalancer 类型的 Service 对外暴露服务。OpenELB 项目最初由 KubeSphere 社区…

Echarts实现散点图

效果图如下&#xff1a; <html><head><meta charsetutf-8><link rel"stylesheet" href"js/leaflet1.7.1/dist/leaflet.css"/><script src"js/leaflet1.7.1/dist/leaflet.js"></script><script src"…