该问题通常发生在将语义分割模型部署在 AWS SageMaker 上并通过 AWS Lambda 做预测时。默认情况下,SageMaker 输出的是 application/x-recordio-protobuf 格式的数据,需要进一步处理才能得到可用的图像数据。以下是解决方法的代码示例:
import boto3
import numpy as np
import cv2
from io import BytesIO
sagemaker_runtime = boto3.client('sagemaker-runtime')
def handler(event, context):
# 从事件中获取图像数据
image_bytes = event['image']
# 调用 SageMaker 服务进行预测,返回 application/x-recordio-protobuf 格式的数据
response = sagemaker_runtime.invoke_endpoint(EndpointName='semantic-segmentation-model',
ContentType='application/x-image',
Body=image_bytes)
# 解析 application/x-recordio-protobuf 格式的数据
seg_record = response['Body'].read()
seg_array = np.frombuffer(seg_record, dtype=np.uint8)
# 处理 seg_array 获得分割结果
seg_image = # do some processing on seg_array
# 返回图像数据
return {'segmentation': seg_image}
在上述代码中,我们通过调用 SageMaker 的客户端来从 Lambda 函数中调用模型。使用 ContentType='application/x-image'
来指定输入类型,这样我们就可以上传图像并将其转为 application/x-recordio-protobuf 格式来进行预测。然后,我们使用 numpy.frombuffer 从 response 中读取 application/x-recordio-protobuf 格式的数据,并使用 cv2 进行处理以获得图像分割结果。最后,我们可以将图像分割结果作为响应返回给调用方。