Aktionen

NetCDF Profile: Unterschied zwischen den Versionen

Aus BAWiki

imported>Lang Guenther
(→‎Kurze Beschreibung: Hinweis zu Mesh1_edge_nodes)
imported>Lang Guenther
(→‎Kantenverzeichnis der Profile: cf_role und start_index ergänzt)
Zeile 109: Zeile 109:
int Mesh1_prof_edges(nMesh1_prof, nMaxMesh1_prof_edges) ;
int Mesh1_prof_edges(nMesh1_prof, nMaxMesh1_prof_edges) ;
: Mesh1_prof_edges:long_name = "Kantenverzeichnis der Profile, vom Anfang zum Ende sortiert" ;
: Mesh1_prof_edges:long_name = "Kantenverzeichnis der Profile, vom Anfang zum Ende sortiert" ;
: Mesh1_prof_edges:cf_role = "prof_edge_connectivity" ;
: Mesh1_prof_edges:_FillValue = -999 ;
: Mesh1_prof_edges:_FillValue = -999 ;
: Mesh1_prof_edges:comment = "Indizes starten mit Null!" ;
: Mesh1_prof_edges:start_index = 0 ;
Hinweise:  
Hinweise:  
# Indizes starten mit Null!
# Ein Standardname sollte gelegentlich ergänzt werden.
# Kann dazu genutzt werden, mehrere zusammenhängende Profile, z. B. Längs- und Querprofile, zu deklarieren.
# Kann dazu genutzt werden, mehrere zusammenhängende Profile, z. B. Längs- und Querprofile, zu deklarieren.
# Einzelne Kanten dürfen mehrfach in (verschiedenen) Listen auftauchen.
# Einzelne Kanten dürfen mehrfach in (verschiedenen) Listen auftauchen.

Version vom 13. April 2012, 07:38 Uhr

Kurze Beschreibung

Es wird die Lage mehrerer (Längs- und Quer-) Profile beschrieben.

Am 13. 04. 2012 wurde der Text an die Deltares-Konventionen angepasst. Die wichtigsten Änderungen sind:

  1. Bei Mesh1_edge_nodes wurde cf_role und start_index ergänzt.

Inhalt der Datei

Dimensionen

  1. nMesh1_node : Anzahl der Profilknoten.
  2. nMesh1_edge : Anzahl der Profilkanten.
  3. nMesh1_prof : Anzahl der Profile (Längs- und Querprofile).
  4. nMaxMesh1_prof_edges : maximale Anzahl der Kanten in einem Profil.
  5. nMaxMesh1_prof_nodes : maximale Anzahl der Knoten auf einem Profil.
  6. Two : konstante Dimension ( = 2 ).

Lokale Koordinaten

Knoten

double Mesh1_node_x(nMesh1_node) ;

Mesh1_node_x:long_name = "x-Koordinate der Profilpunkte" ;
Mesh1_node_x:units = "m" ;
Mesh1_node_x:name_id = 1650 ;
Mesh1_node_x:standard_name = "projection_x_coordinate" ;

double Mesh1_node_y(nMesh1_node) ;

Mesh1_node_y:long_name = "y-Koordinate der Profilpunkte" ;
Mesh1_node_y:units = "m" ;
Mesh1_node_y:name_id = 1651 ;
Mesh1_node_y:standard_name = "projection_y_coordinate" ;

Hinweise:

  1. Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.

Kanten

double Mesh1_edge_x(nMesh1_edge) ;

Mesh1_edge_x:long_name = "x-Koordinate der Profilkanten, Kantenmitte" ;
Mesh1_edge_x:units = "m" ;
Mesh1_edge_x:name_id = 1650 ;
Mesh1_edge_x:bounds = "Mesh1_edge_x_bnd" ;
Mesh1_edge_x:standard_name = "projection_x_coordinate" ;

double Mesh1_edge_y(nMesh1_edge) ;

Mesh1_edge_y:long_name = "y-Koordinate der Profilkanten, Kantenmitte" ;
Mesh1_edge_y:units = "m" ;
Mesh1_edge_y:name_id = 1651 ;
Mesh1_edge_y:bounds = "Mesh1_edge_y_bnd" ;
Mesh1_edge_y:standard_name = "projection_y_coordinate" ;

Hinweise:

  1. Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.

(optional) Begrenzung für Kanten

double Mesh1_edge_x_bnd(nMesh1_edge,Two) ; \\ keine weiteren Metadaten erforderlich

double Mesh1_edge_y_bnd(nMesh1_edge,Two) ; \\ keine weiteren Metadaten erforderlich

Geografische Koordinaten

Knoten

double Mesh1_node_lon(nMesh1_node) ;

Mesh1_node_lon:long_name = "geografische Laenge der Profilpunkte" ;
Mesh1_node_lon:units = "degrees_east" ;
Mesh1_node_lon:name_id = 1653 ;
Mesh1_node_lon:standard_name = "longitude" ;

double Mesh1_node_lat(nMesh1_node) ;

Mesh1_node_lat:long_name = "geografische Breite der Profilpunkte" ;
Mesh1_node_lat:units = "degrees_north" ;
Mesh1_node_lat:name_id = 1652 ;
Mesh1_node_lat:standard_name = "latitude" ;

Hinweise: Wie für Lokale Koordinaten - Knoten.

Kanten

double Mesh1_edge_lon(nMesh1_edge) ;

