Rahul Sharma (Editor)

Kamaelia

Updated on
Edit
Like
Comment
Share on FacebookTweet on TwitterShare on LinkedInShare on Reddit
Developer(s)
  
BBC Research

License
  
Apache License

Operating system
  
Cross-platform

Website
  
www.kamaelia.org

Stable release
  
1.0.12.0 / December 30, 2010; 6 years ago (2010-12-30)

Kamaelia is a free software/open source Python-based systems-development tool and concurrency framework produced by BBC Research.

Kamaelia applications are produced by linking independent components together. These components communicate entirely through "inboxes" and "outboxes" (queues) largely removing the burdens of thread-safety and IPC from the developer. This also makes components reusable in different systems, allows easy unit testing and results in parallelism (between components) by default.

Components are generally implemented as generators - a method more light-weight than allocating a thread to each (though this is also supported). As a result, switching between the execution of components in Kamaelia systems is very fast.

Applications that have been produced using Kamaelia include a Freeview digital video recorder, a network-shared whiteboard, a 3D GUI, an HTTP Server, an audio mixer, a stream multicasting system and a simple BitTorrent client.

License change

Kamaelia's License changed in July 2010 from the Mozilla tri-license (MPL, GPL and LGPL) to the Apache License, with a note that usage under the old licensing scheme was permitted if necessary (due to license incompatibilities), given the rationale for change was to make the codebase more usable by developers not less.

References

Kamaelia Wikipedia