templates1/alcohol.scala
author Christian Urban <urbanc@in.tum.de>
Wed, 16 Jan 2019 12:24:47 +0000
changeset 254 2801734b934a
parent 145 155a7e41615e
permissions -rw-r--r--
updated
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
// Part 2 about Alcohol-Consumption Worldwide
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
//============================================
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
object CW6b {
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
import io.Source
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
import scala.util._
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
val url_alcohol = 
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    10
  "https://raw.githubusercontent.com/fivethirtyeight/data/master/alcohol-consumption/drinks.csv"
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    12
val file_population = 
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    13
  "population.csv"
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    14
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
135
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    16
//(1) Complete the get_csv_page function below. It takes a URL-string
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    17
//    as argument and generates a list of strings corresponding to each
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    18
//    line in the downloaded csv-list. The URL url_alcohol above is one 
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    19
//    possible argument.
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    20
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    21
//def get_csv_page(url: String) : List[String] = ...
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    22
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    23
135
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    24
//    Complete the get_csv_file function below. It takes a file name 
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    25
//    as argument and reads the content of the given file. Like above,
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    26
//    it should generate a list of strings corresponding to each
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    27
//    line in the csv-list. The filename file_population is one possible
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    28
//    argument.
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    30
//def get_csv_file(file: String) : List[String] = ...
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    31
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    32
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    34
//(2) Complete the functions that process the csv-lists. For
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    35
//    process_alcs extract the country name (as String) and the 
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    36
//    pure alcohol consumption (as Double). For process_pops
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    37
//    generate a Map of Strings (country names) to Long numbers 
135
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    38
//    (population sizes). 
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    39
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    40
//def process_alcs(lines: List[String]) : List[(String, Double)] = ...
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    41
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    42
//def process_pops(lines: List[String]) : Map[String, Long] = ...
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    43
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    44
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    45
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    46
//(3) Calculate for each country the overall alcohol_consumption using
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    47
//    the data from the alcohol list and the population sizes list. You
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    48
//    should only include countries on the alcohol list that are also
135
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    49
//    on the population sizes list with the exact same name. Note that
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    50
//    the spelling of some names in the alcohol list differs from the
135
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    51
//    population sizes list. You can ignore entries where the names differ. 
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    52
//    Sort the resulting list according to the country with the highest alcohol 
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    53
//    consumption to the country with the lowest alcohol consumption.
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    54
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    55
//def sorted_country_consumption() : List[(String, Long)] = ...
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    56
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    57
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    58
//   Calculate the world consumption of pure alcohol of all countries, which 
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    59
//   should be the first element in the tuple below. The second element is
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    60
//   the overall consumption of the first n countries in the sorted list
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    61
//   from above; and finally the double should be the percentage of the 
135
e59aebee9770 updated
Christian Urban <urbanc@in.tum.de>
parents: 129
diff changeset
    62
//   first n countries drinking from the the world consumption of alcohol.          
129
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    63
1b0f1573c27c updated
Christian Urban <urbanc@in.tum.de>
parents: 128
diff changeset
    64
//def percentage(n: Int) : (Long, Long, Double) = ...
128
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    65
fd03a2f06286 updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    66
}