/* * Copyright (C) 2008-2009 SVOX AG, Baslerstr. 30, 8048 Zuerich, Switzerland * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * @file picoapi.h * * SVOX Pico application programming interface * (SVOX Pico version 1.0 and later) * * Copyright (C) 2008-2009 SVOX AG, Baslerstr. 30, 8048 Zuerich, Switzerland * All rights reserved. * * History: * - 2009-04-20 -- initial version */ /** * @addtogroup picoapi * @b Basic_Concepts @e SVOX_Pico_System The SVOX Pico 'system' is the entity that manages data common to all SVOX Pico engines, e.g. linguistic data needed to do text-to-speech (TTS) synthesis, license key, etc. All API functions on the Pico system level take a 'pico_System' handle as the first parameter. @e SVOX_Pico_Engine A SVOX Pico 'engine' provides the functions needed to perform actual synthesis. Currently there can be only one engine instance at a time (concurrent engines will be possible in the future). All API functions at the engine level take a 'pico_Engine' handle as the first parameter. @e SVOX_Pico_Resource A SVOX Pico 'resource' denotes all the language- and speaker-dependent data needed to do TTS synthesis. In the following, the term 'resource' may be used interchangeably with the term 'lingware'. A resource file contains a set of knowledge bases for an entire TTS voice or parts of it. @b Basic_Usage In its most basic form, an application must call the following functions in order to perform TTS synthesis: - pico_initialize - pico_loadResource - pico_createVoiceDefinition - pico_addResourceToVoiceDefinition - pico_newEngine - pico_putTextUtf8 - pico_getData (several times) - pico_disposeEngine - pico_releaseVoiceDefinition - pico_unloadResource - pico_terminate It is possible to repeatedly run the above sequence, i.e., the SVOX Pico system may be initialized and terminated multiple times. This may be useful in applications that need TTS functionality only from time to time. @b Conventions @e Function_arguments All arguments that only return values are marked by a leading 'out...' in their name. All arguments that are used as input and output values are marked by a leading 'inout...'. All other arguments are read-only (input) arguments. @e Error_handling All API functions return a status code which is one of the status constants defined in picodefs.h. In case of an error, a more detailed description of the status can be retrieved by calling function 'pico_getSystemStatusMessage' (or 'pico_getEngineStatusMessage' if the error happened on the SVOX Pico engine level). Unlike errors, warnings do not prevent an API function from performing its function, but output might not be as intended. Functions 'pico_getNrSystemWarnings' and 'pico_getNrEngineWarnings' respectively can be used to determine whether an API function caused any warnings. Details about warnings can be retrieved by calling 'pico_getSystemWarning' and 'pico_getEngineWarning' respectively. */ #ifndef PICOAPI_H_ #define PICOAPI_H_ #include "picodefs.h" #ifdef __cplusplus extern "C" { #endif #if 0 } #endif #ifdef _WIN32 # define PICO_EXPORT __declspec( dllexport ) #else # define PICO_EXPORT extern #endif #define PICO_FUNC PICO_EXPORT pico_Status /* ********************************************************************/ /* PICO data types */ /* ********************************************************************/ /* Handle types (opaque) for Pico system, resource, engine ************/ typedef struct pico_system *pico_System; typedef struct pico_resource *pico_Resource; typedef struct pico_engine *pico_Engine; /* Signed/unsigned integer data types *********************************/ #define PICO_INT16_MAX 32767 #define PICO_UINT16_MAX 0xffff #define PICO_INT32_MAX 2147483647 #define PICO_UINT32_MAX 0xffffffff #include <limits.h> #if (SHRT_MAX == PICO_INT16_MAX) typedef short pico_Int16; #else #error "platform not supported" #endif #if (USHRT_MAX == PICO_UINT16_MAX) typedef unsigned short pico_Uint16; #else #error "platform not supported" #endif #if (INT_MAX == PICO_INT32_MAX) typedef int pico_Int32; #else #error "platform not supported" #endif #if (UINT_MAX == PICO_UINT32_MAX) typedef unsigned int pico_Uint32; #else #error "platform not supported" #endif /* Char data type *****************************************************/ typedef unsigned char pico_Char; /* String type to be used when ASCII string values are returned *******/ #define PICO_RETSTRINGSIZE 200 /* maximum length of returned strings */ typedef char pico_Retstring[PICO_RETSTRINGSIZE]; /* ********************************************************************/ /* System-level API functions */ /* ********************************************************************/ /* System initialization and termination functions ********************/ /** Initializes the Pico system and returns its handle in 'outSystem'. 'memory' and 'size' define the location and maximum size of memory in number of bytes that the Pico system will use. The minimum size required depends on the number of engines and configurations of lingware to be used. No additional memory will be allocated by the Pico system. This function must be called before any other API function is called. It may only be called once (e.g. at application startup), unless a call to 'pico_terminate'. */ PICO_FUNC pico_initialize( void *memory, const pico_Uint32 size, pico_System *outSystem ); /** Terminates the Pico system. Lingware resources still being loaded are unloaded automatically. The memory area provided to Pico in 'pico_initialize' is released. The system handle becomes invalid. It is not allowed to call this function as long as Pico engine instances are existing. No API function may be called after this function, except for 'pico_initialize', which reinitializes the system. */ PICO_FUNC pico_terminate( pico_System *system ); /* System status and error/warning message retrieval ******************/ /** Returns in 'outMessage' a description of the system status or of an error that occurred with the most recently called system-level API function. */ PICO_FUNC pico_getSystemStatusMessage( pico_System system, pico_Status errCode, pico_Retstring outMessage ); /** Returns in 'outNrOfWarnings' the number of warnings that occurred with the most recently called system-level API function. */ PICO_FUNC pico_getNrSystemWarnings( pico_System system, pico_Int32 *outNrOfWarnings ); /** Returns in 'outMessage' a description of a warning that occurred with the most recently called system-level API function. 'warningIndex' must be in the range 0..N-1 where N is the number of warnings returned by 'pico_getNrSystemWarnings'. 'outCode' returns the warning as an integer code (cf. PICO_WARN_*). */ PICO_FUNC pico_getSystemWarning( pico_System system, const pico_Int32 warningIndex, pico_Status *outCode, pico_Retstring outMessage ); /* Resource loading and unloading functions ***************************/ /** Loads a resource file into the Pico system. The number of resource files loaded in parallel is limited by PICO_MAX_NUM_RESOURCES. Loading of a resource file may be done at any time (even in parallel to a running engine doing TTS synthesis), but with the general restriction that functions taking a system handle as their first argument must be called in a mutually exclusive fashion. The loaded resource will be available only to engines started after the resource is fully loaded, i.e., not to engines currently running. */ PICO_FUNC pico_loadResource( pico_System system, const pico_Char *resourceFileName, pico_Resource *outResource ); /** Unloads a resource file from the Pico system. If no engine uses the resource file, the resource is removed immediately and its associated internal memory is released, otherwise PICO_EXC_RESOURCE_BUSY is returned. */ PICO_FUNC pico_unloadResource( pico_System system, pico_Resource *inoutResource ); /* *** Resource inspection functions *******************************/ /** Gets the unique resource name of a loaded resource */ PICO_FUNC pico_getResourceName( pico_System system, pico_Resource resource, pico_Retstring outName); /* Voice definition ***************************************************/ /** Creates a voice definition. Resources must be added to the created voice with 'pico_addResourceToVoiceDefinition' before using the voice in 'pico_newEngine'. It is an error to create a voice definition with a previously defined voice name. In that case use 'pico_releaseVoiceName' first. */ PICO_FUNC pico_createVoiceDefinition( pico_System system, const pico_Char *voiceName ); /** Adds a mapping pair ('voiceName', 'resourceName') to the voice definition. Multiple mapping pairs can added to a voice defintion. When calling 'pico_newEngine' with 'voiceName', the corresponding resources from the mappings will be used with that engine. */ PICO_FUNC pico_addResourceToVoiceDefinition( pico_System system, const pico_Char *voiceName, const pico_Char *resourceName ); /** Releases the voice definition 'voiceName'. */ PICO_FUNC pico_releaseVoiceDefinition( pico_System system, const pico_Char *voiceName ); /* Engine creation and deletion functions *****************************/ /** Creates and initializes a new Pico engine instance and returns its handle in 'outEngine'. Only one instance per system is currently possible. */ PICO_FUNC pico_newEngine( pico_System system, const pico_Char *voiceName, pico_Engine *outEngine ); /** Disposes a Pico engine and releases all memory it occupied. The engine handle becomes invalid. */ PICO_FUNC pico_disposeEngine( pico_System system, pico_Engine *inoutEngine ); /* ********************************************************************/ /* Engine-level API functions */ /* ********************************************************************/ /** Puts text 'text' encoded in UTF8 into the Pico text input buffer. 'textSize' is the maximum size in number of bytes accessible in 'text'. The input text may also contain text-input commands to change, for example, speed or pitch of the resulting speech output. The number of bytes actually copied to the Pico text input buffer is returned in 'outBytesPut'. Sentence ends are automatically detected. '\0' characters may be embedded in 'text' to finish text input or separate independently to be synthesized text parts from each other. Repeatedly calling 'pico_getData' will result in the content of the text input buffer to be synthesized (up to the last sentence end or '\0' character detected). To empty the internal buffers without finishing synthesis, use the function 'pico_resetEngine'. */ PICO_FUNC pico_putTextUtf8( pico_Engine engine, const pico_Char *text, const pico_Int16 textSize, pico_Int16 *outBytesPut ); /** Gets speech data from the engine. Every time this function is called, the engine performs, within a short time slot, a small amount of processing its input text, and then gives control back to the calling application. Ie. after calling 'pico_putTextUtf8' (incl. a final embedded '\0'), this function needs to be called repeatedly till 'outBytesReceived' bytes are returned in 'outBuffer'. The type of data returned in 'outBuffer' (e.g. 8 or 16 bit PCM samples) is returned in 'outDataType' and depends on the lingware resources. Possible 'outDataType' values are listed in picodefs.h (PICO_DATA_*). This function returns PICO_STEP_BUSY while processing input and producing speech output. Once all data is returned and there is no more input text available in the Pico text input buffer, PICO_STEP_IDLE is returned. All other function return values indicate a system error. */ PICO_FUNC pico_getData( pico_Engine engine, void *outBuffer, const pico_Int16 bufferSize, pico_Int16 *outBytesReceived, pico_Int16 *outDataType ); /** Resets the engine and clears all engine-internal buffers, in particular text input and signal data output buffers. */ PICO_FUNC pico_resetEngine( pico_Engine engine, pico_Status r_mode ); /* Engine status and error/warning message retrieval ******************/ /** Returns in 'outMessage' a description of the engine status or of an error that occurred with the most recently called engine-level API function. */ PICO_FUNC pico_getEngineStatusMessage( pico_Engine engine, pico_Status errCode, pico_Retstring outMessage ); /** Returns in 'outNrOfWarnings' the number of warnings that occurred with the most recently called engine-level API function. */ PICO_FUNC pico_getNrEngineWarnings( pico_Engine engine, pico_Int32 *outNrOfWarnings ); /** Returns in 'outMessage' a description of a warning that occurred with the most recently called engine-level API function. 'warningIndex' must be in the range 0..N-1 where N is the number of warnings returned by 'pico_getNrEngineWarnings'. 'outCode' returns the warning as an integer code (cf. PICO_WARN_*). */ PICO_FUNC pico_getEngineWarning( pico_Engine engine, const pico_Int32 warningIndex, pico_Status *outCode, pico_Retstring outMessage ); #ifdef __cplusplus } #endif #endif /*PICOAPI_H_*/