pytorch/test/cpp/tensorexpr/padded_buffer.cpp
Richard Barnes e0643fa3fc use irange for loops 5 (#66744)
Summary:
Pull Request resolved: https://github.com/pytorch/pytorch/pull/66744

Modified loops in files under fbsource/fbcode/caffe2/ from the format

`for(TYPE var=x0;var<x_max;x++)`

to the format

`for(const auto var: irange(xmax))`

This was achieved by running r-barnes's loop upgrader script (D28874212) with some modification to exclude all files under /torch/jit and a number of reversions or unused variable suppression warnings added by hand.

Test Plan: Sandcastle

Reviewed By: ngimel

Differential Revision: D31705358

fbshipit-source-id: d6ea350cbaa8f452fc78f238160e5374be637a48
2021-10-18 21:59:50 -07:00

38 lines
941 B
C++

#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 {
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