由于微信不允许外部链接,你需要点击文章尾部左下角的 "阅读原文",才能访问文中链接。

洛杉矶市(Los Angeles)或”爵士乐的诞生地(The Birthplace of Jazz)”是美利坚合众国人口最多的城市之一,人口估计超过四百万。 在这样规模的城市,它的犯罪率是值得我们去探索的。

本项目旨在探讨 2017 年度的犯罪率。这个项目中使用的数据集是在洛杉矶警察局提供的这个链接中下载的(参考文章末尾小编提供的该完整 CSV 数据下载,约 400 M)。

数据准备

library(data.table) #faster way to read large dataset
library(tidyverse) #load dplyr, tidyr and ggplot
library(ggmap) #use to read map
library(maps) #map tools kits
library(mapdata) #read the map data
library(lubridate) #date manuplation
library(ggrepel) #better label
library(varhandle) #load the function unfactor

crime_la <- as.data.frame(fread("Crime_Data_from_2010_to_Present.csv", na.strings = c("NA")))
glimpse(crime_la)

Read 1810088 rows and 26 (of 26) columns from 0.390 GB file in 00:00:05
Observations: 1,810,088
Variables: 26
$ `DR Number`              <int> 1208575, 102005556, 418, 101822289, 421044...
$ `Date Reported`          <chr> "03/14/2013", "01/25/2010", "03/19/2013", ...
$ `Date Occurred`          <chr> "03/11/2013", "01/22/2010", "03/18/2013", ...
$ `Time Occurred`          <int> 1800, 2300, 2030, 1800, 2300, 1400, 2230, ...
$ `Area ID`                <int> 12, 20, 18, 18, 21, 1, 11, 16, 19, 9, 19, ...
$ `Area Name`              <chr> "77th Street", "Olympic", "Southeast", "So...
$ `Reporting District`     <int> 1241, 2071, 1823, 1803, 2133, 111, 1125, 1...
$ `Crime Code`             <int> 626, 510, 510, 510, 745, 110, 510, 510, 51...
$ `Crime Code Description` <chr> "INTIMATE PARTNER - SIMPLE ASSAULT", "VEHI...
$ `MO Codes`               <chr> "0416 0446 1243 2000", "", "", "", "0329",...
$ `Victim Age`             <int> 30, NA, 12, NA, 84, 49, NA, NA, NA, 27, NA...
$ `Victim Sex`             <chr> "F", "", "", "", "M", "F", "", "", "", "F"...
$ `Victim Descent`         <chr> "W", "", "", "", "W", "W", "", "", "", "O"...
$ `Premise Code`           <int> 502, 101, 101, 101, 501, 501, 108, 101, 10...
$ `Premise Description`    <chr> "MULTI-UNIT DWELLING (APARTMENT, DUPLEX, E...
$ `Weapon Used Code`       <int> 400, NA, NA, NA, NA, 400, NA, NA, NA, NA, ...
$ `Weapon Description`     <chr> "STRONG-ARM (HANDS, FIST, FEET OR BODILY F...
$ `Status Code`            <chr> "AO", "IC", "IC", "IC", "IC", "AA", "IC", ...
$ `Status Description`     <chr> "Adult Other", "Invest Cont", "Invest Cont...
$ `Crime Code 1`           <int> 626, 510, 510, 510, 745, 110, 510, 510, 51...
$ `Crime Code 2`           <int> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA...
$ `Crime Code 3`           <int> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA...
$ `Crime Code 4`           <int> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA...
$ Address                  <chr> "6300    BRYNHURST                    AV",...
$ `Cross Street`           <chr> "", "15TH", "", "WALL", "", "", "AVENUE 51...
$ Location                 <chr> "(33.9829, -118.3338)", "(34.0454, -118.31...

本项目中使用的数据包含 180 万个观测值和 26 个变量。数据集的日期从 2010 到最近的 22/08/2018(本文选取的数据集与原文有所不同,日期为 2010 到最 25/08/2018,你可以在文章末尾下载本次操作的数据)。

数据清洗

为了本研究的目的,只选择来自 2017 年度的数据。在分析之前,进行简单的数据分析,例如将数据转换为校正的数据类型、将变量重新编码为可读格式以及选择相关变量,如下所示:

#选择相关变量(relevant variables)
crime_la_selected <- select(crime_la, `Date Occurred`, `Time Occurred`, `Area Name`, `Crime Code Description`, `Victim Age`, `Victim Sex`, `Victim Descent`, `Premise Description`, `Weapon Description`, `Status Description`, Location)

#将日期转换成日期类型
#mdy("01/01/2010") 得到:2010-01-01
crime_la_selected$`Date Occurred` <- mdy(crime_la_selected$`Date Occurred`)

#分离经纬度
location <- crime_la_selected$Location %>% # take coord as string
 str_replace_all("[()]", "") %>% # replace parantheses
 str_split_fixed(", ", n=2) %>% # split up based on comma and space after
 as.data.frame %>% # turn this to a data frame
 transmute(lat=V1, long=V2) # rename the variables

head(crime_la_selected$Location)
'(33.9829, -118.3338)' '(34.0454, -118.3157)' '(33.942, -118.2717)' '(33.9572, -118.2717)' '(34.2009, -118.6369)' '(34.0591, -118.2412)'

head(location)
lat       long
33.9829  -118.3338
34.0454  -118.3157
33.942  -118.2717
33.9572  -118.2717
34.2009  -118.6369
34.0591  -118.2412

#把经度和纬度合并到 crime_la_selected,并移除 location
crime_la_selected <- cbind(crime_la_selected, location)
crime_la_selected <- subset(crime_la_selected, select = -c(Location))

#选取 2017-2018 年期间的数据
crime_selected_years <- filter(crime_la_selected, `Date Occurred` >= as_date("2017-01-01"), `Date Occurred` <= as_date("2017-12-30"))

#删除不需要的数据框,介绍内存消耗
rm(crime_la, crime_la_selected, location) #remove these data frames to same memory
#把日期分为年、月、日
crime_selected_years$year <- year(crime_selected_years$`Date Occurred`)
crime_selected_years$month <- month(crime_selected_years$`Date Occurred`)
crime_selected_years$days <- day(crime_selected_years$`Date Occurred`)

#将变量重新编码成可读格式
crime_selected_years$`Victim Sex` <- recode(crime_selected_years$`Victim Sex`, 'F' = 'Female', 'M' = 'Male', 'X' = 'Unknown')

crime_selected_years$`Victim Descent` <- recode(crime_selected_years$`Victim Descent`, "A" = "Other Asian", "B" = "Black", "C" = "Chinese", "D" = "Cambodian", "F" = "Filipino", "G" = "Guamanian", "H" = "Hispanci/Latin/Mexican", 'I' = "American Indian/Alaskan Native", "J" = "Japanese", "K" = "Korean", "L" = "Laotian", "O" = "Other", "P" = "Pacific Islander", "S" = "Somoan", "U" = "Hawaiian", "V" = "Vietnamese", "W" = "White", "X" = "Unknown", "Z" = "Asian Indian")

#将字符转换成因子
character_vars <- lapply(crime_selected_years, class) == "character"
crime_selected_years[, character_vars] <- lapply(crime_selected_years[, character_vars], as.factor)

glimpse(crime_selected_years)

Observations: 229,946
Variables: 15
$ `Date Occurred`          <date> 2017-07-20, 2017-07-21, 2017-04-21, 2017-...
$ `Time Occurred`          <int> 2000, 1000, 1930, 1700, 745, 1, 730, 2300,...
$ `Area Name`              <fct> West Valley, West Valley, Rampart, Rampart...
$ `Crime Code Description` <fct> BURGLARY FROM VEHICLE, BURGLARY FROM VEHIC...
$ `Victim Age`             <int> 55, 20, 16, 16, 16, 16, 16, 16, 16, 29, 16...
$ `Victim Sex`             <fct> Male, Male, , , , , , , , Male, , , , , , ...
$ `Victim Descent`         <fct> Other, Other, , , , , , , , Black, , , , ,...
$ `Premise Description`    <fct> , , STREET, STREET, STREET, STREET, STREET...
$ `Weapon Description`     <fct> , , , , , , , , , , , , , , , , , , , , , ...
$ `Status Description`     <fct> Invest Cont, Invest Cont, Invest Cont, Inv...
$ lat                      <fct> , , 34.0886, 34.0512, 34.0328, 34.0676, 33...
$ long                     <fct> , , -118.2979, -118.2787, -118.2915, -118....
$ year                     <dbl> 2017, 2017, 2017, 2017, 2017, 2017, 2017, ...
$ month                    <dbl> 7, 7, 4, 2, 4, 4, 4, 3, 5, 6, 1, 2, 3, 3, ...
$ days                     <int> 20, 21, 21, 11, 25, 7, 8, 6, 11, 6, 26, 10...

