Transformers documentation
X-Codec
This model was released on 2024-08-30 and added to Hugging Face Transformers on 2025-08-15.
X-Codec
Overview
The X-Codec model was proposed in Codec Does Matter: Exploring the Semantic Shortcoming of Codec for Audio Language Model by Zhen Ye, Peiwen Sun, Jiahe Lei, Hongzhan Lin, Xu Tan, Zheqi Dai, Qiuqiang Kong, Jianyi Chen, Jiahao Pan, Qifeng Liu, Yike Guo, Wei Xue.
The X-Codec model is a neural audio codec that integrates semantic information from self-supervised models (e.g., HuBERT) alongside traditional acoustic information. This enables:
- Music continuation: Better modeling of musical semantics yields more coherent continuations.
- Text-to-Sound Synthesis: X-Codec captures semantic alignment between text prompts and generated audio.
- Semantic aware audio tokenization: X-Codec is used as an audio tokenizer in the YuE lyrics to song generation model.
The abstract of the paper states the following:
Recent advancements in audio generation have been significantly propelled by the capabilities of Large Language Models (LLMs). The existing research on audio LLM has primarily focused on enhancing the architecture and scale of audio language models, as well as leveraging larger datasets, and generally, acoustic codecs, such as EnCodec, are used for audio tokenization. However, these codecs were originally designed for audio compression, which may lead to suboptimal performance in the context of audio LLM. Our research aims to address the shortcomings of current audio LLM codecs, particularly their challenges in maintaining semantic integrity in generated audio. For instance, existing methods like VALL-E, which condition acoustic token generation on text transcriptions, often suffer from content inaccuracies and elevated word error rates (WER) due to semantic misinterpretations of acoustic tokens, resulting in word skipping and errors. To overcome these issues, we propose a straightforward yet effective approach called X-Codec. X-Codec incorporates semantic features from a pre-trained semantic encoder before the Residual Vector Quantization (RVQ) stage and introduces a semantic reconstruction loss after RVQ. By enhancing the semantic ability of the codec, X-Codec significantly reduces WER in speech synthesis tasks and extends these benefits to non-speech applications, including music and sound generation. Our experiments in text-to-speech, music continuation, and text-to-sound tasks demonstrate that integrating semantic information substantially improves the overall performance of language models in audio generation.
Model cards:
- xcodec-hubert-librispeech (for speech)
- xcodec-wavlm-mls (for speech)
- xcodec-wavlm-more-data (for speech)
- xcodec-hubert-general (for general audio)
- xcodec-hubert-general-balanced (for general audio)
This model was contributed by Manal El Aidouni. The original code can be found here and original checkpoints for the five different models here.
Demos can be found on this page.
Usage example
Here is a quick example of how to encode and decode an audio using this model:
from datasets import load_dataset, Audio
from transformers import XcodecModel, AutoFeatureExtractor
dummy_dataset = load_dataset("hf-internal-testing/librispeech_asr_dummy", "clean", split="validation")
# load model and feature extractor
model_id = "hf-audio/xcodec-hubert-librispeech"
model = XcodecModel.from_pretrained(model_id)
feature_extractor = AutoFeatureExtractor.from_pretrained(model_id)
# load audio sample
dummy_dataset = dummy_dataset.cast_column("audio", Audio(sampling_rate=feature_extractor.sampling_rate))
audio_sample = dummy_dataset[-1]["audio"]["array"]
inputs = feature_extractor(raw_audio=audio_sample, sampling_rate=feature_extractor.sampling_rate, return_tensors="pt")
# encode and decode
encoder_outputs = model.encode(inputs["input_values"])
decoder_outputs = model.decode(encoder_outputs.audio_codes)
audio_values = decoder_outputs.audio_values
# or the equivalent with a forward pass
audio_values = model(inputs["input_values"]).audio_values
To listen to the original and reconstructed audio, run the snippet below and then open the generated original.wav and reconstruction.wav files in your music player to compare.
import soundfile as sf
original = audio_sample
reconstruction = audio_values[0].cpu().detach().numpy()
sampling_rate = feature_extractor.sampling_rate
sf.write("original.wav", original, sampling_rate)
sf.write("reconstruction.wav", reconstruction.T, sampling_rate)XcodecConfig
class transformers.XcodecConfig
< source >( target_bandwidths: typing.Optional[list[float]] = None sample_rate: int = 16000 kernel_size: int = 3 channel_ratios: list = [1, 1] strides: list = [1, 1] block_dilations: list = [1, 1] unit_kernel_size: int = 3 codebook_size: int = 1024 codebook_dim: typing.Optional[int] = None initializer_range: float = 0.02 acoustic_model_config: typing.Union[dict, transformers.models.dac.configuration_dac.DacConfig] = None semantic_model_config: typing.Union[dict, transformers.models.hubert.configuration_hubert.HubertConfig] = None **kwargs )
Parameters
-  target_bandwidths (List[float], optional, defaults to[0.5, 1, 1.5, 2, 4]) — The range of different bandwidths (in kbps) the model can encode audio with.
-  sample_rate (int, optional, defaults to 16000) — The sampling rate at which the audio waveform should be digitalized, in hertz (Hz).
-  kernel_size (int, optional, defaults to 3) — Kernel size for the initial semantic convolution.
-  channel_ratios (List[float], optional, defaults to[1, 1]) — Expansion factors for the number of output channels in each semantic block.
-  strides (List[int], optional, defaults to[1, 1]) — Strides for each semantic encoder block.
-  block_dilations (List[int], optional, defaults to[1, 1]) — Dilation factors for the residual units in semantic blocks.
-  unit_kernel_size (int, optional, defaults to 3) — Kernel size inside each ResidualUnit in semantic blocks.
-  codebook_size (int, optional, defaults to 1024) — Number of entries in each residual quantizer’s codebook.
-  codebook_dim (int, optional) — Dimensionality of each codebook vector. Defaults to sum of hidden size of acoustic and semantic models.
-  initializer_range (float, optional, defaults to 0.02) — Standard deviation of the truncated normal initializer for all weight matrices.
-  acoustic_model_config (Union[Dict, DacConfig], optional) — An instance of the configuration for the acoustic (DAC) model.
-  semantic_model_config (Union[Dict, HubertConfig, WavLMConfig], optional) — An instance of the configuration object for the semantic (HuBERT) model.
This is the configuration class to store the configuration of an XcodecModel. It is used to instantiate a Xcodec model according to the specified arguments, defining the model architecture. Instantiating a configuration with the defaults will yield a similar configuration to that of the Manel/X-Codec architecture.
Configuration objects inherit from PretrainedConfig and can be used to control the model outputs. Read the documentation from PretrainedConfig for more information.
Example:
>>> from transformers import XcodecModel, XcodecConfig
>>> # Initializing configuration
>>> configuration = XcodecConfig()
>>> # Initializing a model (with random weights) from the configuration
>>> model = XcodecModel(configuration)
>>> # Accessing the model configuration
>>> configuration = model.configXcodecModel
class transformers.XcodecModel
< source >( config )
Parameters
- config (XcodecModel) — Model configuration class with all the parameters of the model. Initializing with a config file does not load the weights associated with the model, only the configuration. Check out the from_pretrained() method to load the model weights.
The Xcodec neural audio codec model.
This model inherits from PreTrainedModel. Check the superclass documentation for the generic methods the library implements for all its model (such as downloading or saving, resizing the input embeddings, pruning heads etc.)
This model is also a PyTorch torch.nn.Module subclass. Use it as a regular PyTorch Module and refer to the PyTorch documentation for all matter related to general usage and behavior.
decode
< source >( audio_codes: Tensor return_dict: typing.Optional[bool] = None )
Parameters
-  audio_codes (torch.LongTensorof shape(batch_size, num_quantizers, codes_length)) — Discrete code indices computed usingmodel.encode.
-  return_dict (bool, optional) — Whether or not to return a ModelOutput
encode
< source >( input_values: Tensor bandwidth: typing.Optional[float] = None return_dict: typing.Optional[bool] = None )
Parameters
-  input_values (torch.FloatTensorof shape(batch_size, channels, num_samples)) — Float values of the input audio waveform.
-  bandwidth (float, optional) — The target bandwidth in (kbps) supports only values inconfig.target_bandwidths. Defaults to the highest available bandwidth4.0kbps.
-  return_dict (bool, optional) — Whether or not to return a ModelOutput.
forward
< source >( input_values: Tensor audio_codes: typing.Optional[torch.Tensor] = None bandwidth: typing.Optional[float] = None return_dict: typing.Optional[bool] = None  ) → XcodecOutput or tuple (audio_codes, audio_values)
Parameters
-  input_values (torch.FloatTensorof shape(batch_size, channels, num_samples)) — The raw float values of the input audio waveform.
-  audio_codes (torch.LongTensorof shape(batch_size, num_quantizers, codes_length)— Discrete code indices computed usingmodel.encode.
-  bandwidth (float, optional) — Target bandwidth in kbps. Must be one ofconfig.target_bandwidths. Defaults to the highest available bandwidth.
-  bandwidth (float, optional) — Target bandwidth in kbps. Must be one ofconfig.target_bandwidths. Defaults to the highest available bandwidth.
-  return_dict (bool, optional) — Whether to return aXcodecOutputinstead of a plain tuple.
Returns
XcodecOutput or tuple (audio_codes, audio_values)
- audio_codesof shape- (batch_size, num_quantizers, codes_length): the quantized discrete codes.
- audio_valuesof shape- (batch_size, channels, num_samples): the reconstructed audio waveform given the codes.
The XcodecModel forward method, overrides the __call__ special method.
Although the recipe for forward pass needs to be defined within this function, one should call the Module
instance afterwards instead of this since the former takes care of running the pre and post processing steps while
the latter silently ignores them.
Example:
>>> from datasets import load_dataset
>>> from transformers import AutoFeatureExtractor, XcodecModel
>>> model_id = "hf-audio/xcodec-hubert-librispeech"
>>> model = XcodecModel.from_pretrained(model_id)
>>> feature_extractor = AutoFeatureExtractor.from_pretrained(model_id)
>>> dataset = load_dataset("hf-internal-testing/librispeech_asr_dummy", "clean", split="validation")
>>> dataset = dataset.cast_column("audio", Audio(sampling_rate=feature_extractor.sampling_rate))
>>> audio_sample = dataset[0]['audio']['array']
>>> inputs = feature_extractor(raw_audio=audio_sample, return_tensors="pt")
>>> outputs = model(**inputs)
>>> audio_codes = outputs.audio_codes
>>> audio_values = outputs.audio_values