Limelight Lib Python
limelightlib-python היא הדרך הקלה ביותר לממשק עם מכשירי Limelight. היא עובדת בכל מערכות ההפעלה (MacOS, Windows, Linux) וארכיטקטורות (x86, ARM).
- https://github.com/LimelightVision/limelightlib-python
- https://pypi.org/project/limelightlib-python/
התקנה
pip install limelightlib-python
שימוש
import limelight
import limelightresults
import json
import time
discovered_limelights = limelight.discover_limelights(debug=True)
print("discovered limelights:", discovered_limelights)
if discovered_limelights:
    limelight_address = discovered_limelights[0] 
    ll = limelight.Limelight(limelight_address)
    results = ll.get_results()
    status = ll.get_status()
    print("-----")
    print("targeting results:", results)
    print("-----")
    print("status:", status)
    print("-----")
    print("temp:", ll.get_temp())
    print("-----")
    print("name:", ll.get_name())
    print("-----")
    print("fps:", ll.get_fps())
    print("-----")
    print("hwreport:", ll.hw_report())
    ll.enable_websocket()
   
    # print the current pipeline settings
    print(ll.get_pipeline_atindex(0))
    # update the current pipeline and flush to disk
    pipeline_update = {
    'area_max': 98.7,
    'area_min': 1.98778
    }
    ll.update_pipeline(json.dumps(pipeline_update),flush=1)
    print(ll.get_pipeline_atindex(0))
    # switch to pipeline 1
    ll.pipeline_switch(1)
    # update custom user data
    ll.update_python_inputs([4.2,0.1,9.87])
    
    
    try:
        while True:
            result = ll.get_latest_results()
            parsed_result = limelightresults.parse_results(result)
            if parsed_result is not None:
                print("valid targets: ", parsed_result.validity, ", pipelineIndex: ", parsed_result.pipeline_id,", Targeting Latency: ", parsed_result.targeting_latency)
                #for tag in parsed_result.fiducialResults:
                #    print(tag.robot_pose_target_space, tag.fiducial_id)
            time.sleep(1)  # Set this to 0 for max fps
    except KeyboardInterrupt:
        print("Program interrupted by user, shutting down.")
    finally:
        ll.disable_websocket()
                
שיטות
מבוססות REST
- get_results(): מביא את התוצאות האחרונות באמצעות HTTP GET.
- capture_snapshot(snapname): לוכד תמונה עם שם נתון.
- upload_snapshot(snapname, image_path): מעלה תמונה עם שם נתון וקובץ תמונה.
- snapshot_manifest(): מאחזר את מניפסט התמונות באמצעות HTTP GET.
- delete_snapshots(): מוחק את כל התמונות באמצעות HTTP GET.
- upload_neural_network(nn_type, file_path): מעלה קובץ רשת נוירונית עם סוג מוגדר.
- hw_report(): מביא דוח חומרה באמצעות HTTP GET.
- cal_default(): מביא נתוני כיול ברירת מחדל באמצעות HTTP GET.
- cal_file(): מביא נתוני כיול מקובץ באמצעות HTTP GET.
- cal_eeprom(): מביא נתוני כיול מ-EEPROM באמצעות HTTP GET.
- cal_latest(): מביא את נתוני הכיול האחרונים באמצעות HTTP GET.
- update_cal_eeprom(cal_data): מעדכן נתוני כיול ב-EEPROM באמצעות HTTP POST.
- update_cal_file(cal_data): מעדכן נתוני כיול בקובץ באמצעות HTTP POST.
- delete_cal_latest(): מוחק את נתוני הכיול האחרונים באמצעות HTTP DELETE.
- delete_cal_eeprom(): מוחק נתוני כיול מ-EEPROM באמצעות HTTP DELETE.
- delete_cal_file(): מוחק נתוני כיול מקובץ באמצעות HTTP DELETE.
מבוססות Websocket
- enable_websocket(): מאתחל ומפעיל חיבור WebSocket בתהליכון נפרד.
- disable_websocket(): סוגר את חיבור ה-WebSocket ומצרף את התהליכון.
- get_latest_results(): מחזיר את התוצאות האחרונות שהתקבלו מה-WebSocket.
ניתוח
- limelightresults.parse_results(): מנתח תוצאות ומחזיר אובייקט GeneralResult
מפרט מחלקת תוצאות
class GeneralResult:
    def __init__(self, results):
        self.barcode = results.get("Barcode", [])
        self.classifierResults = [ClassifierResult(item) for item in results.get("Classifier", [])]
        self.detectorResults = [DetectorResult(item) for item in results.get("Detector", [])]
        self.fiducialResults = [FiducialResult(item) for item in results.get("Fiducial", [])]
        self.retroResults = [RetroreflectiveResult(item) for item in results.get("Retro", [])]
        self.botpose = results.get("botpose", [])
        self.botpose_wpiblue = results.get("botpose_wpiblue", [])
        self.botpose_wpired = results.get("botpose_wpired", [])
        self.capture_latency = results.get("cl", 0)
        self.pipeline_id = results.get("pID", 0)
        self.robot_pose_target_space = results.get("t6c_rs", [])
        self.targeting_latency = results.get("tl", 0)
        self.timestamp = results.get("ts", 0)
        self.validity = results.get("v", 0)
        self.parse_latency = 0.0
class RetroreflectiveResult:
    def __init__(self, retro_data):
        self.points = retro_data["pts"]
        self.camera_pose_target_space = retro_data["t6c_ts"]
        self.robot_pose_field_space = retro_data["t6r_fs"]
        self.robot_pose_target_space = retro_data["t6r_ts"]
        self.target_pose_camera_space = retro_data["t6t_cs"]
        self.target_pose_robot_space = retro_data["t6t_rs"]
        self.target_area = retro_data["ta"]
        self.target_x_degrees = retro_data["tx"]
        self.target_x_pixels = retro_data["txp"]
        self.target_y_degrees = retro_data["ty"]
        self.target_y_pixels = retro_data["typ"]
class FiducialResult:
    def __init__(self, fiducial_data):
        self.fiducial_id = fiducial_data["fID"]
        self.family = fiducial_data["fam"]
        self.points = fiducial_data["pts"]
        self.skew = fiducial_data["skew"]
        self.camera_pose_target_space = fiducial_data["t6c_ts"]
        self.robot_pose_field_space = fiducial_data["t6r_fs"]
        self.robot_pose_target_space = fiducial_data["t6r_ts"]
        self.target_pose_camera_space = fiducial_data["t6t_cs"]
        self.target_pose_robot_space = fiducial_data["t6t_rs"]
        self.target_area = fiducial_data["ta"]
        self.target_x_degrees = fiducial_data["tx"]
        self.target_x_pixels = fiducial_data["txp"]
        self.target_y_degrees = fiducial_data["ty"]
        self.target_y_pixels = fiducial_data["typ"]
class DetectorResult:
    def __init__(self, detector_data):
        self.class_name = detector_data["class"]
        self.class_id = detector_data["classID"]
        self.confidence = detector_data["conf"]
        self.points = detector_data["pts"]
        self.target_area = detector_data["ta"]
        self.target_x_degrees = detector_data["tx"]
        self.target_x_pixels = detector_data["txp"]
        self.target_y_degrees = detector_data["ty"]
        self.target_y_pixels = detector_data["typ"]
class ClassifierResult:
    def __init__(self, classifier_data):
        self.class_name = classifier_data["class"]
        self.class_id = classifier_data["classID"]
        self.confidence = classifier_data["conf"]