Aktionen

NetCDF Synoptische Daten auf Profilen: Unterschied zwischen den Versionen

Aus BAWiki

imported>Lang Guenther
(→‎Name der Systemdatei: Text aktualisiert)
(Die LinkTitles-Erweiterung hat automatisch Links zu anderen Seiten hinzugefügt (<a target="_blank" rel="nofollow noreferrer noopener" class="external free" href="https://github.com/bovender/LinkTitles">https://github.com/bovender/LinkTitles</a>).)
 
(33 dazwischenliegende Versionen von 5 Benutzern werden nicht angezeigt)
Zeile 9: Zeile 9:
* [[NetCDF Vertikalkoordinate]]: zeit- und ortsvariable Vertikalkoordinate.
* [[NetCDF Vertikalkoordinate]]: zeit- und ortsvariable Vertikalkoordinate.


=Dimensionen=
=Version ''Discrete Sampling Geometry'' '''trajectoryProfile'''=


# '''nMesh1_node''' = Anzahl der Knoten.
Zur Ablage von Daten auf einem oder mehreren Profilen wird die in CF beschriebene ''Discrete Sampling Geometry'' mit '''featureType=trajectoryProfile''' verwendet. Ein Beispiel (NCDUMP) für Geometrie und Daten ist in  [[Medium:P_synop_ncdump_2D.pdf|P_synop_ncdump_2D.pdf]] zu sehen.
# '''nMesh1_edge''' = Anzahl der Kanten.
 
Daten dieses Typs stimmem im Wesentlichen mit [[NetCDF Synoptische Daten an Einzelpositionen]] überein. Auf die wesentlichen Unterschiede, die allen geophysikalischen Variablen gemein sind, wird am Beispiel der Variable für den [[Wasserstand]] eingegangen.
 
float Mesh0_node_[[Wasserstand]]_2d(nMesh0_data_time, nMesh0_trajectory, nMaxMesh0_trajectory_nodes) ;
: :long_name = "[[Wasserstand]] [ node ]" ;
: :units = "m" ;
: :name_id = 3 ;
: :_FillValue = 1.e+31f ;
: :ancillary_variables = "Mesh0_node_Gesamtwassertiefe_2d" ;
: :cell_measures = "area: Mesh0_node_Wasserflaeche_2d" ;
: :cell_methods = "nMesh0_data_time: point area: mean" ;
: :comment = "ancillary variables may be used for visualization and data analysis as threshold and plot subgrid mask" ;
: :coordinates = "Mesh0_node_lon Mesh0_node_lat Mesh0_node_x Mesh0_node_y Mesh0_trajectory_long_name Mesh0_trajectory_node_distance" ;
: :grid_mapping = "Mesh0_crs" ;
: :standard_name = "sea_surface_height" ;
 
Die wesentlichen Unterschiede zu der entsprechenden Variablen für Einzelpositionen sind:
# Es sind zwei an Stelle einer (Horizontal-) Dimension vorhanden: ''nMesh0_trajectory'' für die Anzahl der Profile und ''nMaxMesh0_trajectory_nodes'' für die (maximale) Anzahl der Positionen entlang eines Profils. Hierdurch kann auf die Daten eines Profils sehr einfach zugegriffen werden.
# Es existiert eine weitere Hilfs-Koordinatenvariable '''Mesh0_trajectory_node_distance'''. Diese ermöglicht die einfache Auftragung der Daten eines Profils in Abhängigkeit von der Koordinate Profil-Meter.
 
=Version [[DATACONVERT]]=
 
==Dimensionen==
 
# '''nMesh1_node''' = Anzahl der Profilknoten.
# '''nMesh1_data_node''' = Anzahl der Profilknoten mit Daten.
# '''nMesh1_edge''' = Anzahl der Profilkanten.
# '''nMesh1_prof''' = Anzahl der Profile.
# '''nMesh1_prof''' = Anzahl der Profile.
# '''nMesh1_strlen0''' = max. Anzahl der Zeichen für Dateinamen.
# '''nMesh1_strlen0''' = max. Anzahl der Zeichen für Dateinamen.
Zeile 22: Zeile 48:
# '''nMesh1_layer_2d''' = Anzahl der Schichten für tiefengemittelte Daten.
# '''nMesh1_layer_2d''' = Anzahl der Schichten für tiefengemittelte Daten.
# '''nMesh1_layer_3d''' = Anzahl der Schichten für tiefenstrukturierte Daten.
# '''nMesh1_layer_3d''' = Anzahl der Schichten für tiefenstrukturierte Daten.
# '''nMesh1_sys''' = Anzahl der Systemdatei-Informationen.
# '''nMaxMesh1_prof_edges''' = maximale Anzahl der Kanten eines Profils.
# '''nMaxMesh1_prof_edges''' = maximale Anzahl der Kanten eines Profils.
# '''nMaxMesh1_prof_nodes''' = maximale Anzahl der Knoten eines Profils.
# '''nMaxMesh1_prof_nodes''' = maximale Anzahl der Knoten eines Profils.
# '''nMaxMesh1_node_ip''' = maximale Anzahl der Interpolationsinformationen an Knoten.


=Geo-Positionen=
==Geo-Positionen==


Obwohl die Anzahl der Geopositionen in der Regel sehr viel kleiner als die Anzahl der
Obwohl die Anzahl der Geopositionen in der Regel sehr viel kleiner als die Anzahl der Knoten (aller Profile) ist, werden die nachfolgenden Felder ohne komprimierte Dimension deklariert, um Probleme beim Verwenden komprimierter Variablen auszuschließen.
Knoten (aller Profile) ist, werden die nachfolgenden Felder ohne komprimierte
Dimension deklariert, um Probleme beim Verwenden komprimierter Variablen auszuschließen.


Längerfristig könnte ggf. die Dimension "nMesh1_node" durch "nMesh1_geopos" ersetzt werden.
===Langer Name===
 
==Langer Name==
char Mesh1_node_gp_long_name(nMesh1_node, nMesh1_strlen1) ;  
char Mesh1_node_gp_long_name(nMesh1_node, nMesh1_strlen1) ;  
: Mesh1_node_gp_long_name:long_name = "Name der Geoposition eines Profilknotens" ;  
: Mesh1_node_gp_long_name:long_name = "Name der Geoposition" ;  
: Mesh1_node_gp_long_name:name_id = 1395 ;
: Mesh1_node_gp_long_name:name_id = 1395 ;
: Mesh1_node_gp_long_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;  
: Mesh1_node_gp_long_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
: Mesh1_node_gp_long_name:_FillValue = "?" ;  
: Mesh1_node_gp_long_name:_FillValue = "?" ;  
: Mesh1_node_gp_long_name:location = "node" ;  
: Mesh1_node_gp_long_name:location = "node" ;
: Mesh1_node_gp_long_name:mesh = "Mesh1" ;  
: Mesh1_node_gp_long_name:mesh = "Mesh1" ;  
: Mesh1_node_gp_long_name:grid_mapping = "Mesh1_crs" ;  
: Mesh1_node_gp_long_name:grid_mapping = "Mesh1_crs" ;  
Hinweise:
Hinweise:
# Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
# Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-[[Kennung]] der Variablen.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.
# Diese Variable soll nicht als Koordinatenvariable verwendet werden, daher kann das Attribut "_FillValue" verwendet werden.
# Diese Variable soll nicht als Koordinatenvariable verwendet werden, daher kann das Attribut "_FillValue" verwendet werden.  


==Code-Name==
===Code-Name===
char Mesh1_node_gp_code_name(nMesh1_node, nMesh1_strlen2) ;  
char Mesh1_node_gp_code_name(nMesh1_node, nMesh1_strlen2) ;  
: Mesh1_node_gp_code_name:long_name = "Kennung der Geoposition eines Profilknotens" ;  
: Mesh1_node_gp_code_name:long_name = "[[Kennung]] der Geoposition" ;  
: Mesh1_node_gp_code_name:name_id = 1394 ;  
: Mesh1_node_gp_code_name:name_id = 1394 ;  
: Mesh1_node_gp_code_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;  
: Mesh1_node_gp_code_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;  
: Mesh1_node_gp_code_name:_FillValue = "?" ;  
: Mesh1_node_gp_code_name:_FillValue = "?" ;  
: Mesh1_node_gp_code_name:location = "node" ;  
: Mesh1_node_gp_code_name:location = "node" ;
: Mesh1_node_gp_code_name:mesh = "Mesh1" ;  
: Mesh1_node_gp_code_name:mesh = "Mesh1" ;  
: Mesh1_node_gp_code_name:grid_mapping = "Mesh1_crs" ;
: Mesh1_node_gp_code_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
Hinweise:
# Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
# Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-[[Kennung]] der Variablen.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.


==Kurzer Name==
===Kurzer Name===
char Mesh1_node_gp_short_name(nMesh1_node, nMesh1_strlen3) ;  
char Mesh1_node_gp_short_name(nMesh1_node, nMesh1_strlen3) ;  
: Mesh1_node_gp_short_name:long_name = "Kuerzel der Geoposition eines Profilknotens" ;  
: Mesh1_node_gp_short_name:long_name = "Kuerzel der Geoposition" ;  
: Mesh1_node_gp_short_name:name_id = 1396 ;  
: Mesh1_node_gp_short_name:name_id = 1396 ;  
: Mesh1_node_gp_short_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;  
: Mesh1_node_gp_short_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;  
: Mesh1_node_gp_short_name:_FillValue = "?" ;  
: Mesh1_node_gp_short_name:_FillValue = "?" ;  
: Mesh1_node_gp_short_name:location = "node" ;  
: Mesh1_node_gp_short_name:location = "node" ;
: Mesh1_node_gp_short_name:mesh = "Mesh1" ;  
: Mesh1_node_gp_short_name:mesh = "Mesh1" ;  
: Mesh1_node_gp_short_name:grid_mapping = "Mesh1_crs" ;
: Mesh1_node_gp_short_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
Hinweise:
# Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
# Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-[[Kennung]] der Variablen.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.


==Geopositions-Identifikationsnummer==
===Geopositions-Identifikationsnummer===
int Mesh1_node_gp_id(nMesh1_node, nMesh1_strlen3) ;  
int Mesh1_node_gp_id(nMesh1_node) ;  
: Mesh1_node_gp_id:long_name = "Identifikationsnummer der Geoposition eines Profilknotens" ;  
: Mesh1_node_gp_id:long_name = "Identifikationsnummer der Geoposition eines Profilknotens" ;  
: Mesh1_node_gp_id:name_id = -999 ;  
: Mesh1_node_gp_id:name_id = -999 ;  
Zeile 82: Zeile 102:
: Mesh1_node_gp_id:valid_range = 1, 100000 ;  
: Mesh1_node_gp_id:valid_range = 1, 100000 ;  
: Mesh1_node_gp_id:_FillValue = -999 ;  
: Mesh1_node_gp_id:_FillValue = -999 ;  
: Mesh1_node_gp_id:location = "node" ;  
: Mesh1_node_gp_id:location = "node" ;
: Mesh1_node_gp_id:mesh = "Mesh1" ;  
: Mesh1_node_gp_id:mesh = "Mesh1" ;  
: Mesh1_node_gp_id:grid_mapping = "Mesh1_crs" ;  
: Mesh1_node_gp_id:grid_mapping = "Mesh1_crs" ;  
Hinweise:
Hinweise:
# Für das Attribut "name_id" liegt noch keine (BAW) PHYDEF-Code-Kennung vor.
# Für das Attribut "name_id" liegt noch keine (BAW) PHYDEF-Code-[[Kennung]] vor.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.
# Für die meisten Knoten liegt keine gültige Bezeichnung vor.


=Geo-Profile=
==Geo-Profile==
Eine Datei wird i. d. R. mehrere Profile enthalten, die durch ein entsprechendes [[NetCDF Profile#Kantenverzeichnis der Profile|Kantenverzeichnis der Profile]] beschrieben werden.
Eine Datei wird i. d. R. mehrere Profile enthalten, die durch ein entsprechendes
 
[[NetCDF Profile#Kantenverzeichnis der Profile|Kantenverzeichnis der Profile]] beschrieben werden.<br>
==Langer Name==
Die Variable mit dem [[NetCDF Profile#Namensverzeichnis der Profile|Namensverzeichnis der Profile]]
char Mesh1_prof_long_name(nMesh1_prof, nMesh1_strlen1) ;
übernimmt die Rolle einer Koordinatenvariable und erlaubt es die Profile über ihren langen Namen zu identifizieren.
: Mesh1_prof_long_name:long_name = "Name des Profils" ;
: Mesh1_prof_long_name:name_id = -999 ;
===Code-Name===
: Mesh1_prof_long_name:coordinates = "Mesh1_prof_x Mesh1_prof_y Mesh1_prof_lon Mesh1_prof_lat" ;
: Mesh1_prof_long_name:_FillValue = "?" ;
: Mesh1_prof_long_name:location = "prof" ;
: Mesh1_prof_long_name:mesh = "Mesh1" ;
: Mesh1_prof_long_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
# Soll diese Variable als Koordinatenvariable verwendet werden, dann müssen die auf "name_id" folgenden Attribute entfernt werden.
 
==Code-Name==
char Mesh1_prof_code_name(nMesh1_prof, nMesh1_strlen2) ;  
char Mesh1_prof_code_name(nMesh1_prof, nMesh1_strlen2) ;  
: Mesh1_prof_code_name:long_name = "Kennung eines Profils" ;  
: Mesh1_prof_code_name:long_name = "[[Kennung]] eines Profils" ;  
: Mesh1_prof_code_name:name_id = -999 ;  
: Mesh1_prof_code_name:name_id = -999 ;  
: Mesh1_prof_code_name:coordinates = "Mesh1_prof_x Mesh1_prof_y Mesh1_prof_lon Mesh1_prof_lat" ;  
: Mesh1_prof_code_name:coordinates = "Mesh1_prof_long_name" ;  
: Mesh1_prof_code_name:_FillValue = "?" ;  
: Mesh1_prof_code_name:_FillValue = "?" ;  
: Mesh1_prof_code_name:location = "prof" ;  
: Mesh1_prof_code_name:location = "prof" ;  
Zeile 115: Zeile 125:
: Mesh1_prof_code_name:grid_mapping = "Mesh1_crs" ;
: Mesh1_prof_code_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
Hinweise:
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-[[Kennung]].


==Kurzer Name==
===Kurzer Name===
char Mesh1_prof_short_name(nMesh1_prof, nMesh1_strlen3) ;  
char Mesh1_prof_short_name(nMesh1_prof, nMesh1_strlen3) ;  
: Mesh1_prof_short_name:long_name = "Kuerzel eines Profils" ;  
: Mesh1_prof_short_name:long_name = "Kuerzel eines Profils" ;  
: Mesh1_prof_short_name:name_id = -999 ;  
: Mesh1_prof_short_name:name_id = -999 ;  
: Mesh1_prof_short_name:coordinates = "Mesh1_prof_x Mesh1_prof_y Mesh1_prof_lon Mesh1_prof_lat" ;  
: Mesh1_prof_short_name:coordinates = "Mesh1_prof_long_name" ;  
: Mesh1_prof_short_name:_FillValue = "?" ;  
: Mesh1_prof_short_name:_FillValue = "?" ;  
: Mesh1_prof_short_name:location = "prof" ;  
: Mesh1_prof_short_name:location = "prof" ;  
Zeile 127: Zeile 137:
: Mesh1_prof_short_name:grid_mapping = "Mesh1_crs" ;
: Mesh1_prof_short_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
Hinweise:
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-[[Kennung]].


==Profil-Identifikationsnummer==
===Profil-Identifikationsnummer===
int Mesh1_prof_id(nMesh1_prof, nMesh1_strlen3) ;  
int Mesh1_prof_id(nMesh1_prof) ;  
: Mesh1_prof_id:long_name = "Identifikationsnummer eines Profils" ;  
: Mesh1_prof_id:long_name = "Identifikationsnummer eines Profils" ;  
: Mesh1_prof_id:name_id = -999 ;  
: Mesh1_prof_id:name_id = -999 ;  
: Mesh1_prof_id:coordinates = "Mesh1_prof_x Mesh1_prof_y Mesh1_prof_lon Mesh1_prof_lat" ;  
: Mesh1_prof_id:coordinates = "Mesh1_prof_long_name" ;  
: Mesh1_prof_id:valid_range = 1, 100000 ;  
: Mesh1_prof_id:valid_range = 1, 100000 ;  
: Mesh1_prof_id:_FillValue = -999 ;  
: Mesh1_prof_id:_FillValue = -999 ;  
Zeile 141: Zeile 151:
Hinweise:
Hinweise:
# Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
# Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-[[Kennung]].


==Profiltyp==
===Profiltyp===
int Mesh1_prof_type(nMesh1_prof) ;  
int Mesh1_prof_type(nMesh1_prof) ;  
: Mesh1_prof_type:long_name = "Typ des Profils" ;  
: Mesh1_prof_type:long_name = "Typ des Profils" ;  
: Mesh1_prof_type:name_id = -999 ;  
: Mesh1_prof_type:name_id = -999 ;  
: Mesh1_prof_type:coordinates = "Mesh1_prof_x Mesh1_prof_y Mesh1_prof_lon Mesh1_prof_lat" ;  
: Mesh1_prof_type:coordinates = "Mesh1_prof_long_name" ;  
: Mesh1_prof_type:valid_range = 0, 1 ;  
: Mesh1_prof_type:valid_range = 0, 1 ;  
: Mesh1_prof_type:_FillValue = -999 ;  
: Mesh1_prof_type:_FillValue = -999 ;  
Zeile 158: Zeile 168:
# Gültige Indizes beginnen hier mit Null!
# Gültige Indizes beginnen hier mit Null!
# Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
# Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-[[Kennung]].
# Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.
# Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.


=Marker=
==Marker==


==Markertyp==
===Markertyp===
int Mesh1_node_marker_type(nMesh1_node) ;  
int Mesh1_node_marker_type(nMesh1_node) ;  
: Mesh1_node_marker_type:long_name = "Marker-Information der Profilknoten" ;  
: Mesh1_node_marker_type:long_name = "Marker-Information der Profilknoten" ;  
Zeile 179: Zeile 189:
# Die fehlenden Komponenten der Struktur "geo_marker" (in P_GRID) müssen beim Lesen dynamisch ergänzt werden.
# Die fehlenden Komponenten der Struktur "geo_marker" (in P_GRID) müssen beim Lesen dynamisch ergänzt werden.
# Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
# Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-[[Kennung]].
# Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.
# Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.
# Alle Knoten müssen über gültige Informationen verfügen.
# Alle Knoten müssen über gültige Informationen verfügen.


=Systemdatei-Informationen=
==Daten an Knoten==
==Name der Systemdatei==
===Profilmeter===
char Mesh1_sys_file_name(nMesh1_sys, nMesh1_strlen0) ;
double Mesh1_prof_node_distance(nMesh1_prof,nMesh1_node) ;
: Mesh1_sys_file_name:long_name = "Name der Systemdatei" ;
: Mesh1_prof_node_distance:long_name = "Profilmeter - Abstand zum Profilanfang" ;
: Mesh1_sys_file_name:name_id = -999 ;
: Mesh1_prof_node_distance:units = "m" ;
: Mesh1_sys_file_name:_FillValue = "?" ;
: Mesh1_prof_node_distance:name_id = -999 ;
: Mesh1_sys_file_name:mesh = "Mesh1" ;
: Mesh1_prof_node_distance:valid_range = 0.0, 1000000.0 ;
Hinweise:
: Mesh1_prof_node_distance:_FillValue = 1.e+31 ;  
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
: Mesh1_prof_node_distance:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
 
: Mesh1_prof_node_distance:grid_mapping = "Mesh1_crs" ;
==Code-Name der Systemdatei==
: Mesh1_prof_node_distance:standard_name = "???" ;
char Mesh1_sys_code_name(nMesh1_sys, nMesh1_strlen2) ;
: Mesh1_prof_node_distance:comment = "distance along profile, with respect to origin of profile" ;
: Mesh1_sys_code_name:long_name = "Kennung Systemdatei" ;
: Mesh1_sys_code_name:name_id = ???? ;
: Mesh1_sys_code_name:_FillValue = "''fillvalue''" ;
 
==Identifikationsnummer der Systemdatei==
int Mesh1_sys_id(nMesh1_sys) ;
: Mesh1_sys_id:long_name = "Identifikationsnummer Systemdatei" ;
: Mesh1_sys_id:name_id = ???? ;
: Mesh1_sys_id:valid_range = "''valid minimum'', ''valid maximum''" ;
: Mesh1_sys_id:_FillValue = "-999" ;
 
==Anzahl der Knoten der Systemdatei==
int Mesh1_sys_nv(nMesh1_sys) ;
: Mesh1_sys_nv:long_name = "Anzahl Knoten Systemdatei" ;
: Mesh1_sys_nv:name_id = ???? ;
: Mesh1_sys_nv:valid_range = "''valid minimum'', ''valid maximum''" ;
: Mesh1_sys_nv:_FillValue = "-999" ;
 
==Anzahl der Polygone der Systemdatei==
int Mesh1_sys_ne(nMesh1_sys) ;
: Mesh1_sys_ne:long_name = "Anzahl Polygone Systemdatei" ;
: Mesh1_sys_ne:name_id = ???? ;
: Mesh1_sys_ne:valid_range = "''valid minimum'', ''valid maximum''" ;
: Mesh1_sys_ne:_FillValue = "-999" ;
 
==System-Identifikationsnummer der Knoten==
int Mesh1_node_sys_id(nMesh1_node) ;
: Mesh1_node_sys_type:standard_name = "'''???'''" ;  
: Mesh1_node_sys_type:long_name = "System-Identifikationsnummer Knoten" ;
: Mesh1_node_sys_long_name:name_id = ???? ;
: Mesh1_node_sys_type:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
: Mesh1_node_sys_type:valid_range = "''valid minimum'', ''valid maximum''" ;
: Mesh1_node_sys_type:_FillValue = "-999" ;
: Mesh1_node_sys_type:location = "node" ;
: Mesh1_node_sys_type:mesh = "Mesh1" ;
: Mesh1_node_sys_type:grid_mapping = "Mesh1_crs" ;
 
=Interpolations-Informationen=
==Interpolationsfaktoren==
double Mesh1_node_ip_factor(nMesh1_node,nMesh1_node_ip) ;
: Mesh1_node_ip_factor:standard_name = "'''???'''" ; 
: Mesh1_node_ip_factor:long_name = "Interpolationsfaktoren Knoten" ;
: Mesh1_node_ip_factor:name_id = ???? ;
: Mesh1_node_ip_factor:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
: Mesh1_node_ip_factor:valid_range = "''valid minimum'', ''valid maximum''" ;
: Mesh1_node_ip_factor:_FillValue = "''fillvalue''" ;
: Mesh1_node_ip_factor:location = "node" ;
: Mesh1_node_ip_factor:mesh = "Mesh1" ;
: Mesh1_node_ip_factor:grid_mapping = "Mesh1_crs" ;
Hinweise:
Hinweise:
# An Positionen ohne Daten wird derzeit 0.0 verwendet.
# Da ein Knoten zu mehreren Profilen gehören kann, muss dieser Wert für alle Profile angegeben werden.
 
# Kann (als Koordinate) zur Darstellung von Daten entlang von Profilen benutzt werden.
==Tiefen der Interpolationspunkte==
# Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-[[Kennung]].
double Mesh1_node_ip_depth(nMesh1_node,nMesh1_node_ip) ;
: Mesh1_node_ip_depth:standard_name = "'''sea_floor_depth_below_geoid'''" ; 
: Mesh1_node_ip_depth:long_name = "Interpolationstiefen Knoten" ;
: Mesh1_node_ip_depth:name_id = 17 ;
: Mesh1_node_ip_depth:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
: Mesh1_node_ip_depth:valid_range = "''valid minimum'', ''valid maximum''" ;
: Mesh1_node_ip_depth:_FillValue = "''fillvalue''" ;
: Mesh1_node_ip_depth:location = "node" ;
: Mesh1_node_ip_depth:mesh = "Mesh1" ;
: Mesh1_node_ip_depth:grid_mapping = "Mesh1_crs" ;
Hinweise:
# An Positionen ohne Daten wird derzeit -10001.0 verwendet.
 
=Daten an Knoten=


===Sonstige===
Hinweise:
Hinweise:
# Es kann analog zu [[NetCDF Synoptische Daten an Einzelpositionen]] vorgegangen werden:
# Es kann analog zu [[NetCDF Synoptische Daten an Einzelpositionen]] vorgegangen werden:
Zeile 268: Zeile 216:
#* [[NetCDF Synoptische Daten an Einzelpositionen#Zeitkoordinaten|Zeitkoordinaten]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Zeitkoordinaten|Zeitkoordinaten]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Vertikalkoordinaten|Vertikalkoordinaten]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Vertikalkoordinaten|Vertikalkoordinaten]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Aktuelle (zeitvariable) Topografie|Topografie]] (an Positionen ohne Daten wird derzeit -10001.0 verwendet),
#* [[NetCDF Synoptische Daten an Einzelpositionen#Aktuelle (zeitvariable) Topografie|Topografie]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Maximale zulässige Tiefe|maximale zulässige Tiefe]] (an Positionen ohne Daten wird derzeit -10001.0 verwendet),
#* [[NetCDF Synoptische Daten an Einzelpositionen#Maximale zulässige Tiefe|maximale zulässige Tiefe]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Wasserstand|Wasserstand]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Wasserstand|Wasserstand]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Tiefengemittelter Salzgehalt|Tiefengemittelter Salzgehalt]],
#* [[NetCDF Synoptische Daten an Einzelpositionen#Tiefengemittelter Salzgehalt|Tiefengemittelter Salzgehalt]],
Zeile 278: Zeile 226:
#* [[NetCDF Synoptische Daten an Einzelpositionen#Tiefengemittelter Schwebstoffgehalt|Tiefengemittelter Schwebstoffgehalt]], und
#* [[NetCDF Synoptische Daten an Einzelpositionen#Tiefengemittelter Schwebstoffgehalt|Tiefengemittelter Schwebstoffgehalt]], und
#* [[NetCDF Synoptische Daten an Einzelpositionen#Tiefenstrukturierter Schwebstoffgehalt|Tiefenstrukturierter Schwebstoffgehalt]].
#* [[NetCDF Synoptische Daten an Einzelpositionen#Tiefenstrukturierter Schwebstoffgehalt|Tiefenstrukturierter Schwebstoffgehalt]].
# Man beachte jedoch, dass nicht an allen Knoten Daten vorhanden sein müssen. An diesen Knoten sollen die entsprechenden "_FillValue" Werte zur Kennzeichnung ungültiger Daten benutzt werden. Da die Knoten sortiert sind - zuerst die Knoten mit Daten, danach diejenigen ohne - könnte dies beim Schreiben der Daten ggf. einfach realisiert werden.
# Um auf Daten einzelner Profile zugreifen zu können, kann (eine Label-Koordinate) "Mesh1_prof_long_name" nicht verwendet werden, da hierfür die Datenvariablen die Dimension nMesh1_prof enthalten müssten. Der Zugriff auf Daten einzelner Profile muss mit Hilfe der entsprechenden Konnektivitätslisten umgesetzt werden.
# Um auf Daten einzelner Profile zugreifen zu können, muss die Variable "Mesh1_prof_long_name" ggf. in dem Attribut "coordinates" mit aufgeführt werden. Ob das nach der CF Metadaten-Konvention zulässig ist, ist einstweilen nicht klar.
# Als einzig denkbare Alternative zu dem zuletzt genannten Punkt käme wahrscheinlich nur eine Zerlegung in einzelne Profile in Frage.


=Daten an Kanten=
==Daten an Kanten==


Hinweise:
Hinweise:
# Bislang liegen keine Daten an Kanten vor. Dies wird sich wahrscheinlich mit Übergang zur SubGrid Technologie ändern.
# Bislang liegen keine Daten an Kanten vor. Dies wird sich wahrscheinlich mit Übergang zur SubGrid Technologie ändern.


=Anmerkungen, Fragen=
==Anmerkungen, Fragen==
Text muss noch ergänzt werden.
* Datei ist CF-konform gemäß [http://puma.nerc.ac.uk/cgi-bin/cf-checker.pl NCAS ''CF Compliance Checker''].
----
----
zurück zu [[NetCDF]]
zurück zu [[NetCDF]]
----
----
[[Strukturübersicht]]
[[Strukturübersicht]]

Aktuelle Version vom 21. Oktober 2022, 09:29 Uhr

Kurze Beschreibung

Synoptische Daten auf mehreren Längs- und Querprofilen.

Weitere Beschreibungen

Version Discrete Sampling Geometry trajectoryProfile

Zur Ablage von Daten auf einem oder mehreren Profilen wird die in CF beschriebene Discrete Sampling Geometry mit featureType=trajectoryProfile verwendet. Ein Beispiel (NCDUMP) für Geometrie und Daten ist in P_synop_ncdump_2D.pdf zu sehen.

Daten dieses Typs stimmem im Wesentlichen mit NetCDF Synoptische Daten an Einzelpositionen überein. Auf die wesentlichen Unterschiede, die allen geophysikalischen Variablen gemein sind, wird am Beispiel der Variable für den Wasserstand eingegangen.

float Mesh0_node_Wasserstand_2d(nMesh0_data_time, nMesh0_trajectory, nMaxMesh0_trajectory_nodes) ;

:long_name = "Wasserstand [ node ]" ;
:units = "m" ;
:name_id = 3 ;
:_FillValue = 1.e+31f ;
:ancillary_variables = "Mesh0_node_Gesamtwassertiefe_2d" ;
:cell_measures = "area: Mesh0_node_Wasserflaeche_2d" ;
:cell_methods = "nMesh0_data_time: point area: mean" ;
:comment = "ancillary variables may be used for visualization and data analysis as threshold and plot subgrid mask" ;
:coordinates = "Mesh0_node_lon Mesh0_node_lat Mesh0_node_x Mesh0_node_y Mesh0_trajectory_long_name Mesh0_trajectory_node_distance" ;
:grid_mapping = "Mesh0_crs" ;
:standard_name = "sea_surface_height" ;

Die wesentlichen Unterschiede zu der entsprechenden Variablen für Einzelpositionen sind:

  1. Es sind zwei an Stelle einer (Horizontal-) Dimension vorhanden: nMesh0_trajectory für die Anzahl der Profile und nMaxMesh0_trajectory_nodes für die (maximale) Anzahl der Positionen entlang eines Profils. Hierdurch kann auf die Daten eines Profils sehr einfach zugegriffen werden.
  2. Es existiert eine weitere Hilfs-Koordinatenvariable Mesh0_trajectory_node_distance. Diese ermöglicht die einfache Auftragung der Daten eines Profils in Abhängigkeit von der Koordinate Profil-Meter.

Version DATACONVERT

Dimensionen

  1. nMesh1_node = Anzahl der Profilknoten.
  2. nMesh1_data_node = Anzahl der Profilknoten mit Daten.
  3. nMesh1_edge = Anzahl der Profilkanten.
  4. nMesh1_prof = Anzahl der Profile.
  5. nMesh1_strlen0 = max. Anzahl der Zeichen für Dateinamen.
  6. nMesh1_strlen1 = max. Anzahl der Zeichen für lange Namen.
  7. nMesh1_strlen2 = max. Anzahl der Zeichen für Code-Bezeichnungen.
  8. nMesh1_strlen3 = max. Anzahl der Zeichen für Kurzbezeichnungen.
  9. nMesh1_time = Anzahl der Zeitpunkte (Gitterdatei).
  10. nMehs1_data_time = UNLIMITED-Dimension, Anzahl der synoptischen Datensätze.
  11. nMesh1_layer_2d = Anzahl der Schichten für tiefengemittelte Daten.
  12. nMesh1_layer_3d = Anzahl der Schichten für tiefenstrukturierte Daten.
  13. nMaxMesh1_prof_edges = maximale Anzahl der Kanten eines Profils.
  14. nMaxMesh1_prof_nodes = maximale Anzahl der Knoten eines Profils.

Geo-Positionen

Obwohl die Anzahl der Geopositionen in der Regel sehr viel kleiner als die Anzahl der Knoten (aller Profile) ist, werden die nachfolgenden Felder ohne komprimierte Dimension deklariert, um Probleme beim Verwenden komprimierter Variablen auszuschließen.

Langer Name

char Mesh1_node_gp_long_name(nMesh1_node, nMesh1_strlen1) ;

Mesh1_node_gp_long_name:long_name = "Name der Geoposition" ;
Mesh1_node_gp_long_name:name_id = 1395 ;
Mesh1_node_gp_long_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_gp_long_name:_FillValue = "?" ;
Mesh1_node_gp_long_name:location = "node" ;
Mesh1_node_gp_long_name:mesh = "Mesh1" ;
Mesh1_node_gp_long_name:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
  2. Für die meisten Knoten liegt keine gültige Bezeichnung vor.
  3. Diese Variable soll nicht als Koordinatenvariable verwendet werden, daher kann das Attribut "_FillValue" verwendet werden.

Code-Name

char Mesh1_node_gp_code_name(nMesh1_node, nMesh1_strlen2) ;

Mesh1_node_gp_code_name:long_name = "Kennung der Geoposition" ;
Mesh1_node_gp_code_name:name_id = 1394 ;
Mesh1_node_gp_code_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_gp_code_name:_FillValue = "?" ;
Mesh1_node_gp_code_name:location = "node" ;
Mesh1_node_gp_code_name:mesh = "Mesh1" ;
Mesh1_node_gp_code_name:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
  2. Für die meisten Knoten liegt keine gültige Bezeichnung vor.

Kurzer Name

char Mesh1_node_gp_short_name(nMesh1_node, nMesh1_strlen3) ;

Mesh1_node_gp_short_name:long_name = "Kuerzel der Geoposition" ;
Mesh1_node_gp_short_name:name_id = 1396 ;
Mesh1_node_gp_short_name:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_gp_short_name:_FillValue = "?" ;
Mesh1_node_gp_short_name:location = "node" ;
Mesh1_node_gp_short_name:mesh = "Mesh1" ;
Mesh1_node_gp_short_name:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
  2. Für die meisten Knoten liegt keine gültige Bezeichnung vor.

Geopositions-Identifikationsnummer

int Mesh1_node_gp_id(nMesh1_node) ;

Mesh1_node_gp_id:long_name = "Identifikationsnummer der Geoposition eines Profilknotens" ;
Mesh1_node_gp_id:name_id = -999 ;
Mesh1_node_gp_id:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_gp_id:valid_range = 1, 100000 ;
Mesh1_node_gp_id:_FillValue = -999 ;
Mesh1_node_gp_id:location = "node" ;
Mesh1_node_gp_id:mesh = "Mesh1" ;
Mesh1_node_gp_id:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Für das Attribut "name_id" liegt noch keine (BAW) PHYDEF-Code-Kennung vor.
  2. Für die meisten Knoten liegt keine gültige Bezeichnung vor.

Geo-Profile

Eine Datei wird i. d. R. mehrere Profile enthalten, die durch ein entsprechendes Kantenverzeichnis der Profile beschrieben werden.
Die Variable mit dem Namensverzeichnis der Profile übernimmt die Rolle einer Koordinatenvariable und erlaubt es die Profile über ihren langen Namen zu identifizieren.

Code-Name

char Mesh1_prof_code_name(nMesh1_prof, nMesh1_strlen2) ;

Mesh1_prof_code_name:long_name = "Kennung eines Profils" ;
Mesh1_prof_code_name:name_id = -999 ;
Mesh1_prof_code_name:coordinates = "Mesh1_prof_long_name" ;
Mesh1_prof_code_name:_FillValue = "?" ;
Mesh1_prof_code_name:location = "prof" ;
Mesh1_prof_code_name:mesh = "Mesh1" ;
Mesh1_prof_code_name:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.

Kurzer Name

char Mesh1_prof_short_name(nMesh1_prof, nMesh1_strlen3) ;

Mesh1_prof_short_name:long_name = "Kuerzel eines Profils" ;
Mesh1_prof_short_name:name_id = -999 ;
Mesh1_prof_short_name:coordinates = "Mesh1_prof_long_name" ;
Mesh1_prof_short_name:_FillValue = "?" ;
Mesh1_prof_short_name:location = "prof" ;
Mesh1_prof_short_name:mesh = "Mesh1" ;
Mesh1_prof_short_name:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.

Profil-Identifikationsnummer

int Mesh1_prof_id(nMesh1_prof) ;

Mesh1_prof_id:long_name = "Identifikationsnummer eines Profils" ;
Mesh1_prof_id:name_id = -999 ;
Mesh1_prof_id:coordinates = "Mesh1_prof_long_name" ;
Mesh1_prof_id:valid_range = 1, 100000 ;
Mesh1_prof_id:_FillValue = -999 ;
Mesh1_prof_id:location = "prof" ;
Mesh1_prof_id:mesh = "Mesh1" ;
Mesh1_prof_id:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
  2. Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.

Profiltyp

int Mesh1_prof_type(nMesh1_prof) ;

Mesh1_prof_type:long_name = "Typ des Profils" ;
Mesh1_prof_type:name_id = -999 ;
Mesh1_prof_type:coordinates = "Mesh1_prof_long_name" ;
Mesh1_prof_type:valid_range = 0, 1 ;
Mesh1_prof_type:_FillValue = -999 ;
Mesh1_prof_type:flag_values = 0, 1 ;
Mesh1_prof_type:flag_meanings = "longitudinal_profile cross_profile" ;
Mesh1_prof_type:location = "prof" ;
Mesh1_prof_type:mesh = "Mesh1" ;
Mesh1_prof_type:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Gültige Indizes beginnen hier mit Null!
  2. Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
  3. Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
  4. Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.

Marker

Markertyp

int Mesh1_node_marker_type(nMesh1_node) ;

Mesh1_node_marker_type:long_name = "Marker-Information der Profilknoten" ;
Mesh1_node_marker_type:name_id = -999 ;
Mesh1_node_marker_type:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_marker_type:valid_range = 0, 7 ;
Mesh1_node_marker_type:_FillValue = -999 ;
Mesh1_node_marker_type:flag_values = 0, 1, 2, 3, 4, 5, 6, 7 ;
Mesh1_node_marker_type:flag_meanings = "PolPuMitDaten PolPuOhnDaten ZwiPuMitDaten ZwiPuOhnDaten PolExMitDaten PolExOhnDaten ZwiExMitDaten ZwiExOhnDaten" ;
Mesh1_node_marker_type:location = "node" ;
Mesh1_node_marker_type:mesh = "Mesh1" ;
Mesh1_node_marker_type:grid_mapping = "Mesh1_crs" ;

Hinweise:

  1. Gültige Indizes beginnen hier mit Null!
  2. Die fehlenden Komponenten der Struktur "geo_marker" (in P_GRID) müssen beim Lesen dynamisch ergänzt werden.
  3. Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
  4. Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.
  5. Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.
  6. Alle Knoten müssen über gültige Informationen verfügen.

Daten an Knoten

Profilmeter

double Mesh1_prof_node_distance(nMesh1_prof,nMesh1_node) ;

Mesh1_prof_node_distance:long_name = "Profilmeter - Abstand zum Profilanfang" ;
Mesh1_prof_node_distance:units = "m" ;
Mesh1_prof_node_distance:name_id = -999 ;
Mesh1_prof_node_distance:valid_range = 0.0, 1000000.0 ;
Mesh1_prof_node_distance:_FillValue = 1.e+31 ;
Mesh1_prof_node_distance:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_prof_node_distance:grid_mapping = "Mesh1_crs" ;
Mesh1_prof_node_distance:standard_name = "???" ;
Mesh1_prof_node_distance:comment = "distance along profile, with respect to origin of profile" ;

Hinweise:

  1. Da ein Knoten zu mehreren Profilen gehören kann, muss dieser Wert für alle Profile angegeben werden.
  2. Kann (als Koordinate) zur Darstellung von Daten entlang von Profilen benutzt werden.
  3. Für das Attribut "name_id" gibt es noch keine gültige (BAW) PHYDEF-Code-Kennung.

Sonstige

Hinweise:

  1. Es kann analog zu NetCDF Synoptische Daten an Einzelpositionen vorgegangen werden:
  2. Um auf Daten einzelner Profile zugreifen zu können, kann (eine Label-Koordinate) "Mesh1_prof_long_name" nicht verwendet werden, da hierfür die Datenvariablen die Dimension nMesh1_prof enthalten müssten. Der Zugriff auf Daten einzelner Profile muss mit Hilfe der entsprechenden Konnektivitätslisten umgesetzt werden.

Daten an Kanten

Hinweise:

  1. Bislang liegen keine Daten an Kanten vor. Dies wird sich wahrscheinlich mit Übergang zur SubGrid Technologie ändern.

Anmerkungen, Fragen


zurück zu NetCDF


Strukturübersicht