2016-07-21 10 views
0

私はh2oライブラリを使ってRstudioでランダムフォレストモデルを訓練した後、これを.rdaファイルとして保存しました。モデルビルドを使用して他のデータにスコアを付けたいと思います。 私はモデルをロードしました。新しいデータセットを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

モデルはH2Oクラスター上に存在し、h2o.saveModel()を使用して保存する必要があります。その後、h2o.loadModel()を再度ロードしてください。 ?h2o.saveModelおよび?h2o.loadModelを参照してください。

ところで、関数間の非対称性に注意してください。つまり、saveModelにディレクトリを与え、loadModelにファイル名を与えます。 (ファイル名はモデルIDになります)

+0

okありがとう!しかし、これは私がそれを保存するためにモデルを再実行する必要があることを意味しますか?または私は古いモデルを読み込み、 'h2o.loadModel()'を使って保存することができますか? (モデルトレーニングが最後に17時間かかったとき) –

+0

@FrancescoDalPont h2o.saveModel()を使用しなかった場合、それをロードすることはできず、再作成する必要があります。ごめんなさい!モデルが訓練にそれほど時間がかかっているなら、チェックポイントを見てみましょう。たとえば、最初の50本の木を作って、そのモデルを保存するだけでなく、学習を続けることができます。そしてこれを50本の木ごとに繰り返す(または1時間に1枚の木がたくさんあります)。また、モデルがあなたのために十分なものになったら、ただ停止します。 –

関連する問題