liuyizhang commited on
Commit
ed7763f
·
1 Parent(s): 434a891

update app.py

Browse files
Files changed (2) hide show
  1. GroundingDINO/groundingdino/version.py +1 -1
  2. app.py +24 -8
GroundingDINO/groundingdino/version.py CHANGED
@@ -1 +1 @@
1
- __version__ = "0.1.0"
 
1
+ __version__ = '0.1.0'
app.py CHANGED
@@ -1,12 +1,15 @@
1
 
2
- import subprocess, os, sys
3
 
4
  os.environ["CUDA_VISIBLE_DEVICES"] = "0"
5
 
6
- sys.path.insert(0, './GroundingDINO')
 
7
 
8
  result = subprocess.run(['pip', 'list'], check=True)
9
- print(f'pip list result = {result}')
 
 
10
 
11
  if not os.path.exists('./sam_vit_h_4b8939.pth'):
12
  result = subprocess.run(['wget', 'https://dl.fbaipublicfiles.com/segment_anything/sam_vit_h_4b8939.pth'], check=True)
@@ -210,12 +213,22 @@ def run_grounded_sam(image_path, text_prompt, task_type, inpaint_prompt, box_thr
210
  # load image
211
  image_pil, image = load_image(image_path.convert("RGB"))
212
 
 
 
213
  # visualize raw image
214
- image_pil.save(os.path.join(output_dir, "raw_image.jpg"))
215
 
216
  # run grounding dino model
 
 
 
 
 
 
 
 
217
  boxes_filt, pred_phrases = get_grounding_output(
218
- groundingdino_model, image, text_prompt, box_threshold, text_threshold, device='cpu'
219
  )
220
 
221
  size = image_pil.size
@@ -250,9 +263,10 @@ def run_grounded_sam(image_path, text_prompt, task_type, inpaint_prompt, box_thr
250
  }
251
  # import ipdb; ipdb.set_trace()
252
  image_with_box = plot_boxes_to_image(image_pil, pred_dict)[0]
253
- image_path = os.path.join(output_dir, "grounding_dino_output.jpg")
254
  image_with_box.save(image_path)
255
  image_result = cv2.cvtColor(cv2.imread(image_path), cv2.COLOR_BGR2RGB)
 
256
  return image_result
257
  elif task_type == 'segment':
258
  assert sam_checkpoint, 'sam_checkpoint is not found!'
@@ -265,9 +279,10 @@ def run_grounded_sam(image_path, text_prompt, task_type, inpaint_prompt, box_thr
265
  for box, label in zip(boxes_filt, pred_phrases):
266
  show_box(box.numpy(), plt.gca(), label)
267
  plt.axis('off')
268
- image_path = os.path.join(output_dir, "grounding_dino_output.jpg")
269
  plt.savefig(image_path, bbox_inches="tight")
270
  image_result = cv2.cvtColor(cv2.imread(image_path), cv2.COLOR_BGR2RGB)
 
271
  return image_result
272
  elif task_type == 'inpainting':
273
  assert inpaint_prompt, 'inpaint_prompt is not found!'
@@ -277,9 +292,10 @@ def run_grounded_sam(image_path, text_prompt, task_type, inpaint_prompt, box_thr
277
  image_pil = Image.fromarray(image)
278
 
279
  image = sd_pipe(prompt=inpaint_prompt, image=image_pil, mask_image=mask_pil).images[0]
280
- image_path = os.path.join(output_dir, "grounded_sam_inpainting_output.jpg")
281
  image.save(image_path)
282
  image_result = cv2.cvtColor(cv2.imread(image_path), cv2.COLOR_BGR2RGB)
 
283
  return image_result
284
  else:
285
  print("task_type:{} error!".format(task_type))
 
1
 
2
+ import subprocess, os, sys, time
3
 
4
  os.environ["CUDA_VISIBLE_DEVICES"] = "0"
5
 
6
+ result = subprocess.run(['pip', 'install', '-e', 'GroundingDINO'], check=True)
7
+ print(f'pip install GroundingDINO = {result}')
8
 
9
  result = subprocess.run(['pip', 'list'], check=True)
10
+ print(f'pip list = {result}')
11
+
12
+ sys.path.insert(0, './GroundingDINO')
13
 
14
  if not os.path.exists('./sam_vit_h_4b8939.pth'):
15
  result = subprocess.run(['wget', 'https://dl.fbaipublicfiles.com/segment_anything/sam_vit_h_4b8939.pth'], check=True)
 
213
  # load image
214
  image_pil, image = load_image(image_path.convert("RGB"))
215
 
216
+ file_temp = int(time.time())
217
+
218
  # visualize raw image
219
+ # image_pil.save(os.path.join(output_dir, f"raw_image_{file_temp}.jpg"))
220
 
221
  # run grounding dino model
222
+ groundingdino_device = 'cpu'
223
+ if device != 'cpu':
224
+ try:
225
+ from groundingdino import _C
226
+ groundingdino_device = 'cuda:0'
227
+ except:
228
+ warnings.warn("Failed to load custom C++ ops. Running on CPU mode Only in groundingdino!")
229
+
230
  boxes_filt, pred_phrases = get_grounding_output(
231
+ groundingdino_model, image, text_prompt, box_threshold, text_threshold, device=groundingdino_device
232
  )
233
 
234
  size = image_pil.size
 
263
  }
264
  # import ipdb; ipdb.set_trace()
265
  image_with_box = plot_boxes_to_image(image_pil, pred_dict)[0]
266
+ image_path = os.path.join(output_dir, f"grounding_dino_output_{file_temp}.jpg")
267
  image_with_box.save(image_path)
268
  image_result = cv2.cvtColor(cv2.imread(image_path), cv2.COLOR_BGR2RGB)
269
+ os.remove(image_path)
270
  return image_result
271
  elif task_type == 'segment':
272
  assert sam_checkpoint, 'sam_checkpoint is not found!'
 
279
  for box, label in zip(boxes_filt, pred_phrases):
280
  show_box(box.numpy(), plt.gca(), label)
281
  plt.axis('off')
282
+ image_path = os.path.join(output_dir, f"grounding_seg_output_{file_temp}.jpg")
283
  plt.savefig(image_path, bbox_inches="tight")
284
  image_result = cv2.cvtColor(cv2.imread(image_path), cv2.COLOR_BGR2RGB)
285
+ os.remove(image_path)
286
  return image_result
287
  elif task_type == 'inpainting':
288
  assert inpaint_prompt, 'inpaint_prompt is not found!'
 
292
  image_pil = Image.fromarray(image)
293
 
294
  image = sd_pipe(prompt=inpaint_prompt, image=image_pil, mask_image=mask_pil).images[0]
295
+ image_path = os.path.join(output_dir, f"grounded_sam_inpainting_output_{file_temp}.jpg")
296
  image.save(image_path)
297
  image_result = cv2.cvtColor(cv2.imread(image_path), cv2.COLOR_BGR2RGB)
298
+ os.remove(image_path)
299
  return image_result
300
  else:
301
  print("task_type:{} error!".format(task_type))