Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

zesterer/the-bitwise-challenge

Folders and files

NameName
Last commit message
Last commit date

Latest commit

History

11 Commits

Repository files navigation

The Bitwise Gamedev Challenge

The Concept

There is one rule: the core game logic is allowed to persist no more than 64 bits (8 bytes) of data between frames/ticks.

Additional Details

In effect, your game should be a pure function with the following inputs:

  • the 64 bit integer emitted by the last frame (you may provide a default value for the first frame)

  • player inputs (keyboard/mouse/controller/etc.) & other environmental information (time delta since the last frame, etc.)

  • Random number generation, provided the state of the RNG is not relied upon for gameplay (i.e: it should be possible to reseed the RNG from true random sources every frame without changing the nature of the gameplay)

and the following outputs:

  • a 64-bit integer that will be persisted to the next frame

  • UI/graphics/other outputs in some stateless form, such as a framebuffer or sound waveforms

No statics, global values, IO (beyond that which falls within the aforementioned categories), side-channel state (such as inducing lag to use the frame time delta as extra state), or other unprincipled 'tricks' are permitted: it should be possible to recreate the entire state of the game at any given frame given only the 64-bit integer and the code that composes the game logic.

Why 64 bits?

Based on personal experimentation, I've found 64 bits to be the perfect middle-ground that keeps the challenge engaging and forces creativity, while also not forbidding a lot of different potential game genres.

Ambiguities

Some games do not have a strict definition of 'frames' or 'ticks'.

For example, a text adventure game might accept many characters of input, but only act on them once the 'return' key is pressed. Does this mean that the game has to store the partially-complete string within its 64-bit state? There is no right answer.

My suggestion would be to decide beforehand where your dividing line is between the 'input system' and the 'core game', and then respect the rules of the challenge within that core. For example, you might decide that an entire command to the text adventure game counts as a single atomic input, and hence need not count toward the stored state of the game.

Suggested Formats

The Bitwise Challenge can be taken both as an individual endeavour, or as a group activity/competition such as a game jam or hackathon.

Pure caches

An exception is made for memoization caches, provided the result of using the cache is indistinguishable from recomputing the cached function on the input every time (you can't, for example, rely on whether a value was present in the cache for some behaviour of the game logic).

You may use such caches for the sake of performance. For example, procedurally generating a game world from a seed on every frame would, understandably, be prohibitely expensive.

An example of such a memoization cache is the cached Rust crate.

Variations

  • Increasing or decreasing the number of bits for varying difficulty

Showcases

If you want your entry added to the list, open an issue!

Inspiration

The idea was partially inspired by this blog post by @nomemory.

About

Can you build a game in just 8 bytes?

Topics

Resources

Stars

Watchers

Forks

AltStyle によって変換されたページ (->オリジナル) /