package test.endtoend; import java.io.IOException; import java.io.PrintWriter; import org.autoplot.RenderType; import org.autoplot.ScriptContext; import org.autoplot.dom.Application; import org.autoplot.dom.Row; import org.das2.qds.QDataSet; import org.das2.qds.ops.Ops; import org.autoplot.jythonsupport.Util; /** * Test Autoplot including:<ul> * <li>use case: load wave file and add spectrogram. * <li>more abstract vap file products * </ul> * @author jbf */ public class Test002 { public static void main(String[] args) { try { ScriptContext.getDocumentModel().getOptions().setAutolayout(false); ScriptContext.getDocumentModel().getCanvases(0).getMarginColumn().setRight("100%-10em"); oldTests(); testVaps(); System.exit(0); // TODO: something is firing up the event thread } catch (Exception ex) { ex.printStackTrace(); System.exit(1); } } static long t0 = System.currentTimeMillis(); public static void xxx(String id) { System.err.println("-- timer -- " + id + " --: " + (System.currentTimeMillis() - t0)); t0 = System.currentTimeMillis(); System.err.println("\n\n"); } private static void doTest(final String s, final String label) throws IOException, InterruptedException, Exception { ScriptContext.load(s); int width = ScriptContext.getDocumentModel().getCanvases(0).getWidth(); int height = ScriptContext.getDocumentModel().getCanvases(0).getHeight(); ScriptContext.setCanvasSize(width, height); // TODO: why? I shouldn't have to set this... ScriptContext.writeToPng(label + ".png"); if ( label.equals("test002_009" ) ) { System.err.println("Rows:"); for ( Row r: ScriptContext.getDocumentModel().getCanvases(0).getRows() ) { System.err.println( r ); } Thread.sleep(10000); ScriptContext.load(s); System.err.println("after reload, Rows:"); for ( Row r: ScriptContext.getDocumentModel().getCanvases(0).getRows() ) { System.err.println( r ); } ScriptContext.writeToPng(label + ".png"); } System.err.printf("wrote to %s.png %dx%d\n", label, width, height); } private static void testVaps() throws Exception { String[] uris = new String[]{ "000 file:///home/jbf/ct/hudson/vap/lon/thb_l2_esa_20080907_electrons_less.vap", "001 file:///home/jbf/ct/hudson/vap/energyCompareHydra.vap", ///"002 file:///home/jbf/ct/autoplot/demos/cdaweb/ISS_DOSANL_TEPC_2_burst.vap", "003 file:///home/jbf/ct/hudson/vap/hydra4.vap", "004 file:///home/jbf/ct/hudson/vap/autoSlice.vap", // legacy vap shows adapt slice //"005 file:///home/jbf/ct/hudson/vap/jon-test_v1_07.vap", "006 file:///home/jbf/ct/hudson/vap/omni_1978_v1_07.vap", //mem "007 file:///home/jbf/ct/hudsonvap/Cluster1_HEEA_slices.vap", "008 file:///home/jbf/ct/hudson/vap/lanl/lanlGeoEpDemo4.vap", "009 file:///home/jbf/ct/hudson/vap/ninePanels.vap", "010 http://autoplot.org/data/autoplot-applet.vap", "011 file:///home/jbf/ct/hudson/vap/twoConnectorsOneDataSource.v1_07.vap", "013 file:///home/jbf/ct/autoplot/demos/science/de_eics_species.vap", //TODO: why does this rerange? "014 file:///home/jbf/ct/hudsonvap/garageTemps_v1_07.vap", //mem "014 file:///home/jbf/ct/autoplot/demos/polarUvi.vap", "015 file:///home/jbf/ct/autoplot/demos/polar.vap", //"020 file:///home/jbf/ct/hudson/vap/auto3.vap", "021 file:///home/jbf/ct/hudson/vap/auto4.v1_07.vap", "022 file:///home/jbf/ct/hudson/vap/tt2000.vap", "023 file:///home/jbf/ct/hudson/vap/seth/multiScheme.vap", "024 file:///home/jbf/ct/hudson/vap/demos/eventsBarForAvailability3.vap", "025 file:///home/jbf/ct/hudson/vap/seth/mageis_rank2_labels.vap", // This was removed: "027 file:///home/jbf/ct/hudson/vap/demoBug.1946.vap", "028 vap+inline:x=[10,20,30,40,50,60,70,80,90]&y=[1,5,2,4,2,5,2,3,2]&x,y&RENDER_TYPE=stairSteps>fillColor=silver", //This fails when user tomcat6 tries to run it. disable for now. //"026 file:///home/jbf/ct/hudson/vap/rbsp/efwComponents.vap", // not getting units... }; for (String s : uris) { int count = Integer.parseInt(s.substring(0, 4).trim()); s = s.substring(4); System.err.printf( "=== test002_%03d %s ===\n", count, s ); String label = String.format("test002_%03d", count); try { doTest(s, label); } catch (Exception ex) { PrintWriter pw = new PrintWriter(label + ".error"); pw.println(s); pw.println(""); ex.printStackTrace(pw); pw.close(); ex.printStackTrace(); } xxx(label + ": " + s); } } private static void oldTests() throws Exception, IOException, InterruptedException { QDataSet ds = Util.getDataSet("file:///home/jbf/ct/hudson/data.backup/wav/fireworks.wav"); final Application dom = ScriptContext.getDocumentModel(); dom.getCanvases(0).setFitted(false); ScriptContext.setCanvasSize(400, 800); ScriptContext.plot(0, Ops.autoHistogram(ds)); dom.getPlots(0).getXaxis().getController().getDasAxis().setUseDomainDivider(true); dom.getPlotElements(0).setRenderType(RenderType.fillToZero); dom.getPlots(0).getYaxis().setLabel("auto histogram of!chttp://www.autoplot.org/data/fireworks.wav"); QDataSet ds2 = Ops.autoHistogram(Ops.log10(Ops.fftWindow(ds, 512))); ScriptContext.plot(1, ds2); dom.getPlots(1).getXaxis().getController().getDasAxis().setUseDomainDivider(true); dom.getPlotElements(1).setRenderType(RenderType.fillToZero); dom.getPlots(1).getYaxis().setLabel("auto histogram of!cpower spectrum"); dom.getPlots(1).getXaxis().setLabel("log(Ops.fftWindow(512)"); ScriptContext.writeToPng("test002.png"); } }