Mercurial > hg > Members > tatsuki > Alice
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; } }