Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
cellular-automata-voxel-shader
Advanced tools
Generate a voxel shader (for MagicaVoxel) from a custom CA rule.
Generate a voxel shader (for MagicaVoxel) from a custom CA rule.
With npm do:
npm install cellular-automata-voxel-shader -g
cavoxelshader rule outOfBoundValue
Return the code of the shader to stdout.
cavoxelshader info [filename]
Extracts the details of a given generated file (rule, outOfBoundValue and version) to stdout.
When used without filename, will list all the files of the current directory with their details to stdout.
cavoxelshader "E 4..6 / 6 von-neumann" 0 > erode.txt
Here "E 4..6 / 6 von-neumann" is the rule and 0 is the out-of-bound value.
In your console / terminal, go into the shader folder of your MagicaVoxel install and execute cavoxelshader "E 4..6 / 6 von-neumann" 0 > erode.txt. This will create a file called erode.txt containing the voxel shader.
Then in MagicaVoxel, load a model (for example monu1 or monu9) and execute xs erode in its console to execute it once. You can also execute xs -n 5 erode, to execute it 5 times, etc.
The rule describes the formula applied on each cells to update its state.
It is recommended to use the custom "Extended" rule format. The command accepts many other rule formats (Life S/B, Generations S/B/C, Vote for Life, Cyclic R/T/C/N, LUKY and NLUKY) but they were originally designed for 2D, most of them allowing only values up to 9.
The format of a valid Extended rule is as follow :
E survivalValues / birthValues neighbourhoodType neighbourhoodRange
The survivalValues defines the counts of alive neighbours necessary for a cell to survive (stay at its current alive state).
The birthValues defines the counts of alive neighbours necessary for a cell to be born (change state from dead to alive).
They are both list of numbers separated by commas (thus allowing number > 9). They can also contains ranges expressed with two dots, also very useful in 3D CA.
For example "E 8,10..26 / 8..26" means :
The most common neighbourhoodTypes are moore (the default) and von-neumann.
The neighbourhoodRange defines the distance that the neighbourhood covers, its radius. Its default value is 1.
A moore neighbourhood (of range 1) basically includes all the cells with a least one corner touching the current cell. In 3D, this gives 26 neighbours for a given cell. A von-neumann neighbourhood (of range 1) includes only the cells directly adjacent to the current cells. In 3D, this gives 6 neighbours for a given cell.
The Wikipedia pages for those neighbourhood include more correct definitions and examples of how the von-neumann neighbourdhood expands with a range > 1. https://en.wikipedia.org/wiki/Moore_neighborhood https://en.wikipedia.org/wiki/Von_Neumann_neighborhood
The Extended rule format also allows more unconventional neighbourhood types : corner (basically the 8 corners of the moore neighbourhood), edge (the edges of the moore neighbourhood), face (the faces of the moore neighbourdhood) and axis (all the cells directly aligned with one of the current cell's faces).
Finally, it is possible to add a probability to each range and value using a colon notation.
For example "E 8:0.75,10..26 / 8..26:0.95" means :
The out-of-bound value basically dictates how the cellular automata must deal with cells which are outside of the volume. Its possible values are 0 (out-of-bound values are always considered dead), 1 (out-of-bound values are always considered alive, useful to create CA expanding from the sides to the center), wrap (the cellular automata behave as if the volume was infinitely repeated in space, i.e. in a 64x64x64 volume the cell [43, 50, 64] would be wrapped to [43, 50, 0]) and clamp (the cellular automata get the nearest cell in the volume, i.e. in a 64x64x64 volume the cell [43, 50, 64] would be mapped to [43, 50, 63]).
Single-state rule formats (Extended, Life S/B, and LUKY) accept a single parameter allowing them to assign different colours to the cell depending on the number of alive cells in the neighbourhood at the time of the execution. By default this parameter is set to 0 which disables it. Setting it to a value of 1 enables it, while setting it to a decimal value between 0 and 1 allows to control the number of colours used.
xs myshader 0 // no colours
xs myshader 1 // one colour per number of alive cells
xs myshader 0.25 // less colours, one colour per 4 alive cells to be precise
It's possible to apply colours without modifying the state of the voxel model by executing a rule which does not do anything (ie. a rule where all cells survives and none are born). This makes it easier to experiment with different neighbourhood types and ranges.
Here are a few examples of such rules : E 0..26 / M
, E 0..6 / V
, E 0..32 / V 2
, E 0..12 / axis 2
, ...
This feature should not be executed in conjunction with multi-state rules (Generations, Cyclic R/T/C/N and NLUKY) if you care about correctness.
See the gallery for several examples.
xs -n
syntax.Thanks to Nick Nenov for sharing his implementation of the colouring single-state rules feature.
MIT
FAQs
Generate a voxel shader (for MagicaVoxel) from a custom CA rule.
The npm package cellular-automata-voxel-shader receives a total of 14 weekly downloads. As such, cellular-automata-voxel-shader popularity was classified as not popular.
We found that cellular-automata-voxel-shader demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.