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

ucar.nc2.ReduceReader Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 1998-2018 John Caron and University Corporation for Atmospheric Research/Unidata
 * See LICENSE for license information.
 */

package ucar.nc2;

import javax.annotation.concurrent.Immutable;
import ucar.ma2.Array;
import ucar.ma2.InvalidRangeException;
import ucar.ma2.Range;
import ucar.ma2.Section;
import ucar.nc2.util.CancelTask;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * Allow dimensions of length 1 to be removed
 *
 * @author caron
 * @since 12/16/13
 */
@Immutable
class ReduceReader implements ProxyReader {
  private final Variable orgClient;
  private final List dims; // dimension index into original

  /**
   * Reduce 1 or more dimension of length 1
   * 
   * @param orgClient original variable
   * @param dims index(es) in original variable of the dimension to reduce; dimension must be length 1.
   */
  ReduceReader(Variable orgClient, List dims) {
    this.orgClient = orgClient;
    this.dims = new ArrayList<>(dims);
    Collections.sort(this.dims);
  }

  @Override
  public Array reallyRead(Variable client, CancelTask cancelTask) throws IOException {
    Array data = orgClient._read();

    for (int i = dims.size() - 1; i >= 0; i--)
      data = data.reduce(dims.get(i)); // highest first
    return data;
  }

  @Override
  public Array reallyRead(Variable client, Section section, CancelTask cancelTask)
      throws IOException, InvalidRangeException {
    Section.Builder orgSection = Section.builder().appendRanges(section.getRanges());
    for (int dim : dims) {
      orgSection.insertRange(dim, Range.ONE); // lowest first
    }

    Array data = orgClient._read(orgSection.build());
    for (int i = dims.size() - 1; i >= 0; i--)
      data = data.reduce(dims.get(i)); // highest first

    return data;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy