-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathgenerate_descriptors.py
65 lines (58 loc) · 2.24 KB
/
generate_descriptors.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#%%
import openai
import json
import pathlib
import numpy as np
import time
openai.api_key = 'your_key'
#%% Example Description Generation for FGVCAircraft
from torchvision.datasets import FGVCAircraft
AIRCRAFT_DIR = 'your_path/fgvcaircraft'
data_dir = pathlib.Path(AIRCRAFT_DIR)
dataset = FGVCAircraft(data_dir, split='test', annotation_level='family', download=True)
classnames = dataset.classes
#%% Generate Prompts.
def generate_prompt(category_name: str):
# you can replace the examples with whatever you want; these were random and worked, could be improved
return f"""Q: What are useful visual features for distinguishing a lemur in a photo?
A: There are several useful visual features to tell there is a lemur in a photo:
- four-limbed primate
- black, grey, white, brown, or red-brown
- wet and hairless nose with curved nostrils
- long tail
- large eyes
- furry bodies
- clawed hands and feet
Q: What are useful visual features for distinguishing a television in a photo?
A: There are several useful visual features to tell there is a television in a photo:
- electronic device
- black or grey
- a large, rectangular screen
- a stand or mount to support the screen
- one or more speakers
- a power cord
- input ports for connecting to other devices
- a remote control
Q: What are useful features for distinguishing a {category_name} in a photo?
A: There are several useful visual features to tell there is a {category_name} in a photo:
-
"""
prompts = [generate_prompt(_c) for _c in classnames]
#%% Query GPT-3.
def stringtolist(description):
return [descriptor[2:] for descriptor in description.split('\n') if (descriptor != '') and (descriptor.startswith('- '))]
descriptions = []
for i in np.arange(0, len(prompts), 20):
st = time.time()
response = openai.Completion.create(
model="text-davinci-003",
prompt=prompts[i:i + 20],
temperature=0.7,
max_tokens=100,
)
print(i, ":", time.time() - st)
descriptions += [stringtolist(_r["text"]) for _r in response["choices"]]
#%% Write generated descriptions to JSON.
descriptions_dict = {_c: _d for _c, _d in zip(dataset.classes, descriptions)}
with open('descriptors/placeholder_name.json', 'w') as outfile:
outfile.write(json.dumps(descriptions_dict, indent=4))