#brainfuck #diagram #effect #programs #stack #generate #algorithm

bin+lib autoperm

A tool for generating brainfuck programs that apply stack effect diagrams

3 unstable releases

0.3.0 Mar 17, 2023
0.2.1 Mar 15, 2023
0.2.0 Mar 14, 2023
0.1.5 Sep 15, 2022
0.1.4 Sep 2, 2022

#611 in Programming languages

GPL-3.0-or-later

30KB
550 lines

Crates.io Documentation Codecov Dependency status

autoperm

autoperm is a tool for generating programs that apply stack effect diagrams. The produced result has the fewest number of MOV* instructions. The algorithm has it's foundations in Tarjan's Strongly Connected Components.

The library is backend agnostic. A brainfuck backend is provided. Installing the crate as a binary gives access to the autoperm command which uses this brainfuck backend.

* A MOV Clears the data at a particular memory address and writes it to a list of other cells

Eventually I will create a proper write up but for now here is my quick explanation.

Install

cargo install autoperm

Usage

$ autoperm a b -- b a
[->+<]<[->+<]>>[-<<+>>]<

$ autoperm
a b c -- c a b
[->+<]<[->+<]<[->+<]>>>[-<<<+>>>]<

a -- a a a a
[->>>>+<<<<]>>>>[-<+<+<+<+>>>>]<

a b c d -- d c a b
[->+<]<<[->>+<<]>[-<+>]<<[->>+<<]>>>>[-<<<<+>>>>]<

a b c -- c
<<[-]>[-]>[-<<+>>]<<

a b c d e f -- c d d f e e b
<<<<<[-]>[->>>>>+<<<<<]>[-<<+>>]>[-<+<+>>]>>[-<<+>>]<[->>>+<<<]>>>[-<<+<+>>>]<

The program assumes the memory pointer is pointing at the top of the stack. Any new cells should start empty and there must be 1 free cell at the top of the stack for temporary storage.

For example:

(a b c -- c)
start must be:
  a  b *c  0 // a and b are cleared
<<[-]>[-]>[-<<+>>]<<
end:
 *c  0  0  0

(a -- a a a a)
start must be:
  a  0  0  0  0 // note: no 0s are initialized before usage
[->>>>+<<<<]>>>>[-<+<+<+<+>>>>]<
end:
  a  a  a *a  0

A walk through for (a b -- a b a b)

a b -- a b a b
<[->>>>+<<<<]>>>>[-<<+<<+>>>>]<<<[->>>+<<<]>>>[-<+<<+>>>]<

# the tape
 0 *1  2  3  T 
 a  b  0  0  0

<[->>>>+<<<<]      0{T}
*0  1  2  3  T 
 0  b  0  0  a

>>>>[-<<+<<+>>>>]  T → {2 0}
 0  1  2  3 *T 
 a  b  a  0  0

<<<[->>>+<<<]      1{T}
 0 *1  2  3  T 
 a  0  a  0  b

>>>[-<+<<+>>>]     T → {1 3}
 0  1  2  3 *T 
 a  b  a  b  0

< 
 0  1  2 *3  T 
 a  b  a  b  0

Dependencies

~2MB
~37K SLoC