LabVIEW (Laboratory Virtual Instru ment Engineering Workbench) là
một môi trường phát triển chương trình, rất giố ng môi trường phát triển của C
hay Basic và National Instrument Lab Windows/CVI. LabVIEW khác với các
ứng dụng đó ở một điể m rất quan trọng. Hệ thống l ập trình khác sử dụng ngôn
ngữ text-based để tạo các dòng mã lệnh, trong khi LabVIEW sử dụng ngôn ngữ
lập trình đồ hoạ,G, để tạo các chương trình dưới dạng sơ đồ khối.
Thế mạnh của LabVIEW.
LabVIEW, giống như C hay Basic, là một hệ thống lập trình đa dụng v ớ i
các thư viện lớn chứa các hàm cho bất kỳ nhiệm vụ lập trình nào. LabVIEW
cũng chứa các công cụ phát triển chương trình thông thường nên bạn có thể đặt
điểm gãy (break point), làm sống động quá trình thực hiện (highlight excution)
để xem dữ liệu truyền trong chương trình nh ư thế nào và thực hi ện từ ng b ước
ch ương trình để ti ến hành gỡ r ố i và phát tri ển ch ương trình d ễ dàng h ơ n.
LabVIEW cung c ấp kh ả n ăng xây d ự ng những chương trình cho các h ệ
th ố ng khoa họ c và k ĩ thu ật. LabVIEW cung cấp cho bạn m ộ t ngôn ng ữ l ập trình
linh ho ạt và có tính kh ả thi.
LabVIEW cung c ấp cách nhanh hơ n để l ập trình vớ i các thiế t bị và các h ệ
th ố ng thu th ập dữ li ệu. V ớ i vi ệ c dùng LabVIEW, bạn có gi ả m bớt th ờ i gian phát
tri ển hệ thố ng và t ăng hiệu su ấ t làm việc. LabVIEW cung cấp nh ững công cụ
mạnh cho vi ệc ghép n ố i với các các thi ết bị v ật lý bên ngoài mà không phải qua
phần thi ết kế h ệ thố ng mộ t cách ph ứ c t ạp nh ư trong các ngôn ng ữ khác.
LabVIEW là ngôn ng ữ l ập trình đồ ho ạ nên r ất trực quan và d ễ s ử d ụ ng.
LabVIEW chứa các thư viện cho việc thu nhận dữ li ệu, đ i ều khiển thi ết bị GPIB
và Serial, phân tích d ữ li ệu, bi ểu di ễn dữ li ệu và cất giữ dữ liệu. V ới một thư
vi ện phong phú cho các hệ thố ng đ i ều khiển, LabVIEW có th ể ứ ng d ụ ng mạnh
trong việc lập trình điều khiển hệ thống.
Nội Dung
Chương 1 Kỹ thuật lập trình trên LabVIEW
1.1. Kỹ thuật lập trình cơ bản trên LabVIEW
1.2.Lập trình nâng cao trên LabVIEW
Chương 2 Thiết bị đo thông minh HP34970A
Chương 3 Xây dựng bài thí nghiệ m trên bệ thí nghiệm máy điện
Kết luận chung
49 trang |
Chia sẻ: lvcdongnoi | Lượt xem: 6119 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Hướng dẫn lập trình Labview, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
luôn được đếm từ 0 nên nếu vòng lặp chỉ thực hiện
một lần, đầu terminal lặp lại sẽ xuất ra giá trị 0.
Vòng While tương đương đoạn giả mã sau:
Do
Execute Diagram inside the Loop (which sets the condition)
While Condition is true.
Để đặt vòng While lên Block Diagram vào Function>>Structures. Vòng
While không đặt lên Block Diagram ngay mà thay vào đó ta có thể đặt vị trí và
thay đổi kích thước của nó. Để thực hiện, kích chuột vào khu vực phía trên bên
trái của những terminal mà ta muốn đặt trong vòng. Sau đó kéo chuột để nó bao
các terminal đó và thả ra. Nếu muốn đặt một đối tượng vào trong vòng While thì
phải kéo đối tượng vào vòng While chứ không được kéo vòng While đè lên đối
tượng. Đây cũng là nguyên tắc chung đối với các structure trong LabVIEW.
* Thanh ghi dịch.
Thanh ghi dịch (có sẵn đối với vòng While và For) chuyển các giá trị từ
một lần lặp đến lần lặp kế tiếp. Có thể tạo thanh ghi dịch bằng cách pop-up trên
viền trái hoặc phải của vòng lặp và chọn Add Shift Register.
Thanh ghi dịch bao gồm một cặp terminal đối diện nhau ở trên mặt đứng
của viền vòng lặp. Terminal bên phải lưu trữ giư liệu khi hoàn thành một lần lặp.
Dữ liệu dịch chuyển đến cuối mỗi lần lặp và chuyển sang terminal trái ở đầu của
lần lặp kế tiếp. Mỗi thanh ghi dịch có thể lưu trữ bất kì kiểu dữ liệu nào. Thanh
ghi dịch tự động thích ứng với kiểu dữ liệu của đối tượng đầu tiên nối vào thanh
ghi dịch. Hình 2-25 minh hoạ cách dùng thanh ghi dịch trong vòng lặp.
Hình 1-24.Vòng While.
VNArmy
15
Để thêm thanh ghi dịch, kích chuột phải vào terminal ở bên phải hoặc trái và
chọn Add Element.
2. Vòng For.
Vòng For cũng thực hiện lặp một đoạn mã như vòng While nhưng số lần
lặp lại được xác định trước. Vòng For cũng giống như vòng For trong các ngôn
ngữ lập trình truyền thống. Nó tương đương với đoạn giả mã sau:
For i=1 to N-1
Excute Diagram inside The Loop.
Theo đó thì vòng For gồm 2 terminal như minh hoạ ở hình 1-26. Trong
đó:
Để đặt vòng For lên Block Diagram cũng thực hiện như vòng While.
3. Case & Sequence Structure.
Cấu trúc Case và Sequence có thể có hai hoặc nhiều đồ hình con
(subdiagram) mà chỉ một trong số chúng thực hiện khi cấu trúc thực hiện. Tại
đỉnh của viền mỗi cấu trúc có một cửa sổ biểu diễn subdiagram. Cửa sổ này gồm
một mục nhận dạng đồ hình (diagram identifier) ở giữa và các nút tăng giảm ở
mỗi cạnh. Đối với cấu trúc Case, phần diagram identifier là một danh sách các
Hình 1-26. Vòng lặp For
Count terminal là một terminal vào xác định số lần lặp.
Iteration terminal là terminal ra, đếm số lần phép lặp đã thực hiện.
Hình 1-25. Cách dùng thanh ghi dịch trong vòng lặp
Trước khi bắt đầu vòng lặp Lần lặp đầu tiên
Giá trị
ban đầu
Giá trị
ban đầu
Giá trị
mới
Giá trị
mới
Giá trị
trước
Giá trị
trước
Giá trị
mới
Giá trị
mới
Lần lặp cuối cùng Lần lặp tiếp theo
VNArmy
16
giá trị để chọn subdiagram, còn với Sequence là số khung theo trình tự (0 đến
n-1). Hình 1-27 minh hoạ cấu trúc Case và Sequence.
a) Cấu trúc Case.
Cấu trúc Case có hai hoặc nhiều subdiagram (các case) mà chỉ có một
case thực hiện. Điều này phụ thuộc vào giá trị của kiểu dữ liệu được nối vào
cạnh ngoài của terminal lựa chọn hay còn gọi là selector. Hình 1-28 minh hoạ
một cấu trúc Case.
Với cấu trúc Case bạn có thể thực hiện:
- Chỉ định danh sách hoặc dãy của các giá trị selector tương ứng với mỗi
case.
- Sử dụng một số nguyên, một số Boolean, một chuỗi hay một kiểu định
nghĩa như một selector.
- Chỉ định một case mặc định (hoặc hoạt động).
- Sắp các case theo giá trị selector đầu tiên.
Để tham khảo về cấu trúc Case có thể tham khảo Online help của nó.
b) Cấu trúc Sequence.
Cấu trúc Sequence trông giống một khung phim thực hiện các subdiagram
hay các khung (frame) bên trong nó một cách tuần tự. Trong các ngôn ngữ lập
trình truyền thống, các lệnh được thực hiện theo thứ tự được viết ra nhưng trong
LabVIEW chương trình được thực hiện theo nguyên tắc dataflow tức là các
node sẽ thực hiện khi tất cả các đầu vào của nó đã sẵn sàng. Tuy nhiên thỉnh
thoảng, vẫn cần phải thực hiện một node trước một node khác. Để điều khiển
việc này G sử dụng cấu trúc Sequence như một phương thức để thực hiện các
node theo thứ tự. Trong cấu trúc này G sẽ thực hiện các node trong sơ đồ của
frame 0 rồi đến frame1, cứ thế cho tới frame cuối cùng thì dữ liệu mới được gửi
ra ngoài.
Hình 1-27. Cấu trúc Case và Sequence
Hình 1-28. Cấu trúc Case
Selection
Terminal
(Selector)
VNArmy
17
Để thêm frame vào cấu trúc, kích chuột phải vào viền của frame và chọn
Add Frame After hoặc Add Frame Before. Hình 1-29 minh hoạ cấu trúc
Sequence.
Để gửi dữ liệu từ frame này sang frame sau nó có thể sử dụng Sequence
Local. Để tạo Sequence Local kích chuột phải vào viền của frame và chọn Add
Sequence Local.
4. Formula node.
Hình 1-30 minh hoạ một node công thức trong LabVIEW. Với node công
thức, ta có thể nhập vào một hay nhiều công thức đơn giản hay phức tạp thay vì
tạo những sơ đồ con cồng kềnh. Để nhập công thức vào sử dụng Label tool. Cần
chú ý rằng cuối mỗi công thức phải có dấu chấm phảy (;). Để tạo các đầu vào
hay đầu ra cho node công thức, kích chuột phải vào biên của node và chọn Add
Input hoặc Add Ouput và đánh tên biến vào. Các biến phân biệt chữ thường
với chữ hoa.
Hình 1-29. Cấu trúc Sequence
y= 4 *x^ 2 + 3 *x+ 1 ;
yx
Hình 1-30. Formula Node.
y=x^2+x+1;
VNArmy
18
Ví dụ về sử dụng cấu trúc.
Hình 1-31 minh hoạ Front Panel và Block Diagram của một chương trình
sử dụng các phần tử điều khiển luồng trong LabVIEW.
IV. Mảng.
1. Khái niệm chung.
Mảng là tập hợp của các phần tử dữ liệu có cùng kiểu. Mảng có kích
thước có thể thay đổi. Mảng có thể có một hoặc nhiều chiều và lên đến 231-1
phần tử mỗi chiều. Có thể truy cập vào mỗi phần tử qua chỉ số của nó. Chỉ số
của các phần tử trong mảng từ 0 đến n-1 với n là số phần tử của mảng. Phần tử
đầu tiên của mảng có chỉ số 0, phần tử thứ 2 có chỉ số 1 …
Hình 1-31.
VNArmy
19
2. Tạo các mảng.
Có thể tạo mảng của các control hay indicator trên Front Panel bằng cách
lấy vỏ mảng từ Control >>Array & Cluster đặt lên Front Panel. Sau đó chọn
đối tượng cần tạo mảng (chẳng hạn kiểu Boolean) đặt vào trong vỏ mảng. Khi
đó sẽ tạo ra mảng của các đối tượng kiểu Boolean. Tương tự nếu ta chọn vỏ
mảng trong Functions >> Array rồi đặt đối tượng vào ta cũng có thể tạo ra
mảng các hằng số theo kiểu vừa chọn ở trên Block Diagram.
3. Tự động ghi chỉ mục.
Các vòng lặp For và While có thể ghi chỉ mục và tích luỹ các mảng ở biên
của nó một cách tự động. Khả năng tích luỹ này được gọi là auto-indexing. Khi
cho phép khả năng này và nối một mảng hoặc một chiều bất kì của mảng vào
đường hầm đầu vào ở biên vòng lặp thì các thành phần của mảng đó nạp vào
vòng lặp mỗi lần một thành phần, bắt đầu từ thành phần đầu tiên. Vòng lặp đặt
chỉ mục cho các phần tử vô hướng từ mảng một chiều và mảng một chiều từ
mảng hai chiều. Tương tự như đối với đường hầm đầu ra, vòng lặp sẽ tích luỹ
các phần tử vào mảng một chiều và mảng một chiều vào mảng hai chiều …
4. Sử dụng các hàm xử lí mảng.
G có nhiều hàm để thực hiện trên mảng được đặt trong
Functions>>Array. Sau đây sẽ giới thiệu một số hàm thông dụng.
a) Build Array.
Hàm Build Array có một hay nhiều đầu vào và một đầu ra. Trong đó, đầu
vào có thể là kiểu mảng hay vô hướng. Hàm Build Array gán các mảng array và
phần tử element ở đầu vào của hàm theo thứ tự từ trên xuống thành mảng array
with appended element(s). Để tạo mảng có n chiều thì các đầu vào array phải
có cùng n chiều và các phần tử element phải có n-1 chiều.
b) Initialize Array.
Tạo mảng n chiều trong đó các phần tử của mảng có cùng giá trị của đầu
vào element và chiều thứ i có số phần tử là dimention i-1.
c) Array Size.
Hàm Array Size trả lại số phần tử trong mỗi chiều của mảng.
d) Array Subset.
VNArmy
20
Hàm Array Subset được dùng để trích ra một phần của mảng hoặc ma
trận. Hàm này sẽ trả lại một phần của mảng bắt đầu từ vị trí index và bao gồm
length phần tử. Chú ý rằng chỉ mục của mảng bắt đầu từ 0.
e) Index Array.
Hàm Index Array sử dụng để truy nhập vào phần tử của mảng. Hàm này
còn được sử dụng để cắt mảng nhiều chiều thành một mảng con của mảng gốc.
Để cắt mảng thực hiện theo các bước sau:
- Kéo hàm Index Array để nó chứa thêm các đầu vào index. Số các đầu vào
này bằng với số chiều của mảng đầu vào.
- Số các chiều của phần lấy ra bằng với số các đầu vào index ở chế độ
Disable Indexing. Muốn chọn Disable Indexing thì kích chuột phải vào đầu
vào index và chọn Disable Indexing từ thực đơn pop-up. Ví dụ, muốn lấy ra
phần tử vô hướng thì không chọn cho đầu vào index nào, muốn lấy ra mảng
một chiều thì cho một đầu vào index ở chế độ Disable Indexing, muốn lấy ra
mảng hai chiều thì cho hai đầu vào index ở chế độ Disable Indexing…
- Các đầu vào index còn lại được nối với giá trị sẽ xác định giá trị của chiều
cần lấy ra. Ví dụ đối với mảng 2 chiều nếu nối đầu vào này với 2 thì sẽ lấy ra
được mảng 1 chiều là cột hoặc hàng tuỳ vào đầu vào ở chế độ Disable
Indexing là thứ nhất hay thứ hai.
Để tham khảo thêm về các hàm xử lý mảng xem thêm trong Online Help
của nó.
Ví dụ về sử dụng mảng.
Hình 1-32
VNArmy
21
Hình 1-32 minh hoạ về việc sử dụng mảng và các hàm xử lý mảng trong
LabVIEW. Hàm Build Array xây dựng một mảng 3 chiều từ 3 mảng 2 chiều.
Hàm Index Array lấy mảng 2 chiều ra từ mảng 3 chiều.
V. Cluster.
1.Khái niệm chung.
Cluster là một kiểu dữ liệu mà có thể bao gồm các phần tử có kiều dữ liệu
khác nhau. Khi dùng cluster, subVI yêu cầu số đầu nối ít hơn. Kiểu dữ liệu
cluster có thể so sánh như kiểu bản ghi trong Pascal và kiểu cấu trúc trong C.
Khác với mảng, cluster có kích thước không đổi. Cũng giống như mảng, cluster
cũng có thể là control hay indicator nhưng cluster không thể chứa cả control và
indicator. Hai cluster chỉ có thể nối với nhau khi các phần tử tương ứng có cùng
kiểu. Hai phần tử tương ứng là hai phần tử có cùng thứ tự trong cluster.
2. Tạo cluster.
Để tạo cluster vào Control>>Array & Cluster và đặt vỏ cluster lên Front
Panel. Sau đó đặt các phần tử vào cluster như đối với mảng. Thứ tự đặt phần tử
vào cluster sẽ qui định thứ tự của phần tử trong cluster. Nếu muốn thay đổi thứ
tự của cluster, kích chuột phải vào cluster và chọn Cluster Order… trong thực
đơn pop-up của nó.
3. Các hàm xử lý đối với Cluster.
Để lắp ráp cluster có 3 hàm là:Bundle và Bundle By Name để lắp ráp
cluster từ những phần tử riêng biệt còn Array To Cluster chuyển mảng thanh
cluster. Tương ứng với các hàm này là 3 hàm tháo rỡ cluster là: Unbundle và
Unbundle By Name để tháo cluster thành các phần tử riêng biệt còn Cluster To
Array để chuyển cluster của các phần tử cùng kiểu thành mảng. Có thể truy cập
vào các hàm này từ Functions >> Cluster. Có thể tham khảo thêm về các hàm
của cluster trong Online Help của nó.
VI. Graph và Chart.
1. Khái niệm chung.
Graph là một thể hiện hai chiều của một hay nhiều đồ thị. Graph nhận dữ
liệu theo khối. Chart cũng thể hiện các đồ thị nhưng chart nhận và cập nhật dữ
liệu từ điểm tới điểm hay mảng tới mảng, giữ lại một chút các điểm trước trong
vùng đệm với mục đích biểu diễn. Có 3 loại graph và 2 loại chart ở trong
Controls >> Graph là: Waveform Graph, XY Graph, Intensity Graph và
Waveform Chart, Intensity Chart.
2. Waveform Graph và XY Graph.
Waveform Graph để biểu diễn các giá trị được lấy mẫu như nhau. XY
Graph có thể biểu diễn bất kì tập các điểm nào dù nó có được lấy mẫu như nhau
không. Waveform Graph chỉ vẽ được các hàm đơn trị với các điểm được phân
bố như nhau dọc theo trục x. XY Graph có thể vẽ được các hàm đa trị. Để vẽ
được đồ thị thì bạn phải có kiểu dữ liệu riêng cho mỗi đồ thị.
a) Vẽ đồ thị đơn.
* Các kiểu dữ liệu cho Waveform Graph.
VNArmy
22
Có 2 kiểu dữ liệu cho Waveform Graph là:
1) Dữ liệu kiểu mảng của các giá trị. Graph sẽ đối xử như các điểm và
tăng lên 1 bắt đầu từ x=0.
2) Dữ liệu là một cluster gồm một giá trị khởi tạo x0, giá trị Δx và một
mảng dữ liệu y.
* Các kiểu dữ liệu cho XY Graph.
Có 2 kiểu dữ liệu cho XY Graph là:
1) Dữ liệu là một cluster chứa một mảng dữ liệu x và một mảng dữ liệu y.
2) Dữ liệu là một mảng các điểm mà mỗi điểm là một cluster của x và y.
b) Vẽ nhiều đồ thị.
* Các kiểu dữ liệu cho Waveform Graph.
Có 5 kiểu dữ liệu cho Waveform Graph là:
1) Kiểu dữ liệu là một mảng hai chiều mà mỗi hàng là một đồ thị như
trong trường hợp vẽ đơn đồ thị. Để chuyển thành mỗi cột biểu diễn
một đồ thị có thể chọn Transpose Array trong thực đơn pop-up của
graph.
2) Dữ liệu là một cluster của một giá trị khởi tạo x, một giá trị Δx và một
mảng 2 chiều y.
3) Kiểu dữ liệu thứ 3 là một mảng của các cluster. Các cluster này chứa
một mảng dữ liệu y. Mảng bên trong mô tả các điểm trong một đồ thị
còn mảng bên ngoài chứa mỗi phần tử ứng với một đồ thị. Kiểu dữ liệu
này rất hữu dụng khi số lượng các phần tử trong mỗi đồ thị là khác
nhau.
4) Kiểu dữ liệu thứ 4 là một cluster của một giá trị x, một giá trị Δx và
một mảng cluster của mảng dữ liệu y.
5) Kiểu dữ liệu thứ 5 là một mảng của các cluster. Mỗi cluster gồm có
một giá trị x, một giá trị Δx và một mảng dữ liệu y.
* Kiểu dữ liệu cho XY Graph.
Có 2 kiểu dữ liệu cho XY Graph là:
1) Mảng các cluster chứa các đồ thị mà mỗi đồ thị là mảng của các điểm.
Mỗi điểm là 1 cluster chứa một giá trị x và một giá trị y.
2) Mảng các cluster chứa các đồ thị mà mỗi đồ thị là một cluster của một
mảng x và một mảng y.
3. Waveform Chart.
Chart khác với graph ở chỗ nó giữ lại các giá trị cũ, lên đến một giá trị mà
ta có thể xác định. Giá trị mới được gắn thêm vào với giá trị cũ để bạn có thể
thấy được giá trị mới trong mạch với giá trị trước đó.
* Kiểu dữ liệu của Waveform Chart.
Có thể gửi cho chart một giá trị hay nhiều giá trị cùng lúc. Chart sẽ quản
lý mỗi giá trị như một phần của dạng sóng cách đều, với mỗi điểm cách điểm
trước đó một điểm theo trục x.
Có thể gửi một giá trị vô hướng hay một mảng cho đồ thị đơn. Chart sẽ
đối xử với chúng như giá trị mới cho đồ thị đơn.
VNArmy
23
Có nhiều cách để gửi dữ liệu cho đa đồ thị. Có thể gửi qua một hay một
mảng cluster của các số vô hướng mà mỗi số biểu diễn một điểm trên đồ thị.
Cũng có thể gửi một mảng 2 chiều cho chart trong đó mỗi hàng sẽ cập nhật cho
một đồ thị. Có thể cho mỗi cột sẽ cập nhật cho một đồ thị bằng cách chọn
Transpose Array từ thực đơn pop-up của chart.
4. Intensity Chart và Intensity Graph.
LabVIEW có hai cách để biểu diễn các mảng dữ liệu 3 chiều: Intensity
Graph và Intensity Chart. Cả hai đồ thị này cũng chấp nhận mảng 2 chiều của
các số mà mỗi số được gắn với một màu.
Ví dụ về sử dụng graph và chart.
Hình 1-33 minh hoạ việc sử dụng graph và chart trong LabVIEW. Chương trình
gửi cho chart từng giá trị một và gửi dữ liệu cho graph theo kiểu cluster của
phần tử khởi tạo X0, Delta X và mảng dữ liệu Y.
VII. Chuỗi.
1. Khái niệm chung.
Hình 1-33.
VNArmy
24
Chuỗi là một tập các kí tự ASCII. Chuỗi có ứng dụng rất rộng rãi. Trong
điều khiển thiết bị, có thể gửi dữ liệu đi như một chuỗi kí tự và sau đó lại chuyển
các chuỗi nhận về thành các số. Khi lưu trữ giữ liệu trước tiên phải chuyển dữ
liệu thành các chuỗi sau đó lưu vào tệp ASCII.
2. Tạo các control và indicator kiểu chuỗi.
Có thể tạo các control và indicator kiểu chuỗi từ Control >> String &
Table. Để nhập hay thay đỗi văn bản bên trong control kiểu chuỗi băng
Operating Tool hay Label Tool. Để tiết kiệm không gian, ta có thể cho chuỗi
hiện thanh scrollbar bằng cách chọn Show >> Scrollbar trong thực đơn pop-up
của nó. Bình thường mục này bị mờ. Để cho nó hiện lên có thể sử dụng
Positioning Tool kéo đủ dài control hay indicator ra.
3. Các hàm xử lý chuỗi.
a)Hàm Format Into String.
Hàm Format Into String chuyển đổi các tham số đầu vào thành chuỗi
result string với việc định dạng nó theo tham số format string. Tham số định
dạng có thể tham khảo trong Online help.
b) Hàm String Length.
Hàm này trả lại số kí tự của chuỗi string trong length.
c) Hàm String Subset.
Hàm String Subset trả lại chuỗi substring được cắt ra từ chuỗi string bắt
đầu từ offset và chứa length kí tự. Offset đối với kí tự đầu tiên là 0.
d) Hàm Scan From String.
Hàm này quét input string và chuyển đổi theo tham số định dạng format
string.
VNArmy
25
Ví dụ về việc sử dụng string trong LabVIEW.
VIII. Tệp.
1. Khái niệm chung.
Các hàm vào ra tệp trong G (Functions>>File I/O) là các công cụ mạnh
và linh hoạt để làm việc với các tệp. Cùng với việc đọc và ghi dữ liệu, hàm vào
ra tệp trong LabVIEW có thể di chuyển và đổi tên các tệp và các thư mục, tạo
các tệp kiểu bảng biểu ASCII, có thể đọc và ghi dữ liệu kiểu nhị phân để tăng
tốc độ và nén tối thiểu.
Có 3 loại tệp khác nhau trong LabVIEW:
- ASCII Byte Stream - Nên lưu trữ dữ liệu dạng ASCII khi muốn truy
cập nó từ gói phần mêm khác như xử lý từ hoặc chương trình bảng
biểu. Để lưu dữ liệu dạng này cần phải chuyển đổi tất cả dữ liệu thành
chuỗi ASCII.
- Tệp Datalog - Những tệp này ở dạng nhị phân mà chỉ G mới có thể
truy nhập được. Datalog tương tự như các tệp cơ sở dữ liệu vì có thể
cất nhiều kiểu dữ liệu khác nhau vào một bản ghi của tệp.
- Binary Byte Stream - Những tệp kiểu này là phương thức lưu trữ dữ
liệu nén chặt nhất và nhanh nhất. Cần chuyển đổi dữ liệu thành dạng
chuỗi nhị phân và phải biết chính xác kiểu dữ liệu nào đang đưọc sử
dụng để lưu trữ vào hay phục hồi lại từ tệp.
2. Các hàm vào ra tệp.
Hầu hết các hoạt động vào ra tệp bao gồm 3 bước cơ bản: mở một tệp
đang có hoặc tạo tệp mới; ghi vào hoặc đọc ra từ tệp; đóng tệp. Do đó LabVIEW
Hình1-34
VNArmy
26
bao gồm nhiều VI tiện ích trong Functions>>File I/O. Phần này sẽ mô tả các
tiện ích mức cao. Những hàm này được xây dựng trên các VI mức trung gian mà
kết hợp chặt chẽ việc kiểm tra và điều khiển lỗi với các hàm vào ra tệp.
a) Write Characters To File VI.
VI này ghi một chuỗi kí tự character string vào một tệp kiểu byte stream
mới hoặc nối thêm chuỗi vào một tệp đang có. VI này mở hoặc tạo tệp, ghi dữ
liệu và sau đó đóng tệp.
b) Read Characters From File VI.
VI này đọc một lượng kí tự từ một tệp kiểu byte stream bắt đầu tư cự ly
xác định. VI này mở hoặc tạo tệp và sau đó đóng tệp.
c) Read Lines From File VI.
VI này đọc một lượng xác định các dòng từ một tệp kiểu byte stream bắt
đầu tư cự ly xác định. VI này mở hoặc tạo tệp và sau đó đóng tệp.
d) Write To Spreadsheet File VI.
Chuyển đổi một mảng 1 hoặc 2 chiều của các số chính xác đơn thành
chuỗi văn bản và ghi chuỗi vào tệp kiểu byte stream hoặc nối thêm vào tệp đã
có. Có thể chuyển vị dữ liệu tuỳ ý. VI này mở hoặc tạo tệp và sau đó đóng tệp.
Có thể dùng VI này để tạo một tệp văn bản có thể đọc bởi hầu hết các chương
trình bảng tính.
e) Read From Spreadsheet File VI.
VNArmy
27
Đọc một lượng xác định các dòng hoặc cột từ một tệp văn bản kiểu số ở
cự ly xác định và chuyển dữ liệu thành mảng 2 chiều kiểu số chính xác đơn. Có
thể chuyển vị dữ liệu tuỳ ý. VI này mở tệp trước khi đọc và sau đó đóng tệp. Có
thể dùng VI này để đọc tệp bảng biểu lưu dưới dạng văn bản.
Ví dụ về sử dụng tệp trong LabVIEW.
Trong ví dụ có sử dụng hàm Write Spreadsheet File để ghi một mảng 2
chiều sang một tệp mà có thể truy nhập bởi các chương trình bảng tính như
Excel chẳng hạn. Việc này cũng tạo điều kiện cho LabVIEW giao tiếp với ngôn
ngữ khác. Hình 1-35 minh hoạ Front Panel và Block Diagram của chương trình.
Hình 1-35.
VNArmy
28
§1.2.LẬP TRÌNH NÂNG CAO TRÊN LABVIEW.
I. Biến đổi Fourier rời rạc.
1. Khái niệm chung.
Khi lấy mẫu tín hiệu, các mẫu của tín hiệu tạo thành sự biểu diễn miền
thời gian của tín hiệu. Sự biểu diễn này đưa ra các biên độ của tín hiệu ở các
khoảng thời gian nó được lấy mẫu. Tuy nhiên, trong nhiều trường hợp ta lại
quan tâm đến tần số của tín hiệu hơn là biên độ của các mẫu. Sự biểu diễn tín
hiệu theo tấn số được gọi là sự biểu diễn theo miền tần số của tín hiệu. Sự biểu
diễn miền tần số có thể cho biết bản chất bên trong của tín hiệu và hệ thống tạo
ra tín hiệu.
Để chuyển các mẫu dữ liệu từ miền thời gian sang miền tần số có thể
dùng thuật toán biến đổi Furier rời rạc - Discrete Fourier Transform (DFT).
Thuật toán DFT thiết lập mối liên quan giữa các mẫu của một tín hiệu trong
miền thời gian và sự biểu diễn của chúng trong miền tần số. Thuật toán DFT
được ứng dụng rộng rãi trong phân tích phổ, cơ học ứng dụng, viễn thông …
Biến đổi Fourier nhanh.
Thuật toán DFT xử lý N mẫu với độ phức tạp thuật toán xấp xỉ N2. Nếu N
là một số luỹ thừa của 2 (N=2m) thì độ phức tạp thuật toán xấp xỉ NlnN. Như
vậy thuật toán DFT có thể tính nhanh hơn và gọi là biến đổi nhanh Fourier - Fast
Fourier Transform (FFT).
Ưu điểm của thuật toán FFT là tốc độ và bộ nhớ vì nó có thể tính FFT
trực tiếp tức là không phải có thêm bộ nhớ đệm. Tuy nhiên, nó chỉ áp dụng được
khi độ dài của dãy là luỹ thừa của 2. Thuật toán DFT có thể áp dụng với dãy có
độ dài bất kì nhưng nó lại chậm hơn và dùng nhiều bộ nhớ hơn vì phải cấp phát
bộ đệm phụ để lưu các kết quả trung gian trong quá trình thực hiện.
Một kĩ thuật thường được dùng để làm đầu vào có số phần tử là luỹ thừa
của 2 là thêm các điểm 0 vào cuối của dãy đầu vào. Việc thêm vào này không
làm ảnh hưởng đến phổ của tín hiệu.
Thư viện phân tích của LabVIEW có 2 VI tính FFT của tín hiệu là Real
FFT VI và Complex FFT VI. Trong đó, Real FFT VI tính FFT của tín hiệu thực
còn Complex FFT VI tính giá trị của tín hiệu phức.
2. Các VI xử lí tín hiệu.
a)Các VI miền tần số.
Hình 2-1 minh hoạ các VI miền tần số. Để lấy các VI miền tần số có thể
truy nhập vào Functions>>Signal Processing>>Frequency Domain. Các VI
miền tần số gồm có:
Buneman Frequency Estimator, Power Spectrum, Cross Power, Complex
FFT, Real FFT, Inverse Real FFT, Inverse Complex FFT, STFT Spectrogram,
Fast Hilbert Transform, Inverse Fast Hilbert Transform Unevenly Sampled
Signal Spectrum, FHT, Inverse FHT,Walsh Hadamard,Walsh Hadamard
Inverse, WVD Spectrogram, Laplace Transform Real, Wavelet Transform
Daubechies4, Wavelet Transform Daubechies4 Inverse.
VNArmy
29
Để tham khảo thêm về các VI này có thể xem thêm trong Help Online
của chúng.
b) Các VI miền thời gian.
Hình 2-2 minh hoạ các VI miên thời gian. Để truy cập vào các VI này vào
Functions>>Signal Processing>>Time Domain. Các VI miền thời gian gồm
có:AutoCorrelation, Convolution, CrossCorrelation, Decimate, Deconvolution,
Derivative x(t), Integral x(t), Unwrap Phase, Y[i] = Clip, {X[i]}, Y[i] = X[i-n],
Zero Padder.
II. Các bộ lọc số- Digital Filter.
1. Giới thiệu về các bộ lọc số.
Các bộ lọc tương tự là một phần quan trong trong khi thiết kế mạch. Các
công cụ lấy mẫu và xử lý tín hiệu số hiện đại khiến nó có thể được thay thế bằng
các bộ lọc số trong các ứng dụng đòi hỏi sự linh hoạt và lập trình được. Các bộ
lọc số tiên tiến hơn những bộ lọc tương tự ở các điểm sau:
- Chúng là các phần mềm có thể lập trình.
- Chúng ổn định và có thể dự đoán được.
- Chúng không bị trôi bởi nhiệt độ và độ ẩm và không yêu cầu phải có
các thành phần chính xác.
2. Các bộ lọc IIR và FIR.
Sự phân biệt giữa IIR và FIR là dựa trên đáp ứng xung của nó. Các bộ lọc
IIR là các bộ lọc có đáp ứng xung vô hạn còn các bộ lọc FIR có đáp ứng xung
hữu hạn. Đáp ứng xung là hữu hạn hay vô hạn là dựa vào cách tính toán ở đầu
ra. Các bộ lọc FIR có đầu ra chỉ phụ thuộc vào giá trị đầu vào hiện tại còn IIR
thì không những phụ thuộc vào đầu vào hiện tại mà còn phụ thuộc vào các đầu
ra trước đó. Vì vậy bộ lọc IIR còn gọi là các bộ lọc đệ qui còn FIR là các bộ lọc
không đệ qui.
Nhược điểm của các bộ lọc IIR là đáp ứng pha của chúng là phi tuyến.
Nếu ứng dụng không yêu cầu thông tin về pha thì có thể dùng IIR.
a) Bộ lọc IIR.
Bộ lọc IIR là các bộ lọc có đáp ứng xung về lý thuyết là vô hạn. Phương
trình sai phân của chúng có dạng như sau:
Hình 2-1. Các VI miền tần số. Hình2-2. Các VI miền thời gian.
VNArmy
30
⎟⎟
⎟
⎠
⎞
⎜⎜
⎜
⎝
⎛
∑
−
= −∑
−
= −−=
1
1
1
00
1 a
N
k ki
yka
bN
j ji
xjbai
y
Bộ lọc IIR trong LabVIEW có các đặc điểm sau:
- Các chỉ số âm mà là kết quả của phương trình (*) được giả sử bằng 0 ở
lần đầu gọi VI.
- Vì trạng thái khởi tạo được giả thiết bằng 0 (với các chỉ số âm) nên quá
trình quá độ diễn ra trước khi bộ lọc ổn định sẽ tỉ lệ với bậc (order) của bộ
lọc. Sự tồn tại của đáp ứng quá độ hay thời gian giữ chậm (Delay) đối với
các bộ lọc thông cao và thông thấp bằng với bậc bộ lọc (Delay=order).
- Thời gian tồn tại của quá trình quá độ đối với bộ lọc dải thông và dải chặn
bằng 2 lần bậc của bộ lọc (Delay=2*order).
- Có thể loại bỏ đáp ứng quá độ ở lần gọi kế tiếp bằng cách đặt bộ nhớ
trạng thái hoạt động. Để thực hiện đặt init/cont control của VI bằng TRUE.
Ưu điểm của bộ lọc này là bộ lọc yêu cầu ít hệ số hơn để thực hiện. Do đó
bộ lọc hoạt động nhanh hơn và không yêu cầu vùng nhớ mở rộng.
Nhược điểm của bộ lọc là đáp ứng pha của nó là phi tuyến.
LabVIEW có các bộ lọc IIR sau:
- Các bộ lọc Butterworth: Đáp ứng tần số của bộ lọc là đáp trơn ở tất cả các
tần số và giảm đơn điệu từ tần số cắt. Bộ lọc Butterworth là trơn tối đa - đáp
ứng lý tưởng bằng 1 ở dải thông và bằng 0 ở dải chặn. Ưu điểm của nó là có
đáp ứng tần số trơn và giảm đơn điệu. Sau khi đặt tần số cắt, LabVIEW sẽ
đặt độ dốc của quá trình quá độ tỉ lệ với bậc của bộ lọc. Bộ lọc bậc càng cao
thì càng tiến tới bộ lọc thông thấp lí tưởng.
- Các bộ lọc Chebyshev: Các bộ lọc Chebyshev giảm tối thiểu đỉnh lỗi ở
dải thông. Đặc tuyến của đáp ứng tần số có đáp ứng biên độ lớn ở dải
thông, giảm đơn điệu biên độ ở dải chặn và có vùng chuyển tiếp sắc hơn bộ
lọc Butterworth. Điều này khiến sai số tuyệt đối nhỏ hơn và tốc độ thực
hiện nhanh hơn.
- Bộ lọc Chebyshev II hay còn gọi là bộ lọc Chebyshev đảo: bộ lọc này
tương tự như bộ lọc Chebyshev nhưng có phân bố sai số trên dải chặn và có
sự bằng phẳng nhất ở dải thông.
- Bộ lọc Eliptic (Cauer): các bộ lọc loại này giảm tối đa các sai số đỉnh
bằng cách phân bố chúng trến khắp dải thông và dải chắn. So với các bộ
lọc Butterworth và Chebyshev cùng bậc thì bộ lọc Eliptic có quá trình QUá
độ giữa dải thông và dải chặn là sắc nhất. Vì vậy, nó được dùng rộng rãi.
- Bộ lọc Bessel: có thể dùng để giảm sự méo pha phi tuyến vốn có trong
các bộ lọc IIR. Ở các bộ lọc bậc cao hơn và với vùng gấp dốc hơn thì méo
pha càng rõ nét đặc biệt ở vùng quá độ của bộ lọc. Bộ lọc này có đặc tuyến
trơn tối đa ở cả pha và biên độ. Đặc tuyến pha ở dải thông của bộ lọc thì
gần như tuyến tính. Cũng giống như bộ lọc Butterworth, bộ lọc Bessel đòi
hỏi bộ lọc bậc cao để giảm sai số, vì vậy nó ít được dùng.
b)Bộ lọc FIR.
(*)
VNArmy
31
Các bộ lọc đáp ứng xung hữu hạn FIR là các bộ lọc số mà có đáp ứng
xung là hữu hạn. Các bộ FIR cũng gọi là các bộ lọc không đệ qui. Phương trình
sai phân của bộ lọc là:
∑−= −=
1
0
n
k ki
xkhiy
Trong đó x biểu diễn dãy đầu vào, y biểu diễn dãy đầu ra, h biểu diễn hệ
số bộ lọc.
Các bộ lọc FIR có các đặc điểm quan trọng sau:
- Chúng có thể đạt được pha tuyến tính bởi sự đối xứng của hệ số.
- Chúng luôn ổn định.
- Có thể thực hiện các hàm lọc dùng tương quan chéo và nói chung luôn
gắn một khoảng trễ với dãy đầu ra.
2
1−= nDelay với n là số hệ số của bộ lọc FIR.
Có thể truy cập vào các bộ lọc trong LabVIEW bằng cách chọn
Functions>> Signal Processing>>Filters. Hình 2-3 minh hoạ các bộ lọc trong
LabVIEW.
III. Tổng quan về VISA.
1. Khái niệm về VISA.
VISA (Virtual Instrument System Architecture) là một chuẩn vào/ra giao
diện chương trình ứng dụng (API) cho thiết bị lập trình được. VISA tự bản thân
nó không cung cấp khả năng lập trình thiết bị mà là một API mức cao mà có thể
gọi đến các driver mức thấp hơn. Sự phân cấp của NI-VISA như hình sau:
VISA có thể điều khiển các thiết bị theo chuẩn VXI, GPIB, hoặc Serial.
Bởi vì VISA là một công nghệ chuẩn để phát triển các trình điều khiển thiết bị,
Hình 2-3. Các bộ lọc trong LabVIEW.
Hình 3-2. Sự phân cấp của VISA API
VNArmy
32
nên hiện tại có rất nhiều instrument driver được viết bởi hãng National
Instrument trên VISA và được hỗ trợ trên nền Windows, Macintosh, HP-UX,..
2. Điểm mạnh của VISA.
- Được chuẩn hoá: VISA là một API chuẩn để xây dựng các trình điều khiển
thiết bị. Bạn chỉ cần sử dụng một API để điều khiển các thiết bị có kiểu
khác nhau, có thể theo chuẩn VXI, GPIB, hoặc serial.
- Có giao diện độc lập: VISA sử dụng các hoạt động tương tự nhau để kết
nối với thiết bị mà không cần quan tâm tới kiểu giao diện của chúng. Lấy
một ví dụ, VISA viết một xâu ASCII (một message-based) tới một thiết bị
thì lệnh này là chung cho tất cả các kiểu thiết bị (VXI, GPIB, serial). Điều
này làm cho việc chuyển đổi bus giao diện trở nên dễ dàng. Bạn chỉ cần
biết một kiểu API là đã có thể sử dụng nó cho các kiểu giao diện khác
nhau.
- Nền độc lập: VISA được thiết kế để có thể hoạt động dễ dàng trên các hệ
điều hành khác nhau. Để đảm bảo sự độc lập khi hoạt động VISA đã định
nghĩa một cách rất cẩn thận các kiểu dữ liệu của nó. Bởi vậy các kích cỡ, số
byte của biến do các HĐH quy định không làm ảnh hưởng đến chương
trình VISA. Các hàm của VISA gọi và liên kết các tham số của chúng là
như nhau trên tất cả các nền. Nó có thể chạy trên các HĐH khác nhau mà
không cần phải biên dịch lại.
- Tính tương thích cao: một lợi thế khác của VISA là nó dễ dàng tương thích
với các giao diện thiết bị mới sẽ được phát triển trong tương lai.
Có thể nói VISA là một công cụ điều khiển phần mềm hiệu quả để tận
dụng, phát huy và nâng cao các thế mạnh phần cứng của thiết bị.
3. Các thành phần cơ bản của VISA:
Cấu trúc đơn giản của một VISA API như sau:
a) Default Resource Manager.
Hình 3-3. Cấu trúc VISA API.
VNArmy
33
Default Resource Manager ở mức cao nhất của hoạt động VISA.
LabVIEW sẽ tự động tổ chức việc trao đổi thông tin với Default Resource
Manager ở lần gọi VISA VI đầu tiên. Default Resource Manager sẽ quản lý tài
nguyên và phiên kết nối.
Tài nguyên (resource) là một đối tượng mà bạn có thể trao đổi thông tin
với nó. Resource có thể là thiết bị (INSTR) hoặc memory access (MEMACC).
Phiên kết nối (session) là một sự kết nối tới một resource đang tồn tại.
Session được VISA sử dụng để mở một phiên làm việc với thiết bị. Có thể chọn
kiểu thiết bị trong session (GPIB, VXI, GPIB-VXI, serial, hoặc all INSTR) song
cần lưu ý khi đã chọn duy nhất một kiểu thiết bị (chẳng hạn Serial) thì không thể
mở một kiểu thiét bị khác. Do vùng nhớ dành cho session có hạn nên mỗi khi
thao tác xong ta cần phải đóng phiên làm việc lại.
Để xác định tài nguyên phải dùng bộ mô tả thiết bị (instrument
descriptor). Instrumnet descriptor có cú pháp như sau:
Interface Type[board index]::Address::VISA Class
Interface Type đặc trưng cho từng kiểu thiết bị (GPIB, VXI, hoặc serial).
Đối với các thiết bị sử dụng chuẩn GPIB hoặc VXI thì board index dùng để xác
định số card giao tiếp gắn trên main board.
Với thiết bị VXI thì address được hiểu là địa chỉ logic còn với thiết bị
GPIB thì đó là địa chỉ phụ (primary address). Lấy ví dụ một máy tính có hai card
GPIB gắn trên main board thì địa chỉ của một thiết bị nối với card thứ nhất sẽ là:
GPIB0::0::INSTR. Thiết bị Serial không sử dụng Address. Ví dụ
ASRL2:INSTR sẽ mô tả cổng COM2.
VISA class là một lớp mà đón gói một vài hoặc tất cả các hoạt động VISA
cho một thiết bị hoặc sự kiện. Lớp chung nhất là INSTR bao gồm tất cả các thao
tác VISA cho một thiết bị. Nếu VISA Class để trống thì nó sẽ mặc định là lớp
INSTR.
b) Communication.
VISA cung cấp hai kiếu giao thức để trao đổi thông tin với thiết bị, đó là
phương thức thông báo (Message-Based)-hỗ trợ cho tất cả các kiểu thiết bị theo
chuẩn GPIB, VXI, Serial và phương thức thanh ghi (Register-Based)-chỉ cho
các thiết bị VXI. Trong giới hạn của đề tài chúng ta sẽ quan tâm tới các thiết bị
Message-Based device.
Với giao thức Message-Based chương trình sẽ gửi một thông báo lệnh tới
hoặc nhận một thông báo dữ liệu từ message-based device. Các thông báo lệnh
(command-string) mà chương trình gửi tới thiết bị là các tập lệnh riêng của từng
thiết bị do nhà sản xuất cung cấp. Đó có thể là lệnh đặt cấu hình hoặc lệnh yêu
cầu gửi dữ liệu. Các thông báo nhận được từ thiết bị có thể là các yêu cầu phục
vụ (SQR) hoặc dữ liệu dưới dạng string. Chương trình sẽ sử dụng các hàm
chuyển đổi xâu-số để chuyển dữ liệu về dạng số để xử lý tiếp.
c) VISA propertopies.
Là các thuộc tính của VISA resources mà ta có thể thiết lập hoặc nhận
được từ chương trình. Có thể kể ra sau đây một vài properties thường gặp:
Serial baud rate, Serial data bits, GPIB readdresing, GPIB unaddresing,
VXI logical address,.. Lưu ý rằng có một vài thuộc tính là thuộc tính chỉ đọc
(read only), do đó không thể thiết lập lại giá trị của chúng.
VNArmy
34
Ngoài ra còn có các VISA Events để lập trình theo sự kiện mà trong
khuôn khổ đề tài này không bàn đến
Các hàm VISA trong LabVIEW.
LabVIEW cung cấp sẵn một thư viện hàm để phối ghép và điều khiển
thiết bị thông qua chuẩn VISA. Để truy cập vào thư viện hàm này chọn
Function>>Instrument I/O>>VISA. Trong đó bạn có thể sử dụng các hàm
khởi tạo, đặt thuộc tính, các hàm VISA mức cao hoặc mức thấp…
Để tham khảo thêm có thể vào Online Help của chúng.
Hình 3-4. VISA functions
VNArmy
35
Chương2
Thiết bị đo thông minh HP34970A
I. Tập lệnh của máy HP34970A.
1. Một số qui ước.
Dấu [ ] biểu thị các tham số hay từ khoá là tuỳ chọn.
Dấu { } chứa các tham số chọn cùng với câu lệnh.
Dấu biểu thị các tham số mà bắt buộc phải thay bằng giá trị.
Dấu | để phân cách giữa các tham số.
2. Cách sử dụng danh sách quét (scanlist).
Hầu hết các câu lệnh của HP34970A đều có một scanlist đi kèm. Scanlist
có dạng (@scc). Trong đó, s là kí hiệu của khe cắm (100,200 hay 300) còn cc là
số hiệu của kênh. Có thể cấu hình scanlist gồm một hay nhiều kênh hay gồm
một dãy kênh. Ví dụ:
(@101) đặt scanlist là một kênh 01 của khe cắm 100.
(@101,203,305) đặt scanlist gồm 3 kênh 101,203 và 305.
(@101:110,204) đặt scanlist gồm các kênh từ 101 đến 110 và kênh 204.
3. Các lệnh đặt cấu hình kênh.
a) Cấu hình đo nhiệt độ.
CONFigure:TEMPerature
{TCouple},{B|E|J|K|N|R|S|T|DEF}
[,1[,|MIN|MAX|DEF}]] ,(@)
Ví dụ: CONF:TEMP TC,B,1,0.003,(@101,102,201)
Lệnh này đặt cấu hình cho các kênh trong scanlist đo nhiệt độ sử dụng cặp
nhiệt ngẫu với các kiểu cặp nhiệt ngẫu khác nhau (mặc định là kiểu J). Độ chính
xác của kênh được xác định bằng thông số resolution.
CONFigure:TEMPerature
{RTD|FRTD},{85|91|DEF}
[,1[,|MIN|MAX|DEF}]] ,(@)
Ví dụ: CONF:TEMP RTD,91,1,0.001,(@103,203)
Lệnh này đặt cấu hình cho các kênh trong scanlist đo nhiệt độ dùng 2-wire
RTD hay 4-wire RTD (FRTD). Tham số 85 và 91 tương ứng với α=0.00385 và
α=0.00391.
Đối với phép đo dùng FRTD thì thiết bị sẽ tự động cặp kênh thứ n và
kênh thứ n+10 (đối với 34901A) hoặc n+8 (đối với 34902A).
CONFigure:TEMPerature
{THERmistor},{2252|5000|10000|DEF}
[,1[,|MIN|MAX|DEF}]] ,(@)
Ví dụ: CONF:TEMP THER,10000,1,0.0001,(@101,102)
Lệnh này đặt cấu hình cho phép đo nhiệt độ dùng bộ biến đổi thermistor.
Mặc định là dùng thermistor 5KΩ.
b) Các lệnh đặt cấu hình đo điện áp.
CONFigure:VOLTage:DC
CONFigure:VOLTage:AC
VNArmy
36
[{|AUTO|MIN|MAX|DEF}
[,|MIN|MAX|DEF}],] (@)
Ví dụ: CONF:VOLT:DC AUTO,0.0003,(@101,103)
hoặc CONF:VOLT:AC AUTO,0.0003(@101,103)
Cấu hình các kênh trong scanlist để đo điện áp một chiều hoặc xoay
chiều.
c) Các lệnh đặt cấu hình đo điện trở.
CONFigure:RESistance
CONFigure:FRESistance
[{|AUTO|MIN|MAX|DEF}
[,|MIN|MAX|DEF}],] (@)
Ví dụ: CONF:RES (@101,102)
hoặc CONF:FRES (@101,102)
Cấu hình các kênh trong scanlist để đo điện trở. Lệnh với tham số RES sẽ
sử dụng phép đo 2-wire. Lệnh với tham số FRES sẽ sử dụng phép đo 4-wire và
thiết bị cũng tự động cặp đôi kênh n với n+10 (34901A) hoặc n+8 (34902A).
d) Các lệnh đặt cấu hình đo điện áp.
CONFigure:CURRent:DC
CONFigure:CURRent:AC
[{|AUTO|MIN|MAX|DEF}
[,|MIN|MAX|DEF}],] (@)
Ví dụ: CONF:CURR:DC (@121)
hoặc CONF:CURR:AC (@122)
Cấu hình các kênh trong scanlist để đo dòng điện một chiều hoặc xoay
chiều. Các phép đo dòng chỉ cho phép đo trên kênh 21 và 22 của HP 34901A
multiplexer module.
e) Các lệnh đặt cấu hình đo tần số và chu kì.
CONFigure:FREQuency
CONFigure:PERiod
[{|AUTO|MIN|MAX|DEF}
[,|MIN|MAX|DEF}],] (@)
Ví dụ: CONF:FREQ (@109,110)
CONF:PER (@111)
Cấu hình các kênh trong scanlist đo chu kì hay tần số.
f) Các lệnh đặt cấu hình đo tín hiệu số.
CONFigure:DIGital:BYTE (@)
Ví dụ: CONF:DIG:BYTE (@201)
Cấu hình thiết bị để đọc các kênh đầu vào số của khối multifunction
module mà được chỉ định trong scanlist. Dạng của kênh số đầu vào có dạng s01
và s02 với s là số của khe cắm. Nếu cho cả 2 kênh đầu vào số vào scanlist thì
thiết bị sẽ đọc từ cả 2 cổng trong cùng một lúc. Điều này cho phép gộp hai tín
hiệu 8-bit thành 1 tín hiệu 16-bit.
g) Các lệnh đặt cấu hình bộ đếm.
CONFigure:TOTalize {READ|RRESet} ,(@)
VNArmy
37
Ví dụ: CONF:TOT READ,(@203)
Cấu hình thiết bị đọc kênh bộ đếm trong multifunction module. Kênh
của bộ đếm có dạng s03 với s là số hiệu của khe cắm. Để bộ đếm không đặt lại
trong khi quét thì sử dụng tham số READ. Để đọc bộ đếm trong quá trình quét
và đặt lại bộ đếm về không sau khi đọc dùng tham số RRESet.
h) Lệnh hỏi cấu hình kênh.
CONFigure? [(@)]
Ví dụ: CONF? (@303)
Lệnh này hỏi về cấu hình của kênh và trả về một loạt các chuỗi. Chuỗi trả
về gồm một loạt các trường được phân cách bởi dấu phảy. Mỗi trường chứa các
tham số của kênh như chức năng, giới hạn, độ chính xác.
Ví dụ: "FRES +1.000000E+02,+3.000000E-04" ,
"TEMP TC,K,+1.000000E+00,+3.000000E-06"
4. Các lệnh đặt đặt cấu hình để thực hiện quét (scan).
Thiết bị HP34970A được gắn một đồng hồ số vạn năng để đọc dữ liệu. Để
thu được dữ liệu từ đồng hồ này, ta phải tạo một lần quét. Tập lệnh SCPI có hộ
trợ đối với việc thực hiện quét để có thể điều khiển từ máy tính. Từ máy tính có
thể đặt khoảng thời gian quét, số lần quét, độ dữ chậm của mỗi kênh…Các bước
thực hiện một lần quét gồm:
a) Đặt danh sách quét.
Mỗi lần quét chỉ thực hiện khi có danh sách quét (scanlist). Khi quét, máy
sẽ chỉ thực hiện quét qua các kênh có trong danh sách quét theo thứ tự tăng dần
từ khe 100 đến 300 còn các kênh khác bỏ qua. Để đặt scanlist có thể dùng lệnh
sau:
ROUTe:SCAN (@scanlist)
Ví dụ: ROUT:SCAN (@101:105,112,114)
Để hỏi về danh sách quét hiện tại sử dụng lệnh:
ROUTe:SCAN?
b) Đặt nguồn khởi động quét.
Mỗi khi có tín hiệu từ nguồn khởi động quét thiết bị sẽ thực hiện lần đảo
qua các kênh. Lệnh thực hiện của nó như sau:
TRIGger:SOURce {BUS|IMMediate|EXTernal|ALARm{1|2|3|4}|TIMer}
Có thể khởi động lần đảo qua này bằng lệnh phần mềm (tham số BUS),
thực hiện liên tục (tham số IMM), khởi động từ xung TTL bên ngoài (tham số
EXT), từ đồng hồ báo nguy (tham số ALAR) hoặc từ bộ đồng hồ bên trong
(tham số TIM). Mặc định là sử dụng tham số TIM.
Để hỏi về nguồn khởi động có thể dùng lệnh hỏi:
TRIGger:SOURce?
c) Đặt khoảng thời gian quét.
Sau mỗi lần đảo qua các kênh có thể đặt khoảng thời gian đợi bằng lệnh:
TRIGger:TIMer {|MIN|MAX}
Khoảng thời gian có thể đặt từ 0 giây đến 359 999 giây (99:59:59 giờ). Các
tham số MIN, MAX tương ứng với giá trị 0 và 359 999.
Để hỏi về khoảng thời gian quét dùng lệnh:
VNArmy
38
TRIGger:TIMer?
d) Đặt số lần quét.
TRIGger:COUNt {|MIN|MAX|INFinity}
Lệnh này sẽ đặt số lần đảo qua các kênh mà một lần quét thực hiện. Số lần
quét có thể đặt từ 1 đến 50 000 hoặc liên tục (tham số INF). Giá trị MIN=1 và
MAX=50 000.
Để hỏi về số lần đảo qua này có thể dùng lệnh:
TRIGger:COUNt?
e) Đặt khoảng thời gian trễ giữa các kênh.
ROUTe:CHANnel:DELay [,(@)]
Lệnh này sẽ thiết lập khoảng thời gian trễ giữa các kênh trong ch_list
bằng tham số seconds.
Có thể thiết lập khoảng thời gian trễ tự động bằng lệnh sau:
TRIGger:CHANnel:DELay:AUTO {OFF|ON}[,(@)]
f) Khởi tạo lần quét.
Có thể khởi tạo lần quét bằng lệnh INIT hoặc READ?. Sự khác nhau
giữa hai lệnh này là lệnh INIT sẽ lưu các kết quả vào bộ nhớ đệm của thiết bị.
Ngoài ra để khởi động từ giao diện từ xa có thể dùng lệnh *TRG.
5. Các lệnh định dạng dữ liệu.
Khi thực hiện quét dữ liệu sẽ được lưu trong bộ nhớ của thiết bị dưới dạng
sau:
Ở dạng mặc định các dữ liệu kèm theo này để ở chế độ tắt. Để bật hay tắt
các dữ liệu kèm theo khi đọc về có thể dùng các lệnh sau đây:
- FORMat:READing:ALARm {OFF|ON} bật hay tắt dữ liệu báo nguy.
- FORMat:READing:CHANnel {OFF|ON} bật hay tắt dữ liệu kênh.
- FORMat:READing:TIME {OFF|ON} bật hay tắt dữ liệu về thời gian.
- FORMat:READing:TIME:TYPE {ABSolute|RELative} sử dụng thời
gian tuyệt đối hay tương đối.
- FORMat:READing:UNIT {OFF|ON} có hay không đơn vị kèm theo.
Để hỏi xem các dữ liệu kèm theo này ở dạng bật hay tắt có thể dùng lệnh
hỏi có dấu hỏi kèm theo mỗi lệnh ví dụ như FORMat:READing:TIME?.
6. Các lệnh đặt mức đo.
Thiết bị HP34970A cho phép đặt thang đo cho dữ liệu gồm độ khuyếch
đại và giá trị bù. Giá trị thu được sẽ được tính theo công thức sau:
Giá trị=Giá trị đo * Khuyếch đại - Giá trị bù
- CALCulate:SCALe:GAIN [,(@)] đặt độ khuyếch đại cho
giá trị.
VNArmy
39
- CALCulate:SCALe:OFFSet [,(@)] đặt giá trị bù.
- CALCulate:SCALe:UNIT [,(@)] đặt đơn vị đo
theo ý của người dùng như PRM, PSI.5
7. Các lệnh đọc dữ liệu.
- DATA:POINts? đếm tổng số giá trị đọc hiện đang lưu trong bộ nhớ.
- DATA:REMove? đọc và xoá khỏi bộ nhớ bắt đầu từ giá trị
cũ nhất. Lệnh này thường để xoá có chu kì khỏi bộ nhớ để khỏi tràn bộ
nhớ. Dữ liệu thu được sẽ có dạng do lệnh định dạng dữ liệu qui định.
- FETCh? chuyển dữ liệu được lưu trong bộ nhớ ra của thiết bị sang máy
tính. Lệnh này không xoá các dữ liệu khỏi bộ nhớ. Dữ liệu ra có dạng theo
như lệnh định dạng dữ liệu qui định.
- R? [] đọc và xoá tất cả dữ liệu trong bộ nhớ theo giá trị
max_count qui định. Đây là một phiên bản của lệnh DATA:REMove?
nhưng thực hiện nhanh hơn. nếu bỏ qua tham số max_count thì lệnh này
đọc và xoá 50000 giá trị từ bộ nhớ. Lệnh này cũng bị ảnh hưởng bởi lệnh
định dạng dữ liệu. Dữ liệu trả về theo dạng khối độ dài xác định.
- READ? đọc dữ liệu từ thiết bị và gửi trực tiếp ra bộ đệm ra chứ không lưu
trữ vào bộ nhớ như lệnh FETC?
- MEASure? có cấu trúc lệnh như là lệnh CONFigure và thực hiện như cặp
lệnh CONF và theo sau là lệnh READ?. Tuy nhiên lệnh này không tiện bởi
khi thực hiện thiết bị sẽ đặt cấu hình phép đo theo các giá trị mặc định và
thực hiện ngay.
II. Sơ đồ thuật toán đo lường dùng chuẩn RS-232.
1. Giới thiệu về chuẩn RS-232.
Chuẩn RS-232 là chuẩn giao tiếp thông dụng nhất giữa máy tính và thiết bị
ngoại vi. Hầu hết mỗi máy tính đều có một vài cổng nối tiếp COM. Kết nối bằng
RS-232 có thể có khoảng cách lớn. Tuy nhiên nó cũng có nhược điểm là tại một
thời điểm chỉ kết nối được với một máy. Tốc độ truyền của RS-232 cũng chậm
hơn so với các chuẩn khác.
2. Các VI làm việc với chuẩn RS-232 trong LabVIEW.
LabVIEW cung cấp một số VI để làm việc với chuẩn RS-232. Có thể truy
nhập vào chúng trong Functions>>Instrument I/O>>Serial.
Hình2-1. Các hàm Serial
VNArmy
40
Các hàm này gồm :
- Serial Port Init: khởi tạo công Serial theo tham số đã chọn.
- Byte at Serial Port: trả lại trong byte count số byte ở bộ đệm vào của
cổng port number.
- Serial Port Read: đọc từ cổng port number số byte yêu cầu.
- Serial Port Write: gửi dữ liệu trong string to write ra cổng port number.
VNArmy
41
3. Thuật toán thu dữ liệu từ chuẩn RS-232.
Bước 1: Khởi tạo.
Bước này gồm có mở thiết bị, khởi tạo đường truyền tín hiệu và xoá thiết bị.
Bước 2: Lập cấu hình cho các kênh.
- Sử dụng lệnh SENS để đặt cấu hình đo cho từng kênh.
- Dùng lệnh CALC: SCAL để đặt mức đo cho mỗi kênh.
- Dùng lệnh ROUT:SCAN để đặt danh sách quét.
Tiếp tục
Khởi tạo
Lập cấu hình
hệ thống
Lập cấu hình
cho các kênh
Lập cấu hình
quét
Lập cấu hình
cho dữ liệu ra
Thu dữ liệu về
và xử lý
Đóng thiết bị
VNArmy
42
Bước 3: Lập cấu hình quét.
- Đặt nguồn khởi động quét bằng lệnh TRIG:SOUR
- Đặt khoảng thời gian quét bằng lệnh TRIG:TIM
- Đặt số lần quét bằng lệnh TRIG:COUN
- Khởi tạo lần quét bằng INIT.
Bước 4: Định dạng dữ liệu thu về
Để định dạng dữ liệu thu về có thể dùng lệnh FORM:READ.
Bước 5: Thu dữ liệu về và xử lý.
Có nhiều lệnh để đọc dữ liệu về nhưng thuận tiện nhất là dùng 2 lệnh
DATA:POIN? và DATA:REM?.Dữ liệu thu về dưới dạng gồm nhiều trường
khác nhau như giá trị, kênh, thời gian .. Để bóc tách lấy dữ liệu ta dùng Data to
3DArray VI để tách lấy phần dữ liệu cần xử lý.
Bước 6: Đóng thiết bị.
Để đóng thiết bị có thể dùng hàm VISA Close của LabVIEW.
VNArmy
43
Chương 3
Xây dựng bài thí nghiệm trên bệ thí nghiệm máy điện.
I. Môc ®Ých cña bµi thÝ nghiÖm.
Thùc hiÖn ®o vµ quan s¸t tÝn hiÖu cña bÖ thÝ nghiÖm m¸y ®iÖn. TÝn hiÖu
thu vÒ sÏ ®−îc biÓu diÔn trªn m¸y tÝnh ®Ó häc viªn tiÖn quan s¸t. Häc viªn cã thÓ
thay ®æi mét sè tham sè trªn bÖ thÝ nghiÖm ®Ó quan s¸t tÝn hiÖu thu vÒ.
II. M« t¶ bµi thÝ nghiÖm.
Sau khi thiÕt lËp c¸c subVI vµ thuËt to¸n ë ch−¬ng 2, chóng ta tiÕn hµnh
thu tÝn hiÖu tõ bÖ thÝ nghiÖm m¸y ®iÖn qua thiÕt bÞ HP 34970A. Front Panel vµ
Block Diagram cña nã cã d¹ng nh− h×nh sau:
Hình 3-1. Front Panel của bài thí nghiệm
VNArmy
44
Front Panel của bài thí nghiệm (hình 3-1) bao gồm một control Channel
Configuration mà mỗi phần tử của nó là một cluster để đặt cấu hình cho các
kênh đo; một control để chọn tài nguyên nối mạng; một control để chọn tần số
lấy mẫu; một bộ hiển thị waveform chart để biểu diễn bằng đồ thị tín hiệu thu
được; một núm xoay để chọn kênh hiển thị và một nút stop để ngừng chương
trình.
Block Diagram của bài thí nghiệm sẽ thực hiện theo như sơ đồ thuật toán
thu tín hiệu đã lập ở chương 2. Block Diagram của nó như hình 3-2. Nó gồm có
phần khởi tạo đường truyền dùng subVI Initalize. Phần này sẽ đặt đường truyền
cho chuẩn RS 232 theo như các tham số của thiết bị HP 34970A. Mã nguồn của
nó như hình 3-3.
Hình 3-2. Block Diagram của bài thí nghiệm
Hình 3-3. Block Diagram của subVI INIT.
VNArmy
45
Phần khởi tạo kênh đo bằng subVI Channel Config. SubVI này sẽ đặt cấu
hình cho các kênh của thiết bị HP 34970A. Mã nguồn của subVI này như sau.
Các kênh được đặt cấu hình sẽ được đưa vào vòng lặp For. Sử dụng hàm
Unbundle By Name để tách lấy các tham số của kênh. Các tham số này sẽ được
gửi đến các subVI tương ứng để gửi tới thiết bị HP 34970A. Phần danh sách
kênh sẽ được tích lại trên biên của vòng For để thành mảng các string. Sau đó
dùng hàm Array to Spreadsheet String để thành scanlist và gửi tới subVI
Scanlist. SubVI này sẽ đặt danh sách quét cho thiết bị HP 34970A.
Phần khởi tạo nguồn khởi động bằng subVI Trigger Config. Block
Diagram của subVI này như hình 3-5. Các tham số của lệnh trigger sẽ được
chọn bằng các dùng các hàm xử lý string. Sau đó nó sẽ được gửi tới thiết bị HP
34970A để đặt cấu hình nguồn khởi động cho thiết bị.
Hình 3-4. SubVI Channel Config Block Diagram.
Hình 3-5. Trigger config Block
VNArmy
46
Phần đọc và xử lý tín hiệu được đưa vào trong một vòng lặp While. Dữ
liệu được đọc bằng subVI Read. Block Diagram của nó có dạng như sau.
Dữ liệu đọc về có dạng chuỗi. Để tách ra các thành phần của nó cần phải
dùng subVI List To 3DArray. Block Diagram của nó như hình 3-7.
Để tách ra phần dữ liệu có thể dùng hàm Array Index. Dữ liệu đọc về sẽ
được đưa qua bộ lọc Butterworth thông thấp để lọc bỏ nhiễu loạn. Sau đó tín
hiệu sẽ được gửi ra waveform chart để biểu diễn. Quá trình này được lặp cho tới
khi nào bấm vào nút stop để kết thúc chương trình.
Khi thực hiện chương trình, trước hết chọn cấu hình của kênh từ control
Channel Configuration. Sau đó chọn tần số lấy mẫu. Sau đó cho chương trình
thực hiện. Khi thực hiện chương trình sẽ gọi đến các VI dạng dialog để đặt cấu
hình cho đường truyền và cấu hình các kênh. Khi muốn hiển thị kênh nào trên
đồ thị sử dụng núm xoay Channel Selection.
Danh mục một số bài thí nghiệm đã thực hiện:
- Quan sát phổ của tín hiệu máy điện.
- Tính toán các tham số của máy điện.
Hình 3-6. Read VI Block Diagram.
Hình 3-7. List To 3DArray Block Diagram.
VNArmy
47
KẾT LUẬN CHUNG.
Đề tài đã nêu được cách tiếp cận với ngôn ngữ lập trình LabVIEW thông
qua kỹ thuật lập trình cơ bản và nâng cao. Đề tài cũng nghiên cứu tập lệnh của
thiết bị thông minh HP 34970A và đưa ra được lưu đồ thuật toán để thu tín hiệu
thông qua chuẩn RS-232. Qua lưu đồ đó thực hiện kết nối máy tính với thiết bị
HP 34970A để điều khiển thiết bị từ bệ thí nghiệm máy điện. Đề tài đã xây dựng
được chương trình cụ thể để thu và biểu diễn tín hiệu.
Hướng phát triển tiếp theo của đề tài:
- Xây dựng hệ thống đo lường và điều khiển thiết bị bằng chuẩn GPIB hoặc
VXI.
- Xây dựng các VI để mô phỏng các thiết bị ảo như HP34970, Kyowa ..
VNArmy
48
MỤC LỤC
Lời nói đầu 1
Chương 1 Kỹ thuật lập trình trên LabVIEW 2
1.1. Kỹ thuật lập trình cơ bản trên LabVIEW 1
1.2.Lập trình nâng cao trên LabVIEW 26
Chương 2 Thiết bị đo thông minh HP34970A 33
Chương 3 Xây dựng bài thí nghiệm trên bệ thí nghiệm máy điện 41
Kết luận chung 45
VNArmy
49
TÀI LIỆU THAM KHẢO
LabVIEW User Manual
G Programming Reference Manual
HP 34970A Data Acquisittion/Switch Unit
Các file đính kèm theo tài liệu này:
- LAP-TRINH-LABVIEW.pdf