ランダムに生成されたピンク ノイズを含む任意のサイズの 2D 画像を生成したいと思います。 ウィキペディアは、ピンク ノイズの 2D 一般化が 1/f^2 として低下するエネルギーを持つことを示唆しています。MATLAB File Exchangeで、1D ピンク ノイズ ベクトルを計算するコードを見つけました。しかし、それを 2 次元に適切に一般化する方法がわかりません。私は fft にあまり詳しくありません。以下の単純な試みでは、ifft を計算すると複雑なベクトルが生成されます。
function pink = pinkNoiseImage(nrow,ncol)
rnrow = 2.^(ceil(log2(nrow)));
rncol = 2.^(ceil(log2(ncol)));
r = randn(rnrow,rncol);
rf = fft(r);
rnup = rnrow/2+1;
cnup = rncol/2+1;
frf = kron(1./sqrt(1:cnup),1./sqrt(1:rnup)');
rf(1:rnup,1:cnup) = rf(1:rnup,1:cnup).*frf;
rf(rnup+1:rnrow,1:cnup) = real(frf(rnrow/2:-1:2,1:cnup))-1i*imag(frf(rnrow/2:-1:2,1:cnup));
rf(1:rnup,cnup+1:rncol) = real(frf(1:rnup,rncol/2:-1:2))-1i*imag(frf(1:rnup,rncol/2:-1:2));
rf(rnup+1:rnrow,cnup+1:rncol) = real(frf(rnrow/2:-1:2,rncol/2:-1:2))-1i*imag(frf(rnrow/2:-1:2,rncol/2:-1:2));
pink = ifft(rf);
ピンク ノイズを含む 2D マトリックスを生成するにはどうすればよいですか?