In my code, somewhere, I generate a gpuArray matrix with a size of 331x331x331x32, (single float) and I want to get an fftn from the array in a for loop. I have a 24GB TITAN RTX GPU, and before getting each fftn, I have 10 GB free on the GPU. But, when I run the code, it can calculate it without problem, but for the second loop, it returns:
An invalid FFT plan was used on the GPU.
If I pause the code and rerun the fftn, it works fine, but again, I get the error for the next loop, and the same story goes for the next loops!
I also tried the reset(gpuDevice(1)) before each for loop and noticed when I have this pice before each iteration, I will get the error, and if I run it twice, the problem will be solved! Would you please explain to me why I have this problem?

 채택된 답변

Matt J
Matt J 2021년 3월 28일
편집: Matt J 2021년 3월 28일

1 개 추천

before getting each fftn, I have 10 GB free on the GPU
But wit the array dimensions you've mentioned the result will consume more than 17 GB in double floating point.
331^3*64*8/2^30
ans = 17.2924
You could try using single floats, but it will be a tight squeeze.

댓글 수: 6

Mojtaba Zarei
Mojtaba Zarei 2021년 3월 28일
편집: Mojtaba Zarei 2021년 3월 28일
Sorry I missed to mention that I have a single floats data! I already have single float data and get these errors!
Matt J
Matt J 2021년 3월 28일
Are you clearing memory on subsequent iterations of the loop? Like I said, it's a tight squeeze. Even with single floats, you will only have enough memory to hold the output - we are not sure about what temporary memory space fftn requires.
Mojtaba Zarei
Mojtaba Zarei 2021년 3월 28일
편집: Mojtaba Zarei 2021년 3월 28일
I use "gather" to store back the data on the CPU and do not clear anything after that. I assumed using "gather," I will clear the memory on the GPU? Should I remove all the gpu variables at the end of each loop?
I even used "reset(gpuArray(1))" before the fftn and I got the same errors!
Matt J
Matt J 2021년 3월 28일
편집: Matt J 2021년 3월 28일
A statement like
A=gather(A)
should erase the gpuArray copy of A, but
B=gather(A)
will not. It will just create a copy of A on the CPU.
Matt J
Matt J 2021년 3월 29일
Incidentally, you might find whosGPU useful
for an approximate idea of how much memory is consumed by your gpuArray variables on the GPU.
Mojtaba Zarei
Mojtaba Zarei 2021년 3월 29일
Thank you Matt, I figured out how to free the memory before the fftn function. Now, it works fine!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 GPU Computing에 대해 자세히 알아보기

태그

질문:

2021년 3월 28일

댓글:

2021년 3월 29일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by