Seed (level generation)

Minecraft seeds are values made up of character(s) (including negative or positive integers) that are used as the basis for generating every Minecraft world.

Compatibility
Seeds are not compatible across editions, but are sometimes compatible with the older and newer versions. However, after Village & Pillage, the villages and other generated structures changed.

seeds between Alpha 1.2.0 and Beta 1.7.3 are mostly the same. Beta 1.8 changed world generation completely and Release 1.2 changed locations of land biomes with the addition of jungles. Release 1.7.2 rewrote the world generation entirely, making seeds from 1.2 through 1.6.4 outdated. 1.13 featured changes to cave generation, new aquatic biomes, and adjustment to mutated biome and structure locations. 1.14 included the new bamboo jungle biome and updated locations of villages out pillager outposts. Not mentioned are structure additions in several updates throughout, but the addition of a generated structure usually does not require a complete change of biome generation.

$$, the Alpha 0.9.0 update was the only update to overhaul world generation. Oceans were changed in the Update Aquatic, and villages & other structures were changed in Village & Pillage.

Legacy Console Edition seeds were updated in a similar schedule to Java Edition equivalents.

World generation
Whenever the game has to generate a new world, it calls upon an algorithm. This algorithm outputs a pseudo-random value that is then used to determine the characteristics and features of the world. However, the algorithm always outputs the same value each time for a constant starting point (seed). This is why seeds exist — to generate entirely different worlds, consistently each time, from single values.

A world's seed is set when that world is created. By default, it is decided automatically, but it can also be set manually. Set and reuse a seed to replay that world, or use a known seed to play the same world as another player. Either a number or a word/phrase can be used, including negatives. If a word/phrase is used, it is converted into a 32-bit integer.

Whenever the world generation algorithm is updated (usually by adding new biomes to the game), the same seed no longer generates the same terrain. This is why in some different versions of the game, the same seed does not produce the same world. If the seed or generator changes in a saved world, new chunks are based on the new seed and no longer match those from the old seed. $$, major (terrain-breaking) changes were observed with Alpha v1.2.0, Beta 1.8, and 1.7.2. Deleted chunks can regenerate if the seed and generator remain the same, but changes if either the seed or generator changes. In fact, deleting chunks is sometimes done to let newly-introduced features appear in an old world; see Tutorials/Updating old oceans in 1.13 using MCEdit.

Because seeds are simply random values read into an algorithm and not actually names of different worlds, using a certain seed does not result in a world with any relevance to the value of that seed. For instance, using a biome name as the seed does not necessarily result in the creation of a world with primarily that biome, nor does it spawn the player within the said biome.

Broken world generation


Broken world generation is when chunks do not load properly and cause certain blocks to not render. Certain seeds can cause the world generation to duplicate chunks in the x or z axis due to Java's Math.random function returning 0. Chunks are invisible (see )

Determining the seed
$$, the player can enter the command to view the world's seed.

$$, the seed can be found on the world options screen. There is also a seed picker that offers the player several pre-set seeds to generate worlds with specific features near the spawn point. Additionally, the beta version has a visible seed on the top of the screen.

Java Edition
If the seed contains characters other than numbers or is longer than 20 characters, the Java  function is used to generate a number seed. This restricts Minecraft to a subset of the possible worlds to 232 (or 4,294,967,296), due to the datatype used. Number seeds or a default world seed must be used to access the full set of possible worlds (264, or 18,446,744,073,709,551,616). There are still only 248 meaningful seeds since Java's  only uses 48 bits of the seed; seeds are equivalent to one another modulo 248.

Bedrock Edition
has a total of 232 (or 4,294,967,296) possible worlds no matter whether strings or numbers are used as the seed. This is because Bedrock Edition uses a 32-bit variant of the Mersenne Twister PRNG, which accepts only 32-bit seeds. The hashing algorithm is identical to : a hash h starts with 0, and for each character c, the value of h is changed to h * 31 + c, within the boundary of a 32-bit integer.

Seed 0
The numeric entry for Minecraft seeds does not allow the number "0" (zero), as the game interprets "0" as a character, hashing it to its ASCII value of. However, by using a text seed for which the Java  function returns a zero value, the "zero seed" can still be used. Word strings that produce a zero seed include. However, any text that hashes to 0 works, such as. Numeric seeds that are congruent to 0 modulo 248 (such as ) will also generate the same terrain as seed 0, but will not display as 0 using.

$$, the game rejects all numbers from -9 to +9. However, changing the last character of the seed by one also changes the output hash code by one, so to arrive to a value of +2 from, the last letter is advanced two positions to become. The shortest version is still ddnqavb, followed by any other letter from a through s.

Trivia

 * Certain seeds return 0 in the internal code, causing infinite arrays of caves and other structures to generate.
 * The seed 107038380838084 returns 0 on the first call and 164311266871034 returns 0 on the second call, causing structures to loop on the X and Z axes respectively.
 * This quirk is exclusive to Java, as Bedrock Edition does not possess seeds that return 0 on the first or second call (however, 257678572 returns 0 on the 6th call).
 * This quirk can also be seen in the Legacy Console Editions, as the worldgen is very similar.
 * If a user modifies the Java Edition source code for any version between 1.7.2 and 1.12.2, and change a value from 2 to 0 for the 6th genlayer, a user can replicate biome generation from Legacy Console Edition on Java edition with the exception of mushroom biomes.
 * Only certain sections of the seed are used to generate specific features within the world. It is possible to generate multiple worlds with identical cave systems and other arrangements of generated structures simply by converting the seed into binary and tweaking the desired bits.
 * An example is the seed generator using only the first 48bits to generate cave systems and badlands clay banding layers.
 * Other features can also be broken, such as decorations.
 * $$, the demo world seed can be played in the full version by entering North Carolina in the seed input.