My PLC Ladder Logic Standard

My PLC Ladder Logic Standard

I love industrial PLCs, industrial automation, and especially Ladder Logic — today everyone one here in Silicon Valley is in Web, SaaS, Mobile, and Cloud engineering, but PLCs remain my first love of programming and technology.

It’s been many years since I worked in industry with PLCs, but way back in 1990 I developed a set of structured ladder logic standards that are still relevant today for high-quality ladder work. So, I wanted to share these standards with you.

Ladder Logic

Ladder logic is a graphical programming language used in industrial control systems to control machines and processes. Its name comes from the resemblance of the program’s structure to the rungs of a ladder.

While it may seem archaic compared to modern software languages and tools, ladder logic is actually a direct continuation of over 100 years of physical relay logic used to control machinery since the dawn of electricity during the Second Industrial Revolution.

This means that engineers today still think and work in a similar way to those from a century ago when it comes to designing and implementing control systems. And while ladder logic may not be the most advanced programming language, it is still widely used and is an important tool for industrial automation. It’s also intuitive and very powerful (including changeable while its running).

Control Relay encased in plastic case
Traditional Control Relay

Ladder logic works by using inputs, such as push buttons and sensors plus logic to control outputs, such as the motors, pumps, and lights that actually move machines and processes.

The logic of ladder programming uses the inputs to decide which outputs should be turned on or off. The structure of the ladder program is similar to relay logic diagrams, with inputs on the left and outputs on the right. The two vertical lines represent the virtual versions of the electrical power used in relay diagrams.

While the basic concept of ladder logic may seem simple, it is an important tool for industrial automation. Its graphical structure makes it easy to understand and modify, while its reliance on simple inputs and outputs makes it a reliable and efficient programming language for controlling machines and processes.

No alt text provided for this image
Ladder Logic Example

Ladder logic’s visual representation allows engineers to build logic based on simple AND, OR, and NOT logic. The structure of the program is usually tied very closely to the physical devices connected to the PLC I/O cards in various racks.

This means that the ladder program is designed to closely match the actual physical devices and processes being controlled. This makes it easier to understand and troubleshoot issues, as the program’s structure closely mirrors the physical layout of the system.

Standard Rungs

One of the most basic ladder logic blocks is start and stop latching logic for a motor. This simple example contains all the key elements of the ladder logic standard and should be used for systems simple and complex.

Simple standards help engineers avoid the temptation to create convoluted combined logic, where they try to cram ever-increasing complexity into a big rung or two. These types of programs are difficult to follow, understand, and modify safely.

Instead, by following the ladder logic standard, engineers can create programs that are easy to understand and modify. This makes troubleshooting and maintenance much easier, and helps to ensure that the system operates reliably and safely.

My standard rungs look like this:

No alt text provided for this image
Example Standard Ladder Logic Rungs

Note the following key standard functions that should be present for nearly every significant on/off ladder section:

Permission Logic

In ladder logic, it’s important to separate out permission logic into a single place that makes it very clear what is needed for this motor to run. This is the logic that protects machines and people from dangerous conditions or damage, so it should be prioritized and made very clear.

Permission inputs may include guards in place, hydraulic pumps running, air pressure, and more. Since these inputs often change over time, it’s essential to have them all in one clear place to avoid making life-threatening mistakes by messing up permission and protection logic.

Adding more rungs (not shown) to detect which permission is not satisfied is also helpful. This allows operators to quickly understand why the machine won’t start, such as a door being open or a pump not running (as nothing is more frustrating than trying to start something, nothing happens, and you have no idea why). This is especially important on complex machines where troubleshooting can be time-consuming and frustrating.

Overall, separating permission logic and making it clear in ladder logic is critical for protecting machines and people and ensuring the system operates safely and reliably.

Start Logic

It’s important to separate out start logic into a separate rung to ensure that it’s clear what is starting the motor. As the system becomes more complex over time, it’s essential to have one place to manage all start inputs, such as start buttons or signals triggered by other processes.

One-shot logic (available on many PLCs) is used in the start system, ensuring that the start signal is momentary, mimicking a start button. This helps keep the machine safe by requiring all the start inputs to drop or open and then re-close to start something. This helps prevent a machine from starting suddenly when power is restored or an E-stop is reset.

By separating start logic and using one-shot logic, operators are required to do something to restart the machine, which can prevent accidents and ensure safer operations.

Stop Logic

Stop logic in ladder logic is quite straightforward — it interrupts the main rung and drops out the latch, which turns off the output. Unlike the start logic, stop logic does not use one-shot logic, so any persistent stop condition will prevent the system from re-starting unexpectedly.

Holding Logic

Since the start logic is one-shot, holding logic is needed in the system. This is usually in the form of its own output and should be very simple. Its only job is to hold the output on, without worrying about stopping or permissions, which have their own logic — this means you should resist the temptation to put stop or permission logic in the holding circuit.

Emergency Logic

It’s important to note that the emergency stop input should be present in every run to ensure that all machine functions and related logic are stopped during an emergency.

Even though external hard-wired E-Stop circuits will kill all power to the outputs, it’s important to have a way to cancel or stop all latched outputs, so they don’t restart when the E-Stop is reset. As such, on reset, the machine should be completely off or dead, and require a standard process to restart.

Extending the Standard

The above simple standard can, of course, be extended to much more complex logic, with timers, automatic modes, numeric logic such as power controls. They generally all fit within this structure to maintain consistency, clarity, and safety.

Digital Inputs

A quick word on digital input standards, usually from MMI or SCADA systems digitally connected to the PLC. Unlike hard-wired inputs, these digital or virtual inputs enter via the network and can have unusual or unspecified behavior, especially in how long they are turned on — they may come on for a specified time, like 250ms, or just stay on indefinitely based on that system’s logic — for example, many systems will set a bit on but never turn it off without separate action in the MMI/SCADA system, acting like a stuck on push button, which is rarely helpful in our logic.

The challenge is to present these inputs in a unified way to the PLC, and to make them act as much like traditional inputs as possible, simplifying the logic involved.

The best way I’ve found to do that is to configure the PLC with two separate but identical-sized binary memory blocks, i.e. a virtual input or data block, consisting of on/off bits.

Then configure the MMI or SCADA system to send inputs to the first area, so if you press a start button on a touch screen, you get a 1 in the input area (start). If you press the stop button, you get a separate 1 in a different input area (stop). These 1s are often left on forever by the MMI/SCADA system, i.e. they never turn off, which makes using them a bit messy.

In your ladder logic, at the top on EVERY scan (before any inputs are used), copy the entire first input block to the second input block and clear the first block, back to all 0s. This will both clear the previous inputs from the MMI / SCADA and make all inputs act like one-shot inputs to the logic, just like a push-button.

This takes a bit of effort to get your head around, but it creates a very simple and easy-to-use input system for all types of digital inputs. It also lets you easily mix and use digital and physical inputs in the same way in the same logic, improving safety and understanding.

Conclusion

Breaking down the logic into standard separate rungs not only makes it easier to understand and modify the system, but it also makes troubleshooting and debugging much simpler. By clearly defining each rung’s purpose and functionality, engineers can quickly identify and isolate any issues that may arise.

Ladder Logic is awesome, but can get increasingly complex over the many years or decades of a machine’s lifetime. As engineers, we want to ensure the logic is clean, simple, and easy to both understand and modify for the long haul. Hopefully this standard helps.


I’m Steve Mushero, fractional CTO for early stage startups, but I started out in heavy industry, building machinery and factories, hence my love for PLCs — Today I work with startups in Silicon Valley that need to scale up their product, processes, and people. See more at SteveMushero.com and my profile here on LinkedIn.

Ken B.

Facility Engineering Manager

1y

Now this brings back some memories. Should also add your fault routine. Nice article Steve.

To view or add a comment, sign in

More articles by Steve Mushero

  • Theory & Practice of Selling

    Theory & Practice of Selling

    Way back in 1932, a young salesman named David Ogilvy was selling stoves in rural England. He would go on to…

    1 Comment
  • Security Review for SaaS Systems

    Security Review for SaaS Systems

    I am often asked by CEOs and CTOs to do security reviews of their SaaS products, as securing them is critical for their…

    1 Comment
  • DevOps Challenges When Outsourcing Your MVP

    DevOps Challenges When Outsourcing Your MVP

    Numerous early-stage startups use outsourcing to develop their Minimum Viable Product (MVP), quickly building something…

    2 Comments
  • Laying Off People, The Right Way

    Laying Off People, The Right Way

    Laying off people is never easy, especially in challenging times when others are doing it, too. Having done this a few…

    3 Comments
  • Software Development for Early-Stage Startups

    Software Development for Early-Stage Startups

    This is part of my series on DevOps for Early Stage Startups, and is designed for non-technical startup CEOs who don’t…

  • Steve Mushero User Manual

    Steve Mushero User Manual

    Like you, I'm a busy person who values efficiency, getting stuff done, and also personal relationships. So this is a…

    2 Comments
  • Laying Off People

    Laying Off People

    Laying off people is never easy, especially in challenging times when others are doing it, too. Having done this a few…

  • Elasticsearch Indexing Data Flow

    Elasticsearch Indexing Data Flow

    Elasticsearch® is a very powerful and flexible distributed data system, accepting and indexing billions of documents…

  • Is Elasticsearch Hard to Manage?

    Is Elasticsearch Hard to Manage?

    Elasticsearch® is a great system for managing data, be it documents, text, logs, metrics, and more. It can do this at…

  • How Elasticsearch Snapshots Work

    How Elasticsearch Snapshots Work

    Elasticsearch is a powerful and dynamic distributed data system, and such things can be hard to backup, especially as…

Insights from the community

Others also viewed

Explore topics