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

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

?? 88_pack_2_0.vhd

?? VHDL的實例加解說,對初學習者用處很大的!
?? 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一区二区三区免费野_久草精品视频
免费成人结看片| 欧美日韩免费一区二区三区 | 国产在线精品一区二区夜色| 国产69精品一区二区亚洲孕妇| 欧美日韩午夜在线视频| 欧美极品xxx| 免费亚洲电影在线| 97久久超碰国产精品| 久久久久久亚洲综合影院红桃| 亚洲国产毛片aaaaa无费看| 国产成人高清在线| 日韩美女一区二区三区四区| 亚洲黄网站在线观看| 成人一区二区三区视频在线观看| 欧美一级爆毛片| 亚洲国产日韩a在线播放| 91在线丨porny丨国产| 国产亚洲综合在线| 国产在线播放一区| 日韩午夜在线播放| 日韩成人一级大片| 69堂亚洲精品首页| 亚洲第一二三四区| 欧美日韩一区视频| 亚洲一区二区三区国产| 在线中文字幕一区二区| 亚洲激情综合网| 一本到三区不卡视频| 中文字幕中文在线不卡住| 国产成人精品一区二区三区网站观看| 日韩亚洲国产中文字幕欧美| 无吗不卡中文字幕| 欧美一区二区三区啪啪| 日韩和欧美的一区| 欧美一区欧美二区| 免费观看一级特黄欧美大片| 欧美精品丝袜中出| 日韩福利电影在线观看| 日韩限制级电影在线观看| 九色综合狠狠综合久久| 久久九九久久九九| 国产成人在线视频免费播放| 亚洲国产成人在线| 97se亚洲国产综合自在线不卡 | 色婷婷久久久久swag精品| 国产精品久久久久aaaa樱花| av不卡一区二区三区| 亚洲欧美乱综合| 欧美日免费三级在线| 日韩电影在线观看一区| 精品国产乱码久久久久久浪潮 | 精品中文av资源站在线观看| 久久综合久久综合九色| www.在线成人| 亚洲成人一区二区| 久久亚洲欧美国产精品乐播| 成人免费视频app| 亚洲激情中文1区| 日韩一区二区在线看| 国产iv一区二区三区| 夜夜嗨av一区二区三区网页| 欧美一区三区四区| 成人综合激情网| 亚洲国产精品一区二区www在线| 91精品国产综合久久婷婷香蕉 | 蜜桃视频在线一区| 国产精品午夜久久| 欧美日韩成人一区二区| 国产成人福利片| 亚洲最色的网站| 欧美精品一区二区三区蜜桃视频| 成人精品免费视频| 日本欧美大码aⅴ在线播放| 国产精品美女久久久久aⅴ| 欧美欧美午夜aⅴ在线观看| 国产精品一二三四区| 性感美女久久精品| 国产精品嫩草99a| 91精品欧美一区二区三区综合在| 国产91精品欧美| 亚洲大片免费看| 中文字幕在线不卡一区二区三区| 91精品国产综合久久福利| 99精品偷自拍| 国产综合久久久久影院| 五月婷婷久久丁香| 亚洲女与黑人做爰| 国产午夜亚洲精品羞羞网站| 4hu四虎永久在线影院成人| 92国产精品观看| 国产精品123区| 蜜臀av一区二区在线观看| 亚洲一区二区三区四区在线观看 | 在线综合视频播放| 色综合一个色综合| 国产sm精品调教视频网站| 蜜臀精品一区二区三区在线观看 | 91偷拍与自偷拍精品| 精品写真视频在线观看| 日韩精品成人一区二区三区| 夜夜嗨av一区二区三区网页| 最新国产精品久久精品| 国产目拍亚洲精品99久久精品| 日韩欧美国产一二三区| 69久久99精品久久久久婷婷| 欧美伊人久久久久久午夜久久久久| gogo大胆日本视频一区| 不卡视频一二三| 成人视屏免费看| 国产99一区视频免费| 韩国精品主播一区二区在线观看 | 免费精品视频在线| 日韩不卡手机在线v区| 午夜精品影院在线观看| 亚洲国产一区二区三区| 午夜伦理一区二区| 天天色综合成人网| 男男视频亚洲欧美| 美日韩一区二区三区| 日韩av电影免费观看高清完整版 | 欧美日韩视频不卡| 欧美日韩在线免费视频| 欧美色成人综合| 欧美撒尿777hd撒尿| 欧美放荡的少妇| 日韩一区二区麻豆国产| 日韩精品一区国产麻豆| 精品电影一区二区| 国产亚洲精品aa| 亚洲免费在线观看| 亚洲午夜精品网| 美国十次综合导航| 国产电影一区在线| 色综合久久久久| 91麻豆精品91久久久久久清纯| 欧美一区二区三区在线电影| 精品国产伦一区二区三区观看体验 | 另类欧美日韩国产在线| 国产一区二区三区精品视频| 成人国产免费视频| 欧美在线视频全部完| 日韩午夜中文字幕| 国产精品丝袜久久久久久app| 亚洲欧美成人一区二区三区| 日韩激情在线观看| 成人免费观看视频| 欧美日韩激情一区二区| 久久精品人人做人人综合| 亚洲免费av高清| 美女爽到高潮91| 99视频超级精品| 日韩一区二区免费电影| 中文字幕中文乱码欧美一区二区| 亚洲成人黄色影院| 国产白丝网站精品污在线入口| 色94色欧美sute亚洲线路一久| 欧美一级高清片| 最新热久久免费视频| 九九久久精品视频| 在线一区二区观看| 国产午夜一区二区三区| 五月婷婷另类国产| 92国产精品观看| www日韩大片| 婷婷中文字幕综合| 91麻豆国产在线观看| 精品对白一区国产伦| 天天射综合影视| 色天使色偷偷av一区二区| www国产成人| 日韩成人午夜电影| 在线视频中文字幕一区二区| 精品国产污污免费网站入口 | 蜜臀av一级做a爰片久久| av不卡在线观看| 久久免费美女视频| 日韩 欧美一区二区三区| 色综合色狠狠综合色| 久久久久成人黄色影片| 六月丁香婷婷色狠狠久久| 欧美视频一区二区在线观看| 国产精品福利一区| 国产精品99久久久久久久vr | 欧美群妇大交群中文字幕| 亚洲天堂精品视频| 成人18视频在线播放| 久久久久成人黄色影片| 韩国中文字幕2020精品| 91精品国产91久久久久久最新毛片| 亚洲一区二区三区精品在线| 日本电影欧美片| 亚洲精品国产品国语在线app| 成人黄色一级视频| 中文在线一区二区| 国产成人av电影在线播放| 久久人人超碰精品| 国产乱一区二区| 国产日韩综合av| 高清不卡在线观看av| 久久精品免费在线观看|