From 28ccfbfc51068a663a80764e14074df5edf2b5ba Mon Sep 17 00:00:00 2001
From: kongdeqiang <kongdeqiang960204@163.com>
Date: 星期五, 13 三月 2026 17:41:41 +0800
Subject: [PATCH] 提交
---
fun_text_processing/text_normalization/es/verbalizers/measure.py | 41 +++++++++++++++++++++++++++++++----------
1 files changed, 31 insertions(+), 10 deletions(-)
diff --git a/fun_text_processing/text_normalization/es/verbalizers/measure.py b/fun_text_processing/text_normalization/es/verbalizers/measure.py
index 0d27ba3..09f9c88 100644
--- a/fun_text_processing/text_normalization/es/verbalizers/measure.py
+++ b/fun_text_processing/text_normalization/es/verbalizers/measure.py
@@ -1,5 +1,3 @@
-
-
import pynini
from fun_text_processing.text_normalization.en.graph_utils import (
DAMO_NOT_QUOTE,
@@ -38,7 +36,9 @@
for False multiple transduction are generated (used for audio-based normalization)
"""
- def __init__(self, decimal: GraphFst, cardinal: GraphFst, fraction: GraphFst, deterministic: bool):
+ def __init__(
+ self, decimal: GraphFst, cardinal: GraphFst, fraction: GraphFst, deterministic: bool
+ ):
super().__init__(name="measure", kind="verbalize", deterministic=deterministic)
graph_decimal_masc = decimal.delete_tokens(decimal.graph_masc)
@@ -52,38 +52,59 @@
DAMO_WHITE_SPACE + "por" + pynini.closure(DAMO_NOT_QUOTE, 1), 0, 1
)
unit_masc |= "por" + pynini.closure(DAMO_NOT_QUOTE, 1)
- unit_masc = pynutil.delete("units: \"") + (pynini.closure(DAMO_NOT_QUOTE) @ unit_masc) + pynutil.delete("\"")
+ unit_masc = (
+ pynutil.delete('units: "')
+ + (pynini.closure(DAMO_NOT_QUOTE) @ unit_masc)
+ + pynutil.delete('"')
+ )
unit_fem = (unit_plural_fem | unit_singular_fem) + pynini.closure(
DAMO_WHITE_SPACE + "por" + pynini.closure(DAMO_NOT_QUOTE, 1), 0, 1
)
- unit_fem = pynutil.delete("units: \"") + (pynini.closure(DAMO_NOT_QUOTE) @ unit_fem) + pynutil.delete("\"")
+ unit_fem = (
+ pynutil.delete('units: "')
+ + (pynini.closure(DAMO_NOT_QUOTE) @ unit_fem)
+ + pynutil.delete('"')
+ )
graph_masc = (graph_cardinal_masc | graph_decimal_masc) + DAMO_WHITE_SPACE + unit_masc
graph_masc |= graph_fraction_masc + DAMO_WHITE_SPACE + pynutil.insert("de ") + unit_masc
graph_masc |= pynutil.add_weight(
- graph_fraction_masc @ (DAMO_SIGMA + pynini.union("medio", "medios")) + DAMO_WHITE_SPACE + unit_masc, -0.001
+ graph_fraction_masc @ (DAMO_SIGMA + pynini.union("medio", "medios"))
+ + DAMO_WHITE_SPACE
+ + unit_masc,
+ -0.001,
) # "medio litro" not "medio de litro"
graph_fem = (graph_cardinal_fem | graph_decimal_fem) + DAMO_WHITE_SPACE + unit_fem
graph_fem |= graph_fraction_fem + DAMO_WHITE_SPACE + pynutil.insert("de ") + unit_fem
graph_fem |= pynutil.add_weight(
- graph_fraction_fem @ (DAMO_SIGMA + pynini.union("media", "medias")) + DAMO_WHITE_SPACE + unit_fem, -0.001
+ graph_fraction_fem @ (DAMO_SIGMA + pynini.union("media", "medias"))
+ + DAMO_WHITE_SPACE
+ + unit_fem,
+ -0.001,
)
graph = graph_masc | graph_fem
graph = (
pynini.cdrewrite(
- pynutil.insert(" de"), "quantity: \"" + pynini.closure(DAMO_NOT_QUOTE, 1), "\"", DAMO_SIGMA
+ pynutil.insert(" de"),
+ 'quantity: "' + pynini.closure(DAMO_NOT_QUOTE, 1),
+ '"',
+ DAMO_SIGMA,
)
@ graph
) # billones de xyz
- graph @= pynini.cdrewrite(pynini.cross(ones, "uno"), "", DAMO_WHITE_SPACE + "por", DAMO_SIGMA)
+ graph @= pynini.cdrewrite(
+ pynini.cross(ones, "uno"), "", DAMO_WHITE_SPACE + "por", DAMO_SIGMA
+ )
# To manage alphanumeric combonations ("a-8, 5x"), we let them use a weighted default path.
- alpha_num_unit = pynutil.delete("units: \"") + pynini.closure(DAMO_NOT_QUOTE) + pynutil.delete("\"")
+ alpha_num_unit = (
+ pynutil.delete('units: "') + pynini.closure(DAMO_NOT_QUOTE) + pynutil.delete('"')
+ )
graph_alpha_num = pynini.union(
(graph_cardinal_masc | graph_decimal_masc) + DAMO_SPACE + alpha_num_unit,
alpha_num_unit + delete_extra_space + (graph_cardinal_masc | graph_decimal_masc),
--
Gitblit v1.9.1