46 lines
1.9 KiB
Python
46 lines
1.9 KiB
Python
|
|
from DMPRUtils.DMPR_process import DMPR_process
|
|||
|
|
import tensorrt as trt
|
|||
|
|
import sys,os
|
|||
|
|
#from DMPRUtils.model.detector import DirectionalPointDetector
|
|||
|
|
from DMPRUtils.yolo_net import Model
|
|||
|
|
import torch
|
|||
|
|
|
|||
|
|
class DMPRModel(object):
|
|||
|
|
def __init__(self, weights=None,
|
|||
|
|
par={'depth_factor':32,'NUM_FEATURE_MAP_CHANNEL':6,'dmpr_thresh':0.3, 'dmprimg_size':640}
|
|||
|
|
):
|
|||
|
|
|
|||
|
|
self.par = par
|
|||
|
|
self.device = 'cuda:0'
|
|||
|
|
self.half =True
|
|||
|
|
|
|||
|
|
if weights.endswith('.engine'):
|
|||
|
|
self.infer_type ='trt'
|
|||
|
|
elif weights.endswith('.pth') or weights.endswith('.pt') :
|
|||
|
|
self.infer_type ='pth'
|
|||
|
|
else:
|
|||
|
|
print('#########ERROR:',weights,': no registered inference type, exit')
|
|||
|
|
sys.exit(0)
|
|||
|
|
|
|||
|
|
if self.infer_type=='trt':
|
|||
|
|
logger = trt.Logger(trt.Logger.ERROR)
|
|||
|
|
with open(weights, "rb") as f, trt.Runtime(logger) as runtime:
|
|||
|
|
self.model=runtime.deserialize_cuda_engine(f.read())# 输入trt本地文件,返回ICudaEngine对象
|
|||
|
|
elif self.infer_type=='pth':
|
|||
|
|
#self.model = DirectionalPointDetector(3, self.par['depth_factor'], self.par['NUM_FEATURE_MAP_CHANNEL']).to(self.device)
|
|||
|
|
confUrl = os.path.join( os.path.dirname(__file__),'DMPRUtils','config','yolov5s.yaml' )
|
|||
|
|
self.model = Model(confUrl, ch=3).to(self.device)
|
|||
|
|
self.model.load_state_dict(torch.load(weights))
|
|||
|
|
print('#######load pt model:%s success '%(weights))
|
|||
|
|
self.par['modelType']=self.infer_type
|
|||
|
|
print('#########加载模型:',weights,' 类型:',self.infer_type)
|
|||
|
|
def eval(self,image):
|
|||
|
|
det,timeInfos = DMPR_process(image, self.model, self.device, self.par)
|
|||
|
|
det = det.cpu().detach().numpy()
|
|||
|
|
return det,timeInfos
|
|||
|
|
|
|||
|
|
def get_ms(self,t1,t0):
|
|||
|
|
return (t1-t0)*1000.0
|
|||
|
|
|
|||
|
|
|