Student Details
Sichen Hu s3754657
Data Visualisation
This visualisation shows the total population change of city of Melbourne in different age groups.
- This visualisation shows the total aged population versus total population of each geography area in each years. The aged people is classified as people who is more than 65 years old (Australian Law Reform Commission, 2017).
---
title: "R Notebook"
subtitle: 
output:
  html_notebook: default
---

# Student Details

Sichen Hu 
s3754657

# Introduction
This report aims to analysing the population change from 2016 to 2041 in different conditions, which includes age groups, geography areas, and genders by using three data visualisations produced in R Studio.
The data is sourced from City of Melbourne Open Data website: https://data.melbourne.vic.gov.au/People-Events/City-of-Melbourne-Population-Forecasts-2016-to-204/vtsx-jhki/data.



# Data Visualisation

```{r include=FALSE}
library(ggplot2)
library(plotly)
library(dplyr)
library(crosstalk)
library(readr)
```

```{r include=FALSE}
Population <- read_csv("S:/Desktop/MATH2270 DT VIS/Assignment 3 DT VIS/City_of_Melbourne_Population_Forecasts_2016_to_2041_-_Age_and_Gender.csv")

```

This visualisation shows the total population change of city of Melbourne in different age groups.

```{r echo=FALSE}
total_pop <- Population %>% filter(Geography == "City_of_Melbourne")
total_pop <- total_pop[, 1:21]
total_pop <- total_pop %>% transmute(Year = Year,
                                     Total_U10 = `Total_0-4`+`Total_5-9`,
                                     Total_10 = `Total_10-14`+`Total_15-19`,
                                     Total_20 = `Total_20-24`+`Total_25-29`,
                                     Total_30 = `Total_30-34`+`Total_35-39`,
                                     Total_40 = `Total_40-44`+`Total_45-49`,
                                     Total_50 = `Total_50-54`+`Total_55-59`,
                                     Total_60 = `Total_60-64`+`Total_65-69`,
                                     Total_70 = `Total_70-74`+`Total_75-79`,
                                     Total_80P = `Total_80-84`+`Total_85+`)
```

```{r echo=FALSE}
updatemenus <- list(
  list(
    active = 0,
    x = -.125,
    type = 'buttons',
    buttons = list(
      list(
        label = "0-10 Years",
        method = "update",
        args = list(list(visible = c(TRUE, "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly")))),
      list(
        label = "10-19 Years",
        method = "update",
        args = list(list(visible = c("legendonly", TRUE, "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly")))),
      list(
        label = "20-29 Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", TRUE,"legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly")))),
      list(
        label = "30-39 Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", "legendonly", TRUE, "legendonly", "legendonly", "legendonly", "legendonly", "legendonly")))),
      list(
        label = "40-49 Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", "legendonly", "legendonly", TRUE,  "legendonly", "legendonly", "legendonly", "legendonly")))),
      list(
        label = "50-59 Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", "legendonly", "legendonly", "legendonly", TRUE,   "legendonly", "legendonly", "legendonly")))),
      list(
        label = "60-69 Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", TRUE, "legendonly", "legendonly")))),
      list(
        label = "70-79 Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", TRUE, "legendonly")))),
      list(
        label = "80+ Years",
        method = "update",
        args = list(list(visible = c("legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", "legendonly", TRUE))))
    )
  )
)

p1 <- plot_ly(data = total_pop) %>% 
  add_lines(x = ~Year, y = ~Total_U10, name = "0-10 Years", visible = "TRUE") %>% 
  add_lines(x = ~Year, y = ~Total_10, name = "10-19 Years", visible = "legendonly") %>%
  add_lines(x = ~Year, y = ~Total_20, name = "20-29 Years", visible = "legendonly") %>% 
  add_lines(x = ~Year, y = ~Total_30, name = "30-39 Years", visible = "legendonly") %>% 
  add_lines(x = ~Year, y = ~Total_40, name = "40-49 Years", visible = "legendonly") %>% 
  add_lines(x = ~Year, y = ~Total_50, name = "50-59 Years", visible = "legendonly") %>% 
  add_lines(x = ~Year, y = ~Total_60, name = "60-69 Years", visible = "legendonly") %>% 
  add_lines(x = ~Year, y = ~Total_70, name = "70-79 Years", visible = "legendonly") %>% 
  add_lines(x = ~Year, y = ~Total_80P, name = "80+ Years", visible = "legendonly") %>% 
  layout(title = "The Population and its Forecast of City of Melbourne in Different Age Groups", showlegend = TRUE,
         xaxis = list(zeroline = F, title="Year"),
         yaxis = list(zeroline = F, title="Population"),
         updatemenus=updatemenus)
p1
   

```


* This visualisation shows the total aged population versus total population of each geography area in each years. The aged people is classified as people who is more than 65 years old (Australian Law Reform Commission, 2017).

```{r echo=FALSE}
geo_pop <- Population %>% filter(Geography != "City_of_Melbourne")
geo_pop <- geo_pop[, 1:21]
geo_pop <- geo_pop %>% transmute(Year = Year,
                                 Geography = Geography,
                                 Total_population = Total_population,
                                 Total_aging = `Total_65-69`+`Total_70-74`+`Total_75-79`+`Total_80-84`+`Total_85+`)

```


```{r echo=FALSE}
p2 <- ggplot(data = geo_pop, aes(x = Total_population, y = Total_aging, group = Geography))
p2 <- p2 + geom_point() + 
  scale_x_continuous(breaks = seq(0,120000, 60000)) + 
  labs(x = "Total Population",
       y = "Total Aged Population",
       title = "Total Population with Total Aged Population of Each Area") + 
  facet_wrap(~Year)

gg2 <- ggplotly(p2, tooltip = "Area", width = 1000, height = 600)
gg2 <- highlight(gg2, on = "plotly_click", color = "red")
gg2
```

* This visualisation demonstrates the population change of different genders in each area.
The area is divided as:

    + Carlton, Kensington, North Melbourne, Parkville as North of CBD;
    + South Yarra, Southbank as South of CBD;
    + Docklands, Port Melbourne, West Melbourne as West of CBD;
    + East Melbourne as East of CBD.

```{r echo=FALSE}
gender_pop <- Population %>% filter(Geography != "City_of_Melbourne")
gender_pop <- gender_pop[, c(1:3,22,41)]
gender_pop$Area <- ifelse(gender_pop$Geography == "Carlton" | gender_pop$Geography == "Kensington" | gender_pop$Geography == "North_Melbourne" | gender_pop$Geography == "Parkville", 'North of CBD',
                                    ifelse(gender_pop$Geography == "Docklands" | gender_pop$Geography == "Port_Melbourne" | gender_pop$Geography == "West_Melbourne_(Industrial)" | gender_pop$Geography == "West_Melbourne_(Residential)", 'West of CBD', 
                                           ifelse(gender_pop$Geography == "South_Yarra" | gender_pop$Geography == "Southbank", 'South of CBD', 
                                                  ifelse(gender_pop$Geography == "East_Melbourne", 'East of CBD', 
                                                         ifelse(gender_pop$Geography == "Melbourne_(CBD)" | gender_pop$Geography == "Melbourne_(Remainder)", 'CBD Area', 'Error')))))

```

```{r echo=FALSE}
p3 <- plot_ly(gender_pop, x = ~Male_population, y = ~Female_population, color = ~Area, frame = ~Year, alpha = 1) %>% 
  add_trace(type = "scatter", mode = "markers") %>% 
  layout(title = "Male Population vs. Female Population by Year",
         yaxis = list(zeroline = F, title = "Female Population"),
         xaxis = list(zeroline = F, title = "Male Population"))
p3

```

```{r include=FALSE}
username <- "Lamia7"
apikey <- "U1KRrB3U9iSIu1M16sHs"
Sys.setenv("plotly_username" = username)
Sys.setenv("plotly_api_key" = apikey)
api_create(p1, filename = "Assignment_3_P1", sharing = "public")
api_create(gg2, filename = "Assignment_3_P2", sharing = "public")
api_create(p3, filename = "Assignment_3_P3", sharing = "public")

```

# Reference

Australian Law Reform Commission 2017, *Who Are Older Australians?*, Australian Government, retrieved 26 October 2019, <https://www.alrc.gov.au/publication/elder-abuse-a-national-legal-response-alrc-report-131/2-concepts-and-context-2/who-are-older-australians/>;

City of Melbourne 2019, *City of Melbourne Population Forecasts 2016 to 2041 - Age and Gender*, City of Melbourne, retrieved 25 October 2019, <https://data.melbourne.vic.gov.au/People-Events/City-of-Melbourne-Population-Forecasts-2016-to-204/vtsx-jhki/data>.




Plotly URL: https://plot.ly/~Lamia7/1/; https://plot.ly/~Lamia7/3/#/; https://plot.ly/~Lamia7/5/#/.

Rpub URL: http://rpubs.com/S3754657/543283.






















