2016-07-21 3 views
0

Я обучил случайную модель леса в 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 .. Любая идея о том, что происходит не так?

ответ

1

Вы не можете сохранить его как файл rda изнутри R. Модель существует в кластере H2O, и вы должны использовать h2o.saveModel(), чтобы сохранить его. А затем h2o.loadModel(), чтобы загрузить его снова. См. ?h2o.saveModel и ?h2o.loadModel.

BTW, обратите внимание на асимметрию между функциями: вы указываете каталог для сохраненияModel, и вы даете имя файла для загрузкиModel. (Имя файла будет идентификатором модели.)

+0

ОК спасибо! но это означает, что я должен повторно запустить модель, чтобы сохранить ее? или я могу загрузить старую модель, а затем сохранить ее с помощью 'h2o.loadModel()'? (в последний раз обучение модели заняло 17 часов) –

+0

@FrancescoDalPont Если вы не использовали h2o.saveModel(), вы не можете загрузить его, и вам нужно будет его переделать. Сожалею! Если модель так долго тренируется, взгляните на контрольно-пропускные пункты: вы можете сделать, скажем, первые 50 деревьев, затем сохранить эту модель, а также продолжить обучение. И повторите это каждые 50 деревьев (или каждый час - сколько бы деревьев вы ни делали за один час). Кроме того, как только модель будет достаточно для вас, вы просто остановитесь. –