changeset 206:5016c7e18c76 working

use flip API
author sugi
date Tue, 26 Mar 2013 01:45:34 +0900
parents 28469b1671e7
children 7dddff9fa7f3
files src/alice/test/codesegment/local/bitonicsort/noarrraylist/EvenPhase.java src/alice/test/codesegment/local/bitonicsort/noarrraylist/MakeData.java src/alice/test/codesegment/local/bitonicsort/noarrraylist/OddPhase.java src/alice/test/codesegment/local/bitonicsort/noarrraylist/SetTask.java src/alice/test/codesegment/local/bitonicsort/noarrraylist/ShowData.java src/alice/test/codesegment/local/bitonicsort/noarrraylist/Sort.java
diffstat 6 files changed, 24 insertions(+), 23 deletions(-) [+]
line wrap: on
line diff
--- a/src/alice/test/codesegment/local/bitonicsort/noarrraylist/EvenPhase.java	Tue Mar 26 01:45:05 2013 +0900
+++ b/src/alice/test/codesegment/local/bitonicsort/noarrraylist/EvenPhase.java	Tue Mar 26 01:45:34 2013 +0900
@@ -44,11 +44,11 @@
 		if (info2==null){
 			DataList list = (DataList)info1.obj;
 			if (count > sort_count){
-				ods.update("array"+info.range, list ,false);
+				info1.flip(CommandType.UPDATE, "array"+info.range, list ,false);
 				return;
 			}
-			ods.put(info.range+"f", "dummy");
-			ods.put(info.range+"b", list, false);
+			info1.flip(CommandType.PUT, info.range+"f", "dummy");
+			info3.flip(CommandType.PUT, info.range+"b", list, false);
 			//System.out.println("next Odd "+info.range+" "+info.range+"b"+" "+(info.range+1)+"f");
 			new OddPhase(info0.key,info.range+"b",(info.range+1)+"f",count,info6.key);
 		} else {
@@ -60,25 +60,25 @@
 		    System.arraycopy(list2.table, 0, list3.table, list1.table.length, list2.table.length);
 			
 		    if (count > sort_count){
-				ods.update("array"+info.range, list3 ,false);
+		    	info1.flip(CommandType.UPDATE, "array"+info.range, list3 ,false);
 				return;
 			}
 			int block_num = info3.asInteger();
 			Sort.quickSort(list3, 0, list3.table.length-1);
 			if (!info.lastFlag){
-				ods.put(info.range+"f",	list3.createDataList(0, block_num/2) ,false);
-				ods.put(info.range+"b",	list3.createDataList(block_num/2, block_num/2),false);
+				info1.flip(CommandType.PUT, info.range+"f",	list3.createDataList(0, block_num/2) ,false);
+				info2.flip(CommandType.PUT, info.range+"b",	list3.createDataList(block_num/2, block_num/2),false);
 				//System.out.println("next Odd "+info.range+" "+ info.range+"b"+" "+(info.range+1)+"f");
 				new OddPhase(info0.key,info.range+"b",(info.range+1)+"f",count,info6.key);
 			} else {
 				int last_block_num = info4.asInteger();
-				ods.put(info.range+"f", list3.createDataList(0, block_num/2) ,false);
-				ods.put(info.range+"b", list3.createDataList(block_num/2, last_block_num) ,false);
+				info1.flip(CommandType.PUT, info.range+"f", list3.createDataList(0, block_num/2) ,false);
+				info2.flip(CommandType.PUT, info.range+"b", list3.createDataList(block_num/2, last_block_num) ,false);
 				//System.out.println("next Odd "+info.range+" "+ info.range+"b");
 				new OddPhase(info0.key ,info.range+"b",count,info6.key);
 			}
 
 		}
-		ods.update(info6.key, count+1);
+		info6.flip(CommandType.UPDATE, info6.key, count+1);
 	}
 }
--- a/src/alice/test/codesegment/local/bitonicsort/noarrraylist/MakeData.java	Tue Mar 26 01:45:05 2013 +0900
+++ b/src/alice/test/codesegment/local/bitonicsort/noarrraylist/MakeData.java	Tue Mar 26 01:45:34 2013 +0900
@@ -25,6 +25,6 @@
 		for (int i = 0; i < size; i++){
 			list.table[i] = rnd.nextInt(100000);
 		}
-		ods.update("list", list, false);
+		info2.flip(CommandType.UPDATE, "list", list, false);
 	}
 }
