16#define SG_COM_VERSION_NAME "5.1.0"
116 void* custom_engine_data);
129 void* custom_engine_data);
232 const unsigned char* algorithms_file,
233 unsigned int algorithms_file_size
294 int *processed_frames,
295 int *remaining_frames
385 const char* expression,
518 double *current_time_ms
void(* SG_LoggingCallback)(const char *message)
Callback that will be called by an Engine to output log messages.
SG_AudioSampleType
Enum of audio sample types.
SG_AudioSampleRate
Enum of audio sample rates.
#define SG_DYN
Used to determine if we are building a shared library, as opposed to building a static library or con...
SG_LoggingLevel
Enum for logging level.
SG_DYN SG_COM_Error SG_COM_GetModeList(SG_COM_EngineHandle engine_handle, char *mode_list, sg_size buffersize)
Get a list of the available behavior modes in an Engine.
void(* SG_COM_EngineBroadcastCallback)(SG_COM_EngineHandle engine_handle, char *packet, sg_size packet_bytes, void *custom_engine_data)
Callback that will be called by an Engine to output packets.
SG_COM_Role
Enum of roles.
@ SG_COM_ROLE_SPEAK
Speaking role.
@ SG_COM_ROLE_LISTEN
Listening role.
SG_DYN SG_COM_Error SG_COM_GetModifier(SG_COM_EngineHandle engine_handle, SG_COM_Modifier modifier, float *value)
Get the value of a modifier.
SG_DYN SG_COM_Error SG_COM_ProcessTick(SG_COM_EngineHandle engine_handle, int *processed_frames, int *remaining_frames)
Performs processing necessary to move one 10ms frame through the pipeline.
SG_DYN SG_COM_Error SG_COM_GetMode(SG_COM_EngineHandle engine_handle, char *mode, sg_size buffersize)
Get the current behavior mode of an Engine.
SG_DYN SG_COM_Error SG_COM_GetPlayableRange(SG_COM_PlayerHandle player_handle, double *min_time_ms, double *max_time_ms)
Get the range of buffered animation.
SG_COM_Modifier
Enum of modifiers.
@ SG_COM_MOD_DART_FREQ
Adjusts frequency of microdarts. Default is 1.0.
@ SG_COM_MOD_EXPRESSION_FREQ
Adjusts frequency of expression change. Default is 1.0.
@ SG_COM_MOD_BLINK_FREQ
Adjusts frequency of blinks. Default is 1.0.
@ SG_COM_MOD_NONVERBAL_MAG
Adjusts magnitude of nonverbal muscle motion. Default is 1.0.
@ SG_COM_MOD_BREATH_SPEED
Adjusts speed of breath. Default is 1.0.
@ SG_COM_MOD_SPEECH_MAG
Adjusts magnitude of speech muscle motion. Default is 1.0.
@ SG_COM_MOD_BREATH_MAG
Adjusts magnitude of breath. Default is 1.0.
@ SG_COM_MOD_NONVERBAL_SPEED
Adjusts speed of nonverbal muscle motion. Default is 1.0.
SG_DYN SG_COM_Error SG_COM_GetRole(SG_COM_EngineHandle engine_handle, SG_COM_Role *role)
Get the current role of an Engine.
SG_DYN SG_COM_Error SG_COM_UnsetAutoModes(SG_COM_EngineHandle engine_handle)
Clear the definitions for all auto modes.
SG_DYN SG_COM_Error SG_COM_CreateAltEngine(const SG_COM_EngineConfig *engine_config, SG_COM_EngineHandle *engine_handle, const unsigned char *algorithms_file, unsigned int algorithms_file_size)
Create an alternative Engine confguration using algorithms file.
SG_DYN SG_COM_Error SG_COM_Reset(SG_COM_EngineHandle engine_handle)
Clears an Engine and resets to initial state.
SG_DYN SG_COM_Error SG_COM_DestroyPlayer(SG_COM_PlayerHandle player_handle)
Destroy a Player.
void(* SG_COM_EngineStatusCallback)(SG_COM_EngineHandle engine_handle, SG_COM_Status status, const char *message, void *custom_engine_data)
Callback that will be called in the event of Engine status update.
SG_DYN SG_COM_Error SG_COM_InsertExpression(SG_COM_EngineHandle engine_handle, const char *expression, sg_size duration_ms, float scale)
Insert an expression.
SG_DYN SG_COM_Error SG_COM_UpdateAnimation(SG_COM_PlayerHandle player_handle, double time_ms, double *current_time_ms)
Set the current play time and update the animation nodes.
SG_COM_Error
Enum of error codes.
@ SG_COM_ERROR_INVALID_PARAM
An invalid parameter was passed to a function.
@ SG_COM_ERROR_INPUT_OVERRUN
The input buffer does not have sufficient free space to perform the requested operation.
@ SG_COM_ERROR_INVALID_PACKET
An invalid data packet was received.
@ SG_COM_ERROR_OUT_OF_ORDER_PACKET_DISCARDED
Process tick was called while the previous tick was in progress.
@ SG_COM_ERROR_NOT_IMPLEMENTED
This operation is not implemented.
@ SG_COM_ERROR_INVALID_HANDLE
An invalid Engine or Player was created or referenced.
@ SG_COM_ERROR_LOW_MEMORY
A low memory condition was detected.
@ SG_COM_ERROR_LICENSE_CHECKOUT_FAILURE
Failed to checkout a valid license.
@ SG_COM_ERROR_UNDEFINED
An unclassified error occurred.
@ SG_COM_ERROR_OK
No error.
@ SG_COM_ERROR_INVALID_LICENSE
The license is invalid.
@ SG_COM_ERROR_INPUT_UNDERRUN
The input buffer does not contain sufficient data to perform the requested operation.
@ SG_COM_ERROR_EXCEPTION
An exception was raised, call SG_COM_GetExceptionText() for details.
@ SG_COM_ERROR_TICK_IN_PROGRESS
SG_DYN unsigned int SG_COM_GetVersionNumber(void)
Get the runtime version number for this library.
struct SG_COM_Player * SG_COM_PlayerHandle
Handle type.
SG_DYN SG_COM_Error SG_COM_CreateEngine(const SG_COM_EngineConfig *engine_config, SG_COM_EngineHandle *engine_handle)
Create an Engine.
SG_DYN const char * SG_COM_GetExceptionText(void)
Retrieve exception text after SG_ERROR_EXCEPTION error.
SG_DYN SG_COM_Error SG_COM_DestroyEngine(SG_COM_EngineHandle engine_handle)
Destroy an Engine.
SG_DYN const char * SG_COM_GetVersionString(void)
Get the runtime version number for this library in string format.
SG_DYN SG_COM_Error SG_COM_SetModifier(SG_COM_EngineHandle engine_handle, SG_COM_Modifier modifier, float value)
Set the value of a modifier.
struct SG_COM_Engine * SG_COM_EngineHandle
Handle type.
SG_COM_Status
Enum of status codes.
@ SG_COM_STATUS_BREATH_CHANGED
The breath switched either from inhale to exhale or from exhale to inhale. The accompanying message i...
@ SG_COM_STATUS_EXPRESSION_CHANGED
The expression of the character changed. The accompanying message contains the path of the expression...
@ SG_COM_STATUS_MODE_CHANGED
The current behavior mode of the character changed, either manually or automatically....
@ SG_COM_STATUS_VOICE_ACTIVITY_CHANGED
A change in voice activity was detected. The accompanying message contains "0" or "1".
@ SG_COM_STATUS_AUTO_MODE_CHANGED
The latest triggered auto mode. The accompanying message contains name of the auto mode.
SG_DYN SG_COM_Error SG_COM_SetRole(SG_COM_EngineHandle engine_handle, SG_COM_Role role)
Set the role of an Engine vis-a-vis the incoming speech: to move as if speaking, or to move as if lis...
SG_DYN SG_COM_Error SG_COM_SetMode(SG_COM_EngineHandle engine_handle, const char *mode)
Set the current behavior mode of an Engine.
SG_DYN SG_COM_Error SG_COM_CreatePlayer(const SG_COM_PlayerConfig *player_config, SG_COM_PlayerHandle *player_handle)
Create a Player to play the output from a Broadcast Engine.
SG_DYN SG_COM_Error SG_COM_ActivateAutoModes(SG_COM_EngineHandle engine_handle)
Activate auto modes.
SG_COM_EngineConfigFlag
Enum of Engine configuration flags.
@ SG_COM_ENGINE_CONFIG_FIXED_RANDOM_SEED
Use a fixed seed in random number generators for deterministic output.
@ SG_COM_ENGINE_CONFIG_NONE
@ SG_COM_ENGINE_CONFIG_ENABLE_IDLE
Enable idle mode.
SG_DYN SG_COM_Error SG_COM_InputAuxData(SG_COM_EngineHandle engine_handle, const void *data, sg_size data_bytes)
Input auxiliary data for processing.
SG_COM_AutoMode
Enum of auto modes.
@ SG_COM_ACKNOWLEDGE_MODE
The mode triggered when a conditions for an acknowledgement are detected in Listen role.
@ SG_COM_NEGATIVE_MODE
The mode triggered when negative emotion is detected.
@ SG_COM_LAUGH_MODE
The mode triggered when a laugh is detected.
@ SG_COM_EFFORT_MODE
The mode triggered when an effort sound is detected.
@ SG_COM_POSITIVE_MODE
The mode triggered when positive emotion is detected.
SG_DYN SG_COM_Error SG_COM_Initialize(SG_LoggingLevel logging_level, SG_LoggingCallback logging_callback, const char *license_data, const char *license_unique_id, const char *license_custom_data)
Initialize the internal context of SG Com.
SG_DYN SG_COM_Error SG_COM_GetAnimationNodes(SG_COM_PlayerHandle player_handle, SG_AnimationNode **animation_nodes, sg_size *num_animation_nodes)
Get the animation nodes for a given Player.
SG_DYN SG_COM_Error SG_COM_ReceivePacket(SG_COM_PlayerHandle player_handle, const char *packet, sg_size packet_bytes)
Receive an output packet from an Engine into the corresponding Player.
SG_DYN SG_COM_Error SG_COM_SetDefaultMode(SG_COM_EngineHandle engine_handle, const char *mode)
Set the default behavior mode of an Engine.
SG_DYN SG_COM_Error SG_COM_Shutdown(void)
Shut down and dispose of the internal context of SG Com.
SG_DYN SG_COM_Error SG_COM_SetAutoMode(SG_COM_EngineHandle engine_handle, SG_COM_AutoMode auto_mode, const char *mode)
Define an auto mode by mapping it to a specific behavior mode.
SG_DYN SG_COM_Error SG_COM_InputAudio(SG_COM_EngineHandle engine_handle, const void *data, sg_size data_bytes)
Input audio data for processing.
Structure containing an animation node.
Structure containing an Engine configuration.
SG_AudioSampleRate audio_sample_rate
The input audio sample rate.
SG_AudioSampleType audio_sample_type
The input audio sample type.
SG_COM_EngineStatusCallback engine_status_callback
Callback for Engine status updates.
SG_COM_EngineBroadcastCallback engine_broadcast_callback
Callback to broadcast packets to remote Players (nullptr if not broadcasting).
SG_COM_EngineConfigFlag flag
Combination of engine configuration flags to enable/disable features.
sg_size character_file_bytes
The size of the loaded character file in bytes.
void * custom_engine_data
Custom user data (or nullptr).
SG_COM_PlayerHandle local_player
A handle to a Player object that can be used to create local animation output from this engine.
float buffer_sec
The maximum duration (in seconds) that the input buffer can hold.
sg_byte * character_file_in_memory
The character file loaded into a memory buffer.
Structure containing a Player configuration.
sg_byte * character_file_in_memory
The character file data loaded into memory.
float buffer_sec
The maximum duration (in seconds) that the output buffer can hold.
sg_size character_file_bytes
The size of the character file data in bytes.