main_marking2/danube_test3.scala
author Christian Urban <christian.urban@kcl.ac.uk>
Mon, 08 Nov 2021 02:20:35 +0000
changeset 407 b2cdb76f8ef2
parent 389 7e084cfbaac9
child 421 864107857d27
permissions -rw-r--r--
updated
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
389
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     1
import CW7b._
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     2
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     3
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     4
// first test 
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     5
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     6
val ls1_urban = List(("1", "a"), ("2", "a"), ("1", "c"), ("2", "a"), ("1", "c"))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     7
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     8
val m_urban = groupById(ls1_urban, Map())
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     9
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    10
assert(m_urban.getOrElse("1", Nil).count(_ == "c") == 2)
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    11
assert(m_urban.getOrElse("1", Nil).count(_ == "a") == 1)
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    12
assert(m_urban.getOrElse("2", Nil) == List("a", "a"))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    13
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    14
// second test
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    15
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    16
def urban_gb(ratings: List[(String, String)]) = 
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    17
  ratings.groupBy(_._1).view.mapValues(_.map(_._2).toSet).toMap 
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    18
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    19
def urban_gb2(ratings: List[(String, String)]) = 
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    20
  ratings.groupBy(_._1).view.mapValues(_.map(_._2)).toMap 
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    21
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    22
def urban_ck(ratings: List[(String, String)]) =
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    23
  urban_gb(ratings) == groupById(ratings, Map()).view.mapValues(_.toSet).toMap
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    24
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    25
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    26
val ls2_urban = List(("1", "a"), ("1", "b"), ("2", "x"), ("3", "a"), ("2", "y"), ("3", "c"))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    27
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    28
assert(urban_ck(ls2_urban))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    29
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    30
// thrird test
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    31
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    32
val ls3_urban = (11 to 1000 by 5).map(_.toString).toList
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    33
val ls4_urban = ls3_urban zip ls3_urban.tail
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    34
val ls5_urban = ls4_urban ::: ls4_urban.reverse
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    35
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    36
assert(urban_ck(ls5_urban))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    37
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    38
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    39
/*
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    40
import io.Source
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    41
import scala.util._
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    42
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    43
def urban_get_csv_file(name: String) : List[String] = {
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    44
  val csv = Source.fromFile(name)
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    45
  csv.mkString.split("\n").toList.drop(1)
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    46
}
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    47
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    48
def urban_process_ratings(lines: List[String]) : List[(String, String)] = {
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    49
  for (cols <- lines.map(_.split(",").toList); 
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    50
       if (cols(2).toFloat >= 4)) yield (cols(0), cols(1))  
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    51
}
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    52
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    53
val urban_ratings = urban_process_ratings(urban_get_csv_file("ratings.csv").take(1000))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    54
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    55
assert(urban_ck(urban_ratings))
7e084cfbaac9 updated marking 2
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    56
*/