Ich habe die folgende Funktion:SystemVerilog unterzeichnet funktioniert nicht richtig
function tx_upconv_out_transaction predict(tx_upconv_in_transaction in_trx);
tx_upconv_out_transaction predicted = tx_upconv_out_transaction::type_id::create("predicted");
//-------golden model-----
// predicted.y = (in_trx.xi * in_trx.cos - in_trx.xq * in_trx.sin)/ (2 ** 17);
$display(" xi = %d, cos = %d xq = %d sin = %d", $signed(in_trx.xi),$signed(in_trx.cos),$signed(in_trx.xq),$signed(in_trx.sin));
predicted.y = ($signed(in_trx.xi) * $signed(in_trx.cos) - $signed(in_trx.xq) * $signed(in_trx.sin))/ (131072);
return predicted;
endfunction: predict
Wo: Das Feld in in_trx sind definiert durch:
bit [15:0] xi;
bit [15:0] xq;
bit [15:0] sin;
bit [15:0] cos;
Für die Eingabe:
xi, qq = fffa (hex)
sin = 0
cos = 7ffe (hex)
Der Ausgang (Anzeige) ist:
xi = -6, cos = 32766 xq = -6 sin = 0
wo es sein sollte:
xi = -6, cos = -2 xq = -6 sin = 0
aber was das $ (signiert) nicht richtig funktioniert? – sara8d
Der vorzeichenbehaftete Dezimalwert von 16'h7ffe ist 32677, nicht -2. So funktioniert es richtig. –