2023-11-04 13:24:17 +00:00
|
|
|
package nu.marginalia.util;
|
|
|
|
|
|
|
|
import nu.marginalia.LanguageModels;
|
|
|
|
import nu.marginalia.WmsaHome;
|
|
|
|
|
|
|
|
import java.nio.file.Files;
|
|
|
|
import java.nio.file.Path;
|
|
|
|
import java.util.Optional;
|
|
|
|
|
|
|
|
public class TestLanguageModels {
|
|
|
|
private static final Path LANGUAGE_MODELS_DEFAULT = WmsaHome.getHomePath().resolve("model");
|
|
|
|
|
|
|
|
public static Path getLanguageModelsPath() {
|
|
|
|
final Path languageModelsHome = Optional.ofNullable(System.getenv("LANGUAGE_MODELS_HOME"))
|
|
|
|
.map(Path::of)
|
|
|
|
.orElse(LANGUAGE_MODELS_DEFAULT);
|
|
|
|
|
|
|
|
if (!Files.isDirectory(languageModelsHome)) {
|
|
|
|
throw new IllegalStateException("Could not find $LANGUAGE_MODELS_HOME, see doc/language-models.md");
|
|
|
|
}
|
|
|
|
return languageModelsHome;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static LanguageModels getLanguageModels() {
|
|
|
|
|
|
|
|
var languageModelsHome = getLanguageModelsPath();
|
|
|
|
|
|
|
|
return new LanguageModels(
|
|
|
|
languageModelsHome.resolve("tfreq-new-algo3.bin"),
|
|
|
|
languageModelsHome.resolve("opennlp-sentence.bin"),
|
|
|
|
languageModelsHome.resolve("English.RDR"),
|
|
|
|
languageModelsHome.resolve("English.DICT"),
|
2024-03-19 09:33:29 +00:00
|
|
|
languageModelsHome.resolve("lid.176.ftz"),
|
|
|
|
languageModelsHome.resolve("segments.bin")
|
2023-11-04 13:24:17 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|