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

ucar.ma2.ArraySequence Maven / Gradle / Ivy

Go to download

The NetCDF-Java Library is a Java interface to NetCDF files, as well as to many other types of scientific data formats.

There is a newer version: 4.3.22
Show newest version
/*
 * Copyright 1998-2009 University Corporation for Atmospheric Research/Unidata
 *
 * Portions of this software were developed by the Unidata Program at the
 * University Corporation for Atmospheric Research.
 *
 * Access and use of this software shall impose the following obligations
 * and understandings on the user. The user is granted the right, without
 * any fee or cost, to use, copy, modify, alter, enhance and distribute
 * this software, and any derivative works thereof, and its supporting
 * documentation for any purpose whatsoever, provided that this entire
 * notice appears in all copies of the software, derivative works and
 * supporting documentation.  Further, UCAR requests that the user credit
 * UCAR/Unidata in any publications that result from the use of this
 * software or in any product that includes this software. The names UCAR
 * and/or Unidata, however, may not be used in any advertising or publicity
 * to endorse or promote any products or commercial entity unless specific
 * written permission is obtained from UCAR/Unidata. The user also
 * understands that UCAR/Unidata is not obligated to provide the user with
 * any support, consulting, training or assistance of any kind with regard
 * to the use, operation and performance of this software nor to provide
 * the user with any updates, revisions, new versions or "bug fixes."
 *
 * THIS SOFTWARE IS PROVIDED BY UCAR/UNIDATA "AS IS" AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL UCAR/UNIDATA BE LIABLE FOR ANY SPECIAL,
 * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING
 * FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
 * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
 * WITH THE ACCESS, USE OR PERFORMANCE OF THIS SOFTWARE.
 */
package ucar.ma2;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Formatter;

/**
 * ArraySequence is the way to contain the data for a Sequence, using a StructureDataIterator.
 * A Sequence is a one-dimensional Structure with indeterminate length.
 * The only data access is through getStructureIterator().
 * So an ArraySequence is really a wrapper around a StructureDataIterator, adapting it to an Array.
 * 
 * @author caron
 * @since Feb 27, 2008
 */
public class ArraySequence extends ArrayStructure {
  private StructureDataIterator iter;

  protected ArraySequence(StructureMembers sm, int[] shape) {
    super(sm, shape);
  }

  /**
   * Constructor
   * @param members the members
   * @param iter the iterator
   * @param nelems iterator count, may be missing (<0)
   */
  public ArraySequence(StructureMembers members, StructureDataIterator iter, int nelems) {
    super(members, new int[] {0});
    this.iter = iter;
    this.nelems = nelems;
  }

  /**                                                             n
   * @return StructureDataIterator.class
   */
  @Override
  public Class getElementType() {
    return StructureDataIterator.class;
  }

  @Override
  public StructureDataIterator getStructureDataIterator() throws java.io.IOException {
    iter = iter.reset();
    return iter;
  }

  public int getStructureDataCount() {
    return nelems;
  }

    @Override
  public long getSizeBytes() {
    return nelems * members.getStructureSize(); // LOOK we may not know the count ???
  }

  @Override
  protected StructureData makeStructureData(ArrayStructure as, int index) {
    throw new UnsupportedOperationException("Cannot subset a Sequence");
  }

