Newtonův fraktál - Newton fractal

Julia nastavila racionální funkci spojenou s Newtonovou metodou pro ƒ: z → z3−1.

The Newtonův fraktál je hranice nastavena v složité letadlo který se vyznačuje Newtonova metoda aplikován na fixní polynomiální nebo transcendentální funkce. To je Julia set z meromorfní funkce což je dáno Newtonovou metodou. Pokud neexistují žádné atraktivní cykly (řádu většího než 1), rozdělí to komplexní rovinu na oblasti , z nichž každý je spojen s a vykořenit polynomu, . Tímto způsobem je Newtonův fraktál podobný Mandelbrotova sada, a stejně jako jiné fraktály vykazuje složitý vzhled vyplývající z jednoduchého popisu. Je to relevantní pro numerická analýza protože to ukazuje, že (mimo region kvadratická konvergence ) Newtonova metoda může být velmi citlivá na výběr výchozího bodu.

Mnoho bodů komplexní roviny je spojeno s jedním z kořeny polynomu následujícím způsobem: bod se použije jako počáteční hodnota pro Newtonovu iteraci , čímž se získá posloupnost bodů Pokud posloupnost konverguje do kořene , pak byl prvkem regionu . Pro každý polynom stupně nejméně 2 však existují body, u nichž Newtonova iterace nesbývá s žádným kořenem: příklady jsou hranice povodí přitažlivosti různých kořenů. Existují dokonce i polynomy, u nichž se otevřené sady výchozích bodů neshodují s žádným kořenem: jednoduchý příklad je , kde jsou některé body přitahovány cyklem 0, 1, 0, 1 ... spíše než kořenem.

Otevřená množina, pro kterou se iterace sbíhají k danému kořenu nebo cyklu (který není pevným bodem), je a Fatou set pro iteraci. Doplňkovou sadou ke spojení všech těchto je sada Julia. Sady Fatou mají společnou hranici, konkrétně sadu Julia. Proto je každý bod sady Julia bodem akumulace pro každou ze sad Fatou. Právě tato vlastnost způsobuje fraktální strukturu množiny Julia (když je stupeň polynomu větší než 2).

Chcete-li vykreslit zajímavé obrázky, je možné nejprve zvolit konkrétní počet složitých bodů a vypočítat koeficienty polynomu

.

Pak pro obdélníkovou mříž , , bodů v , jeden najde index příslušného kořene a používá to k vyplnění × rastrovou mřížku přiřazením ke každému bodu barva . Navíc nebo alternativně mohou barvy záviset na vzdálenosti , která je definována jako první hodnota takhle pro některé dříve pevné malé .

Zobecnění Newtonových fraktálů

Zobecnění Newtonovy iterace je

kde je jakékoli komplexní číslo.[1] Zvláštní volba odpovídá Newtonovu fraktálu. Pevné body této mapy jsou stabilní, když leží uvnitř disku o poloměru 1 se středem na 1. Když je mimo tento disk, pevné body jsou lokálně nestabilní, mapa však stále vykazuje fraktální strukturu ve smyslu Julia set. Li je polynom stupně , pak sekvence je ohraničený pokud je uvnitř disku o poloměru se středem na .

Obecněji je Newtonův fraktál zvláštním případem a Julia set.

Nova fraktál

Fraktál Nova vynalezený v polovině 90. let Paul Derbyshire,[2][3] je zobecnění Newtonova fraktálu s přidáním hodnoty v každém kroku:[4]

Varianta „Julia“ fraktálu Nova zůstává konstanta nad obrazem a inicializuje se na souřadnice pixelů. Inicializuje se „Mandelbrotova“ varianta fraktálu Nova k souřadnicím a sadám pixelů do kritického bodu, kde .[5] Běžně používané polynomy jako nebo vést ke kritickému bodu v .

Implementace

Aby bylo možné implementovat Newtonův fraktál, je nutné mít počáteční funkci i její derivační funkci:

Kořeny funkce jsou

Výše definované funkce lze přeložit do pseudokódu následujícím způsobem:

// z ^ 3-1 float2 Funkce (float2 z){	vrátit se cpow(z, 3) - float2(1, 0); // cpow je exponenciální funkce pro komplexní čísla}// 3 * z ^ 2float2 Derivát (float2 z){	vrátit se 3 * cmul(z, z); // cmul je funkce, která zpracovává násobení komplexních čísel}

Nyní jde jen o implementaci Newtonovy metody pomocí daných funkcí.

float2 kořeny[3] = // Kořeny (řešení) polynomu{	float2(1, 0), 	float2(-.5, čtv(3)/2), 	float2(-.5, -čtv(3)/2)};	barva barvy[3] =  // Přiřaďte barvu každému kořenu{    Červené,    zelená,    modrý}Pro každý pixel (X, y) na the cílová, dělat:{	zx = zmenšen X koordinovat z pixel (zmenšen na lhát v the Mandelbrot X měřítko (-2.5, 1))    z y = zmenšen y koordinovat z pixel (zmenšen na lhát v the Mandelbrot Y měřítko (-1, 1))    float2 z = float2(zx, z y); // Z je původně nastavena na souřadnice pixelů	pro (int opakování = 0;	     opakování < maxIterace;	     opakování++;)	{		z -= cdiv(Funkce(z), Derivát(z)); // cdiv je funkce pro dělení komplexních čísel        plovák tolerance = 0.000001;        		pro (int i = 0; i < kořeny.Délka; i++)		{		    plovák rozdíl = z - kořeny[i];		    			// Pokud je aktuální iterace dostatečně blízko kořenu, vybarvujte pixel.			-li (břišní svaly(rozdíl.X) < tolerance && břišní svaly (rozdíl.y) < tolerance)			{				vrátit se barvy[i]; // Vrátí barvu odpovídající kořenu			}		}		    }        vrátit se Černá; // Pokud není nalezeno žádné řešení}

Viz také

Reference

  1. ^ Simon Tatham. „Fraktály odvozené z Newton – Raphsona“.
  2. ^ Damien M. Jones. "třída Standard_NovaMandel (odkaz na ultra fraktální vzorec)".
  3. ^ Damien M. Jones. "dmjovy nové fraktály 1995-6".
  4. ^ Michael Condron. „Uvolněná Newtonova metoda a Nova Fractal“.
  5. ^ Frederik Slijkerman. „Ultra fraktální příručka: Nova (Julia, Mandelbrot)“.

Další čtení