UIMA Ruta: JCas не может быть инициализирован / скрипт не найден
Я пытаюсь интегрировать скрипт UIMA Ruta (Main.ruta
) в трубопроводе uimaFIT (вMain.java
), но сценарий не может быть найден. Это моя структура проекта:
uima-ruta-maven-test-project/src/main/Main.java
uima-ruta-maven-test-project/script/ruta/Main.ruta
uima-ruta-maven-test-project/descriptor/ruta/MainEngine.xml
Вот мой код для создания AnalysisEngineDescription
:
File file = new File("descriptor/ruta/MainEngine.xml");
AnalysisEngineDescription rutaScript = AnalysisEngineFactory.createEngineDescriptionFromPath(
file.getPath(),
RutaEngine.PARAM_SCRIPT_PATHS, "script",
RutaEngine.PARAM_MAIN_SCRIPT, "Main.ruta");
И это мой вывод на консоль:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
SLF4J: Failed to load class "org.slf4j.impl.StaticMDCBinder".
SLF4J: Defaulting to no-operation MDCAdapter implementation.
SLF4J: See http://www.slf4j.org/codes.html#no_static_mdc_binder for further details.
org.apache.uima.resource.ResourceInitializationException: Initialization of annotator class "org.apache.uima.ruta.engine.RutaEngine" failed. (Descriptor: file:/D:/Programming/MA/uima-ruta-maven-test-project/descriptor/ruta/MainEngine.xml)
at org.apache.uima.analysis_engine.impl.PrimitiveAnalysisEngine_impl.initializeAnalysisComponent(PrimitiveAnalysisEngine_impl.java:260)
at org.apache.uima.analysis_engine.impl.PrimitiveAnalysisEngine_impl.initialize(PrimitiveAnalysisEngine_impl.java:173)
at org.apache.uima.impl.AnalysisEngineFactory_impl.produceResource(AnalysisEngineFactory_impl.java:94)
at org.apache.uima.impl.CompositeResourceFactory_impl.produceResource(CompositeResourceFactory_impl.java:62)
at org.apache.uima.UIMAFramework.produceResource(UIMAFramework.java:289)
at org.apache.uima.UIMAFramework.produceAnalysisEngine(UIMAFramework.java:417)
at org.apache.uima.analysis_engine.asb.impl.ASB_impl.setup(ASB_impl.java:256)
at org.apache.uima.analysis_engine.impl.AggregateAnalysisEngine_impl.initASB(AggregateAnalysisEngine_impl.java:435)
at org.apache.uima.analysis_engine.impl.AggregateAnalysisEngine_impl.initializeAggregateAnalysisEngine(AggregateAnalysisEngine_impl.java:379)
at org.apache.uima.analysis_engine.impl.AggregateAnalysisEngine_impl.initialize(AggregateAnalysisEngine_impl.java:192)
at org.apache.uima.impl.AnalysisEngineFactory_impl.produceResource(AnalysisEngineFactory_impl.java:94)
at org.apache.uima.impl.CompositeResourceFactory_impl.produceResource(CompositeResourceFactory_impl.java:62)
at org.apache.uima.UIMAFramework.produceResource(UIMAFramework.java:289)
at org.apache.uima.UIMAFramework.produceResource(UIMAFramework.java:341)
at org.apache.uima.UIMAFramework.produceAnalysisEngine(UIMAFramework.java:458)
at org.apache.uima.fit.pipeline.SimplePipeline.runPipeline(SimplePipeline.java:178)
at Main.main(Main.java:52)
Caused by: org.apache.uima.resource.ResourceInitializationException
at org.apache.uima.ruta.engine.RutaEngine.initialize(RutaEngine.java:579)
at org.apache.uima.analysis_engine.impl.AnalysisEngineImplBase.lambda$callInitializeMethod$2(AnalysisEngineImplBase.java:612)
at org.apache.uima.analysis_engine.impl.AnalysisEngineImplBase.withContexts(AnalysisEngineImplBase.java:653)
at org.apache.uima.analysis_engine.impl.AnalysisEngineImplBase.callInitializeMethod(AnalysisEngineImplBase.java:612)
at org.apache.uima.analysis_engine.impl.PrimitiveAnalysisEngine_impl.initializeAnalysisComponent(PrimitiveAnalysisEngine_impl.java:252)
... 16 more
Caused by: org.apache.uima.analysis_engine.AnalysisEngineProcessException
at org.apache.uima.ruta.engine.RutaEngine.initializeScript(RutaEngine.java:857)
at org.apache.uima.ruta.engine.RutaEngine.initialize(RutaEngine.java:576)
... 20 more
Caused by: java.io.FileNotFoundException: Script [Main.ruta] cannot be found at [script;D:\Programming\MA\uima-ruta-maven-test-project] or classpath with extension .ruta
... 22 more
Последняя строка вывода моей консоли, похоже, показывает ошибку. Main.ruta
ищется на пути [script;D:\Programming\MA\uima-ruta-maven-test-project]
который, очевидно, не существует, потому что это недопустимый путь. Я думаю, что методcreateEngineDescriptionFromPath
следует добавить "script"
папку в путь к проекту. Но вместо этого он его добавляет.
Кто-нибудь может мне помочь с этим, пожалуйста?
РЕДАКТИРОВАТЬ
Я нашел эту ссылку на документацию, где использование параметровmainScript
а также scriptPaths
объясняется. Пути должны быть написаны с "." вместо того "/".
Я изменил свой код следующим образом:
AnalysisEngineDescription rutaScript = AnalysisEngineFactory.createEngineDescriptionFromPath(
file.getPath(),
RutaEngine.PARAM_SCRIPT_PATHS, "script.ruta",
RutaEngine.PARAM_MAIN_SCRIPT, "script.ruta.Main");
Но теперь я получаю такой вывод консоли:
Exception in thread "main" org.apache.uima.cas.CASRuntimeException: The JCas cannot be initialized. The following errors occurred:
JCas Class "org.apache.uima.ruta.type.AnyLine", loaded from "jar:file:/C:/Users/user/.m2/repository/org/apache/uima/ruta-typesystem/2.7.0/ruta-typesystem-2.7.0.jar!/org/apache/uima/ruta/type/AnyLine.class", is missing required constructor; likely cause is wrong version (UIMA version 3 or later JCas required).
JCas Class "org.apache.uima.ruta.type.EmptyLine", loaded from "jar:file:/C:/Users/user/.m2/repository/org/apache/uima/ruta-typesystem/2.7.0/ruta-typesystem-2.7.0.jar!/org/apache/uima/ruta/type/EmptyLine.class", is missing required constructor; likely cause is wrong version (UIMA version 3 or later JCas required).
JCas Class "org.apache.uima.ruta.type.WSLine", loaded from "jar:file:/C:/Users/user/.m2/repository/org/apache/uima/ruta-typesystem/2.7.0/ruta-typesystem-2.7.0.jar!/org/apache/uima/ruta/type/WSLine.class", is missing required constructor; likely cause is wrong version (UIMA version 3 or later JCas required).
...
at org.apache.uima.cas.impl.FSClassRegistry.reportErrors(FSClassRegistry.java:1284)
at org.apache.uima.cas.impl.FSClassRegistry.loadJCasForTSandClassLoader(FSClassRegistry.java:400)
at org.apache.uima.cas.impl.FSClassRegistry.getGeneratorsForClassLoader(FSClassRegistry.java:1320)
at org.apache.uima.cas.impl.TypeSystemImpl.getGeneratorsForClassLoader(TypeSystemImpl.java:2924)
at org.apache.uima.cas.impl.TypeSystemImpl.commit(TypeSystemImpl.java:1442)
at org.apache.uima.cas.impl.CASImpl.commitTypeSystem(CASImpl.java:1822)
at org.apache.uima.util.CasCreationUtils.doCreateCas(CasCreationUtils.java:620)
at org.apache.uima.util.CasCreationUtils.createCas(CasCreationUtils.java:292)
at org.apache.uima.fit.pipeline.SimplePipeline.runPipeline(SimplePipeline.java:181)
at Main.main(Main.java:52)
Похоже, что типы Ruta не могут быть инициализированы. У меня в pom.xml есть UIMA Ruta версии 2.7.0 и DKPro 2.0.0.
1 ответ
Похоже, что UIMA Ruta 2 плохо сочетается с UIMA v3 и другими библиотеками, которые на него полагаются (в данном случае uimaFit, DKPro).
Я заставил его работать в моем случае со следующими версиями: DKPro 1.11.0, UIMA 2.10.4, UIMA Ruta 2.7.0 и uimaFit 2.4.0 (см. Также этот вопрос).
Недавно был выпущен UIMA Ruta 3. Думаю, эта версия будет лучше работать вместе с UIMA v3.