File: large_bitvector.sail

package info (click to toggle)
sail-ocaml 0.19.1%2Bdfsg5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 18,008 kB
  • sloc: ml: 75,941; ansic: 8,848; python: 1,342; exp: 560; sh: 474; makefile: 218; cpp: 36
file content (35 lines) | stat: -rw-r--r-- 919 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
default Order dec

$include <arith.sail>
$include <vector_dec.sail>

$option --sv-int-size 256

val zeros = pure {
  lean: "BitVec.zero",
  _: "zeros" }: forall 'n, 'n >= 0. int('n) -> bits('n)


val main : unit -> unit

function main() = {
  let x = [0x1FFFF0000FFFF0000 with 15 .. 0 = 0xFFFF];
  print_bits("x = ", x);
  print_int("length(x) = ", length(x));
  let y = replicate_bits(x, 3);
  print_bits("y = ", y);
  print_int("length(y) = ", length(y));
  let z = [y with 63 .. (63 - 15) = 0xCAFE];
  print_bits("z = ", z);
  print_int("length(z) = ", length(z));
  q = slice(z, 0, 64 * 3);
  print_bits("q = ", q);
  w = signed(q);
  print_int("w = ", w);
  print_int("length(q) = ", length(q));
  print_bits("", [0xFFFF with 14 .. 0 = zeros(15)]);
  print_bits("0b1 @ zeros(64 * 3 - 1) = ", 0b1 @ zeros(64 * 3 - 1));
  q[64 * 3 - 2 .. 0] = zeros(64 * 3 - 1);
  print_bits("q                       = ", q);
  ()
}