Evolving Cutting Horse and Sheepdog Behavior on a Simulated Flock Chris Beacham
Abstract The focus of this project is attempting to evolve the behavior of a single agent or small group of agents so that they can effectively direct the movement of a much larger group which displays flocking behavior. This is the same role sheepdogs play to manage herds of livestock.
Other Research There has been little development in this specific field. A lot has been focused on flocking, but not much on controlling flock movement. There was an attempt to build a robotic sheepdog, but their wasn’t much progress on the sheepdog’s behavior. It was an important proof of concept that a robot could be used to handle livestock.
Uses This project could have two foreseen applications: Animation – the current method of controlling flock direction for animation is quite crude. An invisible sheepdog might be very useful. Enhanced control of livestock – This is more unlikely. It’s possible that this project could yield new techniques for controlling flocks that are applicable to real life.
Sheepdog and Cutting Horse The sheepdog is used to direct the movements of sheep, ducks, cows, goats and other herd stock. It accomplishes this by moving around the herd or flock in specific ways. The cutting horse is used with herds of cattle. It’s job is to single out a single cow, and “cut” it off from the herd, thus allowing people to access it.
Flocking The herd will be simulated with a flocking algorithm. Three algorithms make up flocking behavior: Separation Cohesion Alignment
First Quarter The first quarter was spent creating a flocking behavior simulation, and debugging it. This is a screenshot of a flock flying to the right.
Second Quarter The first half of second quarter was spent getting the flocking simulation to settle down, and resemble a herd. This was finally accomplished, through lots of troubleshooting
Second Quarter After the herd was stabilized, a sheepdog agent was added to the simulation At this point, it’s behavior is fairly simple.
Second Quarter After trying out several methods of coding behavior, it was decided that the only one that could be implemented in a reasonable timescale was a weighting system Each sheepdog agent would add weight to pre- calculated vectors to determine it’s behavior. This doesn’t offer as much hope for dynamic behavior, but it is based off similar principals that flocking behavior is. If a good behavior is found, it will be easier to recreate and implement.
Second Quarter This is a screenshot of the first generation of sheepdogs. Their behavior is randomized, and incredibly chaotic. Unfortunately it is not visible in the still photo.
First Generation This is a sample of the genetic pool of the first generation. [ , , , , , , , , , ], [ , , , , , , , , , ], [ , , , , , , , , , ], [ , , , , , , , , , ], [ , , , , , , , , , ], [ , , , , , , , , , ], [ , , , , , , , , , ], [ , , , , , , , , , ],
Precursors Initially, an evolution program was written to fine tune the authors understanding of artificial evolution. This is a genepool of evolved creatures.
Programming Tools Python is being used for the code, with tKinter providing the graphics. Breve was looked at as a possibility, but it was dismissed for being to complex and not documented.