I would like to talk about my experience in commissioning and developing industrial software. When reading the article, please note that it happened almost two years ago, and since then much has changed.
So, in the early spring of 2014, I climbed to the third floor of the concrete mixing hub of one plant. I had at my disposal two Wiggert planetary concrete mixers, a Kubat targeted supply line for two mono-rails and a fully bombed shop downstairs into which concrete had to be delivered. In perspective.
What was the cunning plan? We had to start from scratch the production of hollow flooring in one bay of the workshop and wall panels in the other.
')
Here is what the hollow flooring looks like in a section:
 Photos from echo.co.za
Photos from echo.co.zaSo, to test the concrete mixer, you need to put some successfully (or not) manufactured concrete. The option with ten Dzhamshutami was not considered, so you need to connect the address feed (AP). The mechanical part of the AP includes a pair of specially trained shuttles (kubels), rolling on a monorail, and a concrete distributor operating in a semi-automatic mode:

We begin to enjoy the Kubat documentation: the electrical part consists of a central control cabinet for 314-2DP, two ET200S stations (shuttles) and a CPU 313-2DP IFM (distributor), communicating via Powercom (analogue of Siemens PowerRail, i.e. RS-485 220 / 380V trolleys).

Oops, here are the first rakes: there are no software sources, and they are not foreseen. Okay, we reveal the passwords of the controllers with a special utility. With the dispenser, everything is more or less normal, but the central wreck is decompiled into a hearty porridge on STL, since Most of the program is written on the SFC is not clear what version.
Okay, not a question. To begin with, I send installers to prokidyvat communications along the monorails, connect power and install sensors, while I myself am looking at the diagram:

So, the inverter company Nord, controlled by Profibus. In our case it is used to power the drives of movement and rotation. Download the documentation, cheer up the control registers and write the code:
FUNCTION_BLOCK nord_control VAR_INPUT cmd:INT;  
Oh, it seems the shuttle has gone, but, it seems, some joyful shouts are heard from below. With obscene howls, the installers try to escape along the crane tracks from the racing five-ton glands. Emergency turn off the power and make a break for the calculation of personnel.
It would be nice to have at least some visualization. OK, we make a small project for the touch panel.

Within a couple of weeks, I finish the rest of the program (there should be a picture about the owl), so that concrete could be delivered ... which is not there yet.
In the meantime, the concreting of thermal stands ends at the bottom and the Echo line can be reactivated. It's simple. Or almost easy. The machines have been standing in the rain and pigeon feces since 2008, the trolley and the slip-former, after oil filling and cleaning, start working normally, but the saw throws a full screen of errors and says that it will not go anywhere.

Good fellows from Deutschland are eager to help, but only for a few tens of thousands of euros. Rubles do not accept.
Well, download the program from the controller, trying to understand what it needs. Everything looks as if the two positioning axes are stuck. In principle, this is not surprising: the power modules in the two inverters are completely burnt out. Well, we order new Emerson Unidrive and, in order not to waste time, we return to the BSU for a sekas with planetary concrete mixers.
One Wiggert is already mounted, plugged in and seemingly even tested. However, as always, the devil is in the details (well, of course, except for the extremely curved air connection and electrical wiring).

Dosing inert goes well, fun, with an error of a kilogram of 500. I adjust the sensors of the opening of the dispensers, I set the amount of charge, the error decreases to 2-10 kg.
A couple of weeks come chastotniki. We put them in the cabinet, we carry out the transfer of settings (yes, there are still SM-Applications Plus modules with their own programs) and axis referencing.

Profit! You can begin to produce products. Of course, if you first choose the composition of concrete.
In general, everything ended happy ending and the line safely works to this day.