milandesai opened a new issue #10436: FeedForward.scala and NDArrayIter.scala 
leak memory by not disposing of NDArrays
URL: https://github.com/apache/incubator-mxnet/issues/10436
 
 
   ## Description
   FeedForward.scala and NDArrayIter.scala leak memory by not disposing of 
NDArrays. We see the below leak warnings occur running on MXNet 1.1.0. 
Additionally, there is no clean way of disposing a FeedForward and its contents.
   
   ## Version
   MXNet 1.1.0
   
   ## Error Message:
   ```
   [2018-04-06 01:12:13,895] WARN  - Finalizer - WarnIfNotDisposed - LEAK: An 
instance of class ml.dmlc.mxnet.NDArray was not disposed. Creation point of 
this resource was:
        java.lang.Thread.getStackTrace(Thread.java:1552)
        ml.dmlc.mxnet.WarnIfNotDisposed.$init$(WarnIfNotDisposed.scala:52)
        ml.dmlc.mxnet.NDArray.<init>(NDArray.scala:549)
        ml.dmlc.mxnet.NDArray.slice(NDArray.scala:632)
        ml.dmlc.mxnet.FeedForward.$anonfun$predict$5(FeedForward.scala:233)
        
scala.collection.TraversableLike$WithFilter.$anonfun$foreach$1(TraversableLike.scala:789)
        
scala.collection.IndexedSeqOptimized.foreach(IndexedSeqOptimized.scala:32)
        
scala.collection.IndexedSeqOptimized.foreach$(IndexedSeqOptimized.scala:29)
        scala.collection.mutable.ArrayOps$ofRef.foreach(ArrayOps.scala:191)
        
scala.collection.TraversableLike$WithFilter.foreach(TraversableLike.scala:788)
        ml.dmlc.mxnet.FeedForward.predict(FeedForward.scala:232)
   
   [2018-04-06 01:12:13,895] WARN  - Finalizer - WarnIfNotDisposed - LEAK: An 
instance of class ml.dmlc.mxnet.NDArray was not disposed. Creation point of 
this resource was:
        java.lang.Thread.getStackTrace(Thread.java:1552)
        ml.dmlc.mxnet.WarnIfNotDisposed.$init$(WarnIfNotDisposed.scala:52)
        ml.dmlc.mxnet.NDArray.<init>(NDArray.scala:549)
        ml.dmlc.mxnet.NDArray.slice(NDArray.scala:632)
        ml.dmlc.mxnet.io.NDArrayIter.$anonfun$_getData$2(NDArrayIter.scala:163)
        
scala.collection.TraversableLike.$anonfun$map$1(TraversableLike.scala:234)
        scala.collection.Iterator.foreach(Iterator.scala:929)
        scala.collection.Iterator.foreach$(Iterator.scala:929)
        scala.collection.AbstractIterator.foreach(Iterator.scala:1417)
        scala.collection.IterableLike.foreach(IterableLike.scala:71)
        scala.collection.IterableLike.foreach$(IterableLike.scala:70)
        scala.collection.AbstractIterable.foreach(Iterable.scala:54)
        scala.collection.TraversableLike.map(TraversableLike.scala:234)
        scala.collection.TraversableLike.map$(TraversableLike.scala:227)
        scala.collection.AbstractTraversable.map(Traversable.scala:104)
        ml.dmlc.mxnet.io.NDArrayIter._getData(NDArrayIter.scala:163)
        ml.dmlc.mxnet.io.NDArrayIter.getData(NDArrayIter.scala:176)
        ml.dmlc.mxnet.io.NDArrayIter.next(NDArrayIter.scala:134)
        ml.dmlc.mxnet.FeedForward.predict(FeedForward.scala:226)
   ```
   
   The culprit appears to be FeedForward.scala:233 and NDArrayIter:163. 
Additionally, it would be nice to to provide a method that disposes of a 
FeedForward; i.e. it disposes the symbol, executor, and aux/arg params.

----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on GitHub and use the
URL above to go to the specific comment.
 
For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


With regards,
Apache Git Services

Reply via email to