A uwb locating library
Project description
pyuwb
python sdk for dw1000 uwb locating library.
how to install
pip install pyuwb
definition:
client_id: device sn,format:{group_id}-{type_id}-{client_no} a string.eg:1-2-4.
where: group_id: fixed 1.
type_id: 1--key anchor(connect to computer). 2--normal anchor. 3 --tag
client_no: client NO. start from 0.
use it step by step:
connect
from pyuwb import uwb
h=uwb()
#conect to serial
h.connect()
set or detect anchor & tag
set device list
# set device list
h.set_device(tag_no_list=[1], anchor_no_list=[0])
or auto-detect
# auto-detect the device nearby. if you don't know the device_no, you can use this instead of set_device
h.detect_device()
measure distance
# get distance of two device using the device client_id
dist_meter = h.get_distance('1-3-1', '1-2-0')
set anchor pos
locating the anchor using themselves
anchor_pos_list = h.locate_anchor()
# print the located anchor pos
print(anchor_pos_list)
or set anchor pos directly:
# set anchor position. you could use this instead of locate_anchor() if you know the anchor exact pos.
anchor_pos_list = [{'client_id': '1-2-0', 'pos': {'x': 0, 'y': 5.5, 'z': 0.5}},
{'client_id': '1-2-1', 'pos': {'x': 0, 'y': 0, 'z': 1.1}},
{'client_id': '1-2-2', 'pos': {'x': 2.67, 'y': -0.33, 'z': 0.5}},
{'client_id': '1-2-3', 'pos': {'x': 4.03, 'y': 5.47, 'z': 1.1},
}]
h.set_anchor_location(anchor_pos_list)
measure tag pos
start tag locating once
located_tag_pos = h.start_locate_once()
print('located_tag_pos:', located_tag_pos)
or set callback function and locating in a loop
def function_to_call(tag_no,dist, pos):
# this function will be called everytime one tag is located successfully
print('function_to_call', tag_no,pos, dist)
# set callback
h.set_pos_callback(function_to_call)
# start and wait for 10-seconds
h.set_to_start()
t1=time.time()
while time.time()-t1<10:
h.locate_loop()
# stop the continuous measure
h.stop_measure_h()
use it by example:
get distance:
from pyuwb import uwb
h=uwb()
#conect to serial
h.connect()
# set device list
h.set_device(tag_no_list=[1], anchor_no_list=[0])
# get distance of two device using the device client_id
dist_meter = h.get_distance('1-3-1', '1-2-0')
print('distance between 1-3-1 & 1-2-0', dist_meter,'meter')
locating example 1:
from pyuwb import uwb
h=uwb()
#conect to serial
h.connect(com_port="COM3") #set to None will auto-detect the port
# set device list
h.set_device(tag_no_list=[1,2], anchor_no_list=[0,1,2,3])
# locating the anchor using themself
anchor_pos_list = h.locate_anchor()
# print the located anchor pos
print(anchor_pos_list)
# start tag locating once
located_tag_pos = h.start_locate_once()
print('located_tag_pos:', located_tag_pos)
locating example 2:
from pyuwb import uwb
h=uwb()
h.connect(com_port="COM3") #set to None will auto-detect the port
# auto-detect the device nearby. if you don't know the device_no, you can use this instead of set_device
h.detect_device()
# set anchor position. you could use this instead of locate_anchor() if you know the anchor exact pos.
anchor_pos_list = [{'client_id': '1-2-0', 'pos': {'x': 0, 'y': 5.5, 'z': 0.5}},
{'client_id': '1-2-1', 'pos': {'x': 0, 'y': 0, 'z': 1.1}},
{'client_id': '1-2-2', 'pos': {'x': 2.67, 'y': -0.33, 'z': 0.5}},
{'client_id': '1-2-3', 'pos': {'x': 4.03, 'y': 5.47, 'z': 1.1},
}]
h.set_anchor_location(anchor_pos_list)
def function_to_call(tag_no,dist, pos):
# this function will be called everytime one tag is located successfully
print('function_to_call', tag_no,pos, dist)
# set callback
h.set_pos_callback(function_to_call)
# start and wait for 10-seconds
h.set_to_start()
t1=time.time()
while time.time()-t1<10:
h.locate_loop()
# stop the continuous measure
h.stop_measure_h()
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pyuwb-0.0.4.tar.gz
(29.5 kB
view details)
Built Distribution
pyuwb-0.0.4-py3-none-any.whl
(32.5 kB
view details)
File details
Details for the file pyuwb-0.0.4.tar.gz
.
File metadata
- Download URL: pyuwb-0.0.4.tar.gz
- Upload date:
- Size: 29.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d3d28a6459c7bc72fbdda22c86eb494ee83e17cecba1461129002942ed79ee23 |
|
MD5 | d66d39bf7ec23a0b2ef7f6bff678dcb9 |
|
BLAKE2b-256 | 2b7568c56cf6a9567d01dfc31752283c6e57e12da02826d8fb57b57c3217603d |
File details
Details for the file pyuwb-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: pyuwb-0.0.4-py3-none-any.whl
- Upload date:
- Size: 32.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c638ee45b7ea5011d6ea4562488a4c1b1e0a9e436ac29a79d1198416948ba411 |
|
MD5 | 1d6c6b52682e4192a95fa248cda97996 |
|
BLAKE2b-256 | ad6ca7bb55b13cc310d942e1b1c5d10b1675785a0e1be294adba74bd44bd65c5 |