Averest 3.3.0

dotnet add package Averest --version 3.3.0                
NuGet\Install-Package Averest -Version 3.3.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Averest" Version="3.3.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Averest --version 3.3.0                
#r "nuget: Averest, 3.3.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Averest as a Cake Addin
#addin nuget:?package=Averest&version=3.3.0

// Install Averest as a Cake Tool
#tool nuget:?package=Averest&version=3.3.0                

About Averest

Averest is a framework for the model-based design of reactive systems that supports the modeling, specification, simulation, compilation, formal verification, and synthesis of hardware circuits and software with a special focus on formally proven correctness. It contains compilers for synchronous languages, a simulator for the latter, support for formal verification with temporal and other logics, and various transformations for the hardware and software synthesis of reactive embedded systems which also covers pure hardware circuits and pure software systems. It also provides a small compiler for a tiny sequential programming language called MiniC and code generators for RISC and buffered exposed dataflow processors like the SCAD processor. Averest is developed by the Embedded Systems Group at the RPTU Kaiserslautern-Landau and is the result of a long-term and still ongoing research effort of this group. See also http://www.averest.org for further information.

Synchronous Programs: Quartz

The typical design flow with Averest starts with a system description written in the synchronous programming language Quartz that has been developed by the Embedded Systems Group at the RPTU Kaiserslautern-Landau. Quartz is very similar to Esterel, but also has some differences. Details about the Quartz language can be found in the introductory tutorial at http://www.averest.org/pdf/QuartzPresentation.pdf.

Sequential Programs: MiniC

MiniC is a toy language for sequential programs that has been introduced originally for teaching, but is now also part of Averest to describe sequential programs generated from the synchronous models. Averest provides also code generators for RISC processors, and buffered exposed datapath processors like the SCAD machine developed at RPTU.

Main modules

The full documentation of the API generated by FsDocs is available at http://www.averest.org/AverestLibDoc/reference. To give you a quick overview on the modules of the Averest library, have a look at the following (incomplete) list of modules:

  • Averest.Core

    • Graphs: some basic algorithms on graphs and partial orders
    • Types: implements types of the Quartz language
    • Names: implements qualified names used by identifiers
    • Declarations: implements declarations of modules
    • Abbreviations: implements an abbreviation table to share common subexpressions
    • Expressions: implements the expressions of the Quartz language
    • Actions: implements atomic actions like immediate/delayed assignments and assertions
    • Specifications: implements temporal logic specifications
  • Averest.Quartz

    • UtyExprs: untyped expressions (after initial parsing)
    • UtyStmts: untyped statements (after initial parsing)
    • Statements: typed statements of the Quartz language
    • Compiler: provides parsers and compilers to systems and modules
  • Averest.MiniC

    • Types: Abacus instructions, CMD instructions, MiniC expressions/statements/programs
    • IO: parsers for Abacus, MiniC, CMD programs
    • CodeTransformations: MiniC->C, MiniC->F#, predication and SSA-form of MiniC
    • Compiler: translate to control-dataflow graphs (CMD programs)
    • DataflowProcessNetworks: MiniC->DPN, Leveling DPNs, Parsing DPNs, Simulation of DPNs, Dataflow Computer
    • CodeGenAbacus: perform dataflow analysis (liveness, used variables), register allocation and RISC code generation
    • CodeGenSCAD: DPN->SAT/SMT constraints; DPN+PUalloc->2SAT constraints, VertexDisjointNodeCovers
    • Abacus: simulator for the Abacus RISC processor
    • ScadSim: simulator for the SCAD processor
  • Averest.Analysis

    • BDD: provides a complete implementation of binary decision diagrams
    • Matrices: provides types for matrices, linear equation solvers, linear inequality solvers (simplex and Fourier-Motzkin)
    • SatSolver: provides a little SAT solver with non-chronological backtracking
    • TemporalLogic: provides translations of LTL/LeftCTL*/CTL to omega-automata, and mu-calculus
  • Averest.Transform

    • BitBlast: converts expressions and modules to a bit-level
    • Scalarizer: expands all variables of compound types to scalar enumerations
    • Scheduling: provides some scheduling algorithms (ASAP,ALAP,Force-Directed,List,Linear scheduling)
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.3.0 66 1/13/2025
3.2.1 133 7/16/2024
3.1.1 193 7/11/2023
3.1.0 108 7/10/2023
3.0.8 154 4/11/2023
3.0.7 127 3/22/2023
3.0.6 114 3/21/2023
3.0.5 328 1/14/2023
3.0.4 346 11/21/2022
3.0.3 333 11/18/2022
3.0.2 334 11/18/2022
3.0.1 485 6/13/2022
3.0.0 435 6/3/2022