File: test_0557_min_max_initial_argument.py

package info (click to toggle)
python-awkward 2.8.9-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,932 kB
  • sloc: python: 178,875; cpp: 33,828; sh: 432; makefile: 21; javascript: 8
file content (112 lines) | stat: -rw-r--r-- 4,300 bytes parent folder | download
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
# BSD 3-Clause License; see https://github.com/scikit-hep/awkward/blob/main/LICENSE

from __future__ import annotations

import numpy as np
import pytest  # noqa: F401

import awkward as ak

to_list = ak.operations.to_list

primes = [x for x in range(2, 1000) if all(x % n != 0 for n in range(2, x))]


def test():
    data = ak.highlevel.Array([[1, 3, 5, 4, 2], [], [2, 3, 1], [5]]).layout
    assert to_list(ak.min(data, axis=1, initial=4, highlevel=False)) == [1, None, 1, 4]
    assert (
        ak.min(data.to_typetracer(), axis=1, initial=4, highlevel=False).form
        == ak.min(data, axis=1, initial=4, highlevel=False).form
    )
    assert to_list(ak.min(data, axis=1, highlevel=False)) == [1, None, 1, 5]
    assert (
        ak.min(data.to_typetracer(), axis=1, highlevel=False).form
        == ak.min(data, axis=1, highlevel=False).form
    )
    assert to_list(ak.max(data, axis=1, initial=4, highlevel=False)) == [5, None, 4, 5]
    assert (
        ak.max(data.to_typetracer(), axis=1, initial=4, highlevel=False).form
        == ak.max(data, axis=1, initial=4, highlevel=False).form
    )
    assert to_list(ak.max(data, axis=1, highlevel=False)) == [5, None, 3, 5]
    assert (
        ak.max(data.to_typetracer(), axis=1, highlevel=False).form
        == ak.max(data, axis=1, highlevel=False).form
    )

    data = ak.highlevel.Array(
        [[1.1, 3.3, 5.5, 4.4, 2.2], [], [2.2, 3.3, 1.1], [5.5]]
    ).layout
    assert to_list(ak.min(data, axis=1, initial=4, highlevel=False)) == [
        1.1,
        None,
        1.1,
        4,
    ]
    assert (
        ak.min(data.to_typetracer(), axis=1, initial=4, highlevel=False).form
        == ak.min(data, axis=1, initial=4, highlevel=False).form
    )
    assert to_list(ak.min(data, axis=1, highlevel=False)) == [1.1, None, 1.1, 5.5]
    assert (
        ak.min(data.to_typetracer(), axis=1, highlevel=False).form
        == ak.min(data, axis=1, highlevel=False).form
    )
    assert to_list(ak.max(data, axis=1, initial=4, highlevel=False)) == [
        5.5,
        None,
        4,
        5.5,
    ]
    assert (
        ak.max(data.to_typetracer(), axis=1, initial=4, highlevel=False).form
        == ak.max(data, axis=1, initial=4, highlevel=False).form
    )
    assert to_list(ak.max(data, axis=1, highlevel=False)) == [5.5, None, 3.3, 5.5]
    assert (
        ak.max(data.to_typetracer(), axis=1, highlevel=False).form
        == ak.max(data, axis=1, highlevel=False).form
    )

    data = ak.contents.NumpyArray(np.array(primes[2 : 2 * 3 * 5], dtype=np.int32))
    assert to_list(ak.min(data, axis=-1, initial=4, highlevel=False)) == 4
    assert to_list(ak.min(data, axis=-1, highlevel=False)) == 5
    assert to_list(ak.max(data, axis=-1, initial=114, highlevel=False)) == 114
    assert to_list(ak.max(data, axis=-1, highlevel=False)) == 113

    data = ak.contents.NumpyArray(np.array(primes[2 : 2 * 3 * 5], dtype=np.uint64))
    assert to_list(ak.min(data, axis=-1, initial=4, highlevel=False)) == 4
    assert to_list(ak.min(data, axis=-1, highlevel=False)) == 5
    assert to_list(ak.max(data, axis=-1, initial=114, highlevel=False)) == 114
    assert to_list(ak.max(data, axis=-1, highlevel=False)) == 113

    data = ak.contents.NumpyArray(np.array(primes[2 : 2 * 3 * 5], dtype=np.uint32))
    assert to_list(ak.min(data, axis=-1, initial=4, highlevel=False)) == 4
    assert to_list(ak.min(data, axis=-1, highlevel=False)) == 5
    assert to_list(ak.max(data, axis=-1, initial=114, highlevel=False)) == 114
    assert to_list(ak.max(data, axis=-1, highlevel=False)) == 113


def test_date_time():
    numpy_array = np.array(
        ["2020-07-27T10:41:11", "2019-01-01", "2020-01-01"], "datetime64[s]"
    )

    array = ak.highlevel.Array(numpy_array)
    assert str(array.type) == "3 * datetime64[s]"
    assert array.to_list() == [
        np.datetime64("2020-07-27T10:41:11"),
        np.datetime64("2019-01-01T00:00:00"),
        np.datetime64("2020-01-01T00:00:00"),
    ]

    array = array.layout
    assert to_list(array) == [
        np.datetime64("2020-07-27T10:41:11"),
        np.datetime64("2019-01-01T00:00:00"),
        np.datetime64("2020-01-01T00:00:00"),
    ]

    assert ak.max(array, highlevel=False) == numpy_array[0]
    assert ak.min(array, highlevel=False) == numpy_array[1]