-
Notifications
You must be signed in to change notification settings - Fork 49
Home
The Pothos project is a complete data-flow framework for creating topologies of interconnected processing blocks. Topologies can be designed and tested graphically, and deployed over a network. The Pothos framework API is sleek and smart, enabling users to quickly create custom processing blocks with minimal boiler-plate. Processing blocks can support compuational offload and integration with DMA devices. The project also has a diverse set of processing and hardware support toolkits. Read more on the project overview page.
Get the Pothos development environment up and running with the getting started guide.
- Windows installer available
- January 2015 status update video
- There is now a Pothos users' group
- First version release tag 0.1.0
- The maint branch (pre 0.1.1) is accumulating fixes
- The master branch (pre 0.2.0) is accumulating new features
- Components map
- General blocks
- Graphical widgets
- OpenCL support
- SDR devices
- Audio devices
- FPGA support
- Zynq support
- GNU Radio support
Pothos is a feature-full dataflow programming software suite.
- API to design data flows composed of modular blocks
- Graphical interface to design, deploy, and monitor
- Integration of 3rd party toolkits such as DSP libraries
- Support computational offload to GPUs, DSPs, FPGAs
- Custom processing blocks in any language (we have a binding for)
- Distributing across threadpools, processes, and nodes on a network
- Minimally invasive scheduler, minimal boilerplate for custom blocks
Additional information:
- See the Features summary page for more detailed information.
- See the Roadmap features page for future planned features.
Pothos can be built and installed on a variety of systems including Windows, OSX, and Linux. See the Build Guide for dependencies and compilation instructions. We have limited pre-built binaries available on the Releases page. If you would like get involved with providing distribution binaries, please contact us.
- Project overview
- Getting started
- FAQ
- Video screencasts
- Features summary
- Versioned releases
- Binary downloads
- Developer blog
- Help and support
- Contract services
- Contributing
- Helpful links
- Dive into the graphical developer tools with the Pothos GUI tutorial.
- Learn more about the scheduler and how it works in Scheduler explained.
- Explore the install and execute JSON topologies with the PothosUtil Guide.
- Follow the Blocks Coding Guide to create custom C++ processing blocks.
- Checkout the Doxygen generated documentation for the Pothos Framework API.
- Create processing blocks in Python with this example from the pothos-python wiki.
- Extend serialization support for custom data structures to traverse network boundaries.
Feedback is critical for any open source project. Found a bug? Having trouble? Would a particular feature make your life easier? Please feel free to contact us or use the issue tracker for the relevant toolkit. If possible, please tell us how you are using Pothos, we would love to hear it.
- Project overview
- Getting started
- FAQ
- Video screencasts
- Demo applications
- Features summary
- Versioned releases
- Miscellaneous links
- Help and support
- Pothos users' group
- Twitter @pothosware
- IRC chat #pothos
- Slack workspace
- Contract services
- Developer blog
- Contributing
- Donate
- Build guide
- GUI Tutorial
- SDR Tutorial
- Filter Tutorial
- Doxygen docs
- PothosUtil Guide
- Blocks coding guide
- Scheduler explained
- Remote control guide
- Extending serialization