Commit 18c96f2b authored by Paul's avatar Paul

Solution proposée par Paul Faye

parent 5499c979
--- ---
title: "Analyse de l'incidence du syndrôme grippal" title: "Analyse de l'incidence du syndrôme grippal"
author: "Konrad Hinsen" author: "Paul Faye"
output: output:
pdf_document: pdf_document:
toc: true toc: true
...@@ -44,7 +44,9 @@ Voici l'explication des colonnes donnée sur le [sur le site d'origine](https:// ...@@ -44,7 +44,9 @@ Voici l'explication des colonnes donnée sur le [sur le site d'origine](https://
La première ligne du fichier CSV est un commentaire, que nous ignorons en précisant `skip=1`. La première ligne du fichier CSV est un commentaire, que nous ignorons en précisant `skip=1`.
### Téléchargement ### Téléchargement
```{r} ```{r}
data = read.csv(data_url, skip=1) library(readr)
setwd("C:/Users/Paul Faye/Desktop/MOOC-RR/module3/exo1/")
data = read_csv("incidence_PAY_3.csv", skip = 1)
``` ```
Regardons ce que nous avons obtenu: Regardons ce que nous avons obtenu:
...@@ -63,6 +65,7 @@ Les deux colonnes qui nous intéressent sont `week` et `inc`. Vérifions leurs c ...@@ -63,6 +65,7 @@ Les deux colonnes qui nous intéressent sont `week` et `inc`. Vérifions leurs c
```{r} ```{r}
class(data$week) class(data$week)
class(data$inc) class(data$inc)
``` ```
Ce sont des entiers, tout va bien ! Ce sont des entiers, tout va bien !
...@@ -77,11 +80,13 @@ library(parsedate) ...@@ -77,11 +80,13 @@ library(parsedate)
Pour faciliter le traitement suivant, nous remplaçons ces semaines par les dates qui correspondent aux lundis. Voici une petite fonction qui fait la conversion pour une seule valeur: Pour faciliter le traitement suivant, nous remplaçons ces semaines par les dates qui correspondent aux lundis. Voici une petite fonction qui fait la conversion pour une seule valeur:
```{r} ```{r}
convert_week = function(w) { convert_week = function(w) {
ws = paste(w) ws = paste(w)
iso = paste0(substring(ws, 1, 4), "-W", substring(ws, 5, 6)) iso = paste0(substring(ws, 1, 4), "-W", substring(ws, 5, 6))
as.character(parse_iso_8601(iso)) as.character(parse_iso_8601(iso))
} }
``` ```
Nous appliquons cette fonction à tous les points, créant une nouvelle colonne `date` dans notre jeu de données: Nous appliquons cette fonction à tous les points, créant une nouvelle colonne `date` dans notre jeu de données:
...@@ -90,13 +95,16 @@ data$date = as.Date(convert_week(data$week)) ...@@ -90,13 +95,16 @@ data$date = as.Date(convert_week(data$week))
``` ```
Vérifions qu'elle est de classe `Date`: Vérifions qu'elle est de classe `Date`:
```{r} ```{r}
class(data$date) class(data$date)
``` ```
Les points sont dans l'ordre chronologique inverse, il est donc utile de les trier: Les points sont dans l'ordre chronologique inverse, il est donc utile de les trier:
```{r} ```{r}
data = data[order(data$date),] data = data[order(data$date),]
``` ```
C'est l'occasion pour faire une vérification: nos dates doivent être séparées d'exactement sept jours: C'est l'occasion pour faire une vérification: nos dates doivent être séparées d'exactement sept jours:
...@@ -108,12 +116,16 @@ all(diff(data$date) == 7) ...@@ -108,12 +116,16 @@ all(diff(data$date) == 7)
Regardons enfin à quoi ressemblent nos données ! Regardons enfin à quoi ressemblent nos données !
```{r} ```{r}
plot(data$date, data$inc, type="l", xlab="Date", ylab="Incidence hebdomadaire") plot(data$date, data$inc, type="l", xlab="Date", ylab="Incidence hebdomadaire")
``` ```
Un zoom sur les dernières années montre mieux la localisation des pics en hiver. Le creux des incidences se trouve en été. Un zoom sur les dernières années montre mieux la localisation des pics en hiver. Le creux des incidences se trouve en été.
```{r} ```{r}
with(tail(data, 200), plot(date, inc, type="l", xlab="Date", ylab="Incidence hebdomadaire")) with(tail(data, 200), plot(date, inc, type="l", xlab="Date", ylab="Incidence hebdomadaire"))
``` ```
## L'incidence annuelle ## L'incidence annuelle
...@@ -129,6 +141,7 @@ pic_annuel = function(annee) { ...@@ -129,6 +141,7 @@ pic_annuel = function(annee) {
semaines = data$date > debut & data$date <= fin semaines = data$date > debut & data$date <= fin
sum(data$inc[semaines], na.rm=TRUE) sum(data$inc[semaines], na.rm=TRUE)
} }
``` ```
Nous devons aussi faire attention aux premières et dernières années de notre jeux de données. Les données commencent en octobre 1984, ce qui ne permet pas de quantifier complètement le pic attribué à 1985. Nous l'enlevons donc de notre analyse. Par contre, pour une exécution en octobre 2018, les données se terminent après le 1er août 2018, ce qui nous permet d'inclure cette année. Nous devons aussi faire attention aux premières et dernières années de notre jeux de données. Les données commencent en octobre 1984, ce qui ne permet pas de quantifier complètement le pic attribué à 1985. Nous l'enlevons donc de notre analyse. Par contre, pour une exécution en octobre 2018, les données se terminent après le 1er août 2018, ce qui nous permet d'inclure cette année.
...@@ -141,6 +154,7 @@ Nous créons un nouveau jeu de données pour l'incidence annuelle, en applicant ...@@ -141,6 +154,7 @@ Nous créons un nouveau jeu de données pour l'incidence annuelle, en applicant
inc_annuelle = data.frame(annee = annees, inc_annuelle = data.frame(annee = annees,
incidence = sapply(annees, pic_annuel)) incidence = sapply(annees, pic_annuel))
head(inc_annuelle) head(inc_annuelle)
``` ```
### Inspection ### Inspection
......
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment