test_power_space.py 6.28 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# NIFTy
# Copyright (C) 2017  Theo Steininger
#
# Author: Theo Steininger
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.

19
20
21
22
23
24
25
26
from __future__ import division

import unittest
import numpy as np

from d2o import distributed_data_object
from numpy.testing import assert_, assert_equal, assert_almost_equal,\
        assert_raises
27
from nifty import PowerSpace, RGSpace, Space, LMSpace
28
29
from types import NoneType
from test.common import expand
30
from itertools import product
31

32
33
34
35
36
37
38
39
40
41
42

HARMONIC_SPACES = [RGSpace((8,), harmonic=True), RGSpace((7,8), harmonic=True), RGSpace((5,5), harmonic=True), RGSpace((4,5,7), harmonic=True),
LMSpace(6),LMSpace(9)]

BINNINGS = product([None], [None, 3,4], [True, False]) + product([0.,1.3],[None],[False])


#Try all sensible kinds of combinations of spaces, distributuion strategy and 
#binning parameters
CONSISTENCY_CONFIGS = product(HARMONIC_SPACES, ["not", "equal", "fftw", "freeform"], BINNINGS)

Theo Steininger's avatar
Theo Steininger committed
43
# [harmonic_partner, distribution_strategy,
Theo Steininger's avatar
Theo Steininger committed
44
#  logarithmic, nbin, binbounds, expected]
45
CONSTRUCTOR_CONFIGS = [
Martin Reinecke's avatar
Martin Reinecke committed
46
47
48
    [1, 'not', False, None, None, {'error': ValueError}],
    [RGSpace((8,)), 'not', False, None, None, {'error': ValueError}],
    [RGSpace((8,), harmonic=True), 'not', False, None, None, {
49
50
51
52
        'harmonic': True,
        'shape': (5,),
        'dim': 5,
        'total_volume': 8.0,
Theo Steininger's avatar
Theo Steininger committed
53
        'harmonic_partner': RGSpace((8,), harmonic=True),
Theo Steininger's avatar
Theo Steininger committed
54
        'logarithmic': False,
55
56
57
58
59
60
61
62
        'nbin': None,
        'binbounds': None,
        'pindex': distributed_data_object([0, 1, 2, 3, 4, 3, 2, 1]),
        'kindex': np.array([0., 1., 2., 3., 4.]),
        'rho': np.array([1, 2, 2, 2, 1]),
        'pundex': np.array([0, 1, 2, 3, 4]),
        'k_array': np.array([0., 1., 2., 3., 4., 3., 2., 1.]),
        }],
Martin Reinecke's avatar
Martin Reinecke committed
63
    [RGSpace((8,), harmonic=True), 'not', True, None, None, {
64
65
66
67
        'harmonic': True,
        'shape': (2,),
        'dim': 2,
        'total_volume': 8.0,
Theo Steininger's avatar
Theo Steininger committed
68
        'harmonic_partner': RGSpace((8,), harmonic=True),
Theo Steininger's avatar
Theo Steininger committed
69
        'logarithmic': True,
70
71
72
73
74
75
76
77
78
79
80
81
82
        'nbin': None,
        'binbounds': None,
        'pindex': distributed_data_object([0, 1, 1, 1, 1, 1, 1, 1]),
        'kindex': np.array([0., 2.28571429]),
        'rho': np.array([1, 7]),
        'pundex': np.array([0, 1]),
        'k_array': np.array([0., 2.28571429, 2.28571429, 2.28571429,
                             2.28571429, 2.28571429, 2.28571429, 2.28571429]),
        }],
    ]


def get_distance_array_configs():
Martin Reinecke's avatar
Martin Reinecke committed
83
    da_0 = np.array([0, 1.0, 1.41421356, 2., 2.23606798, 2.82842712])
84
    return [
Martin Reinecke's avatar
Martin Reinecke committed
85
        [RGSpace((4, 4), harmonic=True),  da_0],
86
87
88
89
        ]


def get_weight_configs():
Martin Reinecke's avatar
Martin Reinecke committed
90
91
92
93
94
95
96
97
98
    np.random.seed(42)

    # power 1
    w_0_x = np.random.rand(32, 16, 6)
    # RGSpace((4, 4), harmonic=True)
    # using rho directly
    weight_0 = np.array([1, 4, 4, 2, 4, 1])
    weight_0 = weight_0.reshape([1, 1, 6])
    w_0_res = w_0_x * weight_0
99
100
    return [
        [RGSpace((4, 4), harmonic=True),
Martin Reinecke's avatar
Martin Reinecke committed
101
            w_0_x, 1, (2,), False, w_0_res],
102
        [RGSpace((4, 4), harmonic=True),
Martin Reinecke's avatar
Martin Reinecke committed
103
            w_0_x.copy(), 1, (2,), True, w_0_res],
104
105
106
107
108
        ]


class PowerSpaceInterfaceTest(unittest.TestCase):
    @expand([
Theo Steininger's avatar
Theo Steininger committed
109
        ['harmonic_partner', Space],
Theo Steininger's avatar
Theo Steininger committed
110
        ['logarithmic', bool],
111
112
113
114
115
116
117
118
119
120
121
122
123
        ['nbin', (int, NoneType)],
        ['binbounds', (list, NoneType)],
        ['pindex', distributed_data_object],
        ['kindex', np.ndarray],
        ['rho', np.ndarray],
        ['pundex', np.ndarray],
        ['k_array', distributed_data_object],
        ])
    def test_property_ret_type(self, attribute, expected_type):
        r = RGSpace((4, 4), harmonic=True)
        p = PowerSpace(r)
        assert_(isinstance(getattr(p, attribute), expected_type))

124
class PowerSpaceConsistencyCheck(unittest.TestCase):
125
    @expand(CONSISTENCY_CONFIGS)
126
    def test_pipundexInversion(self, harmonic_partner, distribution_strategy,
127
128
                         binbounds, nbin,logarithmic):
        p = PowerSpace(harmonic_partner=harmonic_partner,
129
130
131
                           distribution_strategy=distribution_strategy,
                           logarithmic=logarithmic, nbin=nbin,
                           binbounds=binbounds)
132
        assert_equal(p.pindex[p.pundex],np.arange(p.dim),err_msg='pundex is not right-inverse of pindex!')
133
134

class PowerSpaceFunctionalityTest(unittest.TestCase):
135
    @expand(CONSISTENCY_CONFIGS)
Theo Steininger's avatar
Theo Steininger committed
136
    def test_constructor(self, harmonic_partner, distribution_strategy,
Theo Steininger's avatar
Theo Steininger committed
137
                         logarithmic, nbin, binbounds, expected):
138
139
        if 'error' in expected:
            with assert_raises(expected['error']):
Theo Steininger's avatar
Theo Steininger committed
140
                PowerSpace(harmonic_partner=harmonic_partner,
141
                           distribution_strategy=distribution_strategy,
Theo Steininger's avatar
Theo Steininger committed
142
143
                           logarithmic=logarithmic, nbin=nbin,
                           binbounds=binbounds)
144
        else:
Theo Steininger's avatar
Theo Steininger committed
145
            p = PowerSpace(harmonic_partner=harmonic_partner,
146
                           distribution_strategy=distribution_strategy,
Theo Steininger's avatar
Theo Steininger committed
147
148
                           logarithmic=logarithmic, nbin=nbin,
                           binbounds=binbounds)
149
150
151
152
153
154
155
            for key, value in expected.iteritems():
                if isinstance(value, np.ndarray):
                    assert_almost_equal(getattr(p, key), value)
                else:
                    assert_equal(getattr(p, key), value)

    @expand(get_distance_array_configs())
Theo Steininger's avatar
Theo Steininger committed
156
157
    def test_distance_array(self, harmonic_partner, expected):
        p = PowerSpace(harmonic_partner=harmonic_partner)
158
159
160
        assert_almost_equal(p.get_distance_array('not'), expected)

    @expand(get_weight_configs())
Theo Steininger's avatar
Theo Steininger committed
161
    def test_weight(self, harmonic_partner, x, power, axes,
162
                    inplace, expected):
Theo Steininger's avatar
Theo Steininger committed
163
        p = PowerSpace(harmonic_partner=harmonic_partner)
164
165
166
167
        res = p.weight(x, power, axes, inplace)
        assert_almost_equal(res, expected)
        if inplace:
            assert_(x is res)