(PECL imagick 3 >= 3.3.0)
Imagick::forwardFourierTransformImage — Implémente la transformée de Fourier discrète (Discrete Fourier Transform - DFT)
Implémente la transformée de Fourier discrète (DFT) de l'image soit en tant que paire d'images magnitude / phase, soit en tant que paire d'images réelles / imaginaires.
magnitude
Si vrai, retourne en tant que paire magnitude / phase, sinon une paire d'images réelles / imaginaires.
Retourne true
en cas de succès.
Exemple #1 Imagick::forwardFourierTransformImage()
<?php
//Utility function for forwardTransformImage
function createMask() {
$draw = new \ImagickDraw();
$draw->setStrokeOpacity(0);
$draw->setStrokeColor('rgb(255, 255, 255)');
$draw->setFillColor('rgb(255, 255, 255)');
// Désine un cercle sur l'axe des y, avec son centre
// à x, y qui touche l'origine
$draw->circle(250, 250, 220, 250);
$imagick = new \Imagick();
$imagick->newImage(512, 512, "black");
$imagick->drawImage($draw);
$imagick->gaussianBlurImage(20, 20);
$imagick->autoLevelImage();
return $imagick;
}
function forwardFourierTransformImage($imagePath) {
$imagick = new \Imagick(realpath($imagePath));
$imagick->resizeimage(512, 512, \Imagick::FILTER_LANCZOS, 1);
$mask = createMask();
$imagick->forwardFourierTransformImage(true);
@$imagick->setimageindex(0);
$magnitude = $imagick->getimage();
@$imagick->setimageindex(1);
$imagickPhase = $imagick->getimage();
if (true) {
$imagickPhase->compositeImage($mask, \Imagick::COMPOSITE_MULTIPLY, 0, 0);
}
if (false) {
$output = clone $imagickPhase;
$output->setimageformat('png');
header("Content-Type: image/png");
echo $output->getImageBlob();
}
$magnitude->inverseFourierTransformImage($imagickPhase, true);
$magnitude->setimageformat('png');
header("Content-Type: image/png");
echo $magnitude->getImageBlob();
}
?>