2026-03-07 12:09:00 +01:00
|
|
|
#include <cassert>
|
2026-02-11 02:52:03 +01:00
|
|
|
import Crafter.Math;
|
|
|
|
|
import std;
|
|
|
|
|
|
|
|
|
|
using namespace Crafter;
|
|
|
|
|
|
|
|
|
|
int main() {
|
2026-03-18 03:16:29 +01:00
|
|
|
// std::random_device rd;
|
|
|
|
|
// std::mt19937 gen(rd());
|
|
|
|
|
// std::uniform_real_distribution<float> dist(0, 100);
|
|
|
|
|
|
|
|
|
|
// Vector<_Float16, 8, 8> vA;
|
|
|
|
|
// for(std::uint32_t i = 0; i < 8; i++) {
|
|
|
|
|
// vA.v[i] = dist(gen);
|
|
|
|
|
// }
|
|
|
|
|
// VectorF16<4, 2, 1> vfA(&vA);
|
|
|
|
|
|
|
|
|
|
// Vector<_Float16, 16, 16> vB;
|
|
|
|
|
// for(std::uint32_t i = 0; i < 16; i++) {
|
|
|
|
|
// vB.v[i] = dist(gen);
|
|
|
|
|
// }
|
|
|
|
|
// VectorF16<4, 2, 2> vfB(&vB);
|
|
|
|
|
|
|
|
|
|
// VectorF16<4, 2, 1> vfC = vfA + vfB;
|
|
|
|
|
// auto start = std::chrono::high_resolution_clock::now();
|
|
|
|
|
// for(std::uint32_t i = 0; i < 90000000; i++) {
|
|
|
|
|
// vfC = vfC + vfB;
|
|
|
|
|
// }
|
|
|
|
|
// auto end = std::chrono::high_resolution_clock::now();
|
|
|
|
|
// std::cout << std::chrono::duration_cast<std::chrono::milliseconds>(end-start) << std::endl;
|
|
|
|
|
// std::println("{}", vfC);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2026-03-19 02:19:01 +01:00
|
|
|
Vector<_Float16, 1326, 32> vA;
|
|
|
|
|
// for(std::uint32_t i = 0; i < 2; i++) {
|
2026-03-18 03:16:29 +01:00
|
|
|
// vA.v[i] = i;
|
|
|
|
|
// }
|
2026-03-19 02:19:01 +01:00
|
|
|
// for(std::uint32_t i = 2; i < 4; i++) {
|
|
|
|
|
// vA.v[i] = i-2;
|
|
|
|
|
// }
|
|
|
|
|
// for(std::uint32_t i = 4; i < 6; i++) {
|
|
|
|
|
// vA.v[i] = i-4;
|
|
|
|
|
// }
|
|
|
|
|
// for(std::uint32_t i = 6; i < 8; i++) {
|
|
|
|
|
// vA.v[i] = i-6;
|
2026-03-18 03:16:29 +01:00
|
|
|
// }
|
2026-03-19 02:19:01 +01:00
|
|
|
for(std::uint32_t i = 0; i < 8; i++) {
|
|
|
|
|
vA.v[i] = i;
|
|
|
|
|
}
|
|
|
|
|
for(std::uint32_t i = 8; i < 16; i++) {
|
|
|
|
|
vA.v[i] = i-8;
|
|
|
|
|
}
|
|
|
|
|
for(std::uint32_t i = 16; i < 24; i++) {
|
|
|
|
|
vA.v[i] = i-16;
|
|
|
|
|
}
|
|
|
|
|
for(std::uint32_t i = 24; i < 32; i++) {
|
|
|
|
|
}
|
|
|
|
|
VectorF16<8, 1, 4> vfA(&vA);
|
|
|
|
|
std::tuple<VectorF16<8, 1, 4>, VectorF16<8, 1, 4>, VectorF16<8, 1, 4>, VectorF16<8, 1, 4>, VectorF16<8, 1, 4>, VectorF16<8, 1, 4>, VectorF16<8, 1, 4>, VectorF16<8, 1, 4>> dot = VectorF16<8, 1, 4>::Normalize(vfA, vfA, vfA, vfA, vfA, vfA, vfA, vfA);
|
|
|
|
|
std::println("{}", std::get<0>(dot));
|
2026-03-18 03:16:29 +01:00
|
|
|
|
2026-03-19 02:19:01 +01:00
|
|
|
Vector<float, 8, 8> vB;
|
|
|
|
|
for(std::uint32_t i = 0; i < 8; i++) {
|
|
|
|
|
vB.v[i] = i;
|
|
|
|
|
}
|
|
|
|
|
vB.Normalize();
|
|
|
|
|
std::string log;
|
|
|
|
|
for(std::uint32_t i = 0; i < 8; i++) {
|
|
|
|
|
log += std::format("{} ", (float)vB.v[i]);
|
|
|
|
|
}
|
|
|
|
|
std::println("{{{}}}", log);
|
2026-02-11 02:52:03 +01:00
|
|
|
}
|