Я обучил случайную модель леса в Rstudio, используя h2o-библиотеку, а затем я сохранил ее как файл .rda, теперь я хотел бы набрать другие данные, используя модель buildt. Итак, я загрузил модель, которая превратила новый набор данных в H2OFrame, и я пытаюсь получить результат с помощью функции predict(model, new_data)
. Что я получаю следующее сообщение об ошибке:Прогнозы с h2o.randomForest сохраненной моделью
ERROR: Unexpected HTTP Status code: 404 Not Found (url = http://localhost:54321/4/Predictions/models/DRF_model_R_1468754145815_1/frames/file1840210c1889_sid_9b90_2)
water.exceptions.H2OKeyNotFoundArgumentException
[1] "water.exceptions.H2OKeyNotFoundArgumentException: Object 'DRF_model_R_1468754145815_1' not found in function: predict for argument: model"
[2] " water.api.ModelMetricsHandler.predict2(ModelMetricsHandler.java:239)"
[3] " sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)"
[4] " sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)"
[5] " sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)"
[6] " java.lang.reflect.Method.invoke(Method.java:498)"
[7] " water.api.Handler.handle(Handler.java:62)"
[8] " water.api.RequestServer.handle(RequestServer.java:655)"
[9] " water.api.RequestServer.serve(RequestServer.java:596)"
[10] " water.JettyHTTPD$H2oDefaultServlet.doGeneric(JettyHTTPD.java:745)"
[11] " water.JettyHTTPD$H2oDefaultServlet.doPost(JettyHTTPD.java:681)"
[12] " javax.servlet.http.HttpServlet.service(HttpServlet.java:755)"
[13] " javax.servlet.http.HttpServlet.service(HttpServlet.java:848)"
[14] " org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:684)"
[15] " org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:503)"
[16] " org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)"
[17] " org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557)"
[18] " org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)"
[19] " org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1086)"
[20] " org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:429)"
[21] " org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)"
[22] " org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1020)"
[23] " org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)"
[24] " org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)"
[25] " org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)"
[26] " org.eclipse.jetty.server.Server.handle(Server.java:370)"
[27] " org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:494)"
[28] " org.eclipse.jetty.server.BlockingHttpConnection.handleRequest(BlockingHttpConnection.java:53)"
[29] " org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:971)"
[30] " org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1033)"
[31] " org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:644)"
[32] " org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235)"
[33] " org.eclipse.jetty.server.BlockingHttpConnection.handle(BlockingHttpConnection.java:72)"
[34] " org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264)"
[35] " org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)"
[36] " org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)"
[37] " java.lang.Thread.run(Thread.java:745)"
Error in .h2o.doSafeREST(h2oRestApiVersion = h2oRestApiVersion, urlSuffix = page, :
ERROR MESSAGE:
Object 'DRF_model_R_1468754145815_1' not found in function: predict for argument: model
Я новичок в H2O .. Любая идея о том, что происходит не так?
ОК спасибо! но это означает, что я должен повторно запустить модель, чтобы сохранить ее? или я могу загрузить старую модель, а затем сохранить ее с помощью 'h2o.loadModel()'? (в последний раз обучение модели заняло 17 часов) –
@FrancescoDalPont Если вы не использовали h2o.saveModel(), вы не можете загрузить его, и вам нужно будет его переделать. Сожалею! Если модель так долго тренируется, взгляните на контрольно-пропускные пункты: вы можете сделать, скажем, первые 50 деревьев, затем сохранить эту модель, а также продолжить обучение. И повторите это каждые 50 деревьев (или каждый час - сколько бы деревьев вы ни делали за один час). Кроме того, как только модель будет достаточно для вас, вы просто остановитесь. –