File: time_observer.cc

package info (click to toggle)
pytorch 1.13.1%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 139,252 kB
  • sloc: cpp: 1,100,274; python: 706,454; ansic: 83,052; asm: 7,618; java: 3,273; sh: 2,841; javascript: 612; makefile: 323; xml: 269; ruby: 185; yacc: 144; objc: 68; lex: 44
file content (38 lines) | stat: -rw-r--r-- 1,133 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#include "time_observer.h"
#include "caffe2/core/logging.h"

namespace caffe2 {

void TimeObserver::Start() {
  start_time_ = timer_.MilliSeconds();
  ++iterations_;
}

void TimeObserver::Stop() {
  double current_run = timer_.MilliSeconds() - start_time_;
  // NOLINTNEXTLINE(cppcoreguidelines-narrowing-conversions,bugprone-narrowing-conversions)
  total_time_ += current_run;
  VLOG(1) << "This net iteration took " << current_run << " ms to complete.\n";
}

void TimeOperatorObserver::Start() {
  start_time_ = timer_.MilliSeconds();
  ++iterations_;
}

void TimeOperatorObserver::Stop() {
  double current_run = timer_.MilliSeconds() - start_time_;
  // NOLINTNEXTLINE(cppcoreguidelines-narrowing-conversions,bugprone-narrowing-conversions)
  total_time_ += current_run;
  VLOG(1) << "This operator iteration took " << current_run
          << " ms to complete.\n";
}

std::unique_ptr<ObserverBase<OperatorBase>> TimeOperatorObserver::rnnCopy(
    OperatorBase* subject,
    int rnn_order) const {
  return std::unique_ptr<ObserverBase<OperatorBase>>(
      new TimeOperatorObserver(subject, nullptr));
}

} // namespace caffe2