我在修改Caffe深度学习库中的一个示例C++程序时,注意到在第234行有一段代码,似乎在之后没有被再次引用。
::google::InitGoogleLogging(argv[0]);
提供的参数是一个prototxt文件,它定义了我正在调用的深度学习模型的参数。让我感到困惑的是,这行代码的结果去哪儿了?我知道它们最终会在程序中被使用,因为如果我在prototxt文件中犯了错误,程序就会崩溃。然而,我很难理解数据是如何传递给执行分类任务的类的。
回答:
首先,argv[0]
并不是你传递给可执行文件的第一个参数,而是可执行文件名。所以你传递给::google::InitGoogleLogging
的是可执行文件名,而不是prototxt文件。'glog'
模块(谷歌日志)使用这个名称来装饰它输出的日志条目。
其次,Caffe使用谷歌日志(即'glog'
)作为其日志模块,因此在运行Caffe时必须初始化这个模块。这就是为什么你的代码中有这一行
::google::InitGoogleLogging(argv[0]);
的原因。