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