Aktionen

NetCDF Synoptische Daten auf Profilen

Aus BAWiki

Kurze Beschreibung

Synoptische Daten auf mehreren Längs- und Querprofilen.

Weitere Beschreibungen

  • NetCDF Profile: Koordinaten und Namensbezeichnungen sowie Koordinatentransformation;
  • NetCDF Zeitkoordinate: Koordinatenvariable time;
  • NetCDF Vertikalkoordinate: Vertikalkoordinate depth oder height:
    1. node_depth_3d : Vertikalkoordinate für tiefenstrukturierte Daten an Knoten;
    2. edge_depth_3d : Vertikalkoordinate für tiefenstrukturierte Daten an Kanten.

Dimensionen

Soweit nicht schon oben festgelegt, kommen noch folgende Dimensionen hinzu:

dimensions:
nMesh1_vedge = total number of computational data above nodes ;
nMesh1_face = total number of computational data above edges ;
nMesh1_prof = total number of (different) profiles ;
nMesh1_strlen1 = maximum number of characters used in long names ;
nMesh1_strlen2 = maximum number of characters used in code names ;
nMesh1_strlen3 = maximum number of characters used in short names ;

Bezeichnungen

Profile

Langer Name

char Mesh1_prof_long_name(nMesh1_prof,nMesh1_strlen1) ;
Mesh1_node_long_name:standard_name = "???" ; \\ no standard name available
Mesh1_node_long_name:long_name = "long name of profile" ;

Code-Name

char Mesh1_prof_code_name(nMesh1_prof,nMesh1_strlen2) ;
Mesh1_node_code_name:standard_name = "???" ; \\ no standard name available
Mesh1_node_code_name:long_name = "code name of profile" ;

Kurzer Name

char Mesh1_prof_short_name(nMesh1_prof,nMesh1_strlen3) ;
Mesh1_node_short_name:standard_name = "???" ; \\ no standard name available
Mesh1_node_short_name:long_name = "short name of profile" ;

Positionen

Marker

Datenkompression

Auf Grund der Verwendung von z-Schichten sind über jeder Position in Abhängigkeit von der Wassertiefe unterschiedlich viele (aktive) Berechnungszellen vorhanden. Zur Reduktion der Größe der Ergebnisdatensätze werden verschiedene Dimensionen in einer komprimierten Dimension zusammengefasst. Dauerhaft fehlende Daten werden daher erst gar nicht in der Datei abgespeichert. Dies reduziert bei drei-dimensionalen Simulationen mit z-Schichten den Speicheraufwand typischer Weise um 60 bis 80 Prozent.

Komprimierte Daten an Knoten

integer nMesh1_pnode(nMesh1_pnode) ; \\ 2D data at nodes, profile oriented
nMesh1_pnode:compress = "nMesh1_node, nMesh1_prof" ;
integer nMesh1_pvedge(nMesh1_pvedge) ; \\ 3D data at nodes, profile oriented
nMesh1_pvedge:compress = "node_depth_3d nMesh1_node nMesh1_prof" ;

Komprimierte Daten an Kanten

integer nMesh1_pedge(nMesh1_pedge) ; \\ 2D data at edges, profile oriented
nMesh1_pedge:compress = "nMesh1_edge, nMesh1_prof" ;
integer nMesh1_pface(nMesh1_pface) ; \\ 3D data at edges, profile oriented
nMesh1_pface:compress = "edge_depth_3d nMesh1_edge nMesh1_prof" ;

Gewichte

Gewichte werden insbesondere im Postprocessing benötigt, um abgeleitete Daten korrekt berechnen zu können, falls die hierfür relevanten Gewichtsfaktoren, hier Längen, nicht in einfacher Weise aus den Koordinaten abgeleitet werden können. Die Verwendung von Gewichten bringt daher eine große Sicherheit in die späteren Weiterverarbeitung der Daten. Beispiele für abgeleitete Daten sind insbesondere Tiefenmittelwerte oder (spezifische) Durchflussberechnungen.

Längen

Durchflusshöhe an Knoten, summiert über alle Schichten

double Mesh1_node_water_depth_2d(time,nMesh1_node) ;
Mesh1_node_water_depth_2d:standard_name = "sea_floor_depth_below_sea_surface" ;
Mesh1_node_water_depth_2d:long_name = "water depth at locations, vertically integrated" ;
Mesh1_node_water_depth_2d:units = "m" ;
Mesh1_node_water_depth_2d:coordinates = "Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_water_depth_2d:_FillValue = fillvalue ;
Mesh1_node_water_depth_2d:valid_range = valid minimum, valid maximum ;
Mesh1_node_water_depth_2d:grid_mapping = "crs" ;
Hinweis: entspricht der Wassertiefe an den Positionen.

Duchflusshöhe an Knoten, differenziert nach Schichten

double Mesh1_node_water_depth_3d(time,nMesh1_vedge) ; \\ compression used
Mesh1_node_water_depth_3d:standard_name = "???" ;
Mesh1_node_water_depth_3d:long_name = "water depth at locations, vertically structured" ;
Mesh1_node_water_depth_3d:units = "m" ;
Mesh1_node_water_depth_3d:coordinates = "Mesh1_node_lon Mesh1_node_lat" ;
Mesh1_node_water_depth_3d:_FillValue = fillvalue ;
Mesh1_node_water_depth_3d:valid_range = valid minimum, valid maximum ;
Mesh1_node_water_depth_3d:grid_mapping = "crs" ;
Hinweis: die Wassertiefe in den einzelnen Schichten ist bei Verwendung von z-Schichten sowohl vom Wasserstand, der Lage der Gewässersohle, und zusätzlich noch von der Position der z-Schichten abhängig. Diese Daten sind für einen Postprozessor nur unter Kenntnis der in dem erzeugenden HN-Verfahren benutzten Algorithmen exakt rekonstruierbar.

Flächen

Aktuelle (zeitvariable) Topografie

Es werden hier Angaben nur für zeitvariable Topografie gemacht. Bei stationärer Topografie entfällt die Dimension time.

Knoten

double Mesh0_node_depth(time,nMesh0_node) ;
Mesh0_node_depth:standard_name = "sea_floor_depth_below_geoid" ;
Mesh0_node_depth:long_name = "sea floor depth at locations" ;
Mesh0_node_depth:units = "m" ;
Mesh0_node_depth:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_depth:_FillValue = fillvalue ;
Mesh0_node_depth:valid_range = valid minimum, valid maximum ;
Mesh0_node_depth:cell_methods = "nMesh0_node: point" ;
Mesh0_node_depth:grid_mapping = "crs" ;

Maximale zulässige Tiefe

  • Vollständig analog zu Aktuelle Tiefe vorgehen, jedoch ohne Dimension time.
  • Vorschlag für die Namensgebung:
    1. Knoten: "Mesh0_node_max_depth(nMesh0_node)" .

Wasserstand

Knoten

double Mesh0_node_water_level(time,nMesh0_node) ;
Mesh0_node_water_level:standard_name = "sea_surface_height_above_geoid" ;
Mesh0_node_water_level:long_name = "water level at locations" ;
Mesh0_node_water_level:units = "m" ;
Mesh0_node_water_level:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_water_level:_FillValue = fillvalue ;
Mesh0_node_water_level:valid_range = valid minimum, valid maximum ;
Mesh0_node_water_level:cell_methods = "nMesh0_node: point" ;
Mesh0_node_water_level:grid_mapping = "crs" ;

Tiefengemittelter Salzgehalt

Knoten

double Mesh0_node_salinity_2d(time,nMesh0_node) ;
Mesh0_node_salinity_2d:standard_name = "sea_water_salinity" ;
Mesh0_node_salinity_2d:long_name = "salinity at locations, depth averaged" ;
Mesh0_node_salinity_2d:units = "0.001" ;
Mesh0_node_salinity_2d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_salinity_2d:_FillValue = fillvalue ;
Mesh0_node_salinity_2d:valid_range = valid minimum, valid maximum ;
Mesh0_node_salinity_2d:cell_methods = "nMesh0_node: mean" ;
Mesh0_node_salinity_2d:cell_measures = "depth: Mesh0_node_water_depth_2d"
Mesh0_node_salinity_2d:grid_mapping = "crs" ;

Tiefenstrukturierter Salzgehalt

Knoten

double Mesh0_node_salinity_3d(time,nMesh0_vedge) ; \\ compression used
Mesh0_node_salinity_3d:standard_name = "sea_water_salinity" ;
Mesh0_node_salinity_3d:long_name = "salinity at locations, vertically structured" ;
Mesh0_node_salinity_3d:units = "0.001" ;
Mesh0_node_salinity_3d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_salinity_3d:_FillValue = fillvalue ;
Mesh0_node_salinity_3d:valid_range = valid minimum, valid maximum ;
Mesh0_node_salinity_3d:cell_methods = "nMesh0_vedge: mean" ;
Mesh0_node_salinity_3d:cell_measures = "depth: Mesh0_node_water_depth_3d" ;
Mesh0_node_salinity_3d:grid_mapping = "crs" ;

Tiefengemittelte Strömungsgeschwindigkeit

Knoten

double Mesh0_node_velocity_x_2d(time,nMesh0_node) ;
Mesh0_node_velocity_x_2d:standard_name = "sea_water_x_velocity" ; \\ or better eastward_sea_water_velocity
Mesh0_node_velocity_x_2d:long_name = "current velocity in x-direction at locations, depth integrated" ;
Mesh0_node_velocity_x_2d:units = "m s-1" ;
Mesh0_node_velocity_x_2d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_velocity_x_2d:_FillValue = fillvalue ;
Mesh0_node_velocity_x_2d:valid_range = valid minimum, valid maximum ;
Mesh0_node_velocity_x_2d:cell_methods = "nMesh0_node: mean" ;
Mesh0_node_velocity_x_2d:cell_measures = "depth: Mesh0_node_water_depth_2d" ;
Mesh0_node_velocity_x_2d:grid_mapping = "crs" ;
Bemerkung: y-Komponente sea_water_y_velocity (northward_sea_water_velocity) analog.

Tiefenstrukturierte Strömungsgeschwindigkeit

Knoten

double Mesh0_node_velocity_x_3d(time,nMesh0_vedge) ; \\ compression used
Mesh0_node_velocity_x_3d:standard_name = "sea_water_x_velocity" ; \\ or better eastward_sea_water_velocity
Mesh0_node_velocity_x_3d:long_name = "current velocity in x-direction at locations, vertically structured" ;
Mesh0_node_velocity_x_3d:units = "m s-1" ;
Mesh0_node_velocity_x_3d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_velocity_x_3d:_FillValue = fillvalue ;
Mesh0_node_velocity_x_3d:valid_range = valid minimum, valid maximum ;
Mesh0_node_velocity_x_3d:cell_methods = "nMesh0_vedge: mean" ;
Mesh0_node_velocity_x_3d:cell_measures = "depth: Mesh0_node_water_depth_3d" ;
Mesh0_node_velocity_x_3d:grid_mapping = "crs" ;
Bemerkung: y-Komponente sea_water_y_velocity (northward_sea_water_velocity) analog.
double Mesh0_node_velocity_z_3d(time,nMesh0_vedge) ; \\ compression used
Mesh0_node_velocity_z_3d:standard_name = "upward_sea_water_velocity" ;
Mesh0_node_velocity_z_3d:long_name = "current velocity in z-direction at locations, vertically structured" ;
Mesh0_node_velocity_z_3d:units = "m s-1" ;
Mesh0_node_velocity_z_3d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_velocity_z_3d:_FillValue = fillvalue ;
Mesh0_node_velocity_z_3d:valid_range = valid minimum, valid maximum ;
Mesh0_node_velocity_z_3d:cell_methods = "nMesh0_vedge: mean" ;
Mesh0_node_velocity_z_3d:cell_measures = "depth: Mesh0_node_water_depth_3d" ;
Mesh0_node_velocity_z_3d:grid_mapping = "crs" ;

Tiefengemittelter Schwebstoffgehalt

Knoten

Gesamtmenge

double Mesh0_node_suspended_matter_2d(time,nMesh0_node) ;
Mesh0_node_suspended_matter_2d:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
Mesh0_node_suspended_matter_2d:long_name = "mass concentration of suspended sediments at locations, depth averaged" ;
Mesh0_node_suspended_matter_2d:units = "0.001" ;
Mesh0_node_suspended_matter_2d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_suspended_matter_2d:_FillValue = fillvalue ;
Mesh0_node_suspended_matter_2d:valid_range = valid minimum, valid maximum ;
Mesh0_node_suspended_matter_2d:cell_methods = "nMesh0_node: mean" ;
Mesh0_node_suspended_matter_2d:cell_measures = "depth: Mesh0_node_water_depth_2d" ;
Mesh0_node_suspended_matter_2d:grid_mapping = "crs" ;

Fraktionen

Option 1: Ein Feld für alle Fraktionen

double Mesh0_node_suspended_matter_classes_2d(nMesh0_susp_classes,time,nMesh0_node) ;
Mesh0_node_suspended_matter_classes_2d:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
Mesh0_node_suspended_matter_classes_2d:long_name = "mass concentration of suspended sediments fractions at locations, depth averaged" ;
Mesh0_node_suspended_matter_classes_2d:units = "0.001" ;
Mesh0_node_suspended_matter_classes_2d:coordinates = "Mesh0_suspended_matter_classes_long_name Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_suspended_matter_classes_2d:_FillValue = fillvalue ;
Mesh0_node_suspended_matter_classes_2d:valid_range = valid minimum, valid maximum ;
Mesh0_node_suspended_matter_classes_2d:cell_methods = "nMesh0_node: mean" ;
Mesh0_node_suspended_matter_classes_2d:cell_measures = "depth: Mesh0_node_water_depth_2d" ;
Mesh0_node_suspended_matter_classes_2d:grid_mapping = "crs" ;

Option 2: Für jede Fraktion ein Feld

double Mesh0_node_suspended_matter_class_fractionname_2d(time,nMesh0_node) ;
Mesh0_node_suspended_matter_class_fractionname_2d:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
Mesh0_node_suspended_matter_class_fractionname_2d:long_name = "mass concentration of suspended sediments fractions at locations, depth averaged, fraction fractionname" ;
Mesh0_node_suspended_matter_class_fractionname_2d:units = "0.001" ;
Mesh0_node_suspended_matter_class_fractionname_2d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_suspended_matter_class_fractionname_2d:_FillValue = fillvalue ;
Mesh0_node_suspended_matter_class_fractionname_2d:valid_range = valid minimum, valid maximum ;
Mesh0_node_suspended_matter_class_fractionname_2d:cell_methods = "nMesh0_node: mean" ;
Mesh0_node_suspended_matter_class_fractionname_2d:cell_measures = "depth: Mesh0_node_water_depth_2d" ;
Mesh0_node_suspended_matter_class_fractionname_2d:grid_mapping = "crs" ;

Tiefenstrukturierter Schwebstoffgehalt

Knoten

Gesamtmenge

double Mesh0_node_suspended_matter_3d(time,nMesh0_vedge) ; \\ compression used
Mesh0_node_suspended_matter_3d:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
Mesh0_node_suspended_matter_3d:long_name = "mass concentration of suspended sediments at locations, vertically structured" ;
Mesh0_node_suspended_matter_3d:units = "0.001" ;
Mesh0_node_suspended_matter_3d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_suspended_matter_3d:_FillValue = fillvalue ;
Mesh0_node_suspended_matter_3d:valid_range = valid minimum, valid maximum ;
Mesh0_node_suspended_matter_3d:cell_methods = "nMesh0_vedge: mean" ;
Mesh0_node_suspended_matter_3d:cell_measures = "depth: Mesh0_node_water_depth_3d" ;
Mesh0_node_suspended_matter_3d:grid_mapping = "crs" ;

Fraktionen

Option 1: Ein Feld für alle Fraktionen

double Mesh0_node_suspended_matter_classes_3d(nMesh0_susp_classes,time,nMesh0_vedge) ;
Mesh0_node_suspended_matter_classes_3d:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
Mesh0_node_suspended_matter_classes_3d:long_name = "mass concentration of suspended sediments fractions at locations, vertically structured" ;
Mesh0_node_suspended_matter_classes_3d:units = "0.001" ;
Mesh0_node_suspended_matter_classes_3d:coordinates = "Mesh0_suspended_matter_classes_long_name Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_suspended_matter_classes_3d:_FillValue = fillvalue ;
Mesh0_node_suspended_matter_classes_3d:valid_range = valid minimum, valid maximum ;
Mesh0_node_suspended_matter_classes_3d:cell_methods = "nMesh0_vedge: mean" ;
Mesh0_node_suspended_matter_classes_3d:cell_measures = "depth: Mesh0_node_water_depth_3d" ;
Mesh0_node_suspended_matter_classes_3d:grid_mapping = "crs" ;

Option 2: Für jede Fraktion ein Feld

double Mesh0_node_suspended_matter_class_fractionname_3d(time,nMesh0_vedge) ;
Mesh0_node_suspended_matter_class_fractionname_3d:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
Mesh0_node_suspended_matter_class_fractionname_3d:long_name = "mass concentration of suspended sediments fractions at locations, vertically structured, fraction fractionname" ;
Mesh0_node_suspended_matter_class_fractionname_3d:units = "0.001" ;
Mesh0_node_suspended_matter_class_fractionname_3d:coordinates = "Mesh0_node_long_name Mesh0_node_lon Mesh0_node_lat" ;
Mesh0_node_suspended_matter_class_fractionname_3d:_FillValue = fillvalue ;
Mesh0_node_suspended_matter_class_fractionname_3d:valid_range = valid minimum, valid maximum ;
Mesh0_node_suspended_matter_class_fractionname_3d:cell_methods = "nMesh0_vedge: mean" ;
Mesh0_node_suspended_matter_class_fractionname_3d:cell_measures = "depth: Mesh0_node_water_depth_3d" ;
Mesh0_node_suspended_matter_class_fractionname_3d:grid_mapping = "crs" ;

Bezeichnung der Schwebstoffklassen

char Mesh0_suspended_matter_classes_long_name(Mesh0_susp_classes,nMesh0_strlen1) ;
Mesh0_suspended_matter_classes_long_name:long_name = "long name of suspension classes" ;

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?
  • Wie kann ein sicherer Zusammenhang zwischen den Daten für die Schwebstoffklassen und den Klassennamen hergestellt werden?
  • Kann der "Mesh0_suspended_matter_class_long_name" in dem Attribut coordinates genutzt werden?
  • Ist es besser, die Daten der Schwebstoffklassen in einzelnen Feldern zu speichern? Dies wäre in Einklang mit den COARDS Konventionen.
  • Sind "coordinates" und "grid_mapping" für die Namensbezeichnungen erforderlich/sinnvoll?
  • Auf die Daten einer Position kann auch über die Namensbezeichnungen zugegriffen werden, daher erscheint der Wert "Mesh0_node_long_name" in dem Attribut coordinates. Dies entspricht der Empfehlung in Abschnitt 6.1 der CF-Metadaten Konvention.
  • Benötigen wir ID und COLOR noch (in dieser Datei)? (sind oben vernachlässigt).

---