NetCDF Synoptische Daten an Einzelpositionen: Unterschied zwischen den Versionen
Aus BAWiki
imported>Lang Guenther (→Datenkompression: Textergänzung) |
imported>Lang Guenther (´Textlöschung) |
||
Zeile 147: | Zeile 147: | ||
::: node_suspended_matter_classes:cell_methods = "height: mean" | ::: node_suspended_matter_classes:cell_methods = "height: mean" | ||
::: node_suspended_matter_classes:grid_mapping = "crs" | ::: node_suspended_matter_classes:grid_mapping = "crs" | ||
=Bezeichnung der Schwebstoffklassen= | =Bezeichnung der Schwebstoffklassen= |
Version vom 10. September 2010, 14:24 Uhr
Kurze Beschreibung
Synoptische Daten an Einzelpositionen.
Weitere Beschreibungen
- NetCDF Einzelpositionen: Koordinaten und Namensbezeichnungen sowie Koordinatentransformation;
- NetCDF Zeitkoordinate: Koordinatenvariable time;
- NetCDF Vertikalkoordinate: Vertikalkoordinate depth oder height:
- node_depth_3d : Vertikalkoordinate für tiefenstrukturierte Daten an Knoten.
Dimensionen
Soweit nicht schon oben festgelegt, kommen noch folgende Dimensionen hinzu:
- dimensions:
- nMesh0_vedge = total number of computational data above nodes ;
- nMesh0_susp_classes = number of suspended sediment classes ;
- nMesh0_strlen1 = maximum number of characters used in long names ;
- nMesh0_strlen2 = maximum number of characters used in code names ;
- nMesh0_strlen3 = maximum number of characters used in short names ;
Positionsbezeichnungen
Langbezeichnung
- char Mesh0_node_long_name(nMesh0_node,nMesh0_strlen1) ;
- Mesh0_node_long_name:standard_name = "???" ; \\ no standard name available
- Mesh0_node_long_name:long_name = "long name of location"
- Mesh0_node_long_name:coordinates = "Mesh0_node_lon Mesh0_node_lat"
- Mesh0_node_long_name:grid_mapping = "crs"
- char Mesh0_node_long_name(nMesh0_node,nMesh0_strlen1) ;
Codekennung
- char Mesh0_node_code_name(nMesh0_node,nMesh0_strlen2) ;
- Mesh0_node_code_name:standard_name = "???" ; \\ no standard name available
- Mesh0_node_code_name:long_name = "code name of location"
- Mesh0_node_code_name:coordinates = "nMesh0_node_long_name Mesh0_node_lon Mesh0_node_lat"
- Mesh0_node_code_name:grid_mapping = "crs"
- char Mesh0_node_code_name(nMesh0_node,nMesh0_strlen2) ;
Kurzbezeichnung
- char Mesh0_node_short_name(nMesh0_node,nMesh0_strlen3) ;
- Mesh0_node_short_name:standard_name = "???" ; \\ no standard name available
- Mesh0_node_short_name:long_name = "short name of location"
- Mesh0_node_short_name:coordinates = "nMesh0_node_long_name Mesh0_node_lon Mesh0_node_lat"
- Mesh0_node_short_name:grid_mapping = "crs"
- char Mesh0_node_short_name(nMesh0_node,nMesh0_strlen3) ;
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 nMesh0_vedge(nMesh0_vedge) ;
- nMesh0_vedge:compress = "node_depth_3d nMesh0_node"
- integer nMesh0_vedge(nMesh0_vedge) ;
Gewichte
Aktuelle (zeitvariable) Topografie
Maximale zulässige Tiefe
Wasserstand
- double node_water_level(time,node) ;
- node_water_level:standard_name = "sea_surface_height_above_geoid" ;
- node_water_level:long_name = "water level" ;
- node_water_level:units = "m" ;
- node_water_level:coordinates = "node_long_name node_lon node_lat"
- node_water_level:_FillValue = "fillvalue"
- node_water_level:valid_range = "valid minimum, valid maximum"
- node_water_level:grid_mapping = "crs"
- double node_water_level(time,node) ;
Zeitvariable Topografie
- double node_water_level(time,node) ;
- node_depth:standard_name = "sea_floor_depth_below_geoid" ;
- node_depth:long_name = "sea floor depth" ;
- node_depth:units = "m" ;
- node_depth:coordinates = "node_long_name node_lon node_lat"
- node_depth:_FillValue = "fillvalue"
- node_depth:valid_range = "valid minimum, valid maximum"
- node_depth:grid_mapping = "crs"
- double node_water_level(time,node) ;
Gesamtwassertiefe
- double node_water_depth(time,node) ;
- node_water_depth:standard_name = "sea_floor_depth_below_sea_surface" ;
- node_water_depth:long_name = "total water depth" ;
- node_water_depth:units = "m" ;
- node_water_depth:coordinates = "node_long_name node_lon node_lat"
- node_water_depth:_FillValue = "fillvalue"
- node_water_depth:valid_range = "valid minimum, valid maximum"
- node_water_depth:grid_mapping = "crs"
- double node_water_depth(time,node) ;
Tiefenstrukturierter Salzgehalt
- double node_salinity(time,vedge) ;
- node_salinity:standard_name = "sea_water_salinity" ;
- node_salinity:long_name = "salinity" ;
- node_salinity:units = "0.001" ;
- node_salinity:coordinates = "node_long_name node_lon node_lat"
- node_salinity:_FillValue = "fillvalue"
- node_salinity:valid_range = "valid minimum, valid maximum"
- node_salinity:cell_methods = "height: mean"
- node_salinity:grid_mapping = "crs"
- double node_salinity(time,vedge) ;
Strömungsgeschwindigkeit, x-Komponente
- double node_velocity_x(time,vedge) ;
- node_velocity_x:standard_name = "sea_water_x_velocity" ; \\ or better eastward_sea_water_velocity
- node_velocity_x:long_name = "current velocity in x-direction" ;
- node_velocity_x:units = "m s-1" ;
- node_velocity_x:coordinates = "node_long_name node_lon node_lat"
- node_velocity_x:_FillValue = "fillvalue"
- node_velocity_x:valid_range = "valid minimum, valid maximum"
- node_velocity_x:cell_methods = "height: mean"
- node_velocity_x:grid_mapping = "crs"
- double node_velocity_x(time,vedge) ;
Strömungsgeschwindigkeit, y-Komponente
- double node_velocity_y(time,vedge) ;
- node_velocity_y:standard_name = "sea_water_y_velocity" ; \\ or better northward_sea_water_velocity
- ... weitere Attribute analog zur x-Komponente der Strömungsgeschwindigkeit
- double node_velocity_y(time,vedge) ;
Strömungsgeschwindigkeit, z-Komponente
- double node_velocity_z(time,vedge) ;
- node_velocity_z:standard_name = "upward_sea_water_velocity" ;
- ... weitere Attribute analog zur x-Komponente der Strömungsgeschwindigkeit
- double node_velocity_z(time,vedge) ;
Schwebstoffgehalt, Gesamtmenge
- double node_suspended_matter(time,vedge) ;
- node_suspended_matter:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
- node_suspended_matter:long_name = "mass concentration of suspended sediments" ;
- node_suspended_matter:units = "kg m-3" ;
- node_suspended_matter:coordinates = "node_long_name node_lon node_lat"
- node_suspended_matter:_FillValue = "fillvalue"
- node_suspended_matter:valid_range = "valid minimum, valid maximum"
- node_suspended_matter:cell_methods = "height: mean"
- node_suspended_matter:grid_mapping = "crs"
- double node_suspended_matter(time,vedge) ;
Schwebstoffgehalt, Fraktionen
- double node_suspended_matter_classes(suspension_classes,time,vedge) ;
- node_suspended_matter_classes:standard_name = "mass_concentration_of_suspended_matter_in_sea_water" ;
- node_suspended_matter_classes:long_name = "mass concentration of suspended sediment fraction" ;
- node_suspended_matter_classes:units = "kg m-3" ;
- node_suspended_matter_classes:coordinates = "node_long_name node_lon node_lat"
- node_suspended_matter_classes:_FillValue = "fillvalue"
- node_suspended_matter_classes:valid_range = "valid minimum, valid maximum"
- node_suspended_matter_classes:cell_methods = "height: mean"
- node_suspended_matter_classes:grid_mapping = "crs"
- double node_suspended_matter_classes(suspension_classes,time,vedge) ;
Bezeichnung der Schwebstoffklassen
- char suspended_matter_classes_long_name(suspension_classes,strlen1) ;
- suspended_matter_classes_long_name:long_name = "long name of suspension class"
- char suspended_matter_classes_long_name(suspension_classes,strlen1) ;
Anmerkungen, Fragen
- Datei ist vollständig CF-konform - keine Erweiterungen erforderlich!
- Soll das BAW-Attribut name_id (für den Code) zusätzlich benutzt werden?
- Können wir Tiefenmittelwerte, z. B. für den Salzgehalt, aus den Daten und Metadaten problemlos berechnen?
- Oder sollen die Tiefenmittelwerte zusätzlich abgelegt 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 "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.
- Datei ist vollständig CF-konform - keine Erweiterungen erforderlich!
- Wie unterscheiden wir aktuelle Tiefe und nicht weiter erodierbare Tiefe? Neuer standard_name erforderlich?
- 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 "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)
- Die Beschreibung der Koordinatentransformation ist für UTM- und Gauß-Krüger-Koordinaten geeignet.
zurück zu NetCDF