1
1
mirror of https://github.com/leon-ai/leon.git synced 2024-12-22 00:01:31 +03:00
leon/scripts/train/train-resolvers-model/train-global-resolvers.js
2023-04-02 20:34:50 +02:00

57 lines
1.7 KiB
JavaScript

import path from 'node:path'
import fs from 'node:fs'
import { composeFromPattern } from '@nlpjs/utils'
import { LogHelper } from '@/helpers/log-helper'
/**
* Train global resolvers
*/
export default (lang, nlp) =>
new Promise(async (resolve) => {
LogHelper.title('Global resolvers training')
const resolversPath = path.join(
process.cwd(),
'core',
'data',
lang,
'global-resolvers'
)
const resolverFiles = await fs.promises.readdir(resolversPath)
for (let i = 0; i < resolverFiles.length; i += 1) {
const resolverFileName = resolverFiles[i]
const resolverPath = path.join(resolversPath, resolverFileName)
const { name: resolverName, intents: resolverIntents } = JSON.parse(
await fs.promises.readFile(resolverPath, 'utf8')
)
const intentKeys = Object.keys(resolverIntents)
LogHelper.info(`[${lang}] Training "${resolverName}" resolver...`)
for (let j = 0; j < intentKeys.length; j += 1) {
const intentName = intentKeys[j]
const intent = `resolver.global.${resolverName}.${intentName}`
const intentObj = resolverIntents[intentName]
nlp.assignDomain(lang, intent, 'system')
for (let k = 0; k < intentObj.utterance_samples.length; k += 1) {
const utteranceSample = intentObj.utterance_samples[k]
// Achieve Cartesian training
const utteranceAlternatives = composeFromPattern(utteranceSample)
utteranceAlternatives.forEach((utteranceAlternative) => {
nlp.addDocument(lang, utteranceAlternative, intent)
})
}
}
LogHelper.success(`[${lang}] "${resolverName}" resolver trained`)
}
resolve()
})