Life simulation of evolving unicellular organisms in a stochastic artificial chemistry.
Microcosm models matter as a discrete artificial chemistry built from six fundamental elements (A, B, C, D, E, and F). Each element carries intrinsic polarity and intrinsic elemental energy; masses are also defined as metadata, but the active dynamics in the current simulation are driven by composition, bond state, polarity, and enval coupling rather than by explicit mechanics.
Larger molecules therefore move more slowly, while smaller and more polar molecules hop more readily through the lattice.
Life is defined by the possession of a genome encoding functional proteins called enzymes together with a scalar environmental optimum called optimal enval. Each enzyme stores a class, a specificity mask over the six elements, an enval response width \(\sigma\), an enval throughput \(\tau\), and a secretion probability.
Thus synthetic and degradative enzymes are exclusive over their allowed alphabet, whereas transmutases only require access to at least one allowed source element.
Anabolase enzymes perform anabolism by sampling accepted substrates from the extracellular and intracellular pools and polymerizing them into a single higher-bond product. The product composition is simply the summed elemental composition of the substrates, but its bond multiplier is elevated above unity. The energetic cost is the increase in bond storage, scaled by a bond-cost fraction \(\lambda\), together with a fixed catalytic cost \(E_{\mathrm{act}}\):
This makes anabolism endergonic unless it is subsidized by previously stored energy or by aligned enval harvesting.
Catabolase enzymes perform catabolism by selecting one accepted substrate of size at least two and fragmenting it into two lower-bond products. The current implementation does not perform the old catabolic isotope-transmutation step; catabolase now extracts only released bond energy, scaled by a harvest fraction \(h_b\) (currently defaulted to 1.0), minus catalytic cost:
If the net usable gain is non-positive, the reaction is discarded.
Transmutase performs transmutation by acting on one accepted molecule and changing exactly one atom at a time along a directed artificial transmutation ladder.
If the raw elemental change is \(\Delta E_{\mathrm{raw}}\), then downhill transmutation only harvests a fraction \(h_d\) of that release, while uphill transmutation pays the full energetic penalty:
The full cellular effect is then:
When both directions are available, transmutase biases more strongly toward uphill moves when aligned enval is abundant and the cell already has substantial energy reserves.
All enzyme classes may couple metabolism to the signed environmental scalar enval. Let \(s\) denote the cell polarity induced by genomic optimal enval (\(s = +1\) for positive-adapted cells, \(s = -1\) for negative-adapted cells, and random sign if the optimum is exactly zero). If the local field is aligned with that polarity, the harvested input magnitude is:
By default the harvested energy term is:
The reaction simultaneously pumps opposite-sign enval back into the environment. With baseline pump magnitude \(P\) and recycle fraction \(f_r\) (default \(P = 0.3\), \(f_r = 1/3\)), the emitted field term is:
Operationally, aligned enval is removed from the local tile while opposite-sign enval is deposited into one randomly sampled site in the local Moore neighborhood (including the source tile). Successful metabolism therefore does not merely consume a pre-existing field; it actively reshapes that field.
The primary environmental variable is a single unbounded signed scalar called enval. At initialization the world begins with a random base enval sampled from the interval \([-1, +1]\), after which diffusion and metabolism are free to push the field to any real value. Enzymatic efficiency \(\phi\) is governed by a Gaussian dependence on local enval mismatch:
The reaction attempt probability is scaled by this efficiency term:
Current base rates are 0.85 for anabolase, 0.98 for catabolase, and 0.30 for transmutase. Strong mismatch therefore suppresses metabolism primarily by preventing reactions from firing at all; enval harvesting falls indirectly because fewer reactions occur.
The enval field itself diffuses across the toroidal lattice by discrete local averaging:
Because reactions continuously remove aligned enval and emit opposite-sign enval, the field is both smoothed by diffusion and destabilized by metabolic feedback.
A cell is a stationary metabolic agent that occupies a tile, stores free energy, stores an internal molecular inventory, and executes its genome each tick.
where \(k\) is the genome-level stress factor and \(n_{\mathrm{enz}}\) is enzyme count. If the accumulated timer exceeds the decay threshold, the cell dies.
Cells may now carry two non-metabolic combat enzymes: defensase and attackase. Founders always begin with one defensase, while attackase is absent from founder genomes and must appear later by mutation during reproduction. Each combat enzyme carries an integer level rather than an element-specificity mask. Founder defensase levels are drawn from a rounded Gaussian distribution centered on 100 (current implementation: \(\sigma = 10\), clamped to at least 1). During reproduction, inherited combat enzymes keep their current level with 50% probability, step downward by a small integer with 25% probability, or step upward by a small integer with 25% probability; combat enzymes can also still be gained, lost, or class-switched by the broader genome-mutation machinery.
Predation is evaluated between edge-adjacent cells of different lineages after the ordinary metabolic step. Let \(A_{\mathrm{atk}}\) and \(A_{\mathrm{def}}\) denote the summed attackase and defensase levels of cell \(A\), and similarly for cell \(B\).
Successful predation performs a phagocytosis-like assimilation event: the loser is removed from the world, while the winner absorbs the loser's stored free energy, internal molecules, and enzyme inventory. Because absorbed enzymes are appended to the predator genome, combat and metabolic repertoires can both expand through ecological interactions rather than by descent alone.
Founders are seeded with an optimal enval drawn from a narrow band around the current world-average enval and initially carry an anabolase, a catabolase, and one Gaussian-sampled defensase. The metabolic founders still begin with ABC specificity, while attackase remains absent until it appears later by mutation or by enzyme class switching.
During division, the offspring optimal enval is inherited by a biased midpoint rule. Let \(P\) be the parental optimal enval and \(W\) the current world-average enval. Define:
Then the offspring receives:
Other genome parameters also mutate stochastically: reproduction threshold, decay time, default secretion probability, enval stress factor, enzyme specificity masks, enzyme class, combat-enzyme level, enval response width, secretion probability, enval throughput, anabolase bond multiplier, and transmutase downhill harvest fraction. Enzyme count may also increase or decrease over evolutionary time.
The central ecological consequence is that successful lineages tend to destabilize the very field regime they exploit. Positive-adapted cells deplete positive enval and emit negative enval; negative-adapted cells deplete negative enval and emit positive enval. The intended macrodynamics are therefore cyclical succession, lineage turnover, and repeated ecological boom-bust behavior.
Microcosm is a browser-native ES-module application with no backend and no build step in the repository itself. The runtime is organized into a small set of source files:
./src/sim/bio.js defines enzyme classes and reaction execution../src/sim/cell.js defines cellular physiology, reaction logging, division, and mutation../src/sim/chem.js defines the artificial chemistry and molecule construction../src/sim/eco.js defines predator-prey interactions and combat mechanisms../src/sim/rng.js defines a seeded pseudorandom number generator and its helpers../src/sim/world.js defines the toroidal world, molecule diffusion, enval diffusion, and spawning../src/render/canvas.js defines the WebGL2 renderer../src/main.js wires together the simulation loop, statistics, interaction, and inspector UI.At startup the simulation builds a 320 x 240 world, spawns 32 founder cells, and advances the world at a fixed step of 10 ms. After initialization, additional founder cells are injected stochastically with a population-dependent spawn probability that declines toward a floor as occupancy rises. The renderer colors the background by local enval and colors cells by lineage identity; an interaction panel can switch tile coloring to per-element concentration channels (A through F). The HUD reports frame rate, tick rate, population, average energy, lineage count, enzyme functional diversity, elemental totals, and average enval. Left-clicking a cell opens a detailed inspector; in Explore mode right-clicking a cell selects its lineage, while in Edit mode right-click drag applies a rectangular enval brush. The inspector exposes internal molecules, genome parameters, recent reactions, and reaction-level energetic bookkeeping, and a button copies the recent reaction log to the clipboard.