Files and Folders

It is essential that you name your folders and files exactly as specified. We run checks like

cd HW2
Rscript -e 'rmarkdown::render("hw2.Rmd")'

from the top of a clone of your repository. If the folders and files are not named exactly as specified these checks will fail and your work will not be graded.

Rmarkdown Usage and Coding Style

Make sure you are using Rmarkdown properly, with explanatory texts surrounding short code chunks. In particular you should not have just one big code chunk.

Your rendered HTML page should be a report with text supporting numerical and graphical results. Code only needs to be visible if you are explaining how to do something (which is a goal of the class notes).

Your Rmarkdown code and your R code should be readable, and the R code should follow the coding standards. This makes maintaining your code and document easier.

Name and Date

Make sure your Rmarkdown file header contains a name: field with your name. A date: field with an appropriate date is also helpful.

Your header should look something like this:

---
title: "HW2"
output: html_document
name: "Your  Name"
date: "February 1, 2024"
---

You can also use one of these as the date line to produce the current date when the document is knit:

date: "`r Sys.Date()`"
date: "`r format(Sys.Date(), '%B %e, %Y')`"

Reproducibility

Make sure your .Rmd file will knit without errors.

Handling Data Files

If your Rmarkdown document makes use of an external data file you need to make sure it can be accessed when someone you give your repository to renders your file. There are several options:

Relying on retrieving a file from the network means it may change or be removed. In some cases this will be what you want, in others maybe not.

Avoiding Messages and Warnings in Output

Some packages produce messages when they are loaded and some computations produce messages or warnings. In a final report you usually do not want these to be visible. You can suppress messages, like the ones produces when loading the tidyverse, by adding the chunk option message = FALSE. Warnings can also be suppressed with the chunk option warning = FALSE, but it is usually better to make sure you understand where the warnings are coming from and modify your code to avoid them (e.g. by adding na.rm = TRUE to some calls).

Remember to Push your Work

Remember to Push your work to your UI GitLab repository after committing it locally. We can’t see it until you do.

It is a good idea to check your class repository on the UI GitLab site to make sure your submission is there.

1. Average Infant Mortality Rate Continent in 2015

The following table shows the average infant mortality rate, in deaths per 1000 live births, for 2015 across countries in five continents as defined in the gapminder data set from the dslabs package.

Continent Infant Mortality
Africa 48.0
Americas 15.6
Asia 18.6
Europe 4.5
Oceania 22.0

Infant mortality for Africa is still quite a bit higher than for the other continents.

2. Average Infant Mortality Rate Over the Years

This graph shows average infant mortality rates over the years for the five continents defined in the gapminder data set from the dslabs package.

All continents show a decrease in infant mortality over time. The curve for Africa is noticeably higher than the curves for the other continents. The bump for 1990-2000 in the Africa curve reflects famine events and conflicts in Africa during these years.

3. Mauna Loa Atmospheric CO\(_2\) Concentration

This plot shows the yearly average CO\(_2\) concentration measured at the Mauna Loa Observatory in Hawaii. Measurements are in parts per million.

CO\(_2\) levels have been rising consistently over the years, with the rate of increase appearing to rise slowly as well.

