【问题标题】:CUDA_ERROR_ILLEGAL_ADDRESS when runnin Faster R-CNN on Matlab在 Matlab 中运行 Faster R-CNN 时的 CUDA_ERROR_ILLEGAL_ADDRESS
【发布时间】:2018-11-10 22:07:28
【问题描述】:

我在 Windows 10 上的 matlab 2018b 中运行更快的 R-CNN。当我增加训练项目的数量或增加 MaxEpoch 时,我遇到了异常 CUDA_ERROR_ILLEGAL_ADDRESS

以下是我gpuDevice的资料

  CUDADevice with properties:

                  Name: 'GeForce GTX 1050'
                 Index: 1
     ComputeCapability: '6.1'
        SupportsDouble: 1
         DriverVersion: 9.2000
        ToolkitVersion: 9.1000
    MaxThreadsPerBlock: 1024
      MaxShmemPerBlock: 49152
    MaxThreadBlockSize: [1024 1024 64]
           MaxGridSize: [2.1475e+09 65535 65535]
             SIMDWidth: 32
           TotalMemory: 4.2950e+09
       AvailableMemory: 3.4635e+09
   MultiprocessorCount: 5
          ClockRateKHz: 1493000
           ComputeMode: 'Default'
  GPUOverlapsTransfers: 1
KernelExecutionTimeout: 1
      CanMapHostMemory: 1
       DeviceSupported: 1
        DeviceSelected: 1

这是我的代码

latest_index =0;

for i=1:6

load (strcat('newDataset', int2str(i), '.mat')); 
len =length(vehicleDataset.imageFilename);

for j=1:len

filename = vehicleDataset.imageFilename{j};
latest_index=latest_index+1;
fulldata.imageFilename{latest_index} = filename;
fulldata.vehicle{latest_index} = vehicleDataset.vehicle{j};

end
end 

trainingDataTable = table(fulldata.imageFilename', fulldata.vehicle');
trainingDataTable.Properties.VariableNames = {'imageFilename','vehicle'};

data.trainingDataTable = trainingDataTable;
trainingDataTable(1:4,:)


% Split data into a training and test set.
idx = floor(0.6 * height(trainingDataTable));

trainingData = trainingDataTable(1:idx,:);
testData = trainingDataTable(idx:end,:);

% Create image input layer.
inputLayer = imageInputLayer([32 32 3]);

% Define the convolutional layer parameters.
filterSize = [3 3];

numFilters = 64;

% Create the middle layers.
middleLayers = [

convolution2dLayer(filterSize, numFilters, 'Padding', 1)   
reluLayer()
convolution2dLayer(filterSize, numFilters, 'Padding', 1)  
reluLayer() 
maxPooling2dLayer(3, 'Stride',2)
];

finalLayers = [

fullyConnectedLayer(128)
% Add a ReLU non-linearity.
reluLayer()

fullyConnectedLayer(width(trainingDataTable))
% Add the softmax loss layer and classification layer. 
softmaxLayer()
classificationLayer()
];

layers = [
inputLayer
middleLayers
finalLayers
];

% Options for step 1.
 optionsStage1 = trainingOptions('sgdm', ...
 'MaxEpochs', 2, ...
 'MiniBatchSize', 1, ...
 'InitialLearnRate', 1e-3, ...
 'CheckpointPath', tempdir);

% Options for step 2.
optionsStage2 = trainingOptions('sgdm', ...
'MaxEpochs', 2, ...
'MiniBatchSize', 1, ...
'InitialLearnRate', 1e-3, ...
'CheckpointPath', tempdir);

% Options for step 3.
optionsStage3 = trainingOptions('sgdm', ...
'MaxEpochs', 2, ...
'MiniBatchSize', 1, ...    
'InitialLearnRate', 1e-3, ...
'CheckpointPath', tempdir);

% Options for step 4.
optionsStage4 = trainingOptions('sgdm', ...
'MaxEpochs', 2, ...
'MiniBatchSize', 1, ...
'InitialLearnRate', 1e-3, ...
'CheckpointPath', tempdir);

 options = [
 optionsStage1
 optionsStage2
 optionsStage3
 optionsStage4
 ];

 doTrainingAndEval = true;

