[Home]Melee

Robo Home | Changes | Preferences | AllPages

Showing revision 65
Melee competitions are your bot vs at least 2 other bots (and usually 9 others for a total of 10 bots.) These bots need to manage radar, energy consumption, and field location much more carefully than their 1v1 counterparts. A good melee bot is usually a good 1v1 bot, but the converse is not necessarily true. Field sizes for these battle are almost always larger than the default and usually are around 1000x1000 - though larger fields can make interesting battles when other bots are so far apart that they can't see each other. These bots are a good challange after OneOnOne due to the new variables that are added to the battle.

Feel free to list good Melee bots here.

-- Mike Dorgan


Stages to a melee battle
  1. 10 bots on field, bots in bad starting positions die right away. Hope you're not one of them.
  2. 6-7 bots on the field, fighting over corners and trying not to get pushed into crossfires
  3. 3-4 bots on field, everyone stays in their corners and snipes at each other. Try to get the other guys to target each other instead of you
  4. Duel

Impressive Melee bots


I thought I should start a separate page about MeleeStrategy, to give us a good place to talk about the sorts of strategic and design ideas that should go in a melee bot away from talking about individual bots too much. Some of this page's content might be duplicated/summarized there. -- Kawigi

Ok, so i have been trying to rework my melee strategy today, and i have a few questions/observations:

Any ideas anyone?? -- Brainfade

Well, I have had lots of ideas on selecting a target (see the page for SpareParts), but for most situations, firing at the closest is best. SpareParts switches around between shooting the closest ("convenience"), shooting the one that keeps shooting him ("vengeance"), shooting at the perceived 'weakest' robot ("smear the queer"), shooting at the robot he thinks he is most likely to hit ("feed off sitting duck"), and shooting (to try and get the kill) whoever has the least energy (this one doesn't seem to be that effective). Of those, I'd say smear the queer and convenience are the most effective methods. -- Kawigi

Do most top melee bots shoot blind (meaning not during a scan event on the target)? I seem to be getting lower bullet damage and higher survival in general as I'm working on a melee strategy for FloodHT. ABC? David Alves? Paul Evans? Iiley? Input? -- Kawigi

My melee bots (GlowBlowMelee and HawkOnFire) are not firing inside the scan event. this wouldn't be good because my bots are turning the radar all the time. My bots made a big jump foreward when I checked for getGunTurnRemaining?()==0. -- rozu

Tron also shoots blind, I tried waiting for a scan to fire but it seemed to get slightly worse results, especially if you are shooting low power bullets. Of course your targeting must account for the extra ticks since the last scan. -- ABC

Lol, go figure I'd name off 4 top melee bot authors and forget the one that has two in the top 10 ;-) You know, rozu, you REALLY have a knack for this. Maybe I just need to put more time into it, but I'm just not having nearly as easy of a time making a strong melee strategy. Thanks for the input, you two. By 'accounting for the ticks', in your case do you mean projecting the pattern forward further? How would a guess-factor type like myself go about doing that? (probably a question for David or Paul) -- Kawigi

DT doesen't have this problem as it 'locks' its radar on the target just before fireing, however if you are firing blind you will simply have to guess where the opponent is (simple linear projection would do for the missing ticks), then apply the guess factor from the guessed point. -- Paul Evans

Interesting. It would be interesting to use a linear projection (or maybe even a quadratic distance sort of projection if they are accelerating/decelerating) for their position. The point is, though, that my gun has to finish turning sometime, which means I'd have to anticipate when that would happen when I first turn my gun (and oddly, my position is also an issue there). Well, plenty to chew on here. Just a side thing, Paul - I do use linear interpolation of missed scans to update my wave bullets - do you do something similar, or more complex/accurate? -- Kawigi

Yes, In my case (PM), I project the pattern further. I also project my position one or two ticks further to account for the gun turning time (easy because Tron has a very predictable short term movement). About guess-factor targeting, I don't really know, but I would guess a method similar to SandboxDT should be the best bet, especially if you want to segment your stats by acceleration/deceleration. I have this strange feeling another SandboxLump(at least) is in the making, if you make it as powerfull as a DT 1.71 I'll have to end my "RC vacation" sooner than I expected... please take your time with the small details! ;) -- ABC

Lol, well, if anyone these days is going to end your "RC vacation", it will probably be Rozu. If I'm to be up in your league with this release, I'll be REALLY taking my time with it. I do think it's possible top-20 melee material at the moment, though (of course, I'd need Rozu to watch it to really know ;-) ). And I'd be happy with that for this release - especially if I could also start in the Pro League at the Robocode Outpost (but that seems to be hard to attain, too). Thanks for the help, though. The state of the art in dueling robots is well covered in these pages, but there seems to be just a modest amount of information on melee strategy, and very little on this level of detail. -- Kawigi

Yep, HawkOnFire is amazing! Rozu came up with a great melee movement, if he adds a good targeting it will surely become a melee king contender. -- ABC

Who says that HeadOnTargeting isn't good. especially if the bot is moving long ways (or even orbiting his enemy) this is a pretty good aiming methode (Troodon is another example). Or when have you seen lastly a micro bot getting first in the MiniBot Challenge (1-on-1) just using HeadOnTargeting :). no seriously, I'm working on it -- rozu

Wow, just checked the Minibot Challenge, amazing is an understatement! You doubled Troodon's score in micro melee! Definitely a king of melee contender, have you tried other simple targeting methods? Something like DuellistMiniMelee?'s "distance factored linear targeting" could maybe improve it's performance enough for at least a 2nd place in the EternalRumble. And would make me finally think seriously about data saving between battles. ;) About HeadOnTargeting, sure it is good, I remember in the "old days", when Tron was fighting Predator for the melee crown, I tried replacing Tron's (now obsolete) targeting with HeadOnTargeting, It got 4th/5th position, exactly what you are getting now with HawkOnFire... -- ABC

1st: pe.SandboxDT 1.91			257123	186150	13680	53577	3631	85	0	154	62	91
2nd: abc.Tron 1.5				217551	151350	8550	53645	3821	167	15	97	67	60
3rd: rz.HawkOnFire 0.1			200436	143900	4500	48745	2984	261	44	51	70	76
4th: rz.GlowBlowMelee 1.3			199193	144750	3420	47928	3026	68	0	40	90	61
5th: cx.mini.Nimrod 0.55			194469	127900	3870	58812	3408	395	81	47	75	61
6th: shinh.Entangled 0.3			191517	135750	5760	46636	3008	316	45	67	59	64
7th: davidalves.net.DuelistMiniMelee 1.2	176261	125850	3870	44102	2036	375	26	44	39	53
8th: tzu.TheArtOfWar 1.2			169196	112050	4410	49806	2679	250	0	49	52	45
9th: myl.micro.Troodon 1.10			164257	116700	2610	42901	1846	184	14	30	48	40
10th: ara.Shera 0.88			153118	104100	2790	43541	2206	433	47	31	32	50
this are 600 rounds, I couldn't wait till I passed 1000. therefore I can't say if this is enough, especially to see the difference from place 3 to 6. but it's obvious, to get first your bot should also be a top 1v1 fighter -- rozu

I just love when this happens (as rare as it is):

SYSTEM: Bonus for killing dummy.micro.Sparrow 2.5: 0
SYSTEM: Bonus for killing mld.Infinity 2.0: 5
SYSTEM: Bonus for killing kano.gamma.KanoGamma 1.8: 6
SYSTEM: Bonus for killing myl.micro.Troodon 1.10: 0
SYSTEM: Bonus for killing pe.SandboxDT 1.91: 5
SYSTEM: Bonus for killing cx.mini.Nimrod 0.55: 8
SYSTEM: Bonus for killing rz.GlowBlowMelee 1.3: 6
SYSTEM: kawigi.sbf.FloodHT wins the round.
I'm trying to get FloodHT among the top 5 in the RO Pro melee division (in hopes that it will qualify into it). I also wouldn't mind releasing a top-10 melee bot, but we have yet to see if I have it in me. I suppose a select few bots debut into the ER in the top 1nd and the last thing it prints out is 34463. -- Kawigi

Hi guys, were using robocode atring. It works great! Now I'm often leading in bullet damage against melee bots of my caliber. Thanks for the pointer, Paul! All I had to do is change my radar code to locking mode if my gun would be cool in the next 5 ticks, and it works like magic. -- Kawigi

eh? Andrew Ford

The melee radar that Kawigi, Paul and probably some others use is based on an alternating full area sweep and lock on target OneOnOne style radar. It sweeps the battlefield observing all bots, then goes into lock mode and scans only it's current target for the same period of time. What Kawigi said is that he gained a lot of accuracy by moving to lock mode right before firing as well, so as to have recent and thorough data on the target at fire time. To see this in action turn on visible scan arcs and run FloodHT or SandboxDT in a melee (SittingDucks are best as opponents since they don't have radars of their own to interfere with what you see). -- Kuuran

You'll see Coriantumr do the same thing, although with a much simpler, smaller way of doing it. -- Kawigi


Ok, so i've been playign around with melee recently (it's more fun than 1v1), but im having targeting problems. To cut a long story short if i run a melee with my bot and 9 SittingDucks? over 100 rounds and i count how many bullets i fire, and how many bullets hit, i get the following:
 
Bullet's Fired: 11624
Bullets Hit   : 6748

I am currently waiting for my gun to finish turning before firing, and have my radar spinning constantly so there is no period where i have no target, i always pick the closest enemy to target. I also dont fire when there are no enemies left. The bullets seem to randomly pass either side of the target, as if they have moved. Just to clarify i use both setAdjustGunForRobotTurn(true) and setAdjustRadarForGunTurn(true). The above results don't really tell half the story as there are situations where the bulelt misses the intended target and hits another bot (i didnt take that into account when getting the data) Anyone have any idea why nearly half my bullets are missing?? Puzzling... --Brainfade

I would have to see your gun's code, but from your description my guess is that you are firing at the bearing the enemy was in when you scanned him, and not at his position. Because you are moving, the e.getBearing()+getHeading() angle will not be correct when your gun finishes turning, specially when you are moving at full speed or the gun needs to turn a lot. Also, if you allways choose the closest enemy as a target, you will get a lot of "thrashing" between targets. Consider only changing target if the new bot comes closer than your current target by some margin. -- ABC

Alas, you were right i was just using the bearing from when i scanned rather than using its scanned position to work out a new angle according to where i was. As for thrashing between enemies, i wasn't strictly telling the truth when i said i always target the nearest enemy, i only change if the newly scanned bot is less than 90% the distance of the current target. I wanna try some stuff with target selection though. Hopefully now i can fix my pattern matcher, and have a reasonable melee bot. Cheers ABC... --Brainfade

Ok, new topic on which i need help - MeleePatternMatching --Brainfade

Something I haven't gotten quite right, in my one or two attempts. The funny thing is that my biggest problem last time I attempted it was too many scans (the occasional two consecutive scans and then assuming that they were 8 ticks apart). -- Kawigi


Ok, so i'm confuzzled. Regardless of who i test against and how much improvement i find i seem to find my rating always goes down. is there some kind of spell i have to cast before being able to make a decent melee bot?? :( --Brainfade

