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"); }
@Before public void setup() { builder = new JiffleBuilder(); }
@Before public void setup() { jb = new JiffleBuilder(); }
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 } }
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
/** * 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 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); }
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()); } }