Network Construction and Training Error Analysis
The following lists the common network construction and training errors in static graph mode.
Incorrect Context Configuration
When performing network training, you must run the following command to specify the backend device: set_context(device_target=device)
. MindSpore supports CPU, GPU, and Ascend. If a GPU backend device is incorrectly specified as Ascend by running set_context(device_target="Ascend")
, the following error message will be displayed:
ValueError: For 'set_context', package type mindspore-gpu support 'device_target' type gpu or cpu, but got Ascend.
The running backend specified by the script must match the actual hardware device.
For details, visit the following website:
MindSpore Configuration Error - 'set_context' Configuration Error
For details about the context configuration, see 'set_context'.
Syntax Errors
Incorrect Construct Parameter
In MindSpore, the basic unit of the neural network is nn.Cell
. All the models or neural network layers must inherit this base class. As a member function of this base class, construct
defines the calculation logic to be executed and must be rewritten in all inherited classes. The function prototype of construct
is:
def construct(self, *inputs, **kwargs):
When the function is rewritten, the following error message may be displayed:
TypeError: The function construct needs 0 positional argument and 0 default argument, but provided 1
This is because the function parameter list is incorrect when the user-defined construct
function is implemented, for example, "def construct(*inputs, **kwargs):"
, where self
is missing. In this case, an error is reported when MindSpore parses the syntax.
For details, visit the following website:
Incorrect Control Flow Syntax
In static graph mode, Python code is not executed by the Python interpreter. Instead, the code is built into a static computational graph for execution. The control flow syntax supported by MindSpore includes if, for, and while statements. The attributes of the objects returned by different branches of the if statement may be inconsistent. As a result, an error is reported. The error message is displayed as follows:
TypeError: Cannot join the return values of different branches, perhaps you need to make them equal.
Type Join Failed: dtype1 = Float32, dtype2 = Float16.
According to the error message, the return values of different branches of the if statement are of different types. One is float32, and the other is float16. As a result, a build error is reported.
ValueError: Cannot join the return values of different branches, perhaps you need to make them equal.
Shape Join Failed: shape1 = (2, 3, 4, 5), shape2 = ().
According to the error message, the dimension shapes of the return values of different branches of the if statement are different. One is a 4-bit tensor of 2*3*4*5
, and the other is a scalar. As a result, a build error is reported.
For details, visit the following website:
MindSpore Syntax Error - Type (Shape) Join Failed
The number of loops of the for and while statements may exceed the permitted range. As a result, the function call stack exceeds the threshold. The error message is displayed as follows:
RuntimeError: Exceed function call depth limit 1000, (function call depth: 1001, simulate call depth: 997).
One solution to the problem that the function call stack exceeds the threshold is to simplify the network structure and reduce the number of loops. Another method is to use mindspore.set_recursion_limit(recursion_limit=value)
to increase the threshold of the function call stack.
For details, visit the following website:
Operator Build Errors
Operator build errors are mainly caused by input parameters that do not meet requirements or operator functions that are not supported.
For example, when the ReduceSum operator is used, the following error message is displayed if the input data exceeds eight dimensions:
RuntimeError: ({'errCode': 'E80012', 'op_name': 'reduce_sum_d', 'param_name': 'x', 'min_value': 0, 'max_value': 8, 'real_value': 10}, 'In op, the num of dimensions of input/output[x] should be in the range of [0, 8], but actually is [10].')
For details, visit the following website:
For example, the Parameter parameter does not support automatic type conversion. When the Parameter operator is used, an error is reported during data type conversion. The error message is as follows:
RuntimeError: Data type conversion of 'Parameter' is not supported, so data type int32 cannot be converted to data type float32 automatically.
For details, visit the following website:
In addition, sometimes errors such as Response is empty
, Try to send request before Open()
and Try to get response before Open()
may appear during the operator compilation process, as shown below:
> result = self._graph_executor.compile(obj, args_list, phase, self._use_vm_mode())
E RuntimeError: Response is empty
E
E ----------------------------------------------------
E - C++ Call Stack: (For framework developers)
E ----------------------------------------------------
E mindspore/ccsrc/backend/common/session/kernel_build_client.h:100 Response
The direct cause of this problem is usually a timeout caused by the subprocess of operator compilation hanging or the call blocking, which can be investigated from the following aspects:
Check the logs to see if there are any other error logs before this error. If yes, please resolve the previous errors first. Some operator related issues (for example, TBE package is not installed properly on Ascend and NVCC not available on GPU) can cause subsequent such errors;
If the graph kernel fusion feature is used, it is possible that the AKG operator compilation of the graph is stuck and timed out, and you can try to turn off the graph kernel fusion feature;
You can try to reduce the number of processes for parallel compilation of operators on Ascend by using the environment variable MS_BUILD_PROCESS_NUM setting, with a value range of 1-24;
Check the memory and CPU usage of the host. It is possible that the host's memory and CPU usage are too high. As a result, the operator compilation process cannot be started and the compilation fails. You can try to identify the processes that occupy too much memory or CPU and optimize them;
If you encounter this issue in a training environment on the cloud, you can try restarting the kernel.
Operator Execution Errors
Operator execution errors are mainly caused by improper input data , operator implementation, or operator initialization. Generally, the analogy method can be used to analyze operator execution errors.
For details, see the following example:
MindSpore Operator Execution Error - nn.GroupNorm Operator Output Exception
Insufficient Resources
During network debugging, Out Of Memory
errors often occur. MindSpore divides the memory into four layers for management on the Ascend device, including runtime, context, dual cursors, and memory overcommitment.
For details about memory management and FAQs of MindSpore on the Ascend device, see MindSpore Ascend Memory Management.