ham-radio-licenses/bin/data-plots.R

117 lines
3.6 KiB
R
Raw Normal View History

2024-01-09 08:40:06 -06:00
library(ggplot2)
library(tidyr)
library(dplyr)
library(forcats)
library(ggthemes)
library(plotly)
library(htmlwidgets)
2024-01-09 08:40:06 -06:00
# Read in data from Wayback Machine archive of http://www.arrl.org/fcc-license-counts
2024-01-09 19:49:07 -06:00
d_raw <- read.csv("data/us ham radio licenses over time.csv")
2024-01-09 08:40:06 -06:00
# What dates do we have?
unique(d_raw$Date)
# Clean up here if needed
d <- d_raw %>%
mutate(Date = as.Date(Date)) %>%
2024-01-09 19:49:07 -06:00
# Drop Tech alone and leave Tech and Tech Plus
select(-c(Tech, Tech.Plus))
2024-01-09 19:49:07 -06:00
2024-01-09 08:40:06 -06:00
d_total <- d %>% filter(State.Territory == "TOTAL")
d_total_long <- d_total %>%
pivot_longer(cols = !c("Date", "State.Territory", "source_name", "source_detail"),
2024-01-09 08:40:06 -06:00
names_to = "lclass",
values_to = "count") %>%
# only keep rows with data so plots look right
filter(!is.na(count))
2024-01-09 08:40:06 -06:00
#### Plots ####
##### Total over time, y = 0 #####
2024-01-09 08:40:06 -06:00
ggplot(data = d_total,
aes(x = Date,
2024-01-09 19:49:07 -06:00
y = Total,
color = source_name)) +
2024-01-09 08:40:06 -06:00
geom_line() +
geom_point(size = 0.3) +
2024-01-09 19:49:07 -06:00
scale_x_date(date_breaks = "10 years",
date_minor_breaks = "1 year",
2024-01-09 08:40:06 -06:00
date_labels = "%Y") +
scale_y_continuous(labels = scales::comma,
limits = c(0, NA)) +
2024-01-09 08:40:06 -06:00
theme_bw() +
labs(title = "US Amateur Licenses",
2024-01-09 19:49:07 -06:00
caption = "w1cdn.net",
color = "Source") +
theme(legend.position="bottom")
ggsave("plots/total-over-time-y.png", width = 6, height = 4)
2024-01-09 08:40:06 -06:00
p <- ggplotly()
htmlwidgets::saveWidget(as_widget(p), selfcontained = TRUE, file = "plots/total-over-time-y.html")
##### Total over time, since 2000 #####
ggplot(data = d_total %>% filter(Date >= as.Date("2000-01-01")),
2024-01-09 08:40:06 -06:00
aes(x = Date,
2024-01-09 19:49:07 -06:00
y = Total,
color = source_name)) +
2024-01-09 08:40:06 -06:00
geom_line() +
geom_point(size = 0.3) +
2024-01-10 22:11:23 -06:00
scale_x_date(date_breaks = "2 years",
date_minor_breaks = "3 months",
2024-01-09 08:40:06 -06:00
date_labels = "%Y") +
scale_y_continuous(labels = scales::comma) +
2024-01-09 08:40:06 -06:00
theme_bw() +
labs(title = "US Amateur Licenses since 2000",
2024-01-09 19:49:07 -06:00
caption = "w1cdn.net",
color = "Source") +
theme(legend.position="bottom")
2024-01-10 22:11:23 -06:00
ggsave("plots/total-over-time-2000.png", width = 6, height = 4)
2024-01-09 08:40:06 -06:00
##### By license class #####
ggplot(data = d_total_long %>% filter(lclass != "Total"),
aes(x = Date,
y = count,
color = fct_reorder2(lclass, Date, count))) +
geom_line() +
geom_point(size = 0.3) +
2024-01-09 19:49:07 -06:00
scale_x_date(date_breaks = "10 years",
date_minor_breaks = "1 year",
2024-01-09 08:40:06 -06:00
date_labels = "%Y") +
scale_y_continuous(labels = scales::comma) +
scale_color_colorblind() +
theme_bw() +
labs(title = "US Amateur Licenses by Class",
y = "Count",
color = "Class",
caption = "w1cdn.net") +
theme(legend.position="bottom")
ggsave("plots/class-over-time.png", width = 6, height = 4)
2024-01-09 08:40:06 -06:00
##### By license class, stacked #####
ggplot(data = d_total_long %>% filter(lclass != "Total"),
aes(x = Date,
y = count,
fill = fct_reorder2(lclass, Date, count))) +
geom_area() +
scale_fill_colorblind() +
2024-01-09 19:49:07 -06:00
scale_x_date(date_breaks = "10 years",
date_minor_breaks = "1 year",
2024-01-09 08:40:06 -06:00
date_labels = "%Y") +
scale_y_continuous(labels = scales::comma) +
theme_bw() +
labs(title = "US Amateur Licenses by Class",
fill = "Class",
caption = "w1cdn.net") +
theme(legend.position="bottom")
ggsave("plots/class-over-time-stacked.png", width = 6, height = 4)
2024-01-09 08:40:06 -06:00