read_verilog -sv << EOF
package p;
typedef struct packed {
  logic a;
  logic b;
} struct_t;

typedef struct packed {
  struct_t g;
  logic [2:0] h;
} nested_struct_t;

typedef union packed {
  logic [4:0] x;
} nested_union_t;

parameter struct_t c = {1'b1, 1'b0};
parameter nested_struct_t x = {{1'b1, 1'b0}, 1'b1, 1'b1, 1'b1};
endpackage

module dut ();
parameter p::struct_t d = p::c;
parameter p::nested_struct_t i = p::x;

parameter p::nested_union_t u = {5'b11001};

localparam e = d.a;
localparam f = d.b;

localparam j = i.g.a;
localparam k = i.g.b;
localparam l = i.h;
localparam m = i.g;

localparam o = u.x;

always_comb begin
  assert(d == 2'b10);
  assert(e == 1'b1);
  assert(f == 1'b0);
  assert(j == 1'b1);
  assert(k == 1'b0);
  assert(l == 3'b111);
  assert(m == 2'b10);
  assert(u == 5'b11001);
end
endmodule
EOF
hierarchy; proc; opt
async2sync
sat -verify -seq 1 -tempinduct -prove-asserts -show-all