```
10 when(in) {
11 out := 1.U
12 } .otherwise {
13 out := 2.U
14 }
```

compiling to Verilog loses information **assign** out = in ? 2'h1 : 2'h2;



```
when en:
                                                    Firrtl
cover(clk, gt(data, 100), 1): data gt 100
always @(posedge clock)
                                                    Verilog
  if (en) cover(data > 8'h64);

▼ Simulation w/ Verilator

# SystemC::Coverage-3
C 'fExample.svl13n7pagev user/ExampleocoverP1hTOP.Example' 2
                           Parse + Translate
"Example.data gt 100": 2
```

|                   | Line                | Toggle              | FSM         | Ready/Valid | Mux Toggle  | Condition |
|-------------------|---------------------|---------------------|-------------|-------------|-------------|-----------|
| Verilator         | <b>V</b> / <b>V</b> | <b>V</b> / <b>V</b> | ✓/X         | <b>✓</b> /X | <b>/</b> /X | X         |
| Treadle           | <b>✓/</b> X         | <b>✓</b> /x         | <b>✓</b> /X | <b>✓/</b> X | <b>✓</b> /X | Х         |
| Firesim           | <b>✓/</b> X         | <b>✓</b> /X         | <b>✓</b> /x | <b>✓/</b> X | <b>✓/</b> X | X         |
| Yosys<br>(Formal) | <b>✓</b> /X         | <b>✓</b> /x         | <b>✓/</b> X | <b>✓</b> /x | <b>✓</b> /X | X         |
| ESSENT            | <b>✓</b> /X         | <b>✓/</b> X         | <b>✓</b> /X | <b>✓</b> /x | <b>✓/</b> X | X         |