معرفی شرکت ها


PyLidar3-1.6


Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر

توضیحات

Library for Lidar. Currently supports YdLidar(X4,G4) from http://www.ydlidar.com
ویژگی مقدار
سیستم عامل OS Independent
نام فایل PyLidar3-1.6
نام PyLidar3
نسخه کتابخانه 1.6
نگهدارنده []
ایمیل نگهدارنده []
نویسنده Lakshman mallidi
ایمیل نویسنده lakshman.mallidi@gmail.com
آدرس صفحه اصلی https://github.com/lakshmanmallidi/PyLidar3
آدرس اینترنتی https://pypi.org/project/PyLidar3/
مجوز -
# PyLidar3 [![Build Status](https://travis-ci.org/joemccann/dillinger.svg?branch=master)](https://github.com/lakshmanmallidi/PyLidar3) [![license](https://img.shields.io/github/license/DAVFoundation/captain-n3m0.svg?style=flat-square)](https://github.com/lakshmanmallidi/PyLidar3/License) <br />PyLidar3 is python 3 package to get data from Lidar device. Currently supports ydlidar from [www.ydlidar.com/]([www.ydlidar.com/). ## Source code Source code is available on github's repository. <br /> [https://github.com/lakshmanmallidi/PyLidar3/blob/master/PyLidar3/\__init.py\_\_](https://github.com/lakshmanmallidi/PyLidar3/blob/master/PyLidar3/__init__.py) ## Dependencies * pyserial * time * math * enum ## Installation ##### Using Pip ``` pip install PyLidar3 ``` You can also install using setup.py file from git repository. ## Usage This package consists of multiple classes representing the version of lidar you are using. The class structure is YdLidarX4 where X4 is version name ydlidar. Further contribution are actively accepted. ##### Class structure: ###### YdLidarX4 `Arguments`: port, chunk_size(default:6000).<br/> `port`: serial port to which device is connected. Example: com4, /dev/ttyAMC0.<br/> `chunk_size`: Number of bytes of data read from device. Increase in chunk_size results in more averaged angle:distance pairs but increase response time result in slower data acquisition. For faster data acquisition decrease chunk_size.<br/> ``` Note: Calibrate chunk size depends on your application and frequency of device. if the chunk size is not enough not all angles are covered. ``` * `Connect` -- Begin serial connection with Lidar by opening serial port. Return success status True/False.<br /> * `StartScanning` -- Begin the lidar and returns a generator which returns a dictionary consisting angle(degrees) and distance(meters).<br /> `Return Format` : {angle(0):distance, angle(2):distance,....................,angle(359):distance}<br /> * `StopScanning` -- Stops scanning but keeps serial connection alive.<br /> * `GetHealthStatus` -- Returns True if Health of lidar is good else returns False<br /> * `GetDeviceInfo` -- Returns Information of Lidar version, serial number etc.<br /> * `Reset` -- Reboot the lidar <br /> * `Disconnect` -- Stop scanning and close serial communication with Lidar. <br /> ###### YdLidarG4 `Arguments`: port, chunk_size(default:6000).<br/> `port`: serial port to which device is connected. Example: com4, /dev/ttyAMC0.<br/> `chunk_size`: Number of bytes of data read from device. Increase in chunk_size results in more averaged angle:distance pairs but increase response time result in slower data acquisition. For faster data acquisition decrease chunk_size.<br/> ``` Note: Calibrate chunk size depends on your application and frequency of device. if the chunk size is not enough not all angles are covered. ``` * `Connect` -- Begin serial connection with Lidar by opening serial port. Return success status True/False.<br /> * `StartScanning` -- Begin the lidar and returns a generator which returns a dictionary consisting angle(degrees) and distance(meters).<br /> `Return Format` : {angle(0):distance, angle(2):distance,....................,angle(359):distance}<br /> * `StopScanning` -- Stops scanning but keeps serial connection alive.<br /> * `GetHealthStatus` -- Returns True if Health of lidar is good else returns False<br /> * `GetDeviceInfo` -- Returns Information of Lidar version, serial number etc.<br /> * `EnableLowPowerMode` -- Enable Low Power Consumption Mode(Turn motor and distance-measuring unit off in StopScanning).<br/> * `DisableLowPowerMode` -- Disable Low Power Consumption Mode(Turn motor and distance-measuring unit on StopScanning).<br/> * `GetLowPowerModeStatus` -- Return True if Low Power Consumption Mode is Enable else return False. <br/> ``` class FrequencyStep(Enum): oneTenthHertz=1 oneHertz=2 ``` * `IncreaseCurrentFrequency` -- Increase current frequency by oneTenth or one depends on enum FrequencyStep. <br/> * `DecreaseCurrentFrequency` -- Decrease current frequency by oneTenth or one depends on enum FrequencyStep. <br/> ``` import PyLidar3 port = input("Enter port name which lidar is connected:") #windows Obj = PyLidar3.YdLidarG4(port) if(Obj.Connect()): print(Obj.GetDeviceInfo()) print(Obj.GetCurrentFrequency()) Obj.IncreaseCurrentFrequency(PyLidar3.FrequencyStep.oneTenthHertz) print(Obj.GetCurrentFrequency()) Obj.DecreaseCurrentFrequency(PyLidar3.FrequencyStep.oneHertz) print(Obj.GetCurrentFrequency()) Obj.Disconnect() else: print("Error connecting to device") ``` * `EnableConstantFrequency` -- Enables constant frequency default Enable. * `DisableConstantFrequency` -- Disable constant frequency. * `SwitchRangingFrequency` -- Switch between ranging frequencies 4khz, 8khz and 9khz, default 9khz. * `GetCurrentRangingFrequency` -- Returns current Ranging Frequency in khz. * `Reset` -- Reboot the lidar <br /> * `Disconnect` -- Stop scanning and close serial communication with Lidar. <br /> ## Examples This Example prints data from lidar ``` import PyLidar3 import time # Time module #Serial port to which lidar connected, Get it from device manager windows #In linux type in terminal -- ls /dev/tty* port = input("Enter port name which lidar is connected:") #windows #port = "/dev/ttyUSB0" #linux Obj = PyLidar3.YdLidarX4(port) #PyLidar3.your_version_of_lidar(port,chunk_size) if(Obj.Connect()): print(Obj.GetDeviceInfo()) gen = Obj.StartScanning() t = time.time() # start time while (time.time() - t) < 30: #scan for 30 seconds print(next(gen)) time.sleep(0.5) Obj.StopScanning() Obj.Disconnect() else: print("Error connecting to device") ``` This Example plot the data. This example needs matplotlib library. ``` import threading import PyLidar3 import matplotlib.pyplot as plt import math import time def draw(): global is_plot while is_plot: plt.figure(1) plt.cla() plt.ylim(-9000,9000) plt.xlim(-9000,9000) plt.scatter(x,y,c='r',s=8) plt.pause(0.001) plt.close("all") is_plot = True x=[] y=[] for _ in range(360): x.append(0) y.append(0) port = input("Enter port name which lidar is connected:") #windows Obj = PyLidar3.YdLidarX4(port) #PyLidar3.your_version_of_lidar(port,chunk_size) threading.Thread(target=draw).start() if(Obj.Connect()): print(Obj.GetDeviceInfo()) gen = Obj.StartScanning() t = time.time() # start time while (time.time() - t) < 30: #scan for 30 seconds data = next(gen) for angle in range(0,360): if(data[angle]>1000): x[angle] = data[angle] * math.cos(math.radians(angle)) y[angle] = data[angle] * math.sin(math.radians(angle)) is_plot = False Obj.StopScanning() Obj.Disconnect() else: print("Error connecting to device") ``` ## Testing A "tesing" branch is maintained in the git repository for testing, debugging and updating the code. Please visit Github repo [https://github.com/lakshmanmallidi/PyLidar3](https://github.com/lakshmanmallidi/PyLidar3) for further information.


نیازمندی

مقدار نام
- pyserial


زبان مورد نیاز

مقدار نام
>=3.4 Python


نحوه نصب


نصب پکیج whl PyLidar3-1.6:

    pip install PyLidar3-1.6.whl


نصب پکیج tar.gz PyLidar3-1.6:

    pip install PyLidar3-1.6.tar.gz