Model Railroad System
2.2.1
|
Block occupation detection using Circuits4Tracks Quad Occupancy Detector and a CTI Train Brain. More...
Public Member Functions | |
C4TTB_Block (name,...) | |
Constructor: initialize the block object. More... | |
occupiedp () | |
The occupiedp method returns yes or no (true or false) indicating block occupation. More... | |
propagate (aspect, from,...) | |
Method used to propagate distant signal states back down the line. More... | |
Static Public Member Functions | |
static | validate (object) |
Type validating code Raises an error if object is not either the empty string or a C4TTB_Block type. More... | |
Private Member Functions | |
_entering () | |
Method for entering a block. More... | |
_exiting () | |
Method for exiting a block. More... | |
Private Attributes | |
acela | |
Acela object. More... | |
forwardsignal | |
Signal object (typically a three color, one head block signal. More... | |
reversesignal | |
Signal object (typically a three color, one head block signal. More... | |
isoccupied | |
Saved occupation state. More... | |
Block occupation detection using Circuits4Tracks Quad Occupancy Detector and a CTI Train Brain.
Above is a simple diagram for using Circuits4Tracks Quad Occupancy Occupancy board has four current sensors. One wires one side of the track power (either DCC or DC) to a common rail and the other side through the Circuits4Tracks Quad Occupancy Detector to rails isolated with gaps (possibly with insulating rail joiners). This code uses a CTI Train Brain to connect a Circuits4Tracks Quad Occupancy Detectors to the computer via a CTI Acela computer interface.
Typical usage:
Four blocks in a loop:
A Schematic of the layout would look like this:
For the track work elements use "blockN occupiedp" for the track work elements' occupied command: eg Block1 would have 'block1 occupiedp' as its occupied command, that is its edit window would look like:
The other three blocks would be similar.
Then in the Main Loop, you would have:
Definition at line 59 of file C4TTB_Block.tcl.
C4TTB_Block::C4TTB_Block | ( | name | , |
... | |||
) |
Constructor: initialize the block object.
Install an CTIAcela object as a component created elsewhere). Install the blocks signal (created elsewhere).
name | Name of the block object |
... | Options:
|
|
private |
Method for entering a block.
|
private |
Method for exiting a block.
C4TTB_Block::occupiedp | ( | ) |
The occupiedp method returns yes or no (true or false) indicating block occupation.
C4TTB_Block::propagate | ( | aspect | , |
from | , | ||
... | |||
) |
Method used to propagate distant signal states back down the line.
aspect | The signal aspect that is being propagated. |
from | The propagating block (not used). |
... | Options:
|
|
static |
Type validating code Raises an error if object is not either the empty string or a C4TTB_Block type.
|
private |
Acela object.
Definition at line 77 of file C4TTB_Block.tcl.
|
private |
Signal object (typically a three color, one head block signal.
Definition at line 81 of file C4TTB_Block.tcl.
|
private |
Saved occupation state.
Definition at line 89 of file C4TTB_Block.tcl.
|
private |
Signal object (typically a three color, one head block signal.
Definition at line 85 of file C4TTB_Block.tcl.