Hướng dẫn lập trình Labview

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

pdf49 trang | Chia sẻ: lvcdongnoi | Lượt xem: 5794 | Lượt tải: 1download
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:

  • pdfLAP-TRINH-LABVIEW.pdf