Giter Club home page Giter Club logo

binflak's Introduction

BinFlak

BinFlak is a language a lot like BrainFlak, but compressed so that programs are a lot shorter, and any sequence of bytes is a unique syntactially-valid program.

Encoding a BrainFlak program into BinFlak is a two-step process:

First, the program is encoded as a base-five number (with the end of the program going in the high bits). Since only one closing-bracket is valid at any given position in a program, all closing-brackets are mapped to 0.

char digit
), ], }, > 0
( 1
[ 2
{ 3
< 4

Second, the numbers are "compacted," by subtracting the number of invalid programs (with more closing than opening braces) are less than it. Currently, this is calculated by brute-force, but I'm sure there's a clean(er) mathematical way to find this.

Finally, this number (as a sequence of extended-ASCII characters or whatnot) is your program.

Decoding a BinFlak program into BrainFlak follows this process in reverse.

As an example, let's translate the BrainFlak program [()()] into BinFlak.

  • To convert it to a base-5 number, we reverse it and follow the table above to get 001012, or 132.
  • Compacting this, we subtract 30, because there are 30 invalid programs less than 1012:
    • 10, 20, 30, 40, 100, 110, 120, 130, 140, 200, 210, 220, 230, 240, 300, 310, 320, 330, 340, 400, 410, 420, 430, 440, 1000, 1001, 1002, 1003, 1004, and 1010 are all invalid because they attempt to close a bracket they never open.
  • Finally, the program is 102, or read as ASCII f.

binflak's People

Contributors

g-rocket avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.