Basic simulation and evaluation

MadKnight
17.7K views

Open Source Your Knowledge, Become a Contributor

Technology knowledge has to be shared and made accessible for free. Join the movement.

Create Content
Previous: Full turn simulation

Random search

This is the brain of our pods. It makes our pods "think" and "come up" with trajectory plans for the near future. To make it work, we need to try a lot of different trajectories and evaluate the outcomes they provide to pick the trajectory with the best score. Trajectory is defined with a list of game moves for the next N turns. We can easily generate trajectories randomly and then simulate the game with them:

Solution sol = new Solution(); float score = sol->RandomizeAndEvaluate(pods);

then just repeat this 10 000 times more and print the best solution found:

static public void DoRandomSearch(Pod[] pods)
{
    Solution best = new Solution();
    float scoreBest = best->RandomizeAndEvaluate(pods);

    for(int i = 0; i < 10000; i++)
    {
        Solution sol = new Solution();
        float score = sol->RandomizeAndEvaluate(pods);

        if (score > scoreBest)
        {
            scoreBest = score;
            best = sol;
        }
    }

    best.Print();
}
Open Source Your Knowledge: become a Contributor and help others learn. Create New Content