google-research
64 строки · 2.0 Кб
1// Copyright 2024 The Google Research Authors.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15#include "memory.h"
16
17#include <cassert>
18#include <iostream>
19
20#include "definitions.h"
21#include "util.h"
22#include "gtest/gtest.h"
23
24namespace automl_zero {
25
26TEST(MemoryTest, NumAddressesAreWithinLimits) {
27const size_t max_addresses = Pow2(8 * sizeof(AddressT));
28EXPECT_LE(kMaxScalarAddresses, max_addresses);
29EXPECT_LE(kMaxVectorAddresses, max_addresses);
30EXPECT_LE(kMaxMatrixAddresses, max_addresses);
31}
32
33TEST(MemoryTest, WipeSetsValuesToZero) {
34const AddressT kSomeAddress = 1;
35const IntegerT kX = 2;
36const IntegerT kY = 3;
37
38Memory<4> memory;
39memory.scalar_[kSomeAddress] = 2.0;
40memory.vector_[kSomeAddress](kX, 0) = 4.0;
41memory.matrix_[kSomeAddress](kX, kY) = 0.5;
42EXPECT_EQ(memory.scalar_[kSomeAddress], 2.0);
43EXPECT_EQ(memory.vector_[kSomeAddress](kX, 0), 4.0);
44EXPECT_EQ(memory.matrix_[kSomeAddress](kX, kY), 0.5);
45
46memory.Wipe();
47EXPECT_EQ(memory.scalar_[kSomeAddress], 0.0);
48EXPECT_EQ(memory.vector_[kSomeAddress](kX, 0), 0.0);
49EXPECT_EQ(memory.matrix_[kSomeAddress](kX, kY), 0.0);
50}
51
52TEST(MemoryTest, RespectsFeaturesSize) {
53Memory<4> memory4;
54EXPECT_EQ(memory4.vector_[0].size(), 4);
55EXPECT_EQ(memory4.matrix_[0].rows(), 4);
56EXPECT_EQ(memory4.matrix_[0].cols(), 4);
57
58Memory<8> memory8;
59EXPECT_EQ(memory8.vector_[0].size(), 8);
60EXPECT_EQ(memory8.matrix_[0].rows(), 8);
61EXPECT_EQ(memory8.matrix_[0].cols(), 8);
62}
63
64} // namespace automl_zero
65