This file is indexed.

/usr/share/doc/netCDF/html/ncFAQ.html is in netcdf-doc 1:4.4.0-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.11"/>
<title>NetCDF: FAQ</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
  $(document).ready(initResizable);
  $(window).load(resizeHeight);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
  $(document).ready(function() { init_search(); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectlogo"><img alt="Logo" src="netcdf-50x50.png"/></td>
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">NetCDF
   &#160;<span id="projectnumber">4.4.0</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.11 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>NetCDF&#160;Documentation</span></a></li>
      <li class="current"><a href="pages.html"><span>Navigation</span></a></li>
      <li><a href="modules.html"><span>NetCDF&#160;Functions</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li><a href="examples.html"><span>Examples</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
        <span class="left">
          <img id="MSearchSelect" src="search/mag_sel.png"
               onmouseover="return searchBox.OnSearchSelectShow()"
               onmouseout="return searchBox.OnSearchSelectHide()"
               alt=""/>
          <input type="text" id="MSearchField" value="Search" accesskey="S"
               onfocus="searchBox.OnSearchFieldFocus(true)" 
               onblur="searchBox.OnSearchFieldFocus(false)" 
               onkeyup="searchBox.OnSearchFieldChange(event)"/>
          </span><span class="right">
            <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
          </span>
        </div>
      </li>
    </ul>
  </div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
      <div id="nav-sync" class="sync"></div>
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('ncFAQ.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<div class="header">
  <div class="headertitle">
<div class="title">FAQ </div>  </div>
</div><!--header-->
<div class="contents">
<div class="toc"><h3>Table of Contents</h3>
<ul><li class="level1"><a href="#ncFAQGeneral">General            </a><ul><li class="level2"><a href="#What-Is-netCDF">What Is netCDF?  </a></li>
<li class="level2"><a href="#HowdoIgetthenetCDFsoftwarepackage">How do I get the netCDF software package? </a></li>
<li class="level2"><a href="#How-do-I-convert-netCDF-data-to-ASCII-or-text">How do I convert netCDF data to ASCII or text? </a></li>
<li class="level2"><a href="#How-do-I-convert-ASCII-or-text-data-to-netCDF">How do I convert ASCII or text data to netCDF? </a></li>
<li class="level2"><a href="#What-is-the-best-way-to-represent-some-particular-data-using-netCDF">What is the best way to represent [some particular data] using netCDF? </a></li>
<li class="level2"><a href="#What-convention-should-be-used-for-the-names-of-netCDF-files">What convention should be used for the names of netCDF files? </a></li>
<li class="level2"><a href="#Is-there-a-mailing-list-for-netCDF-discussions-and-questions">Is there a mailing list for netCDF discussions and questions? </a></li>
<li class="level2"><a href="#Where-are-some-examples-of-netCDF-datasets">Where are some examples of netCDF datasets? </a></li>
<li class="level2"><a href="#What-is-the-best-way-to-handle-time-using-netCDF">What is the best way to handle time using netCDF? </a></li>
<li class="level2"><a href="#Who-else-uses-netCDF">Who else uses netCDF? </a></li>
<li class="level2"><a href="#What-are-some-references-to-netCDF">What are some references to netCDF? </a></li>
<li class="level2"><a href="#How-should-I-cite-use-of-netCDF-software">I&#39;m submitting a paper for publication and want to include a citation for use of netCDF software. What reference should I use? </a></li>
<li class="level2"><a href="#Is-there-a-document-describing-the-actual-physical-format-for-a-Unidata-netCDF-file">Is there a document describing the actual physical format for a Unidata netCDF file? </a></li>
</ul>
</li>
<li class="level1"><a href="#Installation-and-Porting">Installation and Porting                      </a><ul><li class="level2"><a href="#What-does-netCDF-run-on">What does netCDF run on? </a></li>
<li class="level2"><a href="#HowcanIusecu">How can I use current versions of netCDF-4 with Windows? </a></li>
<li class="level2"><a href="#HowcanIusenetCDF41withWindows">How can I use netCDF-4.1 with Windows? </a></li>
<li class="level2"><a href="#How-can-I-use-netCDF-4-with-Windows">How can I use netCDF-4 with Windows? </a></li>
<li class="level2"><a href="#How-do-I-build-and-install-netCDF-for-a-specific-development-environment">How do I build and install netCDF for a specific development environment? </a></li>
<li class="level2"><a href="#How-can-I-tell-if-I-successfully-built-and-installed-netCDF">How can I tell if I successfully built and installed netCDF? </a></li>
<li class="level2"><a href="#How-can-I-tell-what-version-Im-using">How can I tell what version I&#39;m using? </a></li>
<li class="level2"><a href="#Where-does-netCDF-get-installed">Where does netCDF get installed? </a></li>
</ul>
</li>
<li class="level1"><a href="#formatsdatamodelssoftwarereleases">Formats, Data Models, and Software Releases </a><ul><li class="level2"><a href="#How-many-netCDF-formats-are-there-and-what-are-the-differences-among-them">How many netCDF formats are there, and what are the differences among them? </a></li>
<li class="level2"><a href="#How-can-I-tell-which-format-a-netCDF-file-uses">How can I tell which format a netCDF file uses? </a></li>
<li class="level2"><a href="#How-many-netCDF-data-models-are-there">How many netCDF data models are there? </a></li>
<li class="level2"><a href="#How-many-releases-of-the-C-based-netCDF-software-are-supported">How many releases of the C-based netCDF software are supported? </a></li>
<li class="level2"><a href="#Should-I-get-netCDF-3-or-netCDF-4">Should I get netCDF-3 or netCDF-4? </a></li>
<li class="level2"><a href="#whatisenhanceddatamodel">What is the &quot;enhanced data model&quot; of netCDF-4, and how does it differ from the netCDF-3 classic data model? </a></li>
<li class="level2"><a href="#Whydoesnt-the-new-netCDF-4-installation-I-built-seem-to-support-any-of-the-new-features">Why doesn&#39;t the new netCDF-4 installation I built seem to support any of the new features? </a></li>
<li class="level2"><a href="#Will-Unidata-continue-to-support-netCDF-3">Will Unidata continue to support netCDF-3? </a></li>
<li class="level2"><a href="#To-read-compressed-data-what-changes-do-I-need-to-make-to-my-netCDF-3-program">To read compressed data, what changes do I need to make to my netCDF-3 program? </a></li>
<li class="level2"><a href="#To-write-compressed-data-what-changes-do-I-need-to-make-to-my-netCDF-3-program">To write compressed data, what changes do I need to make to my netCDF-3 program? </a></li>
<li class="level2"><a href="#If-I-create-netCDF-4-classic-model-files-can-they-be-read-by-IDL-MATLAB-R-Python-and-ArcGIS">If I create netCDF-4 classic model files, can they be read by IDL, MATLAB, R, Python and ArcGIS? </a></li>
<li class="level2"><a href="#What-applications-are-able-to-deal-with-arbitrary-netCDF-4-files">What applications are able to deal with *arbitrary* netCDF-4 files? </a></li>
<li class="level2"><a href="#How-can-I-convert-netCDF-3-files-into-netCDF-4-files">How can I convert netCDF-3 files into netCDF-4 files? </a></li>
<li class="level2"><a href="#Why-might-someone-want-to-convert-netCDF-4-files-into-netCDF-3-files">Why might someone want to convert netCDF-4 files into netCDF-3 files? </a></li>
<li class="level2"><a href="#How-can-I-convert-netCDF-4-files-into-netCDF-3-files">How can I convert netCDF-4 files into netCDF-3 files? </a></li>
<li class="level2"><a href="#How-can-I-convert-HDF5-files-into-netCDF-4-files">How can I convert HDF5 files into netCDF-4 files? </a></li>
<li class="level2"><a href="#How-can-I-convert-netCDF-4-files-into-HDF5-files">How can I convert netCDF-4 files into HDF5 files? </a></li>
<li class="level2"><a href="#why-arent-different-extensions-used">Why aren&#39;t different extensions used for the different formats, for example &quot;.nc3&quot; and &quot;.nc4&quot;? </a></li>
<li class="level2"><a href="#Why-is-the-default-of-netCDF-4-to-continue-to-create-classic-files-rather-than-netCDF-4-files">Why is the default of netCDF-4 to continue to create classic files, rather than netCDF-4 files? </a></li>
<li class="level2"><a href="#Can-netCDF-4-read-arbitrary-HDF5-files">Can netCDF-4 read arbitrary HDF5 files? </a></li>
<li class="level2"><a href="#I-installed-netCDF-3-with---enable-shared-but-it-looks-like-the-libraries-it-installed-were-netCDF-4-with-names-like-libnetcdf4dylib-Whats-going-on">I installed netCDF-3 with --enable-shared, but it looks like the libraries it installed were netCDF-4, with names like libnetcdf.4.dylib. What&#39;s going on? </a></li>
<li class="level2"><a href="#NetCDF-363-permits-UTF-8-encoded-Unicode-names-Wont-this-break-backward-compatibility-with-previous-software-releases-that-didnt-allow-such-names">NetCDF-3.6.3 permits UTF-8 encoded Unicode names. Won&#39;t this break backward compatibility with previous software releases that didn&#39;t allow such names? </a></li>
<li class="level2"><a href="#How-difficult-is-it-to-convert-my-application-to-handle-arbitrary-netCDF-4-files">How difficult is it to convert my application to handle arbitrary netCDF-4 files? </a></li>
</ul>
</li>
<li class="level1"><a href="#Shared-Libraries">Shared Libraries </a><ul><li class="level2"><a href="#What-are-shared-libraries">What are shared libraries? </a></li>
<li class="level2"><a href="#Can-I-build-netCDF-with-shared-libraries">Can I build netCDF with shared libraries? </a></li>
<li class="level2"><a href="#How-do-I-use-netCDF-shared-libraries">How do I use netCDF shared libraries? </a></li>
</ul>
</li>
<li class="level1"><a href="#Large-File-Support">Large File Support </a><ul><li class="level2"><a href="#Was-it-possible-to-create-netCDF-files-larger-than-2-GiBytes-before-version-36">Was it possible to create netCDF files larger than 2 GiBytes before version 3.6? </a></li>
<li class="level2"><a href="#What-is-Large-File-Support">What is Large File Support? </a></li>
<li class="level2"><a href="#What-does-Large-File-Support-have-to-do-with-netCDF">What does Large File Support have to do with netCDF? </a></li>
<li class="level2"><a href="#Do-I-have-to-know-which-netCDF-file-format-variant-is-used-in-order-to-access-or-modify-a-netCDF-file">Do I have to know which netCDF file format variant is used in order to access or modify a netCDF file? </a></li>
<li class="level2"><a href="#Will-future-versions-of-the-netCDF-library-continue-to-support-accessing-files-in-the-classic-format">Will future versions of the netCDF library continue to support accessing files in the classic format? </a></li>
<li class="level2"><a href="#Should-I-start-using-the-new-64-bit-offset-format-for-all-my-netCDF-files">Should I start using the new 64-bit offset format for all my netCDF files? </a></li>
<li class="level2"><a href="#How-can-I-tell-if-a-netCDF-file-uses-the-classic-format-or-64-bit-offset-format">How can I tell if a netCDF file uses the classic format or 64-bit offset format? </a></li>
<li class="level2"><a href="#What-happens-if-I-create-a-64-bit-offset-format-netCDF-file-and-try-to-open-it-with-an-older-netCDF-application-that-hasnt-been-linked-with-netCDF-36">What happens if I create a 64-bit offset format netCDF file and try to open it with an older netCDF application that hasn&#39;t been linked with netCDF 3.6? </a></li>
<li class="level2"><a href="#Can-I-create-64-bit-offset-files-on-32-bit-platforms">Can I create 64-bit offset files on 32-bit platforms? </a></li>
<li class="level2"><a href="#How-do-I-create-a-64-bit-offset-netCDF-file-from-C-Fortran-77-Fortran-90-or-Cpp">How do I create a 64-bit offset netCDF file from C, Fortran-77, Fortran-90, or C++? </a></li>
<li class="level2"><a href="#How-do-I-create-a-64-bit-offset-netCDF-file-using-the-ncgen-utility">How do I create a 64-bit offset netCDF file using the ncgen utility? </a></li>
<li class="level2"><a href="#Have-all-netCDF-size-limits-been-eliminated">Have all netCDF size limits been eliminated? </a></li>
<li class="level2"><a href="#Why-are-variables-still-limited-in-size">Why are variables still limited in size? </a></li>
<li class="level2"><a href="#How-can-I-write-variables-larger-than-4-GiB">How can I write variables larger than 4 GiB? </a></li>
<li class="level2"><a href="#Why-do-I-get-an-error-message-when-I-try-to-create-a-file-larger-than-2-GiB-with-the-new-library">Why do I get an error message when I try to create a file larger than 2 GiB with the new library? </a></li>
<li class="level2"><a href="#Do-I-need-to-use-special-compiler-flags-to-compile-and-link-my-applications-that-use-netCDF-with-Large-File-Support">Do I need to use special compiler flags to compile and link my applications that use netCDF with Large File Support? </a></li>
<li class="level2"><a href="#isitpossibleclassic360">Is it possible to create a &quot;classic&quot; format netCDF file with netCDF version 3.6.0 that cannot be accessed by applications compiled and linked against earlier versions of the library? </a></li>
</ul>
</li>
<li class="level1"><a href="#NetCDF-and-Other-Software">NetCDF and Other Software </a><ul><li class="level2"><a href="#What-other-software-is-available-for-accessing-displaying-and-manipulating-netCDF-data">What other software is available for accessing, displaying, and manipulating netCDF data? </a></li>
<li class="level2"><a href="#What-other-data-access-interfaces-and-formats-are-available-for-scientific-data">What other data access interfaces and formats are available for scientific data? </a></li>
<li class="level2"><a href="#What-is-the-connection-between-netCDF-and-CDF">What is the connection between netCDF and CDF? </a></li>
<li class="level2"><a href="#What-is-the-connection-between-netCDF-and-HDF">What is the connection between netCDF and HDF? </a></li>
<li class="level2"><a href="#Has-anyone-implemented-client-server-access-for-netCDF-data">Has anyone implemented client-server access for netCDF data? </a></li>
<li class="level2"><a href="#How-do-I-convert-between-GRIB-and-netCDF">How do I convert between GRIB and netCDF? </a></li>
<li class="level2"><a href="#Can-I-recover-data-from-a-netCDF-file-that-was-not-closed-properly">Can I recover data from a netCDF file that was not closed properly? </a></li>
<li class="level2"><a href="#Is-there-a-list-of-reported-problems-and-workarounds">Is there a list of reported problems and workarounds? </a></li>
<li class="level2"><a href="#How-do-I-make-a-bug-report">How do I make a bug report? </a></li>
<li class="level2"><a href="#How-do-I-search-through-past-problem-reports">How do I search through past problem reports? </a></li>
</ul>
</li>
<li class="level1"><a href="#Programming-with-NetCDF">Programming with NetCDF </a><ul><li class="level2"><a href="#Which-programming-languages-have-netCDF-interfaces">Which programming languages have netCDF interfaces? </a></li>
<li class="level2"><a href="#Are-the-netCDF-libraries-thread-safe">Are the netCDF libraries thread-safe? </a></li>
<li class="level2"><a href="#How-does-the-Cpp-interface-differ-from-the-C-interface">How does the C++ interface differ from the C interface? </a></li>
<li class="level2"><a href="#How-does-the-Fortran-interface-differ-from-the-C-interface">How does the Fortran interface differ from the C interface? </a></li>
<li class="level2"><a href="#How-do-the-Java-Perl-Python-Ruby-interfaces-differ-from-the-C-interface">How do the Java, Perl, Python, Ruby, ... interfaces differ from the C interface? </a></li>
<li class="level2"><a href="#How-do-I-handle-errors-in-C">How do I handle errors in C? </a></li>
</ul>
</li>
<li class="level1"><a href="#cmake_faq">CMake </a><ul><li class="level2"><a href="#listoptions">How can I see the options available to CMake? </a></li>
<li class="level2"><a href="#sharedstatic">How do I specify how to build a shared or static library? </a></li>
<li class="level2"><a href="#sharedstaticboth">Can I build both shared and static libraries at the same time with cmake? </a></li>
<li class="level2"><a href="#partlib">How can I specify linking against a particular library? </a></li>
<li class="level2"><a href="#nonstdloc">What if I want to link against multiple libraries in a non-standard location </a></li>
<li class="level2"><a href="#parallelhdf">How can I specify a Parallel Build using HDF5 </a></li>
</ul>
</li>
<li class="level1"><a href="#Plans">Plans </a><ul><li class="level2"><a href="#What-other-future-work-on-netCDF-is-planned">What other future work on netCDF is planned? </a></li>
</ul>
</li>
</ul>
</div>
<div class="textblock"><h1><a class="anchor" id="ncFAQGeneral"></a>
General            </h1>
<h2><a class="anchor" id="What-Is-netCDF"></a>
What Is netCDF?  </h2>
<p>NetCDF (network Common Data Form) is a set of interfaces for array-oriented data access and a <a href="http://www.unidata.ucar.edu/software/netcdf/docs/COPYRIGHT">freely</a> distributed collection of data access libraries for C, Fortran, C++, Java, and other languages. The netCDF libraries support a machine-independent format for representing scientific data. Together, the interfaces, libraries, and format support the creation, access, and sharing of scientific data.</p>
<p>NetCDF data is:</p>
<ul>
<li><em>Self-Describing</em>. A netCDF file includes information about the data it contains.</li>
<li><em>Portable</em>. A netCDF file can be accessed by computers with different ways of storing integers, characters, and floating-point numbers.</li>
<li><em>Scalable</em>. A small subset of a large dataset may be accessed efficiently.</li>
<li><em>Appendable</em>. Data may be appended to a properly structured netCDF file without copying the dataset or redefining its structure.</li>
<li><em>Sharable</em>. One writer and multiple readers may simultaneously access the same netCDF file.</li>
<li><em>Archivable</em>. Access to all earlier forms of netCDF data will be supported by current and future versions of the software.</li>
</ul>
<p>The netCDF software was developed by Glenn Davis, Russ Rew, Ed Hartnett, John Caron, Dennis Heimbigner, Steve Emmerson, Harvey Davies, and Ward Fisher at the Unidata Program Center in Boulder, Colorado, with <a href="http://www.unidata.ucar.edu/software/netcdf/docs/credits.html">contributions</a> from many other netCDF users. </p><hr/>
<h2><a class="anchor" id="HowdoIgetthenetCDFsoftwarepackage"></a>
How do I get the netCDF software package? </h2>
<p>The latest source distribution, which includes the C libraries and utility programs, is available from <a href="/downloads/netcdf/index.jsp">the NetCDF Downloads page</a>. Separate source distributions for the Java library, Fortran libraries, and C++ libraries are also available there. Installation instructions are available with the distribution or <a href="http://www.unidata.ucar.edu/software/netcdf/docs/building.html">online</a>.</p>
<p>Binary distributions of netCDF are available for various platforms from package management systems such as dpkg, RPM, fink, MacPorts, Homebrew, OpenCSW, OpenPKG, and the FreeBSD Ports Collection. </p><hr/>
<h2><a class="anchor" id="How-do-I-convert-netCDF-data-to-ASCII-or-text"></a>
How do I convert netCDF data to ASCII or text? </h2>
<p>One way to convert netCDF data to text is to use the <b>ncdump</b> tool that is part of the netCDF software distribution. It is a command line tool that provides a text representation of a netCDF file's data, just its metadata, or just the data for specified variables, depending on what arguments you use. For more information, see the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/ncdump-man-1.html">ncdump documentation</a>.</p>
<p>Another good tool for conversion of netCDF data to text is the <a href="http://nco.sourceforge.net/nco.html#ncks-netCDF-Kitchen-Sink">"ncks" program</a> that's one of the utility programs in the <a href="software.html#NCO">NCO (NetCDF Operators)</a> package. Similar capabilities are available using programs from the <a href="software.html#CDO">CDO (Climate Data Operators)</a> software, commands from <a href="software.html#NCL">NCL (NCAR Command Language)</a>, or various other packages such as <a href="http://science.arm.gov/~cflynn/ARM_Tested_Tools/">ANAX</a>, cdf2asc, and NOESYS, all "third party" netCDF utilities developed and supported by other organizations. You can find more information about these third-party packages on the <a href="software.html">Software for Manipulating or Displaying NetCDF Data</a> page.</p>
<p>You can also get netCDF data in ASCII from an OPeNDAP server by using a ".ascii" extension with the URL that specifies the data. For details, see the OPeNDAP page on <a href="http://www.opendap.org/useExcel">Using a Spreadsheet Application with DODS</a>.</p>
<p>Another freely available tool, <a href="https://code.google.com/p/netcdf4excel/">netcdf4excel</a>, has been developed as a netCDF add-in for MS Excel that can facilitate the conversion of netCDF data to and from text form.</p>
<p>Note that <b>ncdump</b> and similar tools can print metadata and data values from netCDF files, but in general they don't understand coordinate systems specified in the metadata, only variable arrays and their indices. To interpret georeferencing metadata so you can print the data within a latitude/longitude bounding box, for example, you need a higher level tool that interprets conventions for specifying coordinates, such as the CF conventions. Or you can write a small program using one of the language APIs that provide netCDF support, for which <a href="http://www.unidata.ucar.edu/software/netcdf/examples/programs/">examples are available</a>. </p><hr/>
<h2><a class="anchor" id="How-do-I-convert-ASCII-or-text-data-to-netCDF"></a>
How do I convert ASCII or text data to netCDF? </h2>
<p>One way to convert data in text form to netCDF is to use the <b>ncgen</b> tool that is part of the netCDF software distribution. Using <b>ncgen</b> for this purpose is a two-step process:</p>
<ol type="1">
<li>Convert text data to a file in <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#CDL-Syntax">CDL form</a> using a text editor or text manipulation tools</li>
<li>Convert the CDL representation to netCDF using the <b>ncgen</b> tool with the "-o" or "-b" option</li>
</ol>
<p>For more information, see the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/ncgen-man-1.html">ncgen documentation</a>.</p>
<p>If you have installed the NCAR Command Language (<a href="http://www.ncl.ucar.edu/">NCL</a>) software, there are functions available and described <a href="http://www.ncl.ucar.edu/Applications/list_io.shtml">here</a> and <a href="http://www.ncl.ucar.edu/Applications/read_ascii.shtml">here</a> for reading ASCII and tables into NCL and writing the data out to netCDF files.</p>
<p>With access to <a href="http://www.mathworks.com/">MATLAB</a>, you can create a schema for the desired netCDF file using <a href="http://www.mathworks.com/help/techdoc/ref/ncwriteschema.html">ncwriteschema</a>, read the data using <a href="http://www.mathworks.com/help/techdoc/ref/textscan.html">textscan</a>, and write the data to a netCDF file using <a href="http://www.mathworks.com/help/techdoc/ref/ncwrite.html">ncwrite</a>.</p>
<p>What's new in the latest netCDF release?</p>
<p><a href="http://www.unidata.ucar.edu/software/netcdf/release-notes-latest.html">Release notes</a> for the latest netCDF release are available that describe new features and fixed bugs since the previous release. </p><hr/>
<h2><a class="anchor" id="What-is-the-best-way-to-represent-some-particular-data-using-netCDF"></a>
What is the best way to represent [some particular data] using netCDF? </h2>
<p>There are many ways to represent the same information in any general-purpose data model. Choices left up to the user in the case of netCDF include which information to represent as variables or as variable attributes; what names to choose for variables, dimensions, and attributes; what order to use for the dimensions of multidimensional variables; what variables to include in the same netCDF file; and how to use variable attributes to capture the structure and meaning of data. We provide some guidelines in the NetCDF User's Guide (e.g., the section on <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf/Differences-between-Attributes-and-Variables.html#Differences%20between%20Attributes%20and%20Variables">Differences between Attributes and Variables</a>) and in a new web document <a href="http://www.unidata.ucar.edu/software/netcdf/BestPractices.html">Writing NetCDF Files: BestPractices</a>, but we've found that a little experience helps. Occasionally we have decided it was useful to change the structure of netCDF files after experience with how the data is used. </p><hr/>
<h2><a class="anchor" id="What-convention-should-be-used-for-the-names-of-netCDF-files"></a>
What convention should be used for the names of netCDF files? </h2>
<p>NetCDF files should have the file name extension ".nc". The recommended extension for netCDF files was changed from ".cdf" to ".nc" in 1994 in order to avoid a clash with the NASA CDF file extension, and now it also avoids confusion with "Channel Definition Format" files.</p>
<hr/>
<h2><a class="anchor" id="Is-there-a-mailing-list-for-netCDF-discussions-and-questions"></a>
Is there a mailing list for netCDF discussions and questions? </h2>
<p>The <a href="#" onclick="location.href='mai'+'lto:'+'net'+'cd'+'fgr'+'ou'+'p@u'+'ni'+'dat'+'a.'+'uca'+'r.'+'edu'; return false;">netcd<span style="display: none;">.nosp@m.</span>fgro<span style="display: none;">.nosp@m.</span>up@un<span style="display: none;">.nosp@m.</span>idat<span style="display: none;">.nosp@m.</span>a.uca<span style="display: none;">.nosp@m.</span>r.ed<span style="display: none;">.nosp@m.</span>u</a> mailing-list is intended for discussions and announcements about netCDF interfaces, software, and use. The volume of this list varies widely, from one message per month to a dozen messages per day (especially after a new release). A message posted to this mailing-list will be seen by several hundred people, so it's usually not appropriate for asking simple questions about use. Such questions should instead be sent to <a href="#" onclick="location.href='mai'+'lto:'+'sup'+'po'+'rt-'+'ne'+'tcd'+'f@'+'uni'+'da'+'ta.'+'uc'+'ar.'+'ed'+'u'; return false;">suppo<span style="display: none;">.nosp@m.</span>rt-n<span style="display: none;">.nosp@m.</span>etcdf<span style="display: none;">.nosp@m.</span>@uni<span style="display: none;">.nosp@m.</span>data.<span style="display: none;">.nosp@m.</span>ucar<span style="display: none;">.nosp@m.</span>.edu</a>.</p>
<p>If you would prefer to get only a single daily digest of the postings to the netcdfgroup mailing-list, subscribe instead to the digest form of the mailing-list, containing the same messages but appearing at most once per day instead of whenever anyone sends a message to the group.</p>
<p>To subscribe or unsubscribe to either of these mailing lists, use one of these mailing list actions:</p>
<ul>
<li><a href="#" onclick="location.href='mai'+'lto:'+'net'+'cd'+'fgr'+'ou'+'p-j'+'oi'+'n@u'+'ni'+'dat'+'a.'+'uca'+'r.'+'edu'; return false;">subscribe: non-digest</a> ]</li>
<li><a href="#" onclick="location.href='mai'+'lto:'+'net'+'cd'+'fgr'+'ou'+'p-r'+'eq'+'ues'+'t@'+'uni'+'da'+'ta.'+'uc'+'ar.'+'ed'+'u?s'+'ub'+'jec'+'t='+'sub'+'sc'+'rib'+'e%'+'0A%'+'20'+'%20'+'%2'+'0%2'+'0%'+'20%'+'20'+'%20'+'%2'+'0%2'+'0%'+'20d'+'ig'+'est'; return false;">subscribe: digest</a> ]</li>
<li><a href="http://mailman.unidata.ucar.edu/mailman/options/netcdfgroup">change subscription options</a></li>
<li><a href="/mailing_lists/archives/netcdfgroup/">view posts</a></li>
<li><a href="/search.jsp">search archives</a>. <hr/>
</li>
</ul>
<h2><a class="anchor" id="Where-are-some-examples-of-netCDF-datasets"></a>
Where are some examples of netCDF datasets? </h2>
<p>Here are some <a href="http://www.unidata.ucar.edu/software/netcdf/examples/files.html">example netCDF files</a>. </p><hr/>
<h2><a class="anchor" id="What-is-the-best-way-to-handle-time-using-netCDF"></a>
What is the best way to handle time using netCDF? </h2>
<p>Discussions of conventions for representing time and handling time-dependent data have been a past topic of discussion on the netcdfgroup mailing list. When the subject comes up, interesting discussions often result, so we've archived past discussions on this subject at <a href="http://www.unidata.ucar.edu/software/netcdf/time/">http://www.unidata.ucar.edu/software/netcdf/time/</a>.</p>
<p>A summary of Unidata's recommendations is available from <a href="http://www.unidata.ucar.edu/software/netcdf/time/recs.html">http://www.unidata.ucar.edu/software/netcdf/time/recs.html</a>. Briefly, we recommend use of the units conventions supported by the <a href="/software/udunits/">udunits library</a> for time and other units attributes.</p>
<p>Other groups have established more specific conventions that include the representation of time in netCDF files. For more information on such conventions, see the NetCDF Conventions Page at <a href="http://www.unidata.ucar.edu/software/netcdf/conventions.html">http://www.unidata.ucar.edu/software/netcdf/conventions.html</a>. </p><hr/>
<h2><a class="anchor" id="Who-else-uses-netCDF"></a>
Who else uses netCDF? </h2>
<p>The netCDF mailing list has over 500 addresses (some of which are aliases to more addresses) in thirty countries. Several groups have <a href="http://www.unidata.ucar.edu/software/netcdf/docs/standards.html">adopted netCDF as a standard</a> for representing some forms of scientific data.</p>
<p>A somewhat dated description of some of the projects and groups that have used netCDF is available from <a href="http://www.unidata.ucar.edu/software/netcdf/usage.html">http://www.unidata.ucar.edu/software/netcdf/usage.html</a>. </p><hr/>
<h2><a class="anchor" id="What-are-some-references-to-netCDF"></a>
What are some references to netCDF? </h2>
<p>A primary reference is the User's Guide:</p>
<p>Rew, R. K., G. P. Davis, S. Emmerson, and H. Davies, <b>NetCDF User's Guide for C, An Interface for Data Access, Version 3</b>, April 1997.</p>
<p>Current online and downloadable documentation is available from the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/">documentation directory</a>.</p>
<p>Other references include:</p>
<p>Brown, S. A, M. Folk, G. Goucher, and R. Rew, "Software for Portable
Scientific Data Management," Computers in Physics, American Institute of Physics, Vol. 7, No. 3, May/June 1993, pp. 304-308.</p>
<p>Fulker, D. W., "Unidata Strawman for Storing Earth-Referencing Data," Seventh International Conference on Interactive Information and Processing Systems for Meteorology, Oceanography, and Hydrology, New Orleans, La., American Meteorology Society, January 1991.</p>
<p>Jenter, H. L. and R. P. Signell, 1992. "[NetCDF: A Freely-Available Software-Solution to Data-Access Problems for Numerical Modelers](http://www.unidata.ucar.edu/software/netcdf/papers/jenter_signell_92.pdf)". Proceedings of the American Society of Civil Engineers Conference on Estuarine and Coastal Modeling. Tampa, Florida.</p>
<p>Kuehn, J.A., "Faster Libraries for Creating Network-Portable
Self-Describing Datasets", Proceedings of the 37th Cray User Group Meeting, (Barcelona, Spain, March 1996), Cray User Group, Inc.</p>
<p>Rew, R. K. and G. P. Davis, "NetCDF: An Interface for Scientific Data
Access," IEEE Computer Graphics and Applications, Vol. 10, No. 4, pp. 76-82, July 1990.</p>
<p>Rew, R. K. and G. P. Davis, "The Unidata netCDF: Software for Scientific
Data Access," Sixth International Conference on Interactive Information and Processing Systems for Meteorology, Oceanography, and Hydrology, Anaheim, California, American Meteorology Society, pp. 33-40, February 1990.</p>
<p>Rew, R. K. and G. P. Davis, " [Unidata's netCDF Interface for Data Access: Status and Plans](/netcdf/ams97.html)," Thirteenth International Conference on Interactive Information and Processing Systems for Meteorology, Oceanography, and Hydrology, Anaheim, California, American Meteorology Society, February 1997. </p><hr/>
<h2><a class="anchor" id="How-should-I-cite-use-of-netCDF-software"></a>
I'm submitting a paper for publication and want to include a citation for use of netCDF software. What reference should I use? </h2>
<p>The registered Digital Object Identifier for all versions of netCDF software is <code><a href="http://doi.org/10.5065/D6H70CW6">http://doi.org/10.5065/D6H70CW6</a></code>.</p>
<p>The following can be used as a citation:</p>
<p>Unidata, (<em>year</em>): Network Common Data Form (netCDF) version <em>nc_version</em> [software]. Boulder, CO: UCAR/Unidata. (<a href="http://doi.org/10.5065/D6H70CW6">http://doi.org/10.5065/D6H70CW6</a>)</p>
<p>where <em>year</em> is the year in which the work being described was done and <em>nc_version</em> is the version of netCDF used. For example:</p>
<p>Unidata, (2015): Network Common Data Form (netCDF) version 4.3.3.1 [software]. Boulder, CO: UCAR/Unidata. (<a href="http://doi.org/10.5065/D6H70CW6">http://doi.org/10.5065/D6H70CW6</a>) </p><hr/>
<h2><a class="anchor" id="Is-there-a-document-describing-the-actual-physical-format-for-a-Unidata-netCDF-file"></a>
Is there a document describing the actual physical format for a Unidata netCDF file? </h2>
<p>A short document that specifies the <a href="http://earthdata.nasa.gov/sites/default/files/esdswg/spg/rfc/esds-rfc-011/ESDS-RFC-011v2.00.pdf">format of netCDF classic and 64-bit offset files</a> has been approved as a standard by the NASA ESDS Software Process Group.</p>
<p>In addition, the NetCDF User's Guide contains an <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#File-Format">appendix</a> with the same format specification.</p>
<p>The <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#Structure">"NetCDF File Structure and Performance"</a> chapter provides a less formal explanation of the format of netCDF data to help clarify the performance implications of different data organizations.</p>
<p>If users only access netCDF data through the documented interfaces, future changes to the format will be transparent. </p><hr/>
<h1><a class="anchor" id="Installation-and-Porting"></a>
Installation and Porting                      </h1>
<h2><a class="anchor" id="What-does-netCDF-run-on"></a>
What does netCDF run on? </h2>
<p>We test releases on the following operating systems with various compilers:</p>
<ul>
<li>AIX</li>
<li>HPUX</li>
<li>IRIX, IRIX64</li>
<li>Linux</li>
<li>MacOS X</li>
<li>Solaris</li>
<li>Windows (some versions, see below)</li>
</ul>
<p>The <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-install/index.html">NetCDF Installation and Porting Guide</a> explains how to build netCDF from source on various platforms. Often, it's as easy as running</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;./configure</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;make check install</div></div><!-- fragment --> <hr/>
<h2><a class="anchor" id="HowcanIusecu"></a>
How can I use current versions of netCDF-4 with Windows? </h2>
<p>See <a href="http://www.unidata.ucar.edu/software/netcdf/win_netcdf">http://www.unidata.ucar.edu/software/netcdf/docs/winbin.html</a>.</p>
<h2><a class="anchor" id="HowcanIusenetCDF41withWindows"></a>
How can I use netCDF-4.1 with Windows? </h2>
<p>We recently (Summer of 2010) refactored the core building of the netCDF library. Unfortunately this hopelessly broke the existing port to Microsoft Visual Studio. Resources permitting, the development of a new Visual Studio port will be undertaken in the second half of 2010 at Unidata. Until then, no Visual Studio port of the latest version of the library is available.</p>
<p>Users are advised that the netCDF build is known to work with Cygwin, the free POSIX layer for Windows. Building netCDF with Cygwin, and including the netCDF, HDF5, zlib, and Cygwin DLLs, will allow you to access the netCDF C library on Windows, even from Visual Studio builds.</p>
<p>We understand that Windows users are most comfortable with a Visual Studio build, and we intend to provide one.</p>
<p>The Visual Studio port is complicated by the following factors:</p>
<ul>
<li>No configure script support on windows - the Unix build system uses a configure script to determine details of the build platform and allow the user to specify settings. Windows has no mechanism for this other than statically set properties. A Windows-only config.h file needs to be created for windows using Cygwin, then included with the distribution. Since this contains the version string, it must be updated "by hand" before each release.</li>
<li>No m4 on windows - the Unix build uses the macro language m4 to generate some of the C code in the netCDF library (for example, libsrc/putget.c). M4 must be run under Cygwin to generate these files, and then they must be statically added to the windows distribution. Each new version of netCDF these files should be checked for changes. We are restricting new use of m4 for netCDF compiles, but that doesn't help with the existing files.</li>
<li>No user options on Windows - since Windows does not support a configure step, all user options must be pre-set in the Visual Studio property lists. As a simplification, many options available to Unix users will be unavailable to builders on Windows, such as &ndash;disable-dap, &ndash;disable-netcdf-4, and &ndash;disable-shared.</li>
<li>Large files (&gt; 2 GB) have proved to be a problem area in past Windows builds.</li>
<li>Previous Windows ports have not had to deal with the new OPeNDAP client.</li>
</ul>
<p>Unidata is a community supported organization, and we welcome collaboration with users who would like to assist with the windows port. Users should be sure to start with the netCDF daily snapshot, not a previous release of netCDF.</p>
<p>NOTE: <a href="http://www.paratools.com/">Paratools</a> has contributed <a href="http://www.paratools.com/Azure/NetCDF">instructions for how to build netCDF-4.1.3</a> as a Windows DLL using the MinGW cross compiler.</p>
<p>Nikolay Khabarov has contributed <a href="http://user.iiasa.ac.at/~khabarov/netcdf-win64-and-win32-mingw/">documentation describing a netCDF-4.1.3 port</a> using MinGW to build native Windows 64-bit and 32-bit DLLs. Current limitations include leaving out support for Fortran and C++ interfaces, NetCDF-4, HDF5, the old version 2 API, and DAP access. The netCDF classic format and 64-bit offset format are fully supported. Links are provided to compiled 32-bit and 64-bit DLLs and static libraries.</p>
<p>A developer on the GMT Wiki has posted <a href="http://gmtrac.soest.hawaii.edu/projects/gmt/wiki/BuildingNetCDF">detailed instructions for using CMake</a> and MS Visual C++ on Windows to build netCDF-4.1.3, including OPeNDAP support.</p>
<p>Another developer has contributed an unsupported native Windows build of netCDF-4.1.3 with 32- and 64-bit versions, Fortran bindings, and OPeNDAP support. The announcement of the availability of that port is <a href="http://www.unidata.ucar.edu/mailing_lists/archives/netcdfgroup/2011/msg00363.html">here</a>.</p>
<p>User Veit Eitner has contributed a port of 4.1.1 to Visual Studio, including an F90 port to Intel Fortran. Download <a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/netcdf-4.1.1-win32-src.zip">source (ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/netcdf-4.1.1-win32-src.zip)</a> or <a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/netcdf-4.1.1-win32-bin.zip">binary</a> versions. This port was done before the code was refactored in 4.1.2.</p>
<h2><a class="anchor" id="How-can-I-use-netCDF-4-with-Windows"></a>
How can I use netCDF-4 with Windows? </h2>
<p>Note that we have not ported the F90 or C++ APIs to the Windows platform, only the C and F77 APIs. User contributions of ports to F90 windows compilers are very welcome (send them to <a href="#" onclick="location.href='mai'+'lto:'+'sup'+'po'+'rt-'+'ne'+'tcd'+'f@'+'uni'+'da'+'ta.'+'uc'+'ar.'+'ed'+'u'; return false;">suppo<span style="display: none;">.nosp@m.</span>rt-n<span style="display: none;">.nosp@m.</span>etcdf<span style="display: none;">.nosp@m.</span>@uni<span style="display: none;">.nosp@m.</span>data.<span style="display: none;">.nosp@m.</span>ucar<span style="display: none;">.nosp@m.</span>.edu</a>).</p>
<p>On windows, NetCDF consists of a DLL and the ncgen/ncdump executables. The easiest course is to download one of the pre-built DLLs and utilities and just install them on your system.</p>
<p>Unlike Unix builds, the Visual Studio build <b>always</b> requires HDF5, zlib, and szlib in all cases. All Windows DLL users must also have the HDF5, zlib, and szlib DLLs. These are now available from the Unidata FTP site:</p>
<ul>
<li><a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/zlib123-vs2005.zip">zlib DLLs for 32-bit Windows</a></li>
<li><a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/szip21-vs6-enc.zip">szlib DLLs for 32-bit Windows</a></li>
<li><a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/5-181-win-vs2005.zip">HDF5 DLLs for 32-bit Windows</a></li>
</ul>
<p>Two versions of the netCDF DLLs are available, for different Fortran compilers:</p>
<ul>
<li><a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/win32_vs_PGI_dll_4.0.1.zip">NetCDF for Intel and Portland Group Fortran compilers.</a></li>
<li><a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/win32_vs_f2c_dll_4.0.1.zip">NetCDF for other Fortran compilers.</a></li>
</ul>
<p>To use netCDF, install the DLLs in /system/win32 and the .h files in a directory known to your compiler, and define the DLL_NETCDF preprocessor macro before including <a class="el" href="netcdf_8h.html" title="Main header file for the C API. ">netcdf.h</a>.</p>
<p>The netCDF-4 library can also be built using Visual Studio 2008. Open the solution file win32/NET/netcdf.sln.</p>
<p>If you install the header files in \include directory, the netCDF solution file will work without modifications. Otherwise the properties of the netcdf project must be changed to include the proper header directory.</p>
<p>Both the debug and release builds work. The release build links to different system libraries on Windows, and will not allow debuggers to step into netCDF library code. This is the build most users will be interested in. The debug build is probably of interest only to netCDF library developers.</p>
<p>As of version 4.0.1 (March 2009), the DLL build does not yet include any testing of the extended netCDF-4 data model. The netCDF4/HDF5 format is extensively tested in the classic model, but tests for groups, user-defined types, and other features of the expanded netCDF-4 data model have not yet been ported to Windows.</p>
<p>The <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-install/index.html">NetCDF Installation and Porting Guide</a> documents how to use netCDF with Windows.</p>
<p>Some users have built and released netCDF with Intel Fortran on Windows. See the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/other-builds.html#ifort-361-windows">ifort entry in other builds document</a>.</p>
<p>Windows is a complicated platform to build on. Some useful explanations of the oddities of Windows can be found here:</p>
<ul>
<li>Cygwin documentation for <a href="http://cygwin.com/cygwin-ug-net/dll.html">Building and Using DLLs</a></li>
<li><a href="http://www.openldap.org/faq/data/cache/301.html">OpenLDAP FAQ answer: MinGW Support in Cygwin</a>, by Jon Leichter.</li>
<li><a href="http://cygwin.com/ml/cygwin/2000-06/msg00688.html">cygwin mailing list explanation of Windows DL requirements.</a></li>
<li><a href="http://www.delorie.com/howto/cygwin/mno-cygwin-howto.html">-mno-cygwin - Building Mingw executables using Cygwin</a></li>
</ul>
<p>Once you have the netCDF DLL, you may wish to call it from Visual Basic. The <a href="ftp://ftp.unidata.ucar.edu/pub/netcdf/contrib/win32/netcdf_vb_net_wrapper.zip">netCDF VB wrapper</a> will help you do this.</p>
<p>The SDS (<a href="http://research.microsoft.com/en-us/projects/sds/">Scientific DataSet</a>) library and tools provide .Net developers a way to read, write and share scalars, vectors, and multidimensional grids using CSV, netCDF, and other file formats. It currently uses netCDF version 4.0.1. In addition to .Net libraries, SDS provides a set of utilities and packages: an sds command line utility, a DataSet Viewer application and an add-in for Microsoft Excel 2007 (and later versions). </p><hr/>
<h2><a class="anchor" id="How-do-I-build-and-install-netCDF-for-a-specific-development-environment"></a>
How do I build and install netCDF for a specific development environment? </h2>
<p>You have to build and install the netCDF C library first, before you build and install other language libraries that depend on it, such as Fortran, C++, or Python netCDF libraries. The netCDF Java library is mostly independent of the netCDF C library, unless you need to write netCDF-4 files from Java, in which case you will also need an installed netCDF C library.</p>
<p>For more details, see <a href="http://www.unidata.ucar.edu/software/netcdf/docs/getting_and_building_netcdf.html">Getting and Building netCDF</a>.</p>
<hr/>
<h2><a class="anchor" id="How-can-I-tell-if-I-successfully-built-and-installed-netCDF"></a>
How can I tell if I successfully built and installed netCDF? </h2>
<p>We make build output from various platforms <a href="../builds">available</a> for comparison with your output. In general, you can ignore compiler warnings if the "make test" step is successful. Lines that begin with "\*\*\*" in the "make test" output indicate results from tests. The C and Fortran-77 interfaces are tested extensively, but only rudimentary tests are currently used for the C++ and Fortran-90 interfaces.</p>
<h2><a class="anchor" id="How-can-I-tell-what-version-Im-using"></a>
How can I tell what version I'm using? </h2>
<p>If you invoke</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncdump --version</div></div><!-- fragment --><p>the last line of the resulting output will identify the version associated with the <b>ncdump</b> utility. You can also call one of the functions <code>nc_inq_libvers()</code>, <code>nf_inq_libvers()</code>, or <code>nf90_inq_libvers()</code> from C, Fortran-77, or Fortran-90 programs to get a version string. </p><hr/>
<h2><a class="anchor" id="Where-does-netCDF-get-installed"></a>
Where does netCDF get installed? </h2>
<p>The netCDF installation directory can be set at the time configure is run using the &ndash;prefix argument. If it is not specified, /usr/local is used as the default prefix.</p>
<p>For more information see the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-install">NetCDF Installation and Porting Guide</a>.</p>
<h1><a class="anchor" id="formatsdatamodelssoftwarereleases"></a>
Formats, Data Models, and Software Releases </h1>
<p>In different contexts, "netCDF" may refer to a data model, a software implementation with associated application program interfaces (APIs), or a data format. Confusion may arise in discussions of different versions of the data models, software, and formats. For example, compatibility commitments require that new versions of the software support all previous versions of the format and data model. This section of FAQs is intended to clarify netCDF versions and help users determine what version to build and install.</p>
<h2><a class="anchor" id="How-many-netCDF-formats-are-there-and-what-are-the-differences-among-them"></a>
How many netCDF formats are there, and what are the differences among them? </h2>
<p>There are four netCDF format variants:</p>
<ul>
<li>the classic format</li>
<li>the 64-bit offset format</li>
<li>the netCDF-4 format</li>
<li>the netCDF-4 classic model format</li>
</ul>
<p>(In addition, there are two textual representations for netCDF data, though these are not usually thought of as formats: CDL and NcML.)</p>
<p>The <b>classic format</b> was the only format for netCDF data created between 1989 and 2004 by the reference software from Unidata. It is still the default format for new netCDF data files, and the form in which most netCDF data is stored.</p>
<p>In 2004, the <b>64-bit offset format</b> variant was added. Nearly identical to netCDF classic format, it allows users to create and access far larger datasets than were possible with the original format. (A 64-bit platform is not required to write or read 64-bit offset netCDF files.)</p>
<p>In 2008, the <b>netCDF-4 format</b> was added to support per-variable compression, multiple unlimited dimensions, more complex data types, and better performance, by layering an enhanced netCDF access interface on top of the HDF5 format.</p>
<p>At the same time, a fourth format variant, <b>netCDF-4 classic model format</b>, was added for users who needed the performance benefits of the new format (such as compression) without the complexity of a new programming interface or enhanced data model.</p>
<p>With each additional format variant, the C-based reference software from Unidata has continued to support access to data stored in previous formats transparently, and to also support programs written using previous programming interfaces.</p>
<p>Although strictly speaking, there is no single "netCDF-3 format", that phrase is sometimes used instead of the more cumbersome but correct "netCDF classic or 64-bit offset format" to describe files created by the netCDF-3 (or netCDF-1 or netCDF-2) libraries. Similarly "netCDF-4
format" is sometimes used informally to mean "either the general
netCDF-4 format or the restricted netCDF-4 classic model format". We will use these shorter phrases in FAQs below when no confusion is likely.</p>
<p>A more extensive description of the netCDF formats and a formal specification of the classic and 64-bit formats is available as a <a href="https://earthdata.nasa.gov/sites/default/files/esdswg/spg/rfc/esds-rfc-011/ESDS-RFC-011v2.00.pdf">NASA ESDS community standard</a>.</p>
<h2><a class="anchor" id="How-can-I-tell-which-format-a-netCDF-file-uses"></a>
How can I tell which format a netCDF file uses? </h2>
<p>The short answer is that under most circumstances, you should not care, if you use version 4.0 or later of the netCDF library to access data in the file. But the difference is indicated in the first four bytes of the file, which are 'C', 'D', 'F', '\001' for the classic netCDF format; 'C', 'D', 'F', '\002' for the 64-bit offset format; or '\211', 'H', 'D', 'F' for an HDF5 file, which could be either a netCDF-4 file or a netCDF-4 classic model file. (HDF5 files may also begin with a user-block of 512, 1024, 2048, ... bytes before what is actually an 8-byte signature beginning with the 4 bytes above.)</p>
<p>With netCDF version 4.0 or later, there is an easy way that will distinguish between netCDF-4 and netCDF-4 classic model files, using the "-k" option to <b>ncdump</b> to determine the kind of file, for example:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncdump -k foo.nc</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;classic</div></div><!-- fragment --><p>In a program, you can call the function <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-c.html#nc_005finq-Family">nc_inq_format</a>(or <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-f90.html#Compiling-and-Linking-with-the-NetCDF-Library">nf90_inq_format</a> for the Fortran-90 interface) to determine the format variant of an open netCDF file.</p>
<p>Finally, on a Unix system, one way to display the first four bytes of a file, say foo.nc, is to run the following command:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;od -An -c -N4 foo.nc</div></div><!-- fragment --><p>which will output</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;C   D   F 001</div></div><!-- fragment --><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;C   D   F 002</div></div><!-- fragment --><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;211   H   D   F</div></div><!-- fragment --><p>depending on whether foo.nc is a classic, 64-bit offset, or netCDF-4 file, respectively. This method cannot be used to distinguish between netCDF-4 and netCDF-4 classic model variants, or between a netCDF-4 file and a different kind of HDF5 file. </p><hr/>
<h2><a class="anchor" id="How-many-netCDF-data-models-are-there"></a>
How many netCDF data models are there? </h2>
<p>There are only two netCDF data models, the <a href="/netcdf/workshops/2008/datamodel/NcClassicModel.html">classic model</a> and the <a href="/netcdf/workshops/2008/netcdf4/Nc4DataModel.html">enhanced model</a> (also called the netCDF-4 data model). The classic model is the simpler of the two, and is used for all data stored in classic format, 64-bit offset format, or netCDF-4 classic model format. The enhanced model (sometimes also referred to as the netCDF-4 data model) is an extension of the classic model that adds more powerful forms of data representation and data types at the expense of some additional complexity. Although data represented with the classic model can also be represented using the enhanced model, datasets that use enhanced model features, such as user-defined data types, cannot be represented with the classic model. Use of the enhanced model requires storage in the netCDF-4 format.</p>
<h2><a class="anchor" id="How-many-releases-of-the-C-based-netCDF-software-are-supported"></a>
How many releases of the C-based netCDF software are supported? </h2>
<p>When netCDF version 4.0 was released in June 2008, version 3.6.3 was released simultaneously, and both releases were supported by Unidata. Version 3.6.3 supported only the classic and 64-bit offset formats. Version 4.0 supported both of those format variants by default, and also the netCDF-4 and netCDF-4 classic model formats, if built using a previously installed HDF5 library and using the "--enable-netcdf-4" configure option. Software built from the netCDF-4.0 release without specifying "--enable-netcdf-4" (the default) was identical to software built with netCDF-3.6.3.</p>
<p>Both netCDF-3 and netCDF-4 C libraries are part of a single software release. The netCDF software may be built to support just the classic and 64-bit offset formats (the default) or to also support the netCDF-4 and netCDF-4 classic model formats, if the HDF5-1.8.x library is installed. Unidata no longer supports a separate netCDF-3-only version of the software, but instead supports both the classic and enhanced data models and all four format variants in a single source distribution.</p>
<p>This does not indicate any plan to drop support for netCDF-3 or the formats associated with netCDF-3. Support for earlier formats and APIs will continue with all future versions of netCDF software from Unidata.</p>
<h2><a class="anchor" id="Should-I-get-netCDF-3-or-netCDF-4"></a>
Should I get netCDF-3 or netCDF-4? </h2>
<p>By downloading a current version of netCDF-4, you have the choice to build either</p>
<ul>
<li>the default netCDF-3 libraries, which support classic and 64-bit offset formats, and the classic data model; or</li>
<li>the netCDF-4 libraries, which support netCDF-4 and netCDF-4 classic model formats, as well as classic and 64-bit offset formats, and the enhanced data model.</li>
</ul>
<p>Which version to build depends on how you will use the software.</p>
<p>Installing the simpler netCDF-3 version of the software is recommended if the following situations apply:</p>
<ul>
<li>all the data you need to access is available in netCDF classic or 64-bit offset formats</li>
<li>you are installing netCDF in order to support another software package that uses only netCDF-3 features</li>
<li>you plan to only write data in a form that netCDF-3 software and applications can access</li>
<li>you want to delay upgrading to support netCDF-4 until netCDF-4 formats are more widely used</li>
<li>you cannot install the prerequisite HDF5 1.8 software required to build and install netCDF-4</li>
</ul>
<p>Installing the netCDF-4 version of the software is required for any of the following situations:</p>
<ul>
<li>you need to access netCDF data that makes use of netCDF-4 compression or chunking</li>
<li>you need to access data in all netCDF formats including netCDF-4 or netCDF-4 classic model formats</li>
<li>you need to write non-record variables larger than 4GiB or record variables with more than 4GiB per record (see <a href="http://www.unidata.ucar.edu/software/netcdf/docs/faq.html#Large%20File%20Support10">"Have all netCDF size limits been eliminated?"</a>)</li>
<li>you are installing netCDF to support other software packages that require netCDF-4 features</li>
<li>you want to write data that takes advantage of compression, chunking, or other netCDF-4 features</li>
<li>you want to be able to read netCDF-4 classic model data with no changes to your current software except relinking with the new library</li>
<li>you want to benchmark your current applications with the new libraries to determine whether the benefits are significant enough to justify the upgrade</li>
<li>you need to use parallel I/O with netCDF-4 or netCDF-4 classic files</li>
</ul>
<h2><a class="anchor" id="whatisenhanceddatamodel"></a>
What is the "enhanced data model" of netCDF-4, and how does it differ from the netCDF-3 classic data model? </h2>
<p>The enhanced model (sometimes referred to as the netCDF-4 data model) is an extension to the <a href="/netcdf/workshops/2008/datamodel/NcClassicModel.html">classic model</a> that adds more powerful forms of data representation and data types at the expense of some additional complexity. Specifically, it adds six new primitive data types, four kinds of user-defined data types, multiple unlimited dimensions, and groups to organize data hierarchically and provide scopes for names. A <a href="/netcdf/workshops/2008/netcdf4/Nc4DataModel.html">picture</a> of the enhanced data model, with the extensions to the classic model highlighted in red, is available from the online netCDF workshop.</p>
<p>Although data represented with the classic model can also be represented using the enhanced model, datasets that use features of the enhanced model, such as user-defined data types, cannot be represented with the classic model. Use of added features of the enhanced model requires that data be stored in the netCDF-4 format.</p>
<h2><a class="anchor" id="Whydoesnt-the-new-netCDF-4-installation-I-built-seem-to-support-any-of-the-new-features"></a>
Why doesn't the new netCDF-4 installation I built seem to support any of the new features? </h2>
<p>If you built the software from source without access to an HDF5 library, then only the netCDF-3 library was built and installed. The current release will build full netCDF-4 support if the HDF5 1.8.x library is already installed where it can be found by the configure script or cmake.</p>
<h2><a class="anchor" id="Will-Unidata-continue-to-support-netCDF-3"></a>
Will Unidata continue to support netCDF-3? </h2>
<p>Yes, Unidata has a commitment to preserving backward compatibility.</p>
<p>Because preserving access to archived data for future generations is very important:</p>
<ul>
<li>New netCDF software will provide read and write access to <em>all</em> earlier forms of netCDF data.</li>
<li>C and Fortran programs using documented netCDF APIs from previous releases will be supported by new netCDF software (after recompiling and relinking, if needed).</li>
<li>Future releases of netCDF software will continue to support data access and API compatibility.</li>
</ul>
<h2><a class="anchor" id="To-read-compressed-data-what-changes-do-I-need-to-make-to-my-netCDF-3-program"></a>
To read compressed data, what changes do I need to make to my netCDF-3 program? </h2>
<p>None. No changes to the program source are needed, because the library handles decompressing data as it is accessed. All you need to do is relink your netCDF-3 program to the netCDF-4 library to recognize and handle compressed data.</p>
<h2><a class="anchor" id="To-write-compressed-data-what-changes-do-I-need-to-make-to-my-netCDF-3-program"></a>
To write compressed data, what changes do I need to make to my netCDF-3 program? </h2>
<p>The <b>nccopy</b> utility in versions 4.1.2 and later supports a "-d *level*" deflate option that copies a netCDF file, compressing all variables using the specified level of deflation and default chunking parameters, or you can specify chunking with the "-c" option.</p>
<p>To do this within a program, or if you want different variables to have different levels of deflation, define compression properties when each variable is defined. The function to call is <a href="/netcdf-c.html#nc_005fdef_005fvar_005fdeflate">nc_def_var_deflate</a> for C programs, <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-f90.html#NF90_005fDEF_005fVAR_005fDEFLATE">nf90_def_var_deflate</a> for Fortran 90 programs, <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-f77.html#NF_005fDEF_005fVAR_005fDEFLATE">NF_DEF_VAR_DEFLATE</a> for Fortran 77. For C++ programs, the experimental cxx4 API may be used, assuming you have configured with &ndash;enable-cxx-4.</p>
<p>Although default variable chunking parameters may be adequate, compression can sometimes be improved by choosing good chunking parameters when a variable is first defined. For example, if a 3D field tends to vary a lot with vertical level, but not so much within a horizontal slice corresponding to a single level, then defining chunks to be all or part of a horizontal slice would typically produce better compression than chunks that included multiple horizontal slices. There are other factors in choosing chunk sizes, especially matching how the data will be accessed most frequently. Chunking properties may only be specified when a variable is first defined. The function to call is <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-c.html#nc_005fdef_005fvar_005f">nc_def_var_chunking</a> for C programs, <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-f90.html#NF90_005fDEF_005fVAR_005fCHUNKING">nf90_def_var_chunking</a> for Fortran 90 programs, and <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-f77.html#NF_005fDEF_005fVAR_005fCHUNKING">NF_DEF_VAR_CHUNKING</a> for Fortran 77 programs. For C++ programs, the experimental cxx4 API may be used, assuming you have configured with &ndash;enable-cxx-4.</p>
<h2><a class="anchor" id="If-I-create-netCDF-4-classic-model-files-can-they-be-read-by-IDL-MATLAB-R-Python-and-ArcGIS"></a>
If I create netCDF-4 classic model files, can they be read by IDL, MATLAB, R, Python and ArcGIS? </h2>
<p>IDL 8.0 ships with support for netCDF-4, including support for OPeNDAP remote access.</p>
<p>MATLAB 2012a includes netCDF 4 support with OPeNDAP support turned on, enabling remote access to many kinds of data, as well as use of groups, compression, and chunking. An example is available demonstrating some of the new functions. <a href="http://nctoolbox.github.io/nctoolbox/">NCTOOLBOX</a>, uses netCDF-Java to provide read access to datasets in netCDF-4, GRIB, GRIB2 and other formats through Unidata's Common Data Model.</p>
<p>R has the <a href="http://cirrus.ucsd.edu/~pierce/ncdf/">ncdf4 package</a>.</p>
<p>Python has the <a href="http://code.google.com/p/netcdf4-python/">netcdf4-python package</a>.</p>
<p>ArcGIS 10.0 can read netcdf4 using the Multidimensional Tools in ArcToolbox, and in ArcGIS 10.1, the <a href="http://esriurl.com/MultidimensionSupplementalTools">Multidimensional Supplemental toolbox</a> uses NetCDF4-Python to read OPeNDAP and netCDF4 files, taking advantage of CF conventions if they exist.</p>
<h2><a class="anchor" id="What-applications-are-able-to-deal-with-arbitrary-netCDF-4-files"></a>
What applications are able to deal with *arbitrary* netCDF-4 files? </h2>
<p>The netCDF utilities <b>ncdump</b>, <b>ncgen</b>, and <b>nccopy</b>, available in the Unidata C-based netCDF-4 distribution, are able to deal with arbitrary netCDF-4 files (as well as all other kinds of netCDF files).</p>
<h2><a class="anchor" id="How-can-I-convert-netCDF-3-files-into-netCDF-4-files"></a>
How can I convert netCDF-3 files into netCDF-4 files? </h2>
<p>Every netCDF-3 file can be read or written by a netCDF version 4 library, so in that respect netCDF-3 files are already netCDF-4 files and need no conversion. But if you want to convert a classic or 64-bit offset format file into a netCDF-4 format or netCDF-4 classic model format file, the easiest way is to use the <b>nccopy</b> utility. For example to convert a classic format file foo3.nc to a netCDF-4 format file foo4.nc, use:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;nccopy -k netCDF-4 foo3.nc foo4.nc</div></div><!-- fragment --><p>To convert a classic format file foo3.nc to a netCDF-4 classic model format file foo4c.nc, you could use:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;nccopy -k netCDF-4-classic foo3.nc foo4c.nc</div></div><!-- fragment --><p>If you have installed <a href="http://www.unidata.ucar.edu/software/netcdf/docs/software.html#NCO">NCO</a>, the NCO utility "ncks" can be used to accomplish the same task, as follows:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncks -7 foo3.nc foo4c.nc</div></div><!-- fragment --><p>Another method is available for relatively small files, using the <b>ncdump</b> and <b>ncgen</b> utilities (built with a netCDF-4 library). Assuming "small3.nc" is a small classic format or 64-bit offset format netCDF file, you can create an equivalent netCDF-4 file named "small4.nc" as follows:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncdump small3.nc &gt; small.cdl</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;ncgen -o small4.nc -k netCDF-4-classic small.cdl</div></div><!-- fragment --><h2><a class="anchor" id="Why-might-someone-want-to-convert-netCDF-4-files-into-netCDF-3-files"></a>
Why might someone want to convert netCDF-4 files into netCDF-3 files? </h2>
<p>NetCDF-4 classic model files that use compression can be smaller than the equivalent netCDF-3 files, so downloads are quicker. If they are then unpacked and converted to the equivalent netCDF-3 files, they can be accessed by applications that haven't yet upgraded to netCDF-4.</p>
<h2><a class="anchor" id="How-can-I-convert-netCDF-4-files-into-netCDF-3-files"></a>
How can I convert netCDF-4 files into netCDF-3 files? </h2>
<p>In general, you can't, because netCDF-4 files may have features of the netCDF enhanced data model, such as groups, compound types, variable-length types, or multiple unlimited dimensions, for which no netCDF-3 representation is available. However, if you know that a netCDF-4 file conforms to the classic model, either because it was written as a netCDF-4 classic model file, because the program that wrote it was a netCDF-3 program that was merely relinked to a netCDF-4 library, or because no features of the enhanced model were used in writing the file, then there are several ways to convert it to a netCDF-3 file.</p>
<p>You can use the <b>nccopy</b> utility. For example to convert a netCDF-4 classic-model format file foo4c.nc to a classic format file foo3.nc, use:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;nccopy -k classic foo4c.nc foo3.nc</div></div><!-- fragment --><p>If you have installed <a href="http://www.unidata.ucar.edu/software/netcdf/docs/software.html#NCO">NCO</a>, the NCO utility "ncks" can be used to accomplish the same task, as follows:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncks -3 foo4c.nc foo3.nc</div></div><!-- fragment --><p>For a relatively small netCDF-4 classic model file, "small4c.nc" for example, you can also use the <b>ncdump</b> and <b>ncgen</b> utilities to create an equivalent netCDF-3 classic format file named "small3.nc" as follows:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncdump small4c.nc &gt; small4.cdl</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;ncgen -o small3.nc small4.cdl</div></div><!-- fragment --><h2><a class="anchor" id="How-can-I-convert-HDF5-files-into-netCDF-4-files"></a>
How can I convert HDF5 files into netCDF-4 files? </h2>
<p>NetCDF-4 intentionally supports a simpler data model than HDF5, which means there are HDF5 files that cannot be converted to netCDF-4, including files that make use of features in the following list:</p>
<ul>
<li>Multidimensional data that doesn't use shared dimensions implemented using HDF5 "dimension scales". (This restriction was eliminated in netCDF 4.1.1, permitting access to HDF5 datasets that don't use dimension scales.)</li>
<li>Non-hierarchical organizations of Groups, in which a Group may have multiple parents or may be both an ancestor and a descendant of another Group, creating cycles in the subgroup graph. In the netCDF-4 data model, Groups form a tree with no cycles, so each Group (except the top-level unnamed Group) has a unique parent.</li>
<li>HDF5 "references" which are like pointers to objects and data regions within a file. The netCDF-4 data model does not support references.</li>
<li>Additional primitive types not included in the netCDF-4 data model, including H5T_TIME, H5T_BITFIELD, and user-defined atomic types.</li>
<li>Multiple names for data objects such as variables and groups. The netCDF-4 data model requires that each variable and group have a single distinguished name.</li>
<li>Attributes attached to user-defined types.</li>
<li>Stored property lists</li>
<li>Object names that begin or end with a space</li>
</ul>
<p>If you know that an HDF5 file conforms to the netCDF-4 enhanced data model, either because it was written with netCDF function calls or because it doesn't make use of HDF5 features in the list above, then it can be accessed using netCDF-4, and analyzed, visualized, and manipulated through other applications that can access netCDF-4 files.</p>
<p>The <a href="http://nco.sourceforge.net/nco.html#ncks-netCDF-Kitchen-Sink">ncks tool</a> of the NCO collection of netCDF utilities can take simple HDF5 data as input and produce a netCDF file as output, so this may work:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncks infile.hdf5 outfile.nc</div></div><!-- fragment --><p>Another tool has been developed to convert HDF5-EOS Aura files to netCDF-4 files, and it is currently undergoing testing and documentation before release on the HDF5 web site.</p>
<h2><a class="anchor" id="How-can-I-convert-netCDF-4-files-into-HDF5-files"></a>
How can I convert netCDF-4 files into HDF5 files? </h2>
<p>Every netCDF-4 or netCDF-4 classic model file can be read or written by the HDF5 library, version 1.8 or later, so in that respect netCDF-4 files are already HDF5 files and need no conversion.</p>
<p>The way netCDF-4 data objects are represented using HDF5 is described in detail in the User Manual section <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#NetCDF_002d4-Format">"C.3 The NetCDF-4 Format"</a>.</p>
<h2><a class="anchor" id="why-arent-different-extensions-used"></a>
Why aren't different extensions used for the different formats, for example ".nc3" and ".nc4"? </h2>
<p>The file extension used for netCDF files is purely a convention. The netCDF libraries don't use the file extension. A user can currently create a netCDF file with any extension, even one not consistent with the format of the file.</p>
<p>The <b>ncgen</b> utility uses ".nc" as a default extension for output, but this can be overridden using the "-o" option to specify the name for the output file. Recent versions of <b>ncgen</b> also have a "-k" option to specify what kind of output file is desired, selecting any of the 4 format variants, using either a numeric code or a text string. Most other netCDF client software pays no attention to the file extension, so using more explicit extensions by convention has no significant drawbacks, except possibly causing confusion about format differences that may not be important.</p>
<h2><a class="anchor" id="Why-is-the-default-of-netCDF-4-to-continue-to-create-classic-files-rather-than-netCDF-4-files"></a>
Why is the default of netCDF-4 to continue to create classic files, rather than netCDF-4 files? </h2>
<p>Until widely used netCDF client software has been adapted or upgraded to read netCDF-4 data, classic file format is the default for interoperability with most existing netCDF software.</p>
<h2><a class="anchor" id="Can-netCDF-4-read-arbitrary-HDF5-files"></a>
Can netCDF-4 read arbitrary HDF5 files? </h2>
<p>No, but it can read many HDF5 files, and more recent versions can access more HDF5 data. If you want to access HDF5 data through netCDF interfaces, avoid HDF5 features not included in the netCDF enhanced data model. For more details see "[How can I convert HDF5 files into netCDF-4 files?](#fv15)", above.</p>
<h2><a class="anchor" id=""></a>
</h2>
<p>The number used for the shared library name is not related to the netCDF library version number.</p>
<h2><a class="anchor" id="NetCDF-363-permits-UTF-8-encoded-Unicode-names-Wont-this-break-backward-compatibility-with-previous-software-releases-that-didnt-allow-such-names"></a>
NetCDF-3.6.3 permits UTF-8 encoded Unicode names. Won't this break backward compatibility with previous software releases that didn't allow such names? </h2>
<p>Earlier versions of the netCDF libraries have always been able to read data with arbitrary characters in names. The restriction has been on <em>creating</em> files with names that contained "invalid" special characters. The check for characters used in names occurred when a program tried to define a new variable, dimension, or attribute, and an error would be returned if the characters in the names didn't follow the rules. However, there has never been any such check on reading data, so arbitrary characters have been permitted in names created through a different implementation of the netCDF APIs, or through early versions of netCDF software (before 2.4), which allowed arbitrary names.</p>
<p>In other words, the expansion to handle UTF-8 encoded Unicode characters and special characters such as `:' and ` ' still conforms with Unidata's commitment to backwards compatibility. All old files are still readable and writable by the new software, and programs that used to work will still work when recompiled and relinked with the new libraries. Files using new characters in names will still be readable and writable by programs that used older versions of the libraries. However, programs linked to older library versions will not be able to create new data objects with the new less-restrictive names.</p>
<h2><a class="anchor" id="How-difficult-is-it-to-convert-my-application-to-handle-arbitrary-netCDF-4-files"></a>
How difficult is it to convert my application to handle arbitrary netCDF-4 files? </h2>
<p>Modifying an application to fully support the new enhanced data model may be relatively easy or arbitrarily difficult :-), depending on what your application does and how it is written. Use of recursion is the easiest way to handle nested groups and nested user-defined types. An object-oriented architecture is also helpful in dealing with user-defined types.</p>
<p>We recommend proceeding incrementally, supporting features that are easier to implement first. For example, handling the six new primitive types is relatively straightforward. After that, using recursion (or the group iterator interface used in <b>nccopy</b>) to support Groups is not too difficult. Providing support for user-defined types is more of a challenge, especially since they can be nested.</p>
<p>The utility program <b>nccopy</b>, provided in releases 4.1 and later, shows how this can be done using the C interface. It copies an input netCDF file in any of the format variants, handling nested groups, strings, and any user-defined types, including arbitrarily nested compound types, variable-length types, and data of any valid netCDF-4 type. It also demonstrates how to handle variables that are too large to fit in memory by using an iterator interface. Other generic utility programs can make use of parts of <b>nccopy</b> for more complex operations on netCDF data. </p><hr/>
<h1><a class="anchor" id="Shared-Libraries"></a>
Shared Libraries </h1>
<h2><a class="anchor" id="What-are-shared-libraries"></a>
What are shared libraries? </h2>
<p>Shared libraries are libraries that can be shared by multiple running applications at the same time. This <b>may</b> improve performance.</p>
<p>For example, if I have a library that provides function foo(), and I have two applications that call foo(), then with a shared library, only one copy of the foo() function will be loaded into memory, and both programs will use it. With static libraries, each application would have its own copy of the foo() function.</p>
<p>More information on shared libraries can be found at the following external sites:</p>
<ul>
<li><a href="http://www.tldp.org/HOWTO/Program-Library-HOWTO/index.html">The Program-Library HowTo</a>, by David Wheeler.</li>
<li><a href="http://en.wikipedia.org/wiki/Library_(computer_science)">Wikipedia Library Entry</a> <hr/>
</li>
</ul>
<h2><a class="anchor" id="Can-I-build-netCDF-with-shared-libraries"></a>
Can I build netCDF with shared libraries? </h2>
<p>Starting with version 3.6.2, netCDF can build shared libraries on platforms that support them, but by default netCDF will build static libraries only. To turn on shared libraries, use the &ndash;enable-shared option to the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-install/Running-the-configure-Script.html">netCDF configure script</a>. </p><hr/>
<h2><a class="anchor" id="How-do-I-use-netCDF-shared-libraries"></a>
How do I use netCDF shared libraries? </h2>
<p>With netCDF version 3.6.2, shared libraries can be built on platforms that support them by using the &ndash;enable-shared argument to <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-install/Running-the-configure-Script.html">netCDF configure script</a>.</p>
<p>Users of earlier versions of netCDF can build shared libraries by setting flags correctly during builds.</p>
<p>When you use a static library, the code is copied from the library into your program when the program is built. The library is only needed at build time.</p>
<p>With a shared library the code in the library is not copied into your executable, so the library is needed every time the program is run.</p>
<p>If you write a program that uses the netCDF shared library, the operating system will have to find it every time your program is run. It will look in these places:</p>
<ol type="1">
<li>Directories you specified as shared library locations at <b>build time</b>. Unfortunately this is done differently with different compilers.</li>
<li>Directories specified in the environment variable LD_RUN_PATH at <b>build time</b>.</li>
<li>Directories specified in the OS-specific environment variable for this purpose at <b>run time</b>. (LD_LIBRARY_PATH on Linux and many other Unix variants, LOADLIBS on AIX systems, etc.)</li>
<li>A default list of directories that includes /usr/lib (but don't install software there!), and may or may not contain places you might install netCDF, like /usr/local/lib.</li>
<li>The directories specified in an OS file such as /etc/ld.conf.</li>
</ol>
<p>By default the netCDF library will be installed in /usr/local/lib. (This can be overridden with the &ndash;prefix option to the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf-install/Running-the-configure-Script.html">netCDF configure script</a>).</p>
<p>An external site by Arnaud Desitter has a <a href="http://www.fortran-2000.com/ArnaudRecipes/sharedlib.html">table of different tools and command line options relating to shared libraries</a> on Linux, Solaris, HP-UX, Tru64, AIX, SGI, Win32, MacOS X, VMS (wow!), and OS/390.</p>
<p>For more information about how do to this in Linux users may find it useful to read this external webpage, some documentation from Caldera, a Linux distributor: <a href="http://osr507doc.sco.com/en/tools/ccs_linkedit_dynamic_dirsearch.html">Specifying directories to be searched by the dynamic linker</a>. </p><hr/>
<h1><a class="anchor" id="Large-File-Support"></a>
Large File Support </h1>
<h2><a class="anchor" id="Was-it-possible-to-create-netCDF-files-larger-than-2-GiBytes-before-version-36"></a>
Was it possible to create netCDF files larger than 2 GiBytes before version 3.6? </h2>
<p>Yes, but there are significant restrictions on the structure of large netCDF files that result from the 32-bit relative offsets that are part of the classic netCDF format. For details, see <a href="http://www.unidata.ucar.edu/software/netcdf/documentation/historic/netcdf/NetCDF-Classic-Format-Limitations.html#NetCDF-Classic-Format-Limitations">NetCDF Classic Format Limitations</a> in the User's Guide. </p><hr/>
<h2><a class="anchor" id="What-is-Large-File-Support"></a>
What is Large File Support? </h2>
<p>Large File Support (LFS) refers to operating system and C library facilities to support files larger than 2 GiB. On a few 32-bit platforms the default size of a file offset is still a 4-byte signed integer, which limits the maximum size of a file to 2 GiB. Using LFS interfaces and the 64-bit file offset type, the maximum size of a file may be as large as 2^63^ bytes, or 8 EiB. For some current platforms, large file macros or appropriate compiler flags have to be set to build a library with support for large files. This is handled automatically in netCDF 3.6 and later versions.</p>
<p>More information about Large File Support is available from <a href="http://www.unix.org/version2/whatsnew/lfs.html">Adding Large File Support to the Single UNIX Specification</a>. </p><hr/>
<h2><a class="anchor" id="What-does-Large-File-Support-have-to-do-with-netCDF"></a>
What does Large File Support have to do with netCDF? </h2>
<p>When the netCDF format was created in 1988, 4-byte fields were reserved for file offsets, specifying where the data for each variable started relative to the beginning of the file or the start of a record boundary.</p>
<p>This first netCDF format variant, the only format supported in versions 3.5.1 and earlier, is referred to as the netCDF <em>classic</em> format. The 32-bit file offset in the classic format limits the total sizes of all but the last non-record variables in a file to less than 2 GiB, with a similar limitation for the data within each record for record variables. For more information see <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf/NetCDF-Classic-Format-Limitations.html#NetCDF-Classic-Format-Limitations">Classic Format Limitations</a>.</p>
<p>The netCDF classic format is also identified as <em>version 1</em> or <em>CDF1</em> in reference to the format label at the start of a file.</p>
<p>With netCDF version 3.6 and later, a second variant of netCDF format is supported in addition to the classic format. The new variant is referred to as the <em>64-bit offset</em> format, <em>version 2</em>, or <em>CDF2</em>. The primary difference from the classic format is the use of 64-bit file offsets instead of 32-bit offsets, but it also supports larger variable and record sizes. </p><hr/>
<h2><a class="anchor" id="Do-I-have-to-know-which-netCDF-file-format-variant-is-used-in-order-to-access-or-modify-a-netCDF-file"></a>
Do I have to know which netCDF file format variant is used in order to access or modify a netCDF file? </h2>
<p>No, version 3.6 and later versions of the netCDF C/Fortran library detect which variant of the format is used for each file when it is opened for reading or writing, so it is not necessary to know which variant of the format is used. The version of the format will be preserved by the library on writing. If you want to modify a classic format file to use the 64-bit offset format so you can make it much larger, you will have to create a new file and copy the data to it. The <b>nccopy</b> utility available in version 4.1 can copy a classic file to a 64-bit offset file. </p><hr/>
<h2><a class="anchor" id="Will-future-versions-of-the-netCDF-library-continue-to-support-accessing-files-in-the-classic-format"></a>
Will future versions of the netCDF library continue to support accessing files in the classic format? </h2>
<p>Yes, the 3.6 library and all planned future versions of the library will continue to support reading and writing files using the classic (32-bit offset) format as well as the 64-bit offset format. There is no need to convert existing archives from the classic to the 64-bit offset format. Even netCDF-4, which introduces a third variant of the netCDF format based on HDF5, continues to support accessing classic format netCDF files as well as 64-bit offset netCDF files. NetCDF-4 HDF5 files have even fewer restrictions on size than 64-bit offset netCDF files. </p><hr/>
<h2><a class="anchor" id="Should-I-start-using-the-new-64-bit-offset-format-for-all-my-netCDF-files"></a>
Should I start using the new 64-bit offset format for all my netCDF files? </h2>
<p>No, we discourage users from making use of the 64-bit offset format unless they need it for large files. It may be some time until third-party software that uses the netCDF library is upgraded to 3.6 or later versions that support the large file facilities, so we advise continuing to use the classic netCDF format for data that doesn't require file offsets larger than 32 bits. The library makes this recommendation easy to follow, since the default for file creation is the classic format. </p><hr/>
<h2><a class="anchor" id="How-can-I-tell-if-a-netCDF-file-uses-the-classic-format-or-64-bit-offset-format"></a>
How can I tell if a netCDF file uses the classic format or 64-bit offset format? </h2>
<p>The short answer is that under most circumstances, you should not care, if you use version 3.6.0 or later of the netCDF library. But the difference is indicated in the first four bytes of the file, which are 'C', 'D', 'F', '\001' for the classic netCDF format and 'C', 'D', 'F', '\002' for the 64-bit offset format. On a Unix system, one way to display the first four bytes of a file, say foo.nc, is to run the following command:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;od -An -c -N4 foo.nc</div></div><!-- fragment --><p>which will output</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;C   D   F 001</div></div><!-- fragment --><p>or</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;C   D   F 002</div></div><!-- fragment --><p>depending on whether foo.nc is a classic or 64-bit offset netCDF file, respectively.</p>
<p>With netCDF version 3.6.2 or later, there is an easier way, using the "-k" option to <b>ncdump</b> to determine the kind of file, for example:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;ncdump -k foo.nc</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;classic</div></div><!-- fragment --> <hr/>
<h2><a class="anchor" id="What-happens-if-I-create-a-64-bit-offset-format-netCDF-file-and-try-to-open-it-with-an-older-netCDF-application-that-hasnt-been-linked-with-netCDF-36"></a>
What happens if I create a 64-bit offset format netCDF file and try to open it with an older netCDF application that hasn't been linked with netCDF 3.6? </h2>
<p>The application will indicate an error trying to open the file and present an error message equivalent to "not a netCDF file". This is why it's a good idea not to create 64-bit offset netCDF files until you actually need them. </p><hr/>
<h2><a class="anchor" id="Can-I-create-64-bit-offset-files-on-32-bit-platforms"></a>
Can I create 64-bit offset files on 32-bit platforms? </h2>
<p>Yes, by specifying the appropriate file creation flag you can create 64-bit offset netCDF files the same way on 32-bit platforms as on 64-bit platforms. You do not need to compile the C/Fortran libraries as 64-bit to support access to 64-bit offset netCDF files. </p><hr/>
<h2><a class="anchor" id="How-do-I-create-a-64-bit-offset-netCDF-file-from-C-Fortran-77-Fortran-90-or-Cpp"></a>
How do I create a 64-bit offset netCDF file from C, Fortran-77, Fortran-90, or C++? </h2>
<p>With netCDF version 3.6.0 or later, use the NC_64BIT_OFFSET flag when you call <a class="el" href="group__datasets.html#ga427f5a0b24f1d426a99bcc37b8a39cac" title="Create a new netCDF file. ">nc_create()</a>, as in:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;err = nc_create(&quot;foo.nc&quot;,</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;                NC_NOCLOBBER | NC_64BIT_OFFSET,</div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;                &amp;ncid);</div></div><!-- fragment --><p>In Fortran-77, use the NF_64BIT_OFFSET flag when you call nf_create(), as in:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;iret = nf_create(&#39;foo.nc&#39;,</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;                 IOR(NF_NOCLOBBER,NF_64BIT_OFFSET),</div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;                 ncid)</div></div><!-- fragment --><p>In Fortran-90, use the NF90_64BIT_OFFSET flag when you call nf90_create(), as in:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;iret = nf90_create(path=&quot;foo.nc&quot;,</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;                   cmode=or(nf90_noclobber,nf90_64bit_offset),</div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;                   ncid=ncFileID)</div></div><!-- fragment --><p>In C++, use the Offset64Bits enum in the NcFile constructor, as in:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;NcFile nc(&quot;foo.nc&quot;,</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;          FileMode=NcFile::New,</div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;          FileFormat=NcFile::Offset64Bits);</div></div><!-- fragment --><p>In Java, use the setLargeFile() method of the NetcdfFileWritable class. </p><hr/>
<h2><a class="anchor" id="How-do-I-create-a-64-bit-offset-netCDF-file-using-the-ncgen-utility"></a>
How do I create a 64-bit offset netCDF file using the ncgen utility? </h2>
<p>A command-line option, '-k', specifies the kind of file format variant. By default or if '-k classic' is specified, the generated file will be in netCDF classic format. If '-k 64-bit-offset' is specified, the generated file will use the 64-bit offset format. </p><hr/>
<h2><a class="anchor" id="Have-all-netCDF-size-limits-been-eliminated"></a>
Have all netCDF size limits been eliminated? </h2>
<p>The netCDF-4 HDF5-based format has no practical limits on the size of a variable.</p>
<p>However, for the classic and 64-bit offset formats there are still limits on sizes of netCDF objects. Each fixed-size variable (except the last, when there are no record variables) and the data for one record's worth of a single record variable (except the last) are limited in size to a little less that 4 GiB, which is twice the size limit in versions earlier than netCDF 3.6.</p>
<p>The maximum number of records remains 2^32^-1. </p><hr/>
<h2><a class="anchor" id="Why-are-variables-still-limited-in-size"></a>
Why are variables still limited in size? </h2>
<p>While most platforms support a 64-bit file offset, many platforms only support a 32-bit size for allocated memory blocks, array sizes, and memory pointers. In C developer's jargon, these platforms have a 64-bit <code>off_t</code> type for file offsets, but a 32-bit <code>size_t</code> type for size of arrays. Changing netCDF to assume a 64-bit <code>size_t</code> would restrict netCDF's use to 64-bit platforms. </p><hr/>
<h2><a class="anchor" id="How-can-I-write-variables-larger-than-4-GiB"></a>
How can I write variables larger than 4 GiB? </h2>
<p>You can overcome the 4 GiB size barrier by using the netCDF-4 HDF5 format for your data. The only change required to the program that writes the data is an extra flag to the file creation call, followed by recompiling and relinking to the netCDF-4 library. Programs that access the data would also need to be recompiled and relinked to the netCDF-4 library.</p>
<p>For classic and 64-bit offset netCDF formats, if you change the first dimension of a variable from a fixed size to an unlimited size instead, the variable can be much larger. Even though record variables are restricted to 4 Gib per record, there may be 4 billion records. NetCDF classic or 64-bit offset files can only have one unlimited dimension, so this won't work if you are already using a record dimension for other purposes.</p>
<p>It is also possible to overcome the 4 GiB variable restriction for a single fixed size variable, when there are no record variables, by making it the last variable, as explained in the example in <a href="http://www.unidata.ucar.edu/software/netcdf/documentation/historic/netcdf/NetCDF-Classic-Format-Limitations.html#NetCDF-Classic-Format-Limitations">NetCDF Classic Format Limitations</a>. </p><hr/>
<h2><a class="anchor" id="Why-do-I-get-an-error-message-when-I-try-to-create-a-file-larger-than-2-GiB-with-the-new-library"></a>
Why do I get an error message when I try to create a file larger than 2 GiB with the new library? </h2>
<p>There are several possible reasons why creating a large file can fail that are not related to the netCDF library:</p>
<ul>
<li>User quotas may prevent you from creating large files. On a Unix system, you can use the "ulimit" command to report limitations such as the file-size writing limit.</li>
<li>There is insufficient disk space for the file you are trying to write.</li>
<li><p class="startli">The file system in which you are writing may not be configured to allow large files. On a Unix system, you can test this with a commands such as</p>
<p class="startli">~~~~ {.boldcode} dd if=/dev/zero bs=1000000 count=3000 of=./largefile ls -l largefile rm largefile ~~~~</p>
<p class="startli">which should write a 3 GByte file named "largefile" in the current directory, verify its size, and remove it.</p>
</li>
</ul>
<p>If you get the netCDF library error "One or more variable sizes violate
format constraints", you are trying to define a variable larger than permitted for the file format variant. This error typically occurs when leaving "define mode" rather than when defining a variable. The error status cannot be returned when a variable is first defined, because the last fixed-size variable defined is permitted to be larger than other fixed-size variables (when there are no record variables).</p>
<p>Similarly, the last record variable may be larger than other record variables. This means that subsequently adding a small variable to an existing file may be invalid, because it makes what was previously the last variable now in violation of the format size constraints. For details on the format size constraints, see the Users Guide sections <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#Classic-Limitations">NetCDF Classic Format Limitations</a> and <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#64-bit-Offset-Limitations">NetCDF 64-bit Offset Format Limitations</a>.</p>
<p>If you get the netCDF library error "Invalid dimension size" for a non-negative size, you are exceeding the size limit of netCDF dimensions, which must be less than 2,147,483,644 for classic files with no large file support and otherwise less than 4,294,967,292. </p><hr/>
<h2><a class="anchor" id="Do-I-need-to-use-special-compiler-flags-to-compile-and-link-my-applications-that-use-netCDF-with-Large-File-Support"></a>
Do I need to use special compiler flags to compile and link my applications that use netCDF with Large File Support? </h2>
<p>No, except that 32-bit applications should link with a 32-bit version of the library and 64-bit applications should link with a 64-bit library, similarly to use of other libraries that can support either a 32-bit or 64-bit model of computation. But note that a 32-bit version of the netCDF library fully supports writing and reading 64-bit offset netCDF files. </p><hr/>
<h2><a class="anchor" id="isitpossibleclassic360"></a>
Is it possible to create a "classic" format netCDF file with netCDF version 3.6.0 that cannot be accessed by applications compiled and linked against earlier versions of the library? </h2>
<p>No, classic files created with the new library should be compatible with all older applications, both for reading and writing, with one minor exception. The exception is due to a correction of a netCDF bug that prevented creating records larger than 4 GiB in classic netCDF files with software linked against versions 3.5.1 and earlier. This limitation in total record size was not a limitation of the classic format, but an unnecessary restriction due to the use of too small a type in an internal data structure in the library.</p>
<p>If you want to always make sure your classic netCDF files are readable by older applications, make sure you don't exceed 4 GiBytes for the total size of a record's worth of data. (All records are the same size, computed by adding the size for a record's worth of each record variable, with suitable padding to make sure each record begins on a byte boundary divisible by 4.) </p><hr/>
<h1><a class="anchor" id="NetCDF-and-Other-Software"></a>
NetCDF and Other Software </h1>
<h2><a class="anchor" id="What-other-software-is-available-for-accessing-displaying-and-manipulating-netCDF-data"></a>
What other software is available for accessing, displaying, and manipulating netCDF data? </h2>
<p>Utilities available in the current netCDF distribution from Unidata are <b>ncdump</b>, for converting netCDF files to an ASCII human-readable form, and <b>ncgen</b> for converting from the ASCII human-readable form back to a binary netCDF file or a C or FORTRAN program for generating the netCDF file. <a href="software.html">Software for Manipulating or Displaying NetCDF Data</a> provides a list of other software useful for access, visualization, and analysis of netCDF data and data represented in other forms. Another useful <a href="http://nomads.gfdl.noaa.gov/sandbox/products/vis/data/netcdf/GFDL_VG_NetCDF_Utils.html">guide to netCDF utilities</a> is available from NOAA's Geophysical Fluid Dynamics Laboratory. </p><hr/>
<h2><a class="anchor" id="What-other-data-access-interfaces-and-formats-are-available-for-scientific-data"></a>
What other data access interfaces and formats are available for scientific data? </h2>
<p>The <a href="http://www.cv.nrao.edu/fits/traffic/scidataformats/faq.html">Scientific Data Format Information FAQ</a> provides a somewhat dated description of other access interfaces and formats for scientific data, including <a href="http://nssdc.gsfc.nasa.gov/cdf/cdf_home.html">CDF</a> and <a href="http://hdf.ncsa.uiuc.edu/">HDF</a>. A brief comparison of CDF, netCDF, and HDF is available in the <a href="http://nssdc.gsfc.nasa.gov/cdf/html/FAQ.html">CDF FAQ</a>. Another comparison is in Jan Heijmans' <a href="http://www.xi-advies.nl/downloads/AnIntroductionToDistributedVisualization.pdf">An Introduction to Distributed Visualization</a>. John May's book <a href="http://www.llnl.gov/CASC/news/johnmay/John_May_book.html"><em>Parallel I/O for High Performance Computing</em></a> includes a chapter on Scientific Data Libraries that describes netCDF and HDF5, with example source code for reading and writing files using both interfaces. </p><hr/>
<h2><a class="anchor" id="What-is-the-connection-between-netCDF-and-CDF"></a>
What is the connection between netCDF and CDF? </h2>
<p><a href="http://cdf.gsfc.nasa.gov/">CDF</a> was developed at the NASA Space Science Data Center at Goddard, and is freely available. It was originally a VMS FORTRAN interface for scientific data access. Unidata reimplemented the library from scratch to use <a href="http://www.faqs.org/rfcs/rfc1832.html">XDR</a> for a machine-independent representation, designed the <a href="http://www.unidata.ucar.edu/software/netcdf/documentation/historic/netcdf/CDL-Syntax.htm">CDL</a> (network Common Data form Language) text representation for netCDF data, and added aggregate data access, a single-file implementation, named dimensions, and variable-specific attributes.</p>
<p>NetCDF and CDF have evolved independently. CDF now supports many of the same features as netCDF (aggregate data access, XDR representation, single-file representation, variable-specific attributes), but some differences remain (netCDF doesn't support native-mode representation, CDF doesn't support named dimensions). There is no compatibility between data in CDF and netCDF form, but NASA makes available <a href="http://cdf.gsfc.nasa.gov/html/dtws.html">some translators</a> between various scientific data formats. For a more detailed description of differences between CDF and netCDF, see the <a href="http://cdf.gsfc.nasa.gov/html/FAQ.html">CDF FAQ</a>. </p><hr/>
<h2><a class="anchor" id="What-is-the-connection-between-netCDF-and-HDF"></a>
What is the connection between netCDF and HDF? </h2>
<p>The National Center for Supercomputing Applications (NCSA) originally developed <a href="http://hdf.ncsa.uiuc.edu/">HDF4</a> and made it freely available. HDF4 is an extensible data format for self-describing files that was developed independently of netCDF. HDF4 supports both C and Fortran interfaces, and it has been successfully ported to a wide variety of machine architectures and operating systems. HDF4 emphasizes a single common format for data, on which many interfaces can be built.</p>
<p>NCSA implemented software that provided a netCDF-2 interface to HDF4. With this software, it was possible to use the netCDF calling interface to place data into an HDF4 file.</p>
<p>HDF5, developed and supported by The HDF Group, Inc., a non-profit spin-off from the NCSA group, provides a richer data model, with emphasis on efficiency of access, parallel I/O, and support for high-performance computing. The netCDF-4 project has implemented an enhanced netCDF interface on the HDF5 storage layer to preserve the desirable common characteristics of netCDF and HDF5 while taking advantage of their separate strengths: the widespread use and simplicity of netCDF and the generality and performance of HDF5. </p><hr/>
<h2><a class="anchor" id="Has-anyone-implemented-client-server-access-for-netCDF-data"></a>
Has anyone implemented client-server access for netCDF data? </h2>
<p>Yes, as part of the <a href="http://www.opendap.org/">OPeNDAP</a> framework, developers have implemented a client-server system for access to remote data that supports use of the netCDF interface for clients. A reference version of the software is available from the <a href="http://www.opendap.org/download/index.html/">OPeNDAP download site</a>. After linking your netCDF application with the OPeNDAP netCDF library, you can use URL's to access data from other sites running an OPeNDAP server. This supports accessing small subsets of large datasets remotely through the netCDF interfaces, without copying the datasets.</p>
<p>The 4.1 release of netCDF will include OPeNDAP client support; an experimental version is available now in the snapshot distributions.</p>
<p>Other clients and servers support access through a netCDF interface to netCDF and other kinds of data, including clients written using the <a href="http://www.unidata.ucar.edu/software/netcdf-java/">netCDF-Java library</a> and servers that use the <a href="/software/thredds/current/tds/TDS.html">THREDDS Data Server</a>.</p>
<p>The <a href="http://grads.iges.org/grads/gds/">GrADS Data Server</a> provides subsetting and analysis services across the Internet for any GrADS-readable dataset, including suitable netCDF datasets. The latest version of the <a href="http://ferret.pmel.noaa.gov/LAS">PMEL Live Access Server</a> uses THREDDS Data Server technology to provide flexible access to geo-referenced scientific data, including netCDF data. </p><hr/>
<h2><a class="anchor" id="How-do-I-convert-between-GRIB-and-netCDF"></a>
How do I convert between GRIB and netCDF? </h2>
<p>Several programs and packages have been developed that convert between <a href="http://www.wmo.ch/web/www/DPS/grib-2.html">GRIB</a> and netCDF data: <a href="http://www.ncl.ucar.edu/Applications/grib2netCDF.shtml">ncl_convert2nc</a>, <a href="http://www.nws.noaa.gov/mdl/NDFD_GRIB2Decoder/">degrib</a>, <a href="software.html#CDAT">CDAT</a>, <a href="software.html#CDO">CDO</a>, <a href="http://www.gdal.org/">GDAL</a>, <a href="software.html#GrADS">GrADS</a>, and <a href="http://www.cpc.noaa.gov/products/wesley/wgrib2/">wgrib2</a>.</p>
<p>The Unidata <a href="http://www.unidata.ucar.edu/software/netcdf-java/index.html">netCDF Java Library</a> can read GRIB1 and GRIB2 data (and many other data formats) through a netCDF interface. As a command-line example, you could convert <em>fileIn.grib</em> to <em>fileOut.nc</em> as follows:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;java -Xmx1g -classpath netcdfAll-4.3.jar ucar.nc2.dataset.NetcdfDataset \</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;  -in fileIn.grib -out fileOut.nc [-isLargeFile] [-netcdf4]</div></div><!-- fragment --><p>For more details on using netCDF Java, see the CDM man pages for <a href="http://www.unidata.ucar.edu/software/netcdf-java/reference/manPages.html#nccopy">nccopy</a>. </p><hr/>
<h2>Problems and Bugs </h2>
<h2><a class="anchor" id="Can-I-recover-data-from-a-netCDF-file-that-was-not-closed-properly"></a>
Can I recover data from a netCDF file that was not closed properly? </h2>
<p><em>I have some netcdf files which have data in them and were apparently not properly closed. When I examine them using <b>ncdump</b> they report zero data points, although the size is a few megabytes. Is there a way of recovering them?</em></p>
<p>If the files are in classic format or 64-bit offset format (if they were created by netCDF version 3.6.3 or earlier, for example), then you can use an editor that allows you to change binary files, such as emacs, to correct the four-byte number of records field in the file. This is a bigendian 4 byte integer that begins at the 4th byte in the file.</p>
<p>This is what the first eight bytes would look like for classic format if you had zero records, where printable characters are specified as US-ASCII characters within single-quotes and non-printable bytes are denoted using a hexadecimal number with the notation '\xDD', where each D is a hexadecimal digit:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;&#39;C&#39; &#39;D&#39; &#39;F&#39; \x01 \x00 \x00 \x00 \x00</div></div><!-- fragment --><p>or</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;&#39;C&#39; &#39;D&#39; &#39;F&#39; \x02 \x00 \x00 \x00 \x00</div></div><!-- fragment --><p>for 64-bit-offset format.</p>
<p>And this is what the first eight bytes should look like for classic format if you had 500 records (500 is 01F4 in hexadecimal)</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;&#39;C&#39; &#39;D&#39; &#39;F&#39; \x01 \x00 \x01 \x0f \x04</div></div><!-- fragment --><p>or</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;&#39;C&#39; &#39;D&#39; &#39;F&#39; \x02 \x00 \x01 \x0f \x04</div></div><!-- fragment --><p>for 64-bit-offset format.</p>
<p>So if you can compute how many records should be in the file, you can edit the second four bytes to fix this. You can find out how many records should be in the file from the size of the file and from the variable types and their shapes. See the <a href="http://www.unidata.ucar.edu/software/netcdf/docs/netcdf.html#File-Format">description of the netCDF format</a> for classic and 64-bit offset files for how to figure out how large the file should be for fixed sized variables of particular shapes and for a specified number of record variables of particular shapes.</p>
<p>Note that if you neglected to call the appropriate netCDF close function on a file, data in the last record written but not flushed to the disk may also be lost, but correcting the record count should allow recovery of the other records. </p><hr/>
<h2><a class="anchor" id="Is-there-a-list-of-reported-problems-and-workarounds"></a>
Is there a list of reported problems and workarounds? </h2>
<p>Yes, the document <a href="known_problems.html">Known problems with the netCDF Distribution</a> describes reported problems and workarounds in the latest version and some earlier releases. </p><hr/>
<h2><a class="anchor" id="How-do-I-make-a-bug-report"></a>
How do I make a bug report? </h2>
<p>If you find a bug, send a description to <a href="#" onclick="location.href='mai'+'lto:'+'sup'+'po'+'rt-'+'ne'+'tcd'+'f@'+'uni'+'da'+'ta.'+'uc'+'ar.'+'ed'+'u'; return false;">suppo<span style="display: none;">.nosp@m.</span>rt-n<span style="display: none;">.nosp@m.</span>etcdf<span style="display: none;">.nosp@m.</span>@uni<span style="display: none;">.nosp@m.</span>data.<span style="display: none;">.nosp@m.</span>ucar<span style="display: none;">.nosp@m.</span>.edu</a>. This is also the address to use for questions or discussions about netCDF that are not appropriate for the entire netcdfgroup mailing list. </p><hr/>
<h2><a class="anchor" id="How-do-I-search-through-past-problem-reports"></a>
How do I search through past problem reports? </h2>
<p>A search link is available at the bottom of the <a href="http://www.unidata.ucar.edu/software/netcdf/">netCDF homepage</a>, providing a full-text search of the support questions and answers about netCDF provided by Unidata support staff. </p><hr/>
<h1><a class="anchor" id="Programming-with-NetCDF"></a>
Programming with NetCDF </h1>
<h2><a class="anchor" id="Which-programming-languages-have-netCDF-interfaces"></a>
Which programming languages have netCDF interfaces? </h2>
<p>The netCDF distribution comes with interfaces for C, Fortran77, Fortran90, and C++. Other languages for which interfaces are available separately include:</p>
<ul>
<li><a href="http://freshmeat.net/projects/adanetcdf/">Ada</a></li>
<li><a href="software.html#IDL">IDL</a></li>
<li><a href="software.html#Java%20interface">Java</a></li>
<li><a href="software.html#MATLAB">MATLAB</a></li>
<li><a href="software.html#Perl">Perl</a></li>
<li><a href="software.html#Python">Python</a></li>
<li><a href="software.html#R">R</a></li>
<li><a href="software.html#Ruby">Ruby</a></li>
<li><a href="software.html#Tcl/Tk">Tcl/Tk</a> <hr/>
</li>
</ul>
<h2><a class="anchor" id="Are-the-netCDF-libraries-thread-safe"></a>
Are the netCDF libraries thread-safe? </h2>
<p>The C-based libraries are <em>not</em> thread-safe. C-based libraries are those that depend on the C library, which currently include all language interfaces except for the Java interface. The Java interface is thread-safe when a few simple rules are followed, such as each thread getting their handle to a file. </p><hr/>
<h2><a class="anchor" id="How-does-the-Cpp-interface-differ-from-the-C-interface"></a>
How does the C++ interface differ from the C interface? </h2>
<p>It provides all the functionality of the C interface (except for the generalized mapped access of ncvarputg() and ncvargetg()) and is somewhat simpler to use than the C interface. With the C++ interface, no IDs are needed for netCDF components, there is no need to specify types when creating attributes, and less indirection is required for dealing with dimensions. However, the C++ interface is less mature and less-widely used than the C interface, and the documentation for the C++ interface is less extensive, assuming a familiarity with the netCDF data model and the C interface. Recently development of the C++ interface has languished as resources have been redirected to enhancing the Java interface. </p><hr/>
<h2><a class="anchor" id="How-does-the-Fortran-interface-differ-from-the-C-interface"></a>
How does the Fortran interface differ from the C interface? </h2>
<p>It provides all the functionality of the C interface. The Fortran interface uses Fortran conventions for array indices, subscript order, and strings. There is no difference in the on-disk format for data written from the different language interfaces. Data written by a C language program may be read from a Fortran program and vice-versa. The Fortran-90 interface is much smaller than the FORTRAN 77 interface as a result of using optional arguments and overloaded functions wherever possible. </p><hr/>
<h2><a class="anchor" id="How-do-the-Java-Perl-Python-Ruby-interfaces-differ-from-the-C-interface"></a>
How do the Java, Perl, Python, Ruby, ... interfaces differ from the C interface? </h2>
<p>They provide all the functionality of the C interface, using appropriate language conventions. There is no difference in the on-disk format for data written from the different language interfaces. Data written by a C language program may be read from programs that use other language interfaces, and vice-versa. </p><hr/>
<h2><a class="anchor" id="How-do-I-handle-errors-in-C"></a>
How do I handle errors in C? </h2>
<p>For clarity, the NetCDF C Interface Guide contains examples which use a function called handle_err() to handle potential errors like this:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;status = nc_create(&quot;foo.nc&quot;, NC_NOCLOBBER, &amp;ncid);</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;if (status != NC_NOERR) handle_error(status);</div></div><!-- fragment --><p>Most developers use some sort of macro to invoke netCDF functions and test the status returned in the calling context without a function call, but using such a macro in the User's Guides arguably makes the examples needlessly complex. For example, some really excellent developers define an "ERR" macro and write code like this:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;if (nc_create(testfile, NC_CLOBBER, &amp;ncid)) ERR;</div></div><!-- fragment --><p>where Err is defined in a header file:</p>
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;/* This macro prints an error message with line number and name of</div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160; * test program. */</div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;#define ERR do { \</div><div class="line"><a name="l00004"></a><span class="lineno">    4</span>&#160;fflush(stdout); /* Make sure our stdout is synced with stderr. */ \</div><div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;err++; \</div><div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;fprintf(stderr, &quot;Sorry! Unexpected result, %s, line: %d\n&quot;, \</div><div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;        __FILE__, __LINE__);                                \</div><div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;} while (0)</div></div><!-- fragment --><p>Ultimately, error handling depends on the application which is calling netCDF functions. However we strongly suggest that some form of error checking be used for all netCDF function calls. </p><hr/>
<h1><a class="anchor" id="cmake_faq"></a>
CMake </h1>
<p>Below are a list of commonly-asked questions regarding NetCDF and CMake.</p>
<h2><a class="anchor" id="listoptions"></a>
How can I see the options available to CMake? </h2>
<pre class="fragment">    $ cmake [path to source tree] -L    - This will show the basic options.
    $ cmake [path to source tree] -LA   - This will show the basic and advanced options.
</pre><h2><a class="anchor" id="sharedstatic"></a>
How do I specify how to build a shared or static library? </h2>
<pre class="fragment">This is controlled with the internal `cmake` option, `BUILD_SHARED_LIBS`.

    $ cmake [Source Directory] -DBUILD_SHARED_LIBS=[ON/OFF]
</pre><h2><a class="anchor" id="sharedstaticboth"></a>
Can I build both shared and static libraries at the same time with cmake? </h2>
<p>Not at this time; it is required to instead build first one version, and then the other, if you need both.</p>
<h2><a class="anchor" id="partlib"></a>
How can I specify linking against a particular library? </h2>
<p>It depends on the library. To specify a custom <code>ZLib</code>, for example, you would do the following: </p><pre class="fragment">    $ cmake [Source Directory] -DZLIB_LIBRARY=/path/to/my/zlib.lib
</pre><p><code>HDF5</code> is more complex, since it requires both the <code>hdf5</code> and <code>hdf5_hl</code> libraries. You would specify custom <code>HDF5</code> libraries as follows: </p><pre class="fragment">    $ cmake [Source Directory] -DHDF5_LIB=/path/to/hdf5.lib \
        -DHDF5_HL_LIB=/path/to/hdf5_hl.lib \
        -DHDF5_INCLUDE_DIR=/path/to/hdf5/include
</pre><p>Alternatively, you may specify: </p><pre class="fragment">    $ cmake [Source Directory] \
        -DHDF5_LIBRARIES="/path/to/hdf5.lib;/path/to/hdf5_hl.lib" \
        -DHDF5_INCLUDE_DIRS=/path/to/hdf5/include/
</pre><h2><a class="anchor" id="nonstdloc"></a>
What if I want to link against multiple libraries in a non-standard location </h2>
<pre class="fragment">You can specify the path to search when looking for dependencies and header files using the `CMAKE_PREFIX_PATH` variable:
</pre><ul>
<li>Windows: <pre class="fragment">  $ cmake [Source Directory] -DCMAKE_PREFIX_PATH=c:\shared\libs\
</pre></li>
<li>Linux/Unix/OSX: <pre class="fragment">  $ cmake [Source Directory] -DCMAKE_PREFIX_PATH=/usr/custom_library_locations/
</pre></li>
</ul>
<h2><a class="anchor" id="parallelhdf"></a>
How can I specify a Parallel Build using HDF5 </h2>
<p>If cmake is having problems finding the parallel <code>HDF5</code> install, you can specify the location manually:</p>
<pre class="fragment">    $ cmake [Source Directory] -DENABLE_PARALLEL=ON \
        -DHDF5_LIB=/usr/lib64/openmpi/lib/libhdf5.so \
        -DHDF5_HL_LIB=/usr/lib64/openmpi/lib/libhdf5.hl.so \
        -DHDF5_INCLUDE_DIR=/usr/include/openmpi-x86_64 \
</pre><p>You will, of course, need to use the location of the libraries specific to your development environment. </p><hr/>
<h1><a class="anchor" id="Plans"></a>
Plans </h1>
<h2><a class="anchor" id="What-other-future-work-on-netCDF-is-planned"></a>
What other future work on netCDF is planned? </h2>
<p>Issues, bugs, and plans for netCDF are maintained in the Unidata issue tracker sites for <a href="https://www.unidata.ucar.edu/jira/browse/NCF">netCDF-C</a>, <a href="https://www.unidata.ucar.edu/jira/browse/CDM">Common Data Model / NetCDF-Java</a>, <a href="https://www.unidata.ucar.edu/jira/browse/NCFORTRAN">netCDF-Fortran</a>, and <a href="https://www.unidata.ucar.edu/jira/browse/NCXXF">netCDF-CXX4</a>, and <a href="https://www.unidata.ucar.edu/jira/browse/NCCPP">old netCDF-C++ (deprecated)</a>. </p>
</div></div><!-- contents -->
</div><!-- doc-content -->
<hr size="2"/>
<address style="text-align: center;">
<a href="http://www.unidata.ucar.edu/software/netcdf/">Return to the Main Unidata NetCDF page.</a><br>
<img src="unidata_logo_cmyk.png">
<address style="text-align: right;"><small>
Generated on Sun Mar 27 2016 11:43:30 for NetCDF. NetCDF is
a <a href="http://www.unidata.ucar.edu/">Unidata</a> library.</small></address>
</body>
</html>