Thanks to visit codestin.com
Credit goes to github.com

Skip to content

[pull] master from comfyanonymous:master #46

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weโ€™ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 2 commits into from
May 8, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions comfy/sd.py
Original file line number Diff line number Diff line change
Expand Up @@ -441,8 +441,8 @@ def __init__(self, sd=None, device=None, config=None, dtype=None, metadata=None)
self.working_dtypes = [torch.float16, torch.bfloat16, torch.float32]
elif "vocoder.backbone.channel_layers.0.0.bias" in sd: #Ace Step Audio
self.first_stage_model = comfy.ldm.ace.vae.music_dcae_pipeline.MusicDCAE(source_sample_rate=44100)
self.memory_used_encode = lambda shape, dtype: (shape[2] * 300) * model_management.dtype_size(dtype)
self.memory_used_decode = lambda shape, dtype: (shape[2] * shape[3] * 72000) * model_management.dtype_size(dtype)
self.memory_used_encode = lambda shape, dtype: (shape[2] * 330) * model_management.dtype_size(dtype)
self.memory_used_decode = lambda shape, dtype: (shape[2] * shape[3] * 87000) * model_management.dtype_size(dtype)
self.latent_channels = 8
self.output_channels = 2
# self.upscale_ratio = 2048
Expand Down
10 changes: 9 additions & 1 deletion comfy/text_encoders/ace.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
import logging

from tokenizers import Tokenizer
from .ace_text_cleaners import multilingual_cleaners
from .ace_text_cleaners import multilingual_cleaners, japanese_to_romaji

