I am trying to call a NetLogo model from my Java app. I am using right now the sample code:
public static void main(String[] argv) {
HeadlessWorkspace workspace = HeadlessWorkspace.newInstance();
try {
workspace.open("models/Sample Models/Earth Science/Fire.nlogo");
workspace.command("set density 62");
workspace.command("random-seed 0");
workspace.command("setup");
workspace.command("repeat 50 [ go ]");
System.out.println(workspace.report("burned-trees"));
workspace.dispose();
} catch (IOException | CompilerException | LogoException | InterruptedException ex) {
ex.printStackTrace();
}
}
I have added the dependency in my Netbeans project, but when I try to run it, I get:
------------------------------------------------------------------------
Building JAGO3 1.3
------------------------------------------------------------------------
The POM for org.nlogo:NetLogo:jar:5.2 is missing, no dependency information available
COMPILATION ERROR :
-------------------------------------------------------------
com/digitaldust/jago3/NetLogoManager.java:[16,55] error: cannot access ScalaObject
1 error
this code is added in my POM:
<dependency>
<groupId>org.nlogo</groupId>
<artifactId>NetLogo</artifactId>
<version>5.2</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
It looks like there is no POM for NetLogo, even if it's added as a dependency... Anyway, being a Maven newbie, I don't understand if I am missing something... any help more than welcome.
EDIT
I have tried adding the NetLogo.jar from my NetLogo folder as a local dependency, using this snippet:
<dependency>
<groupId>org.nlogo</groupId>
<artifactId>NetLogo</artifactId>
<version>5.2</version>
<scope>system</scope>
<systemPath>${project.basedir}/src/main/resources/NetLogo.jar</systemPath>
</dependency>
I am able to load the dependency from my current NetLogo installation, but I still get a (different) error:
--- maven-resources-plugin:2.5:resources (default-resources) @ JAGO3 ---
[debug] execute contextualize
Using 'UTF-8' encoding to copy filtered resources.
Copying 26 resources
--- maven-compiler-plugin:2.3.2:compile (default-compile) @ JAGO3 ---
Nothing to compile - all classes are up to date
--- exec-maven-plugin:1.2.1:exec (default-cli) @ JAGO3 ---
Exception in thread "main" java.lang.NoClassDefFoundError: org/nlogo/api/CompilerException
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2693)
at java.lang.Class.privateGetMethodRecursive(Class.java:3040)
at java.lang.Class.getMethod0(Class.java:3010)
at java.lang.Class.getMethod(Class.java:1776)
at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: org.nlogo.api.CompilerException
at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 7 more
EDIT2
I managed to import all jars in the lib folder manually with:
<dependency>
<groupId>org.nlogo</groupId>
<artifactId>netlogo</artifactId>
<version>5.2</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.objectweb.asm</groupId>
<artifactId>asm-all</artifactId>
<version>3.3.1</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.commons.codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.6</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>com.sun.gluegen</groupId>
<artifactId>gluegen-rt</artifactId>
<version>1.1.1</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents.httpclient</groupId>
<artifactId>httpclient</artifactId>
<version>4.2</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents.httpcore</groupId>
<artifactId>httpcore</artifactId>
<version>4.2</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents.httpmime</groupId>
<artifactId>httpmime</artifactId>
<version>4.2</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.jhotdraw</groupId>
<artifactId>jhotdraw</artifactId>
<version>6.0b1</version>
<scope>compile</scope>
<type>jar</type>
</dependency>
<dependency>
<groupId>javax.media</groupId>
<artifactId>jmf</artifactId>
<version>2.1.1e</version>
</dependency>
<dependency>
<groupId>org.jogamp.jogl</groupId>
<artifactId>jogl</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>com.googlecode.json-simple</groupId>
<artifactId>json-simple</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.16</version>
</dependency>
<dependency>
<groupId>mrj</groupId>
<artifactId>mrjadapter</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.parboiled</groupId>
<artifactId>parboiled-core</artifactId>
<version>1.0.2</version>
</dependency>
<dependency>
<groupId>org.parboiled</groupId>
<artifactId>parboiled-java</artifactId>
<version>1.0.2</version>
</dependency>
<dependency>
<groupId>org.pegdown</groupId>
<artifactId>pegdown</artifactId>
<version>1.1.0</version>
</dependency>
<dependency>
<groupId>org.picocontainer</groupId>
<artifactId>picocontainer</artifactId>
<version>2.13.6</version>
</dependency>
<dependency>
<groupId>org.devzendo</groupId>
<artifactId>Quaqua</artifactId>
<version>7.3.4</version>
</dependency>
<dependency>
<groupId>org.scala-lang</groupId>
<artifactId>scala-library</artifactId>
<version>2.9.2</version>
</dependency>
<dependency>
<groupId>org.jdesktop.layout</groupId>
<artifactId>swing-layout</artifactId>
<version>7.3.4</version>
</dependency>
The only issue I have now is that, having a project based on Spark, I already had a scala dependency higher than the NetLogo one... I just removed the Spark scala and Netlogo now works fine.