All Downloads are FREE. Search and download functionalities are using the official Maven repository.

marytts.modules.synthesis.WaveformSynthesizer Maven / Gradle / Ivy

The newest version!
/**
 * Copyright 2000-2006 DFKI GmbH.
 * All Rights Reserved.  Use is subject to license terms.
 *
 * This file is part of MARY TTS.
 *
 * MARY TTS is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, version 3 of the License.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see .
 *
 */
package marytts.modules.synthesis;

import java.util.List;

import javax.sound.sampled.AudioInputStream;

import marytts.exceptions.SynthesisException;

import org.w3c.dom.Element;

/**
 * Provide a common interface for all waveform synthesizers, to be called from within the "wrapping" Synthesis module.
 */
public interface WaveformSynthesizer {
	/**
	 * Start up the waveform synthesizer. This must be called once before calling synthesize().
	 * 
	 * @throws Exception
	 *             Exception
	 */
	public void startup() throws Exception;

	/**
	 * Perform a power-on self test by processing some example input data.
	 * 
	 * @throws Error
	 *             if the module does not work properly.
	 */
	public void powerOnSelfTest() throws Error;

	/**
	 * Synthesize a given part of a MaryXML document. This method is expected to be thread-safe.
	 * 
	 * @param tokensAndBoundaries
	 *            the part of the MaryXML document to synthesize; a list containing a number of adjacent t and boundary elements.
	 * @param voice
	 *            the Voice to use for synthesis
	 * @param outputParams
	 *            any specified output parameters; may be null
	 * @return an AudioInputStream in synthesizer-native audio format.
	 * @throws SynthesisException
	 *             if the voice requested for this section is incompatible with this WaveformSynthesizer.
	 */
	public AudioInputStream synthesize(List tokensAndBoundaries, Voice voice, String outputParams)
			throws SynthesisException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy