Axiomadic (Ax for short) is an ambitious project to create a revolutionary computational reasoning system that seamlessly integrates programming, proof assistance, and parallel computation.
// Define a vector type
data Vec (A : Type) (n : Nat) : Type where
Nil : Vec A 0
Cons : (x : A) -> (xs : Vec A n) -> Vec A (S n)
// Define a parallel map function
def pmap : (A B : Type) -> (n : Nat) -> (f : A -> B) -> Vec A n -> Vec B n
pmap A B Z f Nil = Nil
pmap A B (S n) f (Cons x xs) =
let x' = spawn (f x)
let xs' = pmap A B n f xs
Cons (sync x') xs'
// Define a doubling function
def double : Int -> Int
double x = x + x
// Theorem: pmap preserves length
theorem pmap_preserves_length :
(A B : Type) -> (n : Nat) -> (f : A -> B) -> (v : Vec A n) ->
length (pmap A B n f v) = n
proof
intros A B n f v
induction n
case Z => reflexivity
case S n' =>
simpl
rewrite <- IH
reflexivity
qed
// Main function
def main : Vec Int 4
main =
let v = Cons 1 (Cons 2 (Cons 3 (Cons 4 Nil)))
let result = pmap Int Int 4 double v
assert (length result = 4) // This should be automatically proved
result
// Run main and print result
print (run main)
Axiomadic is currently in the very early stages of development. We have a basic interpreter implemented in Rust, which serves as a proof of concept for some of our core ideas.
Axiomadic aims to be more than just a programming language. Our goal is to create a comprehensive environment for developing, proving, and executing complex computational and mathematical ideas.
- Dependent type system with Cubical Type Theory features
- Built-in parallel computation model (multi-core/CUDA/OpenCL)
- Integrated proof assistant with tactics
- Effect system and linear types
- Metaprogramming capabilities
- Automatic parallelization and proof-guided optimization
graph LR
A[1.1 Core Calculus Implementation] --> B[1.2 Type System Development]
A --> C[2.1 Parallel Computation Model]
B --> D[1.3 Effect System and Linear Types]
B --> E[3.1 Tactic Language Development]
C --> F[2.2 Automatic Parallelization]
E --> G[3.2 Theorem Proving Capabilities]
G --> H[3.3 Integration of Proofs and Code]
B --> I[4.1 Metaprogramming System]
A --> J[4.2 Standard Library Development]
B --> J
C --> J
A --> K[5.1 Compiler Development]
B --> K
C --> K
D --> K
K --> L[5.2 Development Environment]
J --> M[5.3 Package Management and Build System]
K --> M
A --> N[6.1 Language Documentation]
B --> N
C --> N
D --> N
E --> N
F --> N
G --> N
H --> N
I --> N
J --> N
K --> N
L --> N
M --> N
N --> O[6.2 Community Building]
Here's our high-level plan for developing Axiomadic:
- Develop basic interpreter in Rust
- Implement core type system
- Basic types (Int, Float, Bool, etc.)
- Dependent types
- Universe hierarchy
- Develop parallel computation model
- Implement proof assistant features
- Basic tactics
- Theorem proving capabilities
- Implement effect system and linear types
- Add metaprogramming capabilities
- Develop automatic parallelization and proof-guided optimization
- Create standard library
- Develop tooling (IDE support, debugger, etc.)
- Write comprehensive documentation
- Release alpha version
- Dependent Type System: Will support advanced type-level programming and verification.
- Built-in Parallel Computation: Native support for parallel and concurrent programming.
- Integrated Proof Assistant: Will allow for theorem proving and formal verification within the same environment.
- Effect System and Linear Types: For precise control over side effects and resource usage.
- Metaprogramming Capabilities: Will enable powerful code generation and transformation.
- Automatic Parallelization: The compiler will automatically parallelize suitable computations.
While we're not yet at a stage where we can accept code contributions, we're very interested in feedback, ideas, and discussions about the theory and design of Axiomadic.
If you're interested in following the development of Axiomadic or contributing ideas:
- Star and watch this repository for updates.
- Check out our Discussions page to participate in design discussions.
- If you find the concept exciting, spread the word! The more interest we generate, the more resources we can devote to making Axiomadic a reality.
Our current interpreter can handle basic arithmetic operations and function definitions. Here's a simple example:
let mut interpreter = Interpreter::new();
// Define a simple doubling function
let double_func = Expr::Lambda(
vec!["x".to_string()],
Box::new(Expr::Application(
Box::new(Expr::Variable("+".to_string())),
vec![Expr::Variable("x".to_string()), Expr::Variable("x".to_string())]
))
);
interpreter.env.insert("double".to_string(), interpreter.eval(&double_func).unwrap());
// Apply the function
let result = Expr::Application(
Box::new(Expr::Variable("double".to_string())),
vec![Expr::Literal(Value::Int(5))]
);
match interpreter.eval(&result) {
Ok(value) => println!("Result: {}", value),
Err(e) => println!("Error: {}", e),
}
This is just the beginning. Our goal is to evolve this into a full-fledged system supporting all the features described in our vision.
Axiomadic is released under the MIT License.
Axiomadic is inspired by decades of research in programming languages, type theory, and formal verification. We're grateful to the entire PL community for laying the groundwork that makes this project possible.
We're at the start of an exciting journey to revolutionize computational reasoning. Stay tuned for updates!
This revised README reflects the early stage of the project, outlines the vision and roadmap, and provides a realistic picture of where the project currently stands. It also encourages community involvement in the form of discussions and idea-sharing, which is appropriate for this early stage of development.