Невозможно работать быстрее R-CNN с выводом elasti c и обслуживанием тензорного потока - как отладить? - PullRequest
0 голосов
/ 22 января 2020

Я нашел save_model из Model Zoo от Tensorflow . Я могу запустить мою модель Faster R-CNN локально, используя следующий код:

image_np = np.array(Image.open('my_input.jpg'))
image = np.asarray(image_np)
input_tensor = tf.convert_to_tensor(image)
input_tensor = input_tensor[tf.newaxis,...]

model = tf.saved_model.load(os.path.join('<PATH_TO_SAVED_MODEL>'))
model = model.signatures['serving_default']

output_dict = model(input_tensor)

Я хотел попробовать запустить ее с помощью Elasti c Inference и начал с этого руководства . Я поменял местами более быструю модель r-cnn, просто изменив путь к save_model при запуске tenorflow:

EI_VISIBLE_DEVICES=0 amazonei_tensorflow_model_server --model_name=f_r_cnn --model_base_path=/tmp/f_r_cnn --port=9000

Теперь я пытаюсь запустить клиент, чтобы общаться с службой тензорного потока, используя предоставленный шаблон:

from __future__ import print_function

import grpc
import tensorflow as tf
from PIL import Image
import numpy as np
import time
import os
from tensorflow_serving.apis import predict_pb2
from tensorflow_serving.apis import prediction_service_pb2_grpc

tf.app.flags.DEFINE_string('server', 'localhost:9000',
                           'PredictionService host:port')
tf.app.flags.DEFINE_string('image', '', 'path to image in JPEG format')
FLAGS = tf.app.flags.FLAGS

coco_classes_txt = "https://raw.githubusercontent.com/amikelive/coco-labels/master/coco-labels-paper.txt"
local_coco_classes_txt = "/tmp/coco-labels-paper.txt"
# it's a file like object and works just like a file
os.system("curl -o %s -O %s"%(local_coco_classes_txt, coco_classes_txt))
NUM_PREDICTIONS = 5
with open(local_coco_classes_txt) as f:
  classes = ["No Class"] + [line.strip() for line in f.readlines()]


def main(_):
  channel = grpc.insecure_channel(FLAGS.server)
  stub = prediction_service_pb2_grpc.PredictionServiceStub(channel)

  # Send request
  with Image.open(FLAGS.image) as f:
    f.load()
    # See prediction_service.proto for gRPC request/response details.
    data = np.asarray(f)
    data = np.expand_dims(data, axis=0)

    request = predict_pb2.PredictRequest()
    request.model_spec.name = 'f_r_cnn'
    request.inputs['inputs'].CopyFrom(
        tf.contrib.util.make_tensor_proto(data, shape=data.shape))
    result = stub.Predict(request, 60.0)  # 10 secs timeout
    outputs = result.outputs
    detection_classes = outputs["detection_classes"]
    detection_classes = tf.make_ndarray(detection_classes)
    num_detections = int(tf.make_ndarray(outputs["num_detections"])[0])
    print("%d detection[s]" % (num_detections))
    class_label = [classes[int(x)]
                   for x in detection_classes[0][:num_detections]]
    print("SSD Prediction is ", class_label)


if __name__ == '__main__':
  tf.app.run()

Хотя этот клиент прекрасно работал с моделью из учебного пособия (что неудивительно), при попытке установить связь с моей моделью Faster R-CNN с помощью следующая ошибка:

debug_error_string = "{"created":"@1579654607.391705065","description":"Error received from peer ipv6:[::1]:9000","file":"src/core/lib/surface/call.cc","file_line":1052,"grpc_message":"Unexpected error in RPC handling","grpc_status":2}"

Я погуглил эту ошибку и не смог найти ничего полезного. Что такое grpc_status 2? Как я могу найти полезную информацию, которая поможет направить меня в правильном направлении?

Ответы [ 2 ]

1 голос
/ 23 января 2020

"grpc_message": "Неожиданная ошибка в обработке RP C", "grpc_status": 2} "

указывает на то, что обработчик метода на стороне сервера, обрабатывающий запрос, выдал исключение, когда вызывается (мы перехватываем все исключения и генерируем эту общую ошибку c). Поэтому я думаю, что вы можете отладить, посмотрев на свой обработчик методов на стороне сервера для запроса RP C.

0 голосов
/ 29 января 2020

gPP C статус 2 - UNKNOWN . Но из сообщения об ошибке не ясно, что может быть причиной этого. Я подозреваю, что это больше проблема TensorFlow, чем проблема gRP C.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...