All Downloads are FREE. Search and download functionalities are using the official Maven repository.

hex.genmodel.MojoReaderBackendFactory Maven / Gradle / Ivy

There is a newer version: 3.46.0.6
Show newest version
package hex.genmodel;

import hex.genmodel.utils.IOUtils;

import java.io.*;
import java.net.URL;
import java.util.HashMap;
import java.util.zip.ZipEntry;
import java.util.zip.ZipInputStream;

/**
 * Factory class for vending MojoReaderBackend object that can be used to load MOJOs from different data sources.
 *
 * 

This class provides convenience methods for loading MOJOs from files, URLs (this includes classpath resources) * and also from a generic InputStream source.

* *

User needs to make a choice of a Caching Strategy for MOJO sources that are not file based. * Available caching strategies:

*
    *
  • MEMORY: (decompressed) content of the MOJO will be cached in memory, this should be suitable for most cases * (for very large models please make sure that your application has enough memory to hold the unpacked MOJO)
  • *
  • DISK: MOJO is cached in a temporary file on disk, recommended for very large models
  • *
* *

Example of using MojoReaderBackendFactory to read a MOJO from a classpath resource:

* *
 * {@code
 *   public class ExampleApp {
 *     public static void main(String[] args) throws Exception {
 *       URL mojoURL = ExampleApp.class.getResource("/com/company/mojo.zip");
 *       MojoReaderBackend reader = MojoReaderBackendFactory.createReaderBackend(mojoURL, CachingStrategy.MEMORY);
 *       MojoModel model = ModelMojoReader.readFrom(reader);
 *       EasyPredictModelWrapper modelWrapper = new EasyPredictModelWrapper(model);
 *       RowData testRow = new RowData();
 *         for (int i = 0; i < args.length; i++)
 *           testRow.put("C"+i, Double.valueOf(args[i]));
 *       RegressionModelPrediction prediction = (RegressionModelPrediction) modelWrapper.predict(testRow);
 *       System.out.println("Prediction: " + prediction.value);
 *     }
 *   }
 * }
 * 
*/ public class MojoReaderBackendFactory { public enum CachingStrategy { MEMORY, DISK } public static MojoReaderBackend createReaderBackend(String filename) throws IOException { return createReaderBackend(new File(filename)); } public static MojoReaderBackend createReaderBackend(File file) throws IOException { if (file.isFile()) return new ZipfileMojoReaderBackend(file.getPath()); else if (file.isDirectory()) return new FolderMojoReaderBackend(file.getPath()); else throw new IOException("Invalid file specification: " + file); } public static MojoReaderBackend createReaderBackend(URL url, CachingStrategy cachingStrategy) throws IOException { try (InputStream is = url.openStream()) { return createReaderBackend(is, cachingStrategy); } } public static MojoReaderBackend createReaderBackend(InputStream inputStream, CachingStrategy cachingStrategy) throws IOException { switch (cachingStrategy) { case MEMORY: return createInMemoryReaderBackend(inputStream); case DISK: return createTempFileReaderBackend(inputStream); } throw new IllegalStateException("Unexpected caching strategy: " + cachingStrategy); } private static MojoReaderBackend createInMemoryReaderBackend(InputStream inputStream) throws IOException { HashMap content = new HashMap<>(); ZipInputStream zis = new ZipInputStream(inputStream); try { ZipEntry entry; while ((entry = zis.getNextEntry()) != null) { if (entry.getSize() > Integer.MAX_VALUE) throw new IOException("File too large: " + entry.getName()); ByteArrayOutputStream os = new ByteArrayOutputStream(); IOUtils.copyStream(zis, os); content.put(entry.getName(), os.toByteArray()); } zis.close(); } finally { closeQuietly(zis); } return new InMemoryMojoReaderBackend(content); } private static MojoReaderBackend createTempFileReaderBackend(InputStream inputStream) throws IOException { File tmpFile = File.createTempFile("h2o-mojo", ".zip"); tmpFile.deleteOnExit(); // register delete on exit hook (in case tmp reader doesn't do the job) FileOutputStream fos = new FileOutputStream(tmpFile); try { IOUtils.copyStream(inputStream, fos); fos.close(); } catch (IOException e) { closeQuietly(fos); // Windows won't let us delete an open file if (! tmpFile.delete()) e = new IOException(e.getMessage() + " [Note: temp file " + tmpFile + " not deleted]", e); throw e; } finally { closeQuietly(fos); } return new TmpMojoReaderBackend(tmpFile); } private static void closeQuietly(Closeable c) { if (c != null) try { c.close(); } catch (IOException e) { // intentionally ignore exception } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy