Feel free to list good Melee bots here.
-- Mike Dorgan
Ok, so i have been trying to rework my melee strategy today, and i have a few questions/observations:
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 50this 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
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
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 0If 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.
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
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
Is there a problem in the server accepting results for melee battles? It seems that uploading my results allways fails... -- m3thos
Well, there are a large number of corrupted results files in the melee rumble right now. See RoboRumble/ReportedProblems, where rumble problems are usually posted and I made note of this just a few days back. Are all uploads failing, or just a very large number? -- Rednaxela
I ran the melee rumble for a little while last night when I was setting up a robocode environment again. It seemed to get a "500" error response when uploading results about 1/2 the time. I appologize if I shouldn't have been running it. -- Simonton
I'm doubtful it's your fault, as I've been getting those "500" error responses for a while for melee. I think it's because of the same corruption that happened in 1v1 a bit ago, except it went unnoticed/unrepaired in melee. Not certain though... =\ -- Rednaxela