-
Notifications
You must be signed in to change notification settings - Fork 48
Hadrian Basic Use
Download any pre-built Hadrian JAR (except for the hadrian-gae WAR). This article was tested with Hadrian 0.7.1; newer versions should work with no modification. Scala >= 2.10 is required.
Launch a Scala prompt using that JAR as a classpath:
> scala -cp hadrian-standalone-TRUNK-jar-with-dependencies.jar
and import com.opendatagroup.hadrian.jvmcompiler.PFAEngine:
Welcome to Scala version 2.10.5 (Java HotSpot(TM) 64-Bit Server VM, Java 1.8.0_45).
Type in expressions to have them evaluated.
Type :help for more information.
scala> import com.opendatagroup.hadrian.jvmcompiler.PFAEngineLet's start with an engine that merely adds 10 to each input. That's something we can write inline.
scala> val engine = PFAEngine.fromJson("""
| {"input": "double",
| "output": "double",
| "action": {"+": ["input", 100]}}
| """).head
engine: com.opendatagroup.hadrian.jvmcompiler.PFAEngine[AnyRef,AnyRef] = PFA_Engine_1@3f792b9bFor convenience, we could have written it in YAML (all of Hadrian's unit tests are written this way).
scala> val engine = PFAEngine.fromYaml("""
| input: double
| output: double
| action: {+: [input, 100]}
| """).head
engine: com.opendatagroup.hadrian.jvmcompiler.PFAEngine[AnyRef,AnyRef] = PFA_Engine_2@53e211eeNote in both cases that we asked for the .head of what PFAEngine.fromJson and PFAEngine.fromYaml produces. In general, these functions produce a collection of scoring engines from one PFA file (pass multiplicity = 4 and drop .head to see that). These scoring engines can run in parallel and share memory. For now, though, we're only interested in one scoring engine.
By virtue of having created an engine, the PFA has been fully validated. If the PFA is not valid, you would see
- a Jackson exception because the JSON wasn't valid;
- a SnakeYAML exception because the YAML wasn't valid;
-
PFASyntaxExceptionif Hadrian could not build an AST of the PFA from the JSON, for instance if a JSON field name is misspelled; -
PFASemanticExceptionif Hadrian could not build Java bytecode from the AST, for instance if data types don't match; -
PFAInitializationExceptionif Hadrian could not create a scoring engine instance, for instance if the cell/pool data are incorrectly formatted.
Now run the scoring engine on some sample input:
scala> engine.action(java.lang.Double.valueOf(3.14))
res0: AnyRef = 103.14For Java accessibility, the action method takes and returns boxed values of type AnyRef (Object in Java). See [Feeding-Data-to-Hadrian] for a complete menu.
Return to the Hadrian wiki table of contents.
Licensed under the Hadrian Personal Use and Evaluation License (PUEL).