quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../images/main/bulllet_4dots_orange.gif Reduction Operators

Like in Verilog and SystemVerilog, VERA reduction operators are unary, they perform a bit-wise operation on signle operand to produce a single bit result.

   

space.gif

Following reduction Operators are supported in VERA

   

space.gif

Operator

Description

&

and

~&

nand

|

or

~|

nor

^

xor

^~ or ~^

xnor

   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Example : Reduction Operators
   

space.gif


  1 program reduction {
  2   // Bit Wise AND reduction
  3   printf (" &  4'b1001 = %b\n", (&  4'b1001));
  4   printf (" &  4'bx111 = %b\n", (&  4'bx111));
  5   printf (" &  4'bz111 = %b\n", (&  4'bz111));
  6   // Bit Wise NAND reductio\n"
  7   printf (" ~& 4'b1001 = %b\n", (~& 4'b1001));
  8   printf (" ~& 4'bx001 = %b\n", (~& 4'bx001));
  9   printf (" ~& 4'bz001 = %b\n", (~& 4'bz001));
 10   // Bit Wise OR reduction
 11   printf (" |  4'b1001 = %b\n", (|  4'b1001));
 12   printf (" |  4'bx000 = %b\n", (|  4'bx000));
 13   printf (" |  4'bz000 = %b\n", (|  4'bz000));
 14   // Bit Wise OR reduction
 15   printf (" ~| 4'b1001 = %b\n", (~| 4'b1001));
 16   printf (" ~| 4'bx001 = %b\n", (~| 4'bx001));
 17   printf (" ~| 4'bz001 = %b\n", (~| 4'bz001));
 18   // Bit Wise XOR reduction\n"
 19   printf (" ^  4'b1001 = %b\n", (^  4'b1001));
 20   printf (" ^  4'bx001 = %b\n", (^  4'bx001));
 21   printf (" ^  4'bz001 = %b\n", (^  4'bz001));
 22   // Bit Wise XNOR
 23   printf (" ~^ 4'b1001 = %b\n", (~^ 4'b1001));
 24   printf (" ~^ 4'bx001 = %b\n", (~^ 4'bx001));
 25   printf (" ~^ 4'bz001 = %b\n", (~^ 4'bz001));
 26 }
You could download file reduction.vr here
   

space.gif

  ../images/main/bullet_star_pink.gif Simulation : Reduction Operators
   

space.gif

  &  4'b1001 = 0
  &  4'bx111 = x
  &  4'bz111 = x
  ~& 4'b1001 = 1
  ~& 4'bx001 = 1
  ~& 4'bz001 = 1
  |  4'b1001 = 1
  |  4'bx000 = x
  |  4'bz000 = x
  ~| 4'b1001 = 0
  ~| 4'bx001 = 0
  ~| 4'bz001 = 0
  ^  4'b1001 = 0
  ^  4'bx001 = x
  ^  4'bz001 = x
  ~^ 4'b1001 = 1
  ~^ 4'bx001 = x
  ~^ 4'bz001 = x
   

space.gif

   

space.gif

   

space.gif

   

space.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

  

Copyright © 1998-2025

Deepak Kumar Tala - All rights reserved

Do you have any Comment? mail me at:deepak@asic-world.com