Skip to content
/ golyb Public

Go love your brain - yet another optimizing BrainF*ck interpreter in Go

License

Notifications You must be signed in to change notification settings

dim13/golyb

Repository files navigation

GoDoc Build

Go love your brain

Yet another optimizing BrainF*ck interpreter in Go

Installation

go get github.com/dim13/golyb/cmd/golyb

Usage

Usage of golyb:
  -dump
    	Dump AST and terminate
  -file string
    	Source file (required)
  -in string
    	Input file
  -noop
    	Disable optimization
  -out string
    	Output file or /dev/null
  -profile string
    	Write CPU profile to file
  -show
    	Dump tape cells
  -tape value
    	Tape type: static or dynamic (default static)

Tape storage type

  • static: 32k byte cells including 1k margin on the lower end (used by default)
  • dynamic: int cells allocated in 1k chunks as required on access

Code optimization

  • Contraction
  • Clear loops
  • Copy loops
  • Multiplication loops
  • Scan loops (kind of)
  • Operation offsets
  • Reduce NOPs

Reference: http://calmerthanyouare.org/2015/01/07/optimizing-brainfuck.html

Some rough results

Program w/o optimization with optimization speed gain
madelbrot.b 52.3 sec 11.8 sec 4.4x
long.b 48.5 sec 5.4 sec 9.0x
hanoi.b 47.0 sec 1.0 sec 47.0x
bench.b 6.6 sec 1.1 sec 6.0x

Executed on 1.3 GHz Intel Core i5

CPU profiles

mandelbrot.b

optimized

mandelbrot profile

not optimized

mandelbrot profile

long.b

optimized

long profile

not optimized

long profile

hanoi.b

optimized

hanoi profile

not optimized

hanoi profile

About

Go love your brain - yet another optimizing BrainF*ck interpreter in Go

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages