isLinXu commited on
Commit
a04b3a3
1 Parent(s): e59c7d4
Files changed (2) hide show
  1. app.py +316 -0
  2. requirements.txt +20 -0
app.py ADDED
@@ -0,0 +1,316 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import os
2
+ os.system("pip install timm~=0.9.2")
3
+
4
+ import gradio as gr
5
+ import timm
6
+ import torch
7
+ import torchvision.transforms as T
8
+ from PIL import Image, ImageDraw, ImageFont
9
+ import warnings
10
+
11
+ warnings.filterwarnings("ignore")
12
+
13
+ # 获取 ImageNet 类别列表
14
+ imagenet_classes = ['0, tench', '1, goldfish', '2, great_white_shark', '3, tiger_shark', '4, hammerhead',
15
+ '5, electric_ray', '6, stingray',
16
+ '7, cock', '8, hen', '9, ostrich', '10, brambling', '11, goldfinch', '12, house_finch', '13, junco',
17
+ '14, indigo_bunting',
18
+ '15, robin', '16, bulbul', '17, jay', '18, magpie', '19, chickadee', '20, water_ouzel', '21, kite',
19
+ '22, bald_eagle',
20
+ '23, vulture', '24, great_grey_owl', '25, European_fire_salamander', '26, common_newt', '27, eft',
21
+ '28, spotted_salamander',
22
+ '29, axolotl', '30, bullfrog', '31, tree_frog', '32, tailed_frog', '33, loggerhead',
23
+ '34, leatherback_turtle', '35, mud_turtle',
24
+ '36, terrapin', '37, box_turtle', '38, banded_gecko', '39, common_iguana', '40, American_chameleon',
25
+ '41, whiptail',
26
+ '42, agama', '43, frilled_lizard', '44, alligator_lizard', '45, Gila_monster', '46, green_lizard',
27
+ '47, African_chameleon',
28
+ '48, Komodo_dragon', '49, African_crocodile', '50, American_alligator', '51, triceratops',
29
+ '52, thunder_snake', '53, ringneck_snake',
30
+ '54, hognose_snake', '55, green_snake', '56, king_snake', '57, garter_snake', '58, water_snake',
31
+ '59, vine_snake', '60, night_snake', '61, boa_constrictor', '62, rock_python', '63, Indian_cobra',
32
+ '64, green_mamba', '65, sea_snake',
33
+ '66, horned_viper', '67, diamondback', '68, sidewinder', '69, trilobite', '70, harvestman',
34
+ '71, scorpion',
35
+ '72, black_and_gold_garden_spider', '73, barn_spider', '74, garden_spider', '75, black_widow',
36
+ '76, tarantula',
37
+ '77, wolf_spider', '78, tick', '79, centipede', '80, black_grouse',
38
+ '81, ptarmigan', '82, ruffed_grouse', '83, prairie_chicken', '84, peacock', '85, quail',
39
+ '86, partridge', '87, African_grey',
40
+ '88, macaw', '89, sulphur-crested_cockatoo', '90, lorikeet', '91, coucal', '92, bee_eater',
41
+ '93, hornbill', '94, hummingbird', '95, jacamar', '96, toucan', '97, drake',
42
+ '98, red-breasted_merganser', '99, goose', '100, black_swan', '101, tusker', '102, echidna',
43
+ '103, platypus', '104, wallaby', '105, koala', '106, wombat', '107, jellyfish', '108, sea_anemone',
44
+ '109, brain_coral', '110, flatworm', '111, nematode', '112, conch', '113, snail', '114, slug',
45
+ '115, sea_slug', '116, chiton', '117, chambered_nautilus', '118, Dungeness_crab', '119, rock_crab',
46
+ '120, fiddler_crab', '121, king_crab', '122, American_lobster', '123, spiny_lobster',
47
+ '124, crayfish', '125, hermit_crab', '126, isopod', '127, white_stork', '128, black_stork',
48
+ '129, spoonbill', '130, flamingo', '131, little_blue_heron', '132, American_egret', '133, bittern',
49
+ '134, crane', '135, limpkin', '136, European_gallinule', '137, American_coot', '138, bustard',
50
+ '139, ruddy_turnstone', '140, red-backed_sandpiper', '141, redshank', '142, dowitcher',
51
+ '143, oystercatcher', '144, pelican', '145, king_penguin', '146, albatross', '147, grey_whale',
52
+ '148, killer_whale', '149, dugong', '150, sea_lion', '151, Chihuahua', '152, Japanese_spaniel',
53
+ '153, Maltese_dog', '154, Pekinese', '155, Shih-Tzu', '156, Blenheim_spaniel', '157, papillon',
54
+ '158, toy_terrier', '159, Rhodesian_ridgeback', '160, Afghan_hound', '161, basset', '162, beagle',
55
+ '163, bloodhound', '164, bluetick', '165, black-and-tan_coonhound', '166, Walker_hound',
56
+ '167, English_foxhound', '168, redbone', '169, borzoi', '170, Irish_wolfhound',
57
+ '171, Italian_greyhound', '172, whippet', '173, Ibizan_hound', '174, Norwegian_elkhound',
58
+ '175, otterhound', '176, Saluki', '177, Scottish_deerhound', '178, Weimaraner',
59
+ '179, Staffordshire_bullterrier', '180, American_Staffordshire_terrier', '181, Bedlington_terrier',
60
+ '182, Border_terrier', '183, Kerry_blue_terrier', '184, Irish_terrier', '185, Norfolk_terrier',
61
+ '186, Norwich_terrier', '187, Yorkshire_terrier', '188, wire-haired_fox_terrier',
62
+ '189, Lakeland_terrier', '190, Sealyham_terrier', '191, Airedale', '192, cairn',
63
+ '193, Australian_terrier', '194, Dandie_Dinmont', '195, Boston_bull', '196, miniature_schnauzer',
64
+ '197, giant_schnauzer', '198, standard_schnauzer', '199, Scotch_terrier', '200, Tibetan_terrier',
65
+ '201, silky_terrier', '202, soft-coated_wheaten_terrier', '203, West_Highland_white_terrier',
66
+ '204, Lhasa', '205, flat-coated_retriever', '206, curly-coated_retriever', '207, golden_retriever',
67
+ '208, Labrador_retriever', '209, Chesapeake_Bay_retriever', '210, German_short-haired_pointer',
68
+ '211, vizsla', '212, English_setter', '213, Irish_setter', '214, Gordon_setter',
69
+ '215, Brittany_spaniel', '216, clumber', '217, English_springer', '218, Welsh_springer_spaniel',
70
+ '219, cocker_spaniel', '220, Sussex_spaniel', '221, Irish_water_spaniel', '222, kuvasz',
71
+ '223, schipperke', '224, groenendael', '225, malinois', '226, briard', '227, kelpie',
72
+ '228, komondor', '229, Old_English_sheepdog', '230, Shetland_sheepdog', '231, collie',
73
+ '232, Border_collie', '233, Bouvier_des_Flandres', '234, Rottweiler', '235, German_shepherd',
74
+ '236, Doberman', '237, miniature_pinscher', '238, Greater_Swiss_Mountain_dog',
75
+ '239, Bernese_mountain_dog', '240, Appenzeller', '241, EntleBucher', '242, boxer',
76
+ '243, bull_mastiff', '244, Tibetan_mastiff', '245, French_bulldog', '246, Great_Dane',
77
+ '247, Saint_Bernard', '248, Eskimo_dog', '249, malamute', '250, Siberian_husky', '251, dalmatian',
78
+ '252, affenpinscher', '253, basenji', '254, pug', '255, Leonberg', '256, Newfoundland',
79
+ '257, Great_Pyrenees', '258, Samoyed', '259, Pomeranian', '260, chow', '261, keeshond',
80
+ '262, Brabancon_griffon', '263, Pembroke', '264, Cardigan', '265, toy_poodle',
81
+ '266, miniature_poodle', '267, standard_poodle', '268, Mexican_hairless', '269, timber_wolf',
82
+ '270, white_wolf', '271, red_wolf', '272, coyote', '273, dingo', '274, dhole',
83
+ '275, African_hunting_dog', '276, hyena', '277, red_fox', '278, kit_fox', '279, Arctic_fox',
84
+ '280, grey_fox', '281, tabby', '282, tiger_cat', '283, Persian_cat', '284, Siamese_cat',
85
+ '285, Egyptian_cat', '286, cougar', '287, lynx', '288, leopard', '289, snow_leopard', '290, jaguar',
86
+ '291, lion', '292, tiger', '293, cheetah', '294, brown_bear', '295, American_black_bear',
87
+ '296, ice_bear', '297, sloth_bear', '298, mongoose', '299, meerkat', '300, tiger_beetle',
88
+ '301, ladybug', '302, ground_beetle', '303, long-horned_beetle', '304, leaf_beetle',
89
+ '305, dung_beetle', '306, rhinoceros_beetle', '307, weevil', '308, fly', '309, bee', '310, ant',
90
+ '311, grasshopper', '312, cricket', '313, walking_stick', '314, cockroach', '315, mantis',
91
+ '316, cicada', '317, leafhopper', '318, lacewing', '319, dragonfly', '320, damselfly',
92
+ '321, admiral', '322, ringlet', '323, monarch', '324, cabbage_butterfly', '325, sulphur_butterfly',
93
+ '326, lycaenid', '327, starfish', '328, sea_urchin', '329, sea_cucumber', '330, wood_rabbit',
94
+ '331, hare', '332, Angora', '333, hamster', '334, porcupine', '335, fox_squirrel', '336, marmot',
95
+ '337, beaver', '338, guinea_pig', '339, sorrel', '340, zebra', '341, hog', '342, wild_boar',
96
+ '343, warthog', '344, hippopotamus', '345, ox', '346, water_buffalo', '347, bison', '348, ram',
97
+ '349, bighorn', '350, ibex', '351, hartebeest', '352, impala', '353, gazelle', '354, Arabian_camel',
98
+ '355, llama', '356, weasel', '357, mink', '358, polecat', '359, black-footed_ferret', '360, otter',
99
+ '361, skunk', '362, badger', '363, armadillo', '364, three-toed_sloth', '365, orangutan',
100
+ '366, gorilla', '367, chimpanzee', '368, gibbon', '369, siamang', '370, guenon', '371, patas',
101
+ '372, baboon', '373, macaque', '374, langur', '375, colobus', '376, proboscis_monkey',
102
+ '377, marmoset', '378, capuchin', '379, howler_monkey', '380, titi', '381, spider_monkey',
103
+ '382, squirrel_monkey', '383, Madagascar_cat', '384, indri', '385, Indian_elephant',
104
+ '386, African_elephant', '387, lesser_panda', '388, giant_panda', '389, barracouta', '390, eel',
105
+ '391, coho', '392, rock_beauty', '393, anemone_fish', '394, sturgeon', '395, gar', '396, lionfish',
106
+ '397, puffer', '398, abacus', '399, abaya', '400, academic_gown', '401, accordion',
107
+ '402, acoustic_guitar', '403, aircraft_carrier', '404, airliner', '405, airship', '406, altar',
108
+ '407, ambulance', '408, amphibian', '409, analog_clock', '410, apiary', '411, apron', '412, ashcan',
109
+ '413, assault_rifle', '414, backpack', '415, bakery', '416, balance_beam', '417, balloon',
110
+ '418, ballpoint', '419, Band_Aid', '420, banjo', '421, bannister', '422, barbell',
111
+ '423, barber_chair', '424, barbershop', '425, barn', '426, barometer', '427, barrel', '428, barrow',
112
+ '429, baseball', '430, basketball', '431, bassinet', '432, bassoon', '433, bathing_cap',
113
+ '434, bath_towel', '435, bathtub', '436, beach_wagon', '437, beacon', '438, beaker',
114
+ '439, bearskin',
115
+ '440, beer_bottle', '441, beer_glass', '442, bell_cote', '443, bib', '444, bicycle-built-for-two',
116
+ '445, bikini', '446, binder', '447, binoculars', '448, birdhouse', '449, boathouse', '450, bobsled',
117
+ '451, bolo_tie', '452, bonnet', '453, bookcase', '454, bookshop', '455, bottlecap', '456, bow',
118
+ '457, bow_tie', '458, brass', '459, brassiere', '460, breakwater', '461, breastplate', '462, broom',
119
+ '463, bucket', '464, buckle', '465, bulletproof_vest', '466, bullet_train', '467, butcher_shop',
120
+ '468, cab', '469, caldron', '470, candle', '471, cannon', '472, canoe', '473, can_opener',
121
+ '474, cardigan', '475, car_mirror', '476, carousel', "477, carpenter's_kit", '478, carton',
122
+ '479, car_wheel', '480, cash_machine', '481, cassette', '482, cassette_player', '483, castle',
123
+ '484, catamaran', '485, CD_player', '486, cello', '487, cellular_telephone', '488, chain',
124
+ '489, chainlink_fence', '490, chain_mail', '491, chain_saw', '492, chest', '493, chiffonier',
125
+ '494, chime', '495, china_cabinet', '496, Christmas_stocking', '497, church', '498, cinema',
126
+ '499, cleaver', '500, cliff_dwelling', '501, cloak', '502, clog', '503, cocktail_shaker',
127
+ '504, coffee_mug', '505, coffeepot', '506, coil', '507, combination_lock', '508, computer_keyboard',
128
+ '509, confectionery', '510, container_ship', '511, convertible', '512, corkscrew', '513, cornet',
129
+ '514, cowboy_boot', '515, cowboy_hat', '516, cradle', '517, crane', '518, crash_helmet',
130
+ '519, crate', '520, crib', '521, Crock_Pot', '522, croquet_ball', '523, crutch', '524, cuirass',
131
+ '525, dam', '526, desk', '527, desktop_computer', '528, dial_telephone', '529, diaper',
132
+ '530, digital_clock', '531, digital_watch', '532, dining_table', '533, dishrag', '534, dishwasher',
133
+ '535, disk_brake', '536, dock', '537, dogsled', '538, dome', '539, doormat',
134
+ '540, drilling_platform', '541, drum', '542, drumstick', '543, dumbbell', '544, Dutch_oven',
135
+ '545, electric_fan', '546, electric_guitar', '547, electric_locomotive',
136
+ '548, entertainment_center',
137
+ '549, envelope', '550, espresso_maker', '551, face_powder', '552, feather_boa', '553, file',
138
+ '554, fireboat', '555, fire_engine', '556, fire_screen', '557, flagpole', '558, flute',
139
+ '559, folding_chair', '560, football_helmet', '561, forklift', '562, fountain', '563, fountain_pen',
140
+ '564, four-poster', '565, freight_car', '566, French_horn', '567, frying_pan', '568, fur_coat',
141
+ '569, garbage_truck', '570, gasmask', '571, gas_pump', '572, goblet', '573, go-kart',
142
+ '574, golf_ball', '575, golfcart', '576, gondola', '577, gong', '578, gown', '579, grand_piano',
143
+ '580, greenhouse', '581, grille', '582, grocery_store', '583, guillotine', '584, hair_slide',
144
+ '585, hair_spray', '586, half_track', '587, hammer', '588, hamper', '589, hand_blower',
145
+ '590, hand-held_computer', '591, handkerchief', '592, hard_disc', '593, harmonica', '594, harp',
146
+ '595, harvester', '596, hatchet', '597, holster', '598, home_theater', '599, honeycomb',
147
+ '600, hook',
148
+ '601, hoopskirt', '602, horizontal_bar', '603, horse_cart', '604, hourglass', '605, iPod',
149
+ '606, iron', "607, jack-o'-lantern", '608, jean', '609, jeep', '610, jersey', '611, jigsaw_puzzle',
150
+ '612, jinrikisha', '613, joystick', '614, kimono', '615, knee_pad', '616, knot', '617, lab_coat',
151
+ '618, ladle', '619, lampshade', '620, laptop', '621, lawn_mower', '622, lens_cap',
152
+ '623, letter_opener', '624, library', '625, lifeboat', '626, lighter', '627, limousine',
153
+ '628, liner', '629, lipstick', '630, Loafer', '631, lotion', '632, loudspeaker', '633, loupe',
154
+ '634, lumbermill', '635, magnetic_compass', '636, mailbag', '637, mailbox', '638, maillot',
155
+ '639, maillot', '640, manhole_cover', '641, maraca', '642, marimba', '643, mask', '644, matchstick',
156
+ '645, maypole', '646, maze', '647, measuring_cup', '648, medicine_chest', '649, megalith',
157
+ '650, microphone', '651, microwave', '652, military_uniform', '653, milk_can', '654, minibus',
158
+ '655, miniskirt', '656, minivan', '657, missile', '658, mitten', '659, mixing_bowl',
159
+ '660, mobile_home', '661, Model_T', '662, modem', '663, monastery', '664, monitor', '665, moped',
160
+ '666, mortar', '667, mortarboard', '668, mosque', '669, mosquito_net', '670, motor_scooter',
161
+ '671, mountain_bike', '672, mountain_tent', '673, mouse', '674, mousetrap', '675, moving_van',
162
+ '676, muzzle', '677, nail', '678, neck_brace', '679, necklace', '680, nipple', '681, notebook',
163
+ '682, obelisk', '683, oboe', '684, ocarina', '685, odometer', '686, oil_filter', '687, organ',
164
+ '688, oscilloscope', '689, overskirt', '690, oxcart', '691, oxygen_mask', '692, packet',
165
+ '693, paddle', '694, paddlewheel', '695, padlock', '696, paintbrush', '697, pajama', '698, palace',
166
+ '699, panpipe', '700, paper_towel', '701, parachute', '702, parallel_bars', '703, park_bench',
167
+ '704, parking_meter', '705, passenger_car', '706, patio', '707, pay-phone', '708, pedestal',
168
+ '709, pencil_box', '710, pencil_sharpener', '711, perfume', '712, Petri_dish', '713, photocopier',
169
+ '714, pick', '715, pickelhaube', '716, picket_fence', '717, pickup', '718, pier', '719, piggy_bank',
170
+ '720, pill_bottle', '721, pillow', '722, ping-pong_ball', '723, pinwheel', '724, pirate',
171
+ '725, pitcher', '726, plane', '727, planetarium', '728, plastic_bag', '729, plate_rack',
172
+ '730, plow',
173
+ '731, plunger', '732, Polaroid_camera', '733, pole', '734, police_van', '735, poncho',
174
+ '736, pool_table', '737, pop_bottle', '738, pot', "739, potter's_wheel", '740, power_drill',
175
+ '741, prayer_rug', '742, printer', '743, prison', '744, projectile', '745, projector', '746, puck',
176
+ '747, punching_bag', '748, purse', '749, quill', '750, quilt', '751, racer', '752, racket',
177
+ '753, radiator', '754, radio', '755, radio_telescope', '756, rain_barrel',
178
+ '757, recreational_vehicle', '758, reel', '759, reflex_camera', '760, refrigerator',
179
+ '761, remote_control', '762, restaurant', '763, revolver', '764, rifle', '765, rocking_chair',
180
+ '766, rotisserie', '767, rubber_eraser', '768, rugby_ball', '769, rule', '770, running_shoe',
181
+ '771, safe', '772, safety_pin', '773, saltshaker', '774, sandal', '775, sarong', '776, sax',
182
+ '777, scabbard', '778, scale', '779, school_bus', '780, schooner', '781, scoreboard', '782, screen',
183
+ '783, screw', '784, screwdriver', '785, seat_belt', '786, sewing_machine', '787, shield',
184
+ '788, shoe_shop', '789, shoji', '790, shopping_basket', '791, shopping_cart', '792, shovel',
185
+ '793, shower_cap', '794, shower_curtain', '795, ski', '796, ski_mask', '797, sleeping_bag',
186
+ '798, slide_rule', '799, sliding_door', '800, slot', '801, snorkel', '802, snowmobile',
187
+ '803, snowplow', '804, soap_dispenser', '805, soccer_ball', '806, sock', '807, solar_dish',
188
+ '808, sombrero', '809, soup_bowl', '810, space_bar', '811, space_heater', '812, space_shuttle',
189
+ '813, spatula', '814, speedboat', '815, spider_web', '816, spindle', '817, sports_car',
190
+ '818, spotlight', '819, stage', '820, steam_locomotive', '821, steel_arch_bridge',
191
+ '822, steel_drum',
192
+ '823, stethoscope', '824, stole', '825, stone_wall', '826, stopwatch', '827, stove',
193
+ '828, strainer',
194
+ '829, streetcar', '830, stretcher', '831, studio_couch', '832, stupa', '833, submarine',
195
+ '834, suit',
196
+ '835, sundial', '836, sunglass', '837, sunglasses', '838, sunscreen', '839, suspension_bridge',
197
+ '840, swab', '841, sweatshirt', '842, swimming_trunks', '843, swing', '844, switch', '845, syringe',
198
+ '846, table_lamp', '847, tank', '848, tape_player', '849, teapot', '850, teddy', '851, television',
199
+ '852, tennis_ball', '853, thatch', '854, theater_curtain', '855, thimble', '856, thresher',
200
+ '857, throne', '858, tile_roof', '859, toaster', '860, tobacco_shop', '861, toilet_seat',
201
+ '862, torch', '863, totem_pole', '864, tow_truck', '865, toyshop', '866, tractor',
202
+ '867, trailer_truck', '868, tray', '869, trench_coat', '870, tricycle', '871, trimaran',
203
+ '872, tripod', '873, triumphal_arch', '874, trolleybus', '875, trombone', '876, tub',
204
+ '877, turnstile', '878, typewriter_keyboard', '879, umbrella', '880, unicycle', '881, upright',
205
+ '882, vacuum', '883, vase', '884, vault', '885, velvet', '886, vending_machine', '887, vestment',
206
+ '888, viaduct', '889, violin', '890, volleyball', '891, waffle_iron', '892, wall_clock',
207
+ '893, wallet', '894, wardrobe', '895, warplane', '896, washbasin', '897, washer',
208
+ '898, water_bottle', '899, water_jug', '900, water_tower', '901, whiskey_jug', '902, whistle',
209
+ '903, wig', '904, window_screen', '905, window_shade', '906, Windsor_tie', '907, wine_bottle',
210
+ '908, wing', '909, wok', '910, wooden_spoon', '911, wool', '912, worm_fence', '913, wreck',
211
+ '914, yawl', '915, yurt', '916, web_site', '917, comic_book', '918, crossword_puzzle',
212
+ '919, street_sign', '920, traffic_light', '921, book_jacket', '922, menu', '923, plate',
213
+ '924, guacamole', '925, consomme', '926, hot_pot', '927, trifle', '928, ice_cream',
214
+ '929, ice_lolly',
215
+ '930, French_loaf', '931, bagel', '932, pretzel', '933, cheeseburger', '934, hotdog',
216
+ '935, mashed_potato', '936, head_cabbage', '937, broccoli', '938, cauliflower', '939, zucchini',
217
+ '940, spaghetti_squash', '941, acorn_squash', '942, butternut_squash', '943, cucumber',
218
+ '944, artichoke', '945, bell_pepper', '946, cardoon', '947, mushroom', '948, Granny_Smith',
219
+ '949, strawberry', '950, orange', '951, lemon', '952, fig', '953, pineapple', '954, banana',
220
+ '955, jackfruit', '956, custard_apple', '957, pomegranate', '958, hay', '959, carbonara',
221
+ '960, chocolate_sauce', '961, dough', '962, meat_loaf', '963, pizza', '964, potpie', '965, burrito',
222
+ '966, red_wine', '967, espresso', '968, cup', '969, eggnog', '970, alp', '971, bubble',
223
+ '972, cliff',
224
+ '973, coral_reef', '974, geyser', '975, lakeside', '976, promontory', '977, sandbar',
225
+ '978, seashore', '979, valley', '980, volcano', '981, ballplayer', '982, groom', '983, scuba_diver',
226
+ '984, rapeseed', '985, daisy', "986, yellow_lady's_slipper", '987, corn', '988, acorn', '989, hip',
227
+ '990, buckeye', '991, coral_fungus', '992, agaric', '993, gyromitra', '994, stinkhorn',
228
+ '995, earthstar', '996, hen-of-the-woods', '997, bolete', '998, ear', '999, toilet_tissue']
229
+
230
+ def download_test_img():
231
+ # Images
232
+ torch.hub.download_url_to_file(
233
+ 'https://user-images.githubusercontent.com/59380685/266264420-21575a83-4057-41cf-8a4a-b3ea6f332d79.jpg',
234
+ 'bus.jpg')
235
+ torch.hub.download_url_to_file(
236
+ 'https://user-images.githubusercontent.com/59380685/266264536-82afdf58-6b9a-4568-b9df-551ee72cb6d9.jpg',
237
+ 'dogs.jpg')
238
+ torch.hub.download_url_to_file(
239
+ 'https://user-images.githubusercontent.com/59380685/266264600-9d0c26ca-8ba6-45f2-b53b-4dc98460c43e.jpg',
240
+ 'zidane.jpg')
241
+ # 预处理
242
+ def preprocess(image: Image.Image) -> torch.Tensor:
243
+ transform = T.Compose([
244
+ T.Resize(256),
245
+ T.CenterCrop(224),
246
+ T.ToTensor(),
247
+ T.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]),
248
+ ])
249
+ return transform(image).unsqueeze(0)
250
+
251
+
252
+ # 后处理
253
+ def postprocess(output: torch.Tensor) -> (str, float):
254
+ probabilities = torch.nn.functional.softmax(output, dim=1)[0] * 100
255
+ _, index = output.max(1)
256
+ label = imagenet_classes[index.item()]
257
+ confidence = probabilities[index].item()
258
+ return label, confidence
259
+
260
+
261
+ def predict(image: Image.Image, model_name: str) -> (str, float):
262
+ model = get_model(model_name)
263
+ input_tensor = preprocess(image)
264
+ with torch.no_grad():
265
+ output = model(input_tensor)
266
+ return postprocess(output)
267
+
268
+
269
+ def get_model(model_name: str):
270
+ try:
271
+ model = timm.create_model(model_name, pretrained=True)
272
+ model.eval()
273
+ except ValueError:
274
+ raise ValueError(f"Model {model_name} not found or pretrained weights not available.")
275
+ return model
276
+
277
+
278
+ # 将分类名称和置信度绘制在图像上
279
+ def draw_label_on_image(image: Image.Image, label: str, confidence: float) -> Image.Image:
280
+ draw = ImageDraw.Draw(image)
281
+ font = ImageFont.load_default()
282
+ text = f"{label} ({confidence:.2f}%)"
283
+ draw.text((10, 10), text, font=font, fill=(255, 255, 255, 128))
284
+ return image
285
+
286
+
287
+ def predict_and_draw(image: Image.Image, model_name: str) -> Image.Image:
288
+ label, confidence = predict(image, model_name)
289
+ image_output = draw_label_on_image(image, label, confidence)
290
+ return image_output, label, confidence
291
+
292
+ examples = [
293
+ ['bus.jpg', 'resnet50'],
294
+ ['dogs.jpg', 'efficientnet_b0'],
295
+ ['zidane.jpg', 'vgg16_bn']
296
+ ]
297
+ download_test_img()
298
+
299
+ # 定义输入和输出
300
+ image_input = gr.inputs.Image(type="pil")
301
+ model_input = gr.inputs.Dropdown(
302
+ choices=["resnet50", "efficientnet_b0", "efficientnet_b1", "efficientnet_b2", "efficientnet_b3",
303
+ "efficientnet_b4", "efficientnet_b5", "efficientnet_b6", "efficientnet_b7", "mobilenetv3_large_100",
304
+ "mobilenetv3_rw", "resnet18", "resnet34", "resnet101", "resnext50_32x4d", "resnext101_32x8d",
305
+ "vgg11_bn", "vgg13_bn", "vgg16_bn", "vgg19_bn"], label="Model", default="resnet50")
306
+ image_output = gr.outputs.Image(type="pil")
307
+ text_output = gr.outputs.Textbox(label="Label", type="text")
308
+ score_output = gr.outputs.Textbox(label="Confidence", type="text")
309
+
310
+ # 创建 Gradio 界面
311
+ iface = gr.Interface(fn=predict_and_draw, inputs=[image_input, model_input],
312
+ outputs=[image_output, text_output, score_output], examples=examples,
313
+ title="Image Classification on timm", description="Upload an image and classify,it.")
314
+
315
+ # 启动 Gradio 界面
316
+ iface.launch()
requirements.txt ADDED
@@ -0,0 +1,20 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ wget~=3.2
2
+ opencv-python~=4.6.0.66
3
+ numpy~=1.23.0
4
+ torch~=1.13.1
5
+ torchvision~=0.14.1
6
+ pillow~=9.4.0
7
+ gradio~=3.42.0
8
+ ultralytics~=8.0.169
9
+ pyyaml~=6.0
10
+ wandb~=0.13.11
11
+ tqdm~=4.65.0
12
+ matplotlib~=3.7.1
13
+ pandas~=2.0.0
14
+ seaborn~=0.12.2
15
+ requests~=2.31.0
16
+ psutil~=5.9.4
17
+ thop~=0.1.1-2209072238
18
+ timm~=0.9.2
19
+ super-gradients~=3.2.0
20
+ openmim