Fichier:Pinna's illusory intertwining effect.gif

Fichier d’origine (2 000 × 2 000 pixels, taille du fichier : 64 kio, type MIME : image/gif)

Ce fichier et sa description proviennent de Wikimedia Commons.

Description

Description
English: Pinna's illusory intertwining effect, described in Pinna, B., Gregory, R.L. (2002). "Shifts of Edges and Deformations of Patterns". Perception 31: 1503-1508. and Pinna illusion (scholarpedia) Actually, the circles are concentric.
Date
Source Travail personnel
Auteur Jochen Burghardt
Source code
typedef int xT;                      /* x coordinate */
typedef int yT;                      /* y coordinate */

#define pmWd            ((xT)2000)
#define pmHg            ((yT)2000)
#define pmX0            ((xT)pmWd/2)
#define pmY0            ((yT)pmHg/2)

static Pixmap pm;
static GC gcBlack;
static GC gcWhite;
static GC gcGrey;

static inline void rotatePoint(
    xT *xd,
    yT *yd,
    double al,
    xT xs,
    yT ys) 
{
    double const s = sin(al);
    double const c = cos(al);

    *xd = (xT)(xs * c - ys * s); 
    *yd = (yT)(xs * s + ys * c); 
}

static inline void doPinnaCircles(void)
{
    /* circle radiuses */
    double const rMin = 300.0;
    double const rInc = 200.0;
    double const rMax = 950;
    double r;
    /* square side length */
    double const S = 100.0;
    double const s = S * 0.7;
    double alInc = 2 * M_PI * 15 / 360;
    int i;

    XFillRectangle(dpy,pm,gcGrey,0,0,pmWd,pmHg);
    for (r=rMin; r <=rMax; r+=rInc) {
        /* currect radius such that an integer multiple of squares fits */
        double const p  = 2.0 * M_PI * r;
        int const cnt = floor(p/S/2.0) * 2;
        double const pc = cnt * S;
        xT const rc = (xT)(pc / 2.0 / M_PI);
        alInc = - alInc;
        for (i=0; i<cnt; i+=1) {
            /* angle to midpoint of i.th square */
            double const Al = 2.0 * M_PI * i / cnt;
            /* mid point of i.th square */
            xT const xx = pmX0 + (xT)(sin(Al) * rc);
            yT const yy = pmY0 + (yT)(cos(Al) * rc);
            /* edge angle of i.th square */
            double const al = Al + alInc;
            xT xa, xb, xc, xd;
            yT ya, yb, yc, yd;
            rotatePoint(&xa,&ya,-al,+s/2.0,+s/2.0);
            rotatePoint(&xb,&yb,-al,-s/2.0,+s/2.0);
            rotatePoint(&xc,&yc,-al,-s/2.0,-s/2.0);
            rotatePoint(&xd,&yd,-al,+s/2.0,-s/2.0);
            GC const gc = (i % 2 == 0 ? gcWhite : gcBlack);
            XDrawLine(dpy,pm,gc,xx+xa,yy+ya,xx+xb,yy+yb);
            XDrawLine(dpy,pm,gc,xx+xb,yy+yb,xx+xc,yy+yc);
            XDrawLine(dpy,pm,gc,xx+xc,yy+yc,xx+xd,yy+yd);
            XDrawLine(dpy,pm,gc,xx+xd,yy+yd,xx+xa,yy+ya);
        }
    }

    XImage * const im = XGetImage(dpy,pm,0,0,pmWd,pmHg,-1,ZPixmap);
    writePpmFile(stdout,"",im);                           /* library function to print XImage to FILE*, code not included here */
}

/* main() initializes Pixmap pm, and GC gcBlack, gcWhite, gcGrey using library functions, then calls doPinnaCircles(), code not included here */

Conditions d’utilisation

Moi, en tant que détenteur des droits d’auteur sur cette œuvre, je la publie sous la licence suivante :
w:fr:Creative Commons
paternité partage à l’identique
Ce fichier est disponible selon les termes de la licence Creative Commons Attribution – Partage dans les Mêmes Conditions 3.0 Non Transposé.
Vous êtes libre :
  • de partager – de copier, distribuer et transmettre cette œuvre
  • d’adapter – de modifier cette œuvre
Sous les conditions suivantes :
  • paternité – Vous devez donner les informations appropriées concernant l'auteur, fournir un lien vers la licence et indiquer si des modifications ont été faites. Vous pouvez faire cela par tout moyen raisonnable, mais en aucune façon suggérant que l’auteur vous soutient ou approuve l’utilisation que vous en faites.
  • partage à l’identique – Si vous modifiez, transformez ou vous basez sur cet élément, vous devez distribuer votre contribution sous une license identique ou compatible à celle de l’original.

Légendes

Ajoutez en une ligne la description de ce que représente ce fichier

Éléments décrits dans ce fichier

dépeint

Historique du fichier

Cliquer sur une date et heure pour voir le fichier tel qu'il était à ce moment-là.

Date et heureVignetteDimensionsUtilisateurCommentaire
actuel7 novembre 2013 à 21:00Vignette pour la version du 7 novembre 2013 à 21:002 000 × 2 000 (64 kio)Jochen BurghardtUser created page with UploadWizard

Usage global du fichier

Les autres wikis suivants utilisent ce fichier :

Métadonnées