From 8d5fe1f7f4b2b97d6f4ded2b287461a52b1e8d99 Mon Sep 17 00:00:00 2001 From: Gang Deng <13918383742@163.com> Date: Fri, 4 Dec 2020 10:18:23 +0800 Subject: [PATCH] 1.support new version numpy ref: https://stackoverflow.com/questions/55890813/how-to-fix-object-arrays-cannot-be-loaded-when-allow-pickle-false-for-imdb-loa 2. add databank to avoid take_pic.py report error --- data/facebank/.gitignore | 0 mtcnn_pytorch/src/get_nets.py | 41 +++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+) create mode 100644 data/facebank/.gitignore diff --git a/data/facebank/.gitignore b/data/facebank/.gitignore new file mode 100644 index 00000000..e69de29b diff --git a/mtcnn_pytorch/src/get_nets.py b/mtcnn_pytorch/src/get_nets.py index ebf7748d..35919ccb 100644 --- a/mtcnn_pytorch/src/get_nets.py +++ b/mtcnn_pytorch/src/get_nets.py @@ -4,6 +4,11 @@ from collections import OrderedDict import numpy as np +def get_np_version_number(): + ver_str = np.__version__ + ver_list = ver_str.split('.') + ver_num = int(ver_list[0]) * 10000 + int(ver_list[1])*100 + int(ver_list[2]) + return ver_num class Flatten(nn.Module): @@ -51,8 +56,19 @@ def __init__(self): self.conv4_1 = nn.Conv2d(32, 2, 1, 1) self.conv4_2 = nn.Conv2d(32, 4, 1, 1) + np_ver = get_np_version_number() + if np_ver >= 11602: # from np 1.16.2, allow_pickle default set to False + # save np.load + np_load_old = np.load + # modify the default parameters of np.load + np.load = lambda *a,**k: np_load_old(*a, allow_pickle=True, **k) weights = np.load('mtcnn_pytorch/src/weights/pnet.npy')[()] + + if np_ver >= 11602: # from np 1.16.2, allow_pickle default set to False + # restore np.load for future normal usage + np.load = np_load_old + for n, p in self.named_parameters(): p.data = torch.FloatTensor(weights[n]) @@ -96,8 +112,19 @@ def __init__(self): self.conv5_1 = nn.Linear(128, 2) self.conv5_2 = nn.Linear(128, 4) + np_ver = get_np_version_number() + if np_ver >= 11602: # from np 1.16.2, allow_pickle default set to False + # save np.load + np_load_old = np.load + # modify the default parameters of np.load + np.load = lambda *a,**k: np_load_old(*a, allow_pickle=True, **k) weights = np.load('mtcnn_pytorch/src/weights/rnet.npy')[()] + + if np_ver >= 11602: # from np 1.16.2, allow_pickle default set to False + # restore np.load for future normal usage + np.load = np_load_old + for n, p in self.named_parameters(): p.data = torch.FloatTensor(weights[n]) @@ -148,7 +175,21 @@ def __init__(self): self.conv6_2 = nn.Linear(256, 4) self.conv6_3 = nn.Linear(256, 10) + np_ver = get_np_version_number() + if np_ver >= 11602: # from np 1.16.2, allow_pickle default set to False + # save np.load + np_load_old = np.load + # modify the default parameters of np.load + np.load = lambda *a,**k: np_load_old(*a, allow_pickle=True, **k) + weights = np.load('mtcnn_pytorch/src/weights/onet.npy')[()] + + + if np_ver >= 11602: # from np 1.16.2, allow_pickle default set to False + # restore np.load for future normal usage + np.load = np_load_old + + for n, p in self.named_parameters(): p.data = torch.FloatTensor(weights[n])