if doTrainingAndEval
 % Set random seed to ensure example training reproducibility.
 rng(0);

 % Train Faster R-CNN detector. Select a BoxPyramidScale of 1.2 to allow
 % for finer resolution for multiscale object detection.
 detector = trainFasterRCNNObjectDetector(trainingData, layers, options, ...
    'NegativeOverlapRange', [0 0.3], ...
    'PositiveOverlapRange', [0.6 1], ...
    'BoxPyramidScale', 1.2);

 data.detector= detector;
else

% Load pretrained detector for the example.
detector = data.detector;

end

save mix_data data

if doTrainingAndEval

% Run detector on each image in the test set and collect results.

resultsStruct = struct([]);

for i = 1:height(testData)
 % Read the image.
    I = imread(testData.imageFilename{i});
    % Run the detector.
    [bboxes, scores, labels] = detect(detector, I);

    % Collect the results.
    resultsStruct(i).Boxes = bboxes;
    resultsStruct(i).Scores = scores;
    resultsStruct(i).Labels = labels;
end

% Convert the results into a table.
results = struct2table(resultsStruct);

data.results = results;

save mix_data data

else

% Load results from disk.
results = data.results;
end

% Extract expected bounding box locations from test data.
expectedResults = testData(:, 2:end);

% Evaluate the object detector using Average Precision metric.
[ap, recall, precision] = evaluateDetectionPrecision(results, expectedResults);

% Plot precision/recall curve
figure
plot(recall,precision)

xlabel('Recall')
ylabel('Precision')

grid on
title(sprintf('Average Precision = %.2f', ap))

首先它会多次打印警告并抛出以下异常

警告:CUDA 执行期间发生意外错误。 CUDA 错误是: CUDA_ERROR_ILLEGAL_ADDRESS 在 trainFasterRCNNObjectDetector 中(第 320 行) 在 rcnn_trail(第 184 行)

错误使用 - CUDA 执行期间发生意外错误。 CUDA 错误是: CUDA_ERROR_ILLEGAL_ADDRESS

vision.internal.cnn.layer.SmoothL1Loss/backwardLoss 中的错误(第 156 行) idx = (X > -one) & (X

nnet.internal.cnn.DAGNetwork 中的错误>@()efficientBackProp(i)(第 661 行) @() 高效BackProp(i), ...

nnet.internal.cnn.util.executeWithStagedGPUOOMRecovery 中的错误(第 11 行) [ varargout{1:nOutputs} ] = computeFun();

nnet.internal.cnn.DAGNetwork 中的错误>iExecuteWithStagedGPUOOMRecovery(第 1195 行) [varargout{1:nargout}] = nnet.internal.cnn.util.executeWithStagedGPUOOMRecovery(varargin{:});

nnet.internal.cnn.DAGNetwork/computeGradientsForTraining 中的错误(第 660 行) 这些梯度 = iExecuteWithStagedGPUOOMRecovery( ...

nnet.internal.cnn.Trainer/computeGradients 中的错误(第 184 行) [梯度、预测、状态] = net.computeGradientsForTraining(X, Y, 需要状态训练,传播状态);

nnet.internal.cnn.Trainer/train 中的错误(第 85 行) [梯度、预测、状态] = this.computeGradients(net, X, response, 需要状态训练,传播状态);

vision.internal.cnn.trainNetwork 中的错误(第 47 行) trainedNet = trainer.train(trainedNet, trainingDispatcher);

fastRCNNObjectDetector.train 中的错误(第 190 行) [网络,信息] = vision.internal.cnn.trainNetwork(ds, lgraph, opts, mapping, checkpointSaver);

trainFasterRCNNObjectDetector 中的错误(第 410 行) [stage2Detector, fastRCNN, ~, info(2)] = fastRCNNObjectDetector.train(trainingData, fastRCNN, options(2), iStageTwoParams(params), checkpointSaver);

rcnn_trail 中的错误(第 184 行) 检测器 = trainFasterRCNNObjectDetector(trainingData, 层, 选项, ...

【问题讨论】:

    标签: matlab deep-learning


    【解决方案1】:

    在与 Matlab 支持人员交谈后,显然我的 GPU 不是深度学习和神经网络的“正确”GPU。

    但是,我发现问题是 Windows 在运行期间更改了 GPU,为了解决这个问题,我去了 INVIDIA 控制面板 > 程序设置 > 1.选择Mathworks Matlab 2.首选图形处理器选择您的GPU卡

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-01-03
      • 2018-02-24
      • 2021-03-26
      • 2020-02-10
      • 1970-01-01
      • 2020-08-19
      • 2021-04-27
      • 1970-01-01
      相关资源
      最近更新 更多