ROBOT is a tool for working with Open Biomedical Ontologies. It's still in development!
This code can be used as:
- a command-line tool
- a library for any JVM language
The command-line tool is packaged a Jar file and can be run via the robot
shell script. We will soon have packaged releases, but for now please follow the "Build" instruction below.
See examples/README.md for a tutorial with many example commands.
The core ROBOT operations are written in plain Java code, and can be used from any language that uses the Java Virtual Machine. The command-line tool is both built on top of the library of operations. You can add use these operations in your own code, or add new operations written in any JVM language.
The library provides a number of Operation classes for manipulating ontologies. The IOHelper
class contains convenient static methods for loading and saving ontologies, and for loading sets of term IRIs. Here's an example of extracting a "core" subset from an ontology:
IOHelper ioHelper = new IOHelper();
OWLOntology full = ioHelper.loadOntology("ontology.owl");
Set<IRI> coreTerms = ioHelper.loadTerms("coreTerms.txt");
OWLOntology core = ExtractOperation.extract(full, coreTerms);
ioHelper.saveOntology(core, "core.owl");
Alternatively:
IOHelper ioHelper = new IOHelper();
ioHelper.saveOntology(
ExtractOperation.extract(
ioHelper.loadOntology("ontology.owl"),
ioHelper.loadTerms("coreTerms.txt"),
IRI.create("http://example.com")
),
'core.owl'
);
We use Maven as our build tool. Make sure it's installed, then run:
mvn clean package
This will create a self-contained Jar file in bin/robot.jar
.
Other build options:
mvn clean test
runs JUnit tests with reports in[module]/target/surefire-reports
mvn clean verify
rebuilds the package and runs integration tests against it, with reports in[module]/target/failsafe-reports
mvn site
generates reports (including Javadoc and Checkstyle) intarget/site
and[module]/target/site
The library provides a set of Operations and a set of Commands. Commands handle the command-line interface and IO tasks, while Operations focus on manipulating ontologies. Sometimes you will have the pair of an Operation and a Command, but there's no necessity for a one-to-one correspondence between them.
Commands implement the Command interface, which requires a main(String[] args)
method. Each command can be called via main
, but the CommandLineInterface class provides a single entry point for selecting between all the available commands. While each Command can run independently, there are shared conventions for command-line options such as --input
, --prefix
, --output
, etc. These shared conventions are implemented in the CommandLineHelper utility class. There is also an IOHelper class providing convenient methods for loading and saving ontologies and lists of terms. A simple Command will consist of a few CommandLineHelper calls to determine arguments, a few IOHelper calls to load or save files, and one call to the appropriate Operation.
Operations are currently implemented with static methods and no shared interface. They should not contain IO or CLI code.
The current implementation is modular but not pluggable. In particular, the CommandLineInterface class depends on a hard-coded list of Commands.
Many Operations require lists of terms. The IOHelper class defines methods for collecting lists of terms from strings and files, and returning a Set<IRI>
. Our convention is that a term list is a space-separated list of IRIs or CURIEs with optional comments. The "#" character and everything to the end of the line is ignored. Note that a "#" must start the line or be preceded by whitespace -- a "#" inside an IRI does not start a comment.