|
import os |
|
from sys import argv |
|
import multiprocessing as mp |
|
|
|
|
|
def process_language(lang): |
|
|
|
all_pairs = [] |
|
print(f"lang: {lang}") |
|
|
|
for domain in domains: |
|
src_fname = f"{base_path}/{domain}/eng_Latn-{lang}/train.eng_Latn" |
|
tgt_fname = f"{base_path}/{domain}/eng_Latn-{lang}/train.{lang}" |
|
|
|
try: |
|
with open(src_fname, "r", encoding="utf-8") as f1, open( |
|
tgt_fname, "r", encoding="utf-8" |
|
) as f2: |
|
src_sents = [x.strip() for x in f1] |
|
tgt_sents = [x.strip() for x in f2] |
|
all_pairs.extend([(a, b) for (a, b) in zip(src_sents, tgt_sents)]) |
|
except Exception as e: |
|
pass |
|
|
|
all_pairs = list(set(all_pairs)) |
|
src_sents, tgt_sents = zip(*all_pairs) |
|
|
|
os.makedirs(f"{out_dir}/eng_Latn-{lang}", exist_ok=True) |
|
with open( |
|
f"{out_dir}/eng_Latn-{lang}/train.eng_Latn", "w", encoding="utf-8" |
|
) as f1, open( |
|
f"{out_dir}/eng_Latn-{lang}/train.{lang}", "w", encoding="utf-8" |
|
) as f2: |
|
f1.write("\n".join(src_sents)) |
|
f2.write("\n".join(tgt_sents)) |
|
|
|
|
|
if __name__ == "__main__": |
|
|
|
base_path = argv[1] |
|
out_dir = argv[2] |
|
|
|
language_codes = [ |
|
'asm_Beng', 'ben_Beng', 'brx_Deva', 'doi_Deva', 'gom_Deva', |
|
'guj_Gujr', 'hin_Deva', 'kan_Knda', 'kas_Arab', 'kas_Deva', |
|
'mai_Deva', 'mal_Mlym', 'mar_Deva', 'mni_Beng', 'mni_Mtei', |
|
'npi_Deva', 'ory_Orya', 'pan_Guru', 'san_Deva', 'sat_Olck', |
|
'snd_Arab', 'snd_Deva', 'tam_Taml', 'tel_Telu', 'urd_Arab' |
|
] |
|
|
|
domains = os.listdir(base_path) |
|
|
|
with mp.Pool(mp.cpu_count()) as pool: |
|
pool.map(process_language, language_codes) |
|
|