A uwb locating library
Project description
pyuwb
python sdk for dw1000 uwb locating library.
how to install
pip install pyuwb
pyuwb-qt-demo:
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.5.tar.gz
(29.7 kB
view details)
Built Distribution
pyuwb-0.0.5-py3-none-any.whl
(32.5 kB
view details)
File details
Details for the file pyuwb-0.0.5.tar.gz
.
File metadata
- Download URL: pyuwb-0.0.5.tar.gz
- Upload date:
- Size: 29.7 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 | 9964f7a1bc34a246a8504dd6826d9021d4fddb45a6e9eebddfe9d73e8882b96a |
|
MD5 | 00e50749fc5196defc6b4a9bcc941962 |
|
BLAKE2b-256 | 7c7c5dba8030187a02e61bcee23478837141c5a870752202d10fb966c5b056d7 |
File details
Details for the file pyuwb-0.0.5-py3-none-any.whl
.
File metadata
- Download URL: pyuwb-0.0.5-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 | 4fd52d02037377eb08077159ef9f2ccc7234c9d7902961b61dcee0d32f3c0696 |
|
MD5 | 7d3b3a98b865a1b30b8bc73bd79ffb35 |
|
BLAKE2b-256 | aa886917310db3351906ba6ab79611f77ada9ba5ae618fef0834d9164c0e7ea4 |