ucar.nc2.dt.point.NdbcDataset Maven / Gradle / Ivy
Show all versions of netcdf Show documentation
/*
* 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