  @Override
  public Array extractMemberArray(StructureMembers.Member proxym) throws IOException {
    if (proxym.getDataArray() != null)
      return proxym.getDataArray();

    DataType dataType = proxym.getDataType();
    boolean isScalar = (proxym.getSize() == 1) || (dataType == DataType.SEQUENCE);

    // combine the shapes
    int[] mshape = proxym.getShape();
    int rrank = 1 + mshape.length;
    int[] rshape = new int[rrank];
    rshape[0] = nelems;
    System.arraycopy(mshape, 0, rshape, 1, mshape.length);

    if (nelems < 0)
      return extractMemberArrayFromIteration(proxym, rshape);

    // create an empty array to hold the result
    Array result;
    if (dataType == DataType.STRUCTURE) {
      StructureMembers membersw = new StructureMembers(proxym.getStructureMembers()); // no data arrays get propagated
      result = new ArrayStructureW(membersw, rshape);
    } else {
      result = Array.factory(dataType.getPrimitiveClassType(), rshape);
    }

    StructureDataIterator sdataIter = getStructureDataIterator();
    IndexIterator resultIter = result.getIndexIterator();

    while (sdataIter.hasNext()) {
      StructureData sdata = sdataIter.next();
      StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());

      if (isScalar) {
        if (dataType == DataType.DOUBLE)
          resultIter.setDoubleNext(sdata.getScalarDouble(realm));

        else if (dataType == DataType.FLOAT)
          resultIter.setFloatNext(sdata.getScalarFloat(realm));

        else if ((dataType == DataType.BYTE) || (dataType == DataType.ENUM1))
          resultIter.setByteNext(sdata.getScalarByte(realm));

        else if ((dataType == DataType.SHORT) || (dataType == DataType.ENUM2))
          resultIter.setShortNext(sdata.getScalarShort(realm));

        else if ((dataType == DataType.INT) || (dataType == DataType.ENUM4))
          resultIter.setIntNext(sdata.getScalarInt(realm));

        else if (dataType == DataType.LONG)
          resultIter.setLongNext(sdata.getScalarLong(realm));

        else if (dataType == DataType.CHAR)
          resultIter.setCharNext(sdata.getScalarChar(realm));

        else if (dataType == DataType.STRING)
          resultIter.setObjectNext(sdata.getScalarString(realm));

        else if (dataType == DataType.STRUCTURE)
          resultIter.setObjectNext( sdata.getScalarStructure(realm));

        else if (dataType == DataType.SEQUENCE)
          resultIter.setObjectNext( sdata.getArraySequence(realm));

    } else {
        if (dataType == DataType.DOUBLE) {
          double[] data = sdata.getJavaArrayDouble(realm);
          for (double aData : data) resultIter.setDoubleNext(aData);

        } else if (dataType == DataType.FLOAT) {
          float[] data = sdata.getJavaArrayFloat(realm);
          for (float aData : data) resultIter.setFloatNext(aData);

        } else if ((dataType == DataType.BYTE) || (dataType == DataType.ENUM1)) {
          byte[] data = sdata.getJavaArrayByte(realm);
          for (byte aData : data) resultIter.setByteNext(aData);

        } else if ((dataType == DataType.SHORT)|| (dataType == DataType.ENUM2)) {
          short[] data = sdata.getJavaArrayShort(realm);
          for (short aData : data) resultIter.setShortNext(aData);

        } else if ((dataType == DataType.INT)|| (dataType == DataType.ENUM4)) {
          int[] data = sdata.getJavaArrayInt(realm);
          for (int aData : data) resultIter.setIntNext(aData);

        } else if (dataType == DataType.LONG) {
          long[] data = sdata.getJavaArrayLong(realm);
          for (long aData : data) resultIter.setLongNext(aData);

        } else if (dataType == DataType.CHAR) {
          char[] data = sdata.getJavaArrayChar(realm);
          for (char aData : data) resultIter.setCharNext(aData);

        } else if (dataType == DataType.STRING) {
          String[] data = sdata.getJavaArrayString(realm);
          for (String aData : data) resultIter.setObjectNext(aData);

        } else if (dataType == DataType.STRUCTURE) {
          ArrayStructure as = sdata.getArrayStructure(realm);
          StructureDataIterator innerIter = as.getStructureDataIterator();
          while (innerIter.hasNext())
            resultIter.setObjectNext( innerIter.next());
        }

        // LOOK SEQUENCE, OPAQUE ??
      }
    }

    return result;
  }

  private int initial = 1000; // ??
  // when we dont know how many in the iteration
  private Array extractMemberArrayFromIteration(StructureMembers.Member proxym, int[] rshape) throws IOException {
    DataType dataType = proxym.getDataType();
    StructureDataIterator sdataIter = getStructureDataIterator();
    Object dataArray = null;
    int count = 0;

    if (dataType == DataType.DOUBLE) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        double[] data = sdata.getJavaArrayDouble(realm);
        for (double aData : data) result.add(aData);
        count++;
      }
      double[] da = new double[result.size()];
      int i = 0;
      for (Double d : result) da[i++] = d;
      dataArray = da;

    } else if (dataType == DataType.FLOAT) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        float[] data = sdata.getJavaArrayFloat(realm);
        for (float aData : data) result.add(aData);
        count++;
      }
      float[] da = new float[result.size()];
      int i = 0;
      for (Float d : result) da[i++] = d;
      dataArray = da;

    } else if ((dataType == DataType.BYTE) || (dataType == DataType.ENUM1)) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        byte[] data = sdata.getJavaArrayByte(realm);
        for (byte aData : data) result.add(aData);
        count++;
      }
      byte[] da = new byte[result.size()];
      int i = 0;
      for (Byte d : result) da[i++] = d;
      dataArray = da;

    } else if ((dataType == DataType.SHORT)|| (dataType == DataType.ENUM2)) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        short[] data = sdata.getJavaArrayShort(realm);
        for (short aData : data) result.add(aData);
        count++;
      }
      short[] da = new short[result.size()];
      int i = 0;
      for (Short d : result) da[i++] = d;
      dataArray = da;

    } else if ((dataType == DataType.INT)|| (dataType == DataType.ENUM4)) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        int[] data = sdata.getJavaArrayInt(realm);
        for (int aData : data) result.add(aData);
        count++;
      }
      int[] da = new int[result.size()];
      int i = 0;
      for (Integer d : result) da[i++] = d;
      dataArray = da;

    } else if (dataType == DataType.LONG) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        long[] data = sdata.getJavaArrayLong(realm);
        for (long aData : data) result.add(aData);
        count++;
      }
      long[] da = new long[result.size()];
      int i = 0;
      for (Long d : result) da[i++] = d;
      dataArray = da;

    } else if (dataType == DataType.CHAR) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        char[] data = sdata.getJavaArrayChar(realm);
        for (char aData : data) result.add(aData);
        count++;
      }
      char[] da = new char[result.size()];
      int i = 0;
      for (Character d : result) da[i++] = d;
      dataArray = da;

    } else if (dataType == DataType.STRING) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        String[] data = sdata.getJavaArrayString(realm);
        for (String aData : data) result.add(aData);
        count++;
      }
      String[] da = new String[result.size()];
      int i = 0;
      for (String d : result) da[i++] = d;
      dataArray = da;

    } else if (dataType == DataType.STRUCTURE) {
      ArrayList result = new ArrayList(initial);
      while (sdataIter.hasNext()) {
        StructureData sdata = sdataIter.next();
        StructureMembers.Member realm = sdata.getStructureMembers().findMember(proxym.getName());
        ArrayStructure as = sdata.getArrayStructure(realm);
        StructureDataIterator innerIter = as.getStructureDataIterator();
        while (innerIter.hasNext())
          result.add( innerIter.next());
        count++;
      }
      StructureData[] da = new StructureData[result.size()];
      rshape[0] = count;
      StructureMembers membersw = new StructureMembers(proxym.getStructureMembers()); // no data arrays get propagated
      return new ArrayStructureW(membersw, rshape, da);
    }

    // create an array to hold the result
    rshape[0] = count;
    return Array.factory(dataType.getPrimitiveClassType(), rshape, dataArray);
  }

  @Override
  public String toString() {
    return getClass().getName()+" nelems="+ Integer.toString(nelems); 
  }

  @Override
  public void showInternal(Formatter f, String leadingSpace) {
    super.showInternal(f, leadingSpace);
    f.format("%sStructureDataIterator Class=%s hash=0x%x%n", leadingSpace, iter.getClass().getName(), iter.hashCode());
    if (iter instanceof ArrayStructure.ArrayStructureIterator) {
      ArrayStructure.ArrayStructureIterator ii = (ArrayStructure.ArrayStructureIterator)  iter;
      ii.getArrayStructure().showInternal(f, leadingSpace+"  ");     
    }
  }  

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy