0

我正在使用breeze.optimizeScala Breeze 的包,看起来 Breeze ahs 实现了自己的日志库。

有没有办法将 Breeze 配置为使用 log4j 或 slf4j 等标准日志记录,这样我就可以像对应用程序中的其他所有内容一样配置日志记录以进行优化?

或者,我该如何关闭日志消息。默认情况下它们是打开的,并为我记录函数最小化的每次迭代,这为我产生了很多日志噪音。

Apache Commons 的包装器基于他在下面的回答:

import breeze.util.logging.Logger
import breeze.util.logging.Logger.Level
import org.apache.commons.logging.LogFactory

class BreezeCommonsLogger[T: ClassManifest] extends Logger {
    private val log = LogFactory.getLog(classManifest[T].erasure)

    def trace(f: => Any) { if (log.isTraceEnabled()) log.trace(f.toString) }
    def debug(f: => Any) { if (log.isDebugEnabled()) log.debug(f.toString) }
    def info(f: => Any) { if (log.isInfoEnabled()) log.info(f.toString) }
    def warn(f: => Any) { if (log.isWarnEnabled()) log.warn(f.toString) }
    def error(f: => Any) { if (log.isErrorEnabled()) log.error(f.toString) }
    def fatal(f: => Any) { if (log.isFatalEnabled()) log.fatal(f.toString) }
    def level_=(level: Level) {}
    def level = Logger.NEVER
}

我能够像这样使用它:

val lbfgs = new LBFGS[Mat](maxIters, 5, tolerance) {
    override val log = new BreezeCommonsLogger[LBFGS[Mat]]
}
4

1 回答 1

1

请注意优化类如何具有log类型为 的成员变量breeze.util.logging.Logger。要关闭日志消息,提供了一个名为breeze.util.logging.NullLogger. 要覆盖默认值log,您可以执行以下操作:

val opt = new breeze.optimize.OWLQN { 
  override val log = breeze.util.logging.NullLogger
}

这将创建一个匿名类,使OWLQN优化器的一切保持不变,没有日志记录。

在使用 log4j 或 slf4j 等替代日志记录源方面,尝试使用隐式转换将 log4j 记录器转换为 Breeze 记录器,或者考虑将记录器包装在继承自Logger.

于 2013-02-22T16:05:44.493 回答