The Minimal Standard Interface follows from the 'Moving Part Rule', which specifies two electrical signals reporting position to be read as inputs to the signalling system.
The Minimal Standard Interface includes one 'Moving Part Rule' input pair and introduces a pair of signalling system 'output' electrical signals for general purpose use.
The signalling system comprises a Controller (or controllers), and Peripherals. The list of peripherals includes railway light and semaphore signals, gates (considered individually or grouped), track turnouts, track traversers, and train position sensors.
Peripherals may require an electrical power supply. A 50 volt DC bus will be run across the site for this. Peripherals may then be connected using six wires - 2 power and 4 electrical signals.
Some peripherals may have 'local intelligence' with 'CAN Bus' connectivity. Such peripherals will need only four wires for complete connection.
Coloured light and semaphore signals are accommodated.
Semaphore signal arms need to comply with the Moving Part Rule, position of the arm being reported back to the signalling system using the two controller input lines from the Standard Interface. One of the Standard Interface controller output lines could be considered sufficient to enable some mechanical actuator. In practice one of the four possible states will be specified to indicate 'Clear', the other three to show 'Danger'.
With no moving parts, the output pair are 'looped back' to the inputs. This informs the controller a coloured light signal head is present and functional. The two controller outputs will be decoded to show one of 'Red', 'Green', 'Black', and optionally 'Yellow' aspects.
All the above assumes use of 'POTS' (plain old telephone service) technology where every item of signalling equipment is hard-wired back to some signal 'box', a little like a telephone exchange of the 1950s. That's fine, but we could end up with an awful lot of wires !
To help in keeping it simple, we have also designed-in a 'CAN' (Controller Area Network) bus. This could connect to all or any piece of equipment using the same four wire cable, with the potential to reduce wiring complexity from "Total-Nightmare!" to "Near-Trivial"!. CAN bus connection also bypasses limitations of the '2 in, 2 out' wired interface. For example, over the wired interface, the two outputs could be decoded into four states, which for a signal could control one lamp to be 'Red', 'Yellow', 'Green' or 'Off'. A single CAN bus interface module provides local 'intelligence', which could control more than this, more lamps, occulting, alarm, actuator, push button etc.
Implementing a CAN Bus is not so trivial but is of no concern to anyone other than the person coding for it!
The controller we use throughout is the ARM Cortex variant STM32L432KC.
CAN Resources
CAN Bus tutorial from controllerstech.com
STM32L4 HAL and Low Layer User Manual.