Cách viết chương trình PLC dành cho người mới bắt đầu

Hỗ trợ kỹ thuật
09/09/2021 10:00
Rất nhiều người mới bắt đầu vô cùng bối rối khi được yêu cầu bắt đầu viết một đoạn chương trình cho hệ thống thiết bị. Nguyên nhân lớn nhất là do trong trường học mọi người được dạy lập trình PLC bằng việc một dòng lệnh là xử lý hết các tình huống với các bit I/O trong đó. Cách dạy và học đó chỉ đúng với PLC cơ bản.
aa

Trong quá trình học và làm việc với PLC, rất nhiều người mới bắt đầu vô cùng bối rối khi được sếp yêu cầu bắt đầu viết một đoạn chương trình cho hệ thống thiết bị.

• 6 bước để lựa chọn giữa PLC và DCS trong công nghiệp
• PLC, PAC VÀ IPC: Khác biệt và cơ sở lựa chọn

Nguyên nhân lớn nhất là do trong trường học mọi người được dạy lập trình PLC bằng việc một dòng lệnh là xử lý hết các tình huống với các bit I/O trong đó. Cách dạy và học đó là đúng với PLC cơ bản, nhất là đối với các kỹ sư điện quen làm việc với mạch relay.

Tuy nhiên, thời của mạch relay và PLC chỉ chứa được dăm dòng lệnh đã xa lắm rồi. Các Dòng PLC hiện đại như Allen Bradley Controllogix cũng đã ngót nghét 24 – 25 năm tuổi (thậm chí nhiều tuổi hơn các bạn đang đọc bài này).

Nhược điểm khi viết chương trình PLC theo dạng mạch relay

Ở thời điểm này, việc viết một chương trình PLC theo dạng mạch relay sẽ có những nhược điểm sau:

  • Chương trình rất khó hiểu và khó sửa. Người ta nói đùa rằng, chương trình này lúc viết thì có người viết và Chúa hiểu, còn lúc sửa thì chỉ còn có Chúa mới hiểu nổi thôi.
  • Chương trình rất khó viết, vì trong lúc viết, bạn phải chuẩn bị sẵn tất cả các trường hợp có thể xảy ra. Với hệ thống nhỏ một chức năng thì có thể, nhưng gặp hệ thống phức tạp/sử dụng cho nhiều mục đích thì cách viết này vô cùng tai hại.

Cách viết dạng mạch relay sẽ phù hợp với các hệ thống siêu nhỏ, máy cố định và cần thời gian phản ứng rất rất nhanh (< 10ms ). Chương trình viết cũng siêu nhỏ, thích hợp với các thể loại PLC cũ không có nhiều lựa chọn về đặt tên IO cũng như ổ nhớ.

Lập trình theo dạng quy trình (procedure)

Tuy nhiên, với nhiều nhược điểm trên, mình khuyên các bạn sau khi đã làm quen với việc viết một vài dòng lệnh cơ bản, bạn nên học về cách lập trình theo dạng quy trình (procedure). Cách viết chương trình dạng procedure, kết hợp với cách sử dụng các add-on instruction có sẵn trên hệ process sẽ đảm bảo cho bạn viết được một chương trình hoàn chỉnh với mọi kích cỡ.

Cách viết chương trình dạng procedure thực ra là cách viết chương trình đơn giản nhất có thể, dựa hoàn toàn vào việc người viết chương trình mô tả quá trình đấy. Nếu bạn nào từng học lập trình bằng các ngôn ngữ cổ ngày xưa (Pascal) chẳng hạn, thì sẽ cảm giác khá quen thuộc.

Về lý thuyết, cách viết này chỉ là đánh số các bước cần thực hiện để hoàn thành 1 task.

Khi bắt đầu, bước 0 chuyển qua bước 1

Bước 1: làm hành động A1, kiểm tra điều kiện B1, nếu B1 thỏa mãn thì chuyển qua bước 2

Bước 2: làm hành động A2, kiểm tra điều kiện B2, nếu B2 thỏa mãn thì chuyển qua bước 3

