StartAlgorytmyFraktaleZbiór Julii
Baza Wiedzy
Wersja offline serwisu przeznaczona na urządzenia z systemem Android.

Darowizny
darowiznaWspomóż rozwój serwisu


Nagłówki RSS
Kanał artykuły
Kanał implementacje
Kanał komentarze
Kanał forum


Bookmarki









Sonda
Implementacji w jakim języku programowania poszukujesz?
 
Zbiór Julii
Ocena użytkowników:++++- / 11
SłabyŚwietny 
Wpisany przez Tomasz Lubiński
poniedziałek, 18 sierpnia 2008 22:46
Nazwa zbioru Julii (ang. Julia Set) pochodzi od nazwiska jego odkrywcy - francuskiego matematyka Gastona Julii. By zdefiniować zbiór Julii, zdefiniujemy najpierw dla danej stałej c oraz danego punktu p na płaszczyźnie zespolonej nieskończony ciąg liczb zespolonych z0, z1, z2, ... o wartościach zdefiniowanych następująco:
z0 = p
zn+1 = zn2 + c

Julia zauważył, iż dla pewnych punktów p ciąg ten jest ograniczony - nie dąży do nieskończoności, a dla innych ciąg taki jest nieograniczony - dąży do nieskończoności. Zbiory takich punktów nazywa się odpowiednio zbiorem więźniów - dla ciągów ograniczonych oraz zbiorem uciekinierów - dla ciągów nieograniczonych. Oba te zbiory są niepuste i dopełniające się na płaszczyźnie zespolonej, zatem istnieje tylko ich jedna, wspólna granica. Zbiór Julii definiujemy jako zbiór liczb zespolonych p takich, że zdefiniowany powyżej ciąg nie dąży do nieskończoności, czyli jest to zbiór więźniów.

Brzeg tego zbioru jest fraktalem. Po raz pierwszy pojęcie fraktala zostało użyte przez Benoit Mandelbrota w latach 70-tych XX wieku. Po łacinie fractus oznacza podzielny, ułamkowy, cząstkowy. Nazwa ta nie ma ścisłej matematycznej definicji. Oznacza ona obiekty, które mają nietrywialną strukturę w każdej skali oraz są samopodobne - czyli każda ich część przypomina całość. W praktyce by narysować fraktale oblicza się kolejne przybliżenia zbioru, które oznacza się różnymi kolorami. I tak kolejne przybliżenia zdefiniujemy jako zbiór liczb zespolonych p takich, że:
  • 1 przybliżenie: wszystkie punkty
  • 2 przybliżenie: |z1| < 2
  • 3 przybliżenie: |z1| < 2 oraz |z2| < 2
  • 4 przybliżenie: |z1| < 2 oraz |z2| < 2 oraz |z3| < 2
  • ...
  • n-te przybliżenie: |z1| < 2 oraz |z2| < 2, ... |zn-1| < 2


Zatem funkcję obliczającą w jakim maksymalnym przybliżeniu dany punkt p należy do zbioru Julii dla stałej c możemy zdefiniować następująco (gdzie maxIter to maksymalne przybliżenie z jakim chcemy wyznaczać zbiór):

przyblizenie(p, c)
begin
  iter := 0;
  z := p;

  repeat
     iter := iter + 1;
     z = z^2 + c;
  until (|z| < 2) and (iter < maxIter)

  przyblizenie = iter;
end;


Przypomnijmy jeszcze działania na liczbach zespolonych jakie będziemy potrzebować podczas obliczeń. Liczba zespolona z składa się z części rzeczywistej zr oraz części urojonej zi, czyli z = zr + i zi.
Potęgowanie definiujemy następująco:
z2 = (zr2 - zi2) + i(2 zr zi)
Dodawanie definiujemy następująco:
a + b = (ar + br) + i(ai + bi)
Moduł z liczby zespolonej definiujemy następująco:
moduł liczby zespolonej |z|=\sqrt{z_{r}^{2}+z_{i}^{2}} ,
dlatego też w praktyce warunek |z| < 2 zastępuje się równoważną nierównością (zr2 + zi2) < 4. Pozbywamy się tutaj czasochłonnego obliczania pierwiastka kwadratowego.

Dla kolejnych punktów na płaszczyźnie, obliczamy przybliżenia zgodnie z podanym algorytmem i wzorami. Oś X oznacza wartości rzeczywiste, natomiast os Y wartości urojone. Przedstawiając kolejne przybliżenia na płaszczyźnie i oznaczając je różnymi kolorami otrzymujemy wynik - zbiór Julii. kolory kolejnych przybliżeń wyznaczono zgodnie z modelem HSV,ale można też użyć do tego celu odcieni szarości, bądź innego modelu barw. W zależności od parametru c zbiór ten może przybierać różne formy. Poniżej kilka najbardziej znanych przykładów (lewy górny róg ma współrzędne -1.5 -1.25i, dolny prawy róg ma współrzędne 1.5 + 1.25i):

  • the Douady's Rabbit Fractal, zwany też czasem the Dragon Fractal - wartość parametru c = -0.123 + 0.745i
    Zbiór Julii - the Douady's Rabbit Fractal
  • the San Marco Fractal - wartość parametru c = -0.75
    Zbiór Julii - the San Marco Fractal
  • the Siegel Disk Fractal - wartość parametru c = -0.390541 - 0.586788i
    Zbiór Julii - the Siegel Disk Fractal
  • the Dendrite Fractal - wartość parametru c = i
    Zbiór Julii - the Dendrite Fractal


Przykład w JavaScript:
Zaznaczając obszar uzyskasz jego powiększony obraz. Kliknięcie prawym klawiszem (bądź dotknięcie dwoma palcami na urządzeniach z ekranem dotykowym) spowoduje powtórne pokazanie całego zbioru.
Część rzeczywista parameteru c:
Część urojona parameteru c:



Autor Język programowania Komentarz Otwórz Pobierz Ocena
Tomasz Lubiński C# MS Visual Studio .net
Implementacja w C#
Implementacja w C#
++++- / 3
Tomasz Lubiński C/C++ Borland Builder 6
Implementacja w C/C++
Implementacja w C/C++
++++- / 2
Tomasz Lubiński Delphi/Pascal Borland Delphi 5
Implementacja w Delphi/Pascal
Implementacja w Delphi/Pascal
++++- / 1
Tomasz Lubiński Java Script Firefox 3.0+, Safari 3.0+, Chrome 3.0+, Opera 9.5+, IE 9.0+
Implementacja w Java Script
Implementacja w Java Script
+++++ / 1
 
Dodaj własną implementację tego algorytmu
  • Zaloguj się na stronie
Plik:
Język programowania:
Komentarz:
  By móc dodać implementacje zaloguj się na stronie



Poprawiony: środa, 11 stycznia 2012 21:40

Dodaj komentarz

Kod antysapmowy
Odśwież