SUPPORT_LANGUAGES = {
"en": 259, "de": 260, "fr": 262, "es": 284, "it": 285,
Expand Down Expand Up @@ -65,6 +65,14 @@ def __call__(self, string):
if "spa" in lang:
lang = "es"

try:
line_out = japanese_to_romaji(line)
if line_out != line:
lang = "ja"
line = line_out
except:
pass

try:
if structure_pattern.match(line):
token_idx = self.encode(line, "en")
Expand Down
125 changes: 125 additions & 0 deletions comfy/text_encoders/ace_text_cleaners.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,131 @@

import re

def japanese_to_romaji(japanese_text):
"""
Convert Japanese hiragana and katakana to romaji (Latin alphabet representation).

Args:
japanese_text (str): Text containing hiragana and/or katakana characters

Returns:
str: The romaji (Latin alphabet) equivalent
"""
# Dictionary mapping kana characters to their romaji equivalents
kana_map = {
# Katakana characters
'ใ‚ข': 'a', 'ใ‚ค': 'i', 'ใ‚ฆ': 'u', 'ใ‚จ': 'e', 'ใ‚ช': 'o',
'ใ‚ซ': 'ka', 'ใ‚ญ': 'ki', 'ใ‚ฏ': 'ku', 'ใ‚ฑ': 'ke', 'ใ‚ณ': 'ko',
'ใ‚ต': 'sa', 'ใ‚ท': 'shi', 'ใ‚น': 'su', 'ใ‚ป': 'se', 'ใ‚ฝ': 'so',
'ใ‚ฟ': 'ta', 'ใƒ': 'chi', 'ใƒ„': 'tsu', 'ใƒ†': 'te', 'ใƒˆ': 'to',
'ใƒŠ': 'na', 'ใƒ‹': 'ni', 'ใƒŒ': 'nu', 'ใƒ': 'ne', 'ใƒŽ': 'no',
'ใƒ': 'ha', 'ใƒ’': 'hi', 'ใƒ•': 'fu', 'ใƒ˜': 'he', 'ใƒ›': 'ho',
'ใƒž': 'ma', 'ใƒŸ': 'mi', 'ใƒ ': 'mu', 'ใƒก': 'me', 'ใƒข': 'mo',
'ใƒค': 'ya', 'ใƒฆ': 'yu', 'ใƒจ': 'yo',
'ใƒฉ': 'ra', 'ใƒช': 'ri', 'ใƒซ': 'ru', 'ใƒฌ': 're', 'ใƒญ': 'ro',
'ใƒฏ': 'wa', 'ใƒฒ': 'wo', 'ใƒณ': 'n',

# Katakana voiced consonants
'ใ‚ฌ': 'ga', 'ใ‚ฎ': 'gi', 'ใ‚ฐ': 'gu', 'ใ‚ฒ': 'ge', 'ใ‚ด': 'go',
'ใ‚ถ': 'za', 'ใ‚ธ': 'ji', 'ใ‚บ': 'zu', 'ใ‚ผ': 'ze', 'ใ‚พ': 'zo',
'ใƒ€': 'da', 'ใƒ‚': 'ji', 'ใƒ…': 'zu', 'ใƒ‡': 'de', 'ใƒ‰': 'do',
'ใƒ': 'ba', 'ใƒ“': 'bi', 'ใƒ–': 'bu', 'ใƒ™': 'be', 'ใƒœ': 'bo',
'ใƒ‘': 'pa', 'ใƒ”': 'pi', 'ใƒ—': 'pu', 'ใƒš': 'pe', 'ใƒ': 'po',

# Katakana combinations
'ใ‚ญใƒฃ': 'kya', 'ใ‚ญใƒฅ': 'kyu', 'ใ‚ญใƒง': 'kyo',
'ใ‚ทใƒฃ': 'sha', 'ใ‚ทใƒฅ': 'shu', 'ใ‚ทใƒง': 'sho',
'ใƒใƒฃ': 'cha', 'ใƒใƒฅ': 'chu', 'ใƒใƒง': 'cho',
'ใƒ‹ใƒฃ': 'nya', 'ใƒ‹ใƒฅ': 'nyu', 'ใƒ‹ใƒง': 'nyo',
'ใƒ’ใƒฃ': 'hya', 'ใƒ’ใƒฅ': 'hyu', 'ใƒ’ใƒง': 'hyo',
'ใƒŸใƒฃ': 'mya', 'ใƒŸใƒฅ': 'myu', 'ใƒŸใƒง': 'myo',
'ใƒชใƒฃ': 'rya', 'ใƒชใƒฅ': 'ryu', 'ใƒชใƒง': 'ryo',
'ใ‚ฎใƒฃ': 'gya', 'ใ‚ฎใƒฅ': 'gyu', 'ใ‚ฎใƒง': 'gyo',
'ใ‚ธใƒฃ': 'ja', 'ใ‚ธใƒฅ': 'ju', 'ใ‚ธใƒง': 'jo',
'ใƒ“ใƒฃ': 'bya', 'ใƒ“ใƒฅ': 'byu', 'ใƒ“ใƒง': 'byo',
'ใƒ”ใƒฃ': 'pya', 'ใƒ”ใƒฅ': 'pyu', 'ใƒ”ใƒง': 'pyo',

# Katakana small characters and special cases
'ใƒƒ': '', # Small tsu (doubles the following consonant)
'ใƒฃ': 'ya', 'ใƒฅ': 'yu', 'ใƒง': 'yo',

# Katakana extras
'ใƒด': 'vu', 'ใƒ•ใ‚ก': 'fa', 'ใƒ•ใ‚ฃ': 'fi', 'ใƒ•ใ‚ง': 'fe', 'ใƒ•ใ‚ฉ': 'fo',
'ใ‚ฆใ‚ฃ': 'wi', 'ใ‚ฆใ‚ง': 'we', 'ใ‚ฆใ‚ฉ': 'wo',

# Hiragana characters
'ใ‚': 'a', 'ใ„': 'i', 'ใ†': 'u', 'ใˆ': 'e', 'ใŠ': 'o',
'ใ‹': 'ka', 'ใ': 'ki', 'ใ': 'ku', 'ใ‘': 'ke', 'ใ“': 'ko',
'ใ•': 'sa', 'ใ—': 'shi', 'ใ™': 'su', 'ใ›': 'se', 'ใ': 'so',
'ใŸ': 'ta', 'ใก': 'chi', 'ใค': 'tsu', 'ใฆ': 'te', 'ใจ': 'to',
'ใช': 'na', 'ใซ': 'ni', 'ใฌ': 'nu', 'ใญ': 'ne', 'ใฎ': 'no',
'ใฏ': 'ha', 'ใฒ': 'hi', 'ใต': 'fu', 'ใธ': 'he', 'ใป': 'ho',
'ใพ': 'ma', 'ใฟ': 'mi', 'ใ‚€': 'mu', 'ใ‚': 'me', 'ใ‚‚': 'mo',
'ใ‚„': 'ya', 'ใ‚†': 'yu', 'ใ‚ˆ': 'yo',
'ใ‚‰': 'ra', 'ใ‚Š': 'ri', 'ใ‚‹': 'ru', 'ใ‚Œ': 're', 'ใ‚': 'ro',
'ใ‚': 'wa', 'ใ‚’': 'wo', 'ใ‚“': 'n',

# Hiragana voiced consonants
'ใŒ': 'ga', 'ใŽ': 'gi', 'ใ': 'gu', 'ใ’': 'ge', 'ใ”': 'go',
'ใ–': 'za', 'ใ˜': 'ji', 'ใš': 'zu', 'ใœ': 'ze', 'ใž': 'zo',
'ใ ': 'da', 'ใข': 'ji', 'ใฅ': 'zu', 'ใง': 'de', 'ใฉ': 'do',
'ใฐ': 'ba', 'ใณ': 'bi', 'ใถ': 'bu', 'ใน': 'be', 'ใผ': 'bo',
'ใฑ': 'pa', 'ใด': 'pi', 'ใท': 'pu', 'ใบ': 'pe', 'ใฝ': 'po',

# Hiragana combinations
'ใใ‚ƒ': 'kya', 'ใใ‚…': 'kyu', 'ใใ‚‡': 'kyo',
'ใ—ใ‚ƒ': 'sha', 'ใ—ใ‚…': 'shu', 'ใ—ใ‚‡': 'sho',
'ใกใ‚ƒ': 'cha', 'ใกใ‚…': 'chu', 'ใกใ‚‡': 'cho',
'ใซใ‚ƒ': 'nya', 'ใซใ‚…': 'nyu', 'ใซใ‚‡': 'nyo',
'ใฒใ‚ƒ': 'hya', 'ใฒใ‚…': 'hyu', 'ใฒใ‚‡': 'hyo',
'ใฟใ‚ƒ': 'mya', 'ใฟใ‚…': 'myu', 'ใฟใ‚‡': 'myo',
'ใ‚Šใ‚ƒ': 'rya', 'ใ‚Šใ‚…': 'ryu', 'ใ‚Šใ‚‡': 'ryo',
'ใŽใ‚ƒ': 'gya', 'ใŽใ‚…': 'gyu', 'ใŽใ‚‡': 'gyo',
'ใ˜ใ‚ƒ': 'ja', 'ใ˜ใ‚…': 'ju', 'ใ˜ใ‚‡': 'jo',
'ใณใ‚ƒ': 'bya', 'ใณใ‚…': 'byu', 'ใณใ‚‡': 'byo',
'ใดใ‚ƒ': 'pya', 'ใดใ‚…': 'pyu', 'ใดใ‚‡': 'pyo',

# Hiragana small characters and special cases
'ใฃ': '', # Small tsu (doubles the following consonant)
'ใ‚ƒ': 'ya', 'ใ‚…': 'yu', 'ใ‚‡': 'yo',

# Common punctuation and spaces
'ใ€€': ' ', # Japanese space
'ใ€': ', ', 'ใ€‚': '. ',
}

result = []
i = 0

while i < len(japanese_text):
# Check for small tsu (doubling the following consonant)
if i < len(japanese_text) - 1 and (japanese_text[i] == 'ใฃ' or japanese_text[i] == 'ใƒƒ'):
if i < len(japanese_text) - 1 and japanese_text[i+1] in kana_map:
next_romaji = kana_map[japanese_text[i+1]]
if next_romaji and next_romaji[0] not in 'aiueon':
result.append(next_romaji[0]) # Double the consonant
i += 1
continue

# Check for combinations with small ya, yu, yo
if i < len(japanese_text) - 1 and japanese_text[i+1] in ('ใ‚ƒ', 'ใ‚…', 'ใ‚‡', 'ใƒฃ', 'ใƒฅ', 'ใƒง'):
combo = japanese_text[i:i+2]
if combo in kana_map:
result.append(kana_map[combo])
i += 2
continue

# Regular character
if japanese_text[i] in kana_map:
result.append(kana_map[japanese_text[i]])
else:
# If it's not in our map, keep it as is (might be kanji, romaji, etc.)
result.append(japanese_text[i])

i += 1

return ''.join(result)

def number_to_text(num, ordinal=False):
"""
Convert a number (int or float) to its text representation.
Expand Down
Loading