PyTorch错误:The “freeze_support()” line can be omitted if the program is not going to be frozen to produce an executable.
错误代码如下:

RuntimeError: 
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.
 
        This probably means that you are not using fork to start your
        child processes and you have forgotten to use the proper idiom
        in the main module:
 
            if __name__ == '__main__':
                freeze_support()
                ...
 
        The "freeze_support()" line can be omitted if the program
        is not going to be frozen to produce an executable.RuntimeError: 
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.
 
        This probably means that you are not using fork to start your
        child processes and you have forgotten to use the proper idiom
        in the main module:
 
            if __name__ == '__main__':
                freeze_support()
                ...
 
        The "freeze_support()" line can be omitted if the program
        is not going to be frozen to produce an executable.

解决方法

将你要运行的代码块放到main函数中运行即可

if __name__ == '__main__':
    #your code

问题产生原因:
问题:

import Queue
from multiprocessing.managers import BaseManager

BaseManager.register('get_queue', callable=lambda:  Queue.Queue())

manager = BaseManager(address=('', 5000), authkey='abc')
manager.start()
manager.shutdown()

This code will throw a exception

RuntimeError: 
        Attempt to start a new process before the current process
        has finished its bootstrapping phase.

        This probably means that you are on Windows and you have
        forgotten to use the proper idiom in the main module:

            if __name__ == '__main__':
                freeze_support()
                ...

        The "freeze_support()" line can be omitted if the program
        is not going to be frozen to produce a Windows executable.

回答:
This error message is displayed when using multiprocessing with the ‘spawn’ start method (default on platforms lacking fork like windows), and not protecting your code with a if name = ‘main’ guard.

The reason is that with the ‘spawn’ start method a new python process is spawned, which then in turn has to import the main module before it can proceed to do it’s work. If your program does not have the mentioned guard, that subprocess would try to execute the same code as the parent process again, spawning another process and so on, until your program (or computer) crashes.

The message is not ment to tell you to add the freeze_support() line, but to guard your program:

import Queue
from multiprocessing.managers import BaseManager

def main():
    BaseManager.register('get_queue', callable=lambda:  Queue.Queue())

    manager = BaseManager(address=('', 5000), authkey='abc')
    manager.start()
    manager.shutdown()

if __name__ == '__main__':
    # freeze_support() here if program needs to be frozen
    main()  # execute this only when run directly, not when imported!

来源:https://stackoverflow.com/questions/29690091/python2-7-exception-the-freeze-support-line-can-be-omitted-if-the-program

也就是问题在于在使用了pytorch的多线程,如下,然后没有使用if __name__ == '__main__':来保护只有主程序才能执行if __name__ == '__main__':下面的语句,然后多线程创建出来相同的子进程也在不停的和主进程一样创建子进程,导致问题出现。

import torch.multiprocessing as mp

mp.spawn(demo_fn,
             args=(model, world_size, num_epochs),
             nprocs=world_size,
             join=True)

要运行pytorch多线程结构应该类似下方示例:

import .....


........

def run(demo_fn,model,world_size, num_epochs):
    mp.spawn(demo_fn,
             args=(model, world_size, num_epochs),
             nprocs=world_size,
             join=True)

...................

if __name__ == '__main__':
    run(train_model, model_ft, world_size, 300)
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