开发者

How could I apply a genetic algorithm to a simple game that follows rollercoaster tracks? [closed]

As it currently stands, this q开发者_如何学Gouestion is not a good fit for our Q&A format. We expect answers to be supported by facts, references, or expertise, but this question will likely solicit debate, arguments, polling, or extended discussion. If you feel that this question can be improved and possibly reopened, visit the help center for guidance. Closed 10 years ago.

I have free-rein over what I do on a final assignment for school, with respect to modifying a simple direct-x game that currently just has the camera follow some rollercoaster rails. I've developed an interest in genetic algorithms and would like to take this opportunity to apply one and learn something about them. However, I can't think of any way I could possibly apply one in this case. What are some options available to me?


From your query, it seems like that you want to use Genetic Algorithms to get optimized roller coaster rail tracks. For any optimization problem:

  1. you will first need to break down your desired solution into its components or design variables.
  2. Once you have the "variables" you need to look at formulating a objective function with them. Usually you would code it in such a way that your desired solution minimizes it.
  3. Then you need to decide on a coding scheme to use in your Genetic Algorithm. Real Coded Genetic Algorithm is more useful in cases where you have a continuous search space.

These are the first things. Once you have them, you need to decide on a Crossover and Mutation strategy. Then finally you have to decide, whether you want to use a existing GA code in your problem, use some library or code it yourself.

A more descriptive question will help me to add more to this. What language are you looking to work in?

EDIT: I haven't used it myself, PARDISEO is a C++ template based library for among many other things, Genetic Algorithms, as well. Also, you can take a look at the C version of a Real Coded GA at http://www.iitk.ac.in/kangal/codes.shtml

From your(OP) comment:

Literally, all it does is load an xml file with some track coordinates, build the rails, and have teh camera follow these tracks like you were on a rollercoaster. All that in about 100 thousand lines of code

I think you would like to look at the track coordinates as possible design variables and see what combination of them give you a optimized (in terms of cost, better view, comfort, etc..) and then see what mathematical relation you can obtain among the best set. Then you are all set to apply GA to it. :)


What is the criteria for a succesful rollercoaster? Once you can describe that quantitatively, you have your fitness function. Then you need to consider what are the pieces of a rollercoaster? Is it something that you can even break down into pieces? If so, then you have your 'genes', and an individual rollercoast is a solution that can be tested against the fitness function, or mutated, or crossed over. Then you make a population of rollercoasters, do cross over and mutation on a sample size of the population and apply the fitness function to the individuals. You then keep the most fit individuals for the next generation, and repeat the process over again.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