123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- #pragma once
- #include <ATen/core/Tensor.h>
- #include <ATen/AccumulateType.h>
- #include <ATen/Dispatch.h>
- #include <ATen/TensorUtils.h>
- namespace at { namespace native {
- namespace {
- static C10_UNUSED void multilabel_margin_loss_shape_check(
- int64_t& nframe,
- int64_t& dim,
- const int64_t& ndims,
- TensorArg& target_arg,
- const Tensor& input,
- const Tensor& target) {
- bool valid_inputs = (ndims == 2 && input.size(1) != 0) || (ndims == 1 && input.size(0) != 0) || ndims == 0;
- TORCH_CHECK(
- valid_inputs,
- "Expected non-empty vector or matrix with optional 0-dim batch size, but got: ",
- input.sizes());
- if (ndims <= 1) {
- nframe = 1;
- dim = ndims == 0 ? 1 : input.size(0);
- TORCH_CHECK(
- valid_inputs && target.dim() <= 1 && target.numel() == dim,
- "inconsistent size ",
- target.sizes(),
- " for ",
- target_arg);
- } else {
- nframe = input.size(0);
- dim = input.size(1);
- TORCH_CHECK(
- valid_inputs && target.dim() == 2 && target.size(0) == nframe &&
- target.size(1) == dim,
- "inconsistent size ",
- target.sizes(),
- " for ",
- target_arg);
- }
- }
- static C10_UNUSED void multi_margin_loss_shape_check(
- int64_t& nframe,
- int64_t& dim,
- const int64_t& ndims,
- TensorArg& target_arg,
- const Tensor& input,
- const Tensor& target) {
- bool valid_inputs = (ndims == 2 && input.size(1) != 0) || (ndims == 1 && input.size(0) != 0) || ndims == 0;
- if (ndims <= 1) {
- nframe = 1;
- dim = ndims == 0 ? 1 : input.size(0);
- } else {
- nframe = input.size(0);
- dim = input.size(1);
- }
- TORCH_CHECK(
- valid_inputs,
- "Expected non-empty vector or matrix with optional 0-dim batch size, but got: ",
- input.sizes());
- TORCH_CHECK(
- valid_inputs && target.dim() <= 1 && target.numel() == nframe,
- "inconsistent target size, got: ",
- target.sizes());
- }
- } // anonymous namespace
- }} // namespace at::native
|