Super Rotation System: Difference between revisions

From TetrisWiki
Jump to navigation Jump to search
No edit summary
 
 
(80 intermediate revisions by 34 users not shown)
Line 1: Line 1:
'''''Super Rotation System''''', or '''''SRS''''' is the current [[Tetris Guideline]] standard for how [[tetrominoes|tetromino]] behave, in a broad sense. SRS represents where and how tetrominoes spawn, how they [[rotate]], and what [[wall kick|wall kicks]] they may preform. In [[Tetris The Grand Master 3 Terror-Instinct|TI]], a player may choose between ''World'' and ''Classic'' rotation styles. ''World'' closely resembles SRS, and ''Classic'' closely resembles the rotation styles of its predecessors TGM and TAP. [[Henk Rogers]], in his effort to unify all new Tetris games into the Tetris Guideline, required [[Arika]] to include SRS, which they named ''World''. SRS traces its routes back to 1991 when [[BPS]] introduced its signature third and fourth orientations for the ''S'', ''Z'', and ''I'' tetrominoes in their [[Tetris 2 and Bombliss|Tetris 2+Bombliss]]. Later would come flipped-side-up spawned ''T'', ''L'', and ''J'' tetrominoes, and flexible new wall kicks. Probably the most accurate SRS finds itself in BPS's latest games [[Tetris Worlds]] and [[Tetris Deluxe]], which both feature exact same rotation styles.
The '''Super Rotation System''', or '''SRS''' is the current [[Tetris Guideline]] standard for how [[tetromino|tetrominoes]] [[rotate]] and what [[wall kick|wall kicks]] they may perform. SRS traces its roots back to 1991 when [[BPS]] introduced third and fourth rotation states for the ''S'', ''Z'', and ''I'' tetrominoes in the game [[Tetris 2 + Bombliss]]. Two years later, in the game [[Tetris Battle Gaiden]], BPS altered the spawn orientation of the ''T'', ''L'', and ''J'' tetrominoes so that they spawned flat-side first. It was not until the 2001 game, [[Tetris Worlds]], that the wall kick system was introduced, and SRS took its final form. [[Henk Rogers]], in his effort to unify all new Tetris games into the Tetris Guideline, required [[Arika]] to include a form of SRS in their 2005 game, [[Tetris The Grand Master 3 Terror-Instinct]], where it is called "World" rule, in reference to ''Tetris Worlds''.  
==External Links==
 
*[http://www.tetrisconcept.com/tdsg.txt Tetris DS Systems Guide]
==Spawn Orientation and Location==
[[Image:SRS-pieces.png|thumb|The 4 rotation states of all 7 tetrominoes. Starting with the spawn state on the left, the 4 rotation states resulting from successive clockwise rotations are shown in order. The circles merely help to illustrate rotation centers and do not appear in-game.]]
The spawn orientations are included in the diagram on the right.
* All tetrominoes spawn horizontally.
* The ''I'' and ''O'' tetrominoes spawn centrally, and the other, 3-cell wide tetrominoes spawn rounded to the left.
* The ''J'', ''L'' and ''T'' spawn flat-side first, while ''I'', ''S'' and ''Z'' spawn in their upper horizontal orientation.
* In Tetris Worlds, the tetrominoes spawn in rows 22 and 23 (or just row 22 in the case of the "I" tetromino), however, in later games the tetrominoes spawn 1 row lower. Some games spawn the tetrominoes another row lower (in rows 20 and 21), such as ''[[Tetris Effect]]''.
 
==Basic Rotation==
The basic rotation states are shown in the diagram on the right.
Some points to note:
* When unobstructed, the tetrominoes all appear to rotate purely about a single point. These apparent rotation centers are shown as circles in the diagram.
* It is a pure rotation in a mathematical sense, as opposed to the combination of rotation and translation found in other systems such as [[Sega Rotation]] and [[Atari Rotation]].
* As a direct consequence, the ''J'', ''L'', ''S'', ''T'' and ''Z'' tetrominoes have 1 of their 4 states (the spawn state) in a "floating" position where they are not in contact with the bottom of their [[bounding box]].
* This allows the bounding box to descend below the surface of the stack (or the floor of the playing field) making it impossible for the tetrominoes to be rotated without the aid of floor kicks.
* The ''S'', ''Z'' and ''I'' tetrominoes have two horizontally oriented states and two vertically oriented states. It can be argued that having two vertical states leads to faster [[:Category:SRS finesse|finesse]].
* For the ''I'' and ''O'' tetrominoes, the apparent rotation center is at the intersection of gridlines, whereas for the ''J'', ''L'', ''S'', ''T'' and ''Z'' tetrominoes, the rotation center coincides with the center of one of the four constituent [[mino]]s.
 
==Wall Kicks==
When the player attempts to rotate a tetromino, but the position it would normally occupy after basic rotation is obstructed, (either by the wall or floor of the playfield, or by the stack), the game will attempt to "kick" the tetromino into an alternative position nearby.
Some points to note:
* When a rotation is attempted, 5 positions are sequentially tested (inclusive of basic rotation); if none are available, the rotation fails completely.
* Which positions are tested is determined by the initial rotation state, and the desired final rotation state. Because it is possible to rotate both clockwise and counter-clockwise, for each of the 4 initial states there are 2 final states. Therefore there are a total of 8 possible rotations for each tetromino and 8 sets of wall kick data need to be described.
* The positions are commonly described as a sequence of <tt>(&nbsp;x,&nbsp;y)</tt> kick values representing translations relative to basic rotation; a convention of positive x rightwards, positive y upwards is used, e.g. <tt>(-1,+2)</tt> would indicate a kick of 1 cell left and 2 cells up.
* The ''J'', ''L'', ''S'', ''T'' and ''Z'' tetrominoes all share the same kick values, the ''I'' tetromino has its own set of kick values, and the ''O'' tetromino does not kick.
* Several different conventions are commonly used for the naming of the rotation states. On this page, the following convention will be used:
**0 = spawn state
**R = state resulting from a clockwise rotation ("right") from spawn
**L = state resulting from a counter-clockwise ("left") rotation from spawn
**2 = state resulting from 2 successive rotations in either direction from spawn.
 
 
{| border="1" cellspacing="0"
|+'''J, L, S, T, Z Tetromino Wall Kick Data'''
|- align = center
! width="45"|
! bgcolor="#80A3F8" width="60"|Test 1
! bgcolor="#80A3F8" width="60"|Test 2
! bgcolor="#80A3F8" width="60"|Test 3
! bgcolor="#80A3F8" width="60"|Test 4
! bgcolor="#80A3F8" width="60"|Test 5
|- align = center
| bgcolor="#80A3F8"|0->R||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(-1,+1)</tt>||<tt>( 0,-2)</tt>||<tt>(-1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|R->0||<tt>( 0, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(+1,-1)</tt>||<tt>( 0,+2)</tt>||<tt>(+1,+2)</tt>
|- align = center
| bgcolor="#80A3F8"|R->2||<tt>( 0, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(+1,-1)</tt>||<tt>( 0,+2)</tt>||<tt>(+1,+2)</tt>
|- align = center
| bgcolor="#80A3F8"|2->R||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(-1,+1)</tt>||<tt>( 0,-2)</tt>||<tt>(-1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|2->L||<tt>( 0, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(+1,+1)</tt>||<tt>( 0,-2)</tt>||<tt>(+1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|L->2||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(-1,-1)</tt>||<tt>( 0,+2)</tt>||<tt>(-1,+2)</tt>
|- align = center
| bgcolor="#80A3F8"|L->0||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(-1,-1)</tt>||<tt>( 0,+2)</tt>||<tt>(-1,+2)</tt>
|- align = center
| bgcolor="#80A3F8"|0->L||<tt>( 0, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(+1,+1)</tt>||<tt>( 0,-2)</tt>||<tt>(+1,-2)</tt>
|}
 
 
 
{| border="1" cellspacing="0"
|+'''I Tetromino Wall Kick Data'''
|- align = center
! width="45"|
! bgcolor="#80A3F8" width="60"|Test 1
! bgcolor="#80A3F8" width="60"|Test 2
! bgcolor="#80A3F8" width="60"|Test 3
! bgcolor="#80A3F8" width="60"|Test 4
! bgcolor="#80A3F8" width="60"|Test 5
|- align = center
| bgcolor="#80A3F8"|0->R||<tt>( 0, 0)</tt>||<tt>(-2, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(-2,-1)</tt>||<tt>(+1,+2)</tt>
|- align = center
| bgcolor="#80A3F8"|R->0||<tt>( 0, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2,+1)</tt>||<tt>(-1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|R->2||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1,+2)</tt>||<tt>(+2,-1)</tt>
|- align = center
| bgcolor="#80A3F8"|2->R||<tt>( 0, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(-2, 0)</tt>||<tt>(+1,-2)</tt>||<tt>(-2,+1)</tt>
|- align = center
| bgcolor="#80A3F8"|2->L||<tt>( 0, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2,+1)</tt>||<tt>(-1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|L->2||<tt>( 0, 0)</tt>||<tt>(-2, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(-2,-1)</tt>||<tt>(+1,+2)</tt>
|- align = center
| bgcolor="#80A3F8"|L->0||<tt>( 0, 0)</tt>||<tt>(+1, 0)</tt>||<tt>(-2, 0)</tt>||<tt>(+1,-2)</tt>||<tt>(-2,+1)</tt>
|- align = center
| bgcolor="#80A3F8"|0->L||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1,+2)</tt>||<tt>(+2,-1)</tt>
|}
 
 
'''A wall kick example:'''<br>
The desired rotation is 0->L, and from the table above, the wall kick test order is <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(+1,&nbsp;0)</tt>, <tt>(+1,+1)</tt>, <tt>(&nbsp;0,-2)</tt>, <tt>(+1,-2)</tt>.
 
{| cellpadding="2" style="border:1px solid darkgray;"
|- valign=top
|width="200pt"|<playfield>
..........
....GG....
...J.GGG..
...JJJGGGG
.GGG...GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG
</playfield>
'''1.''' Initial position.<br>
Attempt to rotate 0->L.
|width="200pt"|<playfield>
..........
....GG....
....JGGG..
....J.GGGG
.GGXJ..GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG
</playfield>
'''2.''' Test 1, <tt>( 0, 0)</tt> fails.<br>
(Basic rotation fails.)
|width="200pt"|<playfield>
..........
....GG....
.....XGG..
.....JGGGG
.GGGJJ.GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG
</playfield>
'''3.''' Test 2, <tt>(+1, 0)</tt> fails.
|}
 
{| cellpadding="2" style="border:1px solid darkgray;"
|- valign=top
|width="200pt"|<playfield>
..........
....GX....
.....XGG..
....JJGGGG
.GGG...GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG
</playfield>
'''4.''' Test 3, <tt>(+1,+1)</tt> fails.
|width="200pt"|<playfield>
..........
....GG....
.....GGG..
......GGGG
.GGGJ..GGG
GG..J.GGGG
GGGXJ.GGGG
GGGGG.GGGG
</playfield>
'''5.''' Test 4, <tt>( 0,-2)</tt> fails.
|width="200pt"|<playfield>
..........
....GG....
.....GGG..
......GGGG
.GGG.J.GGG
GG...JGGGG
GGGGJJGGGG
GGGGG.GGGG
</playfield>
'''6.''' Final position.<br>
Test 5, <tt>(+1,-2)</tt> succeeds.
|}
 
==Arika SRS==
In their games [[Tetris The Grand Master 3 Terror-Instinct]] and [[Tetris The Grand Master Ace]], Arika were required to include a form of SRS as the default rotation system, in order to conform more closely to [[The Tetris Company]]'s Tetris Guideline. Arika's implementation of SRS uses the exact same wall kick data for the ''J'', ''L'', ''S'', ''T'' and ''Z'' tetrominoes as the Guideline's standard; however, the ''I'' tetromino uses the wall kick data shown below, with differences highlighted:
 
{| border="1" cellspacing="0"
|+'''Arika I Tetromino Wall Kick Data'''
|- align = center
! width="45"|
! bgcolor="#80A3F8" width="60"|Test 1
! bgcolor="#80A3F8" width="60"|Test 2
! bgcolor="#80A3F8" width="60"|Test 3
! bgcolor="#80A3F8" width="60"|Test 4
! bgcolor="#80A3F8" width="60"|Test 5
|- align = center
| bgcolor="#80A3F8"|0->R||<tt>( 0, 0)</tt>||<tt>(-2, 0)</tt>||<tt>(+1, 0)</tt>||bgcolor="#FFFFCC"|<tt>(+1,+2)</tt>||bgcolor="#FFFFCC"|<tt>(-2,-1)</tt>
|- align = center
| bgcolor="#80A3F8"|R->0||<tt>( 0, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2,+1)</tt>||<tt>(-1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|R->2||<tt>( 0, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1,+2)</tt>||<tt>(+2,-1)</tt>
|- align = center
| bgcolor="#80A3F8"|2->R||<tt>( 0, 0)</tt>||bgcolor="#FFFFCC"|<tt>(-2, 0)</tt>||bgcolor="#FFFFCC"|<tt>(+1, 0)</tt>||bgcolor="#FFFFCC"|<tt>(-2,+1)</tt>||bgcolor="#FFFFCC"|<tt>(+1,-1)</tt>
|- align = center
| bgcolor="#80A3F8"|2->L||<tt>( 0, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2,+1)</tt>||bgcolor="#FFFFCC"|<tt>(-1,-1)</tt>
|- align = center
| bgcolor="#80A3F8"|L->2||<tt>( 0, 0)</tt>||bgcolor="#FFFFCC"|<tt>(+1, 0)</tt>||bgcolor="#FFFFCC"|<tt>(-2, 0)</tt>||bgcolor="#FFFFCC"|<tt>(+1,+2)</tt>||bgcolor="#FFFFCC"|<tt>(-2,-1)</tt>
|- align = center
| bgcolor="#80A3F8"|L->0||<tt>( 0, 0)</tt>||bgcolor="#FFFFCC"|<tt>(-2, 0)</tt>||bgcolor="#FFFFCC"|<tt>(+1, 0)</tt>||bgcolor="#FFFFCC"|<tt>(-2,+1)</tt>||bgcolor="#FFFFCC"|<tt>(+1,-2)</tt>
|- align = center
| bgcolor="#80A3F8"|0->L||<tt>( 0, 0)</tt>||bgcolor="#FFFFCC"|<tt>(+2, 0)</tt>||bgcolor="#FFFFCC"|<tt>(-1, 0)</tt>||<tt>(-1,+2)</tt>||<tt>(+2,-1)</tt>
|}
 
The logic behind Arika's modifications is that the ''I'' wall kicks are now symmetric about the y-axis when rotating from or to a horizontal orientation. One noticeable consequence of this is illustrated in the following example:
 
{| cellpadding="2" style="border:1px solid darkgray;"
|- valign=top
|width="150pt"|<playfield>
..........
----......
.GG.GGGGGG
.GG.GGGGGG
IGGGGGGGGG
IGGGGGGGGG
IGGGGGGGGG
IGGGGGGGGG
</playfield>
|width="350pt"|From the dotted position, it is possible to clear 4 lines with both Guideline and Arika SRS by rotating ''clockwise''.
|}
{| cellpadding="2" style="border:1px solid darkgray;"
|- valign=top
|width="150pt"|<playfield>
..........
......----
GGGGGG.GG.
GGGGGG.GG.
GGGGGGGGGI
GGGGGGGGGI
GGGGGGGGGI
GGGGGGGGGI
</playfield>
|width="350pt"|In the symmetric position, only Arika SRS allows the clearing of 4 lines by rotating ''counter-clockwise''.
|}
{| cellpadding="2" style="border:1px solid darkgray;"
|- valign=top
|width="150pt"|<playfield>
......I...
......I---
GGGGGGIGG.
GGGGGGIGG.
GGGGGGGGG.
GGGGGGGGG.
GGGGGGGGG.
GGGGGGGGG.
</playfield>
|width="350pt"|Arika SRS also allows for this position to be achieved by rotating ''clockwise''. However, with Guideline SRS, this is the ''only'' position achievable, regardless of which direction the player rotates.
|}
 
==How Guideline SRS ''Really'' Works==
[[File:SRS-true-rotations.png | thumb | The internal true rotations used in Guideline SRS; offsets are applied to these.]]
 
Instead of directly assigning a set of <tt>(&nbsp;x,&nbsp;y)</tt> kick translations to each of the 8 possible ''rotations'', [[TTC]] actually employed a different approach, and instead assigned a set of <tt>(&nbsp;x,&nbsp;y)</tt> "offset" values to the 4 ''rotation states''. The kick translations are then derived by taking the difference between pairs of offset data. When rotating from A to B, subtracting B's values from A's will give the kick translation for the rotation one way; and subtracting A's values from B's will give the kick translation for rotating back the other way.
 
There is another complexity to TTC's implementation: the derived translations are relative to a different datum. So far on this page, kick translations have been defined relative to "basic rotation", but TTC uses what [[User:Nightmareci|Nightmareci]] has named "true rotation". "True rotation" is still a mathematical pure rotation with no translation involved; however, the rotation center ''always'' coincides with the center of one of the four constituent minos. (Recall that the apparent rotation center of the ''I'' and ''O'' tetrominoes in basic rotation coincided with the intersection of gridlines). This means that for "true rotation", the rotation center for the O piece is not at the geometric center, so the piece will have a "wobble" when rotated. The first kick translation has to be used to correct for this wobble.
 
 
{| border="1" cellspacing="0"
|+ '''J, L, S, T, Z Tetromino Offset Data'''
|- align = center
! width="45"|
! bgcolor="#80A3F8" width="60"|Offset 1
! bgcolor="#80A3F8" width="60"|Offset 2
! bgcolor="#80A3F8" width="60"|Offset 3
! bgcolor="#80A3F8" width="60"|Offset 4
! bgcolor="#80A3F8" width="60"|Offset 5
|-align = center
! bgcolor="#80A3F8"| 0
| <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt>
|-align = center
! bgcolor="#80A3F8"| R
| <tt>( 0, 0)</tt> || <tt>(+1, 0)</tt> || <tt>(+1,-1)</tt> || <tt>( 0,+2)</tt> || <tt>(+1,+2)</tt>
|-align = center
! bgcolor="#80A3F8"| 2
| <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0,  0)</tt> || <tt>( 0, 0)</tt>
|-align = center
! bgcolor="#80A3F8"| L
| <tt>( 0, 0)</tt> || <tt>(-1, 0)</tt> || <tt>(-1,-1)</tt> || <tt>( 0,+2)</tt> || <tt>(-1,+2)</tt>
|}
 
 
{| border="1" cellspacing="0"
|+ '''I Tetromino Offset Data'''
|- align = center
! width="45"|
! bgcolor="#80A3F8" width="60"|Offset 1
! bgcolor="#80A3F8" width="60"|Offset 2
! bgcolor="#80A3F8" width="60"|Offset 3
! bgcolor="#80A3F8" width="60"|Offset 4
! bgcolor="#80A3F8" width="60"|Offset 5
|-align = center
! bgcolor="#80A3F8"| 0
| <tt>( 0, 0)</tt> || <tt>(-1, 0)</tt> || <tt>(+2, 0)</tt> || <tt>(-1, 0)</tt> || <tt>(+2, 0)</tt>
|-align = center
! bgcolor="#80A3F8"| R
| <tt>(-1, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0, 0)</tt> || <tt>( 0,+1)</tt> || <tt>( 0,-2)</tt>
|-align = center
! bgcolor="#80A3F8"| 2
| <tt>(-1,+1)</tt> || <tt>(+1,+1)</tt> || <tt>(-2,+1)</tt> || <tt>(+1, 0)</tt> || <tt>(-2, 0)</tt>
|-align = center
! bgcolor="#80A3F8"| L
| <tt>( 0,+1)</tt> || <tt>( 0,+1)</tt> || <tt>( 0,+1)</tt> || <tt>( 0,-1)</tt> || <tt>( 0,+2)</tt>
|}
 
 
{| border="1" cellspacing="0"
|+ '''O Tetromino Offset Data'''
|- align = center
! width="45"|
! bgcolor="#80A3F8" width="60"|Offset 1
! bgcolor="#80A3F8" width="60"|Offset 2
! bgcolor="#80A3F8" width="60"|Offset 3
! bgcolor="#80A3F8" width="60"|Offset 4
! bgcolor="#80A3F8" width="60"|Offset 5
|-align = center
! bgcolor="#80A3F8"| 0
| <tt>( 0, 0)</tt> || rowspan="4" colspan="4" align=center| No further offset data required
|-align = center
! bgcolor="#80A3F8"| R
| <tt>( 0,-1)</tt>
|-align = center
! bgcolor="#80A3F8"| 2
| <tt>(-1,-1)</tt>
|-align = center
! bgcolor="#80A3F8"| L
| <tt>(-1, 0)</tt>
|}
 
 
'''An example of deriving kick translations from the offsets:'''
 
The offsets for ''J'', rotation state 0 are: <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(&nbsp;0,&nbsp;0)</tt>.<br>
The offsets for ''J'', rotation state R are: <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(+1,&nbsp;0)</tt>, <tt>(+1,-1)</tt>, <tt>(&nbsp;0,+2)</tt>, <tt>(+1,+2)</tt>.<br>
 
<tt>( 0, 0)</tt> - <tt>( 0, 0)</tt> = <tt>( 0, 0)</tt>,<br>
<tt>( 0, 0)</tt> - <tt>(+1, 0)</tt> = <tt>(-1, 0)</tt>,<br>
<tt>( 0, 0)</tt> - <tt>(+1,-1)</tt> = <tt>(-1,+1)</tt>,<br>
<tt>( 0, 0)</tt> - <tt>( 0,+2)</tt> = <tt>( 0,-2)</tt>,<br>
<tt>( 0, 0)</tt> - <tt>(+1,+2)</tt> = <tt>(-1,-2)</tt>.
 
Therefore, the kick translations for the ''J'' rotation 0->R, relative to "true rotation" (which is conveniently the same as "basic rotation" for the ''J'' tetromino), are: <tt>(&nbsp;0,&nbsp;0)</tt>, <tt>(-1,&nbsp;0)</tt>, <tt>(-1,+1)</tt>, <tt>(&nbsp;0,-2)</tt>, <tt>(-1,-2)</tt>.
 
==External links==
*[http://web.archive.org/web/20071015224359/www.the-shell.net/img/srs_study.html Jagorochi's analysis] of SRS wall kicks (web archive)
 
 
[[Category:Rotation systems]]

Latest revision as of 11:08, 17 October 2020

The Super Rotation System, or SRS is the current Tetris Guideline standard for how tetrominoes rotate and what wall kicks they may perform. SRS traces its roots back to 1991 when BPS introduced third and fourth rotation states for the S, Z, and I tetrominoes in the game Tetris 2 + Bombliss. Two years later, in the game Tetris Battle Gaiden, BPS altered the spawn orientation of the T, L, and J tetrominoes so that they spawned flat-side first. It was not until the 2001 game, Tetris Worlds, that the wall kick system was introduced, and SRS took its final form. Henk Rogers, in his effort to unify all new Tetris games into the Tetris Guideline, required Arika to include a form of SRS in their 2005 game, Tetris The Grand Master 3 Terror-Instinct, where it is called "World" rule, in reference to Tetris Worlds.

Spawn Orientation and Location

The 4 rotation states of all 7 tetrominoes. Starting with the spawn state on the left, the 4 rotation states resulting from successive clockwise rotations are shown in order. The circles merely help to illustrate rotation centers and do not appear in-game.

The spawn orientations are included in the diagram on the right.

  • All tetrominoes spawn horizontally.
  • The I and O tetrominoes spawn centrally, and the other, 3-cell wide tetrominoes spawn rounded to the left.
  • The J, L and T spawn flat-side first, while I, S and Z spawn in their upper horizontal orientation.
  • In Tetris Worlds, the tetrominoes spawn in rows 22 and 23 (or just row 22 in the case of the "I" tetromino), however, in later games the tetrominoes spawn 1 row lower. Some games spawn the tetrominoes another row lower (in rows 20 and 21), such as Tetris Effect.

Basic Rotation

The basic rotation states are shown in the diagram on the right. Some points to note:

  • When unobstructed, the tetrominoes all appear to rotate purely about a single point. These apparent rotation centers are shown as circles in the diagram.
  • It is a pure rotation in a mathematical sense, as opposed to the combination of rotation and translation found in other systems such as Sega Rotation and Atari Rotation.
  • As a direct consequence, the J, L, S, T and Z tetrominoes have 1 of their 4 states (the spawn state) in a "floating" position where they are not in contact with the bottom of their bounding box.
  • This allows the bounding box to descend below the surface of the stack (or the floor of the playing field) making it impossible for the tetrominoes to be rotated without the aid of floor kicks.
  • The S, Z and I tetrominoes have two horizontally oriented states and two vertically oriented states. It can be argued that having two vertical states leads to faster finesse.
  • For the I and O tetrominoes, the apparent rotation center is at the intersection of gridlines, whereas for the J, L, S, T and Z tetrominoes, the rotation center coincides with the center of one of the four constituent minos.

Wall Kicks

When the player attempts to rotate a tetromino, but the position it would normally occupy after basic rotation is obstructed, (either by the wall or floor of the playfield, or by the stack), the game will attempt to "kick" the tetromino into an alternative position nearby. Some points to note:

  • When a rotation is attempted, 5 positions are sequentially tested (inclusive of basic rotation); if none are available, the rotation fails completely.
  • Which positions are tested is determined by the initial rotation state, and the desired final rotation state. Because it is possible to rotate both clockwise and counter-clockwise, for each of the 4 initial states there are 2 final states. Therefore there are a total of 8 possible rotations for each tetromino and 8 sets of wall kick data need to be described.
  • The positions are commonly described as a sequence of ( x, y) kick values representing translations relative to basic rotation; a convention of positive x rightwards, positive y upwards is used, e.g. (-1,+2) would indicate a kick of 1 cell left and 2 cells up.
  • The J, L, S, T and Z tetrominoes all share the same kick values, the I tetromino has its own set of kick values, and the O tetromino does not kick.
  • Several different conventions are commonly used for the naming of the rotation states. On this page, the following convention will be used:
    • 0 = spawn state
    • R = state resulting from a clockwise rotation ("right") from spawn
    • L = state resulting from a counter-clockwise ("left") rotation from spawn
    • 2 = state resulting from 2 successive rotations in either direction from spawn.


J, L, S, T, Z Tetromino Wall Kick Data
Test 1 Test 2 Test 3 Test 4 Test 5
0->R ( 0, 0) (-1, 0) (-1,+1) ( 0,-2) (-1,-2)
R->0 ( 0, 0) (+1, 0) (+1,-1) ( 0,+2) (+1,+2)
R->2 ( 0, 0) (+1, 0) (+1,-1) ( 0,+2) (+1,+2)
2->R ( 0, 0) (-1, 0) (-1,+1) ( 0,-2) (-1,-2)
2->L ( 0, 0) (+1, 0) (+1,+1) ( 0,-2) (+1,-2)
L->2 ( 0, 0) (-1, 0) (-1,-1) ( 0,+2) (-1,+2)
L->0 ( 0, 0) (-1, 0) (-1,-1) ( 0,+2) (-1,+2)
0->L ( 0, 0) (+1, 0) (+1,+1) ( 0,-2) (+1,-2)


I Tetromino Wall Kick Data
Test 1 Test 2 Test 3 Test 4 Test 5
0->R ( 0, 0) (-2, 0) (+1, 0) (-2,-1) (+1,+2)
R->0 ( 0, 0) (+2, 0) (-1, 0) (+2,+1) (-1,-2)
R->2 ( 0, 0) (-1, 0) (+2, 0) (-1,+2) (+2,-1)
2->R ( 0, 0) (+1, 0) (-2, 0) (+1,-2) (-2,+1)
2->L ( 0, 0) (+2, 0) (-1, 0) (+2,+1) (-1,-2)
L->2 ( 0, 0) (-2, 0) (+1, 0) (-2,-1) (+1,+2)
L->0 ( 0, 0) (+1, 0) (-2, 0) (+1,-2) (-2,+1)
0->L ( 0, 0) (-1, 0) (+2, 0) (-1,+2) (+2,-1)


A wall kick example:
The desired rotation is 0->L, and from the table above, the wall kick test order is ( 0, 0), (+1, 0), (+1,+1), ( 0,-2), (+1,-2).

..........
....GG....
...J.GGG..
...JJJGGGG
.GGG...GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG

1. Initial position.
Attempt to rotate 0->L.

..........
....GG....
....JGGG..
....J.GGGG
.GGXJ..GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG

2. Test 1, ( 0, 0) fails.
(Basic rotation fails.)

..........
....GG....
.....XGG..
.....JGGGG
.GGGJJ.GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG

3. Test 2, (+1, 0) fails.

..........
....GX....
.....XGG..
....JJGGGG
.GGG...GGG
GG....GGGG
GGGG..GGGG
GGGGG.GGGG

4. Test 3, (+1,+1) fails.

..........
....GG....
.....GGG..
......GGGG
.GGGJ..GGG
GG..J.GGGG
GGGXJ.GGGG
GGGGG.GGGG

5. Test 4, ( 0,-2) fails.

..........
....GG....
.....GGG..
......GGGG
.GGG.J.GGG
GG...JGGGG
GGGGJJGGGG
GGGGG.GGGG

6. Final position.
Test 5, (+1,-2) succeeds.

Arika SRS

In their games Tetris The Grand Master 3 Terror-Instinct and Tetris The Grand Master Ace, Arika were required to include a form of SRS as the default rotation system, in order to conform more closely to The Tetris Company's Tetris Guideline. Arika's implementation of SRS uses the exact same wall kick data for the J, L, S, T and Z tetrominoes as the Guideline's standard; however, the I tetromino uses the wall kick data shown below, with differences highlighted:

Arika I Tetromino Wall Kick Data
Test 1 Test 2 Test 3 Test 4 Test 5
0->R ( 0, 0) (-2, 0) (+1, 0) (+1,+2) (-2,-1)
R->0 ( 0, 0) (+2, 0) (-1, 0) (+2,+1) (-1,-2)
R->2 ( 0, 0) (-1, 0) (+2, 0) (-1,+2) (+2,-1)
2->R ( 0, 0) (-2, 0) (+1, 0) (-2,+1) (+1,-1)
2->L ( 0, 0) (+2, 0) (-1, 0) (+2,+1) (-1,-1)
L->2 ( 0, 0) (+1, 0) (-2, 0) (+1,+2) (-2,-1)
L->0 ( 0, 0) (-2, 0) (+1, 0) (-2,+1) (+1,-2)
0->L ( 0, 0) (+2, 0) (-1, 0) (-1,+2) (+2,-1)

The logic behind Arika's modifications is that the I wall kicks are now symmetric about the y-axis when rotating from or to a horizontal orientation. One noticeable consequence of this is illustrated in the following example:

..........
----......
.GG.GGGGGG
.GG.GGGGGG
IGGGGGGGGG
IGGGGGGGGG
IGGGGGGGGG
IGGGGGGGGG
From the dotted position, it is possible to clear 4 lines with both Guideline and Arika SRS by rotating clockwise.
..........
......----
GGGGGG.GG.
GGGGGG.GG.
GGGGGGGGGI
GGGGGGGGGI
GGGGGGGGGI
GGGGGGGGGI
In the symmetric position, only Arika SRS allows the clearing of 4 lines by rotating counter-clockwise.
......I...
......I---
GGGGGGIGG.
GGGGGGIGG.
GGGGGGGGG.
GGGGGGGGG.
GGGGGGGGG.
GGGGGGGGG.
Arika SRS also allows for this position to be achieved by rotating clockwise. However, with Guideline SRS, this is the only position achievable, regardless of which direction the player rotates.

How Guideline SRS Really Works

The internal true rotations used in Guideline SRS; offsets are applied to these.

Instead of directly assigning a set of ( x, y) kick translations to each of the 8 possible rotations, TTC actually employed a different approach, and instead assigned a set of ( x, y) "offset" values to the 4 rotation states. The kick translations are then derived by taking the difference between pairs of offset data. When rotating from A to B, subtracting B's values from A's will give the kick translation for the rotation one way; and subtracting A's values from B's will give the kick translation for rotating back the other way.

There is another complexity to TTC's implementation: the derived translations are relative to a different datum. So far on this page, kick translations have been defined relative to "basic rotation", but TTC uses what Nightmareci has named "true rotation". "True rotation" is still a mathematical pure rotation with no translation involved; however, the rotation center always coincides with the center of one of the four constituent minos. (Recall that the apparent rotation center of the I and O tetrominoes in basic rotation coincided with the intersection of gridlines). This means that for "true rotation", the rotation center for the O piece is not at the geometric center, so the piece will have a "wobble" when rotated. The first kick translation has to be used to correct for this wobble.


J, L, S, T, Z Tetromino Offset Data
Offset 1 Offset 2 Offset 3 Offset 4 Offset 5
0 ( 0, 0) ( 0, 0) ( 0, 0) ( 0, 0) ( 0, 0)
R ( 0, 0) (+1, 0) (+1,-1) ( 0,+2) (+1,+2)
2 ( 0, 0) ( 0, 0) ( 0, 0) ( 0, 0) ( 0, 0)
L ( 0, 0) (-1, 0) (-1,-1) ( 0,+2) (-1,+2)


I Tetromino Offset Data
Offset 1 Offset 2 Offset 3 Offset 4 Offset 5
0 ( 0, 0) (-1, 0) (+2, 0) (-1, 0) (+2, 0)
R (-1, 0) ( 0, 0) ( 0, 0) ( 0,+1) ( 0,-2)
2 (-1,+1) (+1,+1) (-2,+1) (+1, 0) (-2, 0)
L ( 0,+1) ( 0,+1) ( 0,+1) ( 0,-1) ( 0,+2)


O Tetromino Offset Data
Offset 1 Offset 2 Offset 3 Offset 4 Offset 5
0 ( 0, 0) No further offset data required
R ( 0,-1)
2 (-1,-1)
L (-1, 0)


An example of deriving kick translations from the offsets:

The offsets for J, rotation state 0 are: ( 0, 0), ( 0, 0), ( 0, 0), ( 0, 0), ( 0, 0).
The offsets for J, rotation state R are: ( 0, 0), (+1, 0), (+1,-1), ( 0,+2), (+1,+2).

( 0, 0) - ( 0, 0) = ( 0, 0),
( 0, 0) - (+1, 0) = (-1, 0),
( 0, 0) - (+1,-1) = (-1,+1),
( 0, 0) - ( 0,+2) = ( 0,-2),
( 0, 0) - (+1,+2) = (-1,-2).

Therefore, the kick translations for the J rotation 0->R, relative to "true rotation" (which is conveniently the same as "basic rotation" for the J tetromino), are: ( 0, 0), (-1, 0), (-1,+1), ( 0,-2), (-1,-2).

External links