/// <summary> /// Checks for temporal resolution and runs appropriate aggregation function. /// </summary> /// <param name="errorMsg"></param> /// <param name="output"></param> /// <param name="input"></param> /// <returns></returns> private ITimeSeriesOutput TemporalAggregation(out string errorMsg, ITimeSeriesOutput output, ITimeSeriesInput input) { errorMsg = ""; output.Metadata.Add("gldas_temporalresolution", input.TemporalResolution); output.Metadata.Add("column_1", "Date"); if (input.Units.Contains("imperial")) { output.Metadata["gldas_unit"] = "in"; } // NLDAS static methods used for aggregation as GLDAS is identical in function. Modifier refers to the 3hr difference to nldas's hourly resolution. switch (input.TemporalResolution) { case "daily": output.Data = NLDAS.DailyAggregatedSum(out errorMsg, 3.0, output, input); output.Metadata.Add("column_2", "Daily Total"); return(output); case "weekly": output.Data = NLDAS.WeeklyAggregatedSum(out errorMsg, 3.0, output, input); output.Metadata.Add("column_2", "Weekly Total"); return(output); case "monthly": output.Data = NLDAS.MonthlyAggregatedSum(out errorMsg, 3.0, output, input); output.Metadata.Add("column_2", "Monthly Total"); return(output); default: output.Data = (input.Units.Contains("imperial")) ? NLDAS.UnitConversion(out errorMsg, 3.0, output, input) : output.Data; output.Metadata.Add("column_2", "Hourly Average"); return(output); } }
// -------------- SurfaceRunoff Functions -------------- // /// <summary> /// Get SurfaceRunoff data function. /// </summary> /// <param name="errorMsg"></param> /// <returns></returns> public ITimeSeriesOutput GetData(out string errorMsg) { errorMsg = ""; // If the timezone information is not provided, the tz details are retrieved and set to the geometry.timezone varaible. if (this.Input.Geometry.Timezone.Offset == 0) { Utilities.Time tz = new Utilities.Time(); this.Input.Geometry.Timezone = tz.GetTimezone(out errorMsg, this.Input.Geometry.Point) as Timezone; if (errorMsg.Contains("ERROR")) { return(null); } } ITimeSeriesOutputFactory iFactory = new TimeSeriesOutputFactory(); this.Output = iFactory.Initialize(); switch (this.Input.Source) { case "nldas": // NLDAS SurfaceRunoff Data call NLDAS nldas = new NLDAS(); this.Output = nldas.GetData(out errorMsg, this.Output, this.Input); if (errorMsg.Contains("ERROR")) { return(null); } break; case "gldas": // GLDAS SurfaceRunoff Data call GLDAS gldas = new GLDAS(); this.Output = gldas.GetData(out errorMsg, this.Output, this.Input); if (errorMsg.Contains("ERROR")) { return(null); } break; default: errorMsg = "ERROR: 'Source' for surfacerunoff was not found among available sources or is invalid."; break; } ; // Adds Geometry metadata to the output metadata. NOT WORKING this.Output.Metadata.Concat(this.Input.Geometry.GeometryMetadata); // Adds Timezone info to metadata this.Output.Metadata.Add(this.Input.Source + "_timeZone", this.Input.Geometry.Timezone.Name); this.Output.Metadata.Add(this.Input.Source + "_tz_offset", this.Input.Geometry.Timezone.Offset.ToString()); //TODO: Add output format control return(this.Output); }
/// <summary> /// Check surface runoff data endpoints. /// </summary> /// <returns></returns> public Dictionary <string, string> CheckEndpointStatus() { switch (this.Input.Source) { case "nldas": return(NLDAS.CheckStatus(this.Input)); case "gldas": return(GLDAS.CheckStatus(this.Input)); default: return(new Dictionary <string, string>() { { "status", "invalid source" } }); } }