在数据清洗过程之后,只选择 229902 个观测值和 15 个变量(这里生信元小编选取的数据集的日期从 2010 到最近的 25/08/2018,得到的观测值为 229946 个)。

Total Crime in 2017

让我们来看看 2017 年犯下的 20 大罪案。

year_2017 <- crime_selected_years %>% filter(year == "2017")

group <- year_2017 %>%
 group_by(`Crime Code Description`) %>%
 summarise(total = n()) %>%
 distinct() %>%
 top_n(20)

group %>%
 ggplot(aes(reorder(`Crime Code Description`, total), y = total)) +
 geom_col(fill = "red") +
 geom_label_repel(aes(label = total), size = 2.5) +
 coord_flip() +
 labs(title = "Top 20 Crime Commited in 2017",
      x = "Crime Description",
      y = "Total")

正如你所看到的,在 2017 犯下的大多数罪行是 battery-simple assault,车辆被盗(vehicle stolen)和车内盗窃(burglary from a vehicle)。

Age group

接下来,我将调查最有可能成为犯罪受害者的年龄组。

age <- year_2017 %>%
 group_by(`Victim Age`) %>%
 summarise(total = n()) %>%
 na.omit()

age %>%
 ggplot(aes(x = `Victim Age`, y = total)) +
 geom_line(group = 1) +
 geom_point(size = 0.5) +
 labs(title = "Age Most Likely To Become Crime Victim",
      x = "Victim Age",
      y = "Total")

如上所述,年龄在 25 岁以下的人群最有可能成为 2017 的犯罪受害者。线条飙升最大的(huge spike)表示为 16 岁。

接下来,我将把年龄分为不同的组,并检查哪些犯罪是针对不同年龄组的。我将年龄组分为青少年(10-18岁)、青年(19—35岁)、中年(35-55岁)和老年人(56岁以上)。

year_2017$age_group <- cut(year_2017$`Victim Age`, breaks = c(-Inf, 19, 35, 55, Inf), labels = c("Teenager", "Young Adult", "Middle Age", "Elderly"))

age.group <- year_2017 %>%
 group_by(age_group, `Crime Code Description`) %>%
 summarise(total = n()) %>%
 top_n(20) %>%
 na.omit()

age.group %>%
 ggplot(aes(reorder(x = `Crime Code Description`, total), y = total)) +
 geom_col(fill = 'red') +
 geom_text(aes(label=total), color='black', hjust = -0.1, size = 3) +
 coord_flip() +
 facet_wrap(~ age_group) +
 labs(x = 'Total',
      y = "Crime Description")

可以看出,不同年龄段的犯罪对象不同。

Gender

在这一节中,我将研究针对不同性别的犯罪类型。

gender <- year_2017 %>%
 group_by(`Victim Sex`, `Crime Code Description`) %>%
 summarise(total = n()) %>%
 filter(`Victim Sex` != "Unknown", `Victim Sex` != "H") %>%
 na.omit() %>%
 top_n(20)

gender <- gender[-c(1:30),]

gender %>%
 ggplot(aes(reorder(x = `Crime Code Description`, total), y = total)) +
 geom_col(fill = 'green') +
 geom_text(aes(label=total), color='black', hjust = 0.8, size = 3) +
 coord_flip() +
 facet_wrap(~ `Victim Sex`) +
 labs(x = 'Total',
      y = "Crime Description")

正如你所看到的,两性都可能是不同类型犯罪的受害者。


Map The Crime

