NetCDF Synoptische Daten auf Profilen: Unterschied zwischen den Versionen
Aus BAWiki
imported>Lang Guenther |
imported>Lang Guenther |
||
Zeile 253: | Zeile 253: | ||
#* [[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 ( | #* [[NetCDF Synoptische Daten an Einzelpositionen#Aktuelle (zeitvariable) Topografie|Topografie]], | ||
#* [[NetCDF Synoptische Daten an Einzelpositionen#Maximale zulässige Tiefe|maximale zulässige Tiefe]], | #* [[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]], |
Version vom 19. April 2011, 16:03 Uhr
Kurze Beschreibung
Synoptische Daten auf mehreren Längs- und Querprofilen.
Die nachfolgende Beschreibung ist noch unvollständig. So fehlen z. B. noch die Bezeichnungen für Marker.
Weitere Beschreibungen
- NetCDF Profile: Koordinaten, Topologie sowie Koordinatentransformation der Profile.
- NetCDF Zeitkoordinate: Koordinatenvariable time.
- NetCDF Vertikalkoordinate: zeit- und ortsvariable Vertikalkoordinate.
Dimensionen
- nMesh1_node = Anzahl der Knoten.
- nMesh1_edge = Anzahl der Kanten.
- nMesh1_prof = Anzahl der Profile.
- nMesh1_strlen0 = max. Anzahl der Zeichen für Dateinamen.
- nMesh1_strlen1 = max. Anzahl der Zeichen für lange Namen.
- nMesh1_strlen2 = max. Anzahl der Zeichen für Code-Bezeichnungen.
- nMesh1_strlen3 = max. Anzahl der Zeichen für Kurzbezeichnungen.
- nMesh1_time = Anzahl der Zeitpunkte (Gitterdatei).
- nMehs1_data_time = UNLIMITED-Dimension, Anzahl der synoptischen Datensätze.
- nMesh1_layer_2d = Anzahl der Schichten für tiefengemittelte 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_node_ip = maximale Anzahl der Interpolationsinformationen an Knoten.
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 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 = "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:
- Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
- Für die meisten Knoten liegt keine gültige Bezeichnung vor.
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 = "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:
- Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
- 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 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 = "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:
- Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
- Für die meisten Knoten liegt keine gültige Bezeichnung vor.
Geopositions-Identifikationsnummer
char Mesh1_node_gp_id(nMesh1_node, nMesh1_strlen3) ;
- Mesh1_node_gp_id_name:long_name = "Identifikationsnummer Geoposition" ;
- Mesh1_node_gp_id:name_id = ???? ;
- Mesh1_node_gp_id:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
- Mesh1_node_gp_id:valid_range = "valid minimum, valid maximum" ;
- Mesh1_node_gp_id:_FillValue = "fillvalue ;
- Mesh1_node_gp_id:location = "node" ;
- Mesh1_node_gp_id:mesh = "Mesh1" ;
- Mesh1_node_gp_id:grid_mapping = "Mesh1_crs" ;
Hinweise:
- Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
- Für die meisten Knoten liegt keine gültige Bezeichnung vor.
Geo-Profile
Eine Datei kann i.d.R. mehrere Profile enthalten, die durch ein entsprechendes Kantenverzeichnis der Profile beschrieben werden können.
Langer Name
char Mesh1_prof_long_name(nMesh1_prof, nMesh1_strlen1) ;
- Mesh1_prof_long_name:long_name = "Name des Profils" ;
- Mesh1_prof_long_name:name_id = ???? ;
Hinweise:
- Variable wird als Label-Koordinate benutzt, daher werden die Attribute "coordinates" und "grid_mapping" hier nicht benutzt.
- Das Attribut "name_id" entspricht der (BAW) PHYDEF-Code-Kennung der Variablen.
Code-Name
char Mesh1_prof_code_name(nMesh1_prof, nMesh1_strlen2) ;
- Mesh1_prof_code_name:long_name = "Kennung des Profils" ;
- Mesh1_prof_code_name:name_id = ???? ;
- Mesh1_prof_code_name:coordinates = "Mesh1_prof_long_name" ;
- Mesh1_prof_code_name:location = "prof" ;
- Mesh1_prof_code_name:mesh = "Mesh1" ;
- Mesh1_prof_code_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
- Ggf. bei "coordinates" noch repräsentative Profilkoordinaten angeben.
Kurzer Name
char Mesh1_prof_short_name(nMesh1_prof, nMesh1_strlen3) ;
- Mesh1_prof_short_name:long_name = "Kuerzel Profil" ;
- Mesh1_prof_short_name:name_id = ???? ;
- Mesh1_prof_short_name:coordinates = "Mesh1_prof_long_name" ;
- Mesh1_prof_short_name:location = "prof" ;
- Mesh1_prof_short_name:mesh = "Mesh1" ;
- Mesh1_prof_short_name:grid_mapping = "Mesh1_crs" ;
Hinweise:
- Ggf. bei "coordinates" noch repräsentative Profilkoordinaten angeben.
Profil-Identifikationsnummer
int Mesh1_prof_id(nMesh1_prof) ;
- Mesh1_prof_type:standard_name = "???" ;
- Mesh1_prof_id:long_name = "Identifikationsnummer eines Profils" ;
- Mesh1_prof_id_:name_id = ???? ;
- Mesh1_prof_id:coordinates = "Mesh1_prof_long_name" ;
- Mesh1_prof_id:valid_range = "valid minimum, valid maximum ;
- Mesh1_prof_id:_FillValue = "fillvalue" ;
- Mesh1_prof_id:location = "prof" ;
- Mesh1_prof_id:mesh = "Mesh1" ;
- Mesh1_prof_id:grid_mapping = "Mesh1_crs" ;
Hinweise:
- Dimensionslose Variable, daher ist kein "units" Attribut vorhanden.
- Ggf. bei "coordinates" noch repräsentative Profilkoordinaten angeben.
Profiltyp
int Mesh1_prof_type(nMesh1_prof) ;
- Mesh1_prof_type:standard_name = "??? status_flag" ;
- Mesh1_prof_type:long_name = "Typ des Profils, Längs- oder Querschnitt" ;
- Mesh1_prof_long_name:name_id = ???? ;
- Mesh1_prof_type:coordinates = "Mesh1_prof_long_name" ;
- Mesh1_prof_type:valid_range = "0, 1" ;
- Mesh1_prof_type:_FillValue = "fillvalue" ;
- Mesh1_prof_type:valid_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:
- Ggf. bei "coordinates" noch repräsentative Profilkoordinaten angeben.
- 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:standard_name = "??? status_flag" ;
- Mesh1_node_marker_type:long_name = "Typ der Marker-Information an Knoten" ;
- Mesh1_node_marker_long_name:name_id = ???? ;
- Mesh1_node_marker_type:coordinates = "Mesh1_node_x Mesh1_node_y Mesh1_node_lon Mesh1_node_lat" ;
- Mesh1_node_marker_type:valid_range = "1, 8" ;
- Mesh1_node_marker_type:_FillValue = "fillvalue" ;
- Mesh1_node_marker_type:valid_values = 1, 2, 3, 4, 5, 6, 7, 8 ;
- 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:
- Kann in einer anderen Variablen mit dem Attribut "ancillary_variables" referenziert werden.
Systemdatei-Informationen
Name der Systemdatei
char Mesh1_sys_file_name(nMesh1_sys, nMesh1_strlen0) ;
- Mesh1_sys_file_name:long_name = "Name Systemdatei" ;
- Mesh1_sys_file_name:name_id = "????" ;
- Mesh1_sys_file_name:_FillValue = "fillvalue" ;
Code-Name der Systemdatei
char Mesh1_sys_code_name(nMesh1_sys, nMesh1_strlen2) ;
- 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 = "fillvalue" ;
Anzahl der Knoten der Systemdatei
int Mesh1_sys_nv(nMesh1_sys) ;
- Mesh1_sys_nv:long_name = "Anzahl der Knoten Systemdatei" ;
- Mesh1_sys_nv:name_id = ???? ;
- Mesh1_sys_nv:valid_range = "valid minimum, valid maximum" ;
- Mesh1_sys_nv:_FillValue = "fillvalue" ;
Anzahl der Polygone der Systemdatei
int Mesh1_sys_ne(nMesh1_sys) ;
- Mesh1_sys_ne:long_name = "Anzahl der Polygone Systemdatei" ;
- Mesh1_sys_ne:name_id = ???? ;
- Mesh1_sys_ne:valid_range = "valid minimum, valid maximum" ;
- Mesh1_sys_ne:_FillValue = "fillvalue" ;
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 an 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 = "fillvalue" ;
- 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 an den 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" ;
Tiefen der Interpolationspunkte
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 an den 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" ;
Daten an Knoten
Hinweise:
- Es kann analog zu NetCDF Synoptische Daten an Einzelpositionen vorgegangen werden:
- Gewichte,
- Zeitkoordinaten,
- Vertikalkoordinaten,
- Topografie,
- maximale zulässige Tiefe,
- Wasserstand,
- Tiefengemittelter Salzgehalt,
- Tiefenstrukturierter Salzgehalt,
- Tiefengemittelte Strömungsgeschwindigkeit,
- Tiefenstrukturierte Strömungsgeschwindigkeit,
- Bezeichnung der Schwebstoffklassen,
- Tiefengemittelter Schwebstoffgehalt, und
- 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.
Daten an Kanten
Hinweise:
- Bislang liegen keine Daten an Kanten vor. Dies wird sich mit der SubGrid Technologie ändern.
Anmerkungen, Fragen
- Datei ist nicht vollständig CF-konform. Für das Attribut cell_measures müsste depth als Wert zugelassen werden. Allerdings ist depth ein CF Standardname, und dann könnte dieser Wert doch gemäß Abschnitt 7.3.4 in der CF-Metadaten Konvention zulässig sein.
- Soll das BAW-Attribut name_id (für den Code) zusätzlich benutzt werden?
- Können wir Vektoren zwischen verschiedenen Koordinatensystemen transformieren, um z. B. aus der x- und der y-Komponente die Ostkomponente zu berechnen?
- Benötigen wir ID und COLOR noch (in dieser Datei)? (sind oben vernachlässigt).
zurück zu NetCDF