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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 89_pack_2_0.vhd

?? 基于VHDL語言編程的100個例子,從簡單到復(fù)雜,由淺入深
?? 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;



?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费观看在线视频| 久久精品这里都是精品| 成人激情动漫在线观看| 九九九久久久精品| 麻豆国产精品777777在线| 婷婷综合另类小说色区| 亚洲一区二区三区自拍| 一区二区成人在线| 一区二区日韩av| 亚洲一区二区欧美日韩 | 日韩无一区二区| 欧美手机在线视频| 欧美日韩国产bt| 91精品国产日韩91久久久久久| 欧美在线不卡一区| 51精品秘密在线观看| 日韩精品专区在线| 国产亚洲欧美在线| 国产精品欧美一级免费| 亚洲美女视频一区| 视频一区二区三区中文字幕| 免费在线观看视频一区| 国产精品91一区二区| 成人av一区二区三区| 色婷婷久久一区二区三区麻豆| 在线免费精品视频| 欧美日韩一区在线观看| 精品国产电影一区二区| 国产精品视频yy9299一区| 一区二区三区在线视频免费| 丝袜美腿一区二区三区| 国产剧情在线观看一区二区| jlzzjlzz亚洲日本少妇| 欧美日韩精品一区二区三区| 精品国产乱码久久久久久夜甘婷婷 | 久久99九九99精品| 91在线一区二区| 337p亚洲精品色噜噜噜| 国产人伦精品一区二区| 亚洲午夜激情av| 国产一区二区精品久久91| 91视频你懂的| 久久综合色鬼综合色| 亚洲欧美日韩电影| 国产在线看一区| 在线一区二区三区做爰视频网站| 日韩免费看的电影| 一区二区三区在线不卡| 国产剧情一区二区三区| 欧美理论电影在线| 亚洲视频一区在线观看| 国产一区二区主播在线| 欧美午夜精品久久久| 国产色产综合产在线视频| 香蕉成人伊视频在线观看| 成人午夜电影网站| 日韩欧美一级精品久久| 亚洲一级在线观看| av资源网一区| 精品久久久久久综合日本欧美| 亚洲综合清纯丝袜自拍| 91在线无精精品入口| 中文字幕精品三区| 国产一区二区调教| 日韩欧美国产高清| 日韩福利电影在线| 欧美视频一区在线| 樱花草国产18久久久久| jiyouzz国产精品久久| 久久这里只精品最新地址| 五月综合激情网| 欧美日韩午夜精品| 一区二区国产视频| 日本高清不卡aⅴ免费网站| 国产欧美中文在线| 成人一区在线看| 国产精品麻豆久久久| 成人小视频在线| 亚洲欧美自拍偷拍色图| av男人天堂一区| 亚洲免费av在线| 在线一区二区三区| 亚洲国产精品久久人人爱| 在线观看免费亚洲| 视频一区在线视频| 欧美一级黄色录像| 精品一区二区三区在线观看国产| 日韩午夜在线观看| 久久不见久久见免费视频1| 日韩精品自拍偷拍| 国产制服丝袜一区| 中文字幕乱码亚洲精品一区| 国产一区视频网站| 国产精品免费免费| 在线亚洲欧美专区二区| 亚洲第一福利一区| 日韩欧美高清在线| 国产福利一区二区三区视频| 国产精品女同一区二区三区| 91亚洲精品久久久蜜桃| 亚洲一二三四区不卡| 91精品国产综合久久精品麻豆 | 波多野结衣欧美| 亚洲国产一区视频| 欧美草草影院在线视频| 成人午夜视频福利| 亚洲香肠在线观看| 精品国产一区二区亚洲人成毛片| 福利91精品一区二区三区| 亚洲精品一二三区| 欧美成人猛片aaaaaaa| 高清国产午夜精品久久久久久| 一区精品在线播放| 91精品国产综合久久久久| 成人动漫一区二区三区| 婷婷久久综合九色综合绿巨人| 久久嫩草精品久久久久| 欧美影院一区二区三区| 国产大片一区二区| 五月天亚洲婷婷| 中文字幕日韩欧美一区二区三区| 欧美肥大bbwbbw高潮| 成人av手机在线观看| 久久99精品久久久久| 一区二区高清视频在线观看| 国产视频在线观看一区二区三区| 欧美亚洲综合一区| 97久久超碰国产精品| 久久成人免费网| 亚洲综合av网| 国产精品亲子伦对白| 精品盗摄一区二区三区| 欧美午夜精品久久久久久超碰| 成人爱爱电影网址| 久久99深爱久久99精品| 亚洲国产精品嫩草影院| 综合久久一区二区三区| 国产三级欧美三级| 久久综合久久综合亚洲| 欧美一区二区三区在线观看 | 综合欧美亚洲日本| 国产日韩欧美综合在线| 日韩一级大片在线| 宅男在线国产精品| 欧美绝品在线观看成人午夜影视| 99亚偷拍自图区亚洲| 国产成人精品亚洲777人妖| 韩国精品一区二区| 激情综合网天天干| 久久91精品国产91久久小草| 日本欧美韩国一区三区| 日韩高清不卡一区| 日韩成人精品在线| 久久99久久99小草精品免视看| 日本在线观看不卡视频| 美女一区二区久久| 国产资源在线一区| 国产麻豆视频一区| 国产一区二区三区精品欧美日韩一区二区三区 | 国产黄色91视频| 国产一区二区在线观看免费| 韩国毛片一区二区三区| 国产剧情在线观看一区二区| 国产一区二区网址| 成人一区二区三区中文字幕| 懂色av一区二区三区免费看| 成人网页在线观看| 色哟哟在线观看一区二区三区| 色婷婷av一区二区三区软件| 在线观看91精品国产入口| 欧美丰满美乳xxx高潮www| 日韩免费在线观看| 日本一区二区三区在线观看| 国产精品三级视频| 亚洲美女在线一区| 日韩有码一区二区三区| 韩国女主播一区| 97久久久精品综合88久久| 欧美日韩国产欧美日美国产精品| 6080日韩午夜伦伦午夜伦| 亚洲精品在线电影| 亚洲欧美经典视频| 日韩av一区二| 国产成人午夜99999| 一本一道综合狠狠老| 正在播放一区二区| 国产精品免费视频观看| 五月天婷婷综合| 国产精品一线二线三线| 在线免费观看成人短视频| 日韩午夜在线影院| 亚洲精品一二三四区| 美国欧美日韩国产在线播放| 成人国产电影网| 91精品在线免费观看| 中文字幕不卡在线观看| 日本午夜一本久久久综合| av中文字幕在线不卡| 亚洲精品在线观看视频| 午夜亚洲福利老司机|