I would chose 10 others bots mixed with some of the top melee bots and some bots with more or less the same rating your bot has. then run at least 100 rounds (for minor tweaks I'd say 500) to take in new improvements if your score is getting better or discard them if it doesn't show up reasonably.

I just tested your bot... what I could see is that it had the lowest bulletdamage (even Graviton had more!!!). So I thought that it could be something with your gun: 1000x1000, 100 rounds:

1st: myl.nano.Graviton 1.10		7700	4550	910	1889	350	0	0	92	9	0
2nd: brainfade.melee.Genghis 0.34	3326	450	90	2688	81	1	14	9	91	0
If Genghis has a PM gun then I'd say it isn't working really well. -- rozu

Yeah, you were right. I was using a symbolic pattern matcher, generating the index using godel numbering on the change in xpos, and change in ypos. the problem is that (2^diff)*(3^ydiff) oftens ends up being over 65536, so when you cast it to a char it is being cast to 65536. I'll sort taht at some point, but for the moment i have modded one of Dummy's pattern matchers to fit the bill. hopefully there will be a vast improvement... --Brainfade

Or when you cast it as a char, it becomes ((2^diff)*(3^diff))%65536. And I assume that godel numbering somehow gives you some way to recover those numbers again? -- Kawigi

No, rather than trying to recover them i store the actual values i need in an array list, and just pulll them back out as needed. The problem is that it doesnt seem to become ((2^diff)*(3^diff))%65536, it actually just truncates the number to 65536, meaning that vastly different moves became theoretically equal., i suppose i could actually fix it by just adding %65536 into my code... -- Brainfade

It truncates the number to 65536? (of course, you probably mean 65535, because 65536 isn't a valid char (unsigned short) value). But it doesn't make sense for that to happen, because it's physically not truncation, it's an actual mathematical operation. My experiments show otherwise, though, at least with this snippet:

for (double i=0; i<100000; i++)
	System.out.println((int)((char)i) + "\t");
it does wrap around and the last thing it prints out is 34463. -- Kawigi

Hi guys, were using robocode at uni this semester. our final test is a melee consisting of about 30 robots (I KNOW!!!) since there are soo many bots, a couple of groups have decided to form an alliance. the basic idea is that when we scan a bot, we compair its name to about 7 of ours on a list, and if its there we dont fire. its not much but its less damage, and every little bit helps. my question is this, we need a way to find out if anyone is shooting the alliance team members (i.e. friendly fire), is there a way to communicate to different robots that arent set up as a team? if not then is there a way to know who fired a bullet and who it hit? (so we could all keep individual tallies) this way if someone friendly fires a certain number of times in a round, we dont include them in the next round. thanks -- Bolox

AFAIK you can't communicate with robots not in your Team.

  1. Way to detect who is hit by a bullet - measure EnergyDrop
  2. Way to detect who fired a bullet - measure bullet's heading and power, calculate bullet's speed, and then it's fire coordinates. The iterate through your enmies' movement history and find who was in calculated time in calculated position
Conclusion: unless it is your robot or you can communicate you can only do 1. but not 2. because you will not know heading of a bullet that hit other robot.

Ph

There is no way to communicate, but you can figure out who you hit in the onBulletHit? event, and who hit you in onHitByBullet?. You can print the results in onDeath and onWin. -- Jonathan

ok cool.. thanks guys --Bolox

can somebody help me with avoiding ramfire!?! he kicks my butt every time

Basically, keep moving (preferably sideways) and try to target it with some linear prediction. --GrubbmGait


Hey! How can my bot fight in melees in this site? My bot is KanoGamma 1.8.

We don't have any melee rumbles running actually. We should though... Let me consider it some. -- PEZ

If your bot is a mini or smaller, you could also consider entering it in the RobocodeLittleLeague. It would be nice though to have the melee rumble up and running again. --GrubbmGait

Melee is up and running again (17 januari 2005), although the rankings are far from stable yet. Now is the time to enter the frightening world of melee ! -- GrubbmGait

Any reason why there are no fights in Melee since the 27th? -- BigPete

No specific reason, just nobody is running meleebattles with RR@Home right now. My main computer is currently not available (hardisk crash) and my ancient laptop is not fit to run meleebattles. Also OneOnOne is more popular, but as soon as all bots there have reached around 1000 battles, someone will switch to melee. Remember that every battle fought is run on someones private computer. -- GrubbmGait

Yeah realised that. I have a couple servers lying around, will set them up once exams are over. Thanks. -- BigPete


Robo Home | Changes | Preferences | AllPages
Edit revision 65 of this page | View other revisions | View current revision
Edited May 5, 2006 6:20 EST by GrubbmGait (diff)
Search: