runningthegeneratedequipmentsimulator

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
runningthegeneratedequipmentsimulator [2021/08/28 14:19]
wikiadmin
runningthegeneratedequipmentsimulator [2021/09/02 12:38] (current)
wikiadmin
Line 36: Line 36:
 ==== Using a JSON Configuration for the Simulator ===== ==== Using a JSON Configuration for the Simulator =====
  
-The TransSECS Host software can go online with a process tool and "characterize" it - obtain existing vidsceids, and rptids, as well as alids. This "characterization" is encapsulated in a JSON file, with the name ToolName.json, where ToolName is the name of the host project. After characterization this file will be in the userfiles of the project.+The TransSECS Host software can go online with a process tool and "characterize" it - obtain existing VIDsCEIDs, and RPTIDs. This "characterization" is encapsulated in a JSON file, with the name ToolName.json, where ToolName is the name of the host project. After characterization this file will be in the userfiles of the project.
  
 For example when you build the GEMHost project from the TransSECS distribution, you will see a file For example when you build the GEMHost project from the TransSECS distribution, you will see a file
Line 43: Line 43:
  
 In the project folder (or in the userfiles folder for MIStudio). In the project folder (or in the userfiles folder for MIStudio).
 +
 +Any file generated by TransSECS GEM Host will work. This file describes the tool and so can be used as a basis to reproduce the behavior of the tool. 
 +
 +This JSON file can be loaded into a bare simulator.  You can use the GEMTool example for this, or download the SimulatorTool from [[https://ergotech.com/files/examples/SimlatorTool.zip|here]] (this is just the GEMTool example with CEIDs and the simulation specific VIDs removed).
 +
 +Edit the ToolSimulator.conf file in the MIStudioSuite\TransSECS\resources\ToolSimulator folder 
 +
 +{{:pasted:20210828-142204.png}}
 +
 +You will need to change the section in the .conf file that adds the parameters to point to your file.  You can replace the whole section with this code, or download [[https://ergotech.com/files/examples/ToolSimulator.conf|this configuration file]] and replace the existing file.
 +
 +<code>
 +# Application parameters.  Add parameters as needed starting from 1
 +# To specify a port, uncomment out parameters .4 and .5 and change the port from 5010
 +wrapper.app.parameter.1=com.ergotech.transsecs.secs.EquipmentSimulator
 +wrapper.app.parameter.2=deploy.$toolname$
 +wrapper.app.parameter.3=-g
 +# The -j option allows you to very quickly build a tool simulator from you host project.
 +# See here, for more information https://www.ergotech.com/wiki/doku.php?id=runningthegeneratedequipmentsimulator
 +# Uncomment (remove the # that starts the line) this next line, and the wrapper.app.parameter.5 after providing a path to your host file.
 +#wrapper.app.parameter.4=-j
 +# Edit the next line to point to a JSON file generated by a TransSECS Host application
 +# Any GEM Host project that you build will have a file with the name of the host
 +# for example, GEMHost will have the file GEMHostModel.json in the TransSECS folder (or the UserFiles for MIStudio applications)
 +# You can Characterize the tool (https://ergotech.com/files/guides/TransSECSGEMHostToolCharacterizationGuide.pdf) to get
 +# all the information you need for your simulation.
 +#wrapper.app.parameter.5=\PATH\TO\JSON\FILE
 +#wrapper.app.parameter.6=-p
 +#wrapper.app.parameter.7=5010
 +#wrapper.app.parameter.8=-deviceid
 +#wrapper.app.parameter.9=1
 +</code>
 +
 +Remove the # from the line:
 +
 +<code>
 +wrapper.app.parameter.4=-j
 +</code>
 +
 +Add the path to your JSON file:
  
 <note>You must replace the backslashes (\) with forward slashes (/) in the path name before using this in the .conf file.  In the example above, this would then be <note>You must replace the backslashes (\) with forward slashes (/) in the path name before using this in the .conf file.  In the example above, this would then be
  
-C:/Users/Public/ErgoTech/TransSECSDevices/Projects/GEMHost/GEMHostModel.json </note>+C:/Users/Public/ErgoTech/TransSECSDevices/Projects/GEMHost/GEMHostModel.json 
 +</note>
  
 +<code>
 +wrapper.app.parameter.5=C:/Users/Public/ErgoTech/TransSECSDevices/Projects/GEMHost/GEMHostModel.json
 +</code>
  
-This JSON file can be loaded into bare simulator and used as basis to reproduce the behavior of the tool. To improve the simulator you will probably need to add some of the tool's host commands and other special messages such as those for recipe handling.+Change the //Device ID// and //Port// in the file to match the values in your host.  You can see what you've set in your host by clicking on the root of the tree. 
 + 
 +{{:pasted:20210828-145027.png?0x100}} 
 + 
 +Modify and uncomment the appropriate lines in the .conf file: 
 + 
 +<code> 
 +wrapper.app.parameter.6=-p 
 +wrapper.app.parameter.7=5010 
 +wrapper.app.parameter.8=-deviceid 
 +wrapper.app.parameter.9=1 
 +</code>  
 + 
 +Be sure that the numbering is consecutive.  That is, if you've made other changes, the numbers following the //wrapper.app.parameter.// must start zero and increment without any missing numbers.  Lines that start with # don't count. 
 + 
 +After making these changes, double-click the ToolSimulator executable: 
 + 
 +{{:pasted:20210828-144232.png}} 
 + 
 +The simulator should start and you should see your variables and events in the "VID" and "Send Event" dropdown. 
 + 
 +{{:pasted:20210828-144312.png}} 
 + 
 +Change your "Tool IP Addr" to be //localhost// (or the IP Address of the system on which you are running the simulator).   
 + 
 +{{:pasted:20210828-145027.png}} 
 + 
 +Build your host application, click the SIM/LIVE button and click on a message.  You'll see it connect to the simulator: 
 + 
 +{{:pasted:20210828-150432.png}} 
 + 
 +Choose an event and press the "Send Event" button.  If you have reports attached to the event, choose a VID, change the value, send the event again and you'll see the updated value. 
 + 
 +To improve the simulator you will probably need to add some of the tool's host commands and other special messages such as those for recipe handling.  Simply open the SimulatorTool project,add the messages and rebuild. 
 + 
 +GEM requires that certain variables be available from the tool.  The SimulatorTool (or the GEMTool) provide this set of variables.  If these variable names are not in your JSON file you should leave them in the tool simulator, otherwise, they can be removed (It does no harm to leave them in the simulator - the variables from the JSON file will be used if available).
  
 To use a pre-defined ToolName.json for the simulator, prepare a TransSECS tool project with any number of messages (such as host commands and/or recipe messages), and include only two VIDs (OnlineOfflineState and LocalRemoteState) if not already defined by these names in the JSON file. These two parameters are needed for the base simulator software to be able to enable online/remote. To use a pre-defined ToolName.json for the simulator, prepare a TransSECS tool project with any number of messages (such as host commands and/or recipe messages), and include only two VIDs (OnlineOfflineState and LocalRemoteState) if not already defined by these names in the JSON file. These two parameters are needed for the base simulator software to be able to enable online/remote.
  
-To use the JSON file for the simulator, copy this file into the generated simulator directory and edit the Simulator.config file as described in the section above to expose the .8 and .9 properties (-j and the name of the JSON file). Be sure that the numbering is consecutive+ 
 + 
 +To use the JSON file for the simulator, copy this file into the generated simulator directory and edit the Simulator.config file as described in the section above to expose the .8 and .9 properties (-j and the name of the JSON file).
  • runningthegeneratedequipmentsimulator.1630178358.txt.gz
  • Last modified: 2021/08/28 14:19
  • by wikiadmin