

# Veryl: A Modern Hardware Description Language For Open Source Hardware Design

Naoya Hatta  $^1$  Taichi Ishitani  $^1$  Nathan Bleier  $^2$ 

June 19, 2025

 $<sup>^{1}\</sup>mbox{Pezzy}$  Computing, K.K.

<sup>&</sup>lt;sup>2</sup>University of Michigan

- Error-Prone Constructs
  - Tooling compilation mismatches
  - Clock domain crossing errors
  - Non-synthesizable code

```
module width bug (
  input [2:0] sel,
  input [31:0] a, b,
  output [31:0] out
);
  // Bug I experienced as undergrad
  // ModelSim: 2'b11 \rightarrow 3'b011
  // Altera: 2'b11 \rightarrow 3'b111
  assign out = sel == 2'b11 ? a : b;
endmodule
```

- Error-Prone Constructs
  - Tooling compilation mismatches
  - Clock domain crossing errors
  - Non-synthesizable code
- Academic Productivity Issues
  - No real-time error checking
  - Manual dependency management
  - Poor integration with modern editors

```
// No real-time feedback on errors
module mystery bug (
  input clk, rst,
  input [31:0] data_in,
  output [31:0] data out
);
  // Bug only found during simulation
  always @(posedge clk or rst) begin
    if (rst)
      data out <= 0:
    else
      data_out <= data_in + 1;</pre>
  end
endmodule
```

- Error-Prone Constructs
  - Tooling compilation mismatches
  - Clock domain crossing errors
  - Non-synthesizable code
- Academic Productivity Issues
  - No real-time error checking
  - Manual dependency management
  - Poor integration with modern editors
- Collaboration Friction
  - Complex build setup for newcomers
  - Ad-hoc component re-use
  - Ad-hoc documentation workflow

```
# Typical research project setup
git clone mysterious_repo
cd mysterious_repo
# Now what? No clear build instructions
make? # Command not found
vivado? # Need license, specific version
# Email the author for build instructions
```

- Error-Prone Constructs
  - Tooling compilation mismatches
  - Clock domain crossing errors
  - Non-synthesizable code
- Academic Productivity Issues
  - No real-time error checking
  - Manual dependency management
  - Poor integration with modern editors
- Collaboration Friction
  - Complex build setup for newcomers
  - Ad-hoc component re-use
  - Ad-hoc documentation workflow
- Integration with Existing Codebases
  - Unreadable generated SV
  - Hard to debug generated code

```
// Generated by SpinalHDL - hard to debug!
assign _zz_176 = 3'b100;
assign _zz_177 = execute_INSTRUCTION[19:15];
assign _zz_180 = ($signed(_zz_181) + $signed(_zz_184));
assign _zz_181 = ($signed(_zz_182) + $signed(_zz_183));
assign _zz_184 = (execute_SRC_USE_SUB_LESS ? _zz_185 : _zz_186);
assign _zz_185 = 32'h00000001;
assign _zz_186 = 32'h0;
// What does this actually do?
// Can't integrate with existing SV modules easily
// Can't effectively modify generated SV manually
// Can't intuitively map generated SV to Spinal source-code
```

# The Research Productivity Gap

### **Software Research Today:**

- Language servers and Tree-Sitter
- Package managers for dependencies
- Auto-formatters for consistency
- Integrated docs (e.g., rust-docs)
- CI/CD for reproducible builds

# Hardware Research Reality:

- Basic syntax highlighting
- Manual `include statements
- "House style" varies by lab
- Separate documentation tools
- Complex vendor-specific flows

# The Research Productivity Gap

### **Software Research Today:**

- Language servers and Tree-Sitter
- Package managers for dependencies
- Auto-formatters for consistency
- Integrated docs (e.g., rust-docs)
- CI/CD for reproducible builds

# Hardware Research Reality:

- Basic syntax highlighting
- Manual `include statements
- "House style" varies by lab
- Separate documentation tools
- Complex vendor-specific flows

Young researchers expect modern tooling!

• Barrier to Entry: New students struggle with archaic tooling

- Barrier to Entry: New students struggle with archaic tooling
- Collaboration Friction: Difficult to share and build upon others' work

- Barrier to Entry: New students struggle with archaic tooling
- Collaboration Friction: Difficult to share and build upon others' work
- Research Velocity: Custom, manual, & buggy processes slow down iteration

- Barrier to Entry: New students struggle with archaic tooling
- Collaboration Friction: Difficult to share and build upon others' work
- Research Velocity: Custom, manual, & buggy processes slow down iteration
- Reproducibility: Complex build systems make verification difficult

- Barrier to Entry: New students struggle with archaic tooling
- Collaboration Friction: Difficult to share and build upon others' work
- Research Velocity: Custom, manual, & buggy processes slow down iteration
- Reproducibility: Complex build systems make verification difficult

Open source hardware research needs modern language infrastructure

# Veryl: Research-Focused Design Principles

- 1. Gradual Adoption in Research Projects
  - Drop-in replacement for SystemVerilog modules
  - Integrate with existing research codebases
  - Generate safe, readable SystemVerilog for debugging & integration

# Veryl: Research-Focused Design Principles

- 1. Gradual Adoption in Research Projects
  - Drop-in replacement for SystemVerilog modules
  - Integrate with existing research codebases
  - Generate safe, readable SystemVerilog for debugging & integration
- 2. Modern Research Infrastructure
  - Language server for real-time error checking
  - Package manager for sharing research components
  - Automated formatting for consistent collaboration
  - Integrated documentation with diagrams

# Veryl: Research-Focused Design Principles

### 1. Gradual Adoption in Research Projects

- Drop-in replacement for SystemVerilog modules
- Integrate with existing research codebases
- Generate safe, readable SystemVerilog for debugging & integration

#### 2. Modern Research Infrastructure

- Language server for real-time error checking
- Package manager for sharing research components
- Automated formatting for consistent collaboration
- Integrated documentation with diagrams

# 3. Academic Workflow Support

- ASIC/FPGA portability for prototyping
- Built-in testing framework integration
- Reproducible project configuration with version management
- CI/CD Pipeline to automate testing & artifact evaluation

# **Gradual Adoption: Bidirectional SystemVerilog Interoperability**

#### Veryl seamlessly integrates with existing SystemVerilog ecosystem

## Top-level SystemVerilog:

```
// cpu core.sv - Existing research CPU
module cou core (
 input logic clk, rst_n,
 input logic [31:0] instr.
 input logic [31:0] fp_reg_a,
 input logic [31:0] fp_reg_b,
 input logic [3:0] fp op.
 output logic [31:0] result
 // Instantiate new Verul FPU
 fp alu u fpu (
   .clk(clk), .rst n(rst n),
    .op_a(fp_reg_a), .op_b(fp_reg_b),
    .operation(fp_op),
   .result(fp result)
endmodule
```

# Veryl FPU:

```
// fp alu.veryl
module fp_alu (
   clk
           : input clock
   rst : input reset_async_low
   op_a : input logic
   op b : input logic
                               <32>.
   operation: input logic
                               <3> .
           : output logic
                               <32>,
   inst u_macc: $sv::DW_fp_mac (
      clk : clk . rst n: rst .
      a : op a , b : op b ,
      c : 32'h0 , rct : 3'b000,
         : z .
   // ...
```

# **Generated SystemVerilog:**

```
// fp alu.sv - Generated from Veryl
        module fp_alu (
          input logic clk,
      input logic rst n,
<32>, input logic [31:0] op_a,
          input logic [31:0] op_b,
          input logic [2:0] operation.
          output logic [31:0] z
          // Clean. readable instantiation
          DW fp mac u macc (
          .clk(clk), .rst n(rst n),
          .a(op_a), .b(op_b), .c(32'h0),
            .rct(3'b000), .z(z)
          ):
        endmodule
```

# Gradual Adoption: Bidirectional SystemVerilog Interoperability

## Veryl seamlessly integrates with existing SystemVerilog ecosystem

### Top-level SystemVerilog:

```
// cpu core.sv - Existing research CPU
module cou core (
 input logic clk, rst n,
 input logic [31:0] instr.
 input logic [31:0] fp_reg_a,
 input logic [31:0] fp_reg_b,
 input logic [3:0] fp op.
 output logic [31:0] result
 // Instantiate new Verul FPU
 fp alu u fpu (
    .clk(clk), .rst n(rst n),
    .op_a(fp_reg_a), .op_b(fp_reg_b),
    .operation(fp_op),
   .result(fp result)
endmodule
```

# Vervl FPU:

```
// fp alu.veryl
module fp_alu (
   clk
           : input clock
         : input reset_async_low
   rst
   op_a : input logic
   op b : input
                 logic
                               <32>.
   operation: input logic
                               <3> .
           : output logic
                               <32>.
   inst u_macc: $sv::DW_fp_mac (
      clk : clk . rst n: rst .
      a : opa, b : opb,
      c : 32'h0 , rct : 3'b000,
          : z .
   // ...
```

# **Generated SystemVerilog:**

```
// fp alu.sv - Generated from Verul
module fp_alu (
 input logic clk,
 input logic rst n,
 input logic [31:0] op a,
 input logic [31:0] op_b,
 input logic [2:0] operation.
 output logic [31:0] z
 // Clean. readable instantiation
 DW fp mac u macc (
 .clk(clk), .rst n(rst n),
    .a(op_a), .b(op_b), .c(32'h0),
    .rct(3'b000), .z(z)
endmodule
```

- √ Veryl uses SV
- ✓ SV uses Veryl

✓ Clean

generated code

■ ✓ Readable

IΡ

modules

# **Gradual Adoption: Safety for Debugging & Integration**

#### Veryl catches errors early and generates debuggable SystemVerilog

# SystemVerilog - Runtime Errors:

```
module unsafe_alu (
  input logic clk, rst, [2:0] sel,
  input logic [31:0] a, b,
  output logic [31:0] result);
  always_ff @(posedge clk or rst)
   if (rst) result <= 0;
   else result <= sel == 2'b11 ? a + b : a - b;
endmodule</pre>
```

# **Veryl** - Compile-time Safety:

```
module safe alu (
  i_clk: input clock, i_rst: input reset_async_low,
 i_sel: input logic<3>, i_a: input logic<32>,
  i_b: input logic<32>, o_result: output logic<32>,
 // Strong tuping prevents width mismatches
 // Reset polarity determined by type or config
  always_ff {
   if reset { o result = 0; } else {
      case i sel {
       3'b011: o_result = i_a + i_b;
       default: o_result = i_a - i_b;
     1 1 1 1
```

# Gradual Adoption: Safety for Debugging & Integration

# Veryl catches errors early and generates debuggable SystemVerilog

# SystemVerilog - Runtime Errors:

```
module unsafe_alu (
  input logic clk, rst, [2:0] sel,
  input logic [31:0] a, b,
  output logic [31:0] result);
  always_ff @(posedge clk or rst)
   if (rst) result <= 0;
   else result <= sel == 2'b11 ? a + b : a - b;
endmodule</pre>
```

- ✓ Width mismatches caught at compile-time
- ✓ Clock/reset inference prevents sensitivity errors
- ✓ Strong typing eliminates common bugs
- ✓ Generated code maps clearly to source

# **Veryl - Compile-time Safety:**

```
module safe alu (
  i_clk: input clock, i_rst: input reset_async_low,
 i_sel: input logic<3>, i_a: input logic<32>,
  i_b: input logic<32>, o_result: output logic<32>,
 // Strong typing prevents width mismatches
 // Reset polarity determined by type or config
  always_ff {
    if reset { o result = 0: } else {
      case i_sel {
       3'b011: o_result = i_a + i_b;
      default: o_result = i_a - i_b;
     1 1 1 1
```

# Language Server

```
module width_mismatch (
   i_sel: input logic<3>,
   i_a: input logic<32>,
   o_out: output logic<32>,
}

// Error: width mismatch detected immediately
assign o_out = i_sel == 2'b11 ? i_a : -i_a;
// LSP: Expected 3-bit, got 2-bit
}
```

### Language Server

```
module width_mismatch (
   i_sel: input logic<3>,
   i_a: input logic<32>,
   o_out: output logic<32>,
) {
   // Error: width mismatch detected immediately
   assign o_out = i_sel == 2'b11 ? i_a : -i_a;
   // LSP: Expected 3-bit, got 2-bit
}
```

### Package Management:

```
[project]
name = "research_cpu"
version = "0.1.0"
license = "Apache-2.0"
repository = "https://github.com/..."
[dependencies]
std = "1.0"
riscv_common = { git = "https://github.com/...", versity
```

### Language Server

#### **Automatic Formatting:**

```
$ veryl fmt
$ veryl check
```

Consistent code style & lint checking

### Package Management:

```
[project]
name = "research_cpu"
version = "0.1.0"
license = "Apache-2.0"
repository = "https://github.com/..."
[dependencies]
std = "1.0"
riscv_common = { git = "https://github.com/...", vereference.
```

# Language Server

#### **Automatic Formatting:**

```
$ veryl fmt
$ veryl check
```

Consistent code style & lint checking

# Package Management:

```
[project]
name = "research_cpu"
version = "0.1.0"
license = "Apache-2.0"
repository = "https://github.com/..."
[dependencies]
std = "1.0"
riscv_common = { git = "https://github.com/...", ver
```

# Publishing & Sharing:

```
$ veryl publish
$ veryl build
```

Share with community & reproducible builds

#### Modern Research Infrastructure: Documentation

#### Integrated documentation with diagrams and auto-generation

#### **Rich Documentation Comments:**

```
/// # RISC-V ALU
/// Arithmetic Logic Unit for research processor
/// ``wavedrom
/// { signal: [
/// { name: 'clk', wave: 'p....' },
/// { name: 'op', wave: 'w3.4.6' },
/// { name: 'result', wave: 'x.3.4.' }
/// ]]
/// ``
pub module alu (
/// ALU operation selector
i_op: input alu_op_t,
o_result: output logic<32>,
) { /* ... */ }
```

### \$ veryl doc

#### Modern Research Infrastructure: Documentation

#### Integrated documentation with diagrams and auto-generation

#### **Rich Documentation Comments:**

```
/// # RISC-V ALU
/// Arithmetic Logic Unit for research processor
/// ``wavedrom
/// { signal: [
/// { name: 'clk', wave: 'p....' },
/// { name: 'result', wave: 'x3.4.5' },
/// { name: 'result', wave: 'x3.4.' }
/// ]}
/// ``
pub module alu (
/// ALU operation selector
i_op: input alu_op_t,
o_result: output logic<32>,
) { /* ... */ }
```

\$ veryl doc

#### **Generated Documentation:**



- Doc for packages, interfaces, modules
- Wavedrom & Mermaid diagram support
- Markdown formatting
- Searchable interface

# **Academic Workflow Support**

# **Clock Domain Safety:**

```
module cdc example (
 i_clk_a: input 'a clock,
 i data a: input 'a logic<32>,
 i_clk_b: input 'b clock,
  o_data_b: output 'b logic<32>,
 // Error: Clock domain crossing detected
  assign o_data_b = i_data_a;
            // LSP: Clock domain 'a -> 'b crossing
             // Use unsafe(cdc) block
            // unsafe (cdc) {
            // assign o data b = i data a;
            1/ }
```

# Academic Workflow Support

## Clock Domain Safety:

```
module cdc example (
  i_clk_a: input 'a clock,
  i data a: input 'a logic<32>,
  i_clk_b: input 'b clock,
  o_data_b: output 'b logic<32>,
) {
  // Error: Clock domain crossing detected
  assign o_data_b = i_data_a;
             // LSP: Clock domain 'a -> 'b crossing reset_type = "async_low"
             // Use unsafe(cdc) block
            // unsafe (cdc) {
            // assign o data b = i data a;
            117
```

# ASIC/FPGA Portability:

```
module clocked (
  i clk: input clock, i rst: input reset,
) { /* ... */ }
```

# Veryl.toml determines EDA toolchain compatibility:

```
[build]
clock type = "posedge"
flatten_array_interface = true
emit cond type = true
implicit_parameter_types = ["string"]
expand_inside_operation = true
```

# **Academic Workflow Support: Testing Integration**

## Built-in testing framework integration

# **Multi-Simulator Support:**

```
# Works with multiple simulators
$ veryl test --sim verilator
$ veryl test --sim vcs
$ veryl test --sim vivado
```

# **Integrated Test Discovery:**

```
$ veryl test
[INF0] Compiling test (test_counter)
[INF0] Executing test (test_counter)
[INF0] Succeeded test (test_counter)
[INF0] Completed tests : 1 passed, 0 failed
```

# **Embedded SystemVerilog Tests:**

```
// In counter.veryl
#[test(test counter)]
embed (inline) syfff
  module counter tb:
    logic clk, rst, [7:0] count:
    counter dut(.*):
    initial begin
      rst = 1; #10; rst = 0;
      repeat(10) @(posedge clk):
      assert(count == 8'h0A):
    end
  endmodule
111
// Or include external file:
include(inline, "counter tb.sv"):
```

# **Academic Workflow Support: Testing Integration**

## Built-in testing framework integration

## **Multi-Simulator Support:**

```
# Works with multiple simulators
$ veryl test --sim verilator
$ veryl test --sim vcs
$ veryl test --sim vivado
```

### **Integrated Test Discovery:**

```
$ veryl test
[INFO] Compiling test (test_counter)
[INFO] Executing test (test_counter)
[INFO] Succeeded test (test_counter)
[INFO] Completed tests : 1 passed, 0 failed
```

#### **Embedded Cocotb Tests:**

```
// In counter.vervl
#[test(test counter. counter)]
embed (cocotb) py{{{
  import cocotb
  from cocotb.triggers import RisingEdge
  @cocotb.test()
  async def test_counter(dut):
      dut.rst.value = 1
      await RisingEdge(dut.clk)
      dut.rst.value = 0
      assert dut count value == 0
}}}
```

# **Academic Workflow Support: Reproducible Configuration**

# Verylup - Toolchain Version Manager:

```
# Install specific Veryl toolchain version
$ cargo install verylup
$ verylup install 0.12.0
$ verylup default 0.12.0
# Per-project version pinning
$ verylup override set 0.11.5
$ vervl --version
veryl 0.11.5 (pinned for this project)
# List available versions
$ verylup show
0.10.0
0.11.5
0.12.0 (default)
nightly
```

# **Academic Workflow Support: Reproducible Configuration**

## **Verylup - Toolchain Version Manager:**

```
# Install specific Veryl toolchain version
$ cargo install verylup
$ verylup install 0.12.0
$ verylup default 0.12.0
# Per-project version pinning
$ verylup override set 0.11.5
$ veryl --version
veryl 0.11.5 (pinned for this project)
# List available versions
$ vervlup show
0.10.0
0.11.5
0.12.0 (default)
nightly
```

# Veryl.toml - Project Config:

```
[project]
name = "research cpu"
version = "1.2.0"
description = "RISC-V core for ISCA 2025 paper"
[build]
clock_type = "posedge"
reset_type = "async_low"
[dependencies]
std = "1.0"
axi common = { version = "2.1", git = "..." }
```

# **Academic Workflow Support: Reproducible Configuration**

# **Verylup - Toolchain Version Manager:**

```
# Install specific Veryl toolchain version
$ cargo install verylup
$ verylup install 0.12.0
$ verylup default 0.12.0
# Per-project version pinning
$ verylup override set 0.11.5
$ veryl --version
veryl 0.11.5 (pinned for this project)
# List available versions
$ vervlup show
0.10.0
0.11.5
0.12.0 (default)
nightly
```

# **Veryl.toml** - **Project Config:**

```
[project]
name = "research_cpu"
version = "1.2.0"
description = "RISC-V core for ISCA 2025 paper"
[build]
clock_type = "posedge"
reset_type = "async_low"
[dependencies]
std = "1.0"
axi_common = { version = "2.1", git = "..." }
```

- ullet Veryl toolchain version pinned
- ✓ Project & dependency versions locked
- ✓ Build configuration documented
- ✓ Reproducible across labs
- ✓ No docker required

# **Academic Workflow Support: CI/CD Integration**

## GitHub Actions integration for automated testing and deployment

#### GitHub Actions Workflow:

```
# .qithub/workflows/veryl.yml
name: Veryl CI
on: [push, pull request]
iobs:
  test.
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - uses: vervl-lang/setup-vervl@v1
      - run: veryl fmt --check
      - run: veryl check
      - run: veryl test --sim verilator
      - run: vervl build
      - run: vervl publish --drv-run
```

#### **Automated Workflow:**

- ✓ Lint checking on every commit
- Test execution with multiple simulators
- ✓ Build verification across platforms
- V Package validation before publishing
- ✓ Multi-version testing for compatibility

#### Research Benefits:

- Catch errors before paper submission
- Ensure reproducibility for reviewers
- Automate artifact validation

# Advanced Language Features: Quality of Life Improvements

# Modports with Converse:

```
interface axi_if {
  var awvalid: logic; var awready: logic;
  var wdata: logic<32>;
  modport Manager {
    awready: input, ..output
  }
  modport Subordinate { ..converse(Manager) }
  modport Monitor {..input}
}
```

