annotate src/main/java/jp/ac/u_ryukyu/ie/cr/tatsuki/treemap/functionalJavaTreeMapMemory.java @ 20:195c1a644550

benchmark add
author tatsuki
date Tue, 17 Mar 2015 15:37:19 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
20
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.tatsuki.treemap;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
2
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
3 import java.io.BufferedWriter;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
4 import java.io.File;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
5 import java.io.FileWriter;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
6 import java.io.IOException;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
7 import java.io.PrintWriter;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
8 import java.util.LinkedList;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
9
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
10 import fj.Ord;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
11 import fj.data.TreeMap;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
12
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
13
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
14 public class functionalJavaTreeMapMemory {
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
15 public static void main(String args[]) throws IOException {
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
16 File getFile = new File("./time/fjMemory");
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
17 PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(getFile)));
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
18 TreeMap<Integer, Integer> map = TreeMap.empty(Ord.intOrd);
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
19 LinkedList<TreeMap<Integer, Integer>> list = new LinkedList<TreeMap<Integer, Integer>>();
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
20 list.add(map);
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
21 for (Integer count = 0; count <= 10000; count++) {
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
22 TreeMap<Integer, Integer> newMap = list.getLast();
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
23 TreeMap<Integer, Integer> copyMap = newMap.set(count, count);
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
24 list.add(copyMap);
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
25 long used = getMemory();
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
26 System.out.println(count + " " + used);
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
27 pw.println(count + " " + used);
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
28 }
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
29 pw.close();
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
30 }
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
31
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
32 public static long getMemory() {
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
33 long free = Runtime.getRuntime().freeMemory() / 1024;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
34 long total = Runtime.getRuntime().totalMemory() / 1024;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
35 long used = total - free;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
36 return used;
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
37 }
195c1a644550 benchmark add
tatsuki
parents:
diff changeset
38 }