######################################################################
-def generate(nb, height = 6, width = 8,
+def generate(nb, height, width,
max_nb_squares = 5, max_nb_properties = 10,
many_colors = False):
######################################################################
-def descr2img(descr, height = 6, width = 8):
+def descr2img(descr, height, width):
if type(descr) == list:
return torch.cat([ descr2img(d, height, width) for d in descr ], 0)
######################################################################
-def descr2properties(descr, height = 6, width = 8):
+def descr2properties(descr, height, width):
if type(descr) == list:
return [ descr2properties(d, height, width) for d in descr ]
######################################################################
+def nb_missing_properties(descr, height, width):
+ if type(descr) == list:
+ return [ nb_missing_properties(d, height, width) for d in descr ]
+
+ d = descr.split('<img>', 1)
+ if len(d) == 0: return 0
+ d = d[0].strip().split('<sep>')
+ d = [ x.strip() for x in d ]
+
+ requested_properties = set(d)
+ all_properties = set(descr2properties(descr, height, width))
+ missing_properties = requested_properties - all_properties
+
+ return (len(requested_properties), len(all_properties), len(missing_properties))
+
+######################################################################
+
if __name__ == '__main__':
descr = generate(nb = 5)
- print(descr2properties(descr))
+
+ #print(descr2properties(descr))
+ print(nb_missing_properties(descr))
with open('picoclvr_example.txt', 'w') as f:
for d in descr:
import time
start_time = time.perf_counter()
- descr = generate(10000)
+ descr = generate(nb = 1000)
end_time = time.perf_counter()
print(f'{len(descr) / (end_time - start_time):.02f} samples per second')