The Manage VSD Locations window provides a consolidated location to manage and set the apparent physical location of sounds for trains using Virtual Sound Decoder.
The Manage VSD Locations window has four tabs: Reporters, Blocks, Operations Locations, and Listener. Each tab shows a list of objects, each with a check-box to enable/disable use (for VSD purposes, not for other JMRI purposes), and entry cells for X, Y, and Z location coordinates.The Reporters tab shows a list of all currently defined Reporters. This is intended for use with Digitrax Transponding or other similar locomotive tracking hardware systems.
The Blocks tab shows a list of all currently defined Blocks. This is intended for use with Digitrax Transponding or other similar locomotive tracking hardware systems. Using occupancy sensors it's possible to track exactly one loco.
The Operations Locations tab shows a list of all Locations defined within the JMRI Operations system.
The Listener tab shows the location of the Listener in the VSD sound system. The Listener position has two additional measurements: the Bearing (angle clockwise from the Y axis) and Azimuth (angle up or down from the X/Y plane) which together describe which way the Listener is facing.
With input from locomotive tracking hardware, Virtual Sound Decoder is able to move the apparent source of the locomotive sound to follow the locomotive's position on the layout. Well, there is an option to do this without any hardware, see below.
Note: Reporters and Blocks are not added to the Manage VSD Locations "live". If you add new Reporters or Blocks, you must close and re-open the Manage VSD Locations window to make the new Reporters or Blocks appear.
The VSD Locations system uses a standard "right handed" Cartesian coordinate system, where a location is defined by a combination of distances along an X, Y, and Z axis. The Origin, or center of the coordinates can be in any convenient location, such as the center of the room, a corner of the room, or a corner of the layout.
The X / Y / Z location values can be in any unit you choose, including an arbitrary relative scheme, as long as you are consistent. By default, positive X is to the space's right, positive Y is "forward", and positive Z is "up". Negative values are left, behind, and down, respectively. Alternately you may prefer to think of +X as "East", +Y as "North", and +Z as "up".
Note: The coordinate system can be rotated in any way that makes sense to the user. If it suits the railroad's arrangement better, +Y could be "East", +X "South", and +Z "Up". It is not recommended that the Z axis direction be changed however, unless your operators are accustomed to hanging from the ceiling.
A convenient system for a typical rectangular room-sized layout would be to place the origin at the near corner to the guest's left as the guest stands in the entry door, or the "bottom left" corner of the layout's track plan map, and with Z=0 at the layout's lowest nominal track elevation for the "live" part of the layout. This system ensures that all locations used will have positive X / Y / Z values.
If you do not specifically set the Listener location and orientation, the Listener by default will be at (0, 0, 0) and facing straight ahead along the +Y axis (bearing 0.0 degrees / azimuth 0.0 degrees). To set a different Listener location and/or orientation, go to the Listener tab and set the X / Y / Z coordinates of the Listener's location. The coordinates and units must be the same as those used for the Reporters or other Objects.
The Bearing and Azimuth values set the orientation of the Listener, or the direction the Listener is facing. Bearing is measured clockwise from the +Y axis. Azimuth is measured up (or down if negative) from the X/Y plane. Both measurements are in units of degrees of angle. For example, a Listener standing at the Origin (0, 0, 0) and facing "West" and halfway "up" would have a Bearing of 270 and an Azimuth of +45.
When you have followed the above setup steps, launch the VSDecoder Manager window, create a VSDecoder and run the locomotive. As your locomotive moves around the layout, the sound will follow the locomotive's reported position.
Note: The sound will appear to "jump" from location to location as the locomotive's reported location changes. This effect will be smaller with additional and more closely spaced reporters or blocks.
If you have installed occupancy sensors, you can use JMRI Blocks to enable a location following.
A convenient way to do the setup is creating a Panel with the JMRI Layout Editor. A Layout Editor guidance can be found here.
Your Panel should have all the Blocks and attached Sensors you need. Test and store the
Panel.
Then launch the VSDecoder Manager window and create a VSDecoder.
To start the location following enter the number of the VSDecoder locomotive address into the
Value field of your starting block (Tools ⇒ Tables ⇒ Block). This
sets the new sound position. Now run your locomotive.
If you do not have a hardware tracking system, you can use the JMRI Operations feature to enable a rudimentary form of location following.
To set the Operations locations:
To use Operations for location following, assign the specific locomotive to the train, then select the train in the locomotive's VSDecoder Options pane. When you MOVE the train in Operations, the sound will move to the next location on the Route.
For more information on Operations, see the JMRI® Operations User's Guide
With input from locomotive tracking hardware, Virtual Sound Decoder is able to move the apparent source of the locomotive sound to follow the locomotive's position on the layout.
However, there is an option to do this without tracking hardware:
simply uncheck the CheckBox "Use Blocks" in VSD Preferences.
This data driven "sound following" based on a LayoutEditor panel works as long as there
is an available piece of track.
A disadvantage: a mechanical issue may stop a loco but will not stop the sound
following - sound and loco position will get out of sync.
The next section presents two setup possibilities - a newer and simple way based on a LayoutEditor panel and an earlier way by adding some geometric layout data into a file.
Since JMRI 4.99.5 there is an easy way to use Advanced Location Following. For the setup a LayoutEditor (LE) panel and a simple VSDGeoData.xm file is required.
The LE panel must meet some minimum standards:
Here is an example of a VSDGeoData.xml:
<?xml version="1.0" encoding="UTF-8"?> <vsdecoder-geodata xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <layout-scale>N</layout-scale> <check-time>2000</check-time> <models>Layout Editor Clinic - Full Signals</models> <models-origin>(346, 260, 0)</models-origin> </vsdecoder-geodata>
The attributes are:
The file VSDGeoData.xml should be located in the same folder as your LayoutEditor panel.
To run a locomotive open PanelPro and load your LayoutEditor panel first. Then add a VSDecoder and start the engine. Now enter the DCC address in the Block Tables into a possible starting Block (if the DCC address matches "blockvalues.xml", this happens automatically - since JMRI 5.7.3), then open the throttle.
The current sound position is printed in the System Console.
Watch the System Console for events that stop the sound positioning.
To use another panel do also change the panel title in the VSDGeoData.xml.
Routes, Signals and Dispatcher are not tested.
Note 1: To hear the surround sound, at least two speakers are required.
Note 2: A turntable must have a ray track at a 180 degree offset for each ray track. The turntable support started with JMRI Test Release 5.5.2.
And here is the old setup version of Advanced Location Following.
Note: JMRI Test Release 4.13.2 or newer required.
A file named VSDGeoData.xml is required, which provides two general attributes and some specific attributes for each location.
Here is an example of a VSDGeoData.xml with one location (geodataset):
<?xml version="1.0" encoding="UTF-8"?> <vsdecoder-geodata xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <layout-scale>N</layout-scale> <check-time>2000</check-time> <setup> <geodataset> <reporter-systemname>LR1</reporter-systemname> <position>(-1.5, 1.1, 0.0)</position> <radius>0.0</radius> <slope>0.0</slope> <length>3.0</length> <end-position>(1.5, 1.1, 0.0)</end-position> </geodataset> </setup> </vsdecoder-geodata>
The route in this example is defined as a straight line parallel to the X axis, with a length of three meters.
The general attributes are:
The attributes for each location are:
Example for curve attributes:
... <radius>1.18</radius> <rotate-xpos>0.0</rotate-xpos> <rotate-ypos>0.83</rotate-ypos> ...
The location (geodataset) sequence defined in VSDGeoData.xml describes a route on a layout. The described route should go away from the left to the right in forward direction, or in case of a circle, in clock-wise forward direction.
The Advanced Location Following allows up to eight locomotives. Normally only one locomotive can be detected in a tracking section. If you want to run more than one locomotive, you may create a JMRI Route (up to four for VSD purposes) and add the Route to a Train. Please choose the predetermined Route names VSDRoute1 (default), VSDRoute2, VSDRoute3 or VSDRoute4. On the "Virtual Sound Decoder Manager" window you'll find an "Option" button on each VSDecoder. There you can select a JMRI Train and accordingly a Route. Please note that you need a setup section in your VSDGeoData.xml for each Route you want to use.
How to run a test with the JMRI LocoNet Simulator (without a connection to your layout):
Note: If you choose a Diesel VSD file you might want to add a top-speed element in the config.xml. Please see the config.xml of a Steam VSD file for the syntax and the right place.
During the setting up and test process I recommend to open a JMRI system console, which might provide helpful information: Help ⇒ System Console.
You might also enrich the logging information ( see Debugging and System Logging ), by adding the Logger Category Name
jmri.jmrit.vsdecoder.VSDGeoFile
at DEBUG level.
Once you have a working setup, you can activate an option in your VSD configuration file to print the calculated position points describing the route of your locomotive. Please see the "Create XY coordinates output in console for a VSDecoder" option for details.
For questions, please contact me on the JMRI users Groups.io group.