public void getSourceFromJiffleBuilder(String script) throws JiffleException { JiffleBuilder builder = new JiffleBuilder(); builder.script(script); // Set source and destination parameters, then... String runtimeSource = builder.getRuntimeSource(); } // docs end getSourceFromJiffleBuilder
public RenderedImage buildAndRunScript(File scriptFile, RenderedImage inputImage) throws JiffleException { JiffleBuilder builder = new JiffleBuilder(); builder.script(scriptFile).source("src", inputImage); builder.dest("dest", inputImage.getWidth(), inputImage.getHeight()); builder.run(); return builder.getImage("dest"); } // docs end method
public static void main(String[] args) throws IOException, JiffleException { String basePath = "/opt/gisData/evo-odas/coverave-view-hetero/multires-s2/S2A_MSIL1C_20170410T103021_N0204_R108_T32UNU_20170410T103020.SAFE/20170410T103021026Z_fullres_CC2.4251_T32UNU_"; // prepare inputs and outputs RenderedImage red = readImage(new File(basePath + "B04.tif")); RenderedImage nir = readImage(new File(basePath + "B08.tif")); TiledImage result = ImageUtilities.createConstantImage(red.getWidth(), red.getHeight(), (float) 0); // build the operation JiffleBuilder builder = new JiffleBuilder(); builder.dest("res", result).source("red", red).source("nir", nir); builder.script("n = nir; r = red; res = (n - r) / (n + r);"); // HERE IS THE NDVI SCRIPT! 5.5 seconds! // builder.script("res = (nir - red) / (nir + red);"); // HERE IS THE NDVI SCRIPT! 7.65 sec! JiffleDirectRuntime runtime = builder.getRuntime(); // actually running the calculation final double pixels = (double) red.getWidth() * (double) red.getHeight(); System.out.println( "Computing " + NumberFormat.getNumberInstance().format(pixels) + " pixels"); long start = System.currentTimeMillis(); runtime.evaluateAll(null); long end = System.currentTimeMillis(); System.out.println("Computation of output took " + (end - start) / 1000.0 + " secs"); System.out.println("Writing output to disk"); ImageIO.write(result, "TIF", new File("/tmp/ndvi.tif")); System.out.println("Writing complete"); }
private void runScript(String script, String destVarName) { try { scriptPane.setText(script); JiffleBuilder builder = new JiffleBuilder(); builder.script(script).dest(destVarName, imageWidth, imageHeight); RenderedImage image = builder.run().getImage(destVarName); imagePane.setImage(image); } catch (JiffleException ex) { ex.printStackTrace(); JOptionPane.showMessageDialog(this, "Errors compiling or running the script", "Bummer", JOptionPane.ERROR_MESSAGE); } }
public void runScriptWithBuilder(File scriptFile) throws Exception { // docs-begin-builder-example JiffleBuilder builder = new JiffleBuilder(); // These chained methods read the script from a file, // create a new image for the output, and run the script builder.script(scriptFile).dest("destImg", 500, 500).run(); RenderedImage result = builder.getImage("destImg"); // docs-end-builder-example } }
@Test public void scriptFile() throws Exception { System.out.println(" loading script file"); URL url = JiffleBuilderTest.class.getResource("constant.jfl"); File scriptFile = new File(url.toURI()); jb.script(scriptFile).dest("dest", 10, 10).run(); // no checking of dest image - just as long as we didn't // get an exception we are happy }
public void runScriptWithBuilder(String script, String destVar, WritableRenderedImage destImage) throws JiffleException { // Image bounds are taken from the destination image Rectangle imageBounds = new Rectangle( destImage.getMinX(), destImage.getMinY(), destImage.getWidth(), destImage.getHeight()); // The world bounds are the unit rectangle Rectangle2D worldBounds = new Rectangle2D.Double(0, 0, 1, 1); CoordinateTransform transform = CoordinateTransforms.unitBounds(imageBounds); JiffleBuilder builder = new JiffleBuilder(); // Set the processing area (world units) builder.worldAndNumPixels(worldBounds, destImage.getWidth(), destImage.getHeight()); // Set the script and the destination image with its transform builder.script(script).dest(destVar, destImage, transform); // This executes the script and writes the results into destImage builder.run(); } // docs end builder method
@Test(expected=JiffleRuntimeException.class) public void readOutsideBoundsWithOptionNotSet() throws Exception { System.out.println(" reading outside image bounds with option not set"); String script = "dest = src[$-1, 0];"; RenderedImage srcImg = ImageUtilities.createConstantImage(4, 4, 0); builder.script(script).source("src", srcImg).dest("dest", 4, 4).run(); }
@Test public void removeImage() throws Exception { System.out.println(" remove image"); String script = "dest = 42;" ; jb.script(script).dest("dest", 10, 10).run(); RenderedImage image = jb.removeImage("dest"); assertNotNull(image); image = jb.getImage("dest"); assertNull(image); }
/** * Compiles and runs the "ripple" script using {@link JiffleBuilder}. * @param args ignored * @throws Exception if there are errors compiling the script. */ public static void main(String[] args) throws Exception { JiffleBuilderDemo me = new JiffleBuilderDemo(); File f = JiffleDemoHelper.getScriptFile(args, ImageChoice.RIPPLES); String script = JiffleDemoHelper.readScriptFile(f); JiffleBuilder jb = new JiffleBuilder(); jb.script(script).dest("result", WIDTH, HEIGHT).getRuntime().evaluateAll(null); ImageFrame frame = new ImageFrame(jb.getImage("result"), "Jiffle image demo"); frame.setVisible(true); } }
@Test public void runMethod() throws Exception { System.out.println(" using run() method"); String script = "dest = x();"; jb.script(script).dest("dest", 10, 10).run(); RenderedImage img = jb.getImage("dest"); assertNotNull(img); Evaluator e = new Evaluator() { int x = 0; public double eval(double val) { int xx = x; x = (x + 1) % IMG_WIDTH; return xx; } }; assertImage(null, img, e); }
@Test public void runBasicScript() throws Exception { System.out.println(" basic script with provided dest image"); String script = "dest = con(src1 > 10, src1, null);" ; RenderedImage srcImg1 = createSequenceImage(); WritableRenderedImage destImg = ImageUtilities.createConstantImage(IMG_WIDTH, IMG_WIDTH, 0d); jb.script(script).source("src1", srcImg1).dest("dest", destImg); JiffleDirectRuntime runtime = jb.getRuntime(); runtime.evaluateAll(null); Evaluator e = new Evaluator() { public double eval(double val) { return val > 10 ? val : Double.NaN; } }; assertImage(srcImg1, destImg, e); }
@Test public void builderCreatesDestImage() throws Exception { System.out.println(" builder creating dest image"); String script = "init { n = 0; } dest = n++ ;" ; jb.dest("dest", IMG_WIDTH, IMG_WIDTH).script(script).getRuntime().evaluateAll(null); RenderedImage img = jb.getImage("dest"); assertNotNull(img); RandomIter iter = RandomIterFactory.create(img, null); int k = 0; for (int y = 0; y < IMG_WIDTH; y++) { for (int x = 0; x < IMG_WIDTH; x++) { assertEquals(k, iter.getSample(x, y, 0)); k++ ; } } }
@Test public void nestedCon() throws Exception { String script = "dest = con(src1, con(src1 > src2, 1, null), null);" ; System.out.println(" " + script); final double threshold = IMG_WIDTH * IMG_WIDTH / 2; RenderedImage src1 = createSequenceImage(); RenderedImage src2 = ImageUtilities.createConstantImage(IMG_WIDTH, IMG_WIDTH, threshold); Evaluator e = new Evaluator() { public double eval(double val) { return val > threshold ? 1 : Double.NaN; } }; JiffleBuilder builder = new JiffleBuilder(); builder.script(script).source("src1", src1).source("src2", src2); builder.dest("dest", IMG_WIDTH, IMG_WIDTH); RenderedImage dest = builder.run().getImage("dest"); assertImage(src1, dest, e); }
builder.script(script).source("src", srcImg).dest("dest", 4, 4).run();
private void assertResult(RenderedImage resultImage, String script) throws Exception { JiffleBuilder builder = new JiffleBuilder(); builder.script(script).dest("dest", WIDTH, WIDTH).run(); RenderedImage referenceImage = builder.getImage("dest"); RectIter resultIter = RectIterFactory.create(resultImage, null); RectIter referenceIter = RectIterFactory.create(referenceImage, null); do { do { assertEquals(resultIter.getSample(), referenceIter.getSample()); resultIter.nextPixelDone(); } while (!referenceIter.nextPixelDone()); resultIter.startPixels(); resultIter.nextLineDone(); referenceIter.startPixels(); } while (!referenceIter.nextLineDone()); } }