Dispatch.h 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807
  1. #pragma once
  2. #include <c10/core/ScalarType.h>
  3. #include <c10/macros/Macros.h>
  4. #include <c10/util/Exception.h>
  5. #include <c10/util/Half.h>
  6. #include <c10/util/Metaprogramming.h>
  7. #include <c10/util/complex.h>
  8. #ifdef __CUDACC__
  9. #include <cuda.h> // For CUDA_VERSION
  10. #endif
  11. #ifdef TEMPLATE_SELECTIVE_BUILD
  12. #include <ATen/selected_mobile_ops.h>
  13. #else
  14. namespace at {
  15. /**
  16. * The method should_include_kernel_dtype() returns true/false
  17. * based on whether the switching code for a specific dtype should be
  18. * included based on build time constants generated from tracing model
  19. * execution. This method will be implemented via code-generation and
  20. * included in this file when code-gen is ready.
  21. */
  22. inline constexpr bool should_include_kernel_dtype(
  23. const char* /*kernel_tag_str*/,
  24. at::ScalarType /*scalar_type*/
  25. ) {
  26. return true;
  27. }
  28. } // namespace at
  29. #endif
  30. /**
  31. * In the Facebook internal build (using BUCK), this macro is enabled by
  32. * passing in -c pt.enable_record_kernel_dtype=1 when building the tracer
  33. * binary.
  34. */
  35. #if defined ENABLE_RECORD_KERNEL_FUNCTION_DTYPE
  36. namespace at::detail {
  37. TORCH_API void record_kernel_function_dtype(std::string name);
  38. } // namespace at::detail
  39. #define RECORD_KERNEL_FUNCTION_DTYPE(NAME, enum_type) \
  40. at::detail::record_kernel_function_dtype( \
  41. std::string(NAME) + "$" + toString(enum_type));
  42. #else
  43. #define RECORD_KERNEL_FUNCTION_DTYPE(NAME, enum_type)
  44. #endif
  45. #define AT_PRIVATE_CHECK_SELECTIVE_BUILD(enum_type) \
  46. do { \
  47. if constexpr (!at::should_include_kernel_dtype( \
  48. at_dispatch_name, enum_type)) { \
  49. TORCH_CHECK( \
  50. false, \
  51. "dtype '", \
  52. toString(enum_type), \
  53. "' not selected for kernel tag ", \
  54. at_dispatch_name); \
  55. } \
  56. } while (0)
  57. #define AT_PRIVATE_CASE_TYPE_USING_HINT(enum_type, HINT, ...) \
  58. case enum_type: { \
  59. AT_PRIVATE_CHECK_SELECTIVE_BUILD(enum_type); \
  60. using HINT [[maybe_unused]] = c10::impl::ScalarTypeToCPPTypeT<enum_type>; \
  61. return __VA_ARGS__(); \
  62. }
  63. #define AT_DISPATCH_CASE(enum_type, ...) \
  64. AT_PRIVATE_CASE_TYPE_USING_HINT(enum_type, scalar_t, __VA_ARGS__)
  65. #define AT_DISPATCH_CASE_QINT(enum_type, scalar_type, ...) \
  66. case enum_type: { \
  67. AT_PRIVATE_CHECK_SELECTIVE_BUILD(enum_type); \
  68. using scalar_t = scalar_type; \
  69. using underlying_t [[maybe_unused]] = typename scalar_t::underlying; \
  70. [[maybe_unused]] const auto& SCALAR_TYPE = enum_type; \
  71. [[maybe_unused]] const auto& UNDERLYING_TYPE = toUnderlying(enum_type); \
  72. return __VA_ARGS__(); \
  73. }
  74. #define AT_QINT_SUB_BYTE_PRIVATE_CASE_TYPE( \
  75. enum_type, scalar_type, bitwidth, qmin, qmax, ...) \
  76. case enum_type: { \
  77. AT_PRIVATE_CHECK_SELECTIVE_BUILD(enum_type); \
  78. using scalar_t = scalar_type; \
  79. using underlying_t [[maybe_unused]] = typename scalar_t::underlying; \
  80. [[maybe_unused]] const auto& SCALAR_TYPE = enum_type; \
  81. [[maybe_unused]] const auto& UNDERLYING_TYPE = toUnderlying(enum_type); \
  82. [[maybe_unused]] int bit_width = bitwidth; \
  83. [[maybe_unused]] int64_t quant_min = qmin; \
  84. [[maybe_unused]] int64_t quant_max = qmax; \
  85. return __VA_ARGS__(); \
  86. }
  87. namespace detail {
  88. inline at::ScalarType scalar_type(at::ScalarType s) {
  89. return s;
  90. }
  91. } // namespace detail
  92. // The AT_DISPATCH_* family of macros provides the ability to
  93. // conveniently generate specializations of a kernel over all of the
  94. // dtypes we care about in PyTorch. We call it "dispatch" because
  95. // we are "dispatching" to the correct, dtype-specific kernel.
  96. //
  97. // A standard usage looks like:
  98. //
  99. // AT_DISPATCH_ALL_TYPES(self.scalar_type(), "op_name", [&] {
  100. // // Your code here, with 'scalar_t' now defined to
  101. // // be the dtype in question
  102. // });
  103. //
  104. // There are many variations of this macro, so it's important to
  105. // understand exactly /which/ dtypes you want to get instantiated, as
  106. // well as what the "default" set is.
  107. //
  108. // The default set of dtypes that are instantiated (e.g., by
  109. // AT_DISPATCH_ALL_TYPES) are floating point types (float, double),
  110. // and integral types (int32_t, int64_t, int16_t, int8_t, uint8_t),
  111. // but NOT booleans (bool), half-precision floats (Half) or
  112. // complex number (c10::complex<float>, c10::complex<double>).
  113. // This "cut" is somewhat historical (the default types are the
  114. // ones that TH historically supported), but it also reflects the
  115. // fact that the non-default types are "poorly" behaved (booleans
  116. // are NOT integers mod 2, half precision operations ~essentially
  117. // don't exist on CPU, complex numbers are an experimental application).
  118. //
  119. // Here are the questions you should generally ask to decide which
  120. // dispatch you want:
  121. //
  122. // 1. Is this an integral or floating point specific operation?
  123. // (If so, you'll want one of the FLOATING or INTEGRAL macros.)
  124. //
  125. // 2. Should half be supported? (If you're on CPU, the answer is almost
  126. // definitely no. If you do want support, use one of the AND_HALF
  127. // macros)
  128. //
  129. // Much rarer situations:
  130. //
  131. // 3. Should bool be supported? (You often have to write your kernel
  132. // differently if arithmetic operations are involved.) If so,
  133. // Use AT_DISPATCH_ALL_TYPES_AND along with ScalarType::Bool
  134. //
  135. // 4. Should complex be supported? The answer is almost always no,
  136. // unless you are working on "generic" code that should work on
  137. // all dtypes.
  138. //
  139. // Parameters:
  140. // -----------
  141. //
  142. // 1. The NAME argument is a "tag" that is used to trace and then
  143. // conditionally compile fragments of the case statements such
  144. // that the kernel functions are specialized only for the dtypes
  145. // that are needed. The NAME parameter *must* be a build time
  146. // const char* (can't be std::string, etc...)
  147. //
  148. // Please ensure that the NAME is unique for every implementation
  149. // or you run the risk of over-including code for the kernel
  150. // functions. There is no risk of missing out on any code, so
  151. // it's mostly a risk of a Type-2 error, and not a Type-1 error.
  152. //
  153. // Switch-like syntax:
  154. // -------------------
  155. // There is also a switch-case like syntax which is useful if a kernel
  156. // needs to be specialized for particular scalar types
  157. //
  158. // AT_DISPATCH_SWITCH(self.scalar_type(), "op_name",
  159. // AT_DISPATCH_CASE_INTEGRAL_TYPES([&] {
  160. // op_integral<scalar_t>(iter);
  161. // })
  162. // AT_DISPATCH_CASE_FLOATING_TYPES([&] {
  163. // op_floating<scalar_t>(iter);
  164. // })
  165. // AT_DISPATCH_CASE(kBool, [&] {
  166. // op_bool(iter);
  167. // })
  168. // );
  169. //
  170. // For each AT_DISPATCH_FOO macro, there is a corresponding
  171. // AT_DISPATCH_CASE_FOO macro which can be used inside of an
  172. // AT_DISPATCH_SWITCH block.
  173. // NB: the the_type variable is not used, but we have kept it for
  174. // backwards compatibility. It's probably not used by anyone though;
  175. // but we're just being safe (and it doesn't hurt.) Note we must
  176. // use it to shut up warnings about unused store.
  177. #define AT_DISPATCH_SWITCH(TYPE, NAME, ...) \
  178. [&] { \
  179. const auto& the_type = TYPE; \
  180. constexpr const char* at_dispatch_name = NAME; \
  181. /* don't use TYPE again in case it is an expensive or side-effect op */ \
  182. at::ScalarType _st = ::detail::scalar_type(the_type); \
  183. RECORD_KERNEL_FUNCTION_DTYPE(at_dispatch_name, _st); \
  184. switch (_st) { \
  185. __VA_ARGS__ \
  186. default: \
  187. TORCH_CHECK_NOT_IMPLEMENTED( \
  188. false, \
  189. '"', \
  190. at_dispatch_name, \
  191. "\" not implemented for '", \
  192. toString(_st), \
  193. "'"); \
  194. } \
  195. }()
  196. #define AT_DISPATCH_CASE_FLOATING_TYPES(...) \
  197. AT_DISPATCH_CASE(at::ScalarType::Double, __VA_ARGS__) \
  198. AT_DISPATCH_CASE(at::ScalarType::Float, __VA_ARGS__)
  199. #define AT_DISPATCH_FLOATING_TYPES(TYPE, NAME, ...) \
  200. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__))
  201. #define AT_DISPATCH_CASE_FLOATING_TYPES_AND_HALF(...) \
  202. AT_DISPATCH_CASE(at::ScalarType::Double, __VA_ARGS__) \
  203. AT_DISPATCH_CASE(at::ScalarType::Float, __VA_ARGS__) \
  204. AT_DISPATCH_CASE(at::ScalarType::Half, __VA_ARGS__)
  205. #define AT_DISPATCH_FLOATING_TYPES_AND_HALF(TYPE, NAME, ...) \
  206. AT_DISPATCH_SWITCH( \
  207. TYPE, NAME, AT_DISPATCH_CASE_FLOATING_TYPES_AND_HALF(__VA_ARGS__))
  208. #define AT_DISPATCH_CASE_REDUCED_FLOATING_TYPES(...) \
  209. AT_DISPATCH_CASE(at::ScalarType::Half, __VA_ARGS__) \
  210. AT_DISPATCH_CASE(at::ScalarType::BFloat16, __VA_ARGS__)
  211. #define AT_DISPATCH_REDUCED_FLOATING_TYPES(TYPE, NAME, ...) \
  212. AT_DISPATCH_SWITCH( \
  213. TYPE, NAME, AT_DISPATCH_CASE_REDUCED_FLOATING_TYPES(__VA_ARGS__))
  214. #define AT_DISPATCH_CASE_FLOATING_TYPES_AND(SCALARTYPE, ...) \
  215. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__) \
  216. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  217. #define AT_DISPATCH_FLOATING_TYPES_AND(SCALARTYPE, TYPE, NAME, ...) \
  218. AT_DISPATCH_SWITCH( \
  219. TYPE, \
  220. NAME, \
  221. AT_DISPATCH_CASE_FLOATING_TYPES_AND(SCALARTYPE, __VA_ARGS__))
  222. #define AT_DISPATCH_CASE_FLOATING_TYPES_AND2(SCALARTYPE1, SCALARTYPE2, ...) \
  223. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__) \
  224. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  225. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__)
  226. #define AT_DISPATCH_FLOATING_TYPES_AND2( \
  227. SCALARTYPE1, SCALARTYPE2, TYPE, NAME, ...) \
  228. AT_DISPATCH_SWITCH( \
  229. TYPE, \
  230. NAME, \
  231. AT_DISPATCH_CASE_FLOATING_TYPES_AND2( \
  232. SCALARTYPE1, SCALARTYPE2, __VA_ARGS__))
  233. #define AT_DISPATCH_CASE_FLOATING_TYPES_AND3( \
  234. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, ...) \
  235. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__) \
  236. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  237. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  238. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__)
  239. #define AT_DISPATCH_FLOATING_TYPES_AND3( \
  240. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, TYPE, NAME, ...) \
  241. AT_DISPATCH_SWITCH( \
  242. TYPE, \
  243. NAME, \
  244. AT_DISPATCH_CASE_FLOATING_TYPES_AND3( \
  245. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, __VA_ARGS__))
  246. #define AT_DISPATCH_CASE_FLOATING_TYPES_AND4( \
  247. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, ...) \
  248. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__) \
  249. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  250. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  251. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  252. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__)
  253. #define AT_DISPATCH_CASE_FLOATING_TYPES_AND5( \
  254. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, SCALARTYPE5, ...) \
  255. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__) \
  256. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  257. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  258. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  259. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  260. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__)
  261. #define AT_DISPATCH_FLOATING_TYPES_AND4( \
  262. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, TYPE, NAME, ...) \
  263. AT_DISPATCH_SWITCH( \
  264. TYPE, \
  265. NAME, \
  266. AT_DISPATCH_CASE_FLOATING_TYPES_AND4( \
  267. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, __VA_ARGS__))
  268. #define AT_DISPATCH_FLOATING_TYPES_AND5( \
  269. SCALARTYPE1, \
  270. SCALARTYPE2, \
  271. SCALARTYPE3, \
  272. SCALARTYPE4, \
  273. SCALARTYPE5, \
  274. TYPE, \
  275. NAME, \
  276. ...) \
  277. AT_DISPATCH_SWITCH( \
  278. TYPE, \
  279. NAME, \
  280. AT_DISPATCH_CASE_FLOATING_TYPES_AND5( \
  281. SCALARTYPE1, \
  282. SCALARTYPE2, \
  283. SCALARTYPE3, \
  284. SCALARTYPE4, \
  285. SCALARTYPE5, \
  286. __VA_ARGS__))
  287. #define AT_DISPATCH_CASE_COMPLEX_TYPES(...) \
  288. AT_DISPATCH_CASE(at::ScalarType::ComplexDouble, __VA_ARGS__) \
  289. AT_DISPATCH_CASE(at::ScalarType::ComplexFloat, __VA_ARGS__)
  290. #define AT_DISPATCH_COMPLEX_TYPES(TYPE, NAME, ...) \
  291. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_COMPLEX_TYPES(__VA_ARGS__))
  292. #define AT_DISPATCH_CASE_COMPLEX_TYPES_AND(SCALARTYPE, ...) \
  293. AT_DISPATCH_CASE_COMPLEX_TYPES(__VA_ARGS__) \
  294. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  295. #define AT_DISPATCH_COMPLEX_TYPES_AND(SCALARTYPE, TYPE, NAME, ...) \
  296. AT_DISPATCH_SWITCH( \
  297. TYPE, NAME, AT_DISPATCH_CASE_COMPLEX_TYPES_AND(SCALARTYPE, __VA_ARGS__))
  298. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(...) \
  299. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__) \
  300. AT_DISPATCH_CASE_COMPLEX_TYPES(__VA_ARGS__)
  301. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES(TYPE, NAME, ...) \
  302. AT_DISPATCH_SWITCH( \
  303. TYPE, NAME, AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__))
  304. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND1(SCALARTYPE, ...) \
  305. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__) \
  306. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  307. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES_AND1( \
  308. SCALARTYPE, TYPE, NAME, ...) \
  309. AT_DISPATCH_SWITCH( \
  310. TYPE, \
  311. NAME, \
  312. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND1( \
  313. SCALARTYPE, __VA_ARGS__))
  314. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND2( \
  315. SCALARTYPE1, SCALARTYPE2, ...) \
  316. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__) \
  317. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  318. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__)
  319. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES_AND2( \
  320. SCALARTYPE1, SCALARTYPE2, TYPE, NAME, ...) \
  321. AT_DISPATCH_SWITCH( \
  322. TYPE, \
  323. NAME, \
  324. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND2( \
  325. SCALARTYPE1, SCALARTYPE2, __VA_ARGS__))
  326. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND3( \
  327. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, ...) \
  328. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__) \
  329. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  330. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  331. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__)
  332. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES_AND3( \
  333. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, TYPE, NAME, ...) \
  334. AT_DISPATCH_SWITCH( \
  335. TYPE, \
  336. NAME, \
  337. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND3( \
  338. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, __VA_ARGS__))
  339. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND4( \
  340. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, ...) \
  341. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__) \
  342. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  343. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  344. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  345. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__)
  346. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES_AND4( \
  347. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, TYPE, NAME, ...) \
  348. AT_DISPATCH_SWITCH( \
  349. TYPE, \
  350. NAME, \
  351. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND4( \
  352. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, __VA_ARGS__))
  353. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND5( \
  354. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, SCALARTYPE5, ...) \
  355. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__) \
  356. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  357. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  358. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  359. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  360. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__)
  361. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES_AND5( \
  362. SCALARTYPE1, \
  363. SCALARTYPE2, \
  364. SCALARTYPE3, \
  365. SCALARTYPE4, \
  366. SCALARTYPE5, \
  367. TYPE, \
  368. NAME, \
  369. ...) \
  370. AT_DISPATCH_SWITCH( \
  371. TYPE, \
  372. NAME, \
  373. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND5( \
  374. SCALARTYPE1, \
  375. SCALARTYPE2, \
  376. SCALARTYPE3, \
  377. SCALARTYPE4, \
  378. SCALARTYPE5, \
  379. __VA_ARGS__))
  380. #define AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND6( \
  381. SCALARTYPE1, \
  382. SCALARTYPE2, \
  383. SCALARTYPE3, \
  384. SCALARTYPE4, \
  385. SCALARTYPE5, \
  386. SCALARTYPE6, \
  387. ...) \
  388. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES(__VA_ARGS__) \
  389. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  390. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  391. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  392. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  393. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__) \
  394. AT_DISPATCH_CASE(SCALARTYPE6, __VA_ARGS__)
  395. #define AT_DISPATCH_FLOATING_AND_COMPLEX_TYPES_AND6( \
  396. SCALARTYPE1, \
  397. SCALARTYPE2, \
  398. SCALARTYPE3, \
  399. SCALARTYPE4, \
  400. SCALARTYPE5, \
  401. SCALARTYPE6, \
  402. TYPE, \
  403. NAME, \
  404. ...) \
  405. AT_DISPATCH_SWITCH( \
  406. TYPE, \
  407. NAME, \
  408. AT_DISPATCH_CASE_FLOATING_AND_COMPLEX_TYPES_AND6( \
  409. SCALARTYPE1, \
  410. SCALARTYPE2, \
  411. SCALARTYPE3, \
  412. SCALARTYPE4, \
  413. SCALARTYPE5, \
  414. SCALARTYPE6, \
  415. __VA_ARGS__))
  416. #define AT_DISPATCH_CASE_INTEGRAL_TYPES(...) \
  417. AT_DISPATCH_CASE(at::ScalarType::Byte, __VA_ARGS__) \
  418. AT_DISPATCH_CASE(at::ScalarType::Char, __VA_ARGS__) \
  419. AT_DISPATCH_CASE(at::ScalarType::Int, __VA_ARGS__) \
  420. AT_DISPATCH_CASE(at::ScalarType::Long, __VA_ARGS__) \
  421. AT_DISPATCH_CASE(at::ScalarType::Short, __VA_ARGS__)
  422. #define AT_DISPATCH_INTEGRAL_TYPES(TYPE, NAME, ...) \
  423. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_INTEGRAL_TYPES(__VA_ARGS__))
  424. #define AT_DISPATCH_CASE_INTEGRAL_TYPES_AND(SCALARTYPE, ...) \
  425. AT_DISPATCH_CASE_INTEGRAL_TYPES(__VA_ARGS__) \
  426. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  427. #define AT_DISPATCH_INTEGRAL_TYPES_AND(SCALARTYPE, TYPE, NAME, ...) \
  428. AT_DISPATCH_SWITCH( \
  429. TYPE, \
  430. NAME, \
  431. AT_DISPATCH_CASE_INTEGRAL_TYPES_AND(SCALARTYPE, __VA_ARGS__))
  432. #define AT_DISPATCH_CASE_ALL_TYPES(...) \
  433. AT_DISPATCH_CASE_INTEGRAL_TYPES(__VA_ARGS__) \
  434. AT_DISPATCH_CASE_FLOATING_TYPES(__VA_ARGS__)
  435. #define AT_DISPATCH_ALL_TYPES(TYPE, NAME, ...) \
  436. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_ALL_TYPES(__VA_ARGS__))
  437. #define AT_DISPATCH_CASE_QINT_TYPES(...) \
  438. AT_DISPATCH_CASE_QINT(at::kQInt8, at::qint8, __VA_ARGS__) \
  439. AT_DISPATCH_CASE_QINT(at::kQUInt8, at::quint8, __VA_ARGS__) \
  440. AT_DISPATCH_CASE_QINT(at::kQInt32, at::qint32, __VA_ARGS__)
  441. #define AT_DISPATCH_QINT_TYPES(TYPE, NAME, ...) \
  442. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_QINT_TYPES(__VA_ARGS__))
  443. #define AT_DISPATCH_CASE_QINT_TYPES_AND(SCALARTYPE, ...) \
  444. AT_DISPATCH_CASE_QINT_TYPES(__VA_ARGS__) \
  445. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  446. #define AT_DISPATCH_QINT_TYPES_AND(SCALARTYPE, TYPE, NAME, ...) \
  447. AT_DISPATCH_SWITCH( \
  448. TYPE, NAME, AT_DISPATCH_CASE_QINT_TYPES_AND(SCALARTYPE, __VA_ARGS__))
  449. #define AT_DISPATCH_CASE_QINT_BYTE_TYPES(...) \
  450. AT_DISPATCH_CASE_QINT(at::kQInt8, at::qint8, __VA_ARGS__) \
  451. AT_DISPATCH_CASE_QINT(at::kQUInt8, at::quint8, __VA_ARGS__)
  452. #define AT_DISPATCH_QINT_BYTE_TYPES(TYPE, NAME, ...) \
  453. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_QINT_BYTE_TYPES(__VA_ARGS__))
  454. #define AT_DISPATCH_CASE_QINT_AND_SUB_BYTE_TYPES(...) \
  455. AT_QINT_SUB_BYTE_PRIVATE_CASE_TYPE( \
  456. at::kQInt8, at::qint8, CHAR_BIT, SCHAR_MIN, SCHAR_MAX, __VA_ARGS__) \
  457. AT_QINT_SUB_BYTE_PRIVATE_CASE_TYPE( \
  458. at::kQUInt8, at::quint8, CHAR_BIT, 0, UCHAR_MAX, __VA_ARGS__) \
  459. AT_QINT_SUB_BYTE_PRIVATE_CASE_TYPE( \
  460. at::kQInt32, \
  461. at::qint32, \
  462. CHAR_BIT * sizeof(int), \
  463. INT_MIN, \
  464. INT_MAX, \
  465. __VA_ARGS__) \
  466. AT_QINT_SUB_BYTE_PRIVATE_CASE_TYPE( \
  467. at::kQUInt4x2, at::quint4x2, 4, 0, 15, __VA_ARGS__) \
  468. AT_QINT_SUB_BYTE_PRIVATE_CASE_TYPE( \
  469. at::kQUInt2x4, at::quint2x4, 2, 0, 3, __VA_ARGS__)
  470. #define AT_DISPATCH_QINT_AND_SUB_BYTE_TYPES(TYPE, NAME, ...) \
  471. AT_DISPATCH_SWITCH( \
  472. TYPE, NAME, AT_DISPATCH_CASE_QINT_AND_SUB_BYTE_TYPES(__VA_ARGS__))
  473. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(...) \
  474. AT_DISPATCH_CASE_ALL_TYPES(__VA_ARGS__) \
  475. AT_DISPATCH_CASE_COMPLEX_TYPES(__VA_ARGS__)
  476. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX(TYPE, NAME, ...) \
  477. AT_DISPATCH_SWITCH( \
  478. TYPE, NAME, AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__))
  479. #define AT_DISPATCH_CASE_ALL_TYPES_AND(SCALARTYPE, ...) \
  480. AT_DISPATCH_CASE_ALL_TYPES(__VA_ARGS__) \
  481. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  482. #define AT_DISPATCH_ALL_TYPES_AND(SCALARTYPE, TYPE, NAME, ...) \
  483. AT_DISPATCH_SWITCH( \
  484. TYPE, NAME, AT_DISPATCH_CASE_ALL_TYPES_AND(SCALARTYPE, __VA_ARGS__))
  485. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND(SCALARTYPE, ...) \
  486. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  487. AT_DISPATCH_CASE(SCALARTYPE, __VA_ARGS__)
  488. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND(SCALARTYPE, TYPE, NAME, ...) \
  489. AT_DISPATCH_SWITCH( \
  490. TYPE, \
  491. NAME, \
  492. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND(SCALARTYPE, __VA_ARGS__))
  493. #define AT_DISPATCH_CASE_ALL_TYPES_AND2(SCALARTYPE1, SCALARTYPE2, ...) \
  494. AT_DISPATCH_CASE_ALL_TYPES(__VA_ARGS__) \
  495. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  496. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__)
  497. #define AT_DISPATCH_ALL_TYPES_AND2(SCALARTYPE1, SCALARTYPE2, TYPE, NAME, ...) \
  498. AT_DISPATCH_SWITCH( \
  499. TYPE, \
  500. NAME, \
  501. AT_DISPATCH_CASE_ALL_TYPES_AND2(SCALARTYPE1, SCALARTYPE2, __VA_ARGS__))
  502. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND2( \
  503. SCALARTYPE1, SCALARTYPE2, ...) \
  504. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  505. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  506. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__)
  507. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND2( \
  508. SCALARTYPE1, SCALARTYPE2, TYPE, NAME, ...) \
  509. AT_DISPATCH_SWITCH( \
  510. TYPE, \
  511. NAME, \
  512. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND2( \
  513. SCALARTYPE1, SCALARTYPE2, __VA_ARGS__))
  514. #define AT_DISPATCH_CASE_ALL_TYPES_AND3( \
  515. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, ...) \
  516. AT_DISPATCH_CASE_ALL_TYPES(__VA_ARGS__) \
  517. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  518. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  519. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__)
  520. #define AT_DISPATCH_ALL_TYPES_AND3( \
  521. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, TYPE, NAME, ...) \
  522. AT_DISPATCH_SWITCH( \
  523. TYPE, \
  524. NAME, \
  525. AT_DISPATCH_CASE_ALL_TYPES_AND3( \
  526. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, __VA_ARGS__))
  527. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND3( \
  528. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, ...) \
  529. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  530. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  531. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  532. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__)
  533. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND3( \
  534. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, TYPE, NAME, ...) \
  535. AT_DISPATCH_SWITCH( \
  536. TYPE, \
  537. NAME, \
  538. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND3( \
  539. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, __VA_ARGS__))
  540. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND4( \
  541. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, ...) \
  542. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  543. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  544. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  545. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  546. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__)
  547. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND4( \
  548. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, TYPE, NAME, ...) \
  549. AT_DISPATCH_SWITCH( \
  550. TYPE, \
  551. NAME, \
  552. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND4( \
  553. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, __VA_ARGS__))
  554. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND5( \
  555. SCALARTYPE1, SCALARTYPE2, SCALARTYPE3, SCALARTYPE4, SCALARTYPE5, ...) \
  556. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  557. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  558. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  559. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  560. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  561. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__)
  562. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND5( \
  563. SCALARTYPE1, \
  564. SCALARTYPE2, \
  565. SCALARTYPE3, \
  566. SCALARTYPE4, \
  567. SCALARTYPE5, \
  568. TYPE, \
  569. NAME, \
  570. ...) \
  571. AT_DISPATCH_SWITCH( \
  572. TYPE, \
  573. NAME, \
  574. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND5( \
  575. SCALARTYPE1, \
  576. SCALARTYPE2, \
  577. SCALARTYPE3, \
  578. SCALARTYPE4, \
  579. SCALARTYPE5, \
  580. __VA_ARGS__))
  581. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND6( \
  582. SCALARTYPE1, \
  583. SCALARTYPE2, \
  584. SCALARTYPE3, \
  585. SCALARTYPE4, \
  586. SCALARTYPE5, \
  587. SCALARTYPE6, \
  588. ...) \
  589. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  590. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  591. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  592. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  593. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  594. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__) \
  595. AT_DISPATCH_CASE(SCALARTYPE6, __VA_ARGS__)
  596. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND6( \
  597. SCALARTYPE1, \
  598. SCALARTYPE2, \
  599. SCALARTYPE3, \
  600. SCALARTYPE4, \
  601. SCALARTYPE5, \
  602. SCALARTYPE6, \
  603. TYPE, \
  604. NAME, \
  605. ...) \
  606. AT_DISPATCH_SWITCH( \
  607. TYPE, \
  608. NAME, \
  609. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND6( \
  610. SCALARTYPE1, \
  611. SCALARTYPE2, \
  612. SCALARTYPE3, \
  613. SCALARTYPE4, \
  614. SCALARTYPE5, \
  615. SCALARTYPE6, \
  616. __VA_ARGS__))
  617. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND7( \
  618. SCALARTYPE1, \
  619. SCALARTYPE2, \
  620. SCALARTYPE3, \
  621. SCALARTYPE4, \
  622. SCALARTYPE5, \
  623. SCALARTYPE6, \
  624. SCALARTYPE7, \
  625. ...) \
  626. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  627. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  628. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  629. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  630. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  631. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__) \
  632. AT_DISPATCH_CASE(SCALARTYPE6, __VA_ARGS__) \
  633. AT_DISPATCH_CASE(SCALARTYPE7, __VA_ARGS__)
  634. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND7( \
  635. SCALARTYPE1, \
  636. SCALARTYPE2, \
  637. SCALARTYPE3, \
  638. SCALARTYPE4, \
  639. SCALARTYPE5, \
  640. SCALARTYPE6, \
  641. SCALARTYPE7, \
  642. TYPE, \
  643. NAME, \
  644. ...) \
  645. AT_DISPATCH_SWITCH( \
  646. TYPE, \
  647. NAME, \
  648. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND7( \
  649. SCALARTYPE1, \
  650. SCALARTYPE2, \
  651. SCALARTYPE3, \
  652. SCALARTYPE4, \
  653. SCALARTYPE5, \
  654. SCALARTYPE6, \
  655. SCALARTYPE7, \
  656. __VA_ARGS__))
  657. #define AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND8( \
  658. SCALARTYPE1, \
  659. SCALARTYPE2, \
  660. SCALARTYPE3, \
  661. SCALARTYPE4, \
  662. SCALARTYPE5, \
  663. SCALARTYPE6, \
  664. SCALARTYPE7, \
  665. SCALARTYPE8, \
  666. ...) \
  667. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX(__VA_ARGS__) \
  668. AT_DISPATCH_CASE(SCALARTYPE1, __VA_ARGS__) \
  669. AT_DISPATCH_CASE(SCALARTYPE2, __VA_ARGS__) \
  670. AT_DISPATCH_CASE(SCALARTYPE3, __VA_ARGS__) \
  671. AT_DISPATCH_CASE(SCALARTYPE4, __VA_ARGS__) \
  672. AT_DISPATCH_CASE(SCALARTYPE5, __VA_ARGS__) \
  673. AT_DISPATCH_CASE(SCALARTYPE6, __VA_ARGS__) \
  674. AT_DISPATCH_CASE(SCALARTYPE7, __VA_ARGS__) \
  675. AT_DISPATCH_CASE(SCALARTYPE8, __VA_ARGS__)
  676. #define AT_DISPATCH_ALL_TYPES_AND_COMPLEX_AND8( \
  677. SCALARTYPE1, \
  678. SCALARTYPE2, \
  679. SCALARTYPE3, \
  680. SCALARTYPE4, \
  681. SCALARTYPE5, \
  682. SCALARTYPE6, \
  683. SCALARTYPE7, \
  684. SCALARTYPE8, \
  685. TYPE, \
  686. NAME, \
  687. ...) \
  688. AT_DISPATCH_SWITCH( \
  689. TYPE, \
  690. NAME, \
  691. AT_DISPATCH_CASE_ALL_TYPES_AND_COMPLEX_AND8( \
  692. SCALARTYPE1, \
  693. SCALARTYPE2, \
  694. SCALARTYPE3, \
  695. SCALARTYPE4, \
  696. SCALARTYPE5, \
  697. SCALARTYPE6, \
  698. SCALARTYPE7, \
  699. SCALARTYPE8, \
  700. __VA_ARGS__))
  701. #define AT_DISPATCH_CASE_BIT_TYPES(...) \
  702. AT_DISPATCH_CASE(at::ScalarType::Bits1x8, __VA_ARGS__) \
  703. AT_DISPATCH_CASE(at::ScalarType::Bits2x4, __VA_ARGS__) \
  704. AT_DISPATCH_CASE(at::ScalarType::Bits4x2, __VA_ARGS__) \
  705. AT_DISPATCH_CASE(at::ScalarType::Bits8, __VA_ARGS__) \
  706. AT_DISPATCH_CASE(at::ScalarType::Bits16, __VA_ARGS__)
  707. #define AT_DISPATCH_BIT_TYPES(TYPE, NAME, ...) \
  708. AT_DISPATCH_SWITCH(TYPE, NAME, AT_DISPATCH_CASE_BIT_TYPES(__VA_ARGS__))
  709. #define AT_DISPATCH_INDEX_TYPES(TYPE, NAME, ...) \
  710. AT_DISPATCH_SWITCH( \
  711. TYPE, \
  712. NAME, \
  713. AT_PRIVATE_CASE_TYPE_USING_HINT( \
  714. at::ScalarType::Int, index_t, __VA_ARGS__) \
  715. AT_PRIVATE_CASE_TYPE_USING_HINT( \
  716. at::ScalarType::Long, index_t, __VA_ARGS__))