For those thinking the japanese versions of Pokémon are the only ones that could be completed extremely fast with the use of glitches, well, the UE versions can be completed even faster.
By breaking the game into allowing the modification of its internal variables the main character gets into the Hall of Fame without receiving his first pokemon, yet his pokedex marks 152 out of 151 pokemon.

Game Objectives

  • The objective is to get to the credits as fast as possible.
  • Uses save and restart.
  • Displays extreme breaking of the game.
  • Uses mysterious warping.

Emulator used

  • Visual Boy Advance re-recording v19.3

Stupid Comments

This is an anime themed run! It gets to show Ash is a known cheater and definitely sharked his Pikachu and set his pokedex to mark 152 when there only existed 151 pokemon at the time.
At first it looked like he was going to have a normal day and meet Oak and get his first pokemon, but no, he had to beat Gary in getting to the league. And for that he had obtained a Game Shark.
First, he sharked balls for he wanted to be tripping them. Then he did the same with his items. While the items are scrolled we get to see the game scream OH S... in disbelief of what is going to happen. But nothing would stop it he was only thinking on himself.
After leaving Pallet, a wild Pidgey tried to steal his gameshark so he was forced to enter codes to summon his precious, the over nine thousand poké, so inmensely powerful it even raised the health of its enemy with only its presence.
Realizing that the road was going to be full of obstacles Ash hacked some more. On his mind there was only hate towards his enemy, and figures that resemble yellow and red Ponytas. He teleported straight to the Hall of Fame. What a surprise that Oak greeted him, he was supposed to wait for him at his lab! Oh crap, "Gary was here" written on the desk!?
"Well not only that, when you were out Team Rocket slammed into the lab, and hacked your pokedex leaving this message..."
(They also stole Pikachu)

Serious Comments

Hello, this is my first TAS. I found luck manipulation to be a chore, no idea how you guys do it manually and several times for a single run, if any of you do so of course.
Since I had to be staring at each frame while making this I had enough time to notice patterns or shapes on the glitches and make up a story as I went. If you feel lazy you can try to find what I used as inspiration by watching with frame advance.
Pokemon Yellow is the less buggy out of the first generation Pokemon games. Having been released last, there was time to patch errors like the well known Old Man (MissingNo.) glitch. It also lacks the Brock skip glitch for instance. Well it doesn't matter, it can be finished as quick as Red or Blue can.
Yes, the three games can be finished with this exact same route. Yellow is the slowest for the simple fact that it has ONE extra tile on its map which means you have to walk one extra step. Red and Blue lack this step. Out of the two, Red is the fastest because its first name choice for the protagonist is Red which has one less letter than Blue for Pokemon Blue. The name gets printed three times, for a total of 3 frames advantage for the red version.
Initially I didn't want to use an anime theme, I wanted to use Yellow as the protagonist and Blue as the rival's name. But the second option is Ash and it has much fewer letters than Yellow, for 5 frames advantage (9 minus 4 it takes to select the name). My main goal was not to get 2 minutes on the clock so I decided to save these frames just in case.
(That meant I had to name the rival Gary, despite Blue being the faster option (4 frames again). It would be a mistake not to go with the theme after naming the protagonist Ash on Pokemon Yellow, the Pikachu version... the one that after all tries to resemble the anime.-Scratch this) After a bit of testing, by using a custom name for the rival I eliminate a huge chunk of "lag" while scrolling items. This is not lag per se but the game glitching out due to the items it tries to display do not have valid item values and forcing you to press the B button several times. While scrolling the items I have to pass by the rival's name addresses, so I gave him a name that has values that correspond with actual items taking out the glitchiness (which could be considered bad because now the screen is less glitchy). I also used one of the "letters" to skip Oak. I used to go out of the way to get a value to skip him, but instead this is on the way and I don't lose time other than doing the item switch.
To be able to pull this route, I had to spawn with a trainer id of 76 in hexadecimal (on the lower byte, D359). This has a 1 in 256 chance of happening, and is set when you select New Game, but the random number generator at that time can't be manipulated without inserting idle frames. These frames can be inserted before any valid input given to the game and will modify the generator differently. Before choosing new game there are four valid inputs (first for Game Freak logo, second for intro, third for game logo, and fourth for New Game itself).
I checked manually the combinations of up to four idle frames, but didn't get the 76 I needed. So instead I made two programs do the work for me: One that created movies with every combination of idle frames and another that played these non stop until it found one that worked. I modified tas-movie-editor and Visual Boy Advance for this. They found the best combination quickly, at iteration 74 which corresponds with 5 idle frames.
With the first part of the puzzle I could continue with the plan. First I walked up to the point where I stop... yeah... Ok, it has some significance, one tile forward and the Oak skip trick won't work because the closest value that gets this done doesn't work one tile forward. It also makes it wait until the last moment to show that it is not going to be a normal run, I mean I could have saved as soon as the game started.
I use a save corruption exploit, reset while saving and your file may get corrupted, reset at a specific frame, and you will still be able to load your corrupted file. The corruption fills your owned pokemon data -which you have zero atm- with FFs, or 255 in decimal (if you watch the address D200 -VBA's Memory Watch window- you will see this after resetting). That area includes the pokemon owned counter, in other words the game thinks you have 255 pokemon on your belt, that's a lot of balls.
When Chamale wrote that this exploit gave him over 25 pokemon it rang my bell. I had been testing the ZZAZZ glitch since hanzou introduced it at the forum, this glitch ultimately ends with the overwriting of the items counter and subsequent memory shuffling that allows for a teleport to Hall of Fame as demostrated by hanzou. Since the game only has room for 6 pokemon but think you got 255, pokemon can be switched and that means overwriting data that are not pokemon with whatever data the pokemon had, and not only is this cool, the belt data is right before the owned items data, and having as values FF is perfect.
Switch your first pokemon with the tenth and you will overwrite the items counter, since you will be placing FF in there, now you will have 255 items, but 20 is the regular maximum! Below the item data there is important data, like your current area (D35D), coordinates (D35E, D360-D361 and D362-D363), badges (D355), trainer id (D358-D359), the rival's name, etc. So by manipulating your belt you can manipulate your items and then get access to manipulate this. Items use two bytes, the first for the item, the second for its quantity, so when you switch items you are exchanging four addresses (the two you switch from and the two you switch to). Tossing items modify the address on the quantity byte, these are the even addresses (0-2-4-etc). Completely tossing all of the item will shift all bytes by two, this will most of the time crash your game. The item with value FF is read as the Cancel button, and can't be tossed nor switched, unless the text Cancel doesn't show (and if you do you'll cause a single byte shift).
Now with access to this data from the items menu, I overwrite the area value to be able to get to Route 1 without triggering Oak. The closest value that doesn't crash the game (is FD and is quite far away, but it works -Scratch this too) is E7 and corresponds to the third character "!" given to the rival as his name, it is on the way while scrolling so no time is lost. Please keep in mind that Pokemon Red and Blue accept more values (they don't crash/freeze), like the Card Key item (30) that is on the way as well.
Now in Route 1 I proceed with the final step of a ZZAZZ attempt, to generate a teleport to another area. Get into a wild battle, and switch the area value with whatever value you want, then end the battle through whatever means. You'll spawn at the new location.
First things first, I needed a random encounter on the first possible step. You can't get a random encounter in Pallet so I had to get to Route 1. You can't get a random encounter on the step in which you enter Route 1, and you can't move right because the collision model is actually one tile to the left, (due to my playing with values to skip Oak) which means you are actually next to the wall. Moving left won't trigger a random battle because the grass is not there (in other words the grass is not shifted, only the collision). So the only way is up.
There are two pokemon that can be triggered, Pidgey and Rattata. Pidgey is 6 frames faster and I lucked out in getting one within two frames of optimal while recording the movie. There's no way to manipulate the RNG without adding idle frames. To manipulate it without them like for example primo's do, you have to hold the input when accepting text dialogs. There are none of those after I reset.
I used the bots again, this time there are more than 60 inputs, not four, before the random battle. That means anything bigger than 3 frames and it's hell (3 frames have like 90,000 combinations, which is still doable but would take several days). Since I already had a Pidgey within 2 frames though, the bots only had to check the combinations for one idle frame, which is nothing, and they found one valid run, on the last combination possible, getting a Pidgey with just one frame lost.
I wrote a small program to calculate the number of combinations for 'n' idle frames inserted before 68 possible inputs, lucky me I only had to do number 1:
  1. 68
  2. 2414
  3. 57154
  4. 971635
  5. 13991544 <- 13 Million something
  6. 170230452
  7. 1799579064 <- 1 Billion something
Anyway, the 76 I manipulated earlier as the trainer id is also the code for Hall of Fame, and the data is right next to each other so I don't waste time switching "items". When I switch, the data from one address goes to the other, so I am setting my area value as 76.
This is not the only switch required, because my current coordinate position values would get me out of the map at Hall of Fame and the game would crash. So I switch another item on top of their values keeping things cool.
Then I just run from the battle and profit. Oak is a smart man and can't be fooled easily, he proceeds with the registration but he knows what I did there.
By the way, the pokedex data is between your belt and the items, so when I switch pokemon I also complete the pokedex, in fact it now says 152 out of 151.
Since this wouldn't be complete without Team Rocket, well, they had to make an unexpected appearance, I wasn't expecting that the first time, with a dark tone for music change and everything. Even though the game is about to end, there is trouble ahead...
My RAM map is not complete, so there could be another method to teleport to Hall of Fame, even from the starting room, by creating a patch of grass, setting the exit or escape roping to the final room, or similar. Also, due to the variability of input and frames a couple frames improvement could be found by varying the button presses, I think this is called a "frame rule". But their effect is random, sometimes a combination will speed you a frame here and then slow you down in another place, and usually it is that it can't be sped up.
I DID use a "constant" combination I found and had no chance to use during the movie, I used it on the last dialog, pressing A then the next frame B on a dialog without an "arrow" makes it close 1 frame earlier. The movie's input ends at the same frame though because it's the last dialog.
For those wondering, the run is around 1 minute and 13 seconds according to the ingame timer (which only displays the minutes). DA3F is the address for the hour, then it goes to minutes, seconds and frames (60 fps). A 0:00 run sounds unlikely and the addresses are not even within range for manipulation so that's a no as well ;o

Other comments

I suggest you turn on Input Display, open Memory Watcher, enlarge its height to the max, and set it to watch the address D200 to D350 so you can "see" what happens in memory.
I don't think many people will get what is going on even if they know the Pokémon games. It is very possible to execute these glitches and NOT teleport to the end and instead play some more to make it more friendly to them, but my goal was to find out the final screen time display upon completion, was it going to be 0:00, 0:01 or 0:02? I got a movie where I "walk" to the Hall of Fame and it takes six minutes (perhaps five if optimized), but my goal was speed so I finished this one. All in all, there are enough glitches to perhaps do a glitchfest run, some walk on water, glitched battles, changing the music tempo, palettes, battling gym leaders but changing their pokemon, etc, (yes all that is possible, at the same time may not be so possible but that's what planning is for).
It may be possible to break a frame rule by using a different input combination on certain dialog. Usually it doesn't make a difference but sometimes pressing A alone is faster, or B the frame before then A, or A the frame before then B, or holding B and pressing A the frame that it has to be pressed, etc. When it doesn't work it usually makes you lose one frame instead. This frame advantage can be lost arbitrarily if the game wants to though, for example when you name yourself or your rival, or at reset. And of course a faster way to teleport to the end will also improve the run.
Suggested screenshots:

Bisqwit: Author submitted a replacement movie. Submission updated. Quoting Gia:
I missed a quite obvious optimization and after applying it I also lucked out with the random encounter, the improvement is 672 frames though, not 10.

NesVideoAgent: Hi! I am a robot. I took a few screenshots of this movie and placed them here.
Bisqwit: But the movie desynced for NVA, as it did for me. Removing the said screenshots.

adelikat: The glitching presented here is different enough to warrant a new category. So accepted for publication but not to obsolete the green run.


Chamale
He/Him
Player (206)
Joined: 10/20/2006
Posts: 1355
Location: Canada
zefiris wrote:
I disagree on subject of green run. It has all different glitches involved :(
Yes, but the theme is the same - skip everything and win with a game-breaking bug. BTW, a couple bits are unoptimal (and not just the name and Rattata). Going down the staircase and through the door would both be faster if, instead, you walked right into them rather than turning into them.
Joined: 10/26/2007
Posts: 35
I've seen a bunch of glitchy stuff in red/blue/yellow, but this was really unexpected. Definite yes vote, and yes to obsoleting the green run.
<i>If the day before the day before yesterday is three days after Saturday, what day is today?</i>
Editor, Expert player (2384)
Joined: 5/15/2007
Posts: 3942
Location: Germany
There've been so many game-breaking glitches discovered recently, I wonder how a ZZAZZ* run, if submitted, would be treated. Where is the line to draw, at which point does a run with XY glitches count as a 'glitched' run? If a warp is involved? Before this run was submitted, it looked like a ZZAZZ run would obsolete the current Pokemon Blue run by primo in 1:20. *(that's that one glitch with ditto and his transform move, right?)
Joined: 3/7/2006
Posts: 720
Location: UK
Vote yes for publication, vote no for obsoletion. They're both entertaining, in different ways. The generic save+reset 'bug' has been known for ages, whereas dokokashira is relatively new.
Voted NO for NO reason
Joined: 4/11/2006
Posts: 487
Location: North of Russia :[
dokokashira is more fun. If you talk about absoletion then I just vote AGAINST THIS movie.
BigBoct
He/Him
Editor, Former player
Joined: 8/9/2007
Posts: 1692
Location: Tiffin/Republic, OH
I absolutely love game-breaking bugs. Yes to publication, no to obsoleting the Green run, since they go about it differently.
Previous Name: boct1584
Active player (437)
Joined: 9/27/2004
Posts: 650
Location: Canada
I'm confused about one thing: Is it even possible to reset an actual GBC?
Joined: 2/26/2007
Posts: 1365
Location: Minnesota
I dont know about GB/GBC, but GBA/DS have a "hold down x buttons to reset." IIRC, though, GBA was the first to have this feature. Doesn't the movie use a hard reset, though?
adelikat wrote:
I very much agree with this post.
Bobmario511 wrote:
Forget party hats, Christmas tree hats all the way man.
Player (207)
Joined: 5/29/2004
Posts: 5712
Most Game Boy games let you reset by holding A, B, Start, and Select.
put yourself in my rocketpack if that poochie is one outrageous dude
Joined: 12/29/2007
Posts: 489
No. A+B+start+select is soft reset on GB, GBC, and GBA. (For DS, it's L+R+start+select). EDIT: Bag of Magic Food beat me to it. And this TAS totally blew my mind. I had absolutely no idea that a corrupted save file would cause THIS much glitchiness. But doesn't the game display a "Your save file is corrupted" kind of message? Or is that just for GBA and beyond? Yes vote.
Chamale
He/Him
Player (206)
Joined: 10/20/2006
Posts: 1355
Location: Canada
There is a "save file corrupted" message, but there's one frame where you can hard reset without the message showing.
Former player
Joined: 10/6/2007
Posts: 330
Location: B.C Canada
That was awesome! Really cool. Yes vote for publish, but it's completely different from the green run, so don't obsolete it. Oh, and I played the game a bit after the run ended, and it said you have caught 152 pokemon. It was also impossible to fight a battle.
gia
Player (109)
Joined: 5/3/2006
Posts: 223
Chamale, when I tested those rooms I tested them separately and didn't notice difference, but after doing both I got two frames when after exiting the house. I'm not sure I get what is not turning into the staircase though since it can be accessed from all four sides, I'll take it means having kept the direction for more than that step. Now I haven't handcrafted the movie again yet but just by removing the two frames gained I was not able to start walking earlier once I entered Route 1. ZZAZZ is done by invoking pkmn FE/FB during trainer fly, with the help of ditto. It is supposed to be a turn off/on while saving, not a reset button. To keep playing... ok this is an easy way, open Memory Viewer and type D162, the data will jump to that address. The first value should say FF and there should be a lot of those. Change the first one to "02". Now your belt won't have 255 pokemon, just 2. Now get pikachu, open the belt and switch your first with your third "blank" pokemon and pikachu will pop up, now you can play. You can also lvl up the glitched pokemon if you have them participate in the battle. If you put another number instead of 02 dont put 01 because you'll end up only with the first poke and it is fainted so you wont be able to move. Also make a savestate because if you start toying with the items you will crash a lot. If you want to toy with the 255 "glitched" pokemons you'll crash a lot more, just keep track of where you are until you hopefully find one you can switch to and end the battle with, the first/second/etc ones don't have usable moves.
Former player
Joined: 10/6/2007
Posts: 330
Location: B.C Canada
Well, I didn't really intend to continue. I just wanted to experiment a bit. As I walked, the poison flashes were going. That was funny since I had no visable pokemon.
Player (207)
Joined: 5/29/2004
Posts: 5712
So if you do that and then get the Pokedex, will it be completely filled in, since the game said you'd seen and owned 152 Pokemon before? Or does it not work like that? It would be nice to see all the Pokedex entries in the game without having to do so much.
put yourself in my rocketpack if that poochie is one outrageous dude
gia
Player (109)
Joined: 5/3/2006
Posts: 223
No idea, but unless the event of getting the pokedex clears the pokedex data it should work, the pokedex data is just bitflags, and you set them all to true on that pkmn switch. They are not visible but they are the FF pokemon, one with value 255, and all its data is full of FFs so its stats are 65535 hp, att, def etc, and that includes their name, the poison will take ages to faint the pokes so don't bother. The first one is fainted because it partially comes from your item data (which is empty = full of 00s). Btw on the same sense, don't wait until the burn/poison animation ends, with that much life it takes a long while ;o As you go down you start reading other memory values (the same I read while opening the items menu), so you start getting other pokemon. About their name, names have 11 characters, and require the value "50" to mark the end of the name (that means your name can be max 10 chars), since all addresses get overwritten, that's why you get the 99999999999999... poke, because it keeps going since it doesn't find the ending marker. It gets displayed as blank on the party menu because FF is used as cancel button on menus and has a cloaking effect, any pokemon after the FF poke doesn't get displayed even if it is there, so we don't get to see its name (or pikachu's if you get it), move a pokemon before FF and its name will get displayed.
Editor, Expert player (2384)
Joined: 5/15/2007
Posts: 3942
Location: Germany
Bag of Magic Food wrote:
So if you do that and then get the Pokedex, will it be completely filled in, since the game said you'd seen and owned 152 Pokemon before? Or does it not work like that? It would be nice to see all the Pokedex entries in the game without having to do so much.
Btw, you already glitched the Pokedex, so there's no need to get it anymore.
Joined: 4/11/2006
Posts: 487
Location: North of Russia :[
wait wait wait... then it goes to separate category. "catch'em all" one XD
Chamale
He/Him
Player (206)
Joined: 10/20/2006
Posts: 1355
Location: Canada
Whoa, 10 second improvement all of a sudden? What was the "obvious optimization?"
gia
Player (109)
Joined: 5/3/2006
Posts: 223
Uh if you check third post of 3rd page its that old you just didn't notice. The comments have the explanation.
Editor, Expert player (2483)
Joined: 4/8/2005
Posts: 1573
Location: Gone for a year, just for varietyyyyyyyyy!!
Hello, gia! I haven't watched this nice Poke movie yet, but I'll try to watch it soon..
gia wrote:
About Kings Bounty I had just read that topic a couple days ago!, my bot is for VBA not Genesis, if the emulator's code is public I suppose I could write a quick movie bot provided I don't get lost in the code, but I'd definitely not run it, Aqfaq might be interested though.
Thank you. I'm not any better at running bots than anyone else here, so if you make it work, please give public instruction on how to use it, so that other people (like alden) can try it too. (I'm not sure who would be the author of the movie, if the bot finds an improvement, but I really don't care about that.) I have no idea what would be the best instructions for the bot, but I'll check out some stuff and try to give some efficiency ideas for it soon (although you probably already know all the relevant stuff much better than I do). For avoiding cluttered threads, let's continue the King's Bounty bot discussion here: http://tasvideos.org/forum/viewtopic.php?p=165570#165570 Edit: Or if you are planning to make the bot a more general tool, please create another thread for it.
Emulator Coder
Joined: 6/8/2005
Posts: 237
Location: Madison, Wisconsin
Ye gods, it's over already. :)
Editor, Expert player (2483)
Joined: 4/8/2005
Posts: 1573
Location: Gone for a year, just for varietyyyyyyyyy!!
I have never played this game, but thanks to the detailed comments by the author, I had no problem understanding what happened. This is thoroughly extraordinary, funny and clever.
Joined: 4/26/2008
Posts: 46
Location: Glasgow, Scotland.
I don't think i've seen a game broken so hard. A definate yes vote from me.
Active player (329)
Joined: 2/23/2005
Posts: 786
Just posting to say that I saw this and laughed hysterically at it. Yes vote #48.