reid from https://github.com/michuanhaohao/reid-strong-baseline
zhangmeng
2020-01-17 f7c4a3cfd07adede3308f8d9d3d7315427d90a7c
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
#ifndef CAFFE2_CORE_NET_ASYNC_SCHEDULING_H_
#define CAFFE2_CORE_NET_ASYNC_SCHEDULING_H_
 
#include "caffe2/core/net_async_base.h"
 
namespace caffe2 {
 
class CAFFE2_API AsyncSchedulingNet : public AsyncNetBase {
 public:
  AsyncSchedulingNet(
      const std::shared_ptr<const NetDef>& net_def,
      Workspace* ws);
  ~AsyncSchedulingNet() override;
 
  void Wait() override;
 
 protected:
  bool RunAsync() override;
 
  void pollAndSchedule(int task_id);
  void schedule(int task_id, bool run_inline = false) noexcept;
  void reset() override;
  virtual void finishRun();
  void parentCallback(int parent_id);
  bool isInlineTask(int parent_id, int child_id) const;
 
  std::mutex running_mutex_;
  std::condition_variable running_cv_;
  std::atomic<bool> running_;
 
  std::atomic<int> processed_tasks_num_;
 
  C10_DISABLE_COPY_AND_ASSIGN(AsyncSchedulingNet);
};
 
} // namespace caffe2
 
#endif // CAFFE2_CORE_NET_ASYNC_SCHEDULING_H_