Reactive Blocks

Reactive Blocks[1] is a visual model-driven development environment based on Activity Diagrams supporting formal model analysis, automated code generation, hierarchical modelling, and an extensive library of ready-to-use components for the Java platform.

Reactive Blocks
Developer(s)Bitreactive AS
Initial release2011
Stable release
2.7.0 / 2016-09-16
Operating systemWindows, OS X, Linux
PlatformEclipse / Java
LicenceCommercial, Free Community Edition
Websitehttp://www.bitreactive.com/

Concept

The core technology originated from research at the Norwegian University of Science and Technology and the Institute for Telematics.[2] Reactive Blocks is a visual model-driven development environment supporting formal model analysis, automated code generation, hierarchical modelling, and an extensive library of ready-to-use components for the Java platform. By combining re-usable blocks, a developer can create complex applications graphically.

These building blocks are defined by a combination of graphical models and Java code. The graphical model is based on UML activity diagrams and state machines. The existing library can be extended by user-implemented custom blocks which can include the full abilities of the Java platform. Each block has an extended interface description in the form of input and output pins and a contract. The contract indicates which states a block has, and which pins can be interacted with during which state.

Reactive Blocks uses the graphical model together with the information from the contracts to formally analyse the application to discover common problems such as deadlocks or incorrect terminations. If the analysis finds a problem, the according state of the application can be highlighted to identify the cause. The development environment offers a step-by-step animation of the chain of state transitions leading up to the problem.

An application which passed validation can then be automatically converted into Java code. Since a building block´s application is a correct formal definition, the builder can transform its logic into code. The generated code is packaged in a standard Eclipse Java project and can thus be treated as any other code; exporting runnable JARs, debugging, and profiling work the same.

Supported Platforms

Literature

  • Kraemer, Frank Alexander; Herrmann, Peter (2010). "Reactive Semantics for Distributed UML Activities". Formal Techniques for Distributed Systems: Joint 12th IFIP WG 6.1 International Conference. Amsterdam, The Netherlands: Springer Berlin Heidelberg. pp. 17–31. doi:10.1007/978-3-642-13464-7_3. 10.1007/978-3-642-13464-7_3.
  • Kraemer, Frank Alexander (2015-04-09). "Block by Block Towards IoT Applications" (PDF). Bitreactive. Retrieved 2016-09-26.
gollark: I don't know what you're referring to. I haven't looked since 2054.
gollark: Surely we can be friends without having to have all arbitrary online platforms recognise this.
gollark: Fascinating.
gollark: Why would I have?
gollark: What?

References

  1. Homepage
  2. Kraemer, Frank Alexander (2008). Engineering Reactive Systems: A Compositional and Model-Driven Method Based on Collaborative Building Blocks (PhD). Fakultet for informasjonsteknologi, matematikk og elektroteknikk. hdl:11250/261480.
  3. "Huawei, Bitreactive and Eurotech join OSGi Alliance" (PDF) (Press release). USA: OSGi Alliance. Inventures. 2015-11-03. Retrieved 2016-09-26.
  4. "Kura - Open Source framework for IoT". Eclipse Foundation. Retrieved 2016-09-25.
  5. "Everyware™ Software Framework ( ESF )". Eurotech. Retrieved 2016-09-25.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.