-
當前位置:首頁 > 創(chuàng)意學院 > 品牌設計 > 專題列表 > 正文
- 求講解51單片機電子秤的程序,分模塊詳細點
- 問幾個有關模塊設計報告中的術語定義
- vi設計是什么,做vi設計有什么用途?
- 幫講解一下 研華數據采集卡的范例 中斷方式數據采集adint (單通道模擬量數據采集)這個vi
- 用labview仿真設計實驗,測試電液比例方向閥的流量特性和動態(tài)特性。
子VI AD INT模塊設計(子模塊結構圖)
大家好!今天讓創(chuàng)意嶺的小編來大家介紹下關于子VI AD INT模塊設計的問題,以下是小編對此問題的歸納整理,讓我們一起來看看吧。
開始之前先推薦一個非常厲害的Ai人工智能工具,一鍵生成原創(chuàng)文章、方案、文案、工作計劃、工作報告、論文、代碼、作文、做題和對話答疑等等,官網:https://ai.de1919.com
創(chuàng)意嶺專注品牌設計、策劃,為各大上市企業(yè)、個人提供一站式設計、策劃服務,服務客戶遍布全國,咨詢相關業(yè)務請撥打電話:175-8598-2043,或添加微信:1454722008
本文目錄:
求講解51單片機電子秤的程序,分模塊詳細點
如果想知道更多的東西,建議看一本書:吳鑒鷹單片機實戰(zhàn)精講,網上能找到,代碼我給你了。
/*******************************************************程序:吳鑒鷹基于單片機的電子秤的設計程序
** 這一講的主要內容: 電子稱是什么,講的專業(yè)點就是:
利用物體的重力作用來確定物體質量的測量儀器,也可用來確定與物體質量相關的其他量的大小,
參數,或特性用我們自己話講就是測重量的。
** 功能描述:
** 輸 入:
** 內容:
** 輸 出:
**
** 全局變量:
** 調用模塊:
**
** 作 者: 吳鑒鷹
** 日 期: 14.02.22
備注:有什么錯誤的地方,歡迎各大燒友指正
O(∩_∩)O~
*******************************************************/
#include <reg51.h>
#include <intrins.h>
#include<stdlib.h>
#include<math.h>
#define uchar unsigned char //宏的定義變量類型 uchar 代替 unsigned char
#define uint unsigned int //宏的定義變量類型 uint 代替 unsigned int
#define delay_time_max 50 //按鍵去抖動延時閥值
sbit RS = P2^0;
sbit RW = P2^1;
sbit SCLK = P2^2;
sbit LCDRST = P2^3;
sbit ST=P3^6; //啟動信號
sbit EOC=P3^3; //轉換結束信號,連到外部中斷1口,轉換結束后進入外部中斷
sbit OE=P3^7; //輸出使能
uchar KEY_VALUE;
uchar key_data;
uchar dis_buf; //顯示緩存
uchar temp;
uchar key; //鍵順序碼
uchar result;
uint f;
void delay(uchar x); //x*0.14MS
// 此表為 LED 的字模 0 1 2 3 4 5 6 7 8 9 a b c d e f
unsigned char code LED7Code[] = {~0x3F,~0x06,~0x5B,~0x4F,~0x66,~0x6D,~0x7D,~0x07,~0x7F,~0x6F,~0x77,~0x7C,~0x39,~0x5E,~0x79,~0x71};
unsigned char ADC0809[],KONGBVAI[],DANJIA[];
void ADC0809_change();
/*************************************************************************************
** 函數名稱: delayms
** 功能描述: 譯碼功能,將需要顯示的數字轉成相應的七段譯碼表
如要顯示的字符為“0”,則為7e ---0111 1111,就中間的一個LED不亮
** 輸 入: ms:需要延時的長度
**
**
** 輸 出:
**
** 全局變量:
** 調用模塊:
**
** 作 者: 吳鑒鷹
** 日 期: 14.02.22
**-----------------------------------------------------------------------------------
** 修改人:吳鑒鷹
** 日 期:
**----------------------------------------------------------------------------------
****************************************************************************************/
void delayms(uint ms)
{
uchar i;
while(ms--) for(i=0;i<120;i++);
}
/*********************************************************************************
** 函數名稱: SendByte
** 功能描述: 串口給液晶發(fā)送數據
** 輸 入: Dbyte
**
**
** 輸 出:
** 全局變量:
** 調用模塊:
**
** 作 者: 吳鑒鷹
** 日 期: 14.02.28
************************************************************************************/
void SendByte(uchar Dbyte)
{
uchar i;
for(i=0;i<8;i++)
{
SCLK = 0;
Dbyte=Dbyte<<1; //左移一位
RW = CY; //移出的位給RW
SCLK = 1;
SCLK = 0;
}
}
/***********************************************************************************
** 函數名稱: TransferCom
** 功能描述: 串口給液晶發(fā)送命令
** 輸 入: data0
**
**
** 輸 出:
** 全局變量:
** 調用模塊:
**
** 作 者: 吳鑒鷹
** 日 期: 14.02.28
**********************************************************************************/
void TransferCom(uchar data0)
{
RS=1;
SendByte(0xf8); //11111ABC,RW(0),RS(1),0
SendByte(0xf0&data0); //高四位
SendByte(0xf0&data0<<4); //低四位(先執(zhí)行<<)
RS=0;
}
/*******************************************************************************
** 函數名稱: lcd_mesg
** 功能描述: 寫數據,
** 輸 入: data1
**
**
** 輸 出:
** 全局變量:
** 調用模塊:
**
** 作 者: 吳鑒鷹
** 日 期: 14.02.28
*****************************************************************************/
void TransferData(uchar data1)
{
RS=1;
SendByte(0xfa); //11111ABC,RW(0),RS(1),0
SendByte(0xf0&data1); //高四位
SendByte(0xf0&data1<<4); //低四位(先執(zhí)行<<)
RS=0;
}
問幾個有關模塊設計報告中的術語定義
1\模塊如果退出Python解釋程序然后再進入,原有的定義(函數和變量)就丟失了。所以,如
果需要寫長一點的程序,最好用一個文本編輯程序為解釋程序準備輸入,然后以程序文
件作為輸入來運行Python解釋程序,這稱為準備腳本(script)。當你的程序變長時,
最好把它拆分成幾個文件以利于維護。你還可能想在幾個程序中都使用某個很方便的函
數,但又不想把函數定義賦值到每一個程序中。
為了支持這些,Python有一種辦法可以把定義放在一個文件中然后就可以在一個腳本中
或交互運行中調用。這樣的文件叫做一個模塊;模塊中的定義可以導入其它模塊或主模
塊(主模塊指在解釋程序頂級執(zhí)行的腳本或交互執(zhí)行的程序所能訪問的變量集合)。
模塊是包含了Python定義和語句的文件。文件名由模塊名加上后綴“.py”構成。在模塊
內,模塊的名字(作為一個字符串)可以由全局變量__name__的值獲知。例如,在Pyth
on的搜索路徑中用你習慣使用的文本編輯器(Python 1.5.2包含了一個用Tkinter編寫的
IDLE集成開發(fā)環(huán)境,MS Windows下有一個PythonWin界面也可以進行Python程序編輯)生
成一個名為“fibo.py ”的文件,包含如下內容:
# Fibonacci numbers module
def fib(n): # 輸出小于n的Fibonacci序列
a, b = 0, 1
while b < n:
print b,
a, b = b, a+b
def fib2(n): # 返回小于n的Fibonacci序列
result = []
a, b = 0, 1
while b < n:
result.append(b)
a, b = b, a+b
return result
然后進入Python解釋程序(在IDLE或PythonWin中可以直接進入解釋程序窗口),用如下
命令可以導入模塊:
>>> import fibo
這不會把模塊fibo中的函數的名字直接引入當前的符號表,這只是把模塊名fibo引入。
可以用模塊名來訪問其中的函數:
>>> fibo.fib(1000)
1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987
>>> fibo.fib2(100)
[1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]
>>> fibo.__name__
'fibo'
如果經常使用某個函數可以給它賦一個局部名字:
>>> fib = fibo.fib
>>> fib(500)
1 1 2 3 5 8 13 21 34 55 89 144 233 377
6.1 模塊的進一步介紹
模塊除了可以包含函數定義之外也可以包含可執(zhí)行語句。這些可執(zhí)行語句用來初始化模
塊,它們只在模塊第一次被導入時執(zhí)行。
每個模塊有自己私有的符號表,這個私有符號表對于模塊中的所有函數而言卻是它們的
全局符號表。因此,模塊作者可以在模塊中使用全局變量而不需擔心與模塊用戶的全局
變量沖突。另一方面,如果你有把握的話也可以用訪問模塊中函數的格式,即modname.
itemname的方法來修改模塊中的全局變量。
模塊可以導入其它模塊。我們通常把所有的導入語句放在模塊(或腳本)的開始位置,
這不是規(guī)定要求的。導入的模塊名放入模塊的全局符號表中。
導入還有另一種用法,可以把模塊中的名字直接導入使用者的符號表。例如:
>>> from fibo import fib, fib2
>>> fib(500)
1 1 2 3 5 8 13 21 34 55 89 144 233 377
這不會把模塊名導入使用者的符號表中(例如,上面例子中fibo就沒有定義)。
還有一種辦法可以導入一個模塊中定義的所有名字:
>>> from fibo import *
>>> fib(500)
1 1 2 3 5 8 13 21 34 55 89 144 233 377
這可以把模塊中除了以下劃線結尾的所有名字導入。
6.1.1 模塊搜索路徑
在導入名為spam的模塊時,解釋程序先在當前目錄中尋找名為“spam.py”的文件,然后
從環(huán)境變量PYTHONPATH所定義的目錄列表中尋找。PYTHONPATH的用法和可執(zhí)行文件的搜
索路徑PATH用法相同,都是一個目錄列表。當PYTHONPATH未設置的時候,或者文件仍找
不到,則搜索繼續(xù)在安裝時設定的缺省路徑搜索,在Unix中,這通常是“.:/usr/local
/lib/python” 。
實際上,模塊是按變量sys.path指定的路徑搜索的,此變量在解釋程序啟動時初始化為
包含輸入腳本的目錄(或當前路徑),PYTHONPATH和安裝缺省路徑。這樣,用戶可以通
過修改sys.path 來修改和替換模塊搜索路徑。參見后面關于標準模塊的一節(jié)。
6.1.2 “編譯”的Python文件
為了提高調用許多標準模塊的小程序的啟動時間,一個重要的措施是,如果在找到“sp
am.py ”的目錄中存在一個名為“spam.pyc”的文件,就認為此文件包含了模塊spam的
一個所謂“ 字節(jié)編譯”版本。用于生成“spam.pyc”的“spam.py”的修改時間被記入
了“spam.pyc”中,如果記錄的修改時間與現在文件的時間不相符的話就忽略編譯文件
。
一般不需要自己生成“spam.pyc”這樣的編譯文件。每當“spam.py”成功編譯后解釋程
序就嘗試寫編譯版本“spam.pyc”,如果不可寫也不會出錯;如果因為某種原因此文件
沒有寫完則生成的“spam.pyc”被識別為不完整的而被忽略。編譯文件“spam.pyc”的
格式是不依賴于平臺的,所以不同結構的機器可以共享Python模塊目錄。
下面是對專家的一些竅門:
如果Python解釋程序是以-O標志啟動的,將生成優(yōu)化的編譯代碼,保存在“.pyo”文件
中。目前優(yōu)化不是很多,現在只是去掉assert語句和SET_LINENO指令。使用了-O標志時
,所有字節(jié)碼都是優(yōu)化的,“.pyc”文件被忽略,“.py”文件被編譯為優(yōu)化的字節(jié)碼。
給Python解釋程序兩個優(yōu)化標志(-OO)產生的優(yōu)化代碼有時會導致程序運行不正常。目
前雙重優(yōu)化只從字節(jié)碼中刪除了__doc__字符串,使得“.pyo”文件較小。有些程序可能
是依賴于文檔字符串的,所以只有在確知不會有問題時才可以使用這樣的優(yōu)化。
從“.pyc”或“.pyo”讀入的程序并不能比從“.py”讀入的運行更快,它們只是調入速
度更快一些。
如果一個程序是用在命令行指定腳本文件名的方式運行的,腳本的字節(jié)碼不會寫入“.p
yc ”或“.pyo”文件。所以如果把程序的主要代碼都移入一個模塊,腳本中只剩下導入
該模塊的引導程序則可以略微縮短腳本的啟動時間。
可以有叫做“spam.pyc”(當用了-O標志時為“spam.pyo”)的文件而沒有對應的源文
件“spam.py”。這可以用來分發(fā)一個比較難反編譯的Python代碼庫。
模塊compileall可以把一個目錄中所有模塊編譯為“.pyc”文件(指定了-O選項時編譯
為“.pyo”文件)。
6.2 標準模塊
Python帶有一個標準模塊庫,在另一個文檔《Python庫參考》中進行了描述。一些模塊
直接編入了解釋程序中,這些模塊不是語言的核心,為了運行效率或者為了提供對于系
統(tǒng)調用這樣的系統(tǒng)底層功能而編入了解釋程序中。提供那些模塊是編譯時的選擇,例如
,amoeba模塊只在提供amoeba底層指令的系統(tǒng)中才能提供。
有一個模塊值得特別重視:sys模塊,每一個Python解釋程序中都編譯入了這個模塊。變
量sys.ps1和sys.ps2定義了交互運行時的初始提示和續(xù)行提示。
>>> import sys
>>> sys.ps1
'>>> '
>>> sys.ps2
'... '
>>> sys.ps1 = 'C> '
C> print 'Yuck!'
Yuck!
C>
這兩個變量只在解釋程序以交互方式運行時才有定義。
變量sys.path是一個字符串列表,由它確定解釋程序的模塊搜索路徑。它被初始化為環(huán)
境變量PYTHONPATH所指定的缺省路徑,環(huán)境變量沒有定義時初始化為安裝時的缺省路徑
??梢杂脴藴实牧斜聿僮餍薷倪@個搜索路徑,例如:
>>> import sys
>>> sys.path.append('/ufs/guido/lib/python')
6.3 dir()函數
內置函數dir()用于列出一個模塊所定義的名字,它返回一個字符串列表:
>>> import fibo, sys
>>> dir(fibo)
['__name__', 'fib', 'fib2']
>>> dir(sys)
['__name__', 'argv', 'builtin_module_names', 'copyright', 'exit',
'maxint', 'modules', 'path', 'ps1', 'ps2', 'setprofile', 'settrace',
'stderr', 'stdin', 'stdout', 'version']
沒有自變量時,dir()列出當前定義的名字。
>>> a = [1, 2, 3, 4, 5]
>>> import fibo, sys
>>> fib = fibo.fib
>>> dir()
['__name__', 'a', 'fib', 'fibo', 'sys']
注意dir()列出了所有各類名字:變量名、模塊名、函數名,等等。dir()不會列出內置
函數、變量的名字。要想列出內置名字的話需要使用標準模塊__builtin__:
>>> import __builtin__
>>> dir(__builtin__)
['AccessError', 'AttributeError', 'ConflictError', 'EOFError', 'IOError',
'ImportError', 'IndexError', 'KeyError', 'KeyboardInterrupt',
'MemoryError', 'NameError', 'None', 'OverflowError', 'RuntimeError',
'SyntaxError', 'SystemError', 'SystemExit', 'TypeError', 'ValueError',
'ZeroDivisionError', '__name__', 'abs', 'apply', 'chr', 'cmp', 'coerce',
'compile', 'dir', 'divmod', 'eval', 'execfile', 'filter', 'float',
'getattr', 'hasattr', 'hash', 'hex', 'id', 'input', 'int', 'len', 'long',
'map', 'max', 'min', 'oct', 'open', 'ord', 'pow', 'range', 'raw_input',
'reduce', 'reload', 'repr', 'round', 'setattr', 'str', 'type', 'xrange']
6.4 包
Python中可以用“包”來組織Python的模塊名字空間,名字引用時可以用“帶點的模塊
名。例如,模塊名A.B代表包“A”內名為“B”的子模塊。正如使用模塊可以使不同模塊
的作者不用顧慮彼此的全局變量名會沖突,使用帶點的模塊名可以使多模塊包如NumPy和
PIL的作者不需要擔心彼此的模塊名會沖突。
假設你有一系列處理聲音文件和聲音數據的模塊(稱為一個“包”)。有許多種不同的
聲音文件格式(通常用擴展名來識別,如“wav”,“.aiff”,“.au”),所以你可能
需要制作并維護一組不斷增加的模塊來處理不同文件格式的轉換。你還可能需要對聲音
數據進行許多不同的操作(如混音、回響、均衡、產生模擬立體聲效果),所以你還需
要不斷增加模塊來執(zhí)行這些操作。一下是你的程序包的可能的結構(用一個分層文件系
統(tǒng)表示):
Sound/ 頂層包
__init__.py 初始化音響包
Formats/ 用于文件格式轉換的子程序包
__init__.py
wavread.py
wavwrite.py
aiffread.py
aiffwrite.py
auread.py
auwrite.py
...
Effects/ 用于音響效果的子程序包
__init__.py
echo.py
surround.py
reverse.py
...
Filters/ 用于濾波的子程序包
__init__.py
equalizer.py
vocoder.py
karaoke.py
...
包目錄中的“__init__.py”文件是必須得,用來指示Python把這個目錄看成包,這可以
防止有相同名字如“string”的子目錄掩蓋住在搜索路徑后面一些出現的模塊定義。在
最簡單的情況下,“__init__.py”可以是一個空文件,它也可以包含初始化包所需的代
碼,和設置“__all__”變量,這些后面會加以討論。
包的用戶可以從包中導入單獨的模塊,如:
import Sound.Effects.echo
這可以把子模塊Sound.Effects.echo導入。要引用它也必須用全名,例如:
Sound.Effects.echo.echofilter(input, output, delay=0.7, atten=4)
導入子模塊的另一種辦法是:
from Sound.Effects import echo
這同樣也導入子模塊echo,但調用時不需寫包前綴,所以可以用如:
echo.echofilter(input, output, delay=0.7, atten=4)
另外一種寫法是直接導入所需的函數或變量:
from Sound.Effects.echo import echofilter
這一次同樣是調入了子模塊echo,但是使其函數echofilter直接可用:
echofilter(input, output, delay=0.7, atten=4)
注意使用“from 包 import 項”這樣的格式時,導入的項可以是包的一個子模塊(或子
包),也可以是包內定義的其它名字如函數、類、變量。導入語句首先查找包內是否定
義了所需的項,如果沒有則假設它是一個模塊然后調入。如果找不到,結果引起Import
Error。
相反的,當使用“import item.subitem.subsubitem”這樣的格式時,除最后一個外其
它各項都應該是包,最后一項可以是包也可以是模塊,不允許是前面一項內部定義的類
、函數或變量。
6.4.1 從包中導入*
現在,如果用戶寫“from Sound.Effects import *”會發(fā)生什么情況?理想情況下我們
希望這應該掃描文件系統(tǒng),找到所有包內的子模塊并把它們都導入進來。不幸的是這種
操作在Mac和Windows平臺上不能準確實現,這兩種操作系統(tǒng)對文件名的大小寫沒有準確
信息。在這些平臺上,不知道名為“ECHO.PY”的文件會作為模塊echo、Echo還是ECHO被
導入。(例如,Windows 95在顯示文件名時總是討厭地把第一個字母大寫)。DOS的8+
3文件名限制更是對長模塊名造成了有趣的困難。
這個問題的唯一解決辦法是由模塊作者顯式地提供包的索引。引入*的import語句遵循如
下規(guī)定:如果包的“__init__.py”文件定義了一個名為“__all__”的列表,這個列表
就作為從包內導入*時要導入的所有模塊的名字表。因此當包的新版本發(fā)布時需要包的作
者確保這個列表是最新的。包的作者如果認為不需要導入*的話也可以不支持這種用法。
例如,文件Sounds/Effects/__init__.py 可以包含如下代碼:
__all__ = ["echo", "surround", "reverse"]
這意味著from Sound.Effects import *將從Sound包中導入指定的三個子包。
如果沒有定義__all__,則from Sound.Effects import *語句不會導入Sound.Effects包
中的所有子模塊;此語句只能保證Sound.Effects被導入(可能是執(zhí)行其初始化代碼“_
_init__.py ”)并導入包中直接定義的名字。這包括由“__init__.py”定義的任何名
字和顯式導入的子模塊名。這也包括模塊中已經在前面用import顯式地導入的子模塊,
例如:
import Sound.Effects.echo
import Sound.Effects.surround
from Sound.Effects import *
在這個例子中,echo和surround模塊被導入當前名字空間,因為它們在執(zhí)行from...imp
ort 語句時已定義(在定義了__all__的情況下這一點也是成立的)。
注意用戶應盡量避免使用從模塊或包中導入*的做法,因為這樣經常導致可讀性差的代碼
。盡管如此,在交互運行時可以用導入*的辦法節(jié)省敲鍵次數,而且有些模塊在設計時就
考慮到了這個問題,它們只輸出遵循某種約定的名字。注意,from 包 import 特定子模
塊的用法并沒有錯,實際上這還是我們推薦的用法,除非程序還需要用到來自其它包的
同名的子模塊。
6.4.2 包內部引用
子模塊常常需要彼此引用。例如,模塊surround可能要用到模塊echo。事實上,這樣的
引用十分常見,所以import語句首先從子模塊的所在包中尋找要導入的子模塊才在標準
模塊搜索路徑查找。所以,模塊surround只要寫import echo或from echo import echo
filter。如果在包含本模塊的包中沒有找到要導入的模塊,import語句將去尋找指定名
字的頂級模塊。
當包組織成子包時(比如例中的Sound包),沒有一種簡單的辦法可以引用兄弟包中的子
模塊――必須使用子模塊的全名。例如,如果模塊Sound.Filters.vocoder要引用Sound
.Effects 包中的echo模塊,它可以用Sound.Effects import echo。
通過執(zhí)行類代碼體創(chuàng)建或擴展類Class的對象
ruby 代碼
class [scope::] classname [
body
end
注意:
1、如果superexpr存在,那么該superexpr應當是一個以Class對象為結果的表達式,而且它將是被定義的類的超類。
如果省略superexpr,則默認為類Object
2、所有類定義是在代碼執(zhí)行時候生成的。
3、所有類定義在執(zhí)行后都是一個Class類的對象。
4、所有的這些對象都將賦給名為classname的常量。
5、使用域作用符(::)可以為類定義中的classname前置一個已存在的類或模塊名。這樣會將新的定義插入到前面定義
的模塊和/或類的名字空間中,但不是在這些外部類的作用域中解釋此定義。前面帶有域作用符的classname將被放置在
那個類或模塊所處的頂層(這樣作有個什么好處)
方式二、匿名類
ruby 代碼
class << obj
body
end
該類是一個匿名類,將會和指定的對象關聯(lián)。這時這個匿名類將是該關聯(lián)對象的虛擬類,原來該對象的類,變成了該虛擬 類的超類。
注意:如果直接在類定義外,給你對象新增一些方法和這樣為一個對象創(chuàng)建一個類是等價的。同樣是創(chuàng)建一個虛擬類。
Ruby類定義和其他語言不一樣,其他語言都是在編譯期處理的。而ruby是在代碼運行時候根據類的定義創(chuàng)建的。這樣如下特點:
1、可以在運行時候決定類的定義。這樣根據不同條件,得出不同的類的定義結構
2、如果類定義是可執(zhí)行的代碼,那么它一定是在某個對象的上下文中執(zhí)行的。Ruby中直接把該類作為當前對象
3、這個對象的類屬于Class。說明,所有創(chuàng)建類就是一個對象,他們的類就是Class
太多了!對不起!沒有給您找完
vi設計是什么,做vi設計有什么用途?
VI即(Visual Identity),通譯為視覺識別系統(tǒng),是CIS系統(tǒng)最具傳播力和感染力的部分。是將CI的非可視內容轉化為靜態(tài)的視覺識別符號,以無比豐富的多樣的應用形式,在最為廣泛的層面上,進行最直接的傳播。設計到位、實施科學的視覺識別系統(tǒng),是傳播企業(yè)經營理念、建立企業(yè)知名度、塑造企業(yè)形象的快速便捷之途。x0dx0ax0dx0aVI設計即(Visual Identity),通譯為視覺識別系統(tǒng),是CIS系統(tǒng)最具傳播力和感染力的部分。是將CI的非可視內容轉化為靜態(tài)的視覺識別符號,以無比豐富的多樣的應用形式,在最為廣泛的層面上,進行最直接的傳播。設計到位、實施科學的視覺識別系統(tǒng),是傳播企業(yè)經營理念、建立企業(yè)知名度、塑造企業(yè)形象的快速便捷之途。x0dx0aVI:視覺識別x0dx0aVI:以標志、標準字、標準色為核心展開的完整的、系統(tǒng)的視覺表達體系。將上述的企業(yè)理念、企業(yè)文化、服務內容、企業(yè)規(guī)范等抽象概念轉換為具體符號,塑造出獨特的企業(yè)形象。在CI設計中,視覺識別設計最具傳播力和感染力,最容易被公眾接受,具有重要意義。x0dx0aVI系統(tǒng):x0dx0aA.基本要素系統(tǒng):如企業(yè)名稱、企業(yè)標志、企業(yè)造型、標準字、標準色、象征圖案、宣傳口號等。x0dx0aB.應用系統(tǒng):產品造型、辦公用品、企業(yè)環(huán)境、交通工具、服裝服飾、廣告媒體、招牌、包裝系統(tǒng)、 公務禮品、陳列展示以及印刷出版物等。x0dx0ax0dx0a一套VI設計的主要內容:x0dx0aI.基本要素系統(tǒng)x0dx0aA.標志x0dx0aB.標準字x0dx0aC.標準色x0dx0aD.標志和標準字的組合.x0dx0ax0dx0aII.應用系統(tǒng)x0dx0aA.辦公用品:信封、信紙、便箋、名片、徽章、工作證、請柬、文件夾、介紹信、帳票、備忘錄、資料袋、公文表格等。x0dx0aB.企業(yè)外部建筑環(huán)境:建筑造型、公司旗幟、企業(yè)門面、企業(yè)招牌、公共標識牌、路標指示牌、廣告塔、霓虹燈廣告、庭院美化等。x0dx0aC.企業(yè)內部建筑環(huán)境:企業(yè)內部各部門標識牌、常用標識牌、樓層標識牌、企業(yè)形象牌、旗幟、廣告牌、POP廣告、貨架標牌等。x0dx0aD.交通工具:轎車、面包車、大巴士、貨車、工具車、油罐車、輪船、飛機等。x0dx0aE.服裝服飾:經理制服、管理人員制服、員工制服、禮儀制服、文化衫、領帶、工作帽、鈕扣、肩章、胸卡等。x0dx0aF.廣告媒體:電視廣告、雜志廣告、報紙廣告、網絡廣告、路牌廣告、招貼廣告等。x0dx0aG.產品包裝:紙盒包裝、紙袋包裝、木箱包裝、玻璃容器包裝、塑料袋包裝、金屬包裝、陶瓷包裝、包裝紙。x0dx0aH.公務禮品:T恤衫、領帶、領帶夾、打火機、鑰匙牌、雨傘、紀念章、禮品袋等。x0dx0aI.陳列展示:櫥窗展示、展覽展示、貨架商品展示、陳列商品展示等。x0dx0aJ.印刷品:企業(yè)簡介、商品說明書、產品簡介、年歷等。x0dx0ax0dx0a簡單的說 是一個企業(yè)的形象識別系統(tǒng)
幫講解一下 研華數據采集卡的范例 中斷方式數據采集adint (單通道模擬量數據采集)這個vi
你自己編程還是用組態(tài)軟件,如果是組態(tài)軟件的話,就很簡單了,只要熟悉組態(tài)軟件界面就可以在組態(tài)中設置 各種采集卡上的采集信息方式及信息采集的控制,中斷方式是在設置界面中可以自己設置的。單通道模擬量就可以不考慮同步卡異步卡的問題了用labview仿真設計實驗,測試電液比例方向閥的流量特性和動態(tài)特性。
1 實驗臺設計實驗臺臺體用5 mm 不銹鋼板噴漆制成操作機架。安裝臺面為長1 000 mm、寬700 mm、高900 mm帶t 型槽平臺,實驗所需閥塊安裝在 t 型槽平臺前面板上并預留元件擴展空間。液壓缸為 2 個自設計加工的有效行程為 200 mm 雙作用單桿活塞式液壓缸,分為實驗缸和加載缸。泵站由2 個 1. 5 kw 定量葉片泵采用分別供油方式對液壓實驗臺進行供油。實驗臺硬件構成主要有: 液壓泵站,比例溢流閥、壓力傳感器,流量傳感器,減壓閥、節(jié)流閥、調速閥、電磁方向閥,測試油路塊及蓄能器、濾油器、紫銅管等輔件( 圖1) 。
2 計算機輔助測試系統(tǒng)設計
2. 1 硬件系統(tǒng)的構建
一般液壓計算機輔助測試( cat) 系統(tǒng)主要包括:計算機( 工控pc) ,高精度壓力、流量傳感器,數據采集模塊,信號調理板卡等硬件。
在滿足測試系統(tǒng)硬件要求和測試精度的前提下,選用實驗室標準配置的計算機和國產性能優(yōu)良的壓力及流量傳感器。為提高數據采集系統(tǒng)的整體性能,選 用國產某公司生產的多功能pci -8603 數據采集卡,與labview 軟件有出色的兼容配合性,性能優(yōu)良具有較高性價比。最高采樣頻率為100 ks/s; ad 轉換精度12 位; 基于 pci 總線的單端16 路模擬量輸入與8 路差分輸入; 兩路模擬量輸出。
數據采集卡只能對電壓信號進行模數轉換,其可接收的電壓范圍有: 0 ~ +5 v、-5 ~ +5 v、-10 ~ +10 v,而壓力傳感器輸出的信號多為4 ~ 20 ma 電流信號,因此要進行電流 - 電壓( i/v) 轉換。需將此毫安級電流信號放大并轉換為數據采集卡可接收的電壓信號。故選用電路設計中性價比較高的lm324 放大元件和精密電阻、電容等元器件設計制作了轉換調理板卡。該板卡可實現對壓力傳感器輸出的信號進行放大、濾波降噪和 i/v 轉換等功能。
2. 2 軟件系統(tǒng)的開發(fā)
采用虛擬儀器技術 labview 作為測試系統(tǒng)軟件開發(fā)平臺,可在計算機系統(tǒng)中完成數據采集和處理等各種測試功能。labview 軟件可與數據采集卡的硬件設備驅動程序實現無縫結合,利用“測量和自動化瀏覽器”軟件自動檢測和配置硬件及軟件屬性。系統(tǒng)流程如圖2 所示。
文中的虛擬儀器測控軟件 labview 程序的編制采用模塊化思想,即將比例溢流閥穩(wěn)態(tài)壓力控制、穩(wěn)態(tài)負載特性等各個特性實驗測試項目編制成子vi,通過主vi 調用相應的子vi 來完成實驗項目的測試。并在labview 提供的 express vi 中,實現數據的采集、數字濾波、曲線擬合、波形生成顯示、保存讀取打印文件; 時域分析,頻譜分析等功能。利用自己編制的虛擬信號發(fā)生器取代傳統(tǒng)的函數信號發(fā)生器輸出激勵信號,不僅使信號參數的調整更加便捷而且降低了實驗臺的制作成 本。系統(tǒng)界面如圖3 所示。
3 測試方案及實驗內容的設計與研究
3. 1 比例溢流閥測試方案( 圖4)
如圖4 所示,實驗臺測控系統(tǒng)上位機采用計算機、下位機集成了 ad/da 控制模塊的采集卡,其與壓力傳感器、調理轉換電路結合,構成了比例溢流閥壓力信號采集和控制的硬件系統(tǒng); 信號發(fā)生器則提供可調三角波或正弦波激勵信號驅動比例控制放大器,控制比例溢流閥閥芯產生位移; 傳感器將受控壓力值采集并輸入計算機中得到輸入控制電信號與輸出壓力值之間關系的特性曲線。由壓力傳感器進行的檢測反饋構成了比例控制系統(tǒng)的雙閉環(huán)反饋結 構,有效降低負載突變時對液壓系統(tǒng)產生的擾動,提高了系統(tǒng)控制的響應速度、動態(tài)性能和抗干擾能力。
本文中數據采集卡模擬輸入通道1、2、3、4 分別采集比例溢流閥出口壓力值p1、液壓缸實驗缸工作腔壓力值p2、回油流量q、控制電流 i,并將兩路壓力值進行實時采集。將信號發(fā)生器輸出的激勵信號由數據采集卡0 通道輸出控制信號來驅動比例溢流閥的控制放大器。由于測量過程中容易產生干擾現象,因此使用有效接地的屏蔽線纜、低紋波干擾的直流線性穩(wěn)壓電源、差分測量 系統(tǒng)及模、數電路分置接地可明顯減弱共模電壓干擾。
3. 2 部分實驗內容設計及試驗研究
( 1) 穩(wěn)態(tài)壓力控制特性實驗
系統(tǒng)正常運行時,如圖1,將方向閥3 迅速調至中位,使試驗流量全部通過被測閥2,在信號發(fā)生器中以頻率小于0. 03 hz 的三角波電壓信號在起始最小控制電流in為100 ma 與額定最大電流in為800 ma 之間輸入連續(xù)增大或減小的電信號,閥口開度也隨之相應改變。此時系統(tǒng)將測量的壓力值采集至計算機并在labview 中記錄顯示,得到被測試閥從最低( 高) 開啟壓力運行到最高( 低) 工作壓力的一個完整周期的兩條 p - i 曲線,將其與理想曲線對比。給出 10 組不同的控制電信號且在不同工況下重復該實驗 10 次,得到穩(wěn)態(tài)壓力控制特性曲線,從曲線圖中可得出該測試閥的滯環(huán)、重復精度、線性度、相對調壓偏差等特性指標。
( 2) 穩(wěn)態(tài)負載流量控制特性實驗
實驗中,增大實驗缸負載壓力使其接近靜止,此時將比例溢流閥調至一定供油壓力值( 如6 mpa) ,給出一組輸入電信號( 即壓力值) 如: 最小流量 in、30% in、60% in、90%in、100%in。此時調節(jié)調速閥 4 的流量大小,使其在初始流量與試驗流量之間變化,得到p - q穩(wěn)態(tài)負載流量控制特性曲線,給出 5 組電信號進行測試,可得到被測閥的阻尼特性和響應特性。
( 3) 穩(wěn)壓特性( 測量壓力隨時間變化的特性) 實驗如圖1,實驗中固定負載缸壓力值,此時給被測閥一個控制信號,通過壓力傳感器12 和 13 測量壓力點p1和p2的實時變化。即在10組不同時間間隔內( 如1 s,3 s,5 s…; 2 s,7 s,11 s…) 觀測壓力點的波動變化,記錄結果并保存,對采集到的壓力點進行曲線擬合( 圖5 所示) 。將每組曲線做自相關分析,組與組之間做互相關分析,給出5 組信號進行測試,即得到壓力隨時間變化的特性 p - t 曲線。此實驗可對比 p1、p2壓力點的動態(tài)變化過程反映被測閥的動態(tài)特性以及在閥響應過度過程中系統(tǒng)產生壓力波動的原因。
( 4) 調壓延遲特性實驗
試驗中,在某一工況下,給被測試閥發(fā)出一個或一組變化指令控制電信號,查看壓力值是否及時反應,迅速達到預調定值,延遲時間是多少,并在 labview 中顯示該時間點上壓力值的時域變化、頻譜成分和頻域特性。圖6 為壓力信號采集產生瞬時脈動的時域波形分析和頻譜分析,通過此實驗分析導致調壓延遲的原因,找到縮短調壓延遲和解決系統(tǒng)回路壓力補償的辦法。
本實驗臺適用于壓力31. 5 mpa、流量 200 l/min范圍內的比例溢流閥特性測試,以 dbe10 - 30b -100ym 型先導電反饋比例溢流閥為被測試閥,并在實驗臺預留若干液壓器件擴展位置,以實現比例閥壓力、流量、位移的同步測控。
4 結語
本實驗臺將計算機輔助測試技術和電液比例閥特性測試技術相結合,并利用虛擬儀器技術開發(fā)了比例溢流閥特性計算機輔助測試( cat) 系統(tǒng),不僅可以完成《液壓傳動》教學中所有常規(guī)的實驗內容,還能完成對比例溢流閥各項特性的測試。
對現行比例溢流閥測試內容方案改進設計,使用labview 軟件中強大的信號分析工具對采集的數據進行時域、頻域分析處理; 實現了對兩路及四路壓力值的實時采集,顯示/存儲數據及數據分析處理等功能,為后續(xù)實現比例閥壓力、流量、位移綜合測試及不同參量多點實時同步數據采集打 下了基礎。更好地從多角度獲取比例溢流閥的特性,為工業(yè)生產和工程實際提供可靠的實測參考數據。
此外,測試試驗研究表明,該實驗臺實現了對比例溢流閥特性的自動測試,各項測試指標達到了工業(yè)測試要求。其結構設計合理、體積小巧、測試性能穩(wěn) 定、數據采集分析準確、擴展性強,開發(fā)成本較低,具有較好的性價比、研究性和實用性; 為真正實現液壓測試全自動化和機電液一體化提供了參考依據。
以上就是關于子VI AD INT模塊設計相關問題的回答。希望能幫到你,如有更多相關問題,您也可以聯(lián)系我們的客服進行咨詢,客服也會為您講解更多精彩的知識和內容。
推薦閱讀: