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

ucar.nc2.dt.point.NdbcDataset 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.nc2.dt.point;

import ucar.ma2.*;
import ucar.nc2.*;
import ucar.nc2.dataset.NetcdfDataset;
import ucar.nc2.util.CancelTask;
import ucar.nc2.dt.*;

import java.io.*;
import java.util.*;

/**
 * National Data Buoy Center data. This is a time series at a single buoy.
 *
 * 

This is a single station of data. Assumed to be time ordered. * We construct the list of StationObsDatatype records, but without the data cached. * * @see http://www.ndbc.noaa.gov/index.shtml * * @author caron */ // LOOK when from a dods server, record structure not there. Havent dealt with that yet. public class NdbcDataset extends StationObsDatasetImpl implements TypedDatasetFactoryIF { private ArrayInt.D1 dates; private RecordDatasetHelper recordHelper; private StationImpl station; static public boolean isValidFile(NetcdfFile ds) { if (!ds.findAttValueIgnoreCase(null, "Conventions", "").equalsIgnoreCase("COARDS")) return false; if (!ds.findAttValueIgnoreCase(null, "data_provider", "").equalsIgnoreCase("National Data Buoy Center")) return false; if (null == ds.findAttValueIgnoreCase(null, "station", null)) return false; if (null == ds.findAttValueIgnoreCase(null, "location", null)) return false; if (ds.findVariable("lat") == null) return false; if (ds.findVariable("lon") == null) return false; // DODS wont have record !! if (!ds.hasUnlimitedDimension()) return false; return true; } ///////////////////////////////////////////////// // TypedDatasetFactoryIF public boolean isMine(NetcdfDataset ds) { return isValidFile(ds); } public TypedDataset open( NetcdfDataset ncd, ucar.nc2.util.CancelTask task, StringBuilder errlog) throws IOException { return new NdbcDataset( ncd); } public NdbcDataset() {} public NdbcDataset(NetcdfDataset ds) throws IOException { super(ds); recordHelper = new RecordDatasetHelper(ds, "time", null, dataVariables); removeDataVariable("time"); timeUnit = recordHelper.timeUnit; Variable latVar = ds.findVariable("lat"); double lat = latVar.readScalarDouble(); Variable lonVar = ds.findVariable("lon"); double lon = lonVar.readScalarDouble(); // LOOK assume its time ordered Variable dateVar = ds.findVariable("time"); dates = (ArrayInt.D1) dateVar.read(); int count = (int) dates.getSize(); int firstDate = dates.get(0); int lastDate = dates.get( count-1); startDate = timeUnit.makeDate( (double) firstDate); endDate = timeUnit.makeDate( (double) lastDate); String name = ds.findAttValueIgnoreCase(null, "station", null); String stationDesc = ds.findAttValueIgnoreCase(null, "description", null); // only one station in the file station = new StationImpl( name, stationDesc, lat, lon, Double.NaN, count); stations.add( station); // typed dataset fields title = ds.findAttValueIgnoreCase(null, "data_provider", null) +" Station "+name; desc = title +"\n" + ds.findAttValueIgnoreCase(null, "data_quality", null); setBoundingBox(); } protected void setTimeUnits() {} protected void setStartDate() {} protected void setEndDate() {} protected void setBoundingBox() { boundingBox = stationHelper.getBoundingBox(); } public List getData(CancelTask cancel) throws IOException { return getData( station, cancel); } public int getDataCount() { Dimension unlimitedDim = ncfile.getUnlimitedDimension(); return unlimitedDim.getLength(); } public List getData( ucar.unidata.geoloc.Station s, CancelTask cancel) throws IOException { StationImpl si = (StationImpl) s; int count = getDataCount(); if (null == si.getObservations()) { for (int recno = 0; recno < count; recno++) { double time = dates.get(recno); si.addObs( recordHelper.new RecordStationObs( s, time, time, recno)); if ((cancel != null) && cancel.isCancel()) return null; } } return si.getObservations(); } public DataIterator getDataIterator(int bufferSize) throws IOException { return new NdbcDatatypeIterator(recordHelper.recordVar, bufferSize); } private class NdbcDatatypeIterator extends DatatypeIterator { protected Object makeDatatypeWithData(int recnum, StructureData sdata) { return recordHelper.new RecordStationObs( station, sdata); } NdbcDatatypeIterator(Structure struct, int bufferSize) { super( struct, bufferSize); } } /* public void initNonRecordCase(NetcdfFile ds) throws IOException { this.ds = ds; Variable timeVar = ds.findVariable("record.timeObs"); String timeUnitString = ds.findAttValueIgnoreCase(timeVar, "units", "seconds since 1970-01-01"); try { dateUnit = (DateUnit) SimpleUnit.factoryWithExceptions(timeUnitString); } catch (Exception e) { System.out.println("Error on string = "+timeUnitString+" == "+e.getMessage()); dateUnit = (DateUnit) SimpleUnit.factory("seconds since 1970-01-01"); } // get the station info ArrayChar stationIdArray = (ArrayChar) ds.findVariable("id").read(); ArrayChar stationDescArray = (ArrayChar) ds.findVariable("location").read(); Array latArray = ds.findVariable("latitude").read(); Array lonArray = ds.findVariable("longitude").read(); Array elevArray = ds.findVariable("elevation").read(); Array lastRecordArray = ds.findVariable("lastReport").read(); Index ima = lastRecordArray.getIndex(); int n = ds.findVariable("num_stations").readScalarInt(); for (int i = 0; i





© 2015 - 2025 Weber Informatics LLC | Privacy Policy