Siemens Simatic S7-400 System in A Rack, Left-To-Right: Power Supply Unit (PSU), CPU, Interface Module (IM) and Communication Processor (CP)
Siemens Simatic S7-400 System in A Rack, Left-To-Right: Power Supply Unit (PSU), CPU, Interface Module (IM) and Communication Processor (CP)
Siemens Simatic S7-400 System in A Rack, Left-To-Right: Power Supply Unit (PSU), CPU, Interface Module (IM) and Communication Processor (CP)
Siemens Simatic S7-400 system in a rack, left-to-right: power supply unit (PSU), CPU, interface module
(IM) and communication processor (CP).
PLCs can range from small "building brick" devices with tens of inputs and outputs (I/O), in a
housing integral with the processor, to large rack-mounted modular devices with a count of
thousands of I/O, and which are often networked to other PLC and SCADA systems.
They can be designed for multiple arrangements of digital and analog I/O, extended temperature
ranges, immunity to electrical noise, and resistance to vibration and impact. Programs to control
machine operation are typically stored in battery-backed-up or non-volatile memory.
It was from the automotive industry in the USA that the PLC was born. Before the PLC, control,
sequencing, and safety interlock logic for manufacturing automobiles was mainly composed
of relays, cam timers, drum sequencers, and dedicated closed-loop controllers. Since these
could number in the hundreds or even thousands, the process for updating such facilities for the
yearly model change-over was very time consuming and expensive, as electricians needed to
individually rewire the relays to change their operational characteristics.
When digital computers became available, being general-purpose programmable devices, they
were soon applied to control sequential and combinatorial logic in industrial processes. However
these early computers required specialist programmers and stringent operating environmental
control for temperature, cleanliness, and power quality. To meet these challenges the PLC was
developed with several key attributes. It would tolerate the shop-floor environment, it would
support discrete (bit-form) input and output in an easily extensible manner, it would not require
years of training to use, and it would permit its operation to be monitored. Since many industrial
processes have timescales easily addressed by millisecond response times, modern (fast, small,
reliable) electronics greatly facilitate building reliable controllers, and performance could be
traded off for reliability.[1]
Programming
Early PLCs, up to the mid-1990s, were programmed using proprietary programming panels or
special-purpose programming terminals, which often had dedicated function keys representing
the various logical elements of PLC programs.[2] Some proprietary programming terminals
displayed the elements of PLC programs as graphic symbols, but plain ASCII character
representations of contacts, coils, and wires were common. Programs were stored on cassette
tape cartridges. Facilities for printing and documentation were minimal due to lack of memory
capacity. The oldest PLCs used non-volatile magnetic core memory.
More recently, PLCs are programmed using application software on personal computers, which
now represent the logic in graphic form instead of character symbols. The computer is connected
to the PLC through USB, Ethernet, RS-232, RS-485, or RS-422 cabling. The programming
software allows entry and editing of the ladder-style logic. In some software packages, it is also
possible to view and edit the program in function block diagrams, sequence flow charts and
structured text. Generally the software provides functions for debugging and troubleshooting the
PLC software, for example, by highlighting portions of the logic to show current status during
operation or via simulation. The software will upload and download the PLC program, for backup
and restoration purposes. In some models of programmable controller, the program is transferred
from a personal computer to the PLC through a programming board which writes the program
into a removable chip such as an EPROM
Basics of Programming
There are two types of contacts in PLC's and they are normally open and normally closed
switches. A normally open contact means the contact is on when pressed/closed, and a normally
closed contact is on when open/not pressed. Contacts represent the states of real world inputs
like sensors, switches, if the part is present, empty, full, etc. PLC's also consist of coils, which are
outputs like motors, pumps, lights, timers, etc. The PLC examines inputs and turns coils on or off
whenever it is needed. They can also be used as inputs to other rungs in the ladder diagram. [4]
Functionality
The functionality of the PLC has evolved over the years to include sequential relay control,
motion control, process control, distributed control systems, and networking. The data handling,
storage, processing power, and communication capabilities of some modern PLCs are
approximately equivalent to desktop computers. PLC-like programming combined with remote
I/O hardware, allow a general-purpose desktop computer to overlap some PLCs in certain
applications. Desktop computer controllers have not been generally accepted in heavy industry
because the desktop computers run on less stable operating systems than do PLCs, and
because the desktop computer hardware is typically not designed to the same levels of tolerance
to temperature, humidity, vibration, and longevity as the processors used in PLCs. Operating
systems such as Windows do not lend themselves to deterministic logic execution, with the result
that the controller may not always respond to changes of input status with the consistency in
timing expected from PLCs. Desktop logic applications find use in less critical situations, such as
laboratory automation and use in small facilities where the application is less demanding and
critical, because they are generally much less expensive than PLCs.[citation needed]
PLC topics
Features
Control panel with PLC (grey elements in the center). The unit consists of separate elements, from left to
right; power supply, controller, relay units for in- and output
Control panel with an Allen-Bradley PLC user interface for thermal oxidizer regulation.
The main difference from other computers is that PLCs are armored for severe conditions (such
as dust, moisture, heat, cold), and have the facility for extensive input/output (I/O) arrangements.
These connect the PLC to sensors and actuators. PLCs read limit switches, analog process
variables (such as temperature and pressure), and the positions of complex positioning systems.
Some use machine vision.[7] On the actuator side, PLCs operate electric
motors, pneumatic or hydraulic cylinders, magnetic relays, solenoids, or analog outputs. The
input/output arrangements may be built into a simple PLC, or the PLC may have external I/O
modules attached to a computer network that plugs into the PLC.
Scan time
A PLC program is generally executed repeatedly as long as the controlled system is running. The
status of physical input points is copied to an area of memory accessible to the processor,
sometimes called the "I/O Image Table". The program is then run from its first instruction rung
down to the last rung. It takes some time for the processor of the PLC to evaluate all the rungs
and update the I/O image table with the status of outputs.[8] This scan time may be a few
milliseconds for a small program or on a fast processor, but older PLCs running very large
programs could take much longer (say, up to 100 ms) to execute the program. If the scan time
were too long, the response of the PLC to process conditions would be too slow to be useful.
As PLCs became more advanced, methods were developed to change the sequence of ladder
execution, and subroutines were implemented.[9] This simplified programming could be used to
save scan time for high-speed processes; for example, parts of the program used only for setting
up the machine could be segregated from those parts required to operate at higher speed.
Special-purpose I/O modules may be used where the scan time of the PLC is too long to allow
predictable performance. Precision timing modules, or counter modules for use with shaft
encoders, are used where the scan time would be too long to reliably count pulses or detect the
sense of rotation of an encoder. The relatively slow PLC can still interpret the counted values to
control a machine, but the accumulation of pulses is done by a dedicated module that is
unaffected by the speed of the program execution.
System scale
A small PLC will have a fixed number of connections built in for inputs and outputs. Typically,
expansions are available if the base model has insufficient I/O.
Modular PLCs have a chassis (also called a rack) into which are placed modules with different
functions. The processor and selection of I/O modules are customized for the particular
application. Several racks can be administered by a single processor, and may have thousands
of inputs and outputs. Either a special high speed serial I/O link or comparable communication
method is used so that racks can be distributed away from the processor, reducing the wiring
costs for large plants. Options are also available to mount I/O points directly to the machine and
utilize quick disconnecting cables to sensors and valves, saving time for wiring and replacing
components.
User interface
See also: User interface and List of human-computer interaction topics
PLCs may need to interact with people for the purpose of configuration, alarm reporting, or
everyday control. A human-machine interface (HMI) is employed for this purpose. HMIs are also
referred to as man-machine interfaces (MMIs) and graphical user interfaces (GUIs). A simple
system may use buttons and lights to interact with the user. Text displays are available as well as
graphical touch screens. More complex systems use programming and monitoring software
installed on a computer, with the PLC connected via a communication interface.
Communications
PLCs have built-in communications ports, usually 9-pin RS-232, RS-422, RS-485, Ethernet.
Various protocols are usually included. Many of these protocols are vendor specific.
Most modern PLCs can communicate over a network to some other system, such as a computer
running a SCADA (Supervisory Control And Data Acquisition) system or web browser.
PLCs used in larger I/O systems may have peer-to-peer (P2P) communication between
processors. This allows separate parts of a complex process to have individual control while
allowing the subsystems to co-ordinate over the communication link. These communication links
are also often used for HMI devices such as keypads or PC-type workstations.
Formerly, some manufacturers offered dedicated communication modules as an add-on function
where the processor had no network connection built-in.
Programming
PLC programs are typically written in a special application on a personal computer, then
downloaded by a direct-connection cable or over a network to the PLC. The program is stored in
the PLC either in battery-backed-up RAM or some other non- volatile flash memory. Often, a
single PLC can be programmed to replace thousands of relays.[11]
Under the IEC 61131-3 standard, PLCs can be programmed using standards-based
programming languages. The most commonly used programming language is Ladder diagram
(LD) also known as Ladder logic. It uses Contact-Coil logic to make programs like an electrical
control diagram. A graphical programming notation called Sequential Function Charts is available
on certain programmable controllers. A model which emulated electromechanical control panel
devices (such as the contact and coils of relays) which PLCs replaced. This model remains
common today.
IEC 61131-3 currently defines five programming languages for programmable control
systems: function block diagram (FBD), ladder diagram (LD), structured text (ST; similar to
the Pascal programming language), instruction list (IL; similar to assembly language),
and sequential function chart (SFC).[12] These techniques emphasize logical organization of
operations.[11]
While the fundamental concepts of PLC programming are common to all manufacturers,
differences in I/O addressing, memory organization, and instruction sets mean that PLC
programs are never perfectly interchangeable between different makers. Even within the same
product line of a single manufacturer, different models may not be directly compatible.
Control example shown in ladder diagram
This is a programming example in ladder diagram which shows the control system. A ladder
diagram is a method of drawing control circuits which pre-dates PLCs. The ladder diagram
resembles the schematic diagram of a system built with electromechanical relays.
As an example, say a facility needs to store water in a tank. The water is drawn from the tank by
another system, as needed, and our example system must manage the water level in the tank by
controlling the valve that refills the tank. . Shown are:
Two inputs (from the low and high level switches) represented by contacts of the float
switches
An output to the fill valve, labelled as the fill valve which it controls
An "internal" contact, representing the output signal to the fill valve which is created in the
program.
A logical control scheme created by the interconnection of these items in software
In ladder diagram, the contact symbols represent the state of bits in processor memory, which
corresponds to the state of physical inputs to the system. If a discrete input is energized, the
memory bit is a 1, and a "normally open" contact controlled by that bit will pass a logic "true"
signal on to the next element of the ladder. Therefore, the contacts in the PLC program that
"read" or look at the physical switch contacts in this case must be "opposite" or open in order to
return a TRUE for the closed physical switches. Internal status bits, corresponding to the state of
discrete outputs, are also available to the program.
In the example, the physical state of the float switch contacts must be considered when choosing
"normally open" or "normally closed" symbols in the ladder diagram. The PLC has two discrete
inputs from float switches (Low Level and High Level). Both float switches (normally closed) open
their contacts when the water level in the tank is above the physical location of the switch.
When the water level is below both switches, the float switch physical contacts are both closed,
and a true (logic 1) value is passed to the Fill Valve output. Water begins to fill the tank. The
internal "Fill Valve" contact latches the circuit so that even when the "Low Level" contact opens
(as the water passes the lower switch), the fill valve remains on. Since the High Level is also
normally closed, water continues to flow as the water level remains between the two switch
levels. Once the water level rises enough so that the "High Level" switch is off (opened), the PLC
will shut the inlet to stop the water from overflowing; this is an example of seal-in (latching) logic.
The output is sealed in until a high level condition breaks the circuit. After that the fill valve
remains off until the level drops so low that the Low Level switch is activated, and the process
repeats again.
| (N.C. physical (N.C. physical |
| Switch) Switch) |
| Low Level High Level Fill Valve |
|------[ ]------|------[ ]----------------------(OUT)---------|
| | |
| | |
| | |
| Fill Valve | |
|------[ ]------| |
| |
| |
A complete program may contain thousands of rungs, evaluated in sequence. Typically the PLC
processor will alternately scan all its inputs and update outputs, then evaluate the ladder logic;
input changes during a program scan will not be effective until the next I/O update. A complete
program scan may take only a few milliseconds, much faster than changes in the controlled
process.
Programmable controllers vary in their capabilities for a "rung" of a ladder diagram. Some only
allow a single output bit. There are typically limits to the number of series contacts in line, and the
number of branches that can be used. Each element of the rung is evaluated sequentially. If
elements change their state during evaluation of a rung, hard-to-diagnose faults can be
generated, although sometimes (as above) the technique is useful. Some implementations
forced evaluation from left-to-right as displayed and did not allow reverse flow of a logic signal (in
multi-branched rungs) to affect the output.
Security
Prior to the discovery of the Stuxnet computer worm in June 2010, security of PLCs received little
attention. PLCs generally contain a real-time operating system such as OS-9 or VxWorks, and
exploits for these systems exist much as they do for desktop computer operating systems such
as Microsoft Windows. PLCs can also be attacked by gaining control of a computer they
communicate with.[13]
Simulation
Redundancy
Some special processes need to work permanently with minimum unwanted down time.
Therefore, it is necessary to design a system which is fault-tolerant and capable of handling the
process with faulty modules. In such cases to increase the system availability in the event of
hardware component failure, redundant CPU or I/O modules with the same functionality can be
added to hardware configuration for preventing total or partial process shutdown due to hardware
failure.
PLCs are well adapted to a range of automation tasks. These are typically industrial processes in
manufacturing where the cost of developing and maintaining the automation system is high
relative to the total cost of the automation, and where changes to the system would be expected
during its operational life. PLCs contain input and output devices compatible with industrial pilot
devices and controls; little electrical design is required, and the design problem centers on
expressing the desired sequence of operations. PLC applications are typically highly customized
systems, so the cost of a packaged PLC is low compared to the cost of a specific custom-built
controller design. On the other hand, in the case of mass-produced goods, customized control
systems are economical. This is due to the lower cost of the components, which can be optimally
chosen instead of a "generic" solution, and where the non-recurring engineering charges are
spread over thousands or millions of units.
For high volume or very simple fixed automation tasks, different techniques are used. For
example, a cheap consumer dishwasher would be controlled by an electromechanical cam
timer costing only a few dollars in production quantities.
A microcontroller-based design would be appropriate where hundreds or thousands of units will
be produced and so the development cost (design of power supplies, input/output hardware, and
necessary testing and certification) can be spread over many sales, and where the end-user
would not need to alter the control. Automotive applications are an example; millions of units are
built each year, and very few end-users alter the programming of these controllers. However,
some specialty vehicles such as transit buses economically use PLCs instead of custom-
designed controls, because the volumes are low and the development cost would be
uneconomical.[15]
Very complex process control, such as used in the chemical industry, may require algorithms and
performance beyond the capability of even high-performance PLCs. Very high-speed or precision
controls may also require customized solutions; for example, aircraft flight controls. Single-board
computers using semi-customized or fully proprietary hardware may be chosen for very
demanding control applications where the high development and maintenance cost can be
supported. "Soft PLCs" running on desktop-type computers can interface with industrial I/O
hardware while executing programs within a version of commercial operating systems adapted
for process control needs.[15]
Programmable controllers are widely used in motion, positioning, and/or torque control. Some
manufacturers produce motion control units to be integrated with PLC so that G-code (involving
a CNC machine) can be used to instruct machine movements.[16][citation needed]
PLCs may include logic for single-variable feedback analog control loop, a proportional, integral,
derivative (PID) controller. A PID loop could be used to control the temperature of a
manufacturing process, for example. Historically PLCs were usually configured with only a few
analog control loops; where processes required hundreds or thousands of loops, a distributed
control system (DCS) would instead be used. As PLCs have become more powerful, the
boundary between DCS and PLC applications has been blurred.
PLCs have similar functionality as remote terminal units. An RTU, however, usually does not
support control algorithms or control loops. As hardware rapidly becomes more powerful and
cheaper, RTUs, PLCs, and DCSs are increasingly beginning to overlap in responsibilities, and
many vendors sell RTUs with PLC-like features, and vice versa. The industry has standardized
on the IEC 61131-3 functional block language for creating programs to run on RTUs and PLCs,
although nearly all vendors also offer proprietary alternatives and associated development
environments.
In recent years "safety" PLCs have started to become popular, either as standalone models or as
functionality and safety-rated hardware added to existing controller architectures (Allen-
Bradley Guardlogix, Siemens F-series etc.). These differ from conventional PLC types as being
suitable for use in safety-critical applications for which PLCs have traditionally been
supplemented with hard-wired safety relays. For example, a safety PLC might be used to control
access to a robot cell with trapped-key access, or perhaps to manage the shutdown response to
an emergency stop on a conveyor production line. Such PLCs typically have a restricted regular
instruction set augmented with safety-specific instructions designed to interface with emergency
stops, light screens, and so forth. The flexibility that such systems offer has resulted in rapid
growth of demand for these controllers.
See also
Industrial control systems
Industrial safety systems
PLC Technician