public Population(CreatureTypeList creatureTypes)
 {
     CreatureTypes = creatureTypes;
     Creatures     = new CreatureList();
 }
        static void Main(string[] args)
        {
            SetUpLogger(log: false);

            var watch = new System.Diagnostics.Stopwatch();

            watch.Start();

            SimulationParameters Parameters = new SimulationParameters
            {
                xLimit              = 20,
                yLimit              = 20,
                simulationDays      = 100,
                stepsPerDay         = 180,
                foodPerDay          = 80,
                foodToSurvive       = 1,
                foodToReproduce     = 2,
                numberOfSimulations = 100,
                logOnlyPopulation   = true
            };

            Terrain simulationTerrain = new Terrain(Parameters.xLimit, Parameters.yLimit);

            CreatureTypeList creatureTypes = new CreatureTypeList();

            creatureTypes.Add(new HerbivoreType());
            //creatureTypes.Add(new HostileHerbivoreType(), mutationProbability: 0.02);
            //creatureTypes.Add(new QuickHerbivoreType(), mutationProbability: 0.02);
            //creatureTypes.Add(new QuickHostileHerbivoreType(), mutationProbability: 0.02);
            //creatureTypes.Add(new BigHerbivoreType(), mutationProbability: 0.02);
            //creatureTypes.Add(new BigHostileHerbivoreType(), mutationProbability: 0.02);
            creatureTypes.Add(new CarnivoreType(), mutationProbability: 0.02);
            creatureTypes.Add(new OmnivoreType(), mutationProbability: 0.02);

            Population initialPopulation = new Population(creatureTypes);

            foreach (ICreatureType creatureType in initialPopulation.CreatureTypes)
            {
                string typesString = "";

                typesString += creatureType.Name + ",";
                Parameters.CreatureTypes.Add(typesString.Trim(','));
            }

            using (StreamWriter file = File.CreateText(Directory.GetCurrentDirectory() + @"\logs\parameters.json"))
            {
                string jsonString = JsonConvert.SerializeObject(Parameters);
                file.Write(jsonString);
            }

            initialPopulation.AddCreature(initialPopulation.CreatureTypes[0]);
            initialPopulation.AddCreature(initialPopulation.CreatureTypes[0]);
            initialPopulation.AddCreature(initialPopulation.CreatureTypes[0]);
            initialPopulation.AddCreature(initialPopulation.CreatureTypes[0]);
            initialPopulation.AddCreature(initialPopulation.CreatureTypes[0]);
            initialPopulation.AddCreature(initialPopulation.CreatureTypes[0]);


            Simulation simulationVar = new Simulation(simulationTerrain, Parameters.simulationDays, Parameters.stepsPerDay,
                                                      initialPopulation, Parameters.foodToSurvive, Parameters.foodToReproduce, Parameters.logOnlyPopulation);
            SimulationResults results = new SimulationResults(Parameters.logOnlyPopulation);

            for (int simulationNumber = 0; simulationNumber < Parameters.numberOfSimulations; simulationNumber++)
            {
                Console.WriteLine($"Simulation #{simulationNumber + 1}");
                simulationVar.SetNewSimulation();
                results.AddSingleSimulationResults(simulationVar.RunSimulation(Parameters.foodPerDay, PositionType.Random));
            }

            results.PrintToFile();

            watch.Stop();

            Console.WriteLine($"Simulation duration: {watch.ElapsedMilliseconds * 0.001:N2} seconds.");
        }