當前位置: 首頁>>代碼示例>>Java>>正文


Java Dataset類代碼示例

本文整理匯總了Java中ncsa.hdf.object.Dataset的典型用法代碼示例。如果您正苦於以下問題:Java Dataset類的具體用法?Java Dataset怎麽用?Java Dataset使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Dataset類屬於ncsa.hdf.object包,在下文中一共展示了Dataset類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: _writeArray

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected Dataset _writeArray(String name, Group parent, H5Datatype type,
                              long[] dims,
                              Object data)
    throws Exception
{
    boolean chunked = ArrayUtil.product(dims) > 0;
    /* chunking and/or compression are broken for empty arrays */
    log.debug("Creating {} with dims=[{}] size=[{}] chunks=[{}]...",
              name, xJoined(dims), "", chunked ? xJoined(dims) : "");

    Dataset ds = this.output.createScalarDS(name, parent, type,
                                            dims,
                                            chunked ? dims.clone() : null,
                                            chunked ? dims.clone() : null,
                                            chunked ? compression_level : 0,
                                            data);
    log.info("Created {} with dims=[{}] size=[{}] chunks=[{}]",
             name, xJoined(dims), "", chunked ? xJoined(dims) : "");
    return ds;
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:21,代碼來源:ResultWriterHDF5.java

示例2: writeSpeciesVector

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected void writeSpeciesVector(String name, String title,
                                  Group parent, String[] species, int[] which)
    throws Exception
{
    final String[] specout;
    if (which == null)
        specout = species;
    else {
        specout = new String[which.length];
        for (int i = 0; i < which.length; i++)
            specout[i] = species[which[i]];
    }

    Dataset ds = writeVector(name, parent, specout);
    setAttribute(ds, "TITLE", title);
    setAttribute(ds, "LAYOUT", "[nspecies]");
    setAttribute(ds, "UNITS", "text");
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:19,代碼來源:ResultWriterHDF5.java

示例3: _writeGrid

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected void _writeGrid(VolumeGrid vgrid, double startTime, IGridCalc source)
    throws Exception
{
    Trial t = this.getTrial(source.trial());
    t.writeSimulationData(source);

    /* Only write stuff for the first trial to save time and space */
    if (source.trial() > 0)
        return;

    Group model = this.model();

    t._writeGrid(vgrid, startTime, source);

    writeSpeciesVector("species", "names of all species", model, species, null);

    t.writeRegionLabels(model, source);
    t.writeStimulationData(model, source);
    t.writeReactionData(model, source);
    t.writeEventData(model, source);

    {
        Group output_info = this.output.createGroup("output", model);
        setAttribute(output_info, "TITLE", "output species");
        t.writeOutputInfo(output_info);
    }

    {
        String s = source.getSource().serialize();
        Dataset ds = writeVector("serialized_config", model, s);
        setAttribute(ds, "TITLE", "serialized config");
        setAttribute(ds, "LAYOUT", "XML");
    }
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:35,代碼來源:ResultWriterHDF5.java

示例4: writeRegionLabels

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected void writeRegionLabels(Group parent, IGridCalc source)
    throws Exception
{
    String[] regions = source.getSource().getVolumeGrid().getRegionLabels();
    Dataset ds = writeVector("regions", parent, regions);
    setAttribute(ds, "TITLE", "names of regions");
    setAttribute(ds, "LAYOUT", "[nregions]");
    setAttribute(ds, "UNITS", "text");
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:10,代碼來源:ResultWriterHDF5.java

示例5: writeOutputInfo

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected void writeOutputInfo(Group parent, String identifier,
                                int[] which, int[] elements)
    throws Exception
{
    Group group = output.createGroup(identifier, parent);

    writeSpeciesVector("species", "names of output species", group, species, which);

    Dataset ds = writeVector("elements", group, elements);
    setAttribute(ds, "TITLE", "indices of output elements");
    setAttribute(ds, "LAYOUT", "[nelements]");
    setAttribute(ds, "UNITS", "indices");
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:14,代碼來源:ResultWriterHDF5.java

示例6: getSomething

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
/***********************************************************************
 ***************             Model loading            ******************
 ***********************************************************************/

private static <T> T getSomething(H5File h5, String path)
    throws Exception
{
    Dataset obj = (Dataset) h5.get(path);
    if (obj == null) {
        log.error("Failed to retrieve \"{}\"", path);
        throw new Exception("Path \"" + path + "\" not found");
    }

    return (T) obj.getData();
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:16,代碼來源:ResultWriterHDF5.java

示例7: writeArray

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected Dataset writeArray(String name, Group parent, double[][] items)
    throws Exception
{
    int maxlength = ArrayUtil.maxLength(items);
    long[] dims = {items.length, maxlength};

    double[] flat = ArrayUtil.flatten(items, maxlength);

    return _writeArray(name, parent, double_t, dims, flat);
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:11,代碼來源:ResultWriterHDF5.java

示例8: writeVector

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected Dataset writeVector(String name, Group parent, String... items)
    throws Exception
{
    int maxlength = Math.max(ArrayUtil.maxLength(items) * 4, 1);
    long[] dims = {items.length};

    H5Datatype string_t = new H5Datatype(Datatype.CLASS_STRING, maxlength,
                                         Datatype.NATIVE, Datatype.NATIVE);

    return _writeArray(name, parent, string_t, dims, items);
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:12,代碼來源:ResultWriterHDF5.java

示例9: loadPopulationFromTime

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
private static int[][] loadPopulationFromTime(H5File h5,
                                              int trial,
                                              String output_set,
                                              double pop_from_time)
    throws Exception
{
    String path = "/trial" + trial + "/output/" + output_set;

    final int index;
    {
        double[] times = getSomething(h5, path + "/times");
        if (pop_from_time == -1)
            index = times.length - 1;
        else if (pop_from_time < 0)
            throw new Exception("Time must be nonnegative or -1");
        else {
            index = Arrays.binarySearch(times, pop_from_time);
            if (index < 0)
                throw new Exception("time= " + pop_from_time + " not found "
                                    + "in " + path + "/times");
        }
    }

    String poppath = path + "/population";
    Dataset obj = (Dataset) h5.get(poppath);
    if (obj == null) {
        log.error("Failed to retrieve \"{}\"", path);
        throw new Exception("Path \"" + path + "\" not found");
    }

    /* This is necessary to retrieve dimensions */
    obj.init();

    int rank = obj.getRank();
    long[] dims = obj.getDims();
    long[] start = obj.getStartDims();
    long[] selected = obj.getSelectedDims();
    int[] selectedIndex = obj.getSelectedIndex();

    log.info("Retrieving population from {}:{} row {}", h5, poppath, index);
    log.debug("pristine rank={} dims={} start={} selected={} selectedIndex={}",
              rank, dims, start, selected, selectedIndex);
    start[0] = index;
    selected[0] = 1;
    selected[1] = dims[1];
    selected[2] = dims[2];
    log.debug("selected rank={} dims={} start={} selected={} selectedIndex={}",
              rank, dims, start, selected, selectedIndex);
    int[] data = (int[]) obj.getData();
    int[][] pop = ArrayUtil.reshape(data, (int) dims[1], (int) dims[2]);
    // log.debug("{}", (Object) pop);
    return pop;
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:54,代碼來源:ResultWriterHDF5.java

示例10: createExtensibleArray

import ncsa.hdf.object.Dataset; //導入依賴的package包/類
protected H5ScalarDS createExtensibleArray(String name, Group parent, Datatype type,
                                           String TITLE, String LAYOUT, String UNITS,
                                           long... dims)
    throws Exception
{
    long[] maxdims = dims.clone();
    maxdims[0] = H5F_UNLIMITED;
    long[] chunks = dims.clone();

    /* avoid too small chunks */
    chunks[0] = 1;
    if (ArrayUtil.product(chunks) == 0)
        throw new RuntimeException("Empty chunks: " + xJoined(chunks));

    while (ArrayUtil.product(chunks) < 1024)
        chunks[0] *= 2;

    /* do not write any data in the beginning */
    dims[0] = 0;

    /* Create dataspace */
    int filespace_id = H5.H5Screate_simple(dims.length, dims, maxdims);

    /* Create the dataset creation property list, add the shuffle filter
     * and the gzip compression filter. The order in which the filters
     * are added here is significant — we will see much greater results
     * when the shuffle is applied first. The order in which the filters
     * are added to the property list is the order in which they will be
     * invoked when writing data. */
    int dcpl_id = H5.H5Pcreate(HDF5Constants.H5P_DATASET_CREATE);
    H5.H5Pset_shuffle(dcpl_id);
    H5.H5Pset_deflate(dcpl_id, compression_level);
    H5.H5Pset_chunk(dcpl_id, dims.length, chunks);

    /* Create the dataset */
    final String path = parent.getFullName() + "/" + name;
    H5.H5Dcreate(this.output.getFID(), path,
                 type.toNative(), filespace_id,
                 HDF5Constants.H5P_DEFAULT, dcpl_id, HDF5Constants.H5P_DEFAULT);
    Dataset ds = new H5ScalarDS(this.output, path, "/");
    ds.init();

    log.info("Created {} with dims=[{}] size=[{}] chunks=[{}]",
             name, xJoined(dims), xJoined(maxdims), xJoined(chunks));

    setAttribute(ds, "TITLE", TITLE);
    setAttribute(ds, "LAYOUT", LAYOUT);
    setAttribute(ds, "UNITS", UNITS);

    return (H5ScalarDS) ds;
}
 
開發者ID:neurord,項目名稱:stochdiff,代碼行數:52,代碼來源:ResultWriterHDF5.java


注:本文中的ncsa.hdf.object.Dataset類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。