Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
Hayasen
⚠️ Warning: Early Development Stage
This library is currently under active development and has not been thoroughly tested. Use in production systems at your own risk. APIs may change without notice.
Hayasen is an Embedded Rust library designed to simplify sensor integration in embedded systems. It provides unified, type-safe interfaces for various sensors with a focus on ease of use and reliability.
🚀 Currently Supported Sensors
- MPU9250 - 9-axis motion tracking device (accelerometer, gyroscope, temperature) - Work in Progress
📦 Installation
Add hayasen to your Cargo.toml:
[]
= { = "*", = ["mpu9250"] } # For MPU9250 support
🎯 Quick Start
use *;
use mpu9250_hayasen;
🔧 Features
mpu9250- Enables MPU9250 motion sensor support (enabled by default)- More sensors coming soon!
📚 Documentation
- API Documentation - Complete API reference
- Examples - Practical usage examples (Coming Soon)
- Contributing Guidelines - How to contribute to the project
🏗️ Project Structure
hayasen/
├── src/
│ ├── lib.rs # Main library entry point
│ ├── error.rs # Unified error types
│ ├── functions.rs # Function registry system
│ └── mpu9250.rs # MPU9250 sensor implementation
├── examples/ # Usage examples
└── tests/ # Integration tests
📝 License
This project is dual-licensed under either:
- Apache License, Version 2.0 Apache-2.0
- MIT license MIT
🙏 Acknowledgments
- Inspired by various embedded Rust driver libraries
- Thanks to the Rust embedded working group for excellent tools and guidance
- Community contributors and testers
🐛 Issue Reporting
Found a bug or have a feature request? Please open an issue on GitHub.
🔮 Roadmap
🎯 Short-term Goals (v0.2.0 - v0.5.0)
-
Complete MPU9250 implementation and testing
- Magnetometer support (AK8963)
- Self-test functionality
- Motion detection interrupts
- FIFO buffer support
- Comprehensive unit tests
- Integration tests with hardware
-
Add comprehensive test suite
- Unit tests for all public APIs
- Integration tests with mock I2C
- Hardware-in-the-loop testing
- Continuous integration setup
- Code coverage reporting
-
Create more usage examples
- Basic sensor reading example
- Interrupt-driven motion detection
- Data logging application
- Multi-sensor fusion example
- RTOS integration examples
🚀 Medium-term Goals (v0.6.0 - v0.9.0)
-
Add MAX30102 heart rate sensor support
- Heart rate monitoring
- Oxygen saturation (SpO2) measurement
- FIFO data reading
- Interrupt configuration
- Temperature reading
-
Add CI/CD pipeline
- GitHub Actions for testing
- Automated documentation deployment
- Release automation
- Crate publishing automation
- Cross-compilation testing
🌟 Long-term Goals (v1.0.0+)
-
Support for more sensor types
- BME280 (Temperature, Humidity, Pressure)
- BMP180/BMP280 (Pressure)
- HMC5883L (Magnetometer)
- ADXL345 (Accelerometer)
- TMP36/TMP102 (Temperature)
-
Advanced features
- Sensor fusion algorithms
- Power management utilities
- Async/await support
- No-alloc mode for tiny systems
- WebAssembly support for simulation
-
Ecosystem integration
- Embassy framework support
- RTIC framework integration
- defmt logging support
- Probe-rs debugging support
- Platform-agnostic drivers
📊 Version Timeline
timeline
title Hayasen Development Timeline
section v0.2.x
MPU9250 Completion : Magnetometer<br>Interrupts<br>FIFO
Testing Suite : Unit Tests<br>Integration Tests
section v0.3.x
Examples : Basic Examples<br>Advanced Use Cases
CI/CD : GitHub Actions<br>Auto Documentation
section v0.4.x
MAX30102 Support : Heart Rate<br>SpO2 Monitoring
section v0.5.x
Additional Sensors : BME280<br>HMC5883L
section v1.0.0
Stable API : Production Ready<br>Full Documentation