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

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

?? ad7304.txt

?? 5個模數轉換器adc的vhdl源碼 5個模數轉換器adc的vhdl源碼
?? TXT
?? 第 1 頁 / 共 3 頁
字號:
-------------------------------------------------------------------------------
--  File Name: ad7304.vhd
-------------------------------------------------------------------------------
--  Copyright (C) 2005 Free Model Foundry; http://www.FreeModelFoundry.com
--
--  This program is free software; you can redistribute it and/or modify
--  it under the terms of the GNU General Public License version 2 as
--  published by the Free Software Foundation.
--
--  MODIFICATION HISTORY:
--
--  version: |     author:    |   mod date:   | changes made:
--    V1.0    V.Ljubisavljevic    05 Mar 28     Initial release
--
-------------------------------------------------------------------------------
-- IMPORTANT
-- This model must be compiled without VITAL compliance checking
-------------------------------------------------------------------------------
--  PART DESCRIPTION:
--
--  Library:     CONVERTER_VHDL
--  Technology:  CMOS
--  Part:        AD7304
--  Description: 3V/5V, Rail to Rail, Quad, 8-Bit DAC
-------------------------------------------------------------------------------
-- NOTE
-- Hardware Shutdown SHDN mode is not implemented
-- because it is voltage dependent.
-- It is adopted for Output voltage in shutdown mode to be 0 V because it is
-- pooled down to ground through resistor of 120 ohms resistance.
-------------------------------------------------------------------------------

LIBRARY IEEE;   USE IEEE.std_logic_1164.ALL;
                USE IEEE.VITAL_timing.ALL;
                USE IEEE.VITAL_primitives.ALL;

LIBRARY FMF;    USE FMF.gen_utils.ALL;
                USE FMF.conversions.ALL;

-------------------------------------------------------------------------------
-- ENTITY DECLARATION
-------------------------------------------------------------------------------
ENTITY ad7304 IS
    GENERIC (
        -- tipd delays: interconnect path delays
        tipd_CSNeg          :     VitalDelayType01 := VitalZeroDelay01;
        tipd_CLK            :     VitalDelayType01 := VitalZeroDelay01;
        tipd_SDI            :     VitalDelayType01 := VitalZeroDelay01;
        tipd_LDACNeg        :     VitalDelayType01 := VitalZeroDelay01;
        tipd_CLRNeg         :     VitalDelayType01 := VitalZeroDelay01;
        -- tsetup values: setup times
        tsetup_CSNeg_CLK    :     VitalDelayType   := UnitDelay;
        tsetup_SDI_CLK      :     VitalDelayType   := UnitDelay;
        tsetup_LDACNeg_CLK  :     VitalDelayType   := UnitDelay;
        -- thold values: hold times
        thold_CSNeg_CLK     :     VitalDelayType   := UnitDelay;
        thold_SDI_CLK       :     VitalDelayType   := UnitDelay;
        thold_LDACNeg_CLK   :     VitalDelayType   := UnitDelay;
        -- tpw values: pulse widths
        tpw_CLK_posedge     :     VitalDelayType   := UnitDelay;
        tpw_CLK_negedge     :     VitalDelayType   := UnitDelay;
        tpw_CLRNeg_negedge  :     VitalDelayType   := UnitDelay;
        tpw_LDACNeg_negedge :     VitalDelayType   := UnitDelay;
        -- analog generics: values of Vref inputs In Volts
        Vdd                 :     real;
        Vss                 :     real;
        -- generic control parameters
        InstancePath        :     STRING           := DefaultInstancePath;
        TimingChecksOn      :     BOOLEAN          := DefaultTimingChecks;
        MsgOn               :     BOOLEAN          := DefaultMsgOn;
        XOn                 :     BOOLEAN          := DefaultXon;
        -- For FMF SDF technology file usage
        TimingModel         :     STRING           := DefaultTimingModel
    );
    PORT (
        VrefA               : IN  real             := 0.0;
        VrefB               : IN  real             := 0.0;
        VrefC               : IN  real             := 0.0;
        VrefD               : IN  real             := 0.0;
        VOUTA               : OUT real             := 0.0;
        VOUTB               : OUT real             := 0.0;
        VOUTC               : OUT real             := 0.0;
        VOUTD               : OUT real             := 0.0;
        CLK                 : IN  std_ulogic       := 'U';
        CSNeg               : IN  std_ulogic       := 'U';
        SDI                 : IN  std_ulogic       := 'U';
        LDACNeg             : IN  std_ulogic       := 'U';
        CLRNeg              : IN  std_ulogic       := 'U'
    );

    ATTRIBUTE VITAL_LEVEL0 of ad7304 : ENTITY IS TRUE;
END ad7304;

-------------------------------------------------------------------------------
-- ARCHITECTURE DECLARATION
-------------------------------------------------------------------------------
ARCHITECTURE vhdl_behavioral of ad7304 IS
    ATTRIBUTE VITAL_LEVEL0 of vhdl_behavioral : ARCHITECTURE IS TRUE;

    CONSTANT partID             : STRING  := "ad7304";
    CONSTANT resolution         : INTEGER := 8;

    SUBTYPE dacval_type IS NATURAL RANGE 0 TO (2**resolution-1);
    SUBTYPE stdl8 IS STD_LOGIC_VECTOR (resolution-1 DOWNTO 0);

    SIGNAL CLK_ipd     : std_ulogic := 'U';
    SIGNAL CSNeg_ipd   : std_ulogic := 'U';
    SIGNAL SDI_ipd     : std_ulogic := 'U';
    SIGNAL LDACNeg_ipd : std_ulogic := 'U';
    SIGNAL CLRNeg_ipd  : std_ulogic := 'U';

    SHARED VARIABLE PowerDown  : BOOLEAN := true;  -- True if power down is on
    SHARED VARIABLE PowerDownA : BOOLEAN := false;
    SHARED VARIABLE PowerDownB : BOOLEAN := false;
    SHARED VARIABLE PowerDownC : BOOLEAN := false;
    SHARED VARIABLE PowerDownD : BOOLEAN := false;

BEGIN

    ---------------------------------------------------------------------------
    -- Wire Delays
    ---------------------------------------------------------------------------
    WireDelay : BLOCK
    BEGIN
        w_1 : VitalWireDelay (CLK_ipd, CLK, tipd_CLK);
        w_2 : VitalWireDelay (CSNeg_ipd, CSNeg, tipd_CSNeg);
        w_3 : VitalWireDelay (SDI_ipd, SDI, tipd_SDI);
        w_4 : VitalWireDelay (LDACNeg_ipd, LDACNeg, tipd_LDACNeg);
        w_5 : VitalWireDelay (CLRNeg_ipd, CLRNeg, tipd_CLRNeg);
    END BLOCK;

    Behavior : BLOCK
        PORT (
            CLK     : IN  std_ulogic;
            CSNeg   : IN  std_ulogic;
            SDI     : IN  std_ulogic;
            LDACNeg : IN  std_ulogic;
            CLRNeg  : IN  std_ulogic);
        PORT MAP (
            CLK     => CLK_ipd,
            CSNeg   => CSNeg_ipd,
            SDI     => SDI_ipd,
            LDACNeg => LDACNeg_ipd,
            CLRNeg  => CLRNeg_ipd);

        CONSTANT tsettle : time := 2 us;
        CONSTANT tsdr : time := 2 us;   -- recovery from shutdown
        CONSTANT tsdn : time := 15 us;  -- time to shut down

        -- State machine state type
        TYPE state_type IS (DEFAULT, SERIAL);

        -- State machine current state
        SIGNAL current_state : state_type;
        -- Registers
        SIGNAL inregA        : stdl8     := (OTHERS => '0');
        SIGNAL inregB        : stdl8     := (OTHERS => '0');
        SIGNAL inregC        : stdl8     := (OTHERS => '0');
        SIGNAL inregD        : stdl8     := (OTHERS => '0');
        SIGNAL decregA       : stdl8     := (OTHERS => '0');
        SIGNAL decregB       : stdl8     := (OTHERS => '0');
        SIGNAL decregC       : stdl8     := (OTHERS => '0');
        SIGNAL decregD       : stdl8     := (OTHERS => '0');
        SIGNAL shift_reg     : STD_LOGIC_VECTOR(11 DOWNTO 0)
                                         := (OTHERS => '0');
        -- alias
        ALIAS SAC            : STD_LOGIC IS shift_reg(11);
        ALIAS SDC            : STD_LOGIC IS shift_reg(10);
        ALIAS Address        : STD_LOGIC_VECTOR(1 DOWNTO 0) IS
            shift_reg(9 DOWNTO 8);
        ALIAS Data           : stdl8 IS shift_reg(7 DOWNTO 0);
        -- Internal signals
        SIGNAL VOUTA_zd      : real      := 0.0;
        SIGNAL VOUTB_zd      : real      := 0.0;
        SIGNAL VOUTC_zd      : real      := 0.0;
        SIGNAL VOUTD_zd      : real      := 0.0;
        SIGNAL VrefA_int     : real;    -- Internal VrefA voltage
        SIGNAL VrefB_int     : real;
        SIGNAL VrefC_int     : real;
        SIGNAL VrefD_int     : real;
        -- model signals
        SIGNAL update        : BOOLEAN   := false;
        SIGNAL update_out    : BOOLEAN   := true;
        SIGNAL update_outA   : BOOLEAN   := false;
        SIGNAL update_outB   : BOOLEAN   := false;
        SIGNAL update_outC   : BOOLEAN   := false;
        SIGNAL update_outD   : BOOLEAN   := false;
        -- signals for upadating output
        SIGNAL settleA       : STD_LOGIC := '0';
        SIGNAL settleB       : STD_LOGIC := '0';
        SIGNAL settleC       : STD_LOGIC := '0';
        SIGNAL settleD       : STD_LOGIC := '0';

        -- Increment values for output
        SHARED VARIABLE StepA       : real := 0.0;
        SHARED VARIABLE StepB       : real := 0.0;
        SHARED VARIABLE StepC       : real := 0.0;
        SHARED VARIABLE StepD       : real := 0.0;
        --End values on outputs
        SHARED VARIABLE EndValA     : real := 0.0;
        SHARED VARIABLE EndValB     : real := 0.0;
        SHARED VARIABLE EndValC     : real := 0.0;
        SHARED VARIABLE EndValD     : real := 0.0;
        -- Pull up signals
        SIGNAL          CLK_nwv     : X01;
        SIGNAL          CSNeg_nwv   : X01;
        SIGNAL          SDI_nwv     : X01;
        SIGNAL          LDACNeg_nwv : X01;
        SIGNAL          CLRNeg_nwv  : X01;

        -- purpose: Calculate output voltage from 8 bit input
        PROCEDURE DAConvert (
            in_reg  : IN  stdl8;
            vref_in : IN  real;
            out_v   : OUT real) IS
        BEGIN  -- PROCEDURE DAConvert
            out_v := vref_in * (real(to_nat(in_reg)) / real(2**resolution));
        END PROCEDURE DAConvert;

    BEGIN
        CLK_nwv <=  to_X01(CLK);
        CSNeg_nwv <= to_X01(CSNeg);
        SDI_nwv <= to_X01(SDI);
        LDACNeg_nwv <= to_X01(LDACNeg);
        CLRNeg_nwv <= to_X01(CLRNeg);
        ----------------------------------------------------------------------
        -- Behavior Process
        ----------------------------------------------------------------------
        -- purpose: Determine current state
        -- type   : combinational
        -- inputs : CSNeg, CLRNeg
        state_decode: PROCESS (CSNeg_nwv, CLRNeg_nwv)
        BEGIN  -- PROCESS state_decode
            IF CLRNeg_nwv='1' THEN
                IF falling_edge(CSNeg_nwv) THEN
                    current_state <= SERIAL;
                ELSE
                    current_state <= DEFAULT;
                END IF;
            ELSE
                current_state <= DEFAULT;
            END IF;
        END PROCESS state_decode;

        -- purpose: Control of referent voltages
        -- type   : combinational
        -- inputs : VrefA, VrefB, VrefC, VrefD
        Vref_contorl: PROCESS (VrefA, VrefB, VrefC, VrefD)
            VARIABLE MaxV : real := Vdd;
            VARIABLE MinV : real := Vss;
        BEGIN  -- PROCESS Vref_contorl
            IF NOT (VrefA <= MaxV AND VrefA >= MinV) THEN
                ASSERT false
                    REPORT LF & InstancePath & partID & ": simulation may be"&

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美大片拔萝卜| 国产精品卡一卡二卡三| 国产日产亚洲精品系列| 玉米视频成人免费看| 国产一区二区三区综合| 欧美私人免费视频| 国产亚洲一本大道中文在线| 午夜日韩在线观看| 白白色 亚洲乱淫| 久久久久久毛片| 天天综合日日夜夜精品| 色先锋久久av资源部| 久久影院午夜论| 日本欧美一区二区三区| 欧洲国产伦久久久久久久| 国产喷白浆一区二区三区| 毛片av中文字幕一区二区| 欧美日韩一区久久| 亚洲精品中文在线影院| 北条麻妃一区二区三区| 国产亚洲精品免费| 国产一区免费电影| 日韩片之四级片| 免费成人性网站| 欧美一区二区视频观看视频| 亚洲一区在线播放| 欧美亚洲国产一区二区三区va | 国产午夜精品在线观看| 日韩成人一区二区| 欧美久久一二三四区| 亚洲国产一区二区a毛片| 一本久久综合亚洲鲁鲁五月天 | 久久久午夜精品理论片中文字幕| 日韩成人一区二区三区在线观看| 欧美日韩国产中文| 天堂久久一区二区三区| 欧美午夜一区二区三区 | 日本高清不卡在线观看| 自拍偷自拍亚洲精品播放| 国产成人啪免费观看软件 | 国产精品网站在线| av不卡在线观看| 一区二区日韩av| 欧美日韩一区二区三区高清| 性欧美疯狂xxxxbbbb| 91精品国产综合久久久久久久久久 | 成人高清免费观看| 成人欧美一区二区三区视频网页| 97久久超碰国产精品电影| 一区二区成人在线| 欧美三级电影一区| 老色鬼精品视频在线观看播放| 欧美精品一区二区不卡| 成a人片国产精品| 亚洲男人的天堂在线aⅴ视频| 欧美中文字幕不卡| 美国av一区二区| 国产日韩欧美综合一区| 色香蕉久久蜜桃| 久久国产福利国产秒拍| 国产精品萝li| 欧美久久一区二区| 国产精品12区| 亚洲国产欧美在线| 久久影院视频免费| 在线观看www91| 激情六月婷婷久久| 亚洲美女免费在线| 精品久久久久久久久久久久久久久久久 | 亚洲成人动漫精品| 国产无一区二区| 欧美在线影院一区二区| 麻豆国产精品777777在线| 国产精品福利一区| 欧美一区二区三区四区五区| 丁香亚洲综合激情啪啪综合| 亚洲一区二区综合| 久久精品夜夜夜夜久久| 欧美在线综合视频| 成人性生交大片免费看在线播放| 亚洲国产综合人成综合网站| 久久人人爽人人爽| 欧美电影影音先锋| 色综合久久99| 高清免费成人av| 另类人妖一区二区av| 一区二区三区精品在线| 国产女同性恋一区二区| 日韩一区二区免费在线电影| 色婷婷久久综合| 国产丶欧美丶日本不卡视频| 日日夜夜精品视频天天综合网| 国产精品久久影院| 国产亚洲女人久久久久毛片| 91精品国产综合久久久久久| 欧美亚州韩日在线看免费版国语版| 久久狠狠亚洲综合| 视频一区二区中文字幕| 自拍偷拍国产精品| 欧美极品xxx| 国产亚洲1区2区3区| 欧美大黄免费观看| 日韩一级黄色大片| 在线不卡中文字幕播放| 欧美性受xxxx黑人xyx性爽| 9i在线看片成人免费| 成人午夜av电影| 成人午夜精品一区二区三区| 国产在线播放一区三区四| 久久99日本精品| 久久国产夜色精品鲁鲁99| 日本欧美一区二区三区| 男人的j进女人的j一区| 全部av―极品视觉盛宴亚洲| 丝瓜av网站精品一区二区| 婷婷开心激情综合| 日本亚洲欧美天堂免费| 日本系列欧美系列| 久久国产精品露脸对白| 国产一区二区在线免费观看| 经典三级一区二区| 国产一区二区三区四| 高清国产一区二区三区| 不卡影院免费观看| zzijzzij亚洲日本少妇熟睡| 不卡一区二区在线| 色综合天天综合给合国产| 日本电影欧美片| 欧美日本在线播放| 日韩色在线观看| 久久精品视频免费| 中文字幕日韩精品一区| 亚洲另类春色校园小说| 偷拍自拍另类欧美| 麻豆精品视频在线观看| 国产黄色成人av| 91在线精品一区二区三区| 欧美日韩一区不卡| 精品福利av导航| 亚洲色欲色欲www| 午夜成人免费电影| 国产a级毛片一区| 色婷婷精品大在线视频| 欧美一区在线视频| 国产拍欧美日韩视频二区| 亚洲主播在线观看| 极品销魂美女一区二区三区| av动漫一区二区| 欧美一级高清大全免费观看| 精品久久久久99| 亚洲黄色免费网站| 九一久久久久久| 在线观看日韩电影| 久久精品一区二区三区不卡牛牛| 亚洲精品国产第一综合99久久| 午夜在线成人av| 成人av网站在线观看免费| 国产精品伦一区| 亚洲一区在线观看免费观看电影高清| 美女在线一区二区| 成人高清视频在线| 精品免费日韩av| 夜夜亚洲天天久久| 国产一区二区按摩在线观看| 欧日韩精品视频| 国产欧美一二三区| 日产国产欧美视频一区精品 | 蜜桃av一区二区三区| 国产电影一区在线| 日韩一区二区视频| 亚洲免费观看在线视频| 国产精品亚洲午夜一区二区三区| 欧美日韩一区不卡| 亚洲人精品一区| 国产盗摄女厕一区二区三区| 欧美色综合网站| 国产精品久久久爽爽爽麻豆色哟哟| 日本不卡一二三| 欧美日韩你懂的| 亚洲激情网站免费观看| 成人午夜视频网站| 久久久久久久精| 狠狠色狠狠色综合日日91app| 欧美日韩国产首页在线观看| |精品福利一区二区三区| 国产精品18久久久久| 日韩精品专区在线影院重磅| 天天色 色综合| 欧美三级视频在线播放| 亚洲综合色噜噜狠狠| 91亚洲国产成人精品一区二三| 国产午夜精品一区二区三区嫩草| 久久精品国产久精国产| 日韩欧美一区二区久久婷婷| 日本亚洲欧美天堂免费| 在线不卡中文字幕| 欧美96一区二区免费视频| 日韩三级电影网址| 国产一区二区三区免费看| 久久综合国产精品|