The Secret Soccer Strategies
of the Interrupting Cows

Who we are:

The Interrupting Cows are an ASCII Soccer team created for CS4324. They were developed on the premise that it is possible to plan (and code) successful soccer strategies. These strategies will succeed without the team having the ability to make on-the-fly changes. (This is much like the coach having the absolute say-so; there is no way for the players to disregard the plays when on the field). Unfortunately for all those soccer players out there, we hope to show that the coach does know best. For the purposes of this explanation, the goals are at the east and west ends of the field. Assume that the Interrupting Cows are always moving from the East to the West. There are four positions, two offense and two defense. The players switch position depending on who is closest to the ball. The two closest players play offense, and the two players farther out play defense. A player's position is determined at the beginning of each turn. This algorithm maximizes the capabilities of the players to work together as a team. Instead of the players attempting to keep up with the ball (difficult because the ball moves faster than they do), the closest player assumes the roll of aggressive forward, while the further players take the defensive roles. The advantage here is that if a player that was once defensive is now in the lead with the ball, it will charge, and another will take over defense automatically.

Vision

We can find out nearly exactly where the ball is to get an accurate distance measurement in addition to an angle, which will be used for the player strategies. We know wedges of visibilities from the ball angles, and we can composite multiple wedges to get a better guess. Of course, the ball may have moved then, so we use fuzzy balls to move into a superposition of states. In the event that we get an exact sighting, then the wonderful laws of quantum mechanics come in, and the ball cannot be elsewhere. We identify an exact ball position for the players' strategies by picking randomly from the weighted fuzzy balls.

Offensive Strategy

We have two players dedicated to offense at all times. Their chief goal is to get to the ball. The closest player to the ball moves in the direction of the ball but also tries to always stay east of it (this is to enable the player to kick the ball in the proper direction once he (she) arrives at the ball's location). The second closest player moves towards the ball if it is greater than half the kick distance away. (Kick distance is the definition of how far the ball will travel if unobstructed when kicked. This is defined by the main soccer program.) If it is not, then it will go towards the ball and align itself in a flanking position. The flanking position we use has the player further away stay a little back and to the side of the front player. This helps to protect against break aways by the other team and allows for support of the closer player.

Our players only employ a more refined strategy when they can actually see the ball. (The ball can only be seen if it is in a square directly adjacent to a player.)

Our strategy is based on the theory that the easiest way to score is to break away with the ball.

This is coded very specifically. You may notice some redundancies, but this is intentional to allow the coaches to fine tune the teams.


Defensive Strategy

The two players furthest away from the ball are our "defensive line". These two players work hard to protect our goal line. They both hang back and are quick to cut off any advances by the other team. The two players furthest away from the ball are defensive.

Of these two, the player closest to the ball is more aggressive. This player goes directly to the ball when it comes within its territory - the last part of the east end of the field. Otherwise, it hovers just about kick distance behind the ball and waits for action.

The player furthest away is designated goalie. As the other defensive player, it is in charge of not letting the ball cross the goal line. It does this by immediately attacking any ball that approaches it in the east quarter of the field. It stays back from the pack - about one and a half times kick distance - in order to guard against the break away and to better protect the goal line.

Results

In trial runs, the Interrupting Cows have performed very well against the teams provided in the ASCII soccer package. The Interrupting Cows consistently defeat all of the teams, with the exception of learn1 which does not compile properly and the Dynamic Rollers and Soccer Spaniels who we beat only 60% of the time. This algorithm as proven itself very effective against many different strategies. We hope to compete against other teams in the near future with similar (or better :) ) success.

The Results

We are undefeated against all other sample teams. except for Dynamic Rollers and Soccer Spaniels, whom we beat about 60% of the time. These two teams beat the other teams most of the time.

Interrupting Cows results
Dynamic Rollers and Soccer Spaniels results

The Source Code

main.c

You will need to create a directory cows for it and give it the other default files.

The Coaches

The plays and algorithms for the Interrupting Cows were developed by Gary Yngve and Alison Smith, junior computer science majors at Georgia Tech.
Gary may be contacted at gary@cc.gatech.edu
Alison may be contacted at ans@cc.gatech.edu


Back to the Interrupting Cows' Homepage