You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_mplug_tasks.py 3.6 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. # Copyright (c) Alibaba, Inc. and its affiliates.
  2. import unittest
  3. from PIL import Image
  4. from modelscope.models import Model
  5. from modelscope.outputs import OutputKeys
  6. from modelscope.pipelines import pipeline
  7. from modelscope.utils.constant import Tasks
  8. from modelscope.utils.test_utils import test_level
  9. class MplugTasksTest(unittest.TestCase):
  10. @unittest.skipUnless(test_level() >= 1, 'skip test in current test level')
  11. def test_run_with_image_captioning_with_model(self):
  12. model = Model.from_pretrained(
  13. 'damo/mplug_image-captioning_coco_base_en')
  14. pipeline_caption = pipeline(
  15. task=Tasks.image_captioning,
  16. model=model,
  17. )
  18. image = Image.open('data/test/images/image_mplug_vqa.jpg')
  19. result = pipeline_caption({'image': image})
  20. print(result[OutputKeys.CAPTION])
  21. @unittest.skipUnless(test_level() >= 0, 'skip test in current test level')
  22. def test_run_with_image_captioning_with_name(self):
  23. pipeline_caption = pipeline(
  24. Tasks.image_captioning,
  25. model='damo/mplug_image-captioning_coco_base_en')
  26. image = Image.open('data/test/images/image_mplug_vqa.jpg')
  27. result = pipeline_caption({'image': image})
  28. print(result[OutputKeys.CAPTION])
  29. @unittest.skipUnless(test_level() >= 1, 'skip test in current test level')
  30. def test_run_with_visual_question_answering_with_model(self):
  31. model = Model.from_pretrained(
  32. 'damo/mplug_visual-question-answering_coco_large_en')
  33. pipeline_vqa = pipeline(Tasks.visual_question_answering, model=model)
  34. image = Image.open('data/test/images/image_mplug_vqa.jpg')
  35. question = 'What is the woman doing?'
  36. input = {'image': image, 'question': question}
  37. result = pipeline_vqa(input)
  38. print(result)
  39. @unittest.skipUnless(test_level() >= 0, 'skip test in current test level')
  40. def test_run_with_visual_question_answering_with_name(self):
  41. model = 'damo/mplug_visual-question-answering_coco_large_en'
  42. pipeline_vqa = pipeline(Tasks.visual_question_answering, model=model)
  43. image = Image.open('data/test/images/image_mplug_vqa.jpg')
  44. question = 'What is the woman doing?'
  45. input = {'image': image, 'question': question}
  46. result = pipeline_vqa(input)
  47. print(result)
  48. @unittest.skipUnless(test_level() >= 1, 'skip test in current test level')
  49. def test_run_with_image_text_retrieval_with_model(self):
  50. model = Model.from_pretrained(
  51. 'damo/mplug_image-text-retrieval_flickr30k_large_en')
  52. pipeline_retrieval = pipeline(Tasks.image_text_retrieval, model=model)
  53. image = Image.open('data/test/images/image-text-retrieval.jpg')
  54. question = 'Two young guys with shaggy hair look at their hands while hanging out in the yard.'
  55. input = {'image': image, 'question': question}
  56. result = pipeline_retrieval(input)
  57. print(result)
  58. @unittest.skipUnless(test_level() >= 0, 'skip test in current test level')
  59. def test_run_with_image_text_retrieval_with_name(self):
  60. model = 'damo/mplug_image-text-retrieval_flickr30k_large_en'
  61. pipeline_retrieval = pipeline(Tasks.image_text_retrieval, model=model)
  62. image = Image.open('data/test/images/image-text-retrieval.jpg')
  63. question = 'Two young guys with shaggy hair look at their hands while hanging out in the yard.'
  64. input = {'image': image, 'question': question}
  65. result = pipeline_retrieval(input)
  66. print(result)
  67. if __name__ == '__main__':
  68. unittest.main()