….

Bước kết thúc, thông báo hoàn thành quy trình, về lại bước 0.

Hết.

Nếu bạn muốn hệ thống lặp đi lặp lại, chỉ cần ở 1 bước nào đó, bạn loop ngược về bước 0

Bước N: làm hành động AN, kiểm tra điều kiện BN, nếu BN thỏa mãn thì chuyển qua bước M (M trước N)

Nếu bạn muốn hệ thống có rẽ nhánh về action, cũng chỉ cần:

Bước N: làm hành động AN, kiểm tra điều kiện BN và CN, nếu BN thỏa mãn thì chuyển qua bước M, nếu CN thỏa mãn thì chuyển qua bước L.

Nghe lý thuyết thì khó hiểu, mình sẽ lấy 1 ví dụ cụ thể:

cach viet chuong trinh plc danh cho nguoi moi bat dau
Ví dụ cách viết chương trình dạng procedure.

Đây là bài tập mình copy trên Youtube, giải nó rất rất đơn giản như sau:

Bấm Start thì toàn hệ thống RUN step 0 -> 1 bấm Stop thì toàn hệ thống không Run

Nếu Run, Step 1 → bật bơm HC1 / HC2 / HC3, kiểm tra bơm đã hoạt động chưa → step 2

Nếu Run, Step 2 → duy trì HC1/ HC2/ HC3, kiểm tra điều kiện L+ (LH – Level High) đạt chưa, nếu đã đạt thì → step 3

Nếu Run, Step 3 → tắt HC1/ HC2/ HC3, bật Motor khuấy Thuận, tạo timer khuấy thuận 5s, khi timer đạt thì qua step 4

Nếu Run, Step 4 → tắt motor khuấy thuận, bật motor khuấy nghịch, tạo timer nghịch 5s, khi timer đạt thì qua step 5

Nếu Run, Step 5 → tắt motor khuấy nghịch. Mở VAN. Kiểm tra điều kiện L-, nếu đạt L- (LL – LevelLow) thì qua bước 6

Nếu Run, Bước 6 → đóng VAN. VAN đã đóng thì chuyển về bước 1.

Toàn bộ chương trình bằng chữ mình viết trong vòng 6 phút, vừa đọc vừa viết.

Muốn tăng độ khó cho đề bài, mình chỉ cần sửa đề bài là bật tuần tự HC1, HC2, HC3 theo flowmeter dạng pulse counter (HC1FM, HC2FM, HC3FM) với số lượng 100-200-300 xung (thay vì bật L+). Với kiểu viết chương trình của mình, từ đề bài trên sửa vô cùng dễ

Step 1 → → step 11

step 11 → bật bơm HC1, đếm xung HC1FM, nếu HC1FM = 100→ step 12

step 12 → bật bơm HC2, đếm xung HC2FM, nếu HC2FM = 100→ step 13

Step 13 → bật bơm HC3, đếm xung HC3FM, nếu HC3FM = 100→ step 3

Step 3 → tắt HC1/ HC2/ HC3, bật Motor khuấy Thuận, tạo timer khuấy thuận 5s, khi timer đạt thì qua step 4

Step 4 → tắt motor khuấy thuận, bật motor khuấy nghịch, tạo timer nghịch 5s, khi timer đạt thì qua step 5

Step 5 → tắt motor khuấy nghịch. Mở VAN. Kiểm tra điều kiện L-, nếu đạt L- (LL – LevelLow) thì qua bước 6

Bước 6 → đóng VAN. Reset toàn bộ các biến. VAN đã đóng thì chuyển về bước 1.

Khi viết chương trình dạng procedure, bạn cần chú ý là các action ở từng bước phải được tách ra 1 dòng lệnh riêng, không viết chung trong cùng 1 dòng với các lệnh chuyển bước. Lý do là các action có thể lặp lại (ví dụ HC1 có thể bật ở bước 1, 4, 8) chẳng hạn.

Khi đó, nếu run, đang ở bước 1,4,8, thì HC1 chạy. Việc kiểm soát thực ra sẽ vô cùng dễ dàng.

Triển khai trong PLC thực tế

Trong bài mẫu này, mình sử dụng phần mềm của Rockwell Automation, Studio 5000 V33 và RSEmulate.

Set up các tag cơ bản:

cach viet chuong trinh plc danh cho nguoi moi bat dau

Set up các routine chạy

  • PHASE: chứa chương trình bước
  • OUTPUT: chứa các lệnh action

cach viet chuong trinh plc danh cho nguoi moi bat dau

cach viet chuong trinh plc danh cho nguoi moi bat dau

cach viet chuong trinh plc danh cho nguoi moi bat dau

cach viet chuong trinh plc danh cho nguoi moi bat dau
Đối với tất cả chương trình PLC, trước khi mình đưa vào chạy thực tế trên máy đều chạy giả lập trên Emulation để giả lập tính năng. Mình chạy vào RSEmulate, và từ lúc viết tới lúc emulate không cần sửa lại. Nếu bạn để ý, chương trình của mình khá dài dòng, với 19 dòng. Tuy nhiên, từng dòng của mình viết rất dễ hiểu, và dễ tra ngược lại. Ví dụ, bạn có thể kiểm tra được là hệ thống đang chạy bước nào, nếu van không mở thì tại sao, van không đóng tại sao một cách vô cùng dễ dàng.

Cách viết này giải quyết được cho toàn bộ các hệ thống nếu được miêu tả đúng cách theo quy trình của từng cụm máy thiết bị. Ví dụ 1 máy sẽ có khoảng 200-300 I/O hoạt động theo khoảng 20-30 cụm chức năng thì sẽ cần 20-30 chương trình Phase và Output như vậy. Miễn là miêu tả được thành từng bước, thì sẽ viết ra được. Việc viết chương trình kiểu này không phụ thuộc vào việc bạn dùng PLC gì, hãng nào. Thậm chí, nếu bạn không dùng PLC mà sử dụng các board điều khiển (Arduino chẳng hạn) thì việc code theo procedure kiểu này sẽ đơn giản hóa công việc rất rất nhiều.

Khi bạn bắt đầu viết chương trình kiểu này quen, các việc tiếp theo bạn cần tìm hiểu là:

  • Mô hình và phân chia cấu trúc một cách có hệ thống theo ISA 88:
    • Phân chia cấu trúc vật lý (asset) thành Process Cell/Unit/Control Module
    • Procedural Control Model (Phase)

cach viet chuong trinh plc danh cho nguoi moi bat dau

  • Đặc biệt đối với hệ thống quy trình công nghệ (process control), các thiết bị đầu cuối thường được lập trình sẵn với các Process Objects, tồn tại dưới dạng các khối lệnh thêm vào (add-on instruction hoặc function block). Các khối này được lập trình sẵn với các khối hiển thị trên HMI/SCADA, sẽ giúp bạn triển khai dự án một cách nhanh chóng. Ví dụ về bộ thư viện này của Rockwell Automation là PlantPAx, hiện tại có bản mới nhất là 5.0
  • Sự dụng được Phase Manager vì hệ thống theo ISA88 không chỉ có trạng thái START – STOP mà còn có Stop, Pause, Complete. Các trạng thái này sẽ giúp việc điều khiển quy trình dễ dàng và chính xác hơn, cũng như việc phối hợp giữa các Phase/Task với nhau để tạo thành 1 hệ thống quy trình liên hợp hoàn chỉnh.

cach viet chuong trinh plc danh cho nguoi moi bat dau

Hi vọng với bài viết ngắn này, Hùng giúp mọi người có thể viết được chương trình PLC một cách đơn giản và dễ hiểu nhất.

Hoàng Kim Hùng – Sales Account Manager
Rockwell Automation Việt Nam

Bài liên quan
vcca2026
Tin bài khác
Mouser khám phá tương lai robot hình người trong chương trình “Sự trỗi dậy của robot”

Mouser khám phá tương lai robot hình người trong chương trình “Sự trỗi dậy của robot”

Sự phát triển nhanh chóng của trí tuệ nhân tạo (AI), cảm biến thông minh và điện toán nhúng đang đưa robot hình người từ những ý tưởng trong khoa học viễn tưởng trở thành hiện thực. Nhằm giúp cộng đồng kỹ sư hiểu rõ hơn về xu hướng công nghệ này, Mouser Electronics vừa giới thiệu phần mới nhất trong chuỗi chương trình giáo dục kỹ thuật Empowering Innovation Together (EIT) với chủ đề “Sự trỗi dậy của robot”.
Văn hóa doanh nghiệp: Nền tảng cho hành trình tăng trưởng xanh của BSR

Văn hóa doanh nghiệp: Nền tảng cho hành trình tăng trưởng xanh của BSR

Trong bối cảnh ngành năng lượng toàn cầu đang chuyển dịch mạnh mẽ theo hướng xanh hóa, giảm phát thải và phát triển bền vững, các doanh nghiệp không chỉ cạnh tranh bằng quy mô hay năng lực sản xuất mà còn bằng khả năng thích ứng và giá trị nội sinh. Với Tổng công ty Lọc hóa dầu Việt Nam (BSR), văn hóa doanh nghiệp, con người và tư duy phát triển bền vững đang trở thành nền tảng quan trọng để kiến tạo lợi thế cạnh tranh dài hạn, hướng tới mục tiêu trở thành doanh nghiệp năng lượng hàng đầu khu vực.
Từ giao thông đến đất đai: TP. Hồ Chí Minh đẩy mạnh tự động hóa quy trình quản trị, số hóa dữ liệu

Từ giao thông đến đất đai: TP. Hồ Chí Minh đẩy mạnh tự động hóa quy trình quản trị, số hóa dữ liệu

Tại buổi họp báo cung cấp thông tin về các vấn đề kinh tế - xã hội trên địa bàn TP.Hồ Chí Minh ngày 11/6/2026, nhiều nội dung liên quan đến hạ tầng giao thông, quản lý đất đai, trật tự đô thị và công tác quản lý địa phương đã được các đơn vị chuyên môn trao đổi với báo chí. Dưới góc nhìn chuyển đổi số và quản trị hiện đại, những thông tin được chia sẻ cho thấy xu hướng ngày càng rõ nét của TP. Hồ Chí Minh trong việc ứng dụng dữ liệu và công nghệ nhằm nâng cao hiệu quả quản lý đô thị.
Đào tạo kỹ sư Robot và AI: Đón đầu tương lai từ giảng đường

Đào tạo kỹ sư Robot và AI: Đón đầu tương lai từ giảng đường

Đón đầu xu thế phát triển của cuộc Cách mạng công nghiệp lần thứ tư, Trường Đại học Giao thông Vận tải đã tiên phong xây dựng và triển khai ngành Kỹ thuật Robot và Trí tuệ nhân tạo từ năm 2021. Khi khóa kỹ sư đầu tiên chuẩn bị tốt nghiệp cũng là thời điểm robot và trí tuệ nhân tạo được xác định là công nghệ chiến lược quốc gia, minh chứng cho tầm nhìn, sự chủ động và hướng đi đúng đắn của một chương trình đào tạo hiện đại, gắn kết chặt chẽ giữa nhà trường, doanh nghiệp và nhu cầu phát triển của đất nước.
Thị trường chứng khoán ngày 12/6: Tiền vào chưa đủ mạnh, VN Index lại hụt hơi trước mốc 1.800 điểm

Thị trường chứng khoán ngày 12/6: Tiền vào chưa đủ mạnh, VN Index lại hụt hơi trước mốc 1.800 điểm

Thanh khoản bật tăng sau phiên cạn kiệt dòng tiền, nhưng thị trường vẫn không thoát khỏi sắc đỏ và mất mốc 1.800 điểm. Áp lực từ nhóm bất động sản và cổ phiếu trụ khiến VN Index mất gần 7 điểm, nối dài chuỗi giảm sang tuần thứ tư liên tiếp.
World Cup 2026: Đêm Azteca, trọng tài có thêm đôi mắt

World Cup 2026: Đêm Azteca, trọng tài có thêm đôi mắt

World Cup 2026 mở màn tại Mexico City bằng hai bàn thắng, ba tấm thẻ đỏ và một lời tuyên cáo lạnh lùng của công nghệ - trên sân cỏ hiện đại, những gì khuất sau lưng trọng tài chưa chắc đã thoát khỏi những con mắt điện tử. Mexico thắng Nam Phi 2-0, còn VAR cùng các hệ thống theo dõi tân tiến lập tức chiếm lấy phần hậu cảnh, nơi quyền lực đôi khi đáng sợ hơn cả ánh đèn sân khấu.
Tử vi vòng quay công nghệ ngày 13/6/2026: Tuổi Ngọ đón tin vui tài lộc, tuổi Thân cẩn trọng trong các mối quan hệ

Tử vi vòng quay công nghệ ngày 13/6/2026: Tuổi Ngọ đón tin vui tài lộc, tuổi Thân cẩn trọng trong các mối quan hệ

Những bí ẩn của khoa học đời sống là "món ăn" tinh thần không thể thiếu trong cuộc sống của con người. Tử vi vòng quay công nghệ xem tử vi 12 con giáp ngày 13/6/2026 cho tất cả các tuổi nhằm dự đoán vận hạn về công danh, tiền bạc, tình duyên và sức khỏe.
Petrovietnam công bố và trao quyết định Phó Bí thư Đảng ủy và Phó Tổng Giám đốc Tập đoàn

Petrovietnam công bố và trao quyết định Phó Bí thư Đảng ủy và Phó Tổng Giám đốc Tập đoàn

Ngày 12/6, Tập đoàn Công nghiệp - Năng lượng Quốc gia Việt Nam (Petrovietnam) tổ chức Lễ công bố quyết định đồng chí Lê Mạnh Cường giữ chức Phó Bí thư Đảng ủy Tập đoàn và đồng chí Vũ Đào Minh giữ chức Phó Tổng Giám đốc Tập đoàn.
Nhận định phiên giao dịch ngày 12/6: Nhà đầu tư nên cân bằng danh mục, chờ dòng tiền quay trở lại

Nhận định phiên giao dịch ngày 12/6: Nhà đầu tư nên cân bằng danh mục, chờ dòng tiền quay trở lại

Thị trường chứng khoán đang trong giai đoạn tích lũy khi dòng tiền suy yếu, thanh khoản xuống thấp và chưa xuất hiện động lực đủ mạnh để hình thành xu hướng tăng mới. Các chuyên gia khuyến nghị nhà đầu tư duy trì trạng thái cân bằng danh mục, hạn chế gia tăng tỷ trọng cổ phiếu và chờ tín hiệu cải thiện rõ ràng hơn từ thanh khoản.
Ngành công nghiệp toàn cầu: Tăng hiệu suất động cơ thêm 0,2% có thể tiết kiệm 12 tỷ USD

Ngành công nghiệp toàn cầu: Tăng hiệu suất động cơ thêm 0,2% có thể tiết kiệm 12 tỷ USD

Một cải tiến tưởng chừng rất nhỏ trong hiệu suất vận hành của các động cơ và máy phát điện công nghiệp lại có thể tạo ra tác động kinh tế và môi trường khổng lồ. Theo báo cáo mới từ ABB, việc nâng hiệu suất của các động cơ và máy phát điện đồng bộ công suất lớn thêm chỉ 0,2% có thể giúp các doanh nghiệp trên toàn cầu tiết kiệm từ 9,5 đến 12 tỷ USD chi phí điện năng, đồng thời cắt giảm tới 75 triệu tấn khí thải CO₂ trong vòng đời vận hành 25 năm.
vn-web
song-gia-tri
gao-doc