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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2 - (hide annotations)
Wed Feb 25 11:54:01 2009 UTC (15 years, 11 months ago) by mojays
File size: 9409 byte(s)
First Commit, corresponds to Revision 1008 of Wikisquare-SVN 
1 mojays 2 package appl.parallel.test;
2    
3     import java.awt.Rectangle;
4     import java.io.File;
5     import java.io.FileInputStream;
6     import java.io.Serializable;
7     import java.util.Random;
8     import java.util.Vector;
9    
10     import junit.framework.Test;
11     import junit.framework.TestCase;
12     import junit.framework.TestSuite;
13    
14     import org.apache.log4j.BasicConfigurator;
15     import org.apache.log4j.ConsoleAppender;
16     import org.apache.log4j.Layout;
17     import org.apache.log4j.Level;
18     import org.apache.log4j.LogManager;
19     import org.apache.log4j.Logger;
20     import org.apache.log4j.PropertyConfigurator;
21    
22     import edu.bonn.xulu.io.ImportFactory;
23     import edu.bonn.xulu.plugin.io.grid.array.WritableGridArrayFactory;
24    
25     import schmitzm.data.WritableGrid;
26     import schmitzm.data.WritableGridArray;
27     import schmitzm.data.WritableGridRaster;
28     import schmitzm.geotools.io.GeoImportUtil;
29    
30     import appl.parallel.ComputingResourceContainer;
31     import appl.parallel.client.RemoteEventHandler;
32     import appl.parallel.client.ClientDataServer;
33     import appl.parallel.data.splittable.SplittableLLProxyGrid;
34     import appl.parallel.services.GlobalDiscoveryService;
35     import appl.parallel.spmd.AbstractSPMDTask;
36     import appl.parallel.spmd.SPMDClientController;
37     import appl.parallel.spmd.SPMDTask;
38     import appl.parallel.spmd.SPMDServerController;
39     import appl.parallel.spmd.split.SplittableGrid;
40     import appl.util.RasterMetaData;
41     import appl.util.RasterUtil;
42    
43     /**
44     * This is a minor modification of {@link SPMDTest}. It is only used to test the
45     * Multi-Splittable functionality of the parallelization. For the test of all
46     * other features and more detailed information see {@link SPMDTest}.
47     *
48     * @author Dominik Appl
49     */
50     public class SPMDTest_MultiGrid extends TestCase implements Serializable {
51    
52     transient private final Logger LOG = LogManager.getLogger(this.getClass()
53     .getName());
54    
55     transient private ClientDataServer client;
56     transient private Vector<ComputingResourceContainer> computingResources;
57     transient private SPMDClientController clientController;
58    
59     transient SplittableGrid gridInput;
60     transient SplittableGrid remoteInput;
61     transient SplittableGrid localOutput;
62     transient SplittableGrid remoteOutput;
63    
64     /**
65     * Constructor for SPMDTest.
66     *
67     * @param name
68     */
69     public SPMDTest_MultiGrid(String name) {
70     super(name);
71     }
72    
73     /**
74     * Returns the JUnit test suite that implements the <b>SPMDTest</b>
75     * definition.
76     */
77     public static Test suite() {
78     TestSuite sPMDTest = new TestSuite("SPMDTest");
79     // sPMDTest.setArbiter(DefaultTestArbiter.INSTANCE).setId(
80     // "E873D66A70977ED2A98AAC10B54511DB");
81     //
82     // sPMDTest.addTest(new SPMDTest("testSPMD").setId(
83     // "E873D66A70977ED2E5E8ED20B54511DB").setTestInvocationId(
84     // "E873D66A70977ED2EF7E3C00B54511DB"));
85     return sPMDTest;
86     }
87    
88     /**
89     * @see junit.framework.TestCase#setUp()
90     */
91     protected void setUp() throws Exception {
92     PropertyConfigurator.configure("xululog4j.cfg");
93     computingResources = new GlobalDiscoveryService()
94     .getRemoteResources();
95    
96     for (ComputingResourceContainer computingRes : computingResources) {
97     System.out.println("DiscoveredRessource " + computingRes);
98     }
99     LOG.info("Discovery finished...");
100     RemoteEventHandler handler = new RemoteEventHandler();
101     client = new ClientDataServer(handler);
102     clientController = new SPMDClientController(computingResources,null, client,handler);
103     // ////////// Initialise data \\\\\\\\\\\\\
104     WritableGridRaster baseGrid = GeoImportUtil
105     .readGridRasterFromArcInfoASCII(new File(
106     "../Xulu-Data/minigrid2.arc")); // small data
107     // "../Xulu-Data/large_clue_data/sc1gr0.0")); //large data
108     gridInput = new SplittableLLProxyGrid(new WritableGridArrayFactory(),
109     new RasterMetaData(baseGrid));
110     localOutput = new SplittableLLProxyGrid(new WritableGridArrayFactory(),
111     new RasterMetaData(baseGrid));
112     remoteInput = new SplittableLLProxyGrid(new WritableGridArrayFactory(),
113     new RasterMetaData(baseGrid));
114     remoteOutput = new SplittableLLProxyGrid(
115     new WritableGridArrayFactory(), new RasterMetaData(baseGrid));
116     RasterUtil.copyInto(baseGrid, gridInput);
117     RasterUtil.copyInto(baseGrid, remoteInput);
118     //RasterUtil.copyInto(baseGrid, localOutput);
119     //RasterUtil.copyInto(baseGrid, remoteOutput);
120     }
121    
122     /**
123     * @see junit.framework.TestCase#tearDown()
124     */
125     protected void tearDown() throws Exception {
126     client.close();
127     clientController.close();
128     // GlobalDiscoveryService.getInstance().stopServices();
129     }
130    
131     /**
132     * TestSPMD
133     *
134     * @throws Exception
135     */
136     public void testSPMD() throws Exception {
137     int steps = 4;
138     int neighborhoodRange = 3;
139     System.out.println("Starting step 1: ");
140    
141     /***********************************************************************
142     * START LOCAL ALGORITHM ******************** The simple Algorithm will
143     * calculate the average of the neighborhood und write the output to the
144     * coresponing cell in the output cell
145     **********************************************************************/
146    
147     Rectangle partition = new Rectangle(0, 0, gridInput.getWidth(),
148     gridInput.getHeight());
149     if (gridInput.getWidth() < 20)
150     RasterUtil.printGrid(gridInput, 5, 1, "Input");
151    
152     for (int step = 0; step < steps; step++) {
153     // the overallsum is simply the sum over all elements
154     float overallSum = 0f;
155     long localStartTime = System.currentTimeMillis();
156     for (int y = 0; y < gridInput.getHeight(); y++)
157     for (int x = 0; x < gridInput.getWidth(); x++) {
158     float tmp = gridInput.getRasterSampleAsFloat(x, y);
159     if (!Float.isNaN(tmp))
160     overallSum += tmp;
161     // the local sum is simply the sum over all elements in the
162     // neighborhood
163     float localSum = 0;
164     // number of cells over which the sum is calculated
165     int noOfCells = 0;
166     // for each cell: calculate the sum of all neighbors
167     for (int y2 = y - neighborhoodRange; y2 <= y
168     + neighborhoodRange; y2++)
169     for (int x2 = x - neighborhoodRange; x2 <= x
170     + neighborhoodRange; x2++)
171     // check if the coordinates are valid (inside the
172     // grid and not NaN)
173     if (partition.contains(x2, y2))
174     if (!Float.isNaN(gridInput
175     .getRasterSampleAsFloat(x2, y2))) {
176     localSum += gridInput
177     .getRasterSampleAsFloat(x2, y2);
178     noOfCells++;
179     }
180    
181     localOutput.setRasterSample(localSum / (float) (noOfCells),
182     x, y);
183    
184     }
185    
186     System.out.print("Finished step " + (step+1) + " in "
187     + ((System.currentTimeMillis() - localStartTime)) + " ms");
188     localStartTime = System.currentTimeMillis();
189     System.out.println(" with sum (local calculated): " + overallSum);
190     //copy values into results from output to input (for next step)
191     RasterUtil.copyInto(localOutput, gridInput);
192     }
193     if(gridInput.getWidth()<20)
194     RasterUtil.printGrid(localOutput, 5, 1, "Local Output");
195    
196    
197    
198    
199     /***********************************************************************
200     * START REMOTE ALGORITHM
201     * ******************** All the same..now remotely********************/
202    
203     System.out
204     .println("******************* starting remote execution *****************");
205     long remoteStartTime = System.currentTimeMillis();
206     clientController.setNeighborhoodRange(neighborhoodRange);
207     // initialize as MulitSplittable
208     WritableGrid[] testSplittable = {remoteInput,remoteOutput};
209     clientController.addToMultiDataSplitControl(testSplittable, "gridData");
210    
211     // clientController.addToSplitControl(remoteInput, "inputGrid");
212     // clientController.addToSplitControl(remoteOutput, "outputGrid");
213     System.out.println("After "
214     + ((System.currentTimeMillis() - remoteStartTime))
215     + "ms: finished with adding to splitcontroll");
216    
217     //********************** START STEP CONTROL *********************
218     for (int step = 0; step < steps; step++) {
219     if(step > 0){
220     long updateStartTime = System.currentTimeMillis();
221     clientController.updateNeighborhood(remoteInput);
222     System.out.println("Update took:" + (System.currentTimeMillis()-updateStartTime));
223     }
224     Object[] sum;
225     try {
226     sum = clientController.runSPMDModelTask(
227     new AverageNeighborhoodTestTask_MultiGrid(), neighborhoodRange);
228     //add results
229     float overallSum = 0;
230     for (int i = 0; i < sum.length; i++)
231     overallSum += (Float) sum[i];
232     System.out.println("finished step "
233     + (step+1) + " in "
234     + ((System.currentTimeMillis() - remoteStartTime))
235     + "ms " + " with sum "+
236     + overallSum);
237     remoteStartTime = System.currentTimeMillis();
238    
239     } catch (Throwable e) {
240     // TODO Auto-generated catch block
241     e.printStackTrace();
242     }
243     }
244     //***************** END STEP CONTROL *****************************
245    
246     //After execution:
247     // merge partitions and check if the local and remotely calculated
248     // versions are equal
249     remoteStartTime = System.currentTimeMillis();
250     clientController.mergePartition(remoteOutput);
251     System.out.println("Merging took another "
252     + ((System.currentTimeMillis() - remoteStartTime))
253     + "ms");
254     // Thread.currentThread().sleep(10000);
255     if(remoteInput.getWidth()<20)
256     RasterUtil.printGrid(remoteOutput, 5, 1, "Remote Output");
257     assertTrue(RasterUtil.checkEqual(remoteOutput, localOutput, true));
258     }
259     }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26