1#pragma once
2
3// @generated by torchgen/gen.py from Function.h
4
5#include <ATen/Context.h>
6#include <ATen/DeviceGuard.h>
7#include <ATen/TensorUtils.h>
8#include <ATen/TracerMode.h>
9#include <ATen/core/Generator.h>
10#include <ATen/core/Reduction.h>
11#include <ATen/core/Tensor.h>
12#include <c10/core/Scalar.h>
13#include <c10/core/Storage.h>
14#include <c10/core/TensorOptions.h>
15#include <c10/util/Deprecated.h>
16#include <c10/util/Optional.h>
17
18
19
20#include <ATen/ops/median_ops.h>
21
22namespace at {
23
24
25// aten::median(Tensor self) -> Tensor
26inline at::Tensor median(const at::Tensor & self) {
27 return at::_ops::median::call(self);
28}
29
30// aten::median.dim(Tensor self, int dim, bool keepdim=False) -> (Tensor values, Tensor indices)
31inline ::std::tuple<at::Tensor,at::Tensor> median(const at::Tensor & self, int64_t dim, bool keepdim=false) {
32 return at::_ops::median_dim::call(self, dim, keepdim);
33}
34
35// aten::median.dim_values(Tensor self, int dim, bool keepdim=False, *, Tensor(a!) values, Tensor(b!) indices) -> (Tensor(a!) values, Tensor(b!) indices)
36inline ::std::tuple<at::Tensor &,at::Tensor &> median_out(at::Tensor & values, at::Tensor & indices, const at::Tensor & self, int64_t dim, bool keepdim=false) {
37 return at::_ops::median_dim_values::call(self, dim, keepdim, values, indices);
38}
39// aten::median.dim_values(Tensor self, int dim, bool keepdim=False, *, Tensor(a!) values, Tensor(b!) indices) -> (Tensor(a!) values, Tensor(b!) indices)
40inline ::std::tuple<at::Tensor &,at::Tensor &> median_outf(const at::Tensor & self, int64_t dim, bool keepdim, at::Tensor & values, at::Tensor & indices) {
41 return at::_ops::median_dim_values::call(self, dim, keepdim, values, indices);
42}
43
44// aten::median.names_dim(Tensor self, Dimname dim, bool keepdim=False) -> (Tensor values, Tensor indices)
45inline ::std::tuple<at::Tensor,at::Tensor> median(const at::Tensor & self, at::Dimname dim, bool keepdim=false) {
46 return at::_ops::median_names_dim::call(self, dim, keepdim);
47}
48
49// aten::median.names_dim_values(Tensor self, Dimname dim, bool keepdim=False, *, Tensor(a!) values, Tensor(b!) indices) -> (Tensor(a!) values, Tensor(b!) indices)
50inline ::std::tuple<at::Tensor &,at::Tensor &> median_out(at::Tensor & values, at::Tensor & indices, const at::Tensor & self, at::Dimname dim, bool keepdim=false) {
51 return at::_ops::median_names_dim_values::call(self, dim, keepdim, values, indices);
52}
53// aten::median.names_dim_values(Tensor self, Dimname dim, bool keepdim=False, *, Tensor(a!) values, Tensor(b!) indices) -> (Tensor(a!) values, Tensor(b!) indices)
54inline ::std::tuple<at::Tensor &,at::Tensor &> median_outf(const at::Tensor & self, at::Dimname dim, bool keepdim, at::Tensor & values, at::Tensor & indices) {
55 return at::_ops::median_names_dim_values::call(self, dim, keepdim, values, indices);
56}
57
58// aten::median.out(Tensor self, *, Tensor(a!) out) -> Tensor(a!)
59inline at::Tensor & median_out(at::Tensor & out, const at::Tensor & self) {
60 return at::_ops::median_out::call(self, out);
61}
62// aten::median.out(Tensor self, *, Tensor(a!) out) -> Tensor(a!)
63inline at::Tensor & median_outf(const at::Tensor & self, at::Tensor & out) {
64 return at::_ops::median_out::call(self, out);
65}
66
67}
68