/// <summary> /// Constructor for process tracker: Initialises the trackers for individual processes /// </summary> /// <param name="numTimesteps">The number of time steps in the model</param> /// <param name="lats">The latitudes of active grid cells in the model</param> /// <param name="lons">The longitudes of active grid cells in the model</param> /// <param name="cellIndices">List of indices of active cells in the model grid</param> /// <param name="Filenames">The filenames of the output files to write the tracking results to</param> /// <param name="trackProcesses">Whether to track processes</param> /// <param name="cohortDefinitions">The definitions for cohort functional groups in the model</param> /// <param name="missingValue">The missing value to use in process tracking output files</param> /// <param name="outputFileSuffix">The suffix to be applied to output files from process tracking</param> /// <param name="outputPath">The path to the folder to be used for process tracking outputs</param> /// <param name="trackerMassBins">The mass bins to use for categorising output data in the process trackers</param> /// <param name="specificLocations">Whether the model is being run for specific locations</param> /// <param name="initialisation">The Madingley Model initialisation</param> /// <param name="latCellSize">The size of grid cells latitudinally</param> /// <param name="lonCellSize">The size of grid cells longitudinally</param> public GlobalProcessTracker(uint numTimesteps, float[] lats, float[] lons, List<uint[]> cellIndices, SortedList<string, string> Filenames, Boolean trackProcesses, FunctionalGroupDefinitions cohortDefinitions, FunctionalGroupDefinitions stockDefinitions, double missingValue, string outputFileSuffix, string outputPath, MassBinsHandler trackerMassBins, Boolean specificLocations, MadingleyModelInitialisation initialisation, float latCellSize, float lonCellSize) { // Initialise trackers for ecological processes _TrackProcesses = trackProcesses; if (_TrackProcesses) { _TrackNPP = new GlobalNPPTracker(outputPath, lats.Length, lons.Length, lats, lons, latCellSize, lonCellSize, (int)numTimesteps,stockDefinitions.GetNumberOfFunctionalGroups(),outputFileSuffix); } }
public void Copy(GlobalNPPTracker existing) { this.NPPOutput.Dispose(); this.NPPOutput = null; System.IO.File.Copy(existing.FileName, this.FileName, true); var fileString = "msds:nc?file=" + this.FileName; this.NPPOutput = DataSet.Open(fileString); }
/// <summary> /// Constructor for process tracker: Initialises the trackers for individual processes /// </summary> /// <param name="numTimesteps">The number of time steps in the model</param> /// <param name="lats">The latitudes of active grid cells in the model</param> /// <param name="lons">The longitudes of active grid cells in the model</param> /// <param name="cellIndices">List of indices of active cells in the model grid</param> /// <param name="Filenames">The filenames of the output files to write the tracking results to</param> /// <param name="trackProcesses">Whether to track processes</param> /// <param name="cohortDefinitions">The definitions for cohort functional groups in the model</param> /// <param name="missingValue">The missing value to use in process tracking output files</param> /// <param name="outputFileSuffix">The suffix to be applied to output files from process tracking</param> /// <param name="outputPath">The path to the folder to be used for process tracking outputs</param> /// <param name="trackerMassBins">The mass bins to use for categorising output data in the process trackers</param> /// <param name="specificLocations">Whether the model is being run for specific locations</param> /// <param name="initialisation">The Madingley Model initialisation</param> /// <param name="latCellSize">The size of grid cells latitudinally</param> /// <param name="lonCellSize">The size of grid cells longitudinally</param> public GlobalProcessTracker(uint numTimesteps, float[] lats, float[] lons, List <uint[]> cellIndices, SortedList <string, string> Filenames, Boolean trackProcesses, FunctionalGroupDefinitions cohortDefinitions, FunctionalGroupDefinitions stockDefinitions, double missingValue, string outputFileSuffix, string outputPath, MassBinsHandler trackerMassBins, Boolean specificLocations, MadingleyModelInitialisation initialisation, float latCellSize, float lonCellSize) { // Initialise trackers for ecological processes _TrackProcesses = trackProcesses; if (_TrackProcesses) { _TrackNPP = new GlobalNPPTracker(outputPath, lats.Length, lons.Length, lats, lons, latCellSize, lonCellSize, (int)numTimesteps, stockDefinitions.GetNumberOfFunctionalGroups()); } }