File: test_rand.cpp

package info (click to toggle)
pytorch-cuda 2.6.0%2Bdfsg-7
  • links: PTS, VCS
  • area: contrib
  • in suites: forky, sid, trixie
  • size: 161,620 kB
  • sloc: python: 1,278,832; cpp: 900,322; ansic: 82,710; asm: 7,754; java: 3,363; sh: 2,811; javascript: 2,443; makefile: 597; ruby: 195; xml: 84; objc: 68
file content (39 lines) | stat: -rw-r--r-- 852 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
38
39
#include <gtest/gtest.h>

#include <ATen/core/PhiloxRNGEngine.h>

#include <cstdint>
#include <iostream>
namespace torch {
namespace aot_inductor {

int64_t randint64_cpu(
    uint32_t seed,
    uint32_t offset,
    int64_t low,
    int64_t high) {
  auto gen = at::Philox4_32(seed, 0, offset);
  uint64_t r0 = gen();
  uint64_t r1 = gen();
  uint64_t result = r0 | (r1 << 32);
  return static_cast<int64_t>(result % (high - low)) + low;
}

TEST(TestRand, TestRandn) {
  at::Philox4_32 engine_1(1, 0, 0);
  float a = engine_1.randn(10);
  at::Philox4_32 engine_2(1, 0, 0);
  float b = engine_2.randn(10);

  EXPECT_EQ(a, b);
}

TEST(TestRand, TestRandint64) {
  int64_t a = randint64_cpu(0xffffffff, 100, 0, INT64_MAX);
  int64_t b = randint64_cpu(0xffffffff, 100, 0, INT64_MAX);

  EXPECT_EQ(a, b);
}

} // namespace aot_inductor
} // namespace torch