Amit's 1d->2d matrix that I can base a rewrite of mine on.
This commit is contained in:
parent
80ef052e15
commit
079734941c
2 changed files with 134 additions and 81 deletions
52
tests/matrix2.cpp
Normal file
52
tests/matrix2.cpp
Normal file
|
@ -0,0 +1,52 @@
|
|||
#include <catch2/catch_test_macros.hpp>
|
||||
#include <fmt/core.h>
|
||||
#include <string>
|
||||
#include "rand.hpp"
|
||||
#include "scratchpad/amitmatrix.hpp"
|
||||
#include "worldbuilder.hpp"
|
||||
#include <iostream>
|
||||
#include <numeric>
|
||||
#include <algorithm>
|
||||
|
||||
using namespace fmt;
|
||||
using std::string;
|
||||
|
||||
inline void random_matrix(amt::Matrix<int> &out) {
|
||||
for(size_t y = 0; y < out.rows(); y++) {
|
||||
for(size_t x = 0; x < out.cols(); x++) {
|
||||
out[y][x] = Random::uniform<int>(-10,10);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("basic matrix iterator", "[matrix2:basic]") {
|
||||
size_t width = Random::uniform<size_t>(5, 11);
|
||||
size_t height = Random::uniform<size_t>(3, 13);
|
||||
|
||||
amt::Matrix<int> test{height,width,0};
|
||||
random_matrix(test);
|
||||
|
||||
println("FIRST RANDOM");
|
||||
std::cout << test << std::endl;
|
||||
|
||||
for(auto cell : test) {
|
||||
print("{} ", cell);
|
||||
}
|
||||
|
||||
println("DIRECT ACCESS");
|
||||
for(size_t y = 0; y < test.rows(); y++) {
|
||||
for(size_t x = 0; x < test.cols(); x++) {
|
||||
print("{} ", test(x, y));
|
||||
}
|
||||
}
|
||||
|
||||
auto filled = test;
|
||||
std::fill(filled.begin(), filled.end(), 8);
|
||||
println("SECOND FILLED");
|
||||
std::cout << filled << std::endl;
|
||||
|
||||
auto iota_style = filled;
|
||||
std::iota(iota_style.begin(), iota_style.end(), 0);
|
||||
println("THIRD IOTA");
|
||||
std::cout << iota_style << std::endl;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue