1 unstable release
0.12.0-nightly |
|
---|---|
0.12.0-beta.1 | Nov 15, 2024 |
#437 in Algorithms
231 downloads per month
48KB
658 lines
UltraSONIC: Transactional execution layer with capability-based memory access for zk-AluVM
What is it
UltraSONIC is a state machine with capability-based memory access. In simple words, this means
state machine with cryptographically-protected memory cells
.
What is capability-based memory access (or capability-addressable memory, CAM)? The computers we all used to are random memory access machines (RAM), where a software accesses freely-addressable global memory. This had opened a door for the all the vulnerabilities and hacks happening in computer systems across the world for the past decades... CAM model instead, divides all memory into parts (called words) addressable only with some access token (called capability). You may think of this as of a memory where each part is "owned" by certain party, and can be accessed or modified only given a proof of ownership.
UltraSONIC leverages zk-AluVM, so it is (1) zk-STARK-compatible and (2) exception-less, made with category theory in mind.
Ecosystem
SONARE is a part of a larger ecosystem used to build safe distributed software, which includes:
- Strict types: strong type system made with generalized algebraic data types (GADT) and dependent types;
- AluVM: a functional register-based virtual machine with a reduced instruction set (RISC); UltraSONIC uses a zk-STARK-compatible subset of its instruction set architecture (called zk-AluVM);
- SONARE: runtime environment for UltraSONIC software;
- Cation: a general-purpose high-level programming language made with category theory, which features strict types, termination analysis and can be formally verified;
- Contractum: a domain-specific version of Cation for writing programs for UltraSONIC.
License
Designed in 2019-2024 by Dr Maxim Orlovsky <orlovsky@ubideco.org>
Written in 2024-2025 by Dr Maxim Orlovsky <orlovsky@ubideco.org>
Copyright (C) 2019-2024 LNP/BP Standards Association, Switzerland.
Copyright (C) 2024-2025 Laboratories for Ubiquitous Deterministic Computing (UBIDECO),
Institute for Distributed and Cognitive Systems (InDCS), Switzerland.
Copyright (C) 2019-2025 Dr Maxim Orlovsky.
All rights under the above copyrights are reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Dependencies
~6MB
~109K SLoC