sexy
parent
d97c08ca16
commit
41e0791a53
|
@ -19,7 +19,7 @@
|
||||||
#ifndef LILFBTF5_LILFBTF_H
|
#ifndef LILFBTF5_LILFBTF_H
|
||||||
#define LILFBTF5_LILFBTF_H
|
#define LILFBTF5_LILFBTF_H
|
||||||
|
|
||||||
namespace lilfb
|
namespace fb
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
|
2
libs/BLT
2
libs/BLT
|
@ -1 +1 @@
|
||||||
Subproject commit 148768d6903884feb92066f316915f6ebf97f464
|
Subproject commit b7d69bdcbb4e9bb61650c7d85e7ae444cb21ed74
|
|
@ -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
|
|
@ -3,7 +3,7 @@
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <blt/std/logging.h>
|
#include <blt/std/logging.h>
|
||||||
#include <blt/parse/argparse.h>
|
#include <blt/parse/argparse.h>
|
||||||
#include <lilfbtf/tests.h>
|
#include <lilfbtf/test2.h>
|
||||||
|
|
||||||
struct data {
|
struct data {
|
||||||
float f;
|
float f;
|
||||||
|
@ -24,8 +24,8 @@ int main(int argc, const char** argv)
|
||||||
std::cout << static_cast<void*>(buffer) << " ' " << remaining_bytes << std::endl;
|
std::cout << static_cast<void*>(buffer) << " ' " << remaining_bytes << std::endl;
|
||||||
void_ptr = reinterpret_cast<void*>(&buffer[offset]);
|
void_ptr = reinterpret_cast<void*>(&buffer[offset]);
|
||||||
new_ptr = static_cast<char*>(std::align(alignof(char), sizeof(char), void_ptr, remaining_bytes));
|
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;
|
std::cout << static_cast<void*>(new_ptr) << " : " << remaining_bytes << " | " << (buffer - new_ptr + 1) << std::endl;
|
||||||
offset += (buffer - new_ptr + sizeof(char));
|
offset += (buffer - new_ptr + 1);
|
||||||
|
|
||||||
remaining_bytes = size - offset;
|
remaining_bytes = size - offset;
|
||||||
void_ptr = reinterpret_cast<void*>(&buffer[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;
|
std::cout << static_cast<void*>(new_ptr) << " : " << remaining_bytes << " | " << (buffer - new_ptr + sizeof(data)) << std::endl;
|
||||||
offset += (buffer - new_ptr + sizeof(data));
|
offset += (buffer - new_ptr + sizeof(data));
|
||||||
|
|
||||||
|
|
||||||
delete[](buffer);
|
delete[](buffer);
|
||||||
|
|
||||||
std::cout << "Hello, World!" << std::endl;
|
std::cout << "Hello, World!" << std::endl;
|
||||||
|
|
|
@ -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());
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue