/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package test.endtoend;

import java.io.IOException;
import org.das2.dataset.VectorUtil;
import org.das2.datum.DatumRange;
import org.das2.datum.DatumRangeUtil;
import org.das2.datum.Units;
import org.das2.graph.DefaultPlotSymbol;
import org.autoplot.ScriptContext;
import org.autoplot.dom.Application;
import org.das2.qds.DataSetOps;
import org.das2.qds.DataSetUtil;
import org.das2.qds.MutablePropertyDataSet;
import org.das2.qds.QDataSet;
import org.das2.qds.WritableDataSet;
import org.das2.qds.ops.Ops;

/**
 * das2 end-to-end tests of renderers and tick labelling.  Introduced as part
 * of migration to DomainDivider for tick labelling.
 * @author jbf
 */
public class Test009 {

    static long t0= System.currentTimeMillis();

    public static void writePng( String name ) throws InterruptedException, IOException {
        ScriptContext.writeToPng( name );
        System.out.println("wrote "+name+"  timer: "+(System.currentTimeMillis()-t0));
        resetTimer();
    }

    static void resetTimer() {
        t0= System.currentTimeMillis();
    }

    /**
     * tests at limits of rendering, including single-element datasets, font limits, long labels, zoom
     *
     */
    private static void extremes() throws InterruptedException, IOException {

        Application dom= ScriptContext.getDocumentModel();

        ScriptContext.reset();
        ScriptContext.setCanvasSize(640,480);
        dom.getCanvases(0).setFont("sans-14");

        resetTimer();
        
        ScriptContext.plot( "vap+inline:6.28" ); // single-point series
        dom.getPlotElements(0).getStyle().setSymbolSize(10);
        dom.getPlotElements(0).getStyle().setPlotSymbol(DefaultPlotSymbol.STAR);

        writePng( "test009_040.png" );

        ScriptContext.plot( "vap+inline:ripples(1,30)" ); // 1-record spectrogram  //TODO: image not limited in X
        writePng( "test009_041.png" );

        ScriptContext.plot( "vap+inline:1,2,3,4,5" );
        dom.getPlots(0).getXaxis().setRange( DatumRangeUtil.newDimensionless( 1.9999, 2.0001 ) );
        dom.getPlots(0).getYaxis().setRange( DatumRangeUtil.newDimensionless( 2.9999, 3.0001 ) );
        dom.getPlots(0).setTitle("Colinear points are not colinear when you zoom in");
        writePng( "test009_042.png" );
        
        ScriptContext.plot( "vap+inline:ripples(50)" );
        dom.getCanvases(0).setFont("sans-16");
        dom.getPlots(0).setTitle(".......... This is a really really really really really really really really long title, yes it is ........!cwith a subtitle and extreme symbols: Στ′♦€‡!c");

        String l= "B-GSM!n!u2!r!d3!n!uUP"; //TODO: shows a bug with GrannyTextRender, I think.  Yep, !r without !s causes exception.
        l= "B-GSM!s!n!u2!r!d3!n!kUP!n";

        dom.getPlots(0).getXaxis().setLabel("... This is a really really really really really really really really long label ...!c"+l );
        dom.getPlots(0).getYaxis().setLabel("... This is a really really really really really really really really long label ...!c"+l );
        writePng( "test009_043.png" );

    }

    private static void test1() throws IOException, InterruptedException {
        Application dom = ScriptContext.getDocumentModel();
        ScriptContext.setCanvasSize(800, 600);
        dom.getOptions().setAutolayout(false);
        dom.getCanvases(0).getMarginColumn().setRight("100%-10em");
        ScriptContext.setCanvasSize(800, 600);
        dom.getCanvases(0).setFont("sans-14");
        resetTimer();
        writePng("test009_001.png");
        ScriptContext.save("test009_001.vap");
        dom.getPlots(0).getXaxis().setRange(DatumRangeUtil.parseTimeRangeValid("2009-08-10"));
        writePng("test009_002.png");
        dom.getPlots(0).getXaxis().setRange(DatumRangeUtil.parseTimeRangeValid("1990-01-01 03:15:01 to 03:15:02"));
        writePng("test009_003.png");
        dom.getPlots(0).getXaxis().setRange(DatumRangeUtil.parseTimeRangeValid("1990-01-01 03:15:01.100 to 03:15:01.110"));
        writePng("test009_004.png");
        dom.getPlots(0).getYaxis().setLog(true);
        writePng("test009_005.png");
        dom.getPlots(0).getYaxis().setRange(DatumRangeUtil.newDimensionless(1, 100));
        writePng("test009_006.png");
        dom.getPlots(0).getYaxis().setRange(DatumRangeUtil.newDimensionless(1, 1.1));
        writePng("test009_007.png");
        dom.getPlots(0).getYaxis().setLabel("Y-Axis Label");
        QDataSet rank1Rand = Ops.accum(Ops.randomn(-12345, 10000000));
        resetTimer();
        writePng("test009_008.png");
        ScriptContext.plot(DataSetOps.trim(rank1Rand, 0, 1000));
        writePng("test009_009.png");
        ScriptContext.plot(DataSetOps.trim(rank1Rand, 0, 100000));
        writePng("test009_010.png");
        ScriptContext.plot(DataSetOps.trim(rank1Rand, 0, 10000000));
        writePng("test009_011.png");
        QDataSet vds = rank1Rand;
        QDataSet xds = Ops.findgen(vds.length());
        vds = VectorUtil.reduce2D(xds, vds, 0, vds.length(), Units.dimensionless.createDatum(1e5), Units.dimensionless.createDatum(100));
        ScriptContext.plot(vds);
        writePng("test009_011a.png");
        QDataSet rank2Rand = Ops.add(Ops.randomn(-12345, 100000, 100), Ops.sin(Ops.add(Ops.outerProduct(Ops.linspace(0, 1000., 100000), Ops.replicate(1, 100)), Ops.outerProduct(Ops.replicate(1, 100000), Ops.linspace(0, 10, 100)))));
        resetTimer();
        ScriptContext.plot(DataSetOps.trim(rank2Rand, 0, 100)); // redo these tests with rank2Rand.trim() native trim.
        writePng("test009_012.png");
        ScriptContext.plot(DataSetOps.trim(rank2Rand, 0, 10000));
        writePng("test009_013.png");
        ScriptContext.plot(DataSetOps.trim(rank2Rand, 0, 100000));
        writePng("test009_014.png");
        
        QDataSet x = Ops.randomn(-12345, 1000);
        QDataSet y = Ops.randomn(-12344, 1000);
        ScriptContext.plot(x, y, Ops.sqrt(Ops.add(Ops.pow(x, 2), Ops.pow(y, 2))));
        ScriptContext.setRenderStyle("colorScatter");
        dom.getPlotElements(0).getStyle().setSymbolSize(10);
        writePng("test009_015.png");
        ScriptContext.writeToPdf("test009_015.pdf");
        ScriptContext.setCanvasSize(200, 160);
        dom.getCanvases(0).getMarginColumn().setRight("100%-3em");
        dom.getCanvases(0).setFont("sans-8");
        dom.getPlots(0).getXaxis().setRange(DatumRange.newDatumRange(999, 1021, Units.dimensionless));
        writePng("test009_016.png");
        x = Ops.linspace(-9, 9, 1000);
        y = Ops.cos(x);
        ((MutablePropertyDataSet) y).putProperty(QDataSet.FILL_VALUE, -1e31);
        for (int i = 50; i < 60; i++) {
            ((WritableDataSet) y).putValue(i, -1e31);
        }
        
        ScriptContext.plot(x, y);
        ScriptContext.setRenderStyle("fillToZero");
        ScriptContext.setCanvasSize(800, 600);
        dom.getPlotElements(0).getStyle().setSymbolSize(2);
        writePng("test009_017.png");

        int nn= 50000; // greater than PlotElementController.LARGE_DATASET_COUNT
        QDataSet yy = Ops.randomn(-12344, nn );
        QDataSet zz = Ops.add( yy, Ops.divide( Ops.randomn(-12345, nn ), 10 ) );
        QDataSet tt= Ops.putProperty( Ops.indgen(nn), QDataSet.UNITS, Units.t2010 );
        
        ScriptContext.plot( tt, yy, zz );
        
        ScriptContext.setRenderStyle("colorScatter");
        writePng("test009_018.png");
        
        //dom.getPlots(0).getXaxis().setLog( true );
        //writePng( "test009_017.png" );
        //dom.getPlots(0).getXaxis().setRange( DatumRangeUtil.parseTimeRangeValid("1990-01-01 03:15:01 to 03:15:02") );
        //writePng( "test009_018.png" );

    }

    public static void main(String[] args)  {
        try {

            test1();

            extremes();

            System.exit(0);  // TODO: something is firing up the event thread

        } catch ( RuntimeException ex ) {
            ex.printStackTrace();
            System.exit(1);
        } catch ( InterruptedException ex ) {
            ex.printStackTrace();
            System.exit(1);
        } catch ( IOException ex ) {
            ex.printStackTrace();
            System.exit(1);
        }
    }

}