[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
matlab/netcdf Interface
- Subject: matlab/netcdf Interface
- Date: Wed, 16 Mar 1994 15:18:56 -0700
------- Forwarded Message
>From address@hidden Wed Mar 16 06:07:41 1994
Message-Id: <address@hidden>
To: address@hidden
Subject: ["Miller, Philip W.": Matlab/netcdf interface]
Date: Wed, 16 Mar 1994 13:07:41 -0700
From: Russ Rew <address@hidden>
- ------- Forwarded Message
id AA08972; Wed, 16 Mar 1994 13:29:39 -0500
id <address@hidden>; Wed, 16 Mar 94 13:29:06 PST
From: "Miller, Philip W." <address@hidden>
To: Netcdf <address@hidden>
Subject: Matlab/netcdf interface
Date: Wed, 16 Mar 94 13:26:00 PST
Message-Id: <address@hidden>
Encoding: 133 TEXT
X-Mailer: Microsoft Mail V3.0
I sent the list a message asking for a SAS/netcdf interface similar to the
Matlab/netcdf interface. I have not yet had a positive response to my
request for a SAS interface, but I have had two people ask about the matlab
interface. I take no credit for the matlab interface; I am only a
satisfied user. I responded personally to the people asking about the
matlab interface, but the mail to Brad Beattie was undeliverable. Since I
do not know how to contact Brad and this may be of general interest to the
list, I am posting the README file from the Matlab mexcdf distribution.
I am still hopeful some kind person out there will share their SAS/netcdf
interface.
Phil Miller
address@hidden
--------------------------------------------
/pub/mexcdf/README
available via anonymous ftp from crusty.er.usgs.gov (128.128.19.19)
MEXCDF is a mex-file interface between netCDF and MATLAB 3.5
and 4.1 (for UNIX machines)
that invokes the complete C-Language netCDF interface,
as described in the NetCDF Users Guide. This allows MATLAB
users to read, write, and manipulate netCDF data files in an
efficient manner.
What you should do:
1. Get the mexcdf mex-file.
If you have a SUN 4, DECstation, Mac, or 386PC running Matlab 3.5,
you should be able to grab the appropriate mexcdf binary from
/pub/mexcdf/bin/v35:
mexcdf.mexds DECstation (works with Matlab version 3.5)
mexcdf.mex4 Sun 4 (works with Matlab version 3.5)
mexcdf.mex Mac (macbinary) (works with Matlab version 3.5)
mexcdf.sit.hqx Mac (ASCII) (works with Matlab version 3.5)
mexcdf.mx3 IBM PC 386 (works with Matlab version 3.5, j or
later)
If you have a SUN 4, DECstation, or PC running MATLAB for WINDOWS,
you should be able to grab the appropriate mexcdf binary from
/pub/mexcdf/bin/v41:
mexcdf.mexds DECstation (works with Matlab version 4.1)
mexcdf.mex IBM PC (works with Matlab for Windows)
mexcdf.mex4 Sun 4 (works with Matlab version 4.1)
Use binary mode when you get these files, EXCEPT for
mexcdf.sit.hqx, which should be transfered as ASCII. mexcdf.sit.hqx
should be un-binhexed using binhex4.0 or higher and then unstuffed
using un-stuffit.
NOTE: DON'T rename the mexcdf binary. MATLAB expects MEX files to have
platform-specific file extentions (mex4 on Sun4, mexds on DEC, etc.)
Also get mexcdf.m, which describes the usage of mexcdf and
will allow you to use "help mexcdf" from within matlab.
If you need to compile the source code for mexcdf, grab
the files in /pub/mexcdf/src. Note that mexcdf.c must
be compiled with an ANSI C compiler (e.g. gcc).
2. Get the usage of mexcdf by typing "mexcdf" in Matlab, or check
out the file mexcdf.m.
3. mget everything in the /pub/mexcdf/tools directory (all the m-files
and flux.dat) and check out
some applications that use mexcdf. Note to DOS-Users:
Some of the m-files have file names that are longer than 8 characters,
but they are all uniquely specified by the first 8 characters. Thus
the tools work fine under Matlab on the PC.
The function getcdf.m is an interactive routine written by Jim Mansbridge
that leads you through the extraction of data from netCDF files.
The function mcvgt.m is a noninteractive routine that returns netCDF data
when you already know the name of the variable you want and the
indices of the data slab you wish to return.
The function create_ts.m creates a netCDF time series file using file
using
NOAA PMEL's EPIC conventions. This allows the created file to
be interfaced directly to Don Denbo's PlotPlus program.
The function getts.m gets time series data from netCDF files using
EPIC conventions (e.g. files written by create_ts.m). The user specifies
the variable and the start and stop time and is returned the data
variable and a Julian time variable.
The script cdf_demo.m demonstrates the use of create_ts.m and getts.m by
creating a netcdf time series file of heat flux from Matlab, then
reading selected data back into Matlab.
The function read_gmt.m reads GMT style netCDF grid files (GMT is
Paul Wessel and Walter Smith's freely available plotting and
analysis package).
History of mexcdf: Chuck Denham (address@hidden)
wrote the first netCDF/Matlab interface using m-files
that called stand-alone C-programs to implement the interface. For each
netCDF operation, netCDF files were opened and closed, and netCDF data
were written to matlab .mat files which were then "loaded" into Matlab.
The result was useful, but inefficient. To increase the efficiency,
Jim Mansbridge of CSIRO (address@hidden) combined many
operations
into a single FORTRAN mex-file, called xnetcdf.f. Realizing the utility
of this method, Julie Allen of WHOI (address@hidden) rewrote xnetcdf.f
in C, implemented additional operations (including operations relating to
creation of netCDF files from Matlab), and named the mexfile mexcdf.c.
The mexcdf.c code was rewritten by Chuck Denham to allow more flexibility
in the way the netCDF operations are invoked, and to streamline the code
to work on Macintosh and IBM PCs.
EXAMPLE ftp session:
ftp crusty.er.usgs.gov
user anonymous
cd pub/mexcdf/bin
binary
get mexcdf.mex4 (for sun4)
ascii
cd pub/mexcdf/tools
mget *
bye
- ------- End of Forwarded Message
------- End of Forwarded Message