Package ucar.ma2

Class Index

    • Constructor Summary

      Constructors 
      Modifier Constructor Description
      protected Index​(int rank)
      General case Index - use when you want to manipulate current elements yourself
      protected Index​(int[] _shape)
      Constructor for subclasses only.
        Index​(int[] _shape, int[] _stride)
      Constructor that lets you set the strides yourself.
    • Method Summary

      All Methods Static Methods Instance Methods Concrete Methods 
      Modifier and Type Method Description
      Object clone()  
      static long computeSize​(int[] shape)
      Compute total number of elements in the array.
      int currentElement()
      Get the current element's index into the 1D backing array.
      static Index factory​(int[] shape)
      Generate a subclass of Index optimized for this array's rank
      int[] getCurrentCounter()
      Get the current counter.
      int getRank()
      Get the number of dimensions in the array.
      int[] getShape()
      Get the shape: length of array in each dimension.
      int getShape​(int index)
      Get the length of the ith dimension.
      long getSize()
      Get the total number of elements in the array.
      int incr()
      Increment the current element by 1.
      protected void precalc()
      subclass specialization/optimization calculations
      Index set​(int v0)
      set current element at dimension 0 to v0
      Index set​(int[] index)
      Set the current element's index.
      Index set​(int v0, int v1)
      set current element at dimension 0,1 to v0,v1
      Index set​(int v0, int v1, int v2)
      set current element at dimension 0,1,2 to v0,v1,v2
      Index set​(int v0, int v1, int v2, int v3)
      set current element at dimension 0,1,2,3 to v0,v1,v2,v3
      Index set​(int v0, int v1, int v2, int v3, int v4)
      set current element at dimension 0,1,2,3,4 to v0,v1,v2,v3,v4
      Index set​(int v0, int v1, int v2, int v3, int v4, int v5)
      set current element at dimension 0,1,2,3,4,5 to v0,v1,v2,v3,v4,v5
      Index set​(int v0, int v1, int v2, int v3, int v4, int v5, int v6)
      set current element at dimension 0,1,2,3,4,5,6 to v0,v1,v2,v3,v4,v5,v6
      Index set0​(int v)
      set current element at dimension 0 to v
      Index set1​(int v)
      set current element at dimension 1 to v
      Index set2​(int v)
      set current element at dimension 2 to v
      Index set3​(int v)
      set current element at dimension 3 to v
      Index set4​(int v)
      set current element at dimension 4 to v
      Index set5​(int v)
      set current element at dimension 5 to v
      Index set6​(int v)
      set current element at dimension 6 to v
      void setCurrentCounter​(int currElement)
      Set the current counter from the 1D "current element" currElement = offset + stride[0]*current[0] + ...
      void setDim​(int dim, int value)
      set current element at dimension dim to v
      String toString()  
      String toStringDebug()
      String representation
    • Field Detail

      • scalarIndexImmutable

        public static final Index0D scalarIndexImmutable
      • shape

        protected int[] shape
      • stride

        protected int[] stride
      • rank

        protected int rank
      • size

        protected long size
      • offset

        protected int offset
      • current

        protected int[] current
      • hasvlen

        protected boolean hasvlen
    • Constructor Detail

      • Index

        protected Index​(int rank)
        General case Index - use when you want to manipulate current elements yourself
        Parameters:
        rank - rank of the Index
      • Index

        protected Index​(int[] _shape)
        Constructor for subclasses only.
        Parameters:
        _shape - describes an index section: slowest varying comes first (row major)
      • Index

        public Index​(int[] _shape,
                     int[] _stride)
        Constructor that lets you set the strides yourself. This is used as a counter, not a description of an index section.
        Parameters:
        _shape - Index shape
        _stride - Index stride
    • Method Detail

      • factory

        public static Index factory​(int[] shape)
        Generate a subclass of Index optimized for this array's rank
        Parameters:
        shape - use this shape
        Returns:
        a subclass of Index optimized for this array's rank
      • computeSize

        public static long computeSize​(int[] shape)
        Compute total number of elements in the array. Stop at vlen
        Parameters:
        shape - length of array in each dimension.
        Returns:
        total number of elements in the array.
      • precalc

        protected void precalc()
        subclass specialization/optimization calculations
      • getRank

        public int getRank()
        Get the number of dimensions in the array.
        Returns:
        the number of dimensions in the array.
      • getShape

        public int[] getShape()
        Get the shape: length of array in each dimension.
        Returns:
        the shape
      • getShape

        public int getShape​(int index)
        Get the length of the ith dimension.
        Parameters:
        index - which dimension. must be in [0, getRank())
        Returns:
        the ith dimension length
      • getSize

        public long getSize()
        Get the total number of elements in the array.
        Returns:
        the total number of elements in the array.
      • currentElement

        public int currentElement()
        Get the current element's index into the 1D backing array. VLEN stops processing.
        Returns:
        the current element's index into the 1D backing array.
      • getCurrentCounter

        public int[] getCurrentCounter()
        Get the current counter.
        Returns:
        copy of the current counter.
      • setCurrentCounter

        public void setCurrentCounter​(int currElement)
        Set the current counter from the 1D "current element" currElement = offset + stride[0]*current[0] + ...
        Parameters:
        currElement - set to this value
      • incr

        public int incr()
        Increment the current element by 1. Used by IndexIterator. General rank, with subclass specialization. Vlen skipped.
        Returns:
        currentElement()
      • set

        public Index set​(int[] index)
        Set the current element's index. General-rank case.
        Parameters:
        index - set current value to these values
        Returns:
        this, so you can use A.get(i.set(i))
        Throws:
        ArrayIndexOutOfBoundsException - if index.length != rank.
      • setDim

        public void setDim​(int dim,
                           int value)
        set current element at dimension dim to v
        Parameters:
        dim - set this dimension
        value - to this value
      • set0

        public Index set0​(int v)
        set current element at dimension 0 to v
        Parameters:
        v - set 0th dimension index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set1

        public Index set1​(int v)
        set current element at dimension 1 to v
        Parameters:
        v - set dimension 1 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set2

        public Index set2​(int v)
        set current element at dimension 2 to v
        Parameters:
        v - set dimension 2 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set3

        public Index set3​(int v)
        set current element at dimension 3 to v
        Parameters:
        v - set dimension 3 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set4

        public Index set4​(int v)
        set current element at dimension 4 to v
        Parameters:
        v - set dimension 4 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set5

        public Index set5​(int v)
        set current element at dimension 5 to v
        Parameters:
        v - set dimension 5 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set6

        public Index set6​(int v)
        set current element at dimension 6 to v
        Parameters:
        v - set dimension 6 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set

        public Index set​(int v0)
        set current element at dimension 0 to v0
        Parameters:
        v0 - set dimension 0 index to this value
        Returns:
        this, so you can use A.get(i.set(i))
      • set

        public Index set​(int v0,
                         int v1)
        set current element at dimension 0,1 to v0,v1
        Parameters:
        v0 - set dimension 0 index to this value
        v1 - set dimension 1 index to this value
        Returns:
        this, so you can use A.get(i.set(i,j))
      • set

        public Index set​(int v0,
                         int v1,
                         int v2)
        set current element at dimension 0,1,2 to v0,v1,v2
        Parameters:
        v0 - set dimension 0 index to this value
        v1 - set dimension 1 index to this value
        v2 - set dimension 2 index to this value
        Returns:
        this, so you can use A.get(i.set(i,j,k))
      • set

        public Index set​(int v0,
                         int v1,
                         int v2,
                         int v3)
        set current element at dimension 0,1,2,3 to v0,v1,v2,v3
        Parameters:
        v0 - set dimension 0 index to this value
        v1 - set dimension 1 index to this value
        v2 - set dimension 2 index to this value
        v3 - set dimension 3 index to this value
        Returns:
        this, so you can use A.get(i.set(i,j,k,l))
      • set

        public Index set​(int v0,
                         int v1,
                         int v2,
                         int v3,
                         int v4)
        set current element at dimension 0,1,2,3,4 to v0,v1,v2,v3,v4
        Parameters:
        v0 - set dimension 0 index to this value
        v1 - set dimension 1 index to this value
        v2 - set dimension 2 index to this value
        v3 - set dimension 3 index to this value
        v4 - set dimension 4 index to this value
        Returns:
        this, so you can use A.get(i.set(i,j,k,l,m))
      • set

        public Index set​(int v0,
                         int v1,
                         int v2,
                         int v3,
                         int v4,
                         int v5)
        set current element at dimension 0,1,2,3,4,5 to v0,v1,v2,v3,v4,v5
        Parameters:
        v0 - set dimension 0 index to this value
        v1 - set dimension 1 index to this value
        v2 - set dimension 2 index to this value
        v3 - set dimension 3 index to this value
        v4 - set dimension 4 index to this value
        v5 - set dimension 5 index to this value
        Returns:
        this, so you can use A.get(i.set(i,j,k,l,m,n))
      • set

        public Index set​(int v0,
                         int v1,
                         int v2,
                         int v3,
                         int v4,
                         int v5,
                         int v6)
        set current element at dimension 0,1,2,3,4,5,6 to v0,v1,v2,v3,v4,v5,v6
        Parameters:
        v0 - set dimension 0 index to this value
        v1 - set dimension 1 index to this value
        v2 - set dimension 2 index to this value
        v3 - set dimension 3 index to this value
        v4 - set dimension 4 index to this value
        v5 - set dimension 5 index to this value
        v6 - set dimension 6 index to this value
        Returns:
        this, so you can use A.get(i.set(i,j,k,l,m,n,p))
      • toStringDebug

        public String toStringDebug()
        String representation
        Returns:
        String representation