This commit is contained in:
dompia5 2024-02-08 01:46:40 +01:00
parent 3f1644dbdb
commit 10ad09a79a

View File

@ -156,6 +156,7 @@ struct PlanetParams {
float humidity = 0.0f; // Начальное значение для влажности
float temperature = 0.0f; // Начальное значение для осадков
std::vector < std::tuple<int, glm::vec3 >> Plant_info; // ID , position
std::vector <int> Plant_type_count;
};
std::vector<PlanetParams> planets; // Список всех планет
@ -170,14 +171,17 @@ bool sortFunction(std::tuple<int, float> objA, std::tuple<int, float> objB)
PlanetParams populatePlanet(PlanetParams planet, std::vector<Plant::Plant> plants)
{
float probability=0.5f;
int HOW_MANY_PLANTS = 10000;
int HOW_MANY_PLANTS = 1000;
int PRECISION = 10000;
float NOTHING_SPAWNS_CUTOFF = 0.2;
int sum = 0;
int chosen_number = 0;
std::vector<std::tuple<int, int>> probabilities;
int plant_count = 0;
for (int i = 0; i < plant_specimens.size(); i++)
{
planet.Plant_type_count.push_back(0);
}
sum = NOTHING_SPAWNS_CUTOFF * PRECISION;
int j = 0;
for (auto& plant : plants) {
@ -195,6 +199,7 @@ PlanetParams populatePlanet(PlanetParams planet, std::vector<Plant::Plant> plant
}
std::sort(probabilities.begin(), probabilities.end(), sortFunction);
for (int i = 0; i < HOW_MANY_PLANTS; i++) {
chosen_number = int(sum * (rand() / (RAND_MAX + 1.0))) ;
@ -202,7 +207,7 @@ PlanetParams populatePlanet(PlanetParams planet, std::vector<Plant::Plant> plant
int winnerId = -1;
for (auto& probability : probabilities)
{
if (chosen_number > std::get<1>(probability))
if (chosen_number < std::get<1>(probability))
{
winnerId = std::get<0>(probability);
break;
@ -213,13 +218,19 @@ PlanetParams populatePlanet(PlanetParams planet, std::vector<Plant::Plant> plant
{
Plant::Plant plant = plants[winnerId];
plant_count += 1;
planet.Plant_type_count[winnerId] += 1;
plant.pos = glm::vec3((2.0 * (rand() / (RAND_MAX + 1.0))-1), (2.0 * (rand() / (RAND_MAX + 1.0))-1), (2.0 * (rand() / (RAND_MAX + 1.0)))-1);
planet.Plant_info.push_back(std::make_tuple(winnerId,plant.pos));
}
}
std::cout <<"plant_count:" << plant_count << std::endl;
for (int i = 0; i < planet.Plant_type_count.size(); i++)
{
std::cout << " " <<planet.Plant_type_count[i] ;
}
std::cout << std::endl;
return planet;
@ -374,6 +385,8 @@ void renderImGui() {
if (ImGui::Button("Dodac")) {
newPlanetParams =populatePlanet(newPlanetParams, plant_specimens);
planets.push_back(newPlanetParams);
newPlanetParams.Plant_info.clear();
newPlanetParams.Plant_type_count.clear();
}
ImGui::End();