sclass JEImageCompressionTest1 { settable BufferedImage originalImage; settable BufferedImage scaledImage; *() { this(screenshot()); } *(BufferedImage *originalImage) {} int rows = 20; int imgHeight = 200; Matrix m; long dataBytes, dataChars; Matrix> grid; JE_CompressEachElementIndividually strat; CompressionSearch_AnyType search; CompressionSearch_AnyType.Submission winner; S get() { assertNotNull(originalImage); scaledImage = resizeImageToHeight(originalImage, imgHeight); m = imageToMatrix(scaledImage); dataBytes = m.nCells()*4+2; dataChars = dataBytes*2 + l("lInt(\"\")"); print("Matrix ~ " + takeFirst_str(60, m)); print("Trivial comp ~ " + (m.nCells()*8)); grid = matrixToMNGrid_rows(m, rows); // the cells as int matrices L> flat = matrixToList(grid); // the cells as int lists //L cells = map intMatrixToByteList_littleEndian(flat); L cells = map matrixToList(flat); search = jeCompressionSearch(cells, dataChars); strat = new JE_CompressEachElementIndividually() .elementCompressionStrategy(-> new JE_RepElement) .onCompressionFail(ints -> javaObjectToIJavaExpr(ints); //enableScaffolding(search.scheduler()); //enableScaffolding(strat); //print(scaffolding := metaGet(strat, "scaffolding")); search.addStrategy(strat); runProbabilisticForNSeconds(5.0, search); winner = search.bestSubmission(); print(strat.stats()); if (winner != null) { //print("Hard result (score " + result.scoreRatio() + ")", result.checkUnder(hardJERegime()); print(winner); } ret winnerCode(); } S winnerCode() { ret winner == null ?: str(winner.decompressor()); } }