亚洲欧美第一页_禁久久精品乱码_粉嫩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网站大全| 一区二区三区在线视频播放| 亚洲一卡二卡三卡四卡| 91豆麻精品91久久久久久| 亚洲欧洲制服丝袜| 在线观看亚洲a| 国产在线不卡一区| 国产精品理论片在线观看| 欧美这里有精品| 欧美午夜精品久久久久久超碰 | 在线看国产日韩| 91麻豆6部合集magnet| 视频在线观看国产精品| 国产欧美一区二区精品秋霞影院| 色乱码一区二区三区88| 一本久久a久久精品亚洲| 毛片不卡一区二区| 国产精品久久一级| 一区二区三区电影在线播| 亚洲成人免费看| 国产精品麻豆视频| 26uuu成人网一区二区三区| 91美女在线看| 91精品久久久久久久91蜜桃| 成人免费的视频| 另类综合日韩欧美亚洲| 亚洲成人综合网站| 国产揄拍国内精品对白| 色噜噜狠狠成人中文综合| 欧美日韩高清在线| 欧美久久久久久蜜桃| 日本久久一区二区| 日韩免费性生活视频播放| 99re这里只有精品6| 成人午夜在线视频| 欧美日韩美少妇| 久久久美女艺术照精彩视频福利播放| 7777精品伊人久久久大香线蕉超级流畅 | 欧美日高清视频| 国产欧美日韩视频在线观看| 五月婷婷激情综合| 亚洲午夜一二三区视频| 亚洲黄色片在线观看| 日韩美女视频19| 亚洲日本中文字幕区| 另类中文字幕网| 欧美视频一二三区| 国产午夜精品理论片a级大结局 | 93久久精品日日躁夜夜躁欧美| 欧美日韩免费电影| 1区2区3区国产精品| 中文字幕永久在线不卡| 美女视频黄久久| 欧美在线免费观看视频| 国产精品久久久爽爽爽麻豆色哟哟 | 久久er99精品| 欧洲亚洲精品在线| 亚洲欧洲一区二区在线播放| 国产剧情在线观看一区二区| 国产精品香蕉一区二区三区| 欧美高清视频www夜色资源网| 国产精品激情偷乱一区二区∴| 久久99久久99| 成人av影院在线| 国产片一区二区| 久久91精品国产91久久小草| 91精品国产综合久久婷婷香蕉| 亚洲精品你懂的| 91麻豆视频网站| 一个色综合av| 欧日韩精品视频| 亚洲网友自拍偷拍| 欧美一a一片一级一片| 一区二区三区四区中文字幕| 91麻豆蜜桃一区二区三区| 国产精品美女久久久久久久久 | 青青国产91久久久久久 | 中文字幕的久久| 亚洲福利视频一区| 欧美色老头old∨ideo| 91精品国产综合久久精品| 56国语精品自产拍在线观看| 五月天视频一区| 91精品在线麻豆| 国内精品免费**视频| 欧美日韩亚洲另类| 日韩电影在线观看一区| 99久精品国产| 亚洲一区二区三区国产| 欧美精品自拍偷拍| 精品亚洲porn| 欧美国产视频在线| 成人美女在线视频| 国产欧美一区在线| 色婷婷狠狠综合| 日韩成人午夜电影| 国产人成一区二区三区影院| 91首页免费视频| 日韩影院免费视频| 亚洲精品一区二区三区福利| 亚洲国产日韩一区二区| 制服.丝袜.亚洲.中文.综合| 美女视频一区二区| 1区2区3区欧美| 欧美一级欧美一级在线播放| 国产精品资源在线观看| 一区二区三区四区av| 日韩欧美成人一区二区| 成人av网站在线| 麻豆中文一区二区| 日韩一区日韩二区| 日韩视频国产视频| 麻豆国产精品777777在线| 国产视频一区二区在线| 欧美日韩国产一区| 波多野结衣在线aⅴ中文字幕不卡| 日韩美女在线视频 | 亚洲第一av色| 国产精品美日韩| 欧美变态tickle挠乳网站| 亚洲成人精品影院| 久久久久国产精品麻豆ai换脸 | 国产欧美日韩卡一| 欧美疯狂性受xxxxx喷水图片| 国产成a人亚洲| 国产精品美女久久久久高潮| 欧美一区二区三区影视| 一本一本大道香蕉久在线精品| 韩国v欧美v亚洲v日本v| 亚洲成人av中文| 亚洲视频资源在线| 国产午夜精品美女毛片视频| 日韩一级在线观看| 欧美日韩激情在线| 色综合天天做天天爱| 亚洲国产精品影院| 亚洲天堂成人在线观看| 久久久久久久综合色一本| 日韩一卡二卡三卡四卡| 欧美精品三级在线观看| 在线观看91精品国产入口| 国产盗摄精品一区二区三区在线| 国产精品天干天干在线综合| 精品国产一区二区三区久久影院 | www.欧美亚洲| 成人免费毛片片v| 粉嫩久久99精品久久久久久夜| 国产成人精品网址| 国产经典欧美精品| 成人福利视频网站| 91在线视频观看| 日本韩国精品在线| 在线观看av一区二区| 欧美三级日本三级少妇99| 欧美狂野另类xxxxoooo| 欧美放荡的少妇| 日韩一区二区三区观看| 精品国产一区二区亚洲人成毛片| 精品免费99久久| 久久久99精品久久| 亚洲色图一区二区三区| 亚洲精选在线视频| 性欧美大战久久久久久久久| 五月综合激情网| 国产揄拍国内精品对白| 成人性生交大合| 91电影在线观看| 欧美成人一区二区| 国产婷婷精品av在线| 自拍av一区二区三区| 亚洲第一主播视频| 蜜桃视频第一区免费观看| 国产一区二区三区免费在线观看| 成人性视频免费网站| 欧美三级电影一区| 精品国产乱码久久久久久浪潮| 国产午夜一区二区三区| 亚洲欧美日韩国产综合在线| 亚洲电影一级片| 粉嫩在线一区二区三区视频| 日本乱码高清不卡字幕| 精品国产精品网麻豆系列| 国产精品成人午夜| 日韩电影在线观看网站| av午夜精品一区二区三区| 欧美日韩国产精选| 欧美国产丝袜视频| 青青草97国产精品免费观看| 成人高清视频免费观看| 6080yy午夜一二三区久久| 国产精品免费网站在线观看| 亚洲成人资源网| 成人免费视频网站在线观看| 欧美日韩国产另类一区| 最新久久zyz资源站| 美女任你摸久久| 91国产免费观看| 久久精品日韩一区二区三区| 天天综合日日夜夜精品| 成人ar影院免费观看视频|