verilator/test_regress/t/t_vams_basic.v
2024-10-07 21:44:07 -04:00

56 lines
1.7 KiB
Systemverilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2011 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
`begin_keywords "VAMS-2.3"
module t (/*AUTOARG*/);
task check (integer line, real got, real expec);
real delta;
delta = got-expec;
if (delta > 0.001 || delta < -0.001) begin
$write("Line%0d: Got %g Exp %g\n", line, got, expec);
$stop;
end
endtask
wreal wr;
assign wr = 1.1;
sub sub (.*);
initial begin
check(`__LINE__, asin(0.5) , 0.523599);
check(`__LINE__, asinh(0.5) , 0.481212);
check(`__LINE__, atan(0.5) , 0.463648);
check(`__LINE__, atan2(0.5, 0.3) , 1.03038);
check(`__LINE__, atanh(0.5) , 0.549306);
check(`__LINE__, ceil(2.5) , 3.0);
check(`__LINE__, cos(0.5) , 0.877583);
check(`__LINE__, cosh(0.5) , 1.12763);
check(`__LINE__, exp(2.0) , 7.38906);
check(`__LINE__, floor(2.5) , 2.0);
check(`__LINE__, ln(2.0) , 0.693147);
check(`__LINE__, log(2.0) , 0.30103);
check(`__LINE__, pow(2.0,2.0) , 4.0);
check(`__LINE__, sin(0.5) , 0.479426);
check(`__LINE__, sinh(0.5) , 0.521095);
check(`__LINE__, sqrt(2.0) , 1.414);
check(`__LINE__, tan(0.5) , 0.546302);
check(`__LINE__, tanh(0.5) , 0.462117);
$write("*-* All Finished *-*\n");
$finish;
end
endmodule
module sub (
input wreal wr
);
initial begin
if (wr != 1.1) $stop;
end
endmodule