!c99Shell v. 1.0 pre-release build #16!

Software: Apache/2.2.3 (CentOS). PHP/5.1.6 

uname -a: Linux mx-ll-110-164-51-230.static.3bb.co.th 2.6.18-194.el5PAE #1 SMP Fri Apr 2 15:37:44
EDT 2010 i686
 

uid=48(apache) gid=48(apache) groups=48(apache) 

Safe-mode: OFF (not secure)

/usr/share/gimp/2.0/help/fr/   drwxr-xr-x
Free 50.9 GB of 127.8 GB (39.83%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     plug-in-convmatrix.html (15.89 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
7.2.  Matrice de convolution

7.2.  Matrice de convolution

7.2.1.  Généralités

On accède à ce filtre par le menu d'image en suivant FilteresGénériqueMatrice de Convolution

Nous sommes là dans le coin des mathématiciens. La plupart des filtres de traitement des images utilisent des matrices de convolution. Avec le filtre Matrice de convolution, vous pouvez, si le coeur vous en dit, vous concocter un petit filtre sur mesure.

Mais qu'est-ce que c'est qu'une matrice de convolution? On peut s'en faire une idée approximative sans utiliser les outils mathématiques que bien peu connaissent. Une convolution est un traitement d'une matrice par une autre appelée matrice de convolution ou «noyau» (kernel).

Notre filtre «Matrice de convolution» utilise une première matrice qui est l'image, c-à-d une collection de pixels en coordonnées rectangulaires 2D (il y a des matrices 3D...), et un noyau variable selon l'effet souhaité.

Gimp utilise des matrices de convolution 5x5 ou 3x3. Nous nous limiterons aux matrices 3x3, les plus utilisées. Elles suffisent à tous les effets recherchés. Si toutes les cases des bords du noyau sont à 0, le système considère qu'il s'agit d'une matrice 3x3.

Le filtre étudie successivement chacun des pixels de l'image. Pour chaque pixel, que nous appellerons «pixel initial», il multiplie la valeur de ce pixel et de chacun des 8 pixels qui l'entourent par la valeur correspondante dans le noyau. Il additionne l'ensemble des résultats et le pixel initial prend alors la valeur du résultat final.

Vite un exemple, simple:

À gauche se trouve la matrice de l'image: chaque pixel est indiqué par sa valeur. Le pixel initial est encadré de rouge. La zone d'action du noyau est encadré de vert. Au centre, se trouve le noyau et, à droite, le résultat de la convolution.

Voici ce qui s'est passé: le filtre a lu successivement, de gauche à droite et de haut en bas, les pixels de la zone d'action du noyau et il a multiplié chacun d'eux par la valeur correspondante du noyau et additionné les résultats: (100*0)+(50*1)+(50*0)*(100*0)+(100*0) +(100*0)+(100*0)+(100*0)+(100*0)+(100*0) = 50. Le pixel initial a pris la valeur 50. Précédemment, quand le pixel initial a eu la valeur 50, il a pris la valeur 100 du pixel au dessus (le filtre dépose ses résultats sur une copie de l'image et pas directement dans l'image) et s'est fondu dans l'arrière-plan 100. Le résultat graphique est un décalage du pixel initial d'un pixel vers le bas.

7.2.2.  Options

Matrice

C'est la matrice 5x5 du noyau que vous voulez créer: vous entrez les valeurs voulues directement dans les cases.

Diviseur: le résultat du calcul précédent sera divisé par ce diviseur. Vous n'utiliserez guère que 1 qui laisse le résultat inchangé, et 9 ou 25 selon la taille de la matrice utilisée, ce qui donne la moyenne de la valeur des pixels.

Décalage: cette valeur est ajoutée au résultat de la division. C'est utile si le résultat risque d'être négatif. Le Décalage peut être négatif.

Bordure

Source, Étendre, Enrouler, Rogner

Quand le pixel initial est sur un bord, une partie du noyau porte en dehors des limites de l'image. Vous devez décider de ce que doit faire le filtre. Dans les exemples ci-dessous, le noyau simple de déplacement décrit plus haut a été appliqué plusieurs fois, grâce à Ctrl-F, à l'image:

  • Étendre: cette partie du noyau n'est pas prise en compte. Des pixels disparaissent. La ligne libérée est remplacée par une extension de la ligne suivante.

  • Enrouler: cette partie du noyau étudiera les pixels du bord opposé, ce qui équivaut à faire réapparaître de l'autre côté les pixels qui disparaissent d'un côté.

  • Rogner: Les pixels situés en bordure disparaissent et les parties libérées sont transparentes. Si l'option Poids Alpha n'est pas cochée et si l'image n'a pas de canal alpha, cette option est en grisé.

Canaux

Vous pouvez choisir là le ou les canaux sur lesquels agira le filtre.

Automatique

Quand cette option est cochée, le Diviseur prend la valeur du résultat du calcul de convolution. Si ce résultat est égal à 0 (on ne peut pas diviser par 0), un Décalage de 128 est appliqué. S'il est négatif (on ne peut pas avoir de couleur négative), c'est un décalage de 255 qui est appliqué (ce qui inverse le résultat).

Poids alpha

Si cette option n'est pas cochée, le calcul ne tient pas compte du degré de transparence des couleurs, ce qui peut être cause d'artéfacts lors de l'application d'un flou.

7.2.3.  Exemples

La création de noyaux nécessite des connaissances mathématiques de haut niveau. Mais vous en trouverez de tout faits sur la Toile. En voici quelques exemples:

Figure 11.41.  Augmenter le contraste

Augmenter le contraste
Augmenter le contraste

Figure 11.42.  Flou

Flou
Flou

Figure 11.43.  Amélioration des phrase

Amélioration des phrase
Amélioration des phrase

Figure 11.44.  Détection des bords

Détection des bords
Détection des bords

Figure 11.45.  Repoussage

Repoussage
Repoussage

:: Command execute ::

Enter:
 
Select:
 

:: Shadow's tricks :D ::

Useful Commands
 
Warning. Kernel may be alerted using higher levels
Kernel Info:

:: Preddy's tricks :D ::

Php Safe-Mode Bypass (Read Files)

File:

eg: /etc/passwd

Php Safe-Mode Bypass (List Directories):

Dir:

eg: /etc/

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c999shell v. 1.0 pre-release build #16 Modded by Shadow & Preddy | RootShell Security Group | r57 c99 shell | Generation time: 0.0096 ]--