Skip to content

Commit

Permalink
Merge branch 'main' into david/python
Browse files Browse the repository at this point in the history
  • Loading branch information
davidjmeyer committed Oct 18, 2024
2 parents 83c019b + 53f79c3 commit c9806c9
Show file tree
Hide file tree
Showing 24 changed files with 240 additions and 238 deletions.
4 changes: 2 additions & 2 deletions .run/List All nScopes.run.xml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<component name="ProjectRunConfigurationManager">
<configuration default="false" name="List All nScopes" type="CargoCommandRunConfiguration" factoryName="Cargo Command" folderName="Examples">
<option name="command" value="run --example list_all_nscopes" />
<configuration default="false" name="List All nLabs" type="CargoCommandRunConfiguration" factoryName="Cargo Command" folderName="Examples">
<option name="command" value="run --example list_all_nlabs" />
<option name="workingDirectory" value="file://$PROJECT_DIR$" />
<option name="emulateTerminal" value="false" />
<option name="channel" value="DEFAULT" />
Expand Down
12 changes: 6 additions & 6 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
[package]
name = "nscope"
name = "nlabapi"
version = "1.0.0"
authors = ["David Meyer <david@nscope.org>"]
authors = ["David Meyer <david@getnlab.com>"]
license = "GPL-3.0"
description = """
Communication with nScope devices
Communication with nLab devices
"""
homepage = "https://www.nscope.org"
repository = "https://github.com/nLabs-nScope/nscope-rs"
documentation = "https://github.com/nLabs-nScope/nscope-rs"
homepage = "https://www.getnlab.com"
repository = "https://github.com/nLabs-nScope/nlabapi"
documentation = "https://github.com/nLabs-nScope/nlabapi"
readme = "README.md"
edition = "2018"

Expand Down
26 changes: 14 additions & 12 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
# nscope-rs
[![Crates.io](https://img.shields.io/crates/v/nscope)](https://crates.io/crates/nscope)
[![License](https://img.shields.io/crates/l/nscope)](LICENSE)
[![Documentation](https://docs.rs/nscope/badge.svg)](https://docs.rs/nscope)
# nlabapi
[![Crates.io](https://img.shields.io/crates/v/nlabapi)](https://crates.io/crates/nlabapi)
[![License](https://img.shields.io/crates/l/nlabpi)](LICENSE)
[![Documentation](https://docs.rs/nlabapi/badge.svg)](https://docs.rs/nlabapi)

![Cargo Test](https://github.com/nLabs-nScope/nscope-rs/actions/workflows/tests.yml/badge.svg)
![Cargo Test](https://github.com/nLabs-nScope/nlabapi/actions/workflows/tests.yml/badge.svg)

A Rust implementation of the nScope API.
Low-level software interface for nLab devices

## Building from Source

The nScope API can be built and run from source to enable users and developers to quickly iterate on nScope source code. To establish a development environment, follow the steps below.
The nLab API can be built and run from source to enable users and developers to quickly iterate on nLab source code. To establish a development environment, follow the steps below.


### Prerequisites
Expand Down Expand Up @@ -42,8 +42,8 @@ The above commands should print a version successfully.
### Clone and Install Development Dependencies
```shell
$ git clone https://github.com/nLabs-nScope/nscope-rs.git
$ cd nscope-rs
$ git clone https://github.com/nLabs-nScope/nlabapi.git
$ cd nlabapi
```
### Build and Run
Expand All @@ -54,7 +54,7 @@ $ cargo run --example list_all_nscopes

## Python Development

This project also supports a python interface to the nScope. To set up an environment for python development, follow the steps below.
This project also supports a python interface to the nLab. To set up an environment for python development, follow the steps below.

### Prerequisites

Expand All @@ -72,13 +72,15 @@ $ source venv/bin/activate
$ pip install maturin
```

### Build and install the nscope package for developement
### Build and install the nlabapi package for developement
```shell
$ maturin develop
```

### Build and install the nscope package for developement
### Build and install the nlabapi package for developement
```shell
$ maturin develop
$ python examples/list_all_nscopes.py
```

Low-level software interface for nLab devices
18 changes: 9 additions & 9 deletions examples/analog_outputs.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
/***************************************************************************************************
*
* nLabs, LLC
* https://nscope.org
* https://getnlab.com
* Copyright(c) 2020. All Rights Reserved
*
* This file is part of the nScope API
* This file is part of the nLab API
*
**************************************************************************************************/

use nscope::{LabBench};
use nlabapi::{LabBench};
use std::{thread, time};
use std::error::Error;

Expand All @@ -18,16 +18,16 @@ fn main() -> Result<(), Box<dyn Error>> {
// Create a LabBench
let bench = LabBench::new()?;

// Open the first available nScope
let nscope = bench.open_first_available(true)?;
// Open the first available nLab
let nlab = bench.open_first_available(true)?;

nscope.a1.turn_on();
nlab.a1.turn_on();
thread::sleep(time::Duration::from_secs(10));
nscope.a1.turn_off();
nlab.a1.turn_off();

nscope.a2.turn_on();
nlab.a2.turn_on();
thread::sleep(time::Duration::from_secs(10));
nscope.a2.turn_off();
nlab.a2.turn_off();

Ok(())
}
22 changes: 11 additions & 11 deletions examples/data_request.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
/***************************************************************************************************
*
* nLabs, LLC
* https://nscope.org
* https://getnlab.com
* Copyright(c) 2020. All Rights Reserved
*
* This file is part of the nScope API
* This file is part of the nLab API
*
**************************************************************************************************/

use nscope::{AnalogSignalPolarity, LabBench, Trigger, TriggerType};
use nlabapi::{AnalogSignalPolarity, LabBench, Trigger, TriggerType};
use std::error::Error;

fn main() -> Result<(), Box<dyn Error>> {
Expand All @@ -17,30 +17,30 @@ fn main() -> Result<(), Box<dyn Error>> {
// Create a LabBench
let bench = LabBench::new()?;

// Open the first available nScope
let nscope = bench.open_first_available(true)?;
// Open the first available nLab
let nlab = bench.open_first_available(true)?;

nscope.a1.turn_on();
nlab.a1.turn_on();

let sweep_handle = nscope.request(8000.0, 19200, None);
let sweep_handle = nlab.request(8000.0, 19200, None);

for sample in sweep_handle.receiver {
println!("{:?}", sample.data);
}

nscope.a1.turn_off();
nlab.a1.turn_off();


let sweep_handle = nscope.request(8000.0, 19200, Some(Trigger{
let sweep_handle = nlab.request(8000.0, 19200, Some(Trigger{
is_enabled: true,
trigger_type: TriggerType::RisingEdge,
source_channel: 0,
trigger_level: 0.0,
trigger_delay_us: 0,
}));

nscope.a1.set_polarity(AnalogSignalPolarity::Bipolar);
nscope.a1.turn_on();
nlab.a1.set_polarity(AnalogSignalPolarity::Bipolar);
nlab.a1.turn_on();
for sample in sweep_handle.receiver {
println!("{:?}", sample.data);
}
Expand Down
20 changes: 10 additions & 10 deletions examples/fast_communication.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
/***************************************************************************************************
*
* nLabs, LLC
* https://nscope.org
* https://getnlab.com
* Copyright(c) 2020. All Rights Reserved
*
* This file is part of the nScope API
* This file is part of the nLab API
*
**************************************************************************************************/

use nscope::LabBench;
use nlabapi::LabBench;
use std::error::Error;

fn main() -> Result<(), Box<dyn Error>> {
Expand All @@ -17,16 +17,16 @@ fn main() -> Result<(), Box<dyn Error>> {
// Create a LabBench
let bench = LabBench::new()?;

// Open the first available nScope
let mut nscope = bench.open_first_available(true)?;
// Open the first available nLab
let mut nlab = bench.open_first_available(true)?;

nscope.ch1.turn_on();
nscope.ch2.turn_on();
nscope.ch3.turn_on();
nscope.ch4.turn_on();
nlab.ch1.turn_on();
nlab.ch2.turn_on();
nlab.ch3.turn_on();
nlab.ch4.turn_on();

loop {
let sweep_handle = nscope.request(2_000_000.0, 1200, None);
let sweep_handle = nlab.request(2_000_000.0, 1200, None);
while sweep_handle.receiver.recv().is_ok() {}
}
}
16 changes: 8 additions & 8 deletions examples/list_all_nscopes.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
/***************************************************************************************************
*
* nLabs, LLC
* https://nscope.org
* https://getnlab.com
* Copyright(c) 2020. All Rights Reserved
*
* This file is part of the nScope API
* This file is part of the nLab API
*
**************************************************************************************************/

use nscope::LabBench;
use nlabapi::LabBench;
use std::error::Error;

fn main() -> Result<(), Box<dyn Error>> {
Expand All @@ -17,13 +17,13 @@ fn main() -> Result<(), Box<dyn Error>> {
// Create a LabBench
let bench = LabBench::new()?;

// Print the bench to show a list of detected nScopes
// Print the bench to show a list of detected nLabs
println!("Lab Bench: \n{:?}", bench);

println!("\nManual list of all detected nScopes:");
// Or loop over all nScope links in the list and print them
for nscope_link in bench.list() {
println!(" {:?}", nscope_link)
println!("\nManual list of all detected nLabs:");
// Or loop over all nLab links in the list and print them
for nlab_link in bench.list() {
println!(" {:?}", nlab_link)
}
Ok(())
}
18 changes: 9 additions & 9 deletions examples/monitor_power.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
/***************************************************************************************************
*
* nLabs, LLC
* https://nscope.org
* https://getnlab.com
* Copyright(c) 2020. All Rights Reserved
*
* This file is part of the nScope API
* This file is part of the nLab API
*
**************************************************************************************************/

use nscope::{LabBench, Nscope};
use nlabapi::{LabBench, Nlab};
use std::{thread, time};
use std::error::Error;

Expand All @@ -18,15 +18,15 @@ fn main() -> Result<(), Box<dyn Error>> {
// Create a LabBench
let bench = LabBench::new()?;

// Open all available nScope links
let mut nscopes: Vec<Nscope> = bench.open_all_available();
// Open all available nLab links
let mut nlabs: Vec<Nlab> = bench.open_all_available();

loop {
thread::sleep(time::Duration::from_millis(500));

nscopes.retain(|n| n.is_connected());
nlabs.retain(|n| n.is_connected());

for n in nscopes.iter() {
for n in nlabs.iter() {
match n.power_status() {
Ok(status) => {
let state = format!("{:?}", status.state);
Expand All @@ -36,8 +36,8 @@ fn main() -> Result<(), Box<dyn Error>> {
}
}

if nscopes.is_empty() {
return Err("Cannot find any nScopes".into())
if nlabs.is_empty() {
return Err("Cannot find any nLabs".into())
}
}
}
18 changes: 9 additions & 9 deletions examples/pulse_outputs.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
/***************************************************************************************************
*
* nLabs, LLC
* https://nscope.org
* https://getnlab.com
* Copyright(c) 2020. All Rights Reserved
*
* This file is part of the nScope API
* This file is part of the nLab API
*
**************************************************************************************************/

use nscope::{LabBench};
use nlabapi::{LabBench};
use std::{thread, time};
use std::error::Error;

Expand All @@ -18,16 +18,16 @@ fn main() -> Result<(), Box<dyn Error>> {
// Create a LabBench
let bench = LabBench::new()?;

// Open the first available nScope
let nscope = bench.open_first_available(true)?;
// Open the first available nLab
let nlab = bench.open_first_available(true)?;

nscope.p1.turn_on();
nlab.p1.turn_on();
thread::sleep(time::Duration::from_secs(10));
nscope.p1.turn_off();
nlab.p1.turn_off();

nscope.p2.turn_on();
nlab.p2.turn_on();
thread::sleep(time::Duration::from_secs(10));
nscope.p2.turn_off();
nlab.p2.turn_off();

Ok(())
}
Loading

0 comments on commit c9806c9

Please sign in to comment.