亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 89_pack_2_0.vhd

?? 該源碼為用VHDL(硬件描述語言)編寫的100個實例的源代碼
?? VHD
?? 第 1 頁 / 共 2 頁
字號:
      for N in v1'low to v1'high loop
        if (one_occured = '1') then

         if v1(N) = '0' then
            temp(N) := '1';
         else
            temp(N) := '0';
         end if;

        else
          one_occured := v1(N);
          temp(N) := v1(N);
        end if;

      end loop;        
     
      return temp;
end twos_comp;

--********************************************************************
function "-" (x1, x2: BIT_VECTOR) return BIT_VECTOR is
--********************************************************************

   variable v1 : BIT_VECTOR(x1'high - x1'low downto 0);
   variable v2 : BIT_VECTOR(x2'high - x2'low downto 0);
   variable CARRY: BIT := '0';
   variable S: BIT_VECTOR(1 to 3);
   variable NUM: INTEGER range 0 to 3 := 0;
   variable TEMP,DIF: BIT_VECTOR(v1'range);
   variable I,K: INTEGER;

   begin
      v1 := x1;
      v2 := x2;
      assert v1'length = v2'length
      report "BIT_VECTOR -: operands of unequal lengths"
      severity FAILURE;

      TEMP := twos_comp(v2);
    
      for I in v1'low to v1'high loop
         S:= v1(I) & TEMP(I) & CARRY;
         NUM := 0;

         for K in 1 to 3 loop
            if S(K) = '1' then
               NUM := NUM + 1;
            end if;
         end loop;
   
         case NUM is
            when 0 => DIF(I) := '0'; CARRY := '0';
            when 1 => DIF(I) := '1'; CARRY := '0';
            when 2 => DIF(I) := '0'; CARRY := '1';
            when 3 => DIF(I) := '1'; CARRY := '1';
         end case;
      end loop;

   return DIF;
end "-";

--********************************************************************
function DEC (v2: BIT_VECTOR) return BIT_VECTOR is
--********************************************************************

   variable v1 : BIT_VECTOR(v2'high downto v2'low);
   variable temp : BIT_VECTOR(v1'range);

   begin
      v1 := v2;
      for I in temp'range loop
         temp(I) := '0';
      end loop;
  
      temp(temp'low):= '1';
      temp := v1 - temp;
      return temp;
end DEC; 

--********************************************************************
function "+"(x1, x2 :BIT_VECTOR) return BIT_VECTOR is
--********************************************************************

   variable v1 : BIT_VECTOR(x1'high - x1'low downto 0);
   variable v2 : BIT_VECTOR(x2'high - x2'low downto 0);
   variable CARRY: BIT := '0';
   variable S: BIT_VECTOR(1 to 3);
   variable NUM: INTEGER range 0 to 3 := 0;
   variable SUM: BIT_VECTOR(v1'range);
   variable I,K: INTEGER;

   begin
      v1 := x1;
      v2 := x2;

      assert v1'length = v2'length
      report "BIT_VECTOR +: operands of unequal lengths"
      severity FAILURE;

      for I in v1'low to v1'high loop
         S:= v1(I) & v2(I) & CARRY;
         NUM := 0;
  
         for K in 1 to 3 loop
            if S(K) = '1' then
               NUM := NUM + 1;
            end if;
         end loop;

         case NUM is
            when 0 => SUM(I) := '0'; CARRY := '0';
            when 1 => SUM(I) := '1'; CARRY := '0';
            when 2 => SUM(I) := '0'; CARRY := '1';
            when 3 => SUM(I) := '1'; CARRY := '1';
         end case;
      end loop;
 
      return SUM;
end "+";

--********************************************************************
function inc (v2: BIT_VECTOR) return BIT_VECTOR is
--********************************************************************
 
   variable v1 : BIT_VECTOR(v2'high downto v2'low);
   variable CARRY: BIT := '1';
   variable S: BIT_VECTOR(1 to 2);
   variable NUM: INTEGER range 0 to 2 := 0;
   variable SUM: BIT_VECTOR(v1'range);
   variable I,K: INTEGER;
 
   begin
      v1 := v2;
      for I in v1'low to v1'high loop
 
         S:= v1(I) & CARRY;
         NUM := 0;
         for K in 1 to 2 loop
            if S(K) = '1' then
               NUM := NUM + 1;
            end if;
         end loop;
       
         case NUM is
            when 0 => SUM(I) := '0'; CARRY := '0';
            when 1 => SUM(I) := '1'; CARRY := '0';
            when 2 => SUM(I) := '0'; CARRY := '1';
         end case;
      end loop;
 
      return SUM;
end inc;

--********************************************************************
function ODD_PARITY ( v1 :  BIT_VECTOR ) return BIT is
--********************************************************************

   begin
      if ((SUM(v1) mod 2) = 1) then
         return '0';
      else
         return '1';
      end if;
  end ODD_PARITY;

--********************************************************************
  function EVEN_PARITY ( v1 :  BIT_VECTOR ) return BIT is
--********************************************************************

   begin
      if ((SUM(v1) mod 2) = 1) then
         return '1';
      else
         return '0';
      end if;
  end EVEN_PARITY;

--********************************************************************
function REVERSE(v2:BIT_VECTOR) return BIT_VECTOR is
--********************************************************************

   variable v1 : BIT_VECTOR(v2'high downto v2'low);
   variable temp : BIT_VECTOR(v1'range);

   begin
      v1 := v2;
      for I in v1'high downto v1'low loop
         temp(I) := v1(v1'high - I + v1'low);
      end loop;

      return temp;
end REVERSE;

--********************************************************************
function SUM(v2 : BIT_VECTOR) return integer is
--********************************************************************

   variable v1 : BIT_VECTOR(v2'high downto v2'low);
   variable count : integer := 0;

   begin
      v1 := v2;
      for I in v1'high downto v1'low loop
          if (v1(I) = '1') then 
              count := count + 1; 
          end if;
      end loop;

      return count;
end SUM;


--********************************************************************
function BIT_SLICE (v2: BIT_VECTOR; high_val, low_val:integer ) 
                   return BIT_VECTOR is
--********************************************************************

   -- for use with Vantage Analyst version 1.203 

   variable v1 : BIT_VECTOR(v2'high downto v2'low);
   variable temp : BIT_VECTOR( (high_val - low_val) downto 0);

   begin
      v1 := v2;
      for I in temp'range loop
         temp(i) := v1(low_val + i);
      end loop;

      return temp;
end BIT_SLICE;

--********************************************************************
function ASSIGN_TO_SLICE (v1: BIT_VECTOR;
                          high_val, low_val:integer; 
                          x2: BIT_VECTOR ) return BIT_VECTOR is
--********************************************************************

   -- for use with Vantage Analyst version 1.203 

   variable v2 : BIT_VECTOR(x2'high downto x2'low);
   variable temp : BIT_VECTOR(v1'range);

   begin
      v2 := x2;
      assert (high_val  - low_val + 1) = v2'length
      report "ASSIGN_SLICE: operands of unequal lengths"
      severity FAILURE;

      temp := v1;
      for I in  high_val downto low_val loop
         temp(I) := v2( v2'low + I - low_val);
      end loop;
   
      return temp;
end ASSIGN_TO_SLICE;

--********************************************************************
function "*" (x1, x2: BIT_VECTOR) return BIT_VECTOR is
--********************************************************************

variable A,B,M, M_OUT  : BIT_VECTOR (x1'high downto x1'low);
variable temp  : BIT_VECTOR ((x1'high*2)+1 downto x1'low);
variable x1_sign, x2_sign, M_sign : BIT;
variable COUNT : INTEGER;

begin
      x1_sign := x1(x1'high);
      x2_sign := x2(x2'high);
     
      if (x1_sign = '1') then
        A := twos_comp(x1);
      else
        A := x1;
      end if;

      if (x2_sign = '1') then
        B := twos_comp(x2);
      else
        B := x2;
      end if;

      M_sign := '0';
      if (x1_sign = '0') and (x2_sign = '1') then
        M_sign := '1';
      end if;

      if (x1_sign = '1') and (x2_sign = '0') then
        M_sign := '1';
      end if;


      COUNT := 0;
      while (COUNT < M'high) loop
        M(COUNT) := '0';
        COUNT := COUNT + 1;
      end loop;

      COUNT := 0;
      while (COUNT < 16) loop
         if (A(0) = '1') then
	    M := M + B;
	 end if;
	 A := SHR(A,M(0));
	 M := SHR(M,'0');
	 COUNT := COUNT + 1;
      end loop;

      if (M_sign = '1') then
        temp := twos_comp(M&A);
      else
        temp := M&A;
      end if;

      temp := SHRS(temp,10);
      M_OUT := temp(temp'high/2 downto temp'low);
      return M_OUT;

end "*";

end  BIT_FUNCTIONS;



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合色综合色综合色综合色综合| 免费成人在线视频观看| 成人精品一区二区三区中文字幕| 久久精品一区二区| 成人免费视频视频| 亚洲欧美经典视频| 欧美色倩网站大全免费| 天天综合网 天天综合色| 日韩欧美中文字幕精品| 国产麻豆精品一区二区| 国产精品美女久久久久久2018| 色综合视频在线观看| 爽好多水快深点欧美视频| 日韩精品资源二区在线| 东方aⅴ免费观看久久av| 一区二区三区四区不卡在线 | 久久女同性恋中文字幕| 粉嫩高潮美女一区二区三区| 一级特黄大欧美久久久| 制服丝袜中文字幕一区| 国产美女在线观看一区| 亚洲欧美日韩国产另类专区| 日韩一级黄色大片| 成人午夜视频免费看| 亚洲高清视频的网址| 精品国产一区二区三区久久影院| 北条麻妃一区二区三区| 五月婷婷激情综合| 国产日韩欧美亚洲| 欧美偷拍一区二区| 高清日韩电视剧大全免费| 亚洲伊人伊色伊影伊综合网| 精品99999| 欧美写真视频网站| 懂色av一区二区三区蜜臀| 天堂av在线一区| 中文字幕一区二区三区四区不卡| 日韩欧美在线影院| 色婷婷国产精品久久包臀| 国产综合色产在线精品| 亚洲777理论| 最新欧美精品一区二区三区| 欧美大片一区二区| 在线观看一区二区视频| 成人午夜视频在线观看| 另类小说一区二区三区| 亚洲国产色一区| 中文字幕在线不卡视频| 久久噜噜亚洲综合| 日韩一区二区精品在线观看| 色天使色偷偷av一区二区| 国产成人综合亚洲网站| 蜜桃91丨九色丨蝌蚪91桃色| 亚洲综合在线第一页| 中文字幕中文字幕一区| 久久久久亚洲综合| 日韩欧美国产一二三区| 91精品国产综合久久蜜臀| 在线一区二区三区四区| 99国产精品久久久久久久久久| 韩国精品主播一区二区在线观看 | 在线看不卡av| 99久久精品国产麻豆演员表| 国产成人免费视频一区| 国产一区二区0| 老司机精品视频线观看86| 日韩福利电影在线| 亚洲国产精品一区二区www| 怡红院av一区二区三区| 亚洲精品乱码久久久久久久久| 国产精品久久久久一区| 中文字幕精品一区二区精品绿巨人| 精品国产一区二区三区久久影院| 日韩三级在线免费观看| 欧美一区二区三区日韩视频| 欧美高清www午色夜在线视频| 欧美日韩在线三级| 欧美日韩一区久久| 67194成人在线观看| 91.xcao| 91精品久久久久久久91蜜桃| 欧美一级理论片| 日韩欧美国产三级| 久久精子c满五个校花| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 欧美系列日韩一区| 欧美日韩国产高清一区| 欧美一区二区三区影视| 欧美一区二区视频在线观看2022 | 国产精品影视在线| 成人亚洲一区二区一| k8久久久一区二区三区 | 国产日本欧美一区二区| 欧美国产精品中文字幕| 亚洲精品高清视频在线观看| 亚洲成人资源在线| 久久精品国产亚洲aⅴ| 国产精品白丝jk黑袜喷水| 91在线视频网址| 欧洲一区二区三区在线| 日韩一区二区三区精品视频| 久久人人97超碰com| 亚洲视频一区二区在线| 亚洲第一福利视频在线| 久久国产视频网| 99riav一区二区三区| 欧美精选午夜久久久乱码6080| 精品捆绑美女sm三区| 国产精品二区一区二区aⅴ污介绍| 一区二区三区在线视频观看| 日本不卡123| 成人做爰69片免费看网站| 欧美伊人久久久久久久久影院| 日韩欧美一二三四区| 国产精品日韩精品欧美在线| 婷婷成人激情在线网| 国产不卡视频一区| 在线观看免费亚洲| 精品国产精品网麻豆系列| 亚洲欧美另类在线| 国内精品久久久久影院薰衣草| 91麻豆国产精品久久| 欧美不卡在线视频| 亚洲男女一区二区三区| 久久国产精品99精品国产| 色呦呦日韩精品| 久久综合色之久久综合| 亚洲伊人伊色伊影伊综合网| 国产成人夜色高潮福利影视| 欧美久久婷婷综合色| 亚洲男同性视频| 麻豆精品在线观看| 一本色道久久综合亚洲aⅴ蜜桃| 91精品国产aⅴ一区二区| 亚洲色图一区二区| 国产在线观看一区二区| 91精品国产综合久久福利| 亚洲六月丁香色婷婷综合久久| 另类的小说在线视频另类成人小视频在线| 国产不卡在线视频| 日韩视频免费直播| 亚洲国产精品一区二区尤物区| 菠萝蜜视频在线观看一区| 精品日韩一区二区三区免费视频| 一区二区三区精密机械公司| 国产69精品久久久久777| 精品成人一区二区三区| 亚洲成人av在线电影| 成人avav在线| 国产亚洲精品aa| 久久精品国产一区二区| 91精品国产麻豆| 亚洲一级二级在线| 在线观看视频一区| 亚洲精品亚洲人成人网| fc2成人免费人成在线观看播放| 精品久久免费看| 激情综合网激情| 精品盗摄一区二区三区| 裸体健美xxxx欧美裸体表演| 欧美丰满高潮xxxx喷水动漫| 亚洲永久免费av| 色综合久久天天| 亚洲伦理在线免费看| 色国产精品一区在线观看| 亚洲欧美日韩国产综合在线| 色婷婷亚洲一区二区三区| 亚洲欧洲综合另类| 色菇凉天天综合网| 亚洲欧美另类久久久精品| 色综合久久九月婷婷色综合| 亚洲精品国产精华液| 欧美视频三区在线播放| 三级一区在线视频先锋 | 国产传媒日韩欧美成人| 国产偷v国产偷v亚洲高清| 懂色av一区二区三区免费观看| 亚洲免费av观看| 欧洲视频一区二区| 日本不卡免费在线视频| 精品久久免费看| 国产成人福利片| 国产精品国产三级国产普通话99 | 972aa.com艺术欧美| 伊人性伊人情综合网| 欧美群妇大交群中文字幕| 日韩av一区二区三区四区| 精品福利一区二区三区| 国产成人精品一区二 | 一级做a爱片久久| 欧美一区二区三区婷婷月色| 国内欧美视频一区二区| ...中文天堂在线一区| 欧美色综合网站| 激情综合亚洲精品| 亚洲图片另类小说| 欧美一级黄色录像| 成人毛片在线观看| 五月天中文字幕一区二区| 久久久国产精品麻豆|