使用spark基于出租车GPS数据实现车辆数量统计以及北京每个城区的车辆位置点数分析

使用spark基于出租车GPS数据实现车辆数量统计以及北京每个城区的车辆位置点数分析

本文将介绍如何使用pyspark以及scala实现的spark分析出租车GPS数据,具体来说,我们将计算每个北京城区内的车辆位置点数,以及统计出租车的数量。我们将使用两个数据集:district.txt 包含北京各城区的中心坐标和半径,taxi_gps.txt 包含出租车的GPS位置数据。以下是数据文件的示例内容

1、数据解析

出租车GPS数据文件(taxi_gps.txt)
在这里插入图片描述
北京区域中心坐标及半径数据文件(district.txt)
在这里插入图片描述

2、需求分析

·能够输出以下统计信息
·A:该出租车GPS数据文件(taxi_gps.txt)包含多少量车?
·B:北京每个城区的车辆位置点数(每辆车有多个位置点,允许重复)

A输出:
·以第一列统计车辆数,去重·输出

B输出:
1.从(district.txt)文件中取第一个区的记录,获得其名称D、中心坐标M(xo,yo)和半径r;
2.从(taxi_gps.txt)中获取第一条位置点记录,获得其坐标N(xp,y)
3.利用欧几里得距离计算公式计算点M和N的距离dis,如果dis<r,则认为该位置记录属于区域D;得到<D¡,1>
4.继续从2开始循环,获得第二个位置记录;直至所有记录遍历完。·5.继续从1开始循环,获得第二个区的记录 district.txt

3、统计出租车的数量

接下来,我们统计出租车的数量。我们可以简单地读取taxi_gps.txt文件,然后使用countDistinct函数来统计不同车辆标识的数量。

python实现该功能的代码

from pyspark.sql import SparkSession
from pyspark.sql.functions import countDistinct

# 创建一个SparkSession
spark = SparkSession.builder \
    .getOrCreate()

# 读取出租车GPS数据
taxi_df = spark.read.csv("data/taxi_gps.txt", header=False, inferSchema=True)

# 计算唯一出租车的数量
num_taxis = taxi_df.select(countDistinct("_c0")).collect()[0][0]

# 输出结果
print("出租车的数量为:", num_taxis)

# 停止SparkSession
spark.stop()

scala实现该功能的代码

import org.apache.spark.sql.SparkSession
import org.apache.spark.sql.functions.countDistinct

object CarCount{
  def main(args: Array[String]): Unit = {
    // 创建一个SparkSession
    val spark = SparkSession.builder()
      .appName("TaxiGPS")
      .master("local")
      .getOrCreate()

    // 读取出租车GPS数据
    val taxiDF = spark.read
      .option("header", "false")
      .option("inferSchema", "true")
      .csv("data/taxi_gps.txt")

    // 计算唯一出租车的数量
    val numTaxis = taxiDF.select(countDistinct("_c0")).collect()(0)(0)

    // 输出结果
    println(s"出租车的数量为: $numTaxis")

    // 停止SparkSession
    spark.stop()

  }

}

在这里插入图片描述

4、计算每个城区内每辆车的位置点数

首先,我们使用PySpark读取数据并计算每个城区内每辆车的位置点数。为了实现这一点,我们需要计算每个出租车位置与各城区中心的距离,然后检查距离是否在城区的半径范围内。

python实现该功能的代码

from pyspark.sql import SparkSession
from pyspark.sql.functions import col, countDistinct, udf

# 创建一个SparkSession
spark = SparkSession.builder \
    .getOrCreate()

# 读取区域信息和出租车GPS数据
district_df = spark.read.csv("data/district.txt", header=False, inferSchema=True)
taxi_df = spark.read.csv("data/taxi_gps.txt", header=False, inferSchema=True)

# 提取区域信息
district_info = district_df.select(col("_c0").alias("area"),
                                   col("_c1").cast("double").alias("center_a"),
                                   col("_c2").cast("double").alias("center_b"),
                                   col("_c3").cast("double").alias("radio"))

# 定义UDF以计算两点之间的欧几里得距离
def euclidean_distance(x1, y1, x2, y2):
    return ((x1 - x2) ** 2 + (y1 - y2) ** 2) ** 0.5

calculate_distance = udf(euclidean_distance)

# 计算每个城区内每辆车的位置点数
result_df = district_info.crossJoin(taxi_df) \
    .withColumn("distance", calculate_distance(col("center_a"), col("center_b"), col("_c4"), col("_c5"))).createTempView("car")


spark.sql("select _c0 as car,count(distinct(area)) as cnt  from car where distance*1000 < radio group by _c0").show()


spark.stop()

scala实现该功能的代码

package org.example

import org.apache.spark.sql.SparkSession
import org.apache.spark.sql.functions._
import org.apache.spark.sql.expressions.UserDefinedFunction

object CarLocation {
  def main(args: Array[String]): Unit = {

    // 创建一个SparkSession
    val spark = SparkSession.builder()
      .appName("TaxiGPS")
      .master("local[*]")
      .getOrCreate()

    // 读取区域信息和出租车GPS数据
    val districtDF = spark.read
      .option("header", "false")
      .option("inferSchema", "true")
      .csv("data/district.txt")

    val taxiDF = spark.read
      .option("header", "false")
      .option("inferSchema", "true")
      .csv("data/taxi_gps.txt")

    // 提取区域信息
    val districtInfo = districtDF.select(
      col("_c0").alias("area"),
      col("_c1").cast("double").alias("center_a"),
      col("_c2").cast("double").alias("center_b"),
      col("_c3").cast("double").alias("radio")
    )

    // 定义UDF以计算两点之间的欧几里得距离
    def euclideanDistance(x1: Double, y1: Double, x2: Double, y2: Double): Double = {
      math.sqrt(math.pow(x1 - x2, 2) + math.pow(y1 - y2, 2))
    }

    val calculateDistance: UserDefinedFunction = udf(euclideanDistance _)

    // 计算每个城区内每辆车的位置点数
    val resultDF = districtInfo.crossJoin(taxiDF)
      .withColumn("distance", calculateDistance(col("center_a"), col("center_b"), col("_c4"), col("_c5")))

    resultDF.createOrReplaceTempView("car")

    spark.sql("SELECT _c0 AS car, COUNT(DISTINCT area) AS cnt FROM car WHERE distance * 1000 < radio GROUP BY _c0").show()

    // 停止SparkSession
    spark.stop()
  }

}

在这里插入图片描述

总结

通过以上两个代码示例,我们使用PySpark成功地计算了北京各城区内每辆车的位置点数,并统计了出租车的数量。这些分析可以帮助我们更好地理解出租车在各个城区的分布情况,进而为城市交通管理提供数据支持。PySpark强大的数据处理能力和灵活的编程接口,使得我们能够轻松地处理和分析大规模的GPS数据。

如有遇到问题可以找小编沟通交流哦。另外小编帮忙辅导大课作业,学生毕设等。不限于MapReduce, MySQL, python,java,大数据,模型训练等。 hadoop hdfs yarn spark Django flask flink kafka flume datax sqoop seatunnel echart可视化 机器学习等
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue 3与ESLint、Prettier:构建规范化的前端开发环境

title: Vue 3与ESLint、Prettier&#xff1a;构建规范化的前端开发环境 date: 2024/6/11 updated: 2024/6/11 publisher: cmdragon excerpt: 这篇文章介绍了如何在Vue 3项目中配置ESLint和Prettier以统一代码风格&#xff0c;实现代码规范性与可读性的提升。通过设置规则、解…

49、Flink 的数据源的 SplitReader API 详解

SplitReader API a&#xff09;概述 核心的 SourceReader API 是完全异步的&#xff0c;但实际上&#xff0c;大多数 Sources 都会使用阻塞的操作&#xff0c;例如客户端&#xff08;如 KafkaConsumer&#xff09;的 poll() 阻塞调用&#xff0c;或者分布式文件系统&#xff…

商业智能(BI)期末复习

商业智能&#xff08;BI&#xff09;期末复习 商业智能&#xff08;BI&#xff09;期末复习 2024/06/17 13:30-15:00 1.工作簿包含工作表 2.tableau是一款轻型BI工具 3.敏捷BI成本比较低 因为可以不建立数据仓库 4.敏捷BI的能带来更高的质量系统 是在用户监督下建立起来的 …

Python易错点总结

目录 多分支选择结构 嵌套选择 用match模式识别 match与if的对比 案例&#xff1a;闰年判断 三角形的判断 用whlie循环 高斯求和 死循环 用for循环 ​编辑continue​编辑 whlie与else结合 pass 序列 列表&#xff08;有序&#xff09; 元组&#xff08;有序&…

高仿imtoken钱包源码/获取助记词/获取私钥/自动归集

高仿imtoken钱包/获取助记词/获取私钥/自动归集 带双端&#xff0c;无纯源码 源码下载&#xff1a;https://download.csdn.net/download/m0_66047725/89379118 更多资源下载&#xff1a;关注我。

【免杀】C2远控-APC注入-进程镂空

目录 进程镂空&傀儡进程&#xff08;主要过内存扫描&#xff09;代码 傀儡进程演示如何上线上线演示 APC注入&进程欺骗&#xff08;主要过内存扫描&#xff09;同步调用与异步调用代码演示 进程镂空&傀儡进程&#xff08;主要过内存扫描&#xff09; 进程镂空(Pro…

16.左侧导航菜单制作

左侧导航菜单制作 1. 修改路由&#xff0c;方便查看页面 index.ts import { RouteRecordRaw, createRouter, createWebHistory } from "vue-router"; import Layout from /layout/Index.vueconst routes: Array<RouteRecordRaw> [{path: /,name: home,comp…

记录大三上学期大数据课程设计:基于Hadoop和Spark的中文手写数字实时识别系统

我整理好了两个百度网盘链接&#xff0c;一个是模型文档和数据&#xff0c;一个是镜像&#xff0c;下载、导入虚拟机即可运行。 github地址&#xff1a;Li-Jihong/big-data: 用来记录大三上学期大数据课程设计&#xff1a;基于Hadoop和Spark的中文手写数字实时识别系统 (githu…

服务器如何远程桌面连接不上,服务器远程桌面连接不上解决办法

服务器远程桌面连接不上&#xff0c;是IT运维中常见的挑战之一。针对这一问题&#xff0c;专业的解决方法通常涉及以下几个方面的排查与操作&#xff1a; 首先&#xff0c;我们需要检查网络连接是否正常。远程桌面连接依赖于稳定的网络连接&#xff0c;因此&#xff0c;确认服务…

Rocky Linux 9.4 部署Zabbix 7.0

文章目录 Zabbix基本概念zabbix介绍zabbix特性zabbix结构 安装Zabbix主机名配置配置Zabbix-Server(1)禁用EPEL提供的Zabbix软件包(2)安装Zabbix Server、Web前端、Agent(3)创建初始数据库(4)Zabbix server配置数据库(5)为Zabbix前端配置PHP(6)启动Zabbix server和agent进程(7)放…

【JS重点知识05】正则表达式

目录 一&#xff1a;正则表达式简介 1 什么是正则表达式 2 正则表达式作用 二&#xff1a;语法格式&#xff1a; 1 定义正则表达式 2 检索、判断是否匹配 &#xff08;1&#xff09;test()方法 &#xff08;2&#xff09;exec()方法 三&#xff1a;元字符 普通字符&a…

【C++课程学习】:类和对象(拷贝构造和运算符重载)

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;C课程学习 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 目录 ✍拷贝构造&#xff1a; &#x1f349;特点一&#xff1a; &#x1f349;特点二&#xff1a; &…

消息中间件比较:Redis,Kafka和RabbitMQ

对微服务使用异步通信时&#xff0c;通常使用消息代理。代理确保不同微服务之间的通信可靠且稳定&#xff0c;消息在系统内得到管理和监控&#xff0c;并且消息不会丢失。您可以从几个消息代理中进行选择&#xff0c;它们的规模和数据功能各不相同。这篇博文将比较三种最受欢迎…

基于深度图像的无监督目标跟踪

概要 大致的步骤 深度图像获取:通过深度传感器(例如ToF相机、双目相机等)获取场景的深度图像。深度图转scanscan转pointcloud点云聚类卡尔曼滤波预测匈牙利算法匹配目标ID更新深度图转scan 参考这篇博客 scan转pointcloud

科技云报道:“元年”之后,生成式AI将走向何方?

科技云报道原创。 近两年&#xff0c;以大模型为代表的生成式AI技术&#xff0c;成为引爆数字原生最重要的技术奇点&#xff0c;人们见证了各类文生应用的进展速度。Gartner预测&#xff0c;到2026年&#xff0c;超过80%的企业将使用生成式AI的API或模型&#xff0c;或在生产环…

C++基础(二)

选择结构 选择结构是用来控制程序流程&#xff0c;使得程序可以根据不同的条件执行不同的代码块。 if语句 简单结构 if (表达式) { // 表达式为真时执行的语句。 } else { // 表达式为假时执行的语句。 } #include <iostream> #include <string>using namespace s…

卫星通讯传输电力运维巡检EasyCVR视频汇聚平台智能监控方案

随着科技的快速发展&#xff0c;视频监控技术已广泛应用于各个领域。而卫星通讯作为一种高效、稳定的通信方式&#xff0c;为视频监控系统的远程传输提供了有力支持。 一、方案背景 随着电力行业的快速发展&#xff0c;电力运维巡检工作变得愈发重要。传统的巡检方式往往受到…

知识图谱的应用---新零售

文章目录 新零售知识图谱构建过程典型应用 新零售 新零售&#xff0c;即个人、企业以互联网为依托&#xff0c;通过运用大数据、人工智能等先进技术手段并运用心理学知识&#xff0c;对商品的生产、流通与销售过程进行升级改造&#xff0c;进而重塑业态结构与生态圈&#xff0c…

镜舟科技携手中通快运,入选 2024 爱分析·数据库应用实践报告

典型案例&#xff1a;中通快运重构数据中心&#xff0c;满足业务多种复杂分析需求 中通快运成立于2016年&#xff0c;是中通品牌旗下快运企业&#xff0c;聚焦数智物流新趋势&#xff0c; 提供面向企业及个人客户的全链路一站式物流服务。目前中通快运全国揽派件网点有21000 余…

MySQL存储引擎详述:InnoDB为何胜出?

MySQL作为当前最流行的开源关系型数据库之一,其强大的功能和良好的性能使其广泛应用于各种规模的应用系统中。其中,存储引擎的设计理念是MySQL数据库灵活高效的关键所在。 一、什么是存储引擎 存储引擎是MySQL架构的重要组成部分,负责MySQL中数据的存储和提供了视图,存储过程等…