OB.DAAC Logo
NASA Logo
Ocean Color Science Software

ocssw V2022
Stopwatch.hpp
Go to the documentation of this file.
1 #ifndef FOCS_STOPWATCH
2 #define FOCS_STOPWATCH
3 
4 #include <chrono>
5 #include <cmath>
6 #include <iomanip>
7 #include <sstream>
8 #include <type_traits>
9 
10 #include <iostream>
11 namespace focs {
12 
29 class Stopwatch {
30 using clock = std::chrono::steady_clock;
31 using time_point = clock::time_point;
32 
33 public:
35  void reset() noexcept {
36  mark_ = clock::now();
37  }
38 
48  void reset(const time_point t) noexcept {
49  mark_ = time_point{clock::now() - t};
50  }
51 
63  template<typename T>
64  void reset(const T d) noexcept {
65  reset(time_point{std::chrono::seconds{d}});
66  }
67 
73  template<class T = clock::duration>
74  auto now() const noexcept {
75  return std::chrono::duration_cast<T>(clock::now() - mark_);
76  }
78  auto ns() const noexcept {
79  return std::chrono::duration_cast<std::chrono::nanoseconds>(clock::now() - mark_).count();
80  }
82  auto us() const noexcept {
83  return std::chrono::duration_cast<std::chrono::microseconds>(clock::now() - mark_).count();
84  }
86  auto ms() const noexcept {
87  return std::chrono::duration_cast<std::chrono::milliseconds>(clock::now() - mark_).count();
88  }
90  auto seconds() const noexcept {
91  return std::chrono::duration_cast<std::chrono::seconds>(clock::now() - mark_).count();
92  }
94  auto sec() const noexcept {
95  return seconds();
96  }
98  auto s() const noexcept {
99  return seconds();
100  }
102  auto m() const noexcept {
103  return std::chrono::duration_cast<std::chrono::minutes>(clock::now() - mark_).count();
104  }
106  auto h() const noexcept {
107  return std::chrono::duration_cast<std::chrono::hours>(clock::now() - mark_).count();
108  }
110  auto d() const noexcept {
111  return h() / 24.;
112  }
117  time_point mark(){
118  return mark_;
119  }
120 
125  std::string pretty(int decimals=6) const noexcept {
126  return pretty_print(ns(), decimals);
127  }
128 
137  friend std::ostream& operator<<(std::ostream& out, const Stopwatch& in) {
138  return out << pretty_print(in.ns());
139  }
140 
150  template<typename T>
151  static std::string pretty_print(std::chrono::duration<T> duration, int decimals=6) noexcept {
152  return pretty_print( std::chrono::duration_cast<std::chrono::nanoseconds>(duration), decimals);
153  }
163  static std::string pretty_print(long nanoseconds, int decimals=6) noexcept {
164  std::ostringstream os;
165  if (nanoseconds < 0){
166  nanoseconds *= -1;
167  os << '-';
168  }
169  const auto fraction = nanoseconds % 1'000'000'000;
170  nanoseconds = (nanoseconds - fraction) / 1'000'000'000;
171  const auto seconds = nanoseconds % 60;
172  nanoseconds = (nanoseconds - seconds) / 60;
173  const auto minutes = nanoseconds % 60;
174  nanoseconds = (nanoseconds - minutes) / 60;
175  const auto hours = nanoseconds % 24;
176  nanoseconds = (nanoseconds - hours) / 24;
177 
178  if (nanoseconds > 0){ // days
179  os << nanoseconds << ':';
180  }
181  if (os.tellp() || hours > 0){ // hours
182  if (os.tellp() > 0){
183  os << std::setfill('0') << std::setw(2);
184  }
185  os << hours << ':';
186  }
187  if (os.tellp() || minutes > 0){ // minutes
188  if (os.tellp() > 0){
189  os << std::setfill('0') << std::setw(2);
190  }
191  os << minutes << ':';
192  }
193 
194  if (os.tellp()){
195  os << std::setfill('0') << std::setw(2) << seconds;
196  } else {
197  os << seconds;
198  }
199 
200  // .fraction
201  if (decimals > 0){
202  os << '.' << std::setfill('0') << std::setw(decimals);
203  if (decimals == 9){
204  os << fraction;
205  } else {
206  os << static_cast<unsigned long>(fraction * std::pow(10, decimals - 9));
207  }
208  }
209 
210  return os.str();
211  }
212 
213 private:
214  time_point mark_{clock::now()};
216 };
217 
218 } // namespace focs
219 
220 #endif // FOCS_STOPWATCH
221 
auto seconds() const noexcept
Return elapsed time in seconds.
Definition: Stopwatch.hpp:90
data_t t[NROOTS+1]
Definition: decode_rs.h:77
auto us() const noexcept
Return elapsed time in microseconds.
Definition: Stopwatch.hpp:82
auto ms() const noexcept
Return elapsed time in milliseconds.
Definition: Stopwatch.hpp:86
auto s() const noexcept
Return elapsed time in seconds (alias for seconds()).
Definition: Stopwatch.hpp:98
no change in intended resolving MODur00064 Corrected handling of bad ephemeris attitude resolving resolving GSFcd00179 Corrected handling of fill values for[Sensor|Solar][Zenith|Azimuth] resolving MODxl01751 Changed to validate LUT version against a value retrieved from the resolving MODxl02056 Changed to calculate Solar Diffuser angles without adjustment for estimated post launch changes in the MODIS orientation relative to incidentally resolving defects MODxl01766 Also resolves MODxl01947 Changed to ignore fill values in SCI_ABNORM and SCI_STATE rather than treating them as resolving MODxl01780 Changed to use spacecraft ancillary data to recognise when the mirror encoder data is being set by side A or side B and to change calculations accordingly This removes the need for seperate LUTs for Side A and Side B data it makes the new LUTs incompatible with older versions of the and vice versa Also resolves MODxl01685 A more robust GRing algorithm is being which will create a non default GRing anytime there s even a single geolocated pixel in a granule Removed obsolete messages from seed as required for compatibility with version of the SDP toolkit Corrected test output file names to end in out
Definition: HISTORY.txt:422
time_point mark()
Return the mark in its native format.
Definition: Stopwatch.hpp:117
void reset(const time_point t) noexcept
Reset stopwatch to specified mark. This function is mostly for testing.
Definition: Stopwatch.hpp:48
void reset() noexcept
Reset stopwatch to current (arbitrary) time.
Definition: Stopwatch.hpp:35
auto h() const noexcept
Return elapsed time in hours.
Definition: Stopwatch.hpp:106
auto ns() const noexcept
Return elapsed time in nanoseconds.
Definition: Stopwatch.hpp:78
but the philosophy of the MODIS L1 routines is that the output granule must be if it contains even a single packet of useable data Some of the spacecraft ancillary data in L0 datasets is available only on a cycle that repeates every seconds MOD_PR01 therefore looks backwards up to seconds
Definition: MOD_PR01_pr.txt:31
@ string
static std::string pretty_print(long nanoseconds, int decimals=6) noexcept
Pretty-print the given nanoseconds as <days>:<hours>:<minutes>:<seconds>.<decimals>.
Definition: Stopwatch.hpp:163
auto d() const noexcept
Return elapsed time in days.
Definition: Stopwatch.hpp:110
subroutine os(tamoy, trmoy, pizmoy, tamoyp, trmoyp, palt, phirad, nt, mu, np, rm, gb, rp, xl)
Definition: 6sm1.f:5484
Simple timer for profiling sections of code.
Definition: Stopwatch.hpp:29
auto now() const noexcept
Return elapsed time in the duration specified via the template. Use count() to get the actual value o...
Definition: Stopwatch.hpp:74
static std::string pretty_print(std::chrono::duration< T > duration, int decimals=6) noexcept
Pretty-print the given duration as <days>:<hours>:<minutes>:<seconds>.<decimals>.
Definition: Stopwatch.hpp:151
auto m() const noexcept
Return elapsed time in minutes.
Definition: Stopwatch.hpp:102
friend std::ostream & operator<<(std::ostream &out, const Stopwatch &in)
Pretty print time elapsed to stream.
Definition: Stopwatch.hpp:137
u5 which has been done in the LOCALGRANULEID metadata should have an extension NRT It is requested to identify the NRT production Changes from v6 which may affect scientific the sector rotation may actually occur during one of the scans earlier than the one where it is first reported As a the b1 values are about the LOCALGRANULEID metadata should have an extension NRT It is requested to identify the NRT to fill pixels affected by dead subframes with a special value Output the metadata of noisy and dead subframe Dead Subframe EV and Detector Quality Flag2 Removed the function call of Fill_Dead_Detector_SI to stop interpolating SI values for dead but also for all downstream products for science test only Changes from v5 which will affect scientific to conform to MODIS requirements Removed the Mixed option from the ScanType in the code because the L1A Scan Type is never Mixed Changed for ANSI C compliance and comments to better document the fact that when the HDF_EOS metadata is stricly the and products are off by and in the track respectively Corrected some misspelling of RCS swir_oob_sending_detector to the Reflective LUTs to enable the SWIR OOB correction detector so that if any of the sending detectors becomes noisy or non near by good detectors from the same sending band can be specified as the substitute in the new look up table Code change for adding an additional dimension of mirror side to the Band_21_b1 LUT to separate the coefficient of the two mirror sides for just like other thermal emissive so that the L1B code can calibrate Band scan to scan with mirror side dependency which leads better calibration result Changes which do not affect scientific when the EV data are not provided in this Crosstalk Correction will not be performed to the Band calibration data Changes which do not affect scientific and BB_500m in L1A Logic was added to turn off the or to spatial aggregation processes and the EV_250m_Aggr1km_RefSB and EV_500m_Aggr1km_RefSB fields were set to fill values when SDSs EV_250m and EV_500m are absent in L1A file Logic was added to skip the processing and turn off the output of the L1B QKM and HKM EV data when EV_250m and EV_500m are absent from L1A In this the new process avoids accessing and reading the and L1A EV skips and writing to the L1B and EV omits reading and subsampling SDSs from geolocation file and writing them to the L1B and omits writing metadata to L1B and EV and skips closing the L1A and L1B EV and SDSs Logic was added to turn off the L1B OBC output when the high resolution OBC SDSs are absent from L1A This is accomplished by skipping the openning the writing of metadata and the closing of the L1B OBC hdf which is Bit in the scan by scan bit QA has been changed Until now
Definition: HISTORY.txt:361
std::string pretty(int decimals=6) const noexcept
Pretty-print the elapsed time.
Definition: Stopwatch.hpp:125
auto sec() const noexcept
Return elapsed time in seconds (alias for seconds()).
Definition: Stopwatch.hpp:94
void reset(const T d) noexcept
Reset stopwatch to specified mark. This function is mostly for testing.
Definition: Stopwatch.hpp:64