LS0tCnRpdGxlOiAiQXNzaWdubWVudCAyIE5vdGVzIgpvdXRwdXQ6CiAgaHRtbF9kb2N1bWVudDoKICAgIHRvYzogeWVzCiAgICBjb2RlX2Rvd25sb2FkOiB0cnVlCi0tLQoKYGBge3IgZ2xvYmFsX29wdGlvbnMsIGluY2x1ZGUgPSBGQUxTRX0Ka25pdHI6Om9wdHNfY2h1bmskc2V0KGNvbGxhcHNlID0gVFJVRSkKYGBgCgojIyBGaWxlcyBhbmQgRm9sZGVycwoKSXQgaXMgZXNzZW50aWFsIHRoYXQgeW91IG5hbWUgeW91ciBmb2xkZXJzIGFuZCBmaWxlcyBfZXhhY3RseV8gYXMKc3BlY2lmaWVkLiBXZSBydW4gY2hlY2tzIGxpa2UKYGBgc2hlbGwKY2QgSFcyClJzY3JpcHQgLWUgJ3JtYXJrZG93bjo6cmVuZGVyKCJodzIuUm1kIiknCmBgYApmcm9tIHRoZSB0b3Agb2YgYSBjbG9uZSBvZiB5b3VyIHJlcG9zaXRvcnkuIElmIHRoZSBmb2xkZXJzCmFuZCBmaWxlcyBhcmUgbm90IG5hbWVkIF9leGFjdGx5XyBhcyBzcGVjaWZpZWQgdGhlc2UgY2hlY2tzIHdpbGwgZmFpbAphbmQgeW91ciB3b3JrIHdpbGwgbm90IGJlIGdyYWRlZC4KCgojIyBSbWFya2Rvd24gVXNhZ2UgYW5kIENvZGluZyBTdHlsZQoKTWFrZSBzdXJlIHlvdSBhcmUgdXNpbmcgUm1hcmtkb3duIHByb3Blcmx5LCB3aXRoIGV4cGxhbmF0b3J5IHRleHRzCnN1cnJvdW5kaW5nIHNob3J0IGNvZGUgY2h1bmtzLiBJbiBwYXJ0aWN1bGFyIHlvdSBzaG91bGQgbm90IGhhdmUganVzdApvbmUgYmlnIGNvZGUgY2h1bmsuCgpZb3VyIHJlbmRlcmVkIEhUTUwgcGFnZSBzaG91bGQgYmUgYSByZXBvcnQgd2l0aCB0ZXh0IHN1cHBvcnRpbmcKbnVtZXJpY2FsIGFuZCBncmFwaGljYWwgcmVzdWx0cy4gQ29kZSBvbmx5IG5lZWRzIHRvIGJlIHZpc2libGUgaWYgeW91CmFyZSBleHBsYWluaW5nIGhvdyB0byBkbyBzb21ldGhpbmcgKHdoaWNoIGlzIGEgZ29hbCBvZiB0aGUgY2xhc3Mgbm90ZXMpLgoKWW91ciBSbWFya2Rvd24gY29kZSBhbmQgeW91ciBSIGNvZGUgc2hvdWxkIGJlIHJlYWRhYmxlLCBhbmQgdGhlIFIgY29kZQpzaG91bGQgZm9sbG93IHRoZSBjb2Rpbmcgc3RhbmRhcmRzLiBUaGlzIG1ha2VzIG1haW50YWluaW5nIHlvdXIgY29kZQphbmQgZG9jdW1lbnQgZWFzaWVyLgoKCiMjIE5hbWUgYW5kIERhdGUKCk1ha2Ugc3VyZSB5b3VyIFJtYXJrZG93biBmaWxlIGhlYWRlciBjb250YWlucyBhIGBuYW1lOmAgZmllbGQgd2l0aAp5b3VyIG5hbWUuIEEgYGRhdGU6YCBmaWVsZCB3aXRoIGFuIGFwcHJvcHJpYXRlIGRhdGUgaXMgYWxzbyBoZWxwZnVsLgoKWW91ciBoZWFkZXIgc2hvdWxkIGxvb2sgc29tZXRoaW5nIGxpa2UgdGhpczoKYGBgCi0tLQp0aXRsZTogIkhXMiIKb3V0cHV0OiBodG1sX2RvY3VtZW50Cm5hbWU6ICJZb3VyICBOYW1lIgpkYXRlOiAiRmVicnVhcnkgMSwgMjAyNCIKLS0tCmBgYAoKWW91IGNhbiBhbHNvIHVzZSBvbmUgb2YgdGhlc2UgYXMgdGhlIGRhdGUgbGluZSB0byBwcm9kdWNlIHRoZSBjdXJyZW50IGRhdGUKd2hlbiB0aGUgZG9jdW1lbnQgaXMga25pdDoKCmBgYHtyLCBpbmNsdWRlID0gRkFMU0V9CnJpbmxpbmUgPC0gZnVuY3Rpb24oY29kZSkgewogICAgc3ByaW50ZigiYHIgJXNgIiwgY29kZSkKfQpgYGAKYGBgCmRhdGU6ICJgciByaW5saW5lKCJTeXMuRGF0ZSgpIilgIgpgYGAKYGBgCmRhdGU6ICJgciByaW5saW5lKCJmb3JtYXQoU3lzLkRhdGUoKSwgJyVCICVlLCAlWScpIilgIgpgYGAKCiMjIFJlcHJvZHVjaWJpbGl0eQoKTWFrZSBzdXJlIHlvdXIgYC5SbWRgIGZpbGUgd2lsbCBrbml0IHdpdGhvdXQgZXJyb3JzLgoKKiBFeGNlcHQgZm9yIHBhY2thZ2VzIHlvdXIgY29kZSBzaG91bGQgbm90IGRlcGVuZCBvbiBhbnl0aGluZyBub3QKICBjb250YWluZWQgaW4geW91ciByZXBvc2l0b3J5LgoKKiBZb3VyIGNvZGUgc2hvdWxkIG5vdCBhdHRlbXB0IHRvIG1ha2UgYW55IG1vZGlmaWNhdGlvbnMgb3V0c2lkZQogIHlvdXIgcmVwb3NpdG9yeSwgaW5jbHVkaW5nIGluc3RhbGxpbmcgcGFja2FnZXMuCgoKIyMgSGFuZGxpbmcgRGF0YSBGaWxlcwoKSWYgeW91ciBSbWFya2Rvd24gZG9jdW1lbnQgbWFrZXMgdXNlIG9mIGFuIGV4dGVybmFsIGRhdGEgZmlsZSB5b3UgbmVlZAp0byBtYWtlIHN1cmUgaXQgY2FuIGJlIGFjY2Vzc2VkIHdoZW4gc29tZW9uZSB5b3UgZ2l2ZSB5b3VyIHJlcG9zaXRvcnkKdG8gcmVuZGVycyB5b3VyIGZpbGUuIFRoZXJlIGFyZSBzZXZlcmFsIG9wdGlvbnM6CgoqIEluY2x1ZGUgdGhlIGZpbGUgaW4geW91ciByZXBvc2l0b3J5LiBZb3UgY2FuIHRoZW4gcmVmZXJlbmNlIGl0IGZyb20KICB5b3VyIGNvZGUgd2l0aCBhIHJlbGF0aXZlIHBhdGgsIHJlbGF0aXZlIHRvIHRoZSBsb2NhdGlvbiBvZiB5b3VyCiAgYFJtZGAgZmlsZS4gVGhpcyBpcyByZWFzb25hYmxlIGZvciBzbWFsbCBkYXRhIHNldHMgYW5kIGl0IGZyZWV6ZXMKICB0aGUgZGF0YSBhdCBpdHMgY3VycmVudCBzdGF0ZS4KCiogQWNjZXNzIHRoZSBmaWxlIHVzaW5nIGEgVVJMLiBUaGlzIHdpbGwgbG9hZCB0aGUgZmlsZSBvdmVyIHRoZSBuZXR3b3JrCiAgZWFjaCB0aW1lIHlvdSByZW5kZXIgeW91ciBkb2N1bWVudC4gWW91IG5lZWQgYSBuZXR3b3JrIGNvbm5lY3Rpb24sCiAgYW5kIHlvdSBtYXkgY2F1c2UgdW5uZWNlc3NhcnkgdHJhZmZpYyBpZiB0aGUgZmlsZSBpcyBsYXJnZS4KCiogQ2hlY2sgaWYgeW91IGhhdmUgdGhlIGZpbGUgbG9jYWxseSwgYW5kIGRvd25sb2FkIGl0IGlmIHlvdSBkbwogIG5vdC4gVGhpcyBpcyBvZnRlbiBhIGdvb2Qgb3B0aW9uIGFuZCB0aGVyZSBhcmUgc2V2ZXJhbCBleGFtcGxlIG9mCiAgaG93IHRvIGRvIHRoaXMgaW4gdGhlIG5vdGVzLgoKUmVseWluZyBvbiByZXRyaWV2aW5nIGEgZmlsZSBmcm9tIHRoZSBuZXR3b3JrIG1lYW5zIGl0IG1heSBjaGFuZ2Ugb3IKYmUgcmVtb3ZlZC4gSW4gc29tZSBjYXNlcyB0aGlzIHdpbGwgYmUgd2hhdCB5b3Ugd2FudCwgaW4gb3RoZXJzIG1heWJlCm5vdC4KCgojIyBBdm9pZGluZyBNZXNzYWdlcyBhbmQgV2FybmluZ3MgaW4gT3V0cHV0CgpTb21lIHBhY2thZ2VzIHByb2R1Y2UgX21lc3NhZ2VzXyB3aGVuIHRoZXkgYXJlIGxvYWRlZCBhbmQgc29tZQpjb21wdXRhdGlvbnMgcHJvZHVjZSBfbWVzc2FnZXNfIG9yIF93YXJuaW5nc18uIEluIGEgZmluYWwgcmVwb3J0IHlvdQp1c3VhbGx5IGRvIG5vdCB3YW50IHRoZXNlIHRvIGJlIHZpc2libGUuIFlvdSBjYW4gc3VwcHJlc3MgbWVzc2FnZXMsCmxpa2UgdGhlIG9uZXMgcHJvZHVjZXMgd2hlbiBsb2FkaW5nIHRoZSBgdGlkeXZlcnNlYCwgYnkgYWRkaW5nIHRoZQpjaHVuayBvcHRpb24gYG1lc3NhZ2UgPSBGQUxTRWAuIFdhcm5pbmdzIGNhbiBhbHNvIGJlIHN1cHByZXNzZWQgd2l0aAp0aGUgY2h1bmsgb3B0aW9uIGB3YXJuaW5nID0gRkFMU0VgLCBidXQgaXQgaXMgdXN1YWxseSBiZXR0ZXIgdG8gbWFrZQpzdXJlIHlvdSB1bmRlcnN0YW5kIHdoZXJlIHRoZSB3YXJuaW5ncyBhcmUgY29taW5nIGZyb20gYW5kIG1vZGlmeSB5b3VyCmNvZGUgdG8gYXZvaWQgdGhlbSAoZS5nLiBieSBhZGRpbmcgYG5hLnJtID0gVFJVRWAgdG8gc29tZSBjYWxscykuCgoKIyMgUmVtZW1iZXIgdG8gUHVzaCB5b3VyIFdvcmsKClJlbWVtYmVyIHRvICoqUHVzaCoqIHlvdXIgd29yayB0byB5b3VyIFVJIEdpdExhYiByZXBvc2l0b3J5IGFmdGVyCmNvbW1pdHRpbmcgaXQgbG9jYWxseS4gV2UgY2FuJ3Qgc2VlIGl0IHVudGlsIHlvdSBkby4KCkl0IGlzIGEgZ29vZCBpZGVhIHRvIGNoZWNrIHlvdXIgY2xhc3MgcmVwb3NpdG9yeSBvbiB0aGUgVUkgR2l0TGFiIHNpdGUKdG8gbWFrZSBzdXJlIHlvdXIgc3VibWlzc2lvbiBpcyB0aGVyZS4KCgojIyAxLiBBdmVyYWdlIEluZmFudCBNb3J0YWxpdHkgUmF0ZSBDb250aW5lbnQgaW4gMjAxNQoKVGhlIGZvbGxvd2luZyB0YWJsZSBzaG93cyB0aGUgYXZlcmFnZSBpbmZhbnQgbW9ydGFsaXR5IHJhdGUsIGluIGRlYXRocwpwZXIgMTAwMCBsaXZlIGJpcnRocywgZm9yIDIwMTUgYWNyb3NzIGNvdW50cmllcyBpbiBmaXZlIGNvbnRpbmVudHMgYXMKZGVmaW5lZCBpbiB0aGUgYGdhcG1pbmRlcmAgZGF0YSBzZXQgZnJvbSB0aGUgYGRzbGFic2AgcGFja2FnZS4KCmBgYHtyLCBlY2hvID0gRkFMU0UsIG1lc3NhZ2UgPSBGQUxTRX0KbGlicmFyeSh0aWR5dmVyc2UpCmRhdGEoZ2FwbWluZGVyLCBwYWNrYWdlID0gImRzbGFicyIpCnRibCA8LSBmaWx0ZXIoZ2FwbWluZGVyLCB5ZWFyID09IDIwMTUpIHw+CiAgICBncm91cF9ieShjb250aW5lbnQpIHw+CiAgICBzdW1tYXJpemUoYXZnX2luZmFudF9tb3J0YWxpdHkgPSBtZWFuKGluZmFudF9tb3J0YWxpdHksIG5hLnJtID0gVFJVRSkpCm5hbWVzKHRibCkgPC0gYygiQ29udGluZW50IiwgIkluZmFudCBNb3J0YWxpdHkiKQprYmwgPC0ga25pdHI6OmthYmxlKHRibCwgZGlnaXRzID0gMSwgZm9ybWF0ID0gImh0bWwiKQprYWJsZUV4dHJhOjprYWJsZV9zdHlsaW5nKGtibCwgZnVsbF93aWR0aCA9IEZBTFNFKQpgYGAKSW5mYW50IG1vcnRhbGl0eSBmb3IgQWZyaWNhIGlzIHN0aWxsIHF1aXRlIGEgYml0IGhpZ2hlciB0aGFuIGZvciB0aGUKb3RoZXIgY29udGluZW50cy4KCgojIyAyLiBBdmVyYWdlIEluZmFudCBNb3J0YWxpdHkgUmF0ZSBPdmVyIHRoZSBZZWFycwoKVGhpcyBncmFwaCBzaG93cyBhdmVyYWdlIGluZmFudCBtb3J0YWxpdHkgcmF0ZXMgb3ZlciB0aGUgeWVhcnMgZm9yIHRoZSBmaXZlCmNvbnRpbmVudHMgZGVmaW5lZCBpbiB0aGUgYGdhcG1pbmRlcmAgZGF0YSBzZXQgZnJvbSB0aGUgYGRzbGFic2AKcGFja2FnZS4KCmBgYHtyLCBlY2hvID0gRkFMU0UsIG1lc3NhZ2UgPSBGQUxTRX0KbGlicmFyeSh0aWR5dmVyc2UpCmRhdGEoZ2FwbWluZGVyLCBwYWNrYWdlID0gImRzbGFicyIpCmF2X2xlX3lfYyA8LQogICAgZ3JvdXBfYnkoZ2FwbWluZGVyLCB5ZWFyLCBjb250aW5lbnQpIHw+CiAgICBzdW1tYXJpemUoYXZnX2luZmFudF9tb3J0YWxpdHkgPSBtZWFuKGluZmFudF9tb3J0YWxpdHksIG5hLnJtID0gVFJVRSkpCmdncGxvdChhdl9sZV95X2MsIGFlcyh4ID0geWVhciwgeSA9IGF2Z19pbmZhbnRfbW9ydGFsaXR5LCBjb2xvciA9IGNvbnRpbmVudCkpICsKICAgIGdlb21fbGluZShuYS5ybSA9IFRSVUUpCmBgYAoKQWxsIGNvbnRpbmVudHMgc2hvdyBhIGRlY3JlYXNlIGluIGluZmFudCBtb3J0YWxpdHkgb3ZlciB0aW1lLiAgVGhlCmN1cnZlIGZvciBBZnJpY2EgaXMgbm90aWNlYWJseSBoaWdoZXIgdGhhbiB0aGUgY3VydmVzIGZvciB0aGUgb3RoZXIKY29udGluZW50cy4gVGhlIGJ1bXAgZm9yIDE5OTAtMjAwMCBpbiB0aGUgQWZyaWNhIGN1cnZlIHJlZmxlY3RzIGZhbWluZQpldmVudHMgYW5kIGNvbmZsaWN0cyBpbiBBZnJpY2EgZHVyaW5nIHRoZXNlIHllYXJzLgoKCiMjIDMuIE1hdW5hIExvYSBBdG1vc3BoZXJpYyBDTyRfMiQgQ29uY2VudHJhdGlvbgoKVGhpcyBwbG90IHNob3dzIHRoZSB5ZWFybHkgYXZlcmFnZSBDTyRfMiQgY29uY2VudHJhdGlvbiBtZWFzdXJlZCBhdAp0aGUgTWF1bmEgTG9hIE9ic2VydmF0b3J5IGluIEhhd2FpaS4gTWVhc3VyZW1lbnRzIGFyZSBpbiBwYXJ0cyBwZXIKbWlsbGlvbi4KCmBgYHtyLCBlY2hvID0gRkFMU0UsIG1lc3NhZ2UgPSBGQUxTRX0KbGlicmFyeSh0aWR5dmVyc2UpCnVybCA8LSAiaHR0cHM6Ly93d3cuc3RhdC51aW93YS5lZHUvfmx1a2UvZGF0YS9jbzItMjAyMy5jc3YiCmNvMndpZGUgPC0gcmVhZC5jc3YodXJsLCBuYS5zdHJpbmcgPSAiKioqIikKCmNvMmxvbmcgPC0gcGl2b3RfbG9uZ2VyKGNvMndpZGUsIC15ZWFyLCBuYW1lc190byA9ICJtb250aCIsIHZhbHVlc190byA9ICJjbzIiKQoKY28yeWVhciA8LSBzdW1tYXJpemUoZ3JvdXBfYnkoY28ybG9uZywgeWVhciksIGNvMiA9IG1lYW4oY28yLCBuYS5ybSA9IFRSVUUpKQoKZ2dwbG90KGNvMnllYXIsIGFlcyh4ID0geWVhciwgeSA9IGNvMikpICsgZ2VvbV9saW5lKCkKYGBgCgpDTyRfMiQgbGV2ZWxzIGhhdmUgYmVlbiByaXNpbmcgY29uc2lzdGVudGx5IG92ZXIgdGhlIHllYXJzLCB3aXRoIHRoZQpyYXRlIG9mIGluY3JlYXNlIGFwcGVhcmluZyB0byByaXNlIHNsb3dseSBhcyB3ZWxsLgo=