File: padded_buffer.cpp

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 (37 lines) | stat: -rw-r--r-- 947 bytes parent folder | download | duplicates (3)
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
#include "test/cpp/tensorexpr/padded_buffer.h"

#include <c10/util/Logging.h>
#include <c10/util/irange.h>
#include <sstream>

namespace torch {
namespace jit {
namespace tensorexpr {

int PaddedBufferBase::Index(const std::vector<int>& indices) const {
  TORCH_DCHECK_EQ(dims_.size(), indices.size());
  int total_index = 0;
  for (const auto i : c10::irange(dims_.size())) {
    total_index += indices[i] * strides_[i];
  }
  return total_index;
}

PaddedBufferBase::PaddedBufferBase(
    const std::vector<int>& dims,
    // NOLINTNEXTLINE(modernize-pass-by-value)
    const std::string& name)
    : dims_(dims), name_(name), strides_(dims.size()) {
  for (int i = (int)dims.size() - 1; i >= 0; --i) {
    if (i == (int)dims.size() - 1) {
      strides_[i] = 1;
    } else {
      strides_[i] = strides_[i + 1] * dims[i + 1];
    }
  }
  total_size_ = strides_[0] * dims[0];
}

} // namespace tensorexpr
} // namespace jit
} // namespace torch