libdet.axera / lib /example.py
zheqiushui's picture
Upload 17 files
1634b64 verified
import os
from pydet import AXDet, ModelType
from pyaxdev import enum_devices, sys_init, sys_deinit, AxDeviceType
import cv2
import glob
import argparse
import tqdm
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--model', type=str)
parser.add_argument('--model_type', type=int)
parser.add_argument('--image', type=str)
parser.add_argument('--threshold', type=float, default=0.25)
parser.add_argument('--num_classes', type=int, default=80)
parser.add_argument('--num_kpt', type=int, default=0)
parser.add_argument('--output', type=str, default='results.jpg')
args = parser.parse_args()
# 枚举设备
dev_type = AxDeviceType.unknown_device
dev_id = -1
devices_info = enum_devices()
print("可用设备:", devices_info)
if devices_info['host']['available']:
print("host device available")
sys_init(AxDeviceType.host_device, -1)
dev_type = AxDeviceType.host_device
dev_id = -1
elif devices_info['devices']['count'] > 0:
print("axcl device available, use device-0")
sys_init(AxDeviceType.axcl_device, 0)
dev_type = AxDeviceType.axcl_device
dev_id = 0
else:
raise Exception("No available device")
det = AXDet(
model_path=args.model,
model_type=args.model_type,
threshold=args.threshold,
num_classes=args.num_classes,
num_kpt=args.num_kpt,
dev_type=dev_type,
devid=dev_id,
)
# 加载图像
img = cv2.imread(args.image)
img_infer = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
# 推理
results = det.detect(img_infer)
for obj in results:
box = obj.box
score = obj.score
label = obj.label
kpts = obj.kpts
cv2.rectangle(img, box, (0, 255, 0), 2)
cv2.putText(img, f"{label}: {score:.2f}", (int(box[0]), int(box[1])-5), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2)
if args.num_kpt > 0:
for i in range(args.num_kpt):
cv2.circle(img, kpts[i], 5, (0, 0, 255), -1)
cv2.imwrite(args.output, img)
del det
if devices_info['host']['available']:
sys_deinit(AxDeviceType.host_device, -1)
elif devices_info['devices']['count'] > 0:
sys_deinit(AxDeviceType.axcl_device, 0)