Super Rotation System: Difference between revisions

From TetrisWiki
Jump to navigation Jump to search
*>Tepples
(→‎20g: I just tried your revised example in TDS, and it seems more like a DAS issue.)
 
(68 intermediate revisions by 32 users not shown)
Line 1: Line 1:
[[Image:SRS-pieces.png|thumb|All rotation states of all seven tetrominoes. From top to bottom: I, J, L, O, S, T, Z. The circle doesn't appear in the game; it helps to illustrate the axis on which each tetromino rotates.]]
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''.  
'''''Super Rotation System''''', or '''''SRS''''' is the current [[Tetris Guideline]] standard for how [[tetromino|tetrominoes]] behave, in a broad sense. SRS represents where and how tetrominoes spawn, how they [[rotate]], and what [[wall kick|wall kicks]] they may perform. 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 [[Tetris The Grand Master|TGM]] and [[Tetris The Absolute The Grand Master 2|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.


==Description==
==Spawn Orientation and Location==
All tetrominoes exist inside a bounding square and rotate about the center of this square unless obstructed. Tetrominoes of width 3 (J, L, S, T, Z) are placed in the top two rows of the bounding square and (for J, L, and T) with the flat side down. I is placed in the top middle row.
[[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]]''.


All tetrominoes spawn in 2 usually hidden rows at the top of the playfield. They are placed in the center of these rows, rounding to the left.
==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.


Once a tetromino lands, it does not lock until the lock delay expires. The lock delay is reset whenever the tetromino is moved or rotated (even O, which ordinarily does not rotate). This controversial feature allows a single tetromino to be easily kept "alive" forever. To reduce the negative effects of this, newer Tetris games tend to have modes that reward play speed, such as points per minute or garbage per minute. These modes encourage use of the hard drop (generally mapped to Up), which has no lock delay.
==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.


Wall kicks in SRS are extremely flexible compared to those of earlier games. Some rotations result in new positions that do not overlap the former position at all, allowing for highly controversial T-spin triples (see [[Twists]]).


==20g==
{| border="1" cellspacing="0"
Since Henk Rogers has never been directly involved with a game boasting 20g, certain behaviors are likely undefined in the Tetris Guidelines. TGM3 is the first game to support 20g and SRS, and TDS is the second. Though the rotations are identical, these games have different mobility restrictions due to their different order of processing events in between frames.
|+'''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.
|}


In this example, Left is being held and then a counter clockwise rotation is initiated.
{| cellpadding="2" style="border:1px solid darkgray;"
{|
|- valign=top
|{{pfstart}}
|width="200pt"|<playfield>
{{pfrow| | | | | | | | | | |}}
..........
{{pfrow|G|G|L|L|L| | | | | |}}
....GX....
{{pfrow|G|G|L| | | | | | | |}}
.....XGG..
{{pfrow|G|G|G| | | | | | | |}}
....JJGGGG
{{pfend}}
.GGG...GGG
|{{pfstart}}
GG....GGGG
{{pfrow| | |L|L| | | | | | |}}
GGGG..GGGG
{{pfrow|G|G| |L| | | | | | |}}
GGGGG.GGGG
{{pfrow|G|G| |L| | | | | | |}}
</playfield>
{{pfrow|G|G|G| | | | | | | |}}
'''4.''' Test 3, <tt>(+1,+1)</tt> fails.
{{pfend}}
|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.
|}
|}


The above example ends mid-frame... So the figure on the right is never actually rendered. It simply represents the internal game status after rotation has been processed.
==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:


Now, if the game processes movement followed by gravity, the following scenario will happen (as found in TGM3).
{| border="1" cellspacing="0"
{|
|+'''Arika I Tetromino Wall Kick Data'''
|{{pfstart}}
|- align = center
{{pfrow| | |L|L| | | | | | |}}
! width="45"|
{{pfrow|G|G| |L| | | | | | |}}
! bgcolor="#80A3F8" width="60"|Test 1
{{pfrow|G|G| |L| | | | | | |}}
! bgcolor="#80A3F8" width="60"|Test 2
{{pfrow|G|G|G| | | | | | | |}}
! bgcolor="#80A3F8" width="60"|Test 3
{{pfend}}
! bgcolor="#80A3F8" width="60"|Test 4
|{{pfstart}}
! bgcolor="#80A3F8" width="60"|Test 5
{{pfrow| |L|L| | | | | | | |}}
|- align = center
{{pfrow|G|G|L| | | | | | | |}}
| 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>
{{pfrow|G|G|L| | | | | | | |}}
|- align = center
{{pfrow|G|G|G| | | | | | | |}}
| bgcolor="#80A3F8"|R->0||<tt>( 0, 0)</tt>||<tt>(+2, 0)</tt>||<tt>(-1, 0)</tt>||<tt>(+2,+1)</tt>||<tt>(-1,-2)</tt>
{{pfend}}
|- 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>
|}
|}


On the other hand, if gravity is processed next, the following scenario will happen (as found in TDS). This could be the result of either movement processed after gravity, movement processed before rotation, or (most likely in the case of TDS) movement occurring one or more frames after both rotation and gravity due to slow [[DAS]].
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:
{|
 
|{{pfstart}}
{| cellpadding="2" style="border:1px solid darkgray;"
{{pfrow| | |L|L| | | | | | |}}
|- valign=top
{{pfrow|G|G| |L| | | | | | |}}
|width="150pt"|<playfield>
{{pfrow|G|G| |L| | | | | | |}}
..........
{{pfrow|G|G|G| | | | | | | |}}
----......
{{pfend}}
.GG.GGGGGG
|{{pfstart}}
.GG.GGGGGG
{{pfrow| | | | | | | | | | |}}
IGGGGGGGGG
{{pfrow|G|G|L|L| | | | | | |}}
IGGGGGGGGG
{{pfrow|G|G| |L| | | | | | |}}
IGGGGGGGGG
{{pfrow|G|G|G|L| | | | | | |}}
IGGGGGGGGG
{{pfend}}
</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==
==External links==
*[http://www.tetrisconcept.com/tdsg.txt Tetris DS Systems Guide]
*[http://web.archive.org/web/20071015224359/www.the-shell.net/img/srs_study.html Jagorochi's analysis] of SRS wall kicks (web archive)
*[http://infinitespin.ytmnd.com/ Tetris is ridin' spinnaz]
 
 
[[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