Skip to content
/ aixt Public

Microcontrollers programming framework based on Vlang.

License

Notifications You must be signed in to change notification settings

fermarsan/aixt

Repository files navigation

V-based Programming Framework for Microcontrollers

Aixt is a programming framework for microcontrollers which implements a subset of the V programming language, and is able to be used by low-resource devices. Aixt is composed by 3 main components:

  • The Aixt's V programming language which is a subset of the original V language.
  • The V to C Transpiler, which translate the V source code to C, for the specific C compiler of each microcontroller.
  • The Aixt API (almost all written in V), which makes the programming easy by standardizing the setup and I/O functions.

This diagram shows the Aixt blocks and their interactions:

stateDiagram-v2

    Aixt: V
    state Aixt {
        source: Source code

        API: Microcontroller API
        state API {
            PICs: PIC
            ATM: AT
            STM
            ESP
            RP2040
            PSoC
            others2: ...
            NXT: NXT brick
        }
    }



    Aixt2C: Transpiler
    state Aixt2C {
        state V {
            Transpiler: Transpiler
        }

        state json {
            setup: Setup files
        }
    }

    C: C
    state C {
        Tr_Code: Transpiled code
    }

    state Compiler {
        XC8
        XC16
        arduino_cli
        GCC
        others: ...
        nbc: nbc (NXC)
    }

    state machine {
        BF: Binary file
    }

    source --> Aixt2C
    API --> Aixt2C
    Aixt2C --> C
    C --> Compiler
    Compiler --> machine
Loading

Aixt is designed to be as modular as possible to facilitate the incorporation of new devices and boards. This is mainly possible by using a configuration files (in json format) instead of creating new source code for each new device. That .json file contains the specific parameters of each device, board or compiler such as: variable types, initialization commands, compiler paths, etc.

Aixt to C Transpiler

The transpiler is written in V and uses the V's self native compiler in order to transpile from V to C. This is implemented in the folder src\ and the main source code is the src\aixt.v file. Aixt generates code for 3 different backends:

  • c: for the microcontroller native C compiler
  • nxc: for the NXC compiler (LEGO Mindstorms NXT)
  • arduino: for the Arduino CLI

Aixt's V Language

Aixt's V programing language implements a subset of the V language. The main differences are show as follows:

feature V Aixt's V
strings dynamic-sized fixed-sized and dynamic-sized if supported
arrays dynamic-sized fixed-sized and dynamic-sized if supported
default integers size 32 bits depends on the device
structs allow functions (object-oriented) do not allow functions (only structured programming)
functions multiple return values only one return value
text macros not allowed allowed by using '@[as_macro]' attribute, for functions and constants
C variables access not allowed allowed by using 'C.var_name' syntax
global variables disabled by default enabled by default

Example with main function

/* Turning ON by 5.5 seconds the B7 on a
PIC16F84A microcontroller (XC8 compiler) */
import time
import pin

fn main() {
    pin.setup(pin.b7, pin.output)

    pin.high(pin.b7)    //turn ON the LED on PORTB7
    time.sleep_ms(5500)
    pin.low(pin.b7)
}

Example without main function (Script mode)

// ADC value to serial port on Raspberry Pi Pico (Arduino backend)
import time
import uart
import adc

uart.setup(9600)    // baud rate
adc.setup(12)       // resolution

for { // infinite loop
	analog := adc.read(adc.ch0)
	uart.println('ADC channel 0: ${analog}') // use string interpolation
	time.sleep_ms(500)
}

Example for NXT robotics platform

// "Drawing" an square with a differential platform (motors A and B)
import motor
import time

for {
	motor.write(motor.a, 50)
	motor.write(motor.b, -50)	// reverse
	time.sleep_ms(3000)
	motor.write(motor.a, -50)	// reverse
	time.sleep_ms(500)
}

Aixt API

The Aixt API is inspired by Micropython, Arduino and Tinygo. The API for all the ports includes at least functions for:

  • Digital input/output
  • Analog inputs (ADC)
  • PWM outputs
  • Serial port (UART)

Using Aixt

Installing Aixt from source

git clone https://github.com/fermarsan/aixt.git
cd aixt
make # make.bat on Windows

Running Aixt

run it in a Linux-based system as:

./aixt <command> <device_or_board> <source_file>

or in Windows:

aixt.exe <command> <device_or_board> <source_file>

Generating a Symbolic Link

For running the command aixt from any folder in the file system you can create a symbolic link of it in this way:

run it in a Linux-based system as:

./aixt symlink

or in Windows:

aixt.exe symlink

Running examples:

./aixt -t Emulator test.v
./aixt -b NXT ports/NXT/projects/1_motor.write.v

Prerequisites

  • The V programming language 0.4.9
  • auduino-cli last version (for arduino backend devices only)
  • specific C compiler depending on the device

Project's name

The project's name is inspired in Veasel, the Weasel pet of V Language, and at the same time is a tribute to Ticuna people who live in the Amazon forest between the borders of Colombia, Brasil and Perú. Weasels are mustelids just like otters, so the name Aixt comes from Aixtü, which is a way to say otter in Ticuna language.

Have questions?

Nice, you can contact me via mail.

Email: [email protected]

Want to contribute?

Cool, go ahead and make the contributions you want, then submit a new pull request

The microcontroller or board that you use is not listed here and you know how to program it in C?... You can easily add it to Aixt, please check CONTRIBUTING.md.

Take a look at TODO.md to find a task for you.

Please check CONTRIBUTING.md to learn how you can contribute.

License

The Aixt project is licensed under the MIT, which is attached in this repository.