Mercurial > repos > icfp2013
annotate tools/parse.scala @ 1:cdfc5e2de435
Checking in our problem set and a simple scala parser
author | Joshua Garnett <josh.garnett@gmail.com> |
---|---|
date | Thu, 08 Aug 2013 21:08:01 -0400 |
parents | |
children | 5cf8de487ed6 |
rev | line source |
---|---|
1
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
1 // |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
2 // How to run: scala -cp json-smart-1.0.9-1.jar parse.scala |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
3 // |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
4 import net.minidev.json._ |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
5 import scala.collection.JavaConversions._ |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
6 import scala.collection.mutable._ |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
7 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
8 val file = scala.io.Source.fromFile("../data/myproblems.json").mkString |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
9 val json = JSONValue.parse(file).asInstanceOf[JSONArray] |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
10 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
11 var totalProblems = json.size |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
12 var totalSize = 0 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
13 val operatorHash = HashMap[String, Int]() |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
14 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
15 for(p <- json) { |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
16 val problem = p.asInstanceOf[JSONObject] |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
17 totalSize += problem.get("size").asInstanceOf[java.lang.Integer] |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
18 val operators = problem.get("operators").asInstanceOf[JSONArray] |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
19 for(o <- operators) { |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
20 val operator = o.asInstanceOf[String] |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
21 operatorHash(operator) = operatorHash.get(operator) match { |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
22 case Some(count) => count + 1 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
23 case None => 1 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
24 } |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
25 } |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
26 } |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
27 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
28 println("Total problems: " + totalProblems) |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
29 println("Total size: " + totalSize) |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
30 println("Average size: " + totalSize / totalProblems) |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
31 |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
32 println("Operator Count: ") |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
33 for((key, value) <- operatorHash) { |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
34 println(" " + key + ":" + value) |
cdfc5e2de435
Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff
changeset
|
35 } |