forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathblob_stats.h
46 lines (36 loc) · 1.1 KB
/
blob_stats.h
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
39
40
41
42
43
44
45
46
#pragma once
#include "c10/util/Registry.h"
#include "caffe2/core/blob.h"
#include "caffe2/core/typeid.h"
#include <unordered_map>
namespace caffe2 {
struct BlobStatGetter {
virtual size_t sizeBytes(const Blob& blob) const = 0;
virtual ~BlobStatGetter() {}
};
struct BlobStatRegistry {
private:
std::unordered_map<TypeIdentifier, std::unique_ptr<BlobStatGetter>> map_;
void doRegister(TypeIdentifier id, std::unique_ptr<BlobStatGetter>&& v);
public:
template <typename T, typename Getter>
struct Registrar {
Registrar() {
BlobStatRegistry::instance().doRegister(
TypeMeta::Id<T>(), std::unique_ptr<Getter>(new Getter));
}
};
const BlobStatGetter* get(TypeIdentifier id);
static BlobStatRegistry& instance();
};
#define REGISTER_BLOB_STAT_GETTER(Type, BlobStatGetterClass) \
static BlobStatRegistry::Registrar<Type, BlobStatGetterClass> \
C10_ANONYMOUS_VARIABLE(BlobStatRegistry)
namespace BlobStat {
/**
* Return size in bytes of the blob, if available for a blob of given type.
* If not available, return 0.
*/
CAFFE2_API size_t sizeBytes(const Blob& blob);
}
}