/[xulu]/trunk/src/appl/parallel/test/SplitMapTest.java
ViewVC logotype

Annotation of /trunk/src/appl/parallel/test/SplitMapTest.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 78 - (hide annotations)
Wed Feb 10 16:43:46 2010 UTC (14 years, 11 months ago) by alfonx
File size: 5814 byte(s)
Merged branch 1.8-gt2-2.6 to trunk. Now the trunk is based on GeoTools 2.6.1 and schmitzm-2.0.x
1 mojays 2 package appl.parallel.test;
2    
3     import java.awt.Rectangle;
4     import java.io.File;
5    
6     import junit.framework.Test;
7     import junit.framework.TestCase;
8     import junit.framework.TestSuite;
9 alfonx 78 import schmitzm.data.WritableGrid;
10     import schmitzm.geotools.io.GeoImportUtil;
11 mojays 2 import appl.parallel.data.splittable.SplittableLLProxyGrid;
12     import appl.parallel.spmd.split.AbstractSplitMap;
13     import appl.parallel.spmd.split.SplitMap;
14     import appl.parallel.spmd.split.SplitMap1DHorizontal;
15     import appl.parallel.spmd.split.SplitMap1DVertical;
16     import appl.parallel.spmd.split.SplitMap2D;
17     import appl.util.RasterMetaData;
18     import appl.util.RasterUtil;
19    
20     /**
21     * Generated code for the test suite <b>SplitMapTest</b> located at
22     * <i>/XuluSVN/javasrc/appl/parallel/test/SplitMapTest.testsuite</i>.
23     *
24     * Tests different splitmaps
25     */
26     public class SplitMapTest extends TestCase {
27    
28     Rectangle globalCalcBounds;
29    
30     Rectangle partitionCalcBounds;
31    
32     Rectangle partitionNeighborhoodBounds;
33    
34     Rectangle globalNeighborhoodBounds;
35    
36     Rectangle localCalcBounds;
37    
38     Rectangle localNeighborhoodBounds;
39    
40     private SplittableLLProxyGrid baseGrid;
41    
42     private SplitMap map;
43    
44     /**
45     * Constructor for SplitMapTest.
46     * @param name
47     */
48     public SplitMapTest(String name) {
49     super(name);
50     }
51    
52     /**
53     * Returns the JUnit test suite that implements the <b>SplitMapTest</b>
54     * definition.
55     */
56     public static Test suite() {
57     TestSuite splitMapTest = new TestSuite("SplitMapTest");
58     // splitMapTest.setArbiter(DefaultTestArbiter.INSTANCE).setId(
59     // "D35DB07792EF13413F23D9D0B19111DB");
60     //
61     // splitMapTest.addTest(new SplitMapTest("test1DSplitMap").setId(
62     // "D35DB07792EF134149AEAC40B19111DB").setTestInvocationId(
63     // "D35DB07792EF134168064FE0B19111DB"));
64     return splitMapTest;
65     }
66    
67     /**
68     * @see junit.framework.TestCase#setUp()
69     */
70     protected void setUp() throws Exception {
71     // load a very simple 10x10 Grid
72     WritableGrid loadGrid = GeoImportUtil
73     .readGridRasterFromArcInfoASCII(new File(
74     "../Xulu-Data/regularGrid.arc"));
75     baseGrid = new SplittableLLProxyGrid(new RasterMetaData(loadGrid),2);
76     RasterUtil.copyInto(loadGrid, baseGrid);
77     //RasterUtil.printGrid(baseGrid, "Base grid");
78     }
79    
80     /**
81     * @see junit.framework.TestCase#tearDown()
82     */
83     protected void tearDown() throws Exception {
84     }
85    
86     public void basicTest() {
87     //make simply 2 Partitions without neighborhood
88     map.makeMap();
89     //check first partition
90     initVariables(map, 0);
91     assertEquals(new Rectangle(0, 0, 10, 10), globalCalcBounds);
92     assertEquals(new Rectangle(0, 0, 10, 10), globalNeighborhoodBounds);
93     assertEquals(new Rectangle(0, 0, 5, 10), partitionCalcBounds);
94     assertEquals(new Rectangle(0, 0, 5, 10), partitionNeighborhoodBounds);
95     assertEquals(new Rectangle(0, 0, 5, 10), localCalcBounds);
96     assertEquals(new Rectangle(0, 0, 5, 10), localNeighborhoodBounds);
97     //check second partition
98     initVariables(map, 1);
99     assertEquals(globalCalcBounds, new Rectangle(0, 0, 10, 10));
100     assertEquals(globalNeighborhoodBounds, new Rectangle(0, 0, 10, 10));
101     assertEquals(partitionCalcBounds, new Rectangle(5, 0, 5, 10));
102     assertEquals(partitionNeighborhoodBounds, new Rectangle(5, 0, 5, 10));
103     assertEquals(localCalcBounds, new Rectangle(0, 0, 5, 10));
104     assertEquals(localNeighborhoodBounds, new Rectangle(0, 0, 5, 10));
105     }
106    
107     public void test1DHorizontal() {
108     //2 Partitions
109     map = new SplitMap1DHorizontal(baseGrid.getWidth(), baseGrid.getHeight(),
110     1, 2, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
111    
112    
113    
114     map = new SplitMap1DHorizontal(baseGrid.getWidth(), baseGrid.getHeight(),
115     1, 3, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
116    
117    
118     }
119    
120     public void print(){
121     for(int i=0; i < map.getCount(); i++){
122     RasterUtil.printGrid(baseGrid.getPartition(map.getPartitionCalculationBounds(i)),3,0,"Calculation Partition " + (i+1) + "/" + map.getCount());
123     }
124     for(int i=0; i < map.getCount(); i++){
125     RasterUtil.printGrid(baseGrid.getPartition(map.getPartitionNeighborhoodBounds(i)),3,0,"Neighborhood Partition " + (i+1) + "/" + map.getCount());
126     }
127     }
128    
129     public void test2DIrregular(){
130     // map = new SplitMap2D(10, 10,
131     // 1, 3, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
132    
133     map = new SplitMap2D(baseGrid.getWidth(), baseGrid.getHeight(),
134     1, 9, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
135     print();
136     }
137    
138     /**
139     * 1DSplitMap
140     * @throws Exception
141     */
142     public void test1DVertical() throws Exception {
143     //2 Partitions
144     map = new SplitMap1DVertical(baseGrid.getWidth(), baseGrid.getHeight(),
145     0, 2, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
146     basicTest();
147     //make 3 Partitions
148     map = new SplitMap1DVertical(baseGrid.getWidth(), baseGrid.getHeight(),
149     0, 3, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
150    
151     //make 2 Partitions with neighborhoodrange 2
152     map = new SplitMap1DVertical(baseGrid.getWidth(), baseGrid.getHeight(),
153     2, 2, AbstractSplitMap.NeighborhoodBoxingMode.inBoxing);
154     //intersect the partitions and see if you have the right rect
155    
156     Rectangle r = map.getPartitionNeighborhoodBounds(0).intersection(
157     map.getPartitionNeighborhoodBounds(1));
158     assertEquals(new Rectangle(3, 0, 4, 10), r);
159    
160     initVariables(map, 1);
161     }
162    
163     /**
164     * @param map
165     */
166     private void initVariables(SplitMap map, int pos) {
167     globalCalcBounds = map.getGlobalCalculationBounds();
168     partitionCalcBounds = map.getPartitionCalculationBounds(pos);
169     partitionNeighborhoodBounds = map.getPartitionNeighborhoodBounds(pos);
170     globalNeighborhoodBounds = map.getGlobalBounds();
171     localCalcBounds = map.getLocalCalculationBounds(pos);
172     localNeighborhoodBounds = map.getLocalNeighborhoodBounds(pos);
173    
174     }
175    
176     }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26