How to convolve a 3D matrix along one of its dimension?

조회 수: 32 (최근 30일)
Yuxin Tong
Yuxin Tong 2022년 4월 26일
댓글: Yuxin Tong 2022년 4월 27일
I have a 100by100by2000 ish matrix, say 3rd dimention is representing time where the 100*100 matrix changes. I wanted to convolve this whole matrix through a temporal gaussian filter along the 3rd dimention (the one that is 2000ish long).
With the code I know of I can only think of making a for-loop and do conv() 10000 times. (cuz I believe conv() can only operat on single dimention vectors?) However this for-loop will then be extremely long and it seems like it would take forever to run. I have attached a visual illustration of what I wanted to do.
So my question is: is there a function that is equivilent to conv() that can allow me to do this in more eifficient way? Or can I actually make conv() to run in a vectorized way?
I am aware that there is a fucntion called filter(), but I wasnt really sure what does that function do. If filter actually would work can anyone tell me what is the similarity and difference between filter and conv?
Thx a lot.

채택된 답변

Matt J
Matt J 2022년 4월 26일
If your Gaussian kernels is 1x1xN, you can just use convn as usual
kernel=reshape(gaussianProfile,1,1,[]);
output=convn(Array, kernel);

추가 답변 (3개)

Akira Agata
Akira Agata 2022년 4월 26일
The function smoothdata must be applicable, like:
% Sample data
A = rand(100, 100, 2000);
% Gaussian filter window
win = 15;
% Apply smoothdata along 3rd dimension
dim = 3;
A2 = smoothdata(A, dim, 'gaussian', win);
% Let's check!
figure
plot(squeeze(A(1, 1, :)),'c')
hold on
plot(squeeze(A2(1, 1, :)),'b')
legend({'Original', 'After filtering'})
title('Signal A(1,1,:)')

Matt J
Matt J 2022년 4월 26일
You can use ffts
kernel=reshape(gaussianProfile,1,1,[]);
N=size(Array,3)+size(kernel,3)-1;
F=@(z)fft(z,N,3);
invF=@(z)ifft(z,[],3,'symmetric');
kernel=reshape(gaussianProfile,1,1,[]);
output = invF( F(kernel).*F(Array) );

Matt J
Matt J 2022년 4월 26일
편집: Matt J 2022년 4월 26일
If you have the Image Processing Toolbox, you can use imgaussfilt3,
output = imgaussfilt3(Array,[.1,.1,sigma]);

카테고리

Help CenterFile Exchange에서 Matched Filter and Ambiguity Function에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by