annotate src/main/java/jp/ac/u_ryukyu/ie/cr/tatsuki/jungle/test/TreeMapBenchMark.java @ 181:7282ee629af3

add miss
author tatsuki
date Tue, 17 Mar 2015 15:38:27 +0900
parents 2e6ca84686da
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
179
817febd9c69b change transaction
tatsuki
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.test;
817febd9c69b change transaction
tatsuki
parents:
diff changeset
2
180
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
3 import fj.Ord;
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
4 import fj.data.TreeMap;
179
817febd9c69b change transaction
tatsuki
parents:
diff changeset
5 import org.xml.sax.SAXException;
817febd9c69b change transaction
tatsuki
parents:
diff changeset
6
817febd9c69b change transaction
tatsuki
parents:
diff changeset
7 import javax.xml.parsers.ParserConfigurationException;
817febd9c69b change transaction
tatsuki
parents:
diff changeset
8 import java.io.*;
817febd9c69b change transaction
tatsuki
parents:
diff changeset
9
817febd9c69b change transaction
tatsuki
parents:
diff changeset
10 /**
817febd9c69b change transaction
tatsuki
parents:
diff changeset
11 * Created by e115731 on 15/03/17.
817febd9c69b change transaction
tatsuki
parents:
diff changeset
12 */
817febd9c69b change transaction
tatsuki
parents:
diff changeset
13 public class TreeMapBenchMark {
817febd9c69b change transaction
tatsuki
parents:
diff changeset
14 public static void main(String[] args) throws InterruptedException, IOException, ParserConfigurationException, SAXException {
180
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
15
179
817febd9c69b change transaction
tatsuki
parents:
diff changeset
16
180
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
17 if (args.length == 0) {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
18 System.out.println("args fj or util");
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
19 System.exit(0);
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
20 }
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
21
179
817febd9c69b change transaction
tatsuki
parents:
diff changeset
22 Runtime rt = Runtime.getRuntime();
817febd9c69b change transaction
tatsuki
parents:
diff changeset
23 int cpuNum = rt.availableProcessors();
817febd9c69b change transaction
tatsuki
parents:
diff changeset
24
181
7282ee629af3 add miss
tatsuki
parents: 180
diff changeset
25 File file = new File("./time/get" + args[0] + "TreeMapTime");
180
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
26
179
817febd9c69b change transaction
tatsuki
parents:
diff changeset
27 PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(file)));
180
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
28
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
29 AbstractTreeMapThread readThread[] = null;
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
30
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
31 for (int THREAD_COUNT = 1; THREAD_COUNT <= cpuNum; THREAD_COUNT++) {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
32 readThread = new AbstractTreeMapThread[THREAD_COUNT];
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
33
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
34 if (args[0].equals("fj")) {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
35 TreeMap<String, String> map = TreeMap.empty(Ord.stringOrd);
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
36 map = map.set("test","'test");
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
37 for (int count = 0; THREAD_COUNT > count; count++) {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
38 readThread[count] = new FunctionalTreeMapReadThread(map);
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
39 }
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
40 } else if (args[0].equals("util")) {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
41 java.util.TreeMap map = new java.util.TreeMap();
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
42 map.put("test","test");
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
43 for (int count = 0; THREAD_COUNT > count; count++) {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
44 readThread[count] = new UtilTreeMapReadThread(map);
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
45 }
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
46 } else {
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
47 System.out.println("not allow args");
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
48 System.exit(0);
2e6ca84686da refactor TreeMap BenchMark
tatsuki
parents: 179
diff changeset
49 }
179
817febd9c69b change transaction
tatsuki
parents:
diff changeset
50
817febd9c69b change transaction
tatsuki
parents:
diff changeset
51 for (int count = 0; THREAD_COUNT > count; count++) {
817febd9c69b change transaction
tatsuki
parents:
diff changeset
52 readThread[count].start();
817febd9c69b change transaction
tatsuki
parents:
diff changeset
53 }
817febd9c69b change transaction
tatsuki
parents:
diff changeset
54
817febd9c69b change transaction
tatsuki
parents:
diff changeset
55 System.out.println("StartThread");
817febd9c69b change transaction
tatsuki
parents:
diff changeset
56
817febd9c69b change transaction
tatsuki
parents:
diff changeset
57 Thread.sleep(1000);
817febd9c69b change transaction
tatsuki
parents:
diff changeset
58 long readCount = 0;
817febd9c69b change transaction
tatsuki
parents:
diff changeset
59
817febd9c69b change transaction
tatsuki
parents:
diff changeset
60 for (int count = 0; THREAD_COUNT > count; count++) {
817febd9c69b change transaction
tatsuki
parents:
diff changeset
61 readCount = readCount + readThread[count].getFindCount();
817febd9c69b change transaction
tatsuki
parents:
diff changeset
62 readThread[count].set(false);
817febd9c69b change transaction
tatsuki
parents:
diff changeset
63 }
817febd9c69b change transaction
tatsuki
parents:
diff changeset
64
817febd9c69b change transaction
tatsuki
parents:
diff changeset
65 pw.println(THREAD_COUNT + " " + readCount);
817febd9c69b change transaction
tatsuki
parents:
diff changeset
66 System.out.println(THREAD_COUNT + "readCount = " + readCount);
817febd9c69b change transaction
tatsuki
parents:
diff changeset
67 }
817febd9c69b change transaction
tatsuki
parents:
diff changeset
68
817febd9c69b change transaction
tatsuki
parents:
diff changeset
69 pw.close();
817febd9c69b change transaction
tatsuki
parents:
diff changeset
70 }
817febd9c69b change transaction
tatsuki
parents:
diff changeset
71
817febd9c69b change transaction
tatsuki
parents:
diff changeset
72 }