接下来我们将对犯罪进行地图绘制。为了便于说明,我将只绘制 2017 年所犯的犯罪率最高的地图,这些犯罪行为是车辆被盗和车内盗窃。

#get the map of LA
LA_map <- qmap(location = "Los Angeles", zoom = 12)

#unfactor variable
year_2017$lat <- unfactor(year_2017$lat)
year_2017$long <- unfactor(year_2017$long)

#select relevant variables
mapping <- year_2017 %>%
 select(`Crime Code Description`, long, lat) %>%
 filter(`Crime Code Description` == 'BATTERY - SIMPLE ASSAULT') %>%
 na.omit()

#mapping
LA_map + geom_density_2d(aes(x = long, y = lat), data = mapping) +
 stat_density2d(data = mapping,
   aes(x = long, y = lat, fill = ..level.., alpha = ..level..), size = 0.01,
   bins = 16, geom = "polygon") + scale_fill_gradient(low = "green", high = "red",
   guide = FALSE) + scale_alpha(range = c(0, 0.3), guide = FALSE)

正如你所看到的,battery assault 更可能发生在洛杉矶市中心。

mapping <- year_2017 %>%
 select(`Crime Code Description`, long, lat) %>%
 filter(`Crime Code Description` == 'VEHICLE - STOLEN') %>%
 na.omit()

LA_map + geom_density_2d(aes(x = long, y = lat), data = mapping) +
 stat_density2d(data = mapping,
   aes(x = long, y = lat, fill = ..level.., alpha = ..level..), size = 0.01,
   bins = 16, geom = "polygon") + scale_fill_gradient(low = "green", high = "red",
   guide = FALSE) + scale_alpha(range = c(0, 0.3), guide = FALSE)

有趣的是,大多数车辆在洛杉矶南部更容易被盗。

mapping <- year_2017 %>%
 select(`Crime Code Description`, long, lat) %>%
 filter(`Crime Code Description` == 'BURGLARY FROM VEHICLE') %>%
 na.omit()

LA_map + geom_density_2d(aes(x = long, y = lat), data = mapping) +
 stat_density2d(data = mapping,
   aes(x = long, y = lat, fill = ..level.., alpha = ..level..), size = 0.01,
   bins = 16, geom = "polygon") + scale_fill_gradient(low = "green", high = "red",
   guide = FALSE) + scale_alpha(range = c(0, 0.3), guide = FALSE)

热图显示好莱坞,韩国城和洛杉矶市中心最有可能发生车内盗窃(burgalry from vehicle)。

结论

这只是一个简单的演示,说明如何深入了解数据并绘制位于洛杉矶的犯罪地图。

写在最后

这是一篇关于 R 深入了解数据、数据处理、数据(地图)可视化非常好的练习教程。整个操作脉络清晰、操作也不算难,推荐感兴趣的可以深入了解其中的一些操作原理,举一反三。

本文使用的数据:http://resource-1251708715.cosgz.myqcloud.com/r-example-data/Crime_Data_from_2010_to_Present.csv

原文:https://datascienceplus.com/analysis-of-los-angeles-crime-with-r/

作者:Chi Ting Low | 编译:Steven Shen

·end·

—如果喜欢,快分享给你的朋友们吧—

我们一起愉快的玩耍吧

本文分享自微信公众号 - 生信科技爱好者(bioitee)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

用R来分析洛杉矶犯罪的更多相关文章

  1. Python、R对比分析

    一.Python与R功能对比分析 1.python与R相比速度要快.python可以直接处理上G的数据:R不行,R分析数据时需要先通过数据库把大数据转化为小数据(通过groupby)才能交给R做分析, ...

  2. R语言分析朝阳医院数据

    R语言分析朝阳医院数据 本次实践通过分析朝阳医院2016年销售数据,得出“月均消费次数”.“月均消费金额”.“客单价”.“消费趋势”等结果,并据此作出可视化图形. 一.读取数据: library(op ...

  3. R|生存分析 - KM曲线 ,值得拥有姓名和颜值

    本文首发于“生信补给站”:https://mp.weixin.qq.com/s/lpkWwrLNtkLH8QA75X5STw 生存分析作为分析疾病/癌症预后的出镜频率超高的分析手段,而其结果展示的KM ...

  4. 用R语言分析我的fitbit计步数据

    目标:把fitbit的每日运动记录导入到R语言中进行分析,画出统计图表来 已有原始数据:fitbit2014年每日的记录电子表格文件,全部数据点此下载,示例如下: 日期 消耗卡路里数 步 距离 攀爬楼 ...

  5. 用R语言分析与预測员工离职

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/kMD8d5R/article/details/83542978 https://mmbiz.qpic ...

  6. 使用R语言分析股价波动

    今天看的R语言.做个笔记. 使用R语言读取雅虎財经数据.分析微软公司(股票代码:MSFT)在2015年股价波动超过百分之十的日期. 然后通过检索新闻的方式,看看微软当天有什么新闻发生,导致股价波动. ...

  7. R语言分析(一)-----基本语法

      一, R语言所处理的工作层: 解释一下: 最下面的一层为数据源,往上是数据仓库层,往上是数据探索层,包括统计分析,统计查询,还有就是报告 再往上的三层,分别是数据挖掘,数据展现和数据决策. 由上图 ...

  8. R生存分析AFT

    γ = 1/scale =1/0.902 α = exp(−(Intercept)γ)=exp(-(7.111)*γ) > library(survival) > myfit=survre ...

  9. R1(上)—R关联规则分析之Arules包详解

    Arules包详解 包基本信息 发布日期:2014-12-07 题目:挖掘关联规则和频繁项集 描述:提供了一个表达.处理.分析事务数据和模式(频繁项集合关联规则)的基本框架. URL:http://R ...

  10. 92、R语言分析案例

    1.读取数据 > bank=read.table("bank-full.csv",header=TRUE,sep=";") > 2.查看数据结构 & ...

随机推荐

  1. os模块的使用方法详解

    os模块 os模块负责程序与操作系统的交互,提供了访问操作系统底层的接口:即os模块提供了非常丰富的方法用来处理文件和目录. 使用的时候需要导入该模块:import os 常用方法如下: 方法名 作用 ...

  2. 什么是Redis持久化,如何理解?

    其实redis就是一种高级的以键值对形式存储数据的数据库,而它的好处就是他可以支持数据的持久化,其实redis之所以会有这样的优点,主要是因为,redis的数据都是存放在内存中的,如果不配置持久化,那 ...

  3. 基于 ByteHouse 构建实时数仓实践

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 随着数据的应用场景越来越丰富,企业对数据价值反馈到业务中的时效性要求也越来越高,很早就有人提出过一个概念: 数据的 ...

  4. Easy App Locker - 给你的 mac 应用加锁保护你的隐私

    Easy App Locker可以对Mac上的单个应用进行密码保护.维护Mac上的隐私. 像如果你的某个应用存在隐私数据就可以使用该软件将此应用上锁,这样当你的朋友使用你的 mac 时你就不用担心你的 ...

  5. Logoist - 适用于设计师以及初次使用者的快速制作精美 logo 工具

    ![在这里插入图片描述](https://img-blog.csdnimg.cn/24c0f566dcf14be2aa72afaa78c87c40.png)>从简单的标识到设计开发.它只需要一点 ...

  6. kubernetes(k8s)安装命令行自动补全功能

    Ubuntu下安装命令 root@master1:~# apt install -y bash-completion Reading package lists... Done Building de ...

  7. JavaScript的引入方式

    外部JS文件 deno.js alert('你好!JavaScript'); JS引入方式.html <!--方式一:内部脚本--> <!--标签不能自闭和--> <sc ...

  8. socket搭建web服务端

    import socket from threading import Thread import time def html(conn): time_tag = str(time.time()) p ...

  9. classmethod和staticmethod装饰器

    """ 两个装饰器 @classmethod 把一个对象绑定的方法,修改成为一个类方法 1.在方法中仍然可以引用类中的静态变量 2.可以不用实例化对象,就直接使用类名在外 ...

  10. Java SpringBoot 7z 压缩、解压

    Java SpringBoot 7z 压缩.解压 cmd 7z 文件压缩 7z压缩测试 添加依赖 <dependency> <groupId>org.apache.common ...