Originaldatei zum Herunterladen(1.024 × 1.024 Pixel, Dateigröße: 143 KB, MIME-Typ: image/png)

Dieses Medium wird direkt von Wikimedia Commons aus eingebunden. Quellenangaben und Lizenzbedingungen befinden sich auf der unten zusätzlich eingeblendeten Commons-Beschreibungsseite.

Zur Commons-Seite

Beschreibung

Beschreibung
Italiano: Bak–Tang–Wiesenfeld sandpile, 28 million grains
Datum
Quelle Eigenes Werk
Urheber Claudio Rocchini

Lizenz

Ich, der Urheber dieses Werkes, veröffentliche es unter der folgenden Lizenz:
w:de:Creative Commons
Namensnennung
Diese Datei ist unter der Creative-Commons-Lizenz „Namensnennung 3.0 nicht portiert“ lizenziert.
Dieses Werk darf von dir
  • verbreitet werden – vervielfältigt, verbreitet und öffentlich zugänglich gemacht werden
  • neu zusammengestellt werden – abgewandelt und bearbeitet werden
Zu den folgenden Bedingungen:
  • Namensnennung – Du musst angemessene Urheber- und Rechteangaben machen, einen Link zur Lizenz beifügen und angeben, ob Änderungen vorgenommen wurden. Diese Angaben dürfen in jeder angemessenen Art und Weise gemacht werden, allerdings nicht so, dass der Eindruck entsteht, der Lizenzgeber unterstütze gerade dich oder deine Nutzung besonders.

Source Code

#include <stdio.h>
#include <stdlib.h>
#include <queue>

typedef unsigned char byte;
typedef std::pair<int,int> coord;
const int    N = 1024;
const size_t C = 4;
const size_t S = 28000000;

byte M[N][N];
const int dx[4] = {1,0,-1,0}; 
const int dy[4] = {0,1,0,-1};

int main() {
    memset(M,0,N*N);
	
    for(size_t steps=0;steps<S;++steps) {
        std::queue<coord> q;
        if( ++M[N/2][N/2]>=C ) q.push( coord(N/2,N/2) );
        while( !q.empty() ) {
            const int x = q.front().first;
            const int y = q.front().second;
            q.pop();
            if(M[x][y]<C) continue;
            M[x][y] -= 4;
            for(int d=0;d<4;++d) {
                const int lx = x+dx[d];
                const int ly = y+dy[d];
                if(lx<0 || lx>=N) continue;
                if(ly<0 || ly>=N) continue;
		if(++M[lx][ly]>=C) q.push( coord(lx,ly) );
            }
        }
    }

    const byte co[4][3] = { {255,255,255}, {255,0,0}, {0,255,0}, {0,0,255} };
    FILE * fo = fopen("backtang2.ppm","wb");
    fprintf(fo,"P6\n%d %d\n255\n",N,N);
    for(int x=0;x<N;++x) for(int y=0;y<N;++y)
        fwrite(co[M[x][y]],1,3,fo);
    fclose(fo);

    return 0;
}

Kurzbeschreibungen

Ergänze eine einzeilige Erklärung, was diese Datei darstellt.

In dieser Datei abgebildete Objekte

Motiv

image/png

f5e634e4c4716f43272e8c88965e575c784c5278

145.948 Byte

1.024 Pixel

1.024 Pixel

Dateiversionen

Klicke auf einen Zeitpunkt, um diese Version zu laden.

Version vomVorschaubildMaßeBenutzerKommentar
aktuell11:27, 7. Aug. 2012Vorschaubild der Version vom 11:27, 7. Aug. 20121.024 × 1.024 (143 KB)Rocchini

Die folgende Seite verwendet diese Datei:

Globale Dateiverwendung

Die nachfolgenden anderen Wikis verwenden diese Datei: