These are the bots developed over a few hours in my Ruby on Rails Development Accelerator at Code Fellows. Sciencebot was the project I worked on with Mike Chen and Reed Nelson-Saunders. I then spent some extra time afterwards improving the algorithms. The bot is meant to counteract evasive dodging by locating an enemy tank and shooting in a random pattern around that location. It proves to be a solid algorithm, but only works well at long range.
Should I ever come back to this, future improvements would include improving the firing cone depending on range and a movement algorithm which sends the robot in the opposite direction of anything it detects, putting the chances most in its favor.
# Fork this repo, so you can submit your tank via PR
# Clone your fork. Then install the project dependencies
$ bundle install
# Run the sample robots
$ bundle exec rrobots Killa Duck
# Now go make your own!
If you have a problem installing the GOSU library, there's a helpful error message which links to this:
https://github.com/jlnr/gosu/wiki/Getting-Started-on-Linux
You may need to install a few packages
http://rubydoc.info/gems/rrobots/0.0.1/frames
https://github.com/ralreegorganon/rrobots
http://rubyforge.org/forum/?group_id=1109
battlefield_height #the height of the battlefield
battlefield_width #the width of the battlefield
energy #your remaining energy (if this drops below 0 you are dead)
gun_heading #the heading of your gun, 0 pointing east, 90 pointing
#north, 180 pointing west, 270 pointing south
gun_heat #your gun heat, if this is above 0 you can't shoot
heading #your robots heading, 0 pointing east, 90 pointing north,
#180 pointing west, 270 pointing south
size #your robots radius, if x <= size you hit the left wall
radar_heading #the heading of your radar, 0 pointing east,
#90 pointing north, 180 pointing west, 270 pointing south
time #ticks since match start
speed #your speed (-8/8)
x #your x coordinate, 0...battlefield_width
y #your y coordinate, 0...battlefield_height
accelerate(param) #accelerate (max speed is 8, max accelerate is 1/-1,
#negative speed means moving backwards)
stop #accelerates negative if moving forward (and vice versa),
#may take 8 ticks to stop (and you have to call it every tick)
fire(power) #fires a bullet in the direction of your gun,
#power is 0.1 - 3, this power will heat your gun
turn(degrees) #turns the robot (and the gun and the radar),
#max 10 degrees per tick
turn_gun(degrees) #turns the gun (and the radar), max 30 degrees per tick
turn_radar(degrees) #turns the radar, max 60 degrees per tick
dead #true if you are dead
say(msg) #shows msg above the robot on screen
broadcast(msg) #broadcasts msg to all bots (they receive 'broadcasts'
#events with the msg and rough direction)