main
Brett 2024-03-04 10:58:42 -05:00
parent d97c08ca16
commit 41e0791a53
5 changed files with 228 additions and 6 deletions

View File

@ -19,7 +19,7 @@
#ifndef LILFBTF5_LILFBTF_H
#define LILFBTF5_LILFBTF_H
namespace lilfb
namespace fb
{

@ -1 +1 @@
Subproject commit 148768d6903884feb92066f316915f6ebf97f464
Subproject commit b7d69bdcbb4e9bb61650c7d85e7ae444cb21ed74

View File

@ -0,0 +1,35 @@
/*
* <Short Description>
* Copyright (C) 2024 Brett Terpstra
*
* 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 <https://www.gnu.org/licenses/>.
*/
#ifndef LILFBTF5_TEST2_H
#define LILFBTF5_TEST2_H
namespace fb
{
void execute();
void funny();
inline void execute_tests()
{
execute();
}
}
#endif //LILFBTF5_TEST2_H

View File

@ -3,7 +3,7 @@
#include <memory>
#include <blt/std/logging.h>
#include <blt/parse/argparse.h>
#include <lilfbtf/tests.h>
#include <lilfbtf/test2.h>
struct data {
float f;
@ -24,8 +24,8 @@ int main(int argc, const char** argv)
std::cout << static_cast<void*>(buffer) << " ' " << remaining_bytes << std::endl;
void_ptr = reinterpret_cast<void*>(&buffer[offset]);
new_ptr = static_cast<char*>(std::align(alignof(char), sizeof(char), void_ptr, remaining_bytes));
std::cout << static_cast<void*>(new_ptr) << " : " << remaining_bytes << " | " << (buffer - new_ptr + sizeof(char)) << std::endl;
offset += (buffer - new_ptr + sizeof(char));
std::cout << static_cast<void*>(new_ptr) << " : " << remaining_bytes << " | " << (buffer - new_ptr + 1) << std::endl;
offset += (buffer - new_ptr + 1);
remaining_bytes = size - offset;
void_ptr = reinterpret_cast<void*>(&buffer[offset]);
@ -33,7 +33,6 @@ int main(int argc, const char** argv)
std::cout << static_cast<void*>(new_ptr) << " : " << remaining_bytes << " | " << (buffer - new_ptr + sizeof(data)) << std::endl;
offset += (buffer - new_ptr + sizeof(data));
delete[](buffer);
std::cout << "Hello, World!" << std::endl;

188
tests/src/tests2.cpp Normal file
View File

@ -0,0 +1,188 @@
/*
* <Short Description>
* Copyright (C) 2024 Brett Terpstra
*
* 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 <https://www.gnu.org/licenses/>.
*/
#include <lilfbtf/test2.h>
#include <functional>
#include <blt/std/types.h>
#include "blt/std/ranges.h"
#include "blt/std/allocator.h"
#include <random>
#include <vector>
#include <stack>
namespace fb
{
template<typename arg_type, blt::size_t MAX_ARGS>
class tree
{
using index = blt::u32;
private:
struct node
{
index parent;
std::array<index, MAX_ARGS> children;
std::function<arg_type(blt::span<arg_type>)> func;
};
std::vector<node> nodes;
public:
};
void execute()
{
}
enum class type_t
{
ADD, SUB, MUL, VALUE
};
type_t random_type()
{
static std::random_device dev;
static std::mt19937_64 engine{dev()};
static std::uniform_int_distribution dist(0, 3);
return static_cast<type_t>(dist(engine));
}
type_t random_type_sub()
{
static std::random_device dev;
static std::mt19937_64 engine{dev()};
static std::uniform_int_distribution dist(0, 2);
return static_cast<type_t>(dist(engine));
}
double random_value()
{
static std::random_device dev;
static std::mt19937_64 engine{dev()};
static std::uniform_real_distribution dist(-10.0, 10.0);
return dist(engine);
}
bool choice()
{
static std::random_device dev;
static std::mt19937_64 engine{dev()};
static std::uniform_int_distribution dist(0, 1);
return dist(engine);
}
std::array<blt::i32, 4> arg_c = {2, 2, 2, 0};
class tree1
{
private:
struct node_t
{
std::array<node_t*, 2> children{};
double value = 0;
blt::i32 argc;
type_t type;
explicit node_t(type_t type): argc(arg_c[static_cast<int>(type)]), type(type)
{
if (type == type_t::VALUE)
value = random_value();
}
void evaluate()
{
switch (type)
{
case type_t::ADD:
value = children[0]->value + children[1]->value;
return;
case type_t::SUB:
value = children[0]->value - children[1]->value;
return;
case type_t::MUL:
value = children[0]->value * children[1]->value;
return;
case type_t::VALUE:
return;
}
}
double evaluate_tree()
{
std::stack<node_t*> nodes;
std::stack<node_t*> node_stack;
nodes.push(this);
while (!nodes.empty())
{
auto* top = nodes.top();
node_stack.push(top);
nodes.pop();
for (blt::i32 i = 0; i < top->argc; i++)
nodes.push(top->children[i]);
}
while (!node_stack.empty())
{
node_stack.top()->evaluate();
node_stack.pop();
}
return value;
}
};
node_t* root = nullptr;
public:
blt::bump_allocator<true> alloc{sizeof(node_t) * 8192};
void create(blt::size_t size)
{
root = alloc.emplace<node_t>(random_type());
std::stack<std::pair<node_t*, blt::size_t>> stack;
stack.emplace(root, 0);
while (!stack.empty())
{
auto top = stack.top();
auto* node = top.first;
auto depth = top.second;
stack.pop();
for (blt::i32 i = 0; i < node->argc; i++)
{
auto& assignment = node->children[i];
if (choice())
assignment = alloc.emplace<node_t>(random_type());
else
assignment = alloc.emplace<node_t>(random_type_sub());
if (depth < size)
stack.emplace(assignment, depth + 1);
}
}
}
double evaluate()
{
return root->evaluate_tree();
}
};
void funny()
{
tree1 love;
love.create(10);
BLT_TRACE(love.evaluate());
}
}