Super Rotation System: Difference between revisions
*>Nicholas No edit summary |
→How Guideline SRS Really Works: Spacing |
||
(59 intermediate revisions by 30 users not shown) | |||
Line 1: | Line 1: | ||
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''. | |||
== | ==Spawn Orientation and Location== | ||
All tetrominoes | [[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>( x, 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>( 0, 0)</tt>, <tt>(+1, 0)</tt>, <tt>(+1,+1)</tt>, <tt>( 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. | |||
|} | |} | ||
The | ==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>( x, y)</tt> kick translations to each of the 8 possible ''rotations'', [[TTC]] actually employed a different approach, and instead assigned a set of <tt>( x, 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>( 0, 0)</tt>, <tt>( 0, 0)</tt>, <tt>( 0, 0)</tt>, <tt>( 0, 0)</tt>, <tt>( 0, 0)</tt>.<br> | |||
The offsets for ''J'', rotation state R are: <tt>( 0, 0)</tt>, <tt>(+1, 0)</tt>, <tt>(+1,-1)</tt>, <tt>( 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>( 0, 0)</tt>, <tt>(-1, 0)</tt>, <tt>(-1,+1)</tt>, <tt>( 0,-2)</tt>, <tt>(-1,-2)</tt>. | |||
==External links== | ==External links== | ||
*[http:// | *[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 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.
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) |
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).
1. Initial position. |
2. Test 1, ( 0, 0) fails. |
3. Test 2, (+1, 0) fails. |
4. Test 3, (+1,+1) fails. |
5. Test 4, ( 0,-2) fails. |
6. Final position. |
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:
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:
From the dotted position, it is possible to clear 4 lines with both Guideline and Arika SRS by rotating clockwise. |
In the symmetric position, only Arika SRS allows the clearing of 4 lines by rotating counter-clockwise. |
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
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.
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) |
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) |
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
- Jagorochi's analysis of SRS wall kicks (web archive)