BambuStudio/src/libslic3r/FilamentGroup.hpp

90 lines
3.0 KiB
C++
Raw Normal View History

#ifndef FILAMENT_GROUP_HPP
#define FILAMENT_GROUP_HPP
#include<chrono>
#include<numeric>
#include "GCode/ToolOrderUtils.hpp"
namespace Slic3r
{
struct FlushTimeMachine
{
private:
std::chrono::high_resolution_clock::time_point start;
public:
void time_machine_start()
{
start = std::chrono::high_resolution_clock::now();
}
int time_machine_end()
{
auto end = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);
return duration.count();
}
};
enum FGStrategy {
BestCost,
BestFit
};
class FilamentGroup
{
public:
FilamentGroup(const std::vector<FlushMatrix>& flush_matrix, const int total_filament_num, const std::vector<int>& max_group_size) :
m_flush_matrix{ flush_matrix },
m_total_filament_num{ total_filament_num },
m_max_group_size{ max_group_size }
{}
std::vector<int> calc_filament_group(const std::vector<std::vector<unsigned int>>& layer_filaments, const FGStrategy& g_strategy = FGStrategy::BestFit, int* cost = nullptr);
private:
std::vector<int> calc_filament_group_by_enum(const std::vector<std::vector<unsigned int>>& layer_filaments, const std::vector<unsigned int>& used_filaments, const FGStrategy& g_strategy, int* cost = nullptr);
std::vector<int> calc_filament_group_by_pam(const std::vector<std::vector<unsigned int>>& layer_filaments, const std::vector<unsigned int>& used_filaments, const FGStrategy& g_strategy, int* cost = nullptr, int timeout_ms = 300);
private:
std::vector<FlushMatrix>m_flush_matrix;
std::vector<int>m_max_group_size;
int m_total_filament_num;
public:
std::optional<std::function<bool(int, std::vector<int>&)>> get_custom_seq;
};
class KMediods
{
enum INIT_TYPE
{
Random = 0,
Farthest
};
public:
KMediods(const std::vector<std::vector<float>>& distance_matrix, const int filament_num,const std::vector<int>& max_group_size) :
m_distance_matrix{ distance_matrix },
m_filament_num{ filament_num },
m_max_group_size{ max_group_size }{}
void fit(const FGStrategy& g_strategy,int timeout_ms = 300);
std::vector<int>get_filament_labels()const {
return m_filament_labels;
}
private:
std::vector<int>initialize(INIT_TYPE type);
std::vector<int>assign_label(const std::vector<int>& medoids,const FGStrategy&g_strategy);
int calc_cost(const std::vector<int>& labels, const std::vector<int>& medoids);
private:
std::vector<std::vector<float>>m_distance_matrix;
int m_filament_num;
std::vector<int>m_max_group_size;
std::set<int>m_medoids_set;
const int k = 2;
private:
std::vector<int>m_filament_labels;
};
}
#endif // !FILAMENT_GROUP_HPP