This worked example attempts to document a common workflow a user might follow when using the fingertipsR package.
fingertipsR provides users the ability to import data from the Fingertips website. Fingertips is a major repository of public health indicators in England. The site is structured in the following way:
This example demonstrates how you can plot healthy life expectancy and life expectancy by deprivation for a given year of data that fingertips contains. So, where to start?
There is one function in the fingertipsR package that extracts data from the Fingertips API: fingertips_data(). This function has the following inputs:
At least one of IndicatorID, DomainID or ProfileID must be complete. These fields relate to each other as described in the introduction. AreaCode needs completing if you are extracting data for a particular area or group of areas only. AreaTypeID determines the geography to extract the data for. In this case we want County and Unitary Authority level. ParentAreaTypeID requires an area type code that the AreaTypeID maps to at a higher level of geography. For example, when combining groups of County and Unitary Authorities it is possible to create Government Office Regions. These mappings can be identified using the area_types() function. If ignored, a ParentAreaTypeID will be chosen automatically.
Therefore, the inputs to the fingertips_data function that we need to find out are the ID codes for:
We need to begin by calling the fingertipsR package:
There are two indicators we are interested in for this exercise. Without consulting the Fingertips website, we know approximately what they are called:
We can use the indicators() function to return a list of all the indicators within Fingertips. We can then filter the name field for the term life expectancy (note, the IndicatorName field has been converted to lower case in the following code chunk to ensure matches will not be overlooked as a result of upper case letters).
inds <- indicators_unique()
life_expectancy <- inds[grepl("life expectancy", tolower(inds$IndicatorName)),]
knitr::kable(life_expectancy, row.names = FALSE) #note, this line will only work in a markdown file (*.Rmd). It presents the table for a report| IndicatorID | IndicatorName | 
|---|---|
| 90362 | Healthy life expectancy at birth | 
| 90365 | Gap in life expectancy at birth between each local authority and England as a whole | 
| 90366 | Life expectancy at birth | 
| 90823 | Number of UTLAs where inequality in life expectancy at birth has decreased | 
| 90825 | Inequality in healthy life expectancy at birth ENGLAND | 
| 91102 | Life expectancy at 65 | 
| 92031 | Inequality in healthy life expectancy at birth LA | 
| 92901 | Inequality in life expectancy at birth | 
| 93190 | Inequality in life expectancy at 65 | 
| 650 | Life expectancy - MSOA based | 
| 90366 | Life expectancy at birth | 
| 92901 | Inequality in life expectancy at birth | 
| 92901 | Slope index of inequality in life expectancy at birth within English local authorities, based on local deprivation deciles within each area | 
| 91102 | Life expectancy at 65 | 
| 90366 | Life Expectancy at birth | 
| 92031 | Inequality in healthy life expectancy at birth | 
| 93249 | Disability free life expectancy, (Upper age band 85+) | 
| 93283 | Life expectancy at birth, (upper age band 90+) | 
| 93285 | Life expectancy at birth, (upper age band 85+) | 
| 93298 | Healthy life expectancy, (upper age band 85+) | 
The two indicators we are interested in from this table are:
We can work out what the AreaTypeID codes we are interested in using the function area_types(). We’ve decided that we want to produce the graph at County and Unitary Authority level. From the section Where to start we need codes for AreaTypeID and ParentAreaTypeID.
areaTypes <- area_types()
DT::datatable(areaTypes, filter = "top", rownames = FALSE) #note, this line will only work in a markdown file (*.Rmd). It presents the table for a reportThe table shows that the AreaID for County and Unitary Authority level is 102. The third column, ParentAreaTypeID, shows the IDs of the area types that these map to. In the case of County and Unitary Authorities, these are:
| ParentAreaTypeID | ParentAreaTypeName | 
|---|---|
| 6 | Government Office Region | 
| 104 | PHEC 2015 new plus PHEC 2013 unchanged | 
| 10039 | Depriv. decile (IMD 2015) | 
| 126 | Combined authorities | 
ParentAreaTypeID is 6 by default for the fingertips_data() function for AreaTypeID of 102 (though it changes if different AreaTypeIDs are entered), so we can stick with that in this example. Use the area_types() function to understand more about how areas map to each other.
Finally, we can use the fingertips_data() function with the inputs we have determined previously.
indicators <- c(90362, 90366)
data <- fingertips_data(IndicatorID = indicators,
                        AreaTypeID = 102)
pander::pandoc.table(tail(data), 
                     style="rmarkdown",
                     split.tables = 90, 
                     keep.line.breaks = TRUE) #note, this line will only work in a markdown file (*.Rmd). It presents the table for a report## 
## 
## |      | IndicatorID |      IndicatorName       | ParentCode |
## |:---------:|:-----------:|:------------------------:|:----------:|
## | **10363** |    90366    | Life expectancy at birth | E12000005  |
## | **10364** |    90366    | Life expectancy at birth | E12000006  |
## | **10365** |    90366    | Life expectancy at birth | E12000008  |
## | **10366** |    90366    | Life expectancy at birth | E12000005  |
## | **10367** |    90366    | Life expectancy at birth | E12000008  |
## | **10368** |    90366    | Life expectancy at birth | E12000005  |
## 
## Table: Table continues below
## 
##  
## 
## |      |       ParentName       | AreaCode  |    AreaName    |  AreaType   |
## |:---------:|:----------------------:|:---------:|:--------------:|:-----------:|
## | **10363** |  West Midlands region  | E10000028 | Staffordshire  | County & UA |
## | **10364** | East of England region | E10000029 |    Suffolk     | County & UA |
## | **10365** |   South East region    | E10000030 |     Surrey     | County & UA |
## | **10366** |  West Midlands region  | E10000031 |  Warwickshire  | County & UA |
## | **10367** |   South East region    | E10000032 |  West Sussex   | County & UA |
## | **10368** |  West Midlands region  | E10000034 | Worcestershire | County & UA |
## 
## Table: Table continues below
## 
##  
## 
## |      |  Sex   |   Age    | CategoryType | Category | Timeperiod | Value |
## |:---------:|:------:|:--------:|:------------:|:--------:|:----------:|:-----:|
## | **10363** | Female | All ages |      NA      |    NA    | 2015 - 17  | 82.92 |
## | **10364** | Female | All ages |      NA      |    NA    | 2015 - 17  | 84.11 |
## | **10365** | Female | All ages |      NA      |    NA    | 2015 - 17  | 84.78 |
## | **10366** | Female | All ages |      NA      |    NA    | 2015 - 17  | 83.67 |
## | **10367** | Female | All ages |      NA      |    NA    | 2015 - 17  | 84.09 |
## | **10368** | Female | All ages |      NA      |    NA    | 2015 - 17  | 83.92 |
## 
## Table: Table continues below
## 
##  
## 
## |      | LowerCI95.0limit | UpperCI95.0limit | LowerCI99.8limit |
## |:---------:|:----------------:|:----------------:|:----------------:|
## | **10363** |      82.69       |      83.14       |        NA        |
## | **10364** |      83.89       |      84.33       |        NA        |
## | **10365** |      84.61       |      84.96       |        NA        |
## | **10366** |      83.41       |      83.93       |        NA        |
## | **10367** |      83.89       |       84.3       |        NA        |
## | **10368** |      83.66       |      84.17       |        NA        |
## 
## Table: Table continues below
## 
##  
## 
## |      | UpperCI99.8limit | Count | Denominator | Valuenote |
## |:---------:|:----------------:|:-----:|:-----------:|:---------:|
## | **10363** |        NA        |  NA   |     NA      |    NA     |
## | **10364** |        NA        |  NA   |     NA      |    NA     |
## | **10365** |        NA        |  NA   |     NA      |    NA     |
## | **10366** |        NA        |  NA   |     NA      |    NA     |
## | **10367** |        NA        |  NA   |     NA      |    NA     |
## | **10368** |        NA        |  NA   |     NA      |    NA     |
## 
## Table: Table continues below
## 
##  
## 
## |      |     RecentTrend      | ComparedtoEnglandvalueorpercentiles |
## |:---------:|:--------------------:|:-----------------------------------:|
## | **10363** | Cannot be calculated |               Similar               |
## | **10364** | Cannot be calculated |               Better                |
## | **10365** | Cannot be calculated |               Better                |
## | **10366** | Cannot be calculated |               Better                |
## | **10367** | Cannot be calculated |               Better                |
## | **10368** | Cannot be calculated |               Better                |
## 
## Table: Table continues below
## 
##  
## 
## |      | ComparedtoRegionvalueorpercentiles | TimeperiodSortable | Newdata |
## |:---------:|:----------------------------------:|:------------------:|:-------:|
## | **10363** |              Similar               |      20150000      |   NA    |
## | **10364** |               Better               |      20150000      |   NA    |
## | **10365** |               Better               |      20150000      |   NA    |
## | **10366** |               Better               |      20150000      |   NA    |
## | **10367** |              Similar               |      20150000      |   NA    |
## | **10368** |               Better               |      20150000      |   NA    |
## 
## Table: Table continues below
## 
##  
## 
## |      | Comparedtogoal |
## |:---------:|:--------------:|
## | **10363** |       NA       |
## | **10364** |       NA       |
## | **10365** |       NA       |
## | **10366** |       NA       |
## | **10367** |       NA       |
## | **10368** |       NA       |The data frame returned by fingertips_data() contains 26 variables. For this exercise, we are only interested in a few of them and for the time period 2012-14:
We want to plot life expectancy against deprivation information. As deprivation is a notable cause of health inequalities, the deprivation_deciles() function has been provided to allow easy access to this information. This is populated from the Department for Communities and Local Government Indices of Multiple Deprivation (IMD). Note, there is only information for General Practices, upper and lower tier local authorities (AreaTypeID = 7, 102 and 101 respectively). IMD has only been produced for the years 2010 and 2015 (for the latter areas) as well as 2011 and 2012 for General Practices.
dep <- deprivation_decile(AreaTypeID = 102, Year = 2015)
DT::datatable(dep, filter = "top", rownames = FALSE) #note, this line will only work in a markdown file (*.Rmd). It presents the table for a reportNow we need to merge this with the main dataset:
# merge deprivation onto data
data <- merge(data, dep, by.x = "AreaCode", by.y = "AreaCode", all.x = TRUE)
# remove NA values
data <- data[complete.cases(data),]
DT::datatable(data, filter = "top", rownames = FALSE) #note, this line will only work in a markdown file (*.Rmd). It presents the table for a reportUsing ggplot2 it is possible to plot the outputs.
library(ggplot2)
p <- ggplot(data, aes(x = IMDscore, y = Value, col = factor(IndicatorID)))
p <- p + 
        geom_point() +
        geom_smooth(se = FALSE, method = "loess") +
        facet_wrap(~ Sex) +
        scale_colour_manual(name = "Indicator",
                            breaks = c("90366", "90362"),
                            labels = c("Life expectancy", "Healthy life expectancy"),
                            values = c("#128c4a", "#88c857")) +
        scale_x_reverse() + 
        labs(x = "IMD deprivation",
             y = "Age",
             title = "Life expectancy and healthy life expectancy at birth \nfor Upper Tier Local Authorities (2012 - 2014)") +
        theme_bw()
print(p)