Submission Text Full Submission Page

Introduction

As I felt Generation II of the Pokémon games has been neglected in terms of TASing, I decided to look into it and maybe do a TAS of it myself. At that time, there was only FractalFusion's glitchless run (see here). But during the making of this run, interest in Gen II TASing increased significantly, and I was beat to the punch twice by TheZZAZZGlitch's run (here) and later bobmario511's run (here). I decided to continue anyway, as I planned on using a different route that promised to beat the game even faster, and this is the final result.
It is using the Coin Case glitch which was already used in TheZZAZZGlitch's submission, but it uses a different strategy to achieve an arbitrary code execution out of it.

Categories

  • Aims for the fastest completion time
  • Heavy luck manipulation
  • Heavy glitch abuse
  • Executes arbitrary code
Used emulator: BizHawk 1.5.3

About the run

Emulator choice

I already did my emulator research for my Pokémon Blue TAS (see here), so I knew that BizHawk would be the only suitable emulator for this run. Unfortunately, BizHawk had an awful desync problem with this game. I dug into the source code and found out that the RTC code was broken (bug report), and the BizHawk team was nice enough to include my fix for it. That means that you will need at least version 1.5.3 of BizHawk to run this movie without desyncs. Sadly, that does not mean you can create movies in BizHawk without encountering desyncs now, I found that rewinding, at least in the TASEditor, can still be somewhat buggy (due to an apparently unrelated bug). But since I'm using using BizHawk merely as a playback device for the movie file I create with an external program, and at least the movie playback works correctly now, it does all I need it to do.

Version choice

Pokémon Gold and Silver are considered the same category and there is no significant difference between them in terms of speed. The version differences in terms of encounters are irrelevant to this run, so I went with the version that was used in all the previous movies.

The goal

Unfortunately, this game does not have a very well defined end state, since rolling the credits does not actually mark the end of the game. The credits are played twice, once after beating the Elite Four, and once after beating Red. To make it even worse, beating Red does not actually do anything to your game state other than hiding his sprite on the map and rolling the credits, so there is no such thing as tricking the game into believing you beat Red, since it doesn't keep track of it anyway.
It's easy to see that having the goal defined as "beat Red" is not a good position to be in, since it is not clear whether a run actually beats the game. Here are some examples, gradually skipping more and more of the game:
  • Fight the Elite Four, go to Mt. Silver and beat Red.
  • Go to Mt. Silver and beat Red without beating the Elite Four by tricking the game into making him appear.
  • Go to Mt. Silver, talk to Red, but trick the game into skipping the fight.
  • Manipulating another NPC to become Red and therefore beat Red without going to Mt. Silver.
  • Don't talk to Red at all and jump straight to the text script that plays when he is defeated.
  • Ignore Red completely, and just manipulate the bytes to make him visible (simulates beating the Elite Four), invisible again (simulates beating Red) and jump to the credits.
It's obvious that there needs to be a line somewhere. The rules I used in this run are chosen to both be compatible with what the currently published runs do and also provide adequate visual feedback that you actually just beat Red.
  • You must be in Mt. Silver on the map Red is in.
  • You must talk to Red and run his unaltered NPC scripts until the credits roll.

Luck manipulation

As in any Pokémon TAS, luck manipulation is an important factor. The RNG is basically the same as in Gen I: a hardware clock is used to generate the two random bytes at 0xFFE3 and 0xFFE4, which are used to determine all random events in the game. As in Gen I, the RNG is considered to be unpredictable, so in order to get the results you want there is pretty much no other way than to try out different input combinations until you find one that works. To aid me in grinding this out, and also to do common tasks like walking or scrolling through text optimally, I used a computer program (which is a modified version of the one I wrote for my Pokémon Blue TAS). This run was entirely generated using it, which is also the cause for the high rerecord count.

The Coin Case Glitch

Unlike Gen I, Gen II is generally considered to be solidly programmed and contains only a few known useful glitches. This run uses only a single glitch, named Coin Case glitch.
When displaying the amount of coins the player has in his coin case, the developers accidentally put the wrong termination character at the end of the text string. Incidentally, this minuscule mistake of getting a single byte wrong in an otherwise pretty solid game can be used to rip the game apart and execute arbitrary code. The glitch itself was known to exist for a long time, but the actual research on what is going on and how to exploit it was initiated by Sanqui on the Glitch City forums (see here).