--- a/src/alice/test/codesegment/local/bitonicsort/noarrraylist/OddPhase.java	Tue Mar 26 01:45:05 2013 +0900
+++ b/src/alice/test/codesegment/local/bitonicsort/noarrraylist/OddPhase.java	Tue Mar 26 01:45:34 2013 +0900
@@ -43,13 +43,13 @@
 		if (info2==null){
 			DataList list = (DataList)info1.obj;
 			if (count > sort_count){
-				ods.update("array"+info.range, list, false);
+				info1.flip(CommandType.UPDATE, "array"+info.range, list, false);
 				return;
 			}
 			Sort.quickSort(list,0,list.table.length-1);
 			if (!info.lastFlag){ 
-				ods.put(info.range+"f", list.createDataList(0, block_num/2) ,false);
-				ods.put(info.range+"b", list.createDataList(block_num/2, block_num/2) ,false);
+				info1.flip(CommandType.PUT, info.range+"f", list.createDataList(0, block_num/2) ,false);
+				info3.flip(CommandType.PUT, info.range+"b", list.createDataList(block_num/2, block_num/2) ,false);
 				
 				if (info.range==0){
 					//System.out.println("next Even "+info.range+" "+info.range+"f");	
@@ -59,8 +59,8 @@
 					new EvenPhase(info0.key,(info.range-1)+"b",info.range+"f",count,info6.key);
 				}
 			} else {
-				ods.put(info.range+"f",list, false);
-				ods.put(info.range+"b","dummy");
+				info1.flip(CommandType.PUT, info.range+"f",list, false);
+				info3.flip(CommandType.PUT, info.range+"b","dummy");
 				//System.out.println("next Even "+info.range+" "+ (info.range-1)+"b"+" "+(info.range)+"f");
 				new EvenPhase(info0.key,(info.range-1)+"b",info.range+"f",count,info6.key);
 			}
@@ -74,13 +74,13 @@
 			System.arraycopy(list2.table, 0, list3.table, list1.table.length, list2.table.length);
 			
 			if (count > sort_count){
-				ods.update("array"+info.range, list3, false);
+				info1.flip(CommandType.UPDATE, "array"+info.range, list3, false);
 				return;
 			}
 
 			Sort.quickSort(list3,0,list3.table.length-1);
-			ods.put(info.range+"f", list3.createDataList(0, block_num/2) ,false);
-			ods.put(info.range+"b", list3.createDataList(block_num/2, block_num/2) ,false);
+			info1.flip(CommandType.PUT, info.range+"f", list3.createDataList(0, block_num/2) ,false);
+			info2.flip(CommandType.PUT, info.range+"b", list3.createDataList(block_num/2, block_num/2) ,false);
 
 			if (info.range==0){
 				//System.out.println("next Even2b "+info.range+" "+ info.range+"f");
@@ -90,7 +90,7 @@
 				new EvenPhase(info0.key,(info.range-1)+"b",info.range+"f",count,info6.key);
 			}
 		}
-		ods.update(info6.key, count+1);
+		info6.flip(CommandType.UPDATE, info6.key, count+1);
 	}
 	
 }
--- a/src/alice/test/codesegment/local/bitonicsort/noarrraylist/SetTask.java	Tue Mar 26 01:45:05 2013 +0900
+++ b/src/alice/test/codesegment/local/bitonicsort/noarrraylist/SetTask.java	Tue Mar 26 01:45:34 2013 +0900
@@ -21,6 +21,7 @@
 		
 		int sort_count = conf.getSplitNum();
 		ods.put("sort_count", sort_count*2);
+
 	
 		int block_num = (conf.getLength() + conf.getSplitNum() - 1 ) / sort_count;
 		ods.put("block_num", block_num);
--- a/src/alice/test/codesegment/local/bitonicsort/noarrraylist/ShowData.java	Tue Mar 26 01:45:05 2013 +0900
+++ b/src/alice/test/codesegment/local/bitonicsort/noarrraylist/ShowData.java	Tue Mar 26 01:45:34 2013 +0900
@@ -34,7 +34,7 @@
 		
 		int start = 0;
 		for (int i= 0;i < cnt; i++){
-			DataList dlist = (DataList)info[i].obj;	
+			DataList dlist = (DataList)info[i].obj;
 			System.arraycopy(dlist.table, 0, list.table, start, dlist.table.length);
 			start += dlist.table.length;
 		}
--- a/src/alice/test/codesegment/local/bitonicsort/noarrraylist/Sort.java	Tue Mar 26 01:45:05 2013 +0900
+++ b/src/alice/test/codesegment/local/bitonicsort/noarrraylist/Sort.java	Tue Mar 26 01:45:34 2013 +0900
@@ -4,12 +4,12 @@
 	
 	// this method has "stack overflow" problem
 	public static void quickSort(DataList data, int begin,int end){
-		int[] stack = new int[1024];
+		int[] stack = new int[8192];
 		int sp = 0;
 		int p = 0;
 		while(true){
 			while(begin < end){
-				if (end-begin< 150){
+				if (end-begin< 200){
 					bubbleSort(data,begin,end);
 					break;
 				} else {
@@ -53,7 +53,7 @@
 		System.out.println("checking ....");
 		for (int i = 0; i< data.table.length-1; i++){
 			if (data.table[i] > data.table[i+1]){
-				System.out.println("MISS "+data.table[i]+" > "+data.table[i+1]+"Position is "+i);
+				System.out.println("MISS "+data.table[i]+" > "+data.table[i+1]+" Position is "+i);
 				return;
 			}
 		}