Skip to main content

A uwb locating library

Project description

pyuwb

python sdk for dw1000 uwb locating library.

how to install

pip install pyuwb

pyuwb-qt-demo:

avatar

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:  2--anchorz(connect to computer). 1--normal anchor. 0 --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-0-1', '1-1-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-1-0', 'pos': {'x': 0, 'y': 5.5, 'z': 0.5}},
                       {'client_id': '1-1-1', 'pos': {'x': 0, 'y': 0, 'z': 1.1}},
                       {'client_id': '1-1-2', 'pos': {'x': 2.67, 'y': -0.33, 'z': 0.5}},
                       {'client_id': '1-1-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()

detail-api

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.6.tar.gz (30.7 kB view details)

Uploaded Source

Built Distribution

pyuwb-0.0.6-py3-none-any.whl (33.5 kB view details)

Uploaded Python 3

File details

Details for the file pyuwb-0.0.6.tar.gz.

File metadata

  • Download URL: pyuwb-0.0.6.tar.gz
  • Upload date:
  • Size: 30.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

Hashes for pyuwb-0.0.6.tar.gz
Algorithm Hash digest
SHA256 abbf71c3cf9a30482c139849f5f022f7f52a6d77b4a641622da6bfd6afb2431c
MD5 47b1027c2cc8520ade243408783dbded
BLAKE2b-256 7fc5b342f510044af1b4f22fd31ec22b98e14db9752aff8997c12d79b764b24f

See more details on using hashes here.

File details

Details for the file pyuwb-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: pyuwb-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 33.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

Hashes for pyuwb-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f98540c6192e81f3f399f57509937ec53b4280cffd895f6f73b865e7b5c06082
MD5 a87d9a90bb54ff33eb2d57c4b65e2f60
BLAKE2b-256 2c3d079ecc94c20e52b06686ac0a41ff2a3d99faf784b2a89878bff4873ab685

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page