Mesh1_edge_lon:long_name = "geografische Laenge der Profilkanten, Kantenmitte" ;
Mesh1_edge_lon:units = "degrees_east" ;
Mesh1_edge_lon:name_id = 1653 ;
Mesh1_edge_lon:bounds = "Mesh1_edge_lon_bnd" ;
Mesh1_edge_lon:standard_name = "longitude" ;

double Mesh1_edge_lat(nMesh1_edge) ;

Mesh1_edge_lat:long_name = "geografische Breite der Profilkanten, Kantenmitte" ;
Mesh1_edge_lat:units = "degrees_north" ;
Mesh1_edge_lat:name_id = 1652 ;
Mesh1_edge_lat:bounds = "Mesh1_edge_lat_bnd" ;
Mesh1_edge_lat:standard_name = "latitude" ;

Hinweise: Wie für Lokale Koordinaten - Kanten.

(optional) Begrenzung für Kanten

double Mesh1_edge_lon_bnd(nMesh1_edge,Two) ; \\ keine weiteren Metadaten erforderlich

double Mesh1_edge_lat_bnd(nMesh1_edge,Two) ; \\ keine weiteren Metadaten erforderlich

Topologische Daten

Knotenverzeichnis der Kanten

int Mesh1_edge_nodes(nMesh1_edge, two) ;

Mesh1_edge_nodes:long_name = "Knotenverzeichnis der Profilkanten, Anfangs- und Endpunkt" ;
Mesh1_edge_nodes:cf_role = "edge_node_connectivity" ;
Mesh1_edge_nodes:start_index = 0 ;

Hinweise:

  1. Ist Teil der Struktur "geo_profile_segment" in Paket P_GRID.

Namensverzeichnis der Profile

char Mesh1_prof_long_name(nMesh1_prof, nMesh1_strlen1) ;

Mesh1_prof_long_name:long_name = "Name des Profils" ;

Hinweise:

  1. Steht als labeled coordinate variable für den Zugriff auf die einzelnen Profile zur Verfügung.
  2. Ist Teil der Struktur "geo_profile" in Paket P_GRID.

Kantenverzeichnis der Profile

int Mesh1_prof_edges(nMesh1_prof, nMaxMesh1_prof_edges) ;

Mesh1_prof_edges:long_name = "Kantenverzeichnis der Profile, vom Anfang zum Ende sortiert" ;
Mesh1_prof_edges:cf_role = "prof_edge_connectivity" ;
Mesh1_prof_edges:_FillValue = -999 ;
Mesh1_prof_edges:start_index = 0 ;

Hinweise:

  1. Kann dazu genutzt werden, mehrere zusammenhängende Profile, z. B. Längs- und Querprofile, zu deklarieren.
  2. Einzelne Kanten dürfen mehrfach in (verschiedenen) Listen auftauchen.
  3. Bei stark unterschiedlichen Profillängen ggf. NetCDF Kompression von Daten durch Aufsammeln nutzen.
  4. Ist Teil der Struktur "geo_profile_segment" in Paket P_GRID. Die laufende Nummer des Segments, wie auch die Verweise auf die benachbarten Segmente werden nicht nach NetCDF geschrieben. Diese Informationen müssen nach dem Lesen dynamisch ermittelt werden.

Knotenverzeichnis der Profile

int Mesh1_prof_nodes(nMesh1_prof, nMaxMesh1_prof_nodes) ;

Mesh1_prof_nodes:long_name = "Knotenverzeichnis der Profile, vom Anfang zum Ende sortiert" ;
Mesh1_prof_nodes:_FillValue = -999 ;
Mesh1_prof_nodes:comment = "Indizes starten mit Null!" ;

Hinweise:

  1. Indizes starten mit Null!
  2. Ein Standardname sollte gelegentlich ergänzt werden.
  3. Kann dazu genutzt werden, mehrere zusammenhängende Profile, z. B. Längs- und Querprofile, zu deklarieren.
  4. Bei stark unterschiedlichen Profillängen ggf. NetCDF Kompression von Daten durch Aufsammeln nutzen.

Topologievariable

int Mesh1 ;

Mesh1:long_name = "Profil-Gitternetz, kein SubGrid" ;
Mesh1:dimensionality = 1 ;
Mesh1:locations = "node edge prof" ;
Mesh1:node_coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1:edge_coordinates = "Mesh1_edge_x Mesh1_edge_y Mesh1_edge_lon Mesh1_edge_lat" ;
Mesh1:prof_coordinates = "Mesh1_prof_long_name" ;
Mesh1:prof_node_connectivity = "Mesh1_prof_nodes" ;
Mesh1:prof_edge_connectivity = "Mesh1_prof_edges" ;
Mesh1:edge_node_connectivity = "Mesh1_edge_nodes" ;

Hinweise:

  1. Ein Standardname sollte gelegentlich ergänzt werden.
  2. Die orange markierten Bezeichnungen stellen Abweichungen bzw. Ergänzungen zu den Deltares-CF-Erweiterungen dar.
  3. Profil prof als zusätzliche Lokation erforderlich, um die Konnektivitätsliste für die verschiedenen Profile in der bestehenden Systematik für die Namensgebung der Attribute ausdrücken zu können.

Koordinatentransformation

Siehe unter NetCDF Grid Mapping Variable.

Anmerkungen, Fragen


zurück zu NetCDF


Strukturübersicht