# Advanced Language Features: Quality of Life Improvements

## Modports with Converse:

```
interface axi_if {
    var awvalid: logic; var awready: logic;
    var wdata: logic<32>;
    modport Manager {
        awready: input, ..output
    }
    modport Subordinate { ..converse(Manager) } }
    modport Monitor { ..input}
}
```

#### **Generics:**

```
package PackageA::<T: u32> {
    const X: u32 = T;
    struct StructA::<Y: u32> {
        x: logic<X>,
        y: logic<Y>,
    }
}
```

Generics supported for: function, module, interface, package, struct, union

# Advanced Language Features: Quality of Life Improvements

#### Modports with Converse:

```
interface axi_if {
    var awvalid: logic; var awready: logic;
    var wdata: logic
modport Monitor {..input}

product Monitor {..input}

product
```

#### **Generics:**

```
package PackageA::<T: u32> {
   const X: u32 = T;
   struct StructA::<Y: u32> {
      x: logic<X>,
      y: logic<Y>,
   }
}
```

Generics supported for: function, module, interface, package, struct, union

# **Trait-like Prototypes:**

```
proto package Arithmetic {
   const T: type;
   fn add(a: T, b: T) -> T;
   fn sub(a: T, b: T) -> T;
}
// Implement for different types
package ArithmeticInt::<\mathref{N}: \ullet \ullet
```

Prototypes supported for: module, interface, and package

# **Current Veryl Adoption and Usage**

### Growing ecosystem with real-world deployments in industry and academia

# **Industry Adoption:**

- PEZY Computing HPC/Al accelerator
  - 50k lines of Veryl code
  - Mixed with 6M lines of SystemVerilog
  - Next-generation chip development

### Open Source Tools

- RgGen: CSR generator with Veryl support
- Marlin: Rust-based testbench framework

# **Academic Usage:**

- Luleå University of Technology (Sweden)
  - Digital design course
  - MIPS32 subset implementation
  - Veryl as advanced option

## Open Source Processors

- bluecore: Linux-bootable RISC-V (4k lines)
- very-holy-core: Holy Core Course in Veryl

#### The Future of Academic Hardware Research

Join us in building modern infrastructure for open-source architecture research

#### Where We're Going:

# How You Can Help Shape This Future:

- Modern Research Velocity
  - Real-time error detection and feedback
  - Seamless collaboration and reproducibility
  - Integrated testing and CI/CD workflows

#### Open Research Ecosystem

- Easy sharing of research components
- Veryl Standard Library (AXI, Asynch FIFO, etc.)
- Standardized documentation and diagrams
- Cross-lab compatibility and reuse

#### Academic-First Design

- Built for research constraints and workflows
- Gradual adoption without disruption
- Safety and debuggability as priorities

#### The Future of Academic Hardware Research

#### Join us in building modern infrastructure for open-source architecture research

#### Where We're Going:

## Modern Research Velocity

- · Real-time error detection and feedback
- Seamless collaboration and reproducibility
- Integrated testing and CI/CD workflows

#### Open Research Ecosystem

- Easy sharing of research components
- Veryl Standard Library (AXI, Asynch FIFO, etc.)
- Standardized documentation and diagrams
- Cross-lab compatibility and reuse

#### Academic-First Design

- Built for research constraints and workflows
- Gradual adoption without disruption
- Safety and debuggability as priorities

# How You Can Help Shape This Future:

- ✓ Try Veryl in Your Research
  - Start with one module in an existing project
  - Share your experience and pain points

# ■ ✓ Contribute to the Ecosystem

- Language features, standard library
- Documentation, tutorials, examples
- Tool integrations (EDA, simulators)

# ■ ✓ Build the Community

- Use in courses and research projects
- Publish artifacts and share experiences

# **Getting Started with Veryl**

# Ready to modernize your hardware research workflow?

#### **Quick Installation:**

```
# Install Veryl toolchain manager
$ cargo install verylup
```

```
# Install latest Veryl compiler
$ verylup install latest
```

```
# Create your first project
$ veryl new my_research_project
$ cd my_research_project
$ veryl build
```

# Resources & Community:

- Documentation: veryl-lang.org
- Source Code: github.com/veryl-lang
- Examples: Real-world processor implementations
- Community: Active development & support