Module: vizInterface
Executive Summary
This module provides an interface to package up Basilisk messages and pass them onto the Vizard application. This allows for the Basilisk simulation data to be recorded to a file for play-back, or for live streaming of the simulation data. It is possible to record the simulation data of a single spacecraft or a multitude of spacecraft.
Module Assumptions and Limitations
The module is only able to read Basilisk simulation state messages that are accessable from the task group that
is calling vizInterface
.
Message Connection Descriptions
The following messages are set directly within vizInterface
. Additional messages are set within the
VizSpacecraftData
data structures for each spacecraft.
Parameter |
Default |
Description |
---|---|---|
opnavImageOutMsgs |
(optional) vector of Image output messages, the corresponding camera configuration input message is setup
through |
|
epochInMsg |
(optional) simulation epoch date/time input msg |
|
spiceInMsgs |
(optional) vector of input messages of planet Spice data |
The VizSpacecraftData
structure, defined in Module: vizStructures, contains a range of input messages for each spacecraft added.
Parameter |
Default |
Description |
---|---|---|
scStateInMsg |
msg of incoming spacecraft state data |
|
rwInMsgs |
(optional) Vector of incoming RW state messages |
|
thrInMsgs |
(optional) vector of thruster input messages |
|
cssInMsgs |
(optional) Vector of CSS config log messages |
Handshaking Protocol
vizInterface
facilitates the port configuration and handshaking process between BSK and Vizard. The current implementation of this protocol is defined here for developers, for use if an alternate visualization destination is desired.
BSK instantiates the broadcast socket using zmq_bind
, and the 2-way socket using zmq_connect
. Vizard joins these sockets using reciprocal connect
and bind
structure where appropriate.
The remaining complexity is with the 2-way socket, which couples BSK and Vizard in lockstep. After instantiation, vizInterface
empties the socket and sends “PING” to start communication. When sending a sim update, vizInterface
first sends the string “SIM_UPDATE”, followed by 2 empty messages, followed by the serialized message protobuffer. It then listens for the response “OK”. Periodic “PING” messages may be sent to keep the socket alive. To receive user input from Vizard, vizInterface
sends the string “REQUEST_INPUT”. It then collects the user input message, followed by a status string. The string “VIZARD_INPUT” signifies a successful send, while “ERROR” signifies an issue during transmission. When using opNav
, the string “REQUEST_IMAGE_” is sent to request for an image from configured onboard cameras.
For more specifics in message packaging and handling, see the source code for this module.
User Guide
The vizInterface
module can be directly configured, or setup using the helper methods in vizSupport.
More information can be found in BSK Scripting Settings page. The scenarioFormationBasic illustrates and
discusses how to configure vizInterface
for use with multiple satellites.
Defines
-
VIZ_MAX_SIZE
-
class VizInterface : public SysModel
- #include <vizInterface.h>
Defines a data structure for the spacecraft state messages and ID’s.
Public Functions
-
VizInterface()
VizInterface Constructor
-
~VizInterface()
VizInterface Destructor
-
void Reset(uint64_t CurrentSimNanos)
A Reset method to put the module back into a clean state
- Parameters:
CurrentSimNanos – The current sim time in nanoseconds
-
void UpdateState(uint64_t CurrentSimNanos)
Update this module at the task rate
- Parameters:
CurrentSimNanos – The current sim time
-
void ReadBSKMessages()
A method in which the module reads the content of all available bsk messages
-
void WriteProtobuffer(uint64_t CurrentSimNanos)
The method in which the vizInterface writes a protobuffer with the information from the simulation.
- Parameters:
CurrentSimNanos – The current sim time in nanoseconds
-
void addCamMsgToModule(Message<CameraConfigMsgPayload> *tmpMsg)
Method to add a Vizard instrument camera module to vizInterface
- Parameters:
tmpMsg – Camera configuration msg
Public Members
-
std::vector<VizSpacecraftData> scData
vector of spacecraft data containers
-
std::vector<ReadFunctor<SpicePlanetStateMsgPayload>> spiceInMsgs
vector of input messages of planet Spice data
-
std::vector<LocationPbMsg*> locations
vector of ground or spacecraft locations
-
std::vector<GravBodyInfo> gravBodyInformation
vector of gravitational body info
vector of vizard instrument camera output messages
[int] Set non-zero positive value if Unity/Viz couple in direct communication. (1 - regular opNav, 2 - performance opNav)
-
bool saveFile
[Bool] Set True if Vizard should save a file of the data.
-
bool liveStream
[Bool] Set True if Vizard should receive a live stream of BSK data.
-
bool broadcastStream
[Bool] Set True if messages should be broadcast for listener Vizards to pick up.
-
bool noDisplay
[Bool] Set True if Vizard should run performance opNav (no Vizard display)
-
std::vector<void*> bskImagePtrs
[RUN] vector of permanent pointers for the images to be used in BSK without relying on ZMQ because ZMQ will free it (whenever, who knows)
-
std::vector<ReadFunctor<CameraConfigMsgPayload>> cameraConfInMsgs
vector of incoming camera data messages
-
std::vector<MsgCurrStatus> cameraConfMsgStatus
vector of msg status of incoming camera data
-
std::vector<CameraConfigMsgPayload> cameraConfigBuffers
vector of Camera config buffers
-
int64_t FrameNumber
Number of frames that have been updated for TimeStamp message.
-
std::string protoFilename
Filename for where to save the protobuff message.
-
VizSettings settings
container for the Viz settings that can be specified from BSK
-
LiveVizSettings liveSettings
container for Viz settings that are updated on each time step
-
std::vector<VizEventDialog*> vizEventDialogs = {}
vector of dialog boxes to show
-
std::string reqComProtocol
Communication protocol to use when connecting to 2-way Vizard.
-
std::string reqComAddress
Communication address to use when connecting to 2-way Vizard.
-
std::string reqPortNumber
Communication port number to use when connecting to 2-way Vizard.
-
std::string pubComProtocol
Communication protocol to use when connecting to broadcast Vizard.
-
std::string pubComAddress
Communication address to use when connecting to broadcast Vizard.
-
std::string pubPortNumber
Communication port number to use when connecting to broadcast Vizard.
-
double broadcastSettingsSendDelay
Real-time delay between sending Viz settings to broadcast socket.
-
ReadFunctor<EpochMsgPayload> epochInMsg
simulation epoch date/time input msg
-
MsgCurrStatus epochMsgStatus
ID of the epoch msg.
-
EpochMsgPayload epochMsgBuffer
epoch msg data
-
Message<VizUserInputMsgPayload> userInputMsg
User input from Vizard.
-
BSKLogger bskLogger
BSK Logging object.
Private Functions
-
void receiveUserInput(uint64_t CurrentSimNanos)
request user input from Vizard, save as
During liveStream mode, ask Vizard for any user inputs recorded since the last timestep. Parse and package into VizUserInputMsgPayload for handling in Python.
- Parameters:
CurrentSimNanos – The current sim time
-
void requestImage(size_t camCounter, uint64_t CurrentSimNanos)
request image from Vizard and store it in output img msg
Requests an image from Vizard and stores it in the image output message
Private Members
-
void *requester_context
2-way context pointer (container for socket management)
-
void *requester_socket
2-way socket pointer (ZMQ_REQ)
-
void *publisher_context
Broadcast context pointer (container for socket management)
-
void *publisher_socket
Broadcast socket pointer (ZMQ_PUB)
-
int firstPass
Flag to intialize the viz at first timestep.
-
std::vector<MsgCurrStatus> spiceInMsgStatus
status of the incoming planets’ spice data messages
-
std::vector<SpicePlanetStateMsgPayload> spiceMessage
Spice message copies.
-
std::ofstream *outputStream
Output file stream opened in reset.
-
int64_t now
Current system time stamp.
-
int64_t lastSettingsSendTime
System time stamp when settings message was last sent to broadcast socket.
-
VizInterface()