-
-
Notifications
You must be signed in to change notification settings - Fork 145
Error Messages List
This is a work in progress list and therefore some instructions may yet need adding.
Explanation and Fix
This error occurs when curl
cannot validate an SSL/TLS certificate, often due to issues with your machine’s root certificates, internet connection, or network restrictions preventing contact with a Certificate Authority (CA). This issue is unrelated to AllTalk or its installer—it’s specific to curl
's handling of certificates when downloading files from GitHub. This error is out of scope for support on here, so the below is only a general guide on the issue.
curl: (35) schannel: next InitializeSecurityContext failed: CRYPT_E_NO_REVOCATION_CHECK
The error CRYPT_E_NO_REVOCATION_CHECK
typically means:
- System Clock Issues: An incorrect time or timezone on your machine can prevent certificate validation.
- Outdated version of CURL: Some older versions of CURL need updating,
- Outdated Root Certificates: Your machine’s root certificates may need updating.
- Network or Firewall Restrictions: If the system cannot contact the Certificate Authority (CA) to confirm the certificate’s validity, the check may fail.
- Internet Connection Problems: Temporary internet issues or restricted network settings can also prevent successful communication with the CA.
-
Ensure Correct System Time and Date
Make sure your system time, date, and timezone are accurate. Certificates depend on correct timestamps to verify their validity. -
Update
curl
to a new build - Ensure you have done this
Typically on Windows systems you will have Microsoft's version of CURL installed, which at time of writing was 8.9.1. You can check the version by runningcurl --version
at a command prompt:Curl 8.9.1 has no known issues with downloads and this error, hence it would be something else causing the problem (Antivirus, Firewall etc). In this case you can either investigate your Antivirus, Firewall, Router etc OR perform Step 6 in the list below, which will bypass the CURL issue, but doesnt ensure you are downloading a confirmed/known copy of the software.
To be 100% clear, some Antivirus, Internet Proxies and VPN software may be affecting CURL's ability to check SSL certificates, for example, Avast Antivirus appears to cause this issue Source.
If you have manually installed curl on your system you may want to update CURL to ensure its not a bug as there have been issues with some versions of CURL. Updating to the latest version from this link curl's website.
-
Check Internet Connection and Firewall Settings
- Internet Connection: Ensure you’re connected to the internet and that the connection is stable.
- Firewall or Network Restrictions: Sometimes firewalls or security software may block the certificate validation process. If possible, temporarily disable or adjust firewall settings to see if it resolves the issue.
-
Update Your System
An outdated system can sometimes have missing certificates or certificate management tools. Run a system update:- Windows: Use Windows Update to get the latest updates.
- Linux/macOS: Run your package manager’s update commands.
-
Update Root Certificates
⚠️ Proceed with caution: Updating certificates can involve advanced system changes.-
On Windows: Run
certutil -generateSSTFromWU roots.sst
in PowerShell or Command Prompt to update root certificates. -
On Linux/macOS:
sudo apt update && sudo apt install --reinstall ca-certificates # Debian/Ubuntu sudo update-ca-certificates # Update cert store
-
On Windows: Run
-
Add
--ssl-no-revoke
to all curl commands inatsetup.bat
This technically speaking is a security risk as it bypasses checks to make sure things you are downloading are coming from a safe source, hence I do and will not add this to standard the setup routine. You would manually editatsetup.bat
and any lines that start withcurl
you would add--ssl-no-revoke
onto the start, before the-LO
e.g.curl -LO https://github.com/erew123/file-blah-blah.....etc..
you would add
--ssl-no-revoke
aftercurl
and before the-LO
as shown below:curl --ssl-no-revoke -LO https://github.com/erew123/file-blah-blah.....etc...
which should bypass the ssl revocation check.
As the line numbers change when updating atsetup.bat I cannot specify the exact line numbers here.
Certificate validation checks occur locally on your machine, but they may also involve communication with a Certificate Authority (CA). Here’s a simplified explanation:
- Local Certificate Verification: Your machine first checks its local certificates to confirm the chain of trust.
-
Certificate Authority (CA) Communication: If network access is available, the system may connect to the CA to confirm that the certificate hasn’t been revoked. This can happen through:
- CRL (Certificate Revocation List): A list of revoked certificates provided by the CA.
- OCSP (Online Certificate Status Protocol): A real-time check with the CA to verify the certificate’s status.
If your internet connection is unstable, if network access is restricted by a firewall, or if your machine’s certificates are outdated, this process may fail, resulting in errors like CRYPT_E_NO_REVOCATION_CHECK
.
Summary
Most validation happens locally, but a final revocation check (CRL or OCSP) often requires internet access. If internet access is restricted or there are issues with local certificate configurations, this check may fail.
Relevant Links:
- AllTalk Installer Line: Installer Command
- Manual DeepSpeed Download: Download Here
Explanation and Resolution
During the installation of requirements, you may encounter the following warning:
ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts.
coqui-tts 0.24.1 requires transformers<4.41.0,>=4.33.0, but you have transformers 4.43.3 which is incompatible.
This warning is related to a version conflict between Coqui-TTS and the Transformers library. It's connected to the "TypeError in Transformers Library with Coqui XTTS TTS Engine" issue discussed earlier.
Key points to understand:
- Coqui-TTS and the XTTS engine currently require Transformers version 4.40.2 for generating streaming audio.
- Other TTS engines (like Parler-TTS) may attempt to install a later version of Transformers.
- This conflict primarily affects streaming audio generation with the Coqui XTTS engine.
- Non-streaming audio generation is not affected by this issue.
- Streaming audio with XTTS: Affected (requires Transformers 4.40.2)
- Non-streaming audio with XTTS: Not affected (works with any Transformers version)
- Other uses (e.g., Kobold): May be affected if using XTTS with streaming audio
To resolve this issue and enable streaming audio with XTTS:
-
Downgrade Transformers to version 4.40.2:
pip install transformers==4.40.2
-
Be aware that this may generate a dependency warning for Parler-TTS, but it should still function correctly.
- This is a temporary solution until the Coqui-TTS engine is updated to support newer versions of Transformers for streaming audio.
- AllTalk is not responsible for the maintenance or upkeep of the Coqui-TTS engine.
- You can re-run the setup process and reapply requirements in the future if you need to change this configuration.
The Coqui-TTS team is working on updating their engine to support newer versions of Transformers. Once this update is released, it should resolve the conflict without requiring a specific version downgrade.
If you primarily use XTTS for streaming audio, it's recommended to downgrade Transformers to 4.40.2. If you don't use XTTS streaming or can work without it temporarily, you may keep the latest version of Transformers installed.
🟨 {something} Encountered problems while solving: package {something} is excluded by strict repo priority
Explanation and Fix
This error occurs due to strict channel priority in Conda, which prevents packages from lower-priority channels (like conda-forge
) from being installed, even if explicitly requested. It typically happens when Conda is configured to prefer packages from higher-priority channels (e.g., defaults
) over others, causing certain packages to be excluded.
-
Ensure you're using the correct Conda environment:
-
On Windows: Run your environment setup script or locate
conda.exe
in your system.
You can often find it in the Miniconda or Anaconda installation directory:orC:\Users\<YourUsername>\Miniconda3\Scripts\conda.exe
C:\ProgramData\Anaconda3\Scripts\conda.exe
-
On Linux/Mac: Locate
conda
by running:which conda
-
On Windows: Run your environment setup script or locate
-
Check if there is a system-wide Conda installation: There may be a global Conda installation on your system, separate from the environment currently being set up. To confirm, search for other installations of Conda:
- On Windows: Look in
C:\Program Files
orC:\ProgramData
directories for global installations. - On Linux/Mac: Check common global installation paths like
/opt/anaconda3/
or/usr/local/miniconda3/
.
- On Windows: Look in
-
Change the channel priority to flexible: Run the following command to allow Conda to consider packages from lower-priority channels like
conda-forge
:conda config --set channel_priority flexible
-
Install the required package: After changing the priority, you can now install the package without encountering the error:
conda install -y conda-forge::ffmpeg
By setting channel priority to flexible, Conda can use packages from any listed channel as long as they fulfill the dependencies, rather than strictly preferring packages from high-priority channels.
Conda's documentation on channels can be found here https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-channels.html
Explanation and Fix
This error occurs on Linux systems when trying to install Python packages that require compilation of C extensions. It happens because the GNU Compiler Collection (GCC) is not installed on the system.
Python often relies on C extensions for performance-critical parts of packages. When installing such packages, Python uses the system's C compiler (typically gcc) to build these extensions. If gcc is not available, the installation fails.
To fix this:
-
Install the necessary compilers using the following command:
sudo apt install gcc g++
-
After installation, retry the Python package installation.
Note: You may need to install additional development libraries depending on the package you're trying to install. For example, Python development files might be required:
sudo apt install python3-dev
After installing gcc and any necessary development libraries, remember to rerun your package installation command.
🟥 The OrderedVocab you are attempting to save contains holes for indices [XXXX, XXXX], your vocabulary could be corrupted!
Explanation and Fix
This error typically occurs when something has been corrupted or interpreted incorrectly by the Transformers library (Huggingface) during dataset processing or within the model's config.json
file.
The OrderedVocab you are attempting to save contains holes for indices [XXXX, XXXX], your vocabulary could be corrupted!
This is most likely due to an upstream issue in Coqui's scripts or Huggingface's Transformers library, where the dataset or vocabulary becomes misaligned.
The simplest solution is to rebuild your training dataset and try again. This usually resolves the issue.
If this error becomes frequent, I will add extra validation checks into the finetuning process to inspect datasets for potential issues. However, since this is likely an upstream issue (involving third-party libraries), it may not be fully resolvable within AllTalk.
🟪 torch.cuda.OutOfMemoryError
: CUDA out of memory error. Tried to allocate XXX MiB. GPU 0 has a total capacity of XXX GiB of which 0 bytes is free.
Explanation and Troubleshooting Steps
This error occurs when your GPU’s VRAM (Video RAM) is fully allocated, and PyTorch is unable to reserve the additional memory required for a task. This may happen with demanding tasks, such as TTS generation or model fine-tuning, which can quickly exhaust VRAM, especially on GPUs with lower memory capacity (e.g., 6GB or less).
torch.cuda.OutOfMemoryError: CUDA out of memory. Tried to allocate 14.00 MiB. GPU 0 has a total capacity of 6.00 GiB of which 0 bytes is free.
The CUDA out of memory
error signifies that:
- The GPU is at its VRAM capacity, preventing the allocation of additional memory for the current process.
- The specific memory requested and the GPU’s total VRAM may vary, but the error indicates an inability to free up sufficient VRAM for the next operation.
- Restart the application or your computer to clear any unused GPU memory.
- Close other GPU-intensive programs that may be using VRAM, such as games, graphics software, web pages with lots of images or other AI applications.
- If applicable, reduce the batch size or modify parameters that may increase VRAM usage.
- When finetuning you can adjust a few settings to potentially improve the situation, Memory Management Help Link 1 and Help Link 2
In NVIDIA drivers version 536.40 and above, a “shared memory fallback” feature allows applications to use system RAM if the GPU runs out of VRAM, which can prevent crashes but may reduce performance. Disabling this setting may help maintain performance stability but could cause the application to crash if VRAM maxes out. Enabling it will allow your Windows system to use System Ram as GPU VRAM, but will slow things down and can still result in out of memory issues.
Steps to Disable Shared Memory Fallback:
- Open Task Manager and locate the path of the
python.exe
process running your application. (For example:"C:\path\to\python.exe"
) - Open the NVIDIA Control Panel (right-click on the desktop and select “NVIDIA Control Panel”).
- Go to Manage 3D Settings and navigate to the Program Settings tab.
- Click Add to select a program, then browse and select the
python.exe
file noted in Step 1. - Under CUDA - Sysmem Fallback Policy, set the value to Prefer No Sysmem Fallback.
- Click Apply to save the changes, and then restart the application.
Re-enabling Shared Memory Fallback:
- Return to the NVIDIA Control Panel > Manage 3D Settings > Program Settings tab.
- Select the relevant
python.exe
file and set CUDA - Sysmem Fallback Policy to Driver Default. - Click Apply, and restart your application.
Note: This feature is available only on Windows. Linux currently does not support shared memory fallback.
- Linux does not support shared memory fallback for VRAM, so VRAM constraints are stricter. Ensure your system has sufficient VRAM and system RAM to meet your application’s requirements. Consider upgrading your GPU if you regularly encounter this limitation.
- If feasible, use a smaller model or reduce the complexity of the task to require less memory.
- Certain applications or model versions may require significantly less VRAM and could provide a solution without compromising too much performance.
Running out of VRAM is a common limitation, especially for demanding AI tasks. On Windows, shared memory fallback may alleviate the issue by offloading to system RAM, although this can impact performance. Disabling this fallback can stabilize performance, but it may lead to crashes if VRAM is exceeded. Linux users will need to rely on VRAM optimization techniques since shared memory fallback is not supported.
For more information, see NVIDIA’s official documentation: NVIDIA System Memory Fallback Guide
Explanation and Fix
If you have an issue with one of the TTS engines failing to start-up because Coqui TTS (XTTS, VITS) is damaged OR Parler TTS is damaged, you can download the base tts_engine.json
and save it over your current tts_engine.json
file to get back to factory. It can be downloaded from here using the Download Raw file
(arrow pointing down over an inbox icon on the top right of the page) and saving it over the top of your alltalk_tts/system/tts_engines/tts_engine.json
file.
Explanation and Fix
This error occurs when Python cannot find a module that your code is trying to import. It typically means that either:
- The required package is not installed in your environment.
- The package is installed but not in the Python path.
To fix this:
-
Ensure you're using the correct Python environment:
- On Windows: Run
start_environment.bat
- On Linux: Run
./start_environment.sh
- On Windows: Run
-
Ensure all requirements are installed correctly:
pip install -r requirements.txt
-
If the error persists, try uninstalling and reinstalling the specific package with the force and upgrade options:
pip uninstall XXXXXXX pip install XXXXXXX --upgrade --force-reinstall
-
Clear the pip cache to ensure you're not using any corrupted downloads:
pip cache purge
-
Check if the package name in your code matches exactly with the installed package name.
If you're still experiencing issues, ensure you're using the correct version of Python for your project.
Explanation and Resolution
You may encounter the following error when starting AllTalk:
Traceback (most recent call last):
File "C:\AI\alltalk_tts\tts_server.py", line 148, in
from ffmpeg.asyncio import FFmpeg
ModuleNotFoundError: No module named 'ffmpeg.asyncio'
[AllTalk TTS] Warning TTS Engine has NOT started up yet. Will keep trying for 240 seconds maximum. Please wait.
[AllTalk TTS] Warning Mechanical hard drives and a slow PCI BUS are examples of things that can affect load times.
[AllTalk TTS] Warning Some TTS engines index their AI TTS models on loading, which can be slow on CPU or old systems.
[AllTalk TTS] Warning Using one of the other TTS engines on slower systems can help ease this issue.
Please check the Windows sections if you are on Windows and the Linux sections further down in "Manual Installation of ffmpeg"
Windows: This error typically occurs when the necessary build tools are not properly installed or configured on your Windows system. Specifically, it's likely related to missing or incorrectly installed:
- "MSVC v143 - VS 2022 C++ x64/x86 build tools"
- "Windows 10 SDK" or "Windows 11 SDK" (depending on your version of Windows)
These tools are required for compiling certain Python packages, including the FFmpeg module that AllTalk depends on.
To resolve this issue, follow these steps:
-
Delete the
\alltalk_tts\alltalk_environment\
folder to ensure a clean slate. -
Reinstall the necessary build tools:
a. Download Visual Studio 2022 Community Edition:
- Go to the Visual Studio downloads page
- Look for "Visual Studio 2022" under the "Community" edition
- Click the "Free download" button under Visual Studio Community 2022
b. Run the installer and select the following components:
- "MSVC v143 - VS 2022 C++ x64/x86 build tools"
- "Windows 10 SDK" or "Windows 11 SDK" (depending on your Windows version)
-
After installing the build tools, reinstall AllTalk following the standard installation procedure.
For detailed instructions on installing these requirements, refer to the AllTalk wiki page: Install ‐ WINDOWS ‐ Python C & SDK Requirements
- Ensure you have administrator rights when installing these tools and AllTalk.
- The installation of Visual Studio build tools might take some time, so be patient during the process.
- If you're using an older version of Windows, make sure to install the appropriate SDK version.
Always check that you have the correct build tools installed before setting up AllTalk or any Python environment that requires compiled modules. This can save time troubleshooting compilation-related errors later.
If the above steps don't resolve the issue, you can try manually installing ffmpeg using conda in your Python environment. Follow these instructions based on your operating system and the environment you're using.
If you do not understand Python environments, when you are in a Python environment or what a Python environment really is, then please read the quick explainer here Understanding Python Environments Simplified
Windows:
- Open a command prompt in the AllTalk folder
alltalk_tts
- Activate AllTalk's custom Python environment:
start_environment.bat
- Navigate to the Conda scripts folder:
cd alltalk_environment\conda\Scripts
- Install ffmpeg:
conda install -y conda-forge::ffmpeg
Linux:
- Open a terminal in the AllTalk folder
alltalk_tts
- Activate AllTalk's custom Python environment:
./start_environment.sh
- Navigate to the Conda scripts folder:
cd alltalk_environment/conda/Scripts
- Install ffmpeg:
conda install -y conda-forge::ffmpeg
Windows:
- Open a command prompt in the Text Generation Web UI folder
text-generation-webui
- Activate Text Generation Web UI's custom Python environment:
cmd_windows.bat
- Navigate to the Conda scripts folder:
cd installer_files\conda\Scripts
- Install ffmpeg:
conda install -y conda-forge::ffmpeg
Linux:
- Open a terminal in the Text Generation Web UI folder
text-generation-webui
- Activate Text Generation Web UI's custom Python environment:
./cmd_linux.sh
- Navigate into the Text Generation Web UI's conda scripts folder:
cd installer_files/conda/Scripts
- Install ffmpeg:
conda install -y conda-forge::ffmpeg
- Make sure you have internet connectivity when running these commands.
- If you encounter permission issues, you may need to run the command prompt or terminal as an administrator.
- After installation, restart your application or script to ensure the changes take effect.
- If you still encounter the "No module named 'ffmpeg.asyncio'" error after installing ffmpeg, you may need to reinstall or update the ffmpeg-python package:
Explanation and Fix
Run this command to check if PortAudio libraries exist on your system:
ls /usr/lib/x86_64-linux-gnu/libportaudio*
Expected output should show these files:
/usr/lib/x86_64-linux-gnu/libportaudio.so
/usr/lib/x86_64-linux-gnu/libportaudio.so.2
/usr/lib/x86_64-linux-gnu/libportaudio.so.2.0.0
Alternatively, you can verify PortAudio installation using pkg-config:
pkg-config --libs portaudio-2.0
Expected output:
-L/usr/lib/x86_64-linux-gnu -lportaudio
If the above checks fail, you can perform a complete reinstallation:
# Update package list
sudo apt-get update
# Remove existing PortAudio installation
sudo apt-get remove --purge portaudio19-dev
# Install PortAudio and related packages
sudo apt-get install portaudio19-dev python3-pyaudio
sudo apt-get install libasound2-dev
After installing system packages, ensure PortAudio works in your Python environment:
-
Activate the AllTalk environment:
./start_environment.sh
-
Check if sounddevice is installed:
pip show sounddevice
-
If sounddevice is not installed, install it:
pip install sounddevice
After completing these steps, the PortAudio checks in AllTalk should pass successfully.
Note: If you use Synaptic Package Manager, you can also verify the PortAudio installation through its graphical interface.
Explanation and Fix
If you have not installed Espeak-NG, please do so by installing it from the \alltalk_tts\system\espeak-ng\
folder.
If you have installed Espeak-NG you can try closing the Command Prompt window, opening a new one and trying again. Sometimes Windows may have altered the System Path Variables and opening a new Command Prompt can resolve this.
You can test espeak-ng is available by typing espeak-ng --version
, which should show the version number of Espeak-NG. You can also run the AllTalk Python Environment and test it in there, which should also work. If it does, then AllTalk should now start up fine. But if not, keep reading.
If that doesn't work you can check a list of all folders in the path, by opening a Command Prompt and typing path
which will show all folders that can be searched when you type in a command. You should find C:\Program Files\eSpeak NG\
in the list. (This is the typical location it would be installed to)
If the folder path doesn't show up, you can add it to the path with the following method.
To fix this:
-
Open the Start Menu
- Click on the Start button (Windows logo) or press the Windows key on your keyboard.
-
Search for "Environment Variables"
- In the search bar, type "Environment Variables".
- Click on "Edit the system environment variables" when it appears in the search results.
-
Open Environment Variables Window
- In the System Properties window that appears, click the "Environment Variables..." button at the bottom.
-
Find the PATH Variable
- In the Environment Variables window, under the System variables section, scroll down and find the variable called Path.
- Select Path and then click Edit....
-
Add a New Entry
- In the Edit Environment Variable window, click New.
- Type (or paste) the folder path:
C:\Program Files\eSpeak NG\
(This is the typical location it would be installed to)
-
Save the Changes
- Once the path is added, click OK to close each window:
- First, close the Edit Environment Variable window.
- Then, close the Environment Variables window.
- Finally, close the System Properties window.
-
Restart Command Prompt or Applications
- If you have any Command Prompt windows or applications open, close them and reopen them to apply the changes.
- The system will now recognize the
C:\Program Files\eSpeak NG\
directory when searching for executable files.
Explanation and Fix
This error occurs when Python is unable to load a required DLL (Dynamic-Link Library) file. This can happen due to several reasons:
- The DLL file is missing or corrupted.
- There's a mismatch between the Python version and the package version.
- The system's PATH environment variable is not set correctly.
To fix this:
-
Ensure you're using the correct Python environment:
- On Windows: Run
start_environment.bat
- On Linux: Run
./start_environment.sh
- On Windows: Run
-
Reinstall the package that's causing the error with force and upgrade options:
pip uninstall package_name pip install package_name --upgrade --force-reinstall
-
Clear the pip cache to ensure you're not using any corrupted downloads:
pip cache purge
-
If the error persists, try installing the package with a specific version that's known to be compatible with your Python version:
pip install package_name==X.X.X
-
Check if all required Visual C++ Redistributables are installed on your system.
-
Verify that your system's PATH environment variable includes the directory containing the DLL files.
If the problem continues, you may need to investigate which specific DLL is failing to load and ensure it's present in your system.
Explanation and Fix
This error occurs when there's a version mismatch between PyTorch and DeepSpeed. The error message typically looks like this:
RuntimeError: PyTorch version mismatch! DeepSpeed ops were compiled and installed with a different version than what is being used at runtime. Please re-install DeepSpeed or switch torch versions. Install torch version=2.2, Runtime torch version=2.3
ERROR: Application startup failed. Exiting.
This error indicates that DeepSpeed was compiled and installed with a different version of PyTorch than the one currently being used at runtime.
To fix this issue:
-
Ensure that you have the correct versions of PyTorch and DeepSpeed installed for your project.
-
Re-install DeepSpeed with the correct PyTorch version.
-
If the problem persists, you may need to switch your PyTorch version to match the one DeepSpeed was compiled with.
For detailed instructions on installing the correct versions and resolving this issue, please refer to one of the following guides:
- For Linux: Install - LINUX - Requirements and DeepSpeed
- For Windows: Windows - Requirements & DeepSpeed
These guides provide step-by-step instructions for setting up the correct environment and resolving version conflicts.
🟦 TypeError in Transformers Library with Coqui XTTS TTS Engine *prepare*attention_mask_for_generation
Explanation and Fix
This error occurs due to a version incompatibility between the Transformers library and the Coqui XTTS TTS engine. The error message typically looks like this:
alltalk_tts_v2beta\alltalk_environment\env\Lib\site-packages\transformers\generation\utils.py", line 498, in *prepare*attention_mask_for_generation
torch.isin(elements=inputs, test_elements=pad_token_id).any()
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
TypeError: isin() received an invalid combination of arguments - got (elements=Tensor, test_elements=int, ), but expected one of:
* (Tensor elements, Tensor test_elements, *, bool assume_unique, bool invert, Tensor out)
* (Number element, Tensor test_elements, *, bool assume_unique, bool invert, Tensor out)
* (Tensor elements, Number test_element, *, bool assume_unique, bool invert, Tensor out)
This error is specific to the Coqui XTTS TTS engine and occurs when it's used with a newer version of the Transformers library that is incompatible with the current Coqui XTTS implementation.
To resolve this issue, you need to install a specific older version of the Transformers library that is compatible with the current Coqui XTTS TTS engine. Follow these steps:
-
Activate your Python environment:
- On Windows: Run
start_environment.bat
- On Linux: Run
./start_environment.sh
- On Windows: Run
-
Install the compatible version of Transformers:
pip install transformers==4.40.2
The Coqui TTS team at Idiap is working on an update to make the XTTS engine compatible with newer versions of Transformers. However, this update is not yet ready for general release. You can track the progress of this update here: Idiap Coqui-AI TTS Update
Until this update is released, using the older version of Transformers as described above is the recommended solution.
🟦 ConnectionResetError: [WinError 10054] An existing connection was forcibly closed by the remote host
Explanation and Troubleshooting Steps
This error is a network-related issue that occurs when a connection between the client (your web browser running Gradio) and the server (AllTalk backend) is unexpectedly terminated.
ConnectionResetError: [WinError 10054] An existing connection was forcibly closed by the remote host
This error indicates that the network request from Gradio in your web browser couldn't reach the AllTalk backend. It's a general network error that can have various causes.
- AllTalk is not running or has crashed.
- Firewall or antivirus software is intercepting the network request.
- Network configuration issues.
- Recent security updates or browser extensions blocking localhost or specific IP ranges.
-
Restart the System: Often, a simple system restart can resolve this issue.
-
Check AllTalk Status: Ensure that AllTalk is running and hasn't crashed.
-
Try a Different Browser: If the issue persists in one browser, try accessing AllTalk through a different web browser.
-
Use Local IP Address: Instead of using localhost or 127.0.0.1, try accessing AllTalk using your machine's local IP address. For example:
http://192.168.1.20:7852/?__theme=dark
(Replace 192.168.1.20 with your actual local IP address)
-
Check Firewall and Antivirus: Temporarily disable your firewall and antivirus software to see if they're causing the issue. If this resolves the problem, add an exception for AllTalk.
-
Review Browser Extensions: Disable browser extensions, especially security-related ones, to see if they're interfering with the connection.
-
Network Reset: In some cases, resetting your network settings might help:
- Open Command Prompt as Administrator
- Run these commands:
netsh winsock reset netsh int ip reset ipconfig /release ipconfig /renew ipconfig /flushdns
- Restart your computer
-
Check for Recent Updates: If the issue started after a recent update, consider if any security patches might be affecting local connections. For example, there have been recent concerns about the "0-day flaw" in browsers: 18-year-old security flaw in Firefox and Chrome exploited in attacks
If the issue persists after trying these steps, it may be worth checking for any system-wide network issues or consulting with a network administrator if you're on a managed network.
🟦 [Errno 10048] error while attempting to bind on address ('0.0.0.0', 7851): only one usage of each socket address (protocol/network address/port) is normally permitted
Explanation and Troubleshooting Steps
This error indicates that something is already running on the port number specified OR for some reason multiple AllTalk instances of the tts_engine.py is running and a new one is attempting to start up on the same port number.
[Errno 10048] error while attempting to bind on address ('0.0.0.0', 7851): only one usage of each socket address (protocol/network address/port) is normally permitted
This error indicates that port 7851 is already in use by another process. In networking, only one application can bind to a specific port at a time. This is a common issue when:
- A previous instance of AllTalk didn't shut down properly
- Another application is using the same port
- Multiple instances of AllTalk are trying to run simultaneously
- Zombie AllTalk process still running in the background
- Another application is using port 7851
- Multiple instances of tts_engine.py were started
- Previous crash or improper shutdown left the port in a bound state
- Open the Gradio interface
- Navigate to the settings section
- Look for the port configuration option
- Change the port number to an unused port (e.g., 7852)
- Alternatively, edit the
confignew.json
file directly and modify the port number - Restart AllTalk
- Open Task Manager (Ctrl + Shift + Esc)
- Go to the "Details" or "Processes" tab
- Look for Python processes
- Right-click and select "Properties" to verify if it's AllTalk-related
- If confirmed, right-click and select "End Task"
- Open terminal
- Find processes using the port:
sudo lsof -i :7851
- Find Python processes that might be AllTalk:
ps aux | grep python
- Kill the specific process:
or force kill if necessary:
kill <process_id>
kill -9 <process_id>
- Check what's using the port:
- Windows:
netstat -ano | findstr :7851
- Linux:
netstat -tulpn | grep :7851
- Windows:
- Identify the process ID (PID)
- Verify if it's AllTalk-related
- Close the application using that port
- Always close AllTalk properly through the interface
- Check for running instances before starting a new one
- Consider setting up a different default port in the configuration
- Implement a startup script that checks for existing instances
Explanation
You may encounter the following warning when running PyTorch-based applications:
UserWarning: 1Torch was not compiled with flash attention.
This warning is related to a feature called "Flash Attention" in PyTorch, which is an optimization for certain types of attention mechanisms in neural networks.
Key points to understand:
- This is a generic PyTorch issue and not specific to AllTalk or any particular application.
- Flash Attention is not currently supported on Windows systems.
- On Windows, this message is a notification rather than an error.
- For Windows users: This warning can be safely ignored. It does not affect the functionality of your PyTorch-based applications.
- For non-Windows users: If you're seeing this on a non-Windows system where Flash Attention should be supported, you might want to investigate further.
PyTorch checks if it was compiled with Flash Attention support. On Windows, where this feature is not available, the check always returns false, resulting in this warning.
For Windows users:
- No action is required. You can safely ignore this warning.
- If you want to suppress the warning, you can use Python's warning filters, but this is generally unnecessary.
For non-Windows users seeing this unexpectedly:
- Ensure you have the latest version of PyTorch installed.
- Check if your CUDA installation (if applicable) is up to date and compatible with your PyTorch version.
This issue has been widely discussed in the PyTorch community. For more details, you can refer to the following GitHub issue: PyTorch Issue #108175
Unless you specifically need Flash Attention for your work (which is rare for most users), you can continue using PyTorch as normal. This warning does not indicate a problem with your setup or code on Windows systems.
🟦 IMPORTANT: You are using gradio version 4.32.2, however version 5.x.x is available, please upgrade.
Explanation and Troubleshooting Steps
Gradio's developers just like telling everyone to upgrade to their latest version. I cant stop the messages appearing and I have as yet not tested later versions of Gradio, the messages are safe to ignore.
Explanation
PyTorch whom make Torch have included this message with Torch version 2.4.x to state that some time in the future, they will be removing a feature from Torch. At this stage in time, it is nothing more than a warning note to anyone whom develops things to work with Torch. Annoying as the message is, its just a warning message and I cannot filter it out, well, I can, but it would filter out other possible Torch errors that may actually mean something at this point in time.
I am not the developer of the Coqui TTS engine and I know that the developer is currently working on updating the Coqui TTS engine and so assumedly a change will be made in future that will clear up this message.
This error if safe to ignore at this time assuming you are using the XTTS models supplied by AllTalk and not using someone else's model that (I guess) they could have potentially done something with, though this is highly unlikely as I've never seen any other persons XTTS model being shared, so I only mention this as an FYI.
FutureWarning: You are using torch.load with weights_only=False (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for weights_only will be flipped to True. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via torch.serialization.add_safe_globals. We recommend you start setting weights_only=True for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.
🟦 UserWarning: huggingface_hub
cache-system uses symlinks by default to efficiently store duplicated files.....etc
Explanation
This is typically only seen on Windows machines and is safe to ignore. This is just a warning from Huggingface's cache system that downloads may be slightly degraded as it doesn't have full Administrator access to your user accounts temp cache area https://huggingface.co/docs/huggingface_hub/v0.25.2/guides/manage-cache#limitations and it in no way impacts AllTalk.
UserWarning: `huggingface_hub` cache-system uses symlinks by default to efficiently store duplicated files but your
machine does not support them in C:\Users\useraccount\.cache\huggingface\hub\models--Systran--faster-whisper-large-v2.
Caching files will still work but in a degraded version that might require more space on your disk. This warning can
be disabled by setting the `HF_HUB_DISABLE_SYMLINKS_WARNING` environment variable. For more details, see
https://huggingface.co/docs/huggingface_hub/how-to-cache#limitations.
To support symlinks on Windows, you either need to activate Developer Mode or to run Python as an administrator. In
order to activate developer mode, see this article: https://docs.microsoft.com/en-us/windows/apps/get-started/enable
-your-device-for-development
warnings.warn(message)
🟦 Error: mkl-service + Intel(R) MKL: MKL_THREADING_LAYER=INTEL is incompatible with {library-name-here} library
Explanation and Fix
This error may arise due to incompatibility between Intel’s MKL threading layer (MKL_THREADING_LAYER=INTEL
) and certain libraries, such as libgomp-a34b3233.so.1
, used by the Python environment. It often appears with messages similar to:
Error: mkl-service + Intel(R) MKL: MKL_THREADING_LAYER=INTEL is incompatible with libgomp-a34b3233.so.1 library.
Try to import numpy first or set the threading layer accordingly. Set MKL_SERVICE_FORCE_INTEL to force it.
In addition, it may be accompanied by warnings during the AllTalk startup sequence:
[AllTalk Startup] Warning TTS Subprocess has NOT started up yet, Will keep trying for 120 seconds maximum. Please wait.
[AllTalk Startup] Startup timed out. Full help available here https://github.com/erew123/alltalk_tts#-help-with-problems
This error may occur due to a version mismatch between PyTorch and DeepSpeed or an environmental setting conflict that prevents AllTalk from initializing. When this happens, AllTalk may repeatedly attempt to start without success, leading to a startup timeout.
To resolve this issue:
-
Set the MKL Threading Layer: Set the environment variable
MKL_THREADING_LAYER=GNU
before starting AllTalk. This can resolve compatibility issues between MKL and other libraries. For example:Or simply starting AllTalk asexport MKL_THREADING_LAYER=GNU ./start_alltalk.sh
MKL_THREADING_LAYER=GNU ./start_alltalk.sh
Explanation and Resolution
When using SillyTavern with AllTalk, you may encounter the following error:
HTTP 404: Failed to fetch audio data
This error typically occurs due to a version mismatch between the AllTalk extension in SillyTavern and the version of AllTalk you're running.
Key points to understand:
- SillyTavern currently comes bundled with the AllTalk version 1 extension by default.
- If you're running AllTalk version 2, the bundled extension will be incompatible, leading to this error.
- The extension needs to be manually updated to match your AllTalk version.
To resolve this issue, you need to update the AllTalk extension in SillyTavern to match your AllTalk version. Here's what to do:
- Determine which version of AllTalk you're running (likely version 2 if you're seeing this error).
- Follow the instructions provided in the AllTalk wiki to update the SillyTavern extension.
Detailed instructions for updating the extension can be found here: SillyTavern Extension Update Instructions
- Always ensure that your SillyTavern AllTalk extension version matches the version of AllTalk you're running.
- Keep an eye on both AllTalk and SillyTavern updates, as you may need to manually update the extension after upgrading either component.
In the future, the extension will be updated in SillyTavern. Until then, manual updates are necessary to ensure compatibility.
Before reporting issues with AllTalk integration in SillyTavern, always verify that you have the correct extension version installed. If you're unsure, refer to the AllTalk documentation or the SillyTavern Extension wiki page linked above.
Explanation and Resolution
If you are encountering issues and wish to reset the AllTalk settings in SillyTavern, you can do so with the following process.
- Browse to your
\SillyTavern\data\default-user\
folder and make a backup copy of thesettings.json
. This is to be used if you make a mistake and need to recover the file. - Open the
settings.json
file in notepad or whatever text editor software you use. - Search the file for
alltalk
and you should find a section called"tts": {
that has an AllTalk section within it. - You are going to select from
"AllTalk": {
all the way down to its closing bracket},
and delete that section e.g.
- Once you have deleted that section, save the file and re-start SillTavern.
- Set up your AllTalk settings again in SillyTavern, as if it was a brand new installation.
- [Optional] If you have accidentally damaged the format of the file, you can recover from the copy you made earlier and try again.
Explanation and Fix
You can get an error message similar to the one shown below when you are using the Coqui TTS engine, with XTTS and you are trying to stream audio. This will therefore affect Kobold as it currently only uses streaming. It will affect any other application where you are using streaming with XTTS.
This issue is caused by the fact that the Coqui TTS engine (at time of writing) requires transformers version 4.42.4 to support streaming. Other TTS engines or software like Text-generation-webui may install a different version of transformers. Parler for example, installs version 4.43.X and you are given the option when installing AllTalk to downgrade transformers. The fix is listed down below the example error message.
ERROR: Exception in ASGI application
Traceback (most recent call last):
File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\responses.py", line 257, in __call__
await wrap(partial(self.listen_for_disconnect, receive))
File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\responses.py", line 253, in wrap
await func()
File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\responses.py", line 230, in listen_for_disconnect
message = await receive()
^^^^^^^^^^^^^^^
File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\uvicorn\protocols\http\h11_impl.py", line 534, in receive
await self.message_event.wait()
File "C:\AI\text-generation-webui\installer_files\env\Lib\asyncio\locks.py", line 213, in wait
await fut
asyncio.exceptions.CancelledError: Cancelled by cancel scope 2564324bb90
During handling of the above exception, another exception occurred:
+ Exception Group Traceback (most recent call last):
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\uvicorn\protocols\http\h11_impl.py", line 406, in run_asgi
| result = await app( # type: ignore[func-returns-value]
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\uvicorn\middleware\proxy_headers.py", line 60, in __call__
| return await self.app(scope, receive, send)
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\fastapi\applications.py", line 1054, in __call__
| await super().__call__(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\applications.py", line 113, in __call__
| await self.middleware_stack(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\middleware\errors.py", line 187, in __call__
| raise exc
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\middleware\errors.py", line 165, in __call__
| await self.app(scope, receive, _send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\middleware\cors.py", line 85, in __call__
| await self.app(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\middleware\exceptions.py", line 62, in __call__
| await wrap_app_handling_exceptions(self.app, conn)(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\_exception_handler.py", line 62, in wrapped_app
| raise exc
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\_exception_handler.py", line 51, in wrapped_app
| await app(scope, receive, sender)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\routing.py", line 715, in __call__
| await self.middleware_stack(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\routing.py", line 735, in app
| await route.handle(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\routing.py", line 288, in handle
| await self.app(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\routing.py", line 76, in app
| await wrap_app_handling_exceptions(app, request)(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\_exception_handler.py", line 62, in wrapped_app
| raise exc
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\_exception_handler.py", line 51, in wrapped_app
| await app(scope, receive, sender)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\routing.py", line 74, in app
| await response(scope, receive, send)
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\responses.py", line 250, in __call__
| async with anyio.create_task_group() as task_group:
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\anyio\_backends\_asyncio.py", line 763, in __aexit__
| raise BaseExceptionGroup(
| ExceptionGroup: unhandled errors in a TaskGroup (1 sub-exception)
+-+---------------- 1 ----------------
| Traceback (most recent call last):
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\responses.py", line 253, in wrap
| await func()
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\starlette\responses.py", line 242, in stream_response
| async for chunk in self.body_iterator:
| File "C:\AI\text-generation-webui\extensions\alltalk_tts\tts_server.py", line 708, in stream_response
| async for chunk in response:
| File "C:\AI\text-generation-webui\extensions\alltalk_tts\system\tts_engines\xtts\model_engine.py", line 556, in generate_tts
| for i, chunk in enumerate(output):
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\torch\utils\_contextlib.py", line 36, in generator_context
| response = gen.send(None)
| ^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\TTS\tts\models\xtts.py", line 658, in inference_stream
| gpt_generator = self.gpt.get_generator(
| ^^^^^^^^^^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\TTS\tts\layers\xtts\gpt.py", line 602, in get_generator
| return self.gpt_inference.generate_stream(
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\torch\utils\_contextlib.py", line 116, in decorate_context
| return func(*args, **kwargs)
| ^^^^^^^^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\TTS\tts\layers\xtts\stream_generator.py", line 179, in generate
| model_kwargs["attention_mask"] = self._prepare_attention_mask_for_generation(
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| File "C:\AI\text-generation-webui\installer_files\env\Lib\site-packages\transformers\generation\utils.py", line 498, in _prepare_attention_mask_for_generation
| torch.isin(elements=inputs, test_elements=pad_token_id).any()
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| TypeError: isin() received an invalid combination of arguments - got (elements=Tensor, test_elements=int, ), but expected one of:
| * (Tensor elements, Tensor test_elements, *, bool assume_unique = False, bool invert = False, Tensor out = None)
| * (Number element, Tensor test_elements, *, bool assume_unique = False, bool invert = False, Tensor out = None)
| * (Tensor elements, Number test_element, *, bool assume_unique = False, bool invert = False, Tensor out = None)
|
+------------------------------------
To fix this:
- Ensure you're using the correct Python environment:
- On Windows: Run
start_environment.bat
- On Linux: Run
./start_environment.sh
- On Windows: Run
Obviously if you are running within Text-generation-webui's Python environment (not installing AllTalk as a Standalone install) you would use Text-generation-webui's files to start its Python environment e.g. cmd_windows.bat. If you don't feel you quite understand Python environments, please go read Understanding Python Environments which should help explain things.
- Install transformers version 4.42.4:
pip install transformers==4.42.4
When this installs, you will see a message showing the version of transformers it is replacing, Successfully uninstalled transformers-X.XX.X
, so you may want to make a note of that in case you want to revert back at a later stage. The message would look something like:
```
Installing collected packages: transformers
Attempting uninstall: transformers
Found existing installation: transformers 4.43.3
Uninstalling transformers-4.43.3:
Successfully uninstalled transformers-4.43.3
```
You WILL get a message about PIP not being able to confirm all version are correct and it may say there COULD be issues with other packages (the PIP dependency resolver will report this, typically in RED text). This should get you back to working with XTTS, though it may cause issues with Parler TTS as Parler's dev's have not tested Parler with an earlier version of transformers (though it appears to be working absolutely fine). I cannot speak as to any other software it may impact e.g. it may impact Text-generation-webui's model loaders (possibly). You can always upgrade transformers with the above method and changing the version installed.
If for any reason you have an issue where AllTalk is failing to load because it cant find the model file or something like that, you can always reset the model it is trying to load, to something like Piper, which should at least allow AllTalk to load in. Instructions to do this are below on Dealing with a TTS engine not loading e.g. model file is missing etc.
.
Explanation and Potential Solutions
This warning appears when using Coqui TTS models and indicates that the input text exceeds the character limit for the specified language. The warning typically looks like this:
Warning: The text length exceeds the character limit of XXX for language 'XX', this might cause truncated audio.
- Coqui TTS models have predefined character limits for each supported language.
- These limits are set in the tokenizer and are based on the model's training data.
- Exceeding this limit may result in degraded audio quality or truncation of the generated speech.
- This is a warning, not an error. The system will still attempt to process the text, but the results may not be optimal.
- The actual impact on audio quality can vary depending on the specific model and the extent to which the limit is exceeded.
-
Reduce Input Text: The most straightforward solution is to shorten your input text to fall within the character limit for the chosen language.
-
Split Text: For longer passages, consider splitting the text into smaller segments that fall within the limit and process them separately.
-
Adjust Tokenizer Limits: While it's possible to modify the character limits in the tokenizer, this won't actually improve the model's performance or remove the underlying limitation. It will only suppress the warning.
To adjust the limit (not recommended):
tokenizer = TTSTokenizer.from_pretrained(model_name) tokenizer.max_input_tokens = new_limit # e.g., 1000 tokenizer.save_pretrained(output_dir)
Note: This modification only affects the warning threshold, not the model's actual capabilities.
For more detailed discussions on this topic, you can refer to:
Explanation and Potential Solutions
Using one of the TTS engines, audio is cut short, not produced correctly etc.
I do NOT make any of the underlying TTS engines or models, they are developed/made/managed and maintained by the original 3rd parties.
If you want to confirm that AllTalk is passing over the full text to whatever TTS engine you are using, please enable the debug_fullttstext
in the debug options as detailed here in the Gradio interface > Global Settings
tab.
With that debugging enabled, whatever is shown in the console output is passed onto the underlying TTS engine, its then up to the underlying TTS engine to generate the TTS and hand it back to AllTalk.
-
Contact the TTS engine developer: Raise the issue with the original developers if you believe there is a bug they need to investigate. The link to the developers sites can be found in the AllTalk interface in
TTS Engine Settings
>{chosen TTS engine}
>Engine Information
. A list with links to the TTS developers sites is also maintained here. -
Ensure correct punctuation/formatting: Anecdotal experience suggests ensuring you have correct punctuation e.g. ensure there is a full stop/period at the end of sentences.
-
Voice cloning engines: When using voice cloning, audio samples that cut early have been observed to potentially lead to cut audio or additions of audio silences.
-
Coqui/XTTS specific: DeepSpeed may have some impact, but I have been unable to validate this. You can:
- Try disabling DeepSpeed to see if that helps with the issue (if you have DeepSpeed enabled).
- Try the alternative generation method
API TTS
, which can be loaded with theLoad Different Model
choices on the Gradio interfaceGenerate TTS
tab.