Code execution goals

In this run, the goal is to execute code such that we are able to beat Red (using the definition above) as fast as possible. In order to be able to beat Red we need to do several things:
  • Make Red appear in Mt. Silver: This is controlled by bit 2 of flag $d8a3. It is initially set ( = hidden) and is usually reset upon beating the Elite Four.
  • Teleport to Mt. Silver: Maps are specified using a map group and an index. Red is on map 0x44 in map group 3. To get there, we manipulate the map we are in to contain a warp straight to this map.
  • Skip the fight with Red: The Game has several fail-safes that will skip a fight. We can make the game believe we have no Pokémon in our party to trigger such a fail-safe by setting the number of Pokémon in our party to 0.

Code execution setup

In order to escalate a single faulty byte into an arbitrary code execution, some setup is required. After failing to finish processing the text properly, the game reads an invalid pointer and jumps to address $e112, which is in ECHO RAM and is actually $c112. In this chunk of RAM the game stores parameters for playing sound effects, more specifically SFX channels 5-8. Those parameters are reset frequently and are therefore usually filled with 0s (read: NOPs) and by chance end in a "ret" instruction eventually. That is the reason the bug is unnoticeable most of the time. If the game happened to play a sound effect right before you use the coin case, however, the parameters will contain data which will be interpreted as machine instructions. Most of the sound effects are harmless (read: not useful), with 5 exceptions: The cries of Bellsprout, Machop, Machoke, Omanyte and Celebi all happen to contain an "inc sp" instruction which corrupts the stack pointer (stack entries are 2 byte wide, but the stack pointer is incremented by only 1 byte). After corrupting the stack, the execution jumps to $eb12 (which is ECHO RAM for $cb12).
The memory $cb12 until $cbff is the end bit of a segment that stores the (meta-)tiles the current map is composed of. It is safe to assume that this is filled this 0s, since almost no map is big enough to acutally use the whole segment, so the execution will simply slide through to the next addresses.
Starting at $cc20, the game stores the new tiles the game needs to load when the player moves in the overworld. Every time a player moves, the newly visible tiles are loaded to here before transferring them to Video RAM. These are 40 (20x2) tiles when moving vertically, and 36 (2x18) tiles when moving horizontally. The addresses $cc20 to $cc48 contain the index numbers of the tiles in the current tileset. These values can only go up to 0x7f, which makes it impossible to trigger a (far) jump instruction, not to mention you would need to find a spot on some map that actually contains the data you want. The addresses $cc48 to $cc70 contain the corresponding palette IDs and are also way too small and too hard to manipulate for our purposes. The following addresses are what is useful to us: $cc70 to $cc98 contain pointers to the positions where the newly loaded tiles should be inserted in the BG map. The BG map is a 32x32 tile buffer located at $9800-$9C00 which holds the current background tiles. It features a "window", that defines the (20x18 tiles) portion of the buffer that is actually visible on screen. When moving, the new tiles are inserted at the respective edge of the window and then the window is moves smoothly to that side to create the moving effect. The position of this window resets every time the whole screen needs to be redrawn, which is every time something partially covers the screen, like menus, text boxes, battle screens, etc, so its position can be manipulated easily. If moving in a particular way, we can make these pointers include $98DA, $98FA, which spell out to the machine code "jp c,FA98".
So our journey continues at $da98 ($fa98 is ECHO RAM again), which is in the middle of the data for the third Pokémon in the players party. The next bytes look roughly as follows:
$da97-$da98   Attack EV
$da99-$da9a   Defense EV
$da9b-$da9c   Speed EV
$da9d-$da9e   Special EV
$da9f         Attack and Defense DVs
$daa0         Speed and Special DVs
Up to now we just bounced around in the game's RAM randomly, this is the first place where we can manipulate the data so that we go where we want it to. We can manipulate the DVs to be a RAM address we want to go to and the lower byte of the Special EV to be a jump instruction to bring us there. This run uses DVs 0xe3d8 and special EV 0x4c2 to spell out "jp nz,d8e3". Note that this is not the only address that would have worked, but it was the fastest DVs to manipulate and also the DV differences are irrelevant during the battles fought in this run.
So we arrived at our final destination, $d8e3, which is the name of the fifth PC Box. PC boxes can be renamed individually and their names are a single block of memory, which is ideal for manipulation. We can name the boxes to spell out any code we want, but we are limited to the characters in the alphabet that is provided. For some odd reason, you can actually use more different characters for box names than for other names, like the player name or the nickname for Pokémon. This is why other such blocks of names, like the nicknames of the party Pokémon, are not as useful.

The executed code

Disclaimer: The paragraphs below describe in detail what code is executed to achieve the goals stated above and how it works. It is very lengthy and technical, so if you're not interested you can just call it magic and skip the rest of this section.
The names used in this run are:
Box 5: 'v O  é  1  2  D  i  ♀
Box 6: T  é  2  2  T  é  7  2
Box 7: pk 's X  Y  Q  4  g  9
Box 8: Z  'm 0  2  p  1
which give the following block of bytes:
d6 8e ea f7 f8 83 a8 f5 50
93 ea f8 f8 93 ea fd f8 50
e1 d4 XX XX 90 fa a6 ff 50 // XX means that the values are actually irrelevant, they will be overwritten.
99 d2 f6 f8 af f7 50
and spell out the following code:
Bytes Instruction Comment
Box 5
d6 8e sub 8e a is bc initially -> a := 2e
ea f7 f8 ld (f8f7),a alter third byte in box 7
83 add e e is e1 -> a := 0f
a8 xor b b is eb -> a := e4
f5 push af push e400 on to stack
50 ld d,b end of string byte, harmless
Box 6
93 sub e e is e1 -> a := 03
ea f8 f8 ld (f8f8),a alter fourth byte in box 7
93 sub e e is e1 -> a := 22
ea fd f8 ld (f8fd),a alter ninth byte in box 7
50 ld d,b end of string byte, harmless
Box 7
e1 pop hl pop e400 from stack
d4 (2e) (03) call nc,032E this function delays the game by one frame; carry will never be set here
90 sub b a is 0 after the call returns, this sets the carry flag
fa a6 ff ld a,(FFA6) reads the joypad buttons that were pressed (which are fetched during the frame transition)
(22) ldi (hl),a writes joypad input to hl (e4XX) and increments hl
Box 8
99 sbc c c is always 0, subtract with carry will set the carry flag if a is 0
d2 f6 f8 jp nc,(F8F6) jumps back to "call nc,032E" if the joypad input was not 0
af xor a a := 0
f7 rst 30 execute code from e400
50 ld d,b dead code
This piece of code is a fully functional bootstrapping program for executing (almost) arbitrary code. It uses the joypad input as its code (note that there are exactly 8 buttons on a Gameboy that correspond to the 8 bits in the input byte). It continues reading inputs until the input is 0 (no buttons are pressed) for one frame and then executes the inputs. Most bytes can be inputed using this method, with the exception of the byte 0 (marks the end of the input sequence) and all bytes with a lower nibble of 0xf (i.e. 0x0f, 0x1f, 0x2f...), because pressing A+B+START+SELECT is used by the game for soft resets.
The code relies heavily on the initial values of the registers, which depends on every byte we went through during the coin case glitch, but is ultimately deterministic. The "rst 30" which is used to execute the code is not an actual reset handler function but the end bit of the actual reset handler at $28. What is does is essentially a "ld l,a" followed by "jp (hl)". That means as long as the number of written bytes is smaller than 256, this will bring us to the start of our written code.
The memory from $c400 onwards belongs to the tiles which are currently shown on the screen. I chose this memory location because it both is harmless to write to and gives nice visual feedback when the bytes are written literally on the screen.
The actual bytes which are written in this run are:
21 46 d9 36 18 23 36 c4
3e 76 ea 0b d2 97 ea 22
da ea a3 d8 f8 25 f9 c9
19 03 17 03 44 00
which spell out:
ld hl,d946     // stores pointer to warp data
ld (hl),18
inc hl
ld (hl),c4     // overwrite warp data pointer with $c418 (which is the address of the bytes after the "ret")
ld a,76
ld (d20b),a    // $d20b contains the tile the player currently stands on, tile $76 allows the warp we are going to perform.
sub a          // a := 0 (Note that "xor a" or "ld a,0" can't be used because of the limitations on the bytes we can input).
ld (da22),a    // $da22 stores the number of Pokémon currently in our party. Settings this to 0 will allow us to skip the Red fight.
ld (d8a3),a    // $d8a3 contains the flag that determines whether Red is visible on the map. Resetting the flag makes him visible.
ld hl,sp+25
ld sp,hl       // fixes the (still corrupted) stack pointer and lets us return straight to the overworld without leaving the main menu first.
ret            // return to the normal game code
19 03          // Position of the warp on the map. ($3,$19) is the exact position we will be standing when executing this code.
17 03 44       // Where the warp takes us. This is "entrance 0x17 of map 0x44 in map group 3". The map only has one intended entrance,
               //     entrance 0x17 reads invalid coordinates which happen to put us right next to Red.
00             // ends inputting bytes and starts execution.
A short explanation of warps in this game: There are two kinds of warps, "tile warps" and "edge warps". Tile warps are triggered when walking onto a specific position on the map. These are used e.g. for stairs or doors. Edge warps on the other hand are triggered when standing on it and moving towards a certain direction. They are used e.g. when exiting buildings. Which type some warp belongs to is determined by the index of the tile. By setting the current tile to $76, we enable an edge warp when walking to the left.

Comments on the route

Intro

  • I set the text speed to fast, turn off battle animations and set the battle style to "SET" to make the overall game play faster.
  • Date and time are irrelevant, so I simply go with the defaults.
  • I name the player "I". Like in Gen I, each character printed on the screen cost one frame, making shorter names faster.

New Bark Town

  • Totodile is the fastest starter for this route, very closely followed by Cyndaquil (they might actually be about the same).
  • I manipulate the DVs to be 14 Attack, 3 Defense, 13 Speed and 8 Special, which spell out the address $d8e3 needed to the arbitrary code execution. Having a suboptimal Special DV of 8, however, means that we will lose a total of three turns during the course of this run compared for having a DV of 15. Also, it is by far the hardest luck manipulation in this run.

Route 30

  • After beating Youngster Mikey, a wild Caterpie is fought in order to increase Totodile's special EV by 20. As explained above, we will need a specific amount of Special EV in order to be able to perform our arbitrary code execution out of the Coin Case glitch. Doing all mandatory fights, Croconaw ends up exactly 50 EV short (other EV values are possible but slower), so wild encounters are used to compensate. Unfortunately, you can't get 50 Special EV with a single wild encounter until Route 36, and we'll never get there in this run.

Violet City

  • The AI of Bird Keepers forces them to use a damaging move whenever possible, so taking damage from Spearow's Peck and Pidgeotto's Gust is unavoidable.
  • After beating Falkner and talking to the lab assistant in the Pokémon Center, I rename the Boxes to spell out the program I want to run during the Coin Case glitch, since this is the closest I'll get to a PC in this run.

Route 32

  • After beating Albert, I catch a Bellsprout. This Bellsprout serves several functions:
    • Adding Bellsprout to my PokeDex. This allows me to play Bellsprout's cry whenever I want, which is important to triggering the Coin Case glitch.
    • Increasing the number of party Pokémon to 3. I need to manipulate the third Pokémon's data, so I need to have at least 3 Pokémon.
    • Beating Russell. His Geodudes take a long time to kill using Totodile, since it doesn't know Water Gun yet. Using Bellsprout in the Russell fight is actually important to this route: Totodile's resulting Special EV, when using it instead, would require at least 3 wild encounters to fix.

Union Cave

  • After Russell is beaten using Bellsprout, a wild Zubat is fought in order to increase Totodile's special EV by 30. Now the Special EV will be 0x4c2 (1218) at the end, the exact value we need.

Slowpoke Well

  • The first Rocket has two identical Rattatas, but the first one needs two hits whereas the second one only needs one. The level-up to 13 after the first Rattata provides us with the extra damage needed.

Azalea City

  • In Azalea Gym you can choose between fighting Bug Catcher Josh or Al. Josh is about 7 seconds faster. I considered fighting Al nonetheless, because the resulting Special EV differs by 10, but it won't help in reducing the number of wild encounters.
  • The Bugsy fight is the only occasion in this run where using Rage is actually faster, but only because my DVs are suboptimal and 3 Water Gun crits won't kill.
  • Besides increasing our Special DV, fighting the wild Caterpie and Zubat help Totodile to reach level 18 after Bugsy and evolve into Croconaw, which saves time in the upcoming rival fight.

Ilex Forest

  • When hunting Farfetch'd, the route used here is not the shortest route in terms of steps, but it is faster by around 1.5 seconds (assuming you get no encounters of course).
  • Cut is taught to Bellsprout, since it still has an empty move slot.

Goldenrod City

  • Super Nerd Eric is the last trainer before finally getting the Coin Case and performing the glitch.
  • The text box for picking up the Coin Case resets the BG map window, so taking 3 steps to the left puts us in the right position to enable the jump to $fa98 when activation the Coin Case.
  • Croconaw is swapped to the third spot in our party. His special EV ans DVs contain values to allow jumping to $d8e3, where our code we put in as the Box names waits to be executed.
  • Bellsprout's cry is played by checking its stats and the Coin Case glitch is triggered. The glitchy characters that appear on the screen is the actual code written by the bootstrapping program.
  • Due to the executed code, there now is an edge warp to Mt. Silver directly to our left, so by walking to the left we end up in Mt. Silver right in front of Red. Also, because we returned directly to the overworld without leaving the item menu first, the screen is not redrawn and we see the item menu instead of the overworld until the map transition is done.
  • When I talk to Red, the fight is skipped since the game thinks we have no Pokémon in our party, and the credits roll.

Nach: Judging.
FractalFusion: Add Youtube.
FractalFusion: Replaced movie file with one that is about 10 seconds faster, and replaced temp Youtube encode.


Joined: 12/29/2007
Posts: 489
Fishaman P wrote:
If all the console runners use Gold and the TAS uses Gold, people are going to think Gold is faster. Just shake things up a bit :)
Seconding this; Silver is for some reason so underrated compared to Gold.
Skilled player (1041)
Joined: 7/24/2013
Posts: 175
I won't change to Silver in this submission, because I simply don't want to risk delaying it even more. I'm reasonably certain that the key features I need as well as the mechanics and the memory addresses are the same in Gold and Silver, but if anything goes wrong, because of a version difference I didn't anticipate (whether it is a good or a bad one), it could break my program and I would need to investigate and change it to cope with it, which could cost a lot of time. If I ever make another run of it, and I have more time to investigate and tinker around, I'll definitely look into using Silver, but at the moment I'm just trying to get an updated version going.
Player (27)
Joined: 3/2/2014
Posts: 34
Location: Canada
When I saw the submission for Gold glitched, I thought it used the any% glitched route, until I realized that you rerouted the whole "game" with a faster route. Yes vote for me.
Meerkov wrote:
The human element of the run is far more entertaining than the game itself. If it wasn't for someone lying about their record 40 years ago, I don't think we'd take a second look at this run/game. Meh vote.
Skilled player (1041)
Joined: 7/24/2013
Posts: 175
I finished the updatd version of this movie: http://tasvideos.org/userfiles/info/13184606113877724 It seems I can't update the submission file myself, I'd be great if someone can do that. I'll be updating the submission text to reflect the changes, though.
Editor, Expert player (2080)
Joined: 6/15/2005
Posts: 3284
Video of new improvement: Link to video
Joined: 1/9/2013
Posts: 27
Location: Virginia
Radiant wrote:
I'd say that if you're going for speed, anything that triggers the credits counts as a win;
inb4 the site gets tons of submissions of games that allow you to view the credits from the options menu? :P Also in this game you beat 8 gyms and then the elite 4, then the credits roll. ... then you go to the other continent and beat the other 8 gyms and then beat Red. So there's two examples why concrete definitions like that don't work around here, the second being the more important one to this discussion since Red is not just a bonus boss, there's actually a whole other continent of content between the first credit roll and fighting Red. One of the reasons Gen 2 and the remakes are my favorite pokemon games, the amount of content to beat. But anyways... Red is, indisputedly, the last boss of the game. He's a boss (special battle music, leadup, last in an area), and you have to beat all 16 gym leaders and the elite 4 just to gain access to him in a normal play, so he will always be the last one fought, and when you beat him he vanishes and the credits roll. The TAS uses bugs to skip to the final boss's room, activate the boss, talk to the boss, then insta-end the boss fight (making him vanish and rolling the credits). This TAS beats the game as far as I see it!
Joined: 5/14/2007
Posts: 525
Location: Pisces-Cetus filament
I like your choice for ending input. I suggested a different point in a previous post because I had not watched the run since a new run was being created and thought the credits played twice in the submitted movie. Fractal, do you still think Silver Version could be completed faster? I suggest these images for possible publication screenshots: I'm curious about one thing, though: Why did you delete the following sentences from the submission text when they still apply? - "Contains speed-entertainment tradeoffs" - "Also, using names other than "A" costs some frames, but naming everything in the run the same does not exactly add to the overall entertainment value."
AzumaK wrote: I swear my 1 year old daughter's favorite TASVideo is your R4MI run :3 xxNKxx wrote: ok thanks handsome feos :D Help improving TASVideos!
Editor, Player (95)
Joined: 5/27/2006
Posts: 240
Zeupar wrote:
I'm curious about one thing, though: Why did you delete the following sentences from the submission text when they still apply?
i believe he got rid of them in his updated version
Skilled player (1743)
Joined: 9/17/2009
Posts: 4986
Location: ̶C̶a̶n̶a̶d̶a̶ "Kanatah"
BioSpark wrote:
Zeupar wrote:
I'm curious about one thing, though: Why did you delete the following sentences from the submission text when they still apply?
i believe he got rid of them in his updated version
The updated encode has bellsprout with the name "B" rather than "A".
ALAKTORN
He/Him
Former player
Joined: 10/19/2009
Posts: 2527
Location: Italy
wait a second, I just noticed something in the Bugsy fight… against the Scyther, you 2HKO it without crits, doesn’t that mean that you could OHKO with a crit, considering crit is 2× damage? or does the boosted Rage attack not activate on the first turn, but only in the second, so in the first turn you can’t do as much damage as in 2 turns? edit: actually you do the same to the Zubat in the rival fight right after… 2HKO with no crit Scratch instead of 1HKO with crit, why is that?
Player (27)
Joined: 3/2/2014
Posts: 34
Location: Canada
jlun2 wrote:
Fishaman P wrote:
This is where we differ. Console runners require Red, so the TAS should too.
I agree, but only because it'll make the commenters on Youtube stop saying "now make a run that beats Red" or something. :P
If you really wanted the TAS to beat Red, you could always glitch a Level 1 Geodude and underflow it from level 1 to 100 (yes Experience Underflow works in GSC too). You still are beating RED, it's just that the battle ends instantly because you don't have any Pokemon in your party.
Meerkov wrote:
The human element of the run is far more entertaining than the game itself. If it wasn't for someone lying about their record 40 years ago, I don't think we'd take a second look at this run/game. Meh vote.
Joined: 12/31/2009
Posts: 174
luckytyphlosion wrote:
jlun2 wrote:
Fishaman P wrote:
This is where we differ. Console runners require Red, so the TAS should too.
I agree, but only because it'll make the commenters on Youtube stop saying "now make a run that beats Red" or something. :P
If you really wanted the TAS to beat Red, you could always glitch a Level 1 Geodude and underflow it from level 1 to 100 (yes Experience Underflow works in GSC too). You still are beating RED, it's just that the battle ends instantly because you don't have any Pokemon in your party.
Why bother with a geodude? You could literally modify bellsprout into anything you want.
Player (27)
Joined: 3/2/2014
Posts: 34
Location: Canada
Zanoab wrote:
luckytyphlosion wrote:
jlun2 wrote:
Fishaman P wrote:
This is where we differ. Console runners require Red, so the TAS should too.
I agree, but only because it'll make the commenters on Youtube stop saying "now make a run that beats Red" or something. :P
If you really wanted the TAS to beat Red, you could always glitch a Level 1 Geodude and underflow it from level 1 to 100 (yes Experience Underflow works in GSC too). You still are beating RED, it's just that the battle ends instantly because you don't have any Pokemon in your party.
Why bother with a geodude? You could literally modify bellsprout into anything you want.
Geodude gets Rollout, which doubles its power after every use, up to 5 turns. Eventually, it turns from a 30 base power to a 480 base power move.
Meerkov wrote:
The human element of the run is far more entertaining than the game itself. If it wasn't for someone lying about their record 40 years ago, I don't think we'd take a second look at this run/game. Meh vote.
Joined: 12/31/2009
Posts: 174
luckytyphlosion wrote:
Zanoab wrote:
luckytyphlosion wrote:
jlun2 wrote:
Fishaman P wrote:
This is where we differ. Console runners require Red, so the TAS should too.
I agree, but only because it'll make the commenters on Youtube stop saying "now make a run that beats Red" or something. :P
If you really wanted the TAS to beat Red, you could always glitch a Level 1 Geodude and underflow it from level 1 to 100 (yes Experience Underflow works in GSC too). You still are beating RED, it's just that the battle ends instantly because you don't have any Pokemon in your party.
Why bother with a geodude? You could literally modify bellsprout into anything you want.
Geodude gets Rollout, which doubles its power after every use, up to 5 turns. Eventually, it turns from a 30 base power to a 480 base power move.
I meant you could turn Bellsprout into any pokemon with any stats with any moves within a few seconds compared to taking a detour and manipulating a Geodude.
Chamale
He/Him
Player (182)
Joined: 10/20/2006
Posts: 1355
Location: Canada
luckytyphlosion wrote:
If you really wanted the TAS to beat Red, you could always glitch a Level 1 Geodude and underflow it from level 1 to 100 (yes Experience Underflow works in GSC too). You still are beating RED, it's just that the battle ends instantly because you don't have any Pokemon in your party.
While this would work, Geodude would have to go up all 99 levels individually. Zanoab is right, it's faster to glitch one of your Pokémon to a higher level anyway.
against the Scyther, you 2HKO it without crits, doesn’t that mean that you could OHKO with a crit, considering crit is 2× damage? or does the boosted Rage attack not activate on the first turn, but only in the second, so in the first turn you can’t do as much damage as in 2 turns?
In Gen 1 and Gen 2 crit is slightly less than 2x damage, so I don't think it would be possible to get the OHKO with a crit there.
Skilled player (1041)
Joined: 7/24/2013
Posts: 175
Chamale wrote:
against the Scyther, you 2HKO it without crits, doesn’t that mean that you could OHKO with a crit, considering crit is 2× damage? or does the boosted Rage attack not activate on the first turn, but only in the second, so in the first turn you can’t do as much damage as in 2 turns?
In Gen 1 and Gen 2 crit is slightly less than 2x damage, so I don't think it would be possible to get the OHKO with a crit there.
The crit mechanics in Gen I and II are different, while Gen I doubles your level for a crit, Gen II doubles your damage during the calculation. However, after considering the crit, 2 is added to the the final resulting damage, that means max crits are 2 damage less than double the amount of max non-crits. Additionally, You get a badge boost of 9/8 after beating Falkner, which only applies to non-crit damage (crits always use the original, unmodified stat for calculations). In the Bugsy fight, a max Rage crit is 40HP, while a max non-crit is 25, and Scyther has 50 HP. Zubat's case is similar.
ALAKTORN
He/Him
Former player
Joined: 10/19/2009
Posts: 2527
Location: Italy
thanks for the explanation, MrWint
Skilled player (1041)
Joined: 7/24/2013
Posts: 175
Zeupar wrote:
I'm curious about one thing, though: Why did you delete the following sentences from the submission text when they still apply? - "Contains speed-entertainment tradeoffs" - "Also, using names other than "A" costs some frames, but naming everything in the run the same does not exactly add to the overall entertainment value."
While the naming tradeoff still applies, I deemed it not worth mentioning anymore, the only reason I mentioned it in the first place was because I had a Speed-entertainment tradeoff paragraph anyway. On its own, it costs no more than 10 frames throughout the run, which is insignificant.
Editor, Expert player (2080)
Joined: 6/15/2005
Posts: 3284
Zeupar wrote:
Fractal, do you still think Silver Version could be completed faster?
I'm doing a test run right now, so I'm just using Gold. However, I had the idea that Silver might be faster based on an event that can be done during day time in Silver, but requires night time in Gold (which takes longer to set). It depends on if there are any other factors that depend on time of day.
Player (27)
Joined: 3/2/2014
Posts: 34
Location: Canada
Chamale wrote:
While this would work, Geodude would have to go up all 99 levels individually. Zanoab is right, it's faster to glitch one of your Pokémon to a higher level anyway.
I guess so. I was thinking about glitching a Geodude if it wasn't possible to change the species index and level of a Pokemon, which then you could use the Celebi Egg glitch a level 1 Geodude/Other Pokemon in the Medium Slow Experience group Egg.
FractalFusion wrote:
I'm doing a test run right now, so I'm just using Gold. However, I had the idea that Silver might be faster based on an event that can be done during day time in Silver, but requires night time in Gold (which takes longer to set). It depends on if there are any other factors that depend on time of day.
What event are you talking about?
Meerkov wrote:
The human element of the run is far more entertaining than the game itself. If it wasn't for someone lying about their record 40 years ago, I don't think we'd take a second look at this run/game. Meh vote.
Editor, Player (95)
Joined: 5/27/2006
Posts: 240
luckytyphlosion wrote:
I guess so. I was thinking about glitching a Geodude if it wasn't possible to change the species index and level of a Pokemon, which then you could use the Celebi Egg glitch a level 1 Geodude/Other Pokemon in the Medium Slow Experience group Egg.
i don't think you understand. by executing arbitrary code, he can do just about anything with the game. it would probably be easy to set bellsprout's attack and speed to some ridiculously high number to fight red.
Player (27)
Joined: 3/2/2014
Posts: 34
Location: Canada
BioSpark wrote:
i don't think you understand. by executing arbitrary code, he can do just about anything with the game. it would probably be easy to set bellsprout's attack and speed to some ridiculously high number to fight red.
I already know he could, but this was like an alternative in case he couldn't make a program to edit values of a Pokemon. He also has restrictions (assuming using the same code in the TAS) with his bootstrapping code which are: 1. You can't produce bytes ending with 0xF (0x1F, 0x2F, 0x3F etc.) and 2. the program can only be 256 bytes long. If you were to change Bellsprout to defeat RED's team, you would hack Bellsprout to have 188+ speed (faster than any Pokemon of RED's team), change its level to 100 and either change his moveset to Horn Drill with one PP up applied or change its attack to 999 and hack away with cut.
Meerkov wrote:
The human element of the run is far more entertaining than the game itself. If it wasn't for someone lying about their record 40 years ago, I don't think we'd take a second look at this run/game. Meh vote.
Patashu
He/Him
Joined: 10/2/2005
Posts: 4045
luckytyphlosion wrote:
BioSpark wrote:
i don't think you understand. by executing arbitrary code, he can do just about anything with the game. it would probably be easy to set bellsprout's attack and speed to some ridiculously high number to fight red.
I already know he could, but this was like an alternative in case he couldn't make a program to edit values of a Pokemon. He also has restrictions (assuming using the same code in the TAS) with his bootstrapping code which are: 1. You can't produce bytes ending with 0xF (0x1F, 0x2F, 0x3F etc.) and 2. the program can only be 256 bytes long.
He does, yes, but he could easily write a slightly longer bootstrapping code that gets around this restriction and it wouldn't take much longer. Or use the first bootstrap code to write a second bootstrap code, for example. Again - Once you have arbitrary code execution, you can satisfy any arbitrary category/requirements.
My Chiptune music, made in Famitracker: http://soundcloud.com/patashu My twitch. I stream mostly shmups & rhythm games http://twitch.tv/patashu My youtube, again shmups and rhythm games and misc stuff: http://youtube.com/user/patashu
Editor, Expert player (2080)
Joined: 6/15/2005
Posts: 3284
luckytyphlosion wrote:
FractalFusion wrote:
I'm doing a test run right now, so I'm just using Gold. However, I had the idea that Silver might be faster based on an event that can be done during day time in Silver, but requires night time in Gold (which takes longer to set). It depends on if there are any other factors that depend on time of day.
What event are you talking about?
A wild Pokemon that can poison the player. Weedle (Silver, day time), or Spinarak (Gold, night time).
Skilled player (1743)
Joined: 9/17/2009
Posts: 4986
Location: ̶C̶a̶n̶a̶d̶a̶ "Kanatah"
FractalFusion wrote:
A wild Pokemon that can poison the player. Weedle (Silver, day time), or Spinarak (Gold, night time).
How much would the route change?