LiveMEA_rs is a Rust library for live data recording from MEA (Microelectrode Array) devices of FinalSpark. It enables real-time data acquisition and processing from MEA devices over a network connection.
Authors: Maiden Labs [github]
Maiden Labs is a non profit user research lab committed to open-source scientific discovery through biocomputing. Utilizing decentralized technologies, we improve access to biocomputing research, advancing interdisciplinary AI and biocomputing related efforts for greater scientific impact and innovation.
- Connects to an MEA server to retrieve live data
- Supports both single-sample and multi-sample data recording
- Uses tokiofor asynchronous networking
- Structured data output with timestamps and electrode readings
Add finalspark-rs to your Cargo.toml:
[dependencies]
finalspark-rs = { git = "https://github.com/FinalSpark-np/LiveMEA_rs.git" }
tokio = { version = "1.0", features = ["full"] }use finalspark_rs::LiveMEA;
#[tokio::main]
async fn main() {
    let live_mea = LiveMEA::new();
    
    // Record a single sample
    match live_mea.record_sample(1).await {
        Ok(data) => {
            println!("Recorded sample with timestamp: {}", data.timestamp);
            println!("Number of electrodes: {}", data.data.len());
            println!("Samples per electrode: {}", data.data[0].len());
        },
        Err(e) => eprintln!("Error recording sample: {}", e),
    }
}use finalspark_rs::LiveMEA;
#[tokio::main]
async fn main() {
    let live_mea = LiveMEA::new();
    match live_mea.record_n_samples(1, 5).await {
        Ok(samples) => {
            println!("Successfully recorded {} samples", samples.len());
            for (i, sample) in samples.iter().enumerate() {
                println!("Sample {} timestamp: {}", i + 1, sample.timestamp);
            }
        },
        Err(e) => eprintln!("Error recording samples: {}", e),
    }
}The LiveData struct contains:
- timestamp: String in RFC3339 format representing when the sample was recorded
- data: 2D vector containing electrode readings where:- First dimension: 32 electrodes
- Second dimension: 4096 samples per electrode
 
- tokio- Async runtime and networking
- serde&- serde_json- Data serialization
- chrono- Timestamp handling
- tokio-tungstenite- WebSocket communication
- url- URL parsing and handling
This project is licensed under the MIT License. See LICENSE for details.
Contributions are welcome! Please submit an issue or pull request on GitHub.