R语言ggHoriPlot包绘制地平线图

embedded/2024/10/10 10:04:44/

数据和代码获取:请查看主页个人信息!!!

关键词“地平线图”

1. 数据读取与处理

首先,从TSV文件中读取数据,并进行数据清洗和处理。

rm(list=ls())
pacman::p_load(tidyverse,ggalt,ggHoriPlot,hrbrthemes)
​
sports <- read_tsv("activity.tsv")

2. 数据清洗

sports <- sports %>%group_by(activity) %>% filter(max(p) > 3e-04, !grepl('n\\.e\\.c', activity)) %>% arrange(time) %>%mutate(p_peak = p / max(p), p_smooth = (lag(p_peak) + p_peak + lead(p_peak)) / 3,p_smooth = coalesce(p_smooth, p_peak)) %>% ungroup() %>%do({ rbind(.,filter(., time == 0) %>%mutate(time = 24*60))}) %>%mutate(time = ifelse(time < 3 * 60, time + 24 * 60, time)) %>%mutate(activity = reorder(activity, p_peak, FUN=which.max)) %>% arrange(activity) %>%mutate(activity.f = reorder(as.character(activity), desc(activity)))
​
sports <- mutate(sports, time2 = time/60)

3. 绘制初步图表

根据处理后的数据生成初步图表,展示不同体育活动在一天中的分布情况。

ggplot(sports, aes(time2, p_smooth)) +geom_horizon(bandwidth=0.1) +facet_grid(activity.f~.) +scale_x_continuous(expand=c(0,0), breaks=seq(from = 3, to = 27, by = 3), labels = function(x) {sprintf("%02d:00", as.integer(x %% 24))}) +viridis::scale_fill_viridis(name = "Activity relative to peak", discrete=TRUE,labels=scales::percent(seq(0, 1, 0.1)+0.1))

4. 美化图表

进一步美化图表,使其更具吸引力和可读性。

ggplot(sports, aes(time2, p_smooth)) +geom_horizon(bandwidth=0.1) +facet_grid(activity.f~.) +scale_x_continuous(expand=c(0,0), breaks=seq(from = 3, to = 27, by = 3), labels = function(x) {sprintf("%02d:00", as.integer(x %% 24))}) +viridis::scale_fill_viridis(name = "Activity relative to peak", discrete=TRUE,labels=scales::percent(seq(0, 1, 0.1)+0.1)) +theme_ipsum_rc(grid="") +theme(panel.spacing.y=unit(-0.05, "lines"),strip.text.y = element_text(hjust=0, angle=360),axis.text.y=element_blank(),axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1))
​
ggsave('pic.png', bg = 'white', width = 8, height = 6)

5. 可视化结果

这张图表展示了不同体育活动在一天中的高峰时段。颜色深浅代表了活动强度的相对峰值。通过这张图表,我们可以清晰地看到各项活动在一天中不同时间段的分布情况。


http://www.ppmy.cn/embedded/50578.html

相关文章

Laravel 的事件监听器与服务提供者和服务容器的二三事

一. Laravel 的事件监听器与服务提供者和服务容器有密切的关系。 服务提供者用于注册服务、绑定依赖关系以及执行框架的初始化设置。在服务提供者的 register 方法中&#xff0c;可以注册事件和事件监听器。 服务容器则负责管理对象的创建和依赖注入。事件监听器通常会被注册…

Java面试题--JVM大厂篇之深入了解Java虚拟机(JVM):工作机制与优化策略

引言&#xff1a; Java虚拟机&#xff08;Java Virtual Machine&#xff0c;简称JVM&#xff09;是Java程序员绕不开的主题。作为Java语言的执行平台&#xff0c;JVM不仅为Java程序提供了平台无关性&#xff0c;还承担了内存管理、线程管理和垃圾回收等复杂任务。了解JVM的工作…

java技术专家面试指南80问【java学习+面试宝典】(二)

unzip 命令 解压 *.zip 文件&#xff1a;unzip test.zip 。 查看 *.zip 文件的内容&#xff1a;unzip -l jasper.zip 。 什么Docker Docker是一个容器化平台&#xff0c;它以容器的形式将您的应用程序及其所有依赖项打包在一起&#xff0c;以确保您的应用程序在任何环境中无…

算法第9章 图算法设计

7-1 旅游规划 #include <iostream> #include <algorithm> #include <cstring> using namespace std; typedef pair<int,int> PII; const int N 510; int g[N][N]; int n,m,s,d; int dist[N]; int w[N],t[N][N]; bool st[N]; void dijkstra(){ memset…

智能语音新革命:有道与Azure的API服务对决

在当今技术飞速发展的时代&#xff0c;API&#xff08;应用程序接口&#xff09;已经成为连接不同软件和服务的桥梁。无论是开发移动应用、构建网页服务&#xff0c;还是实现物联网设备的互联互通&#xff0c;API都在其中扮演着不可或缺的角色。随着市场上各种API接口的涌现&am…

王思聪隐形女儿曝光

王思聪"隐形"女儿曝光&#xff01;黄一鸣独自面对怀孕风波&#xff0c;坚持生下爱情结晶近日&#xff0c;娱乐圈掀起了一场惊天波澜&#xff01;前王思聪绯闻女友黄一鸣在接受专访时&#xff0c;大胆揭露了她与王思聪之间的爱恨纠葛&#xff0c;并首度公开承认&#…

shiny在服务器上部署

将一个Shiny应用程序部署到服务器上可以通过多种方式实现&#xff0c;包括使用Shiny Server、Shinyapps.io或者Docker。以下是如何使用Shiny Server在服务器上部署Shiny应用程序的详细步骤。 步骤 1: 准备服务器环境 确保你的服务器运行的是Ubuntu或其他Linux发行版&#xff…

Linux笔记--vi编辑器

vi编辑器 基本操作 对于vi编辑器有这几种模式 移动 当编辑一个过大的文件时通过方向键移动光标过慢所以可以使用快捷键进行移动 编辑 dw指令只能在单词第一个字母处使用 D指令删除的是当前行 查找替换 pattern指代想要搜索的内容