SageMaker TensorFlow對(duì)象檢測(cè)模型
這篇文章描述了如何在Amazon SageMaker中使用TensorFlow對(duì)象檢測(cè)模型API來(lái)實(shí)現(xiàn)這一點(diǎn)。
首先,基于AWS示例筆記本,將解釋如何使用SageMaker端點(diǎn)在單個(gè)圖像上運(yùn)行模型。對(duì)于較小的圖像,這種方法可行,但對(duì)于較大的圖像,我們會(huì)遇到問(wèn)題。
為了解決這些問(wèn)題,改用批處理轉(zhuǎn)換作業(yè)。
起點(diǎn):使用SageMaker TensorFLow對(duì)象檢測(cè)API進(jìn)行模型推斷
AWS提供了一些關(guān)于GitHub如何使用SageMaker的好例子。
使用此示例使用TensorFlow對(duì)象檢測(cè)API對(duì)對(duì)象檢測(cè)模型進(jìn)行預(yù)測(cè):
將模型部署為端點(diǎn)時(shí),可以通過(guò)調(diào)用端點(diǎn),使用該模型一次推斷一個(gè)圖像。此代碼取自示例筆記本,顯示了如何定義TensorFlowModel并將其部署為模型端點(diǎn):
import cv2
import sagemaker
from sagemaker.utils import name_from_base
from sagemaker.tensorflow import TensorFlowModel
role = sagemaker.get_execution_role()
model_artefact = '<your-model-s3-path>'
model_endpoint = TensorFlowModel(
name=name_from_base('tf2-object-detection'),
model_data=model_artefact,
role=role,
framework_version='2.2',
)
predictor = model_endpoint.deploy(initial_instance_count=1, instance_type='ml.m5.large')
然后,將圖像加載為NumPy數(shù)組,并將其解析為列表,以便將其傳遞給端點(diǎn):
def image_file_to_tensor(path):
cv_img = cv2.imread(path,1).a(chǎn)stype('uint8')
cv_img = cv2.cvtColor(cv_img, cv2.COLOR_BGR2RGB)
return cv_img
img = image_file_to_tensor('test_images/22673445.jpg')
input = {
'instances': [img.tolist()]
}
最后,調(diào)用端點(diǎn):
detections = predictor.predict(input)['predictions'][0]
問(wèn)題:端點(diǎn)請(qǐng)求負(fù)載大小太大
這在使用小圖像時(shí)很好,因?yàn)锳PI調(diào)用的請(qǐng)求負(fù)載足夠小。然而,當(dāng)使用較大的圖片時(shí),API返回413錯(cuò)誤。這意味著有效負(fù)載超過(guò)了允許的大小,即6 MB。
當(dāng)然,我們可以在調(diào)用端點(diǎn)之前調(diào)整圖像的大小,但我想使用批處理轉(zhuǎn)換作業(yè)。
解決方案:改用批處理轉(zhuǎn)換作業(yè)
使用SageMaker批量轉(zhuǎn)換作業(yè),你可以定義自己的最大負(fù)載大小,這樣我們就不會(huì)遇到413個(gè)錯(cuò)誤。其次,這些作業(yè)可用于一次性處理全套圖像。
圖像需要存儲(chǔ)在S3存儲(chǔ)桶中。所有圖像都以批處理模式(名稱中的內(nèi)容)進(jìn)行處理,預(yù)測(cè)也存儲(chǔ)在S3上。
為了使用批處理轉(zhuǎn)換作業(yè),我們?cè)俅味x了TensorFlowModel,但這次我們還定義了入口點(diǎn)和源目錄:
model_batch = TensorFlowModel(
name=name_from_base('tf2-object-detection'),
model_data=model_artifact,
role=role,
framework_version='2.2',
entry_point='inference.py',
source_dir='.',
)
inference.py代碼轉(zhuǎn)換模型的輸入和輸出數(shù)據(jù),如文檔中所述。此代碼需要將請(qǐng)求負(fù)載(圖像)更改為NumPy數(shù)組,并將其解析為列表對(duì)象。
從這個(gè)示例開(kāi)始,我更改了代碼,使其加載圖像并將其轉(zhuǎn)換為NumPy數(shù)組。inference.py中input_h(yuǎn)andler函數(shù)更改為以下內(nèi)容:
import io
import json
import numpy as np
from PIL import Image
def input_h(yuǎn)andler(data, context):
""" Pre-process request input before it is sent to TensorFlow Serving REST API
Args:
data (obj): the request data, in format of dict or string
context (Context): an object containing request and configuration details
Returns:
(dict): a JSON-serializable dict that contains request body and headers
"""
if context.request_content_type == "application/x-image":
payload = data.read()
image = Image.open(io.BytesIO(payload))
array = np.a(chǎn)sarray(image)
return json.dumps({'instances': [array.tolist()]})
raise ValueError('{{"error": "unsupported content type {}"}}'.format(
context.request_content_type or "unknown"))
注意,在上面的代碼中排除了output_h(yuǎn)andler函數(shù)。
此函數(shù)需要Python包NumPy和Pillow,它們未安裝在運(yùn)行批處理推斷作業(yè)的機(jī)器上。
我們可以創(chuàng)建自己的鏡像并使用該鏡像(在TensorFlowModel對(duì)象初始化時(shí)使用image_uri關(guān)鍵字)。
也可以提供requirements.txt并將其存儲(chǔ)在筆記本所在的文件夾中(稱為source_dir=“.”)。該文件在鏡像引導(dǎo)期間用于使用pip安裝所需的包。內(nèi)容為:
numpy
pillow
首先,想使用OpenCV(就像在endpoint示例中一樣),但該軟件包不太容易安裝。
我們現(xiàn)在使用模型創(chuàng)建transformer對(duì)象,而不是將模型部署為模型端點(diǎn):
input_path = "s3://bucket/input"
output_path = "s3://bucket/output"
tensorflow_serving_transformer = model_batch.transformer(
instance_count=1,
instance_type="ml.m5.large",
max_concurrent_transforms=1,
max_payload=5,
output_path=output_path,
)
最后,使用transform:
tensorflow_serving_transformer.transform(
input_path,
content_type="application/x-image",
)
圖像由模型處理,結(jié)果將作為JSON文件最終在output_path bucket中。命名等于輸入文件名,后跟.out擴(kuò)展名。你還可以調(diào)整和優(yōu)化實(shí)例類型、最大負(fù)載等。
最后
這很可能不是最具成本效益的方法,因?yàn)槲覀儗D像作為NumPy數(shù)組傳遞給轉(zhuǎn)換器。
此外,我們還可以在inference.py中調(diào)整output_h(yuǎn)andler函數(shù)壓縮并存儲(chǔ)在S3上的JSON,或僅返回相關(guān)檢測(cè)。
原文標(biāo)題 : SageMaker TensorFlow對(duì)象檢測(cè)模型

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
圖片新聞
-
機(jī)器人奧運(yùn)會(huì)戰(zhàn)報(bào):宇樹機(jī)器人摘下首金,天工Ultra搶走首位“百米飛人”
-
存儲(chǔ)圈掐架!江波龍起訴佰維,索賠121萬(wàn)
-
長(zhǎng)安汽車母公司突然更名:從“中國(guó)長(zhǎng)安”到“辰致科技”
-
豆包前負(fù)責(zé)人喬木出軌BP后續(xù):均被辭退
-
字節(jié)AI Lab負(fù)責(zé)人李航卸任后返聘,Seed進(jìn)入調(diào)整期
-
員工持股爆雷?廣汽埃安緊急回應(yīng)
-
中國(guó)“智造”背后的「關(guān)鍵力量」
-
小米汽車研發(fā)中心重磅落地,寶馬家門口“搶人”
最新活動(dòng)更多
-
即日-9.16點(diǎn)擊進(jìn)入 >> 【限時(shí)福利】TE 2025國(guó)際物聯(lián)網(wǎng)展·深圳站
-
10月23日立即報(bào)名>> Works With 開(kāi)發(fā)者大會(huì)深圳站
-
10月24日立即參評(píng)>> 【評(píng)選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評(píng)選
-
11月27日立即報(bào)名>> 【工程師系列】汽車電子技術(shù)在線大會(huì)
-
12月18日立即報(bào)名>> 【線下會(huì)議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
-
精彩回顧立即查看>> 【限時(shí)下載】ADI中國(guó)三十周年感恩回饋助力企業(yè)升級(jí)!
推薦專題
- 1 阿里首位程序員,“掃地僧”多隆已離職
- 2 先進(jìn)算力新選擇 | 2025華為算力場(chǎng)景發(fā)布會(huì)暨北京xPN伙伴大會(huì)成功舉辦
- 3 宇樹機(jī)器人撞人事件的深度剖析:六維力傳感器如何成為人機(jī)安全的關(guān)鍵屏障
- 4 清華跑出具身智能獨(dú)角獸:給機(jī)器人安上眼睛和大腦,融資近20億
- 5 踢館大廠和微軟,剖析WPS靈犀的AI實(shí)用主義
- 6 特朗普要求英特爾首位華人 CEO 辭職
- 7 AI版“四萬(wàn)億刺激”計(jì)劃來(lái)了
- 8 騰訊 Q2 財(cái)報(bào)亮眼:AI 已成第二增長(zhǎng)曲線
- 9 谷歌吹響AI沖鋒號(hào),AI還有哪些機(jī)會(huì)
- 10 蘋果把身家押在Siri上:一場(chǎng)輸不起的自我革命