Integrace verletů - Verlet integration
Integrace verletů (Francouzská výslovnost:[vɛʁˈlɛ]) je numerická metoda zvyklá na integrovat Newton pohybové rovnice.[1] Často se používá k výpočtu trajektorie částic v molekulární dynamika simulace a počítačová grafika. Algoritmus byl poprvé použit v roce 1791 uživatelem Delambre a od té doby byl znovuobjeven mnohokrát, naposledy uživatelem Loup Verlet v 60. letech pro použití v molekulární dynamice. To bylo také používáno Cowell a Krommelin v roce 1909 vypočítat oběžnou dráhu Halleyova kometa, a tím Carl Størmer v roce 1907 ke studiu trajektorií elektrických částic v a magnetické pole (proto se také nazývá Störmerova metoda).[2]Integrátor Verlet poskytuje dobré numerická stabilita, stejně jako další vlastnosti, které jsou důležité v fyzické systémy jako časová reverzibilita a uchování symplektické formy ve fázovém prostoru, bez podstatných dodatečných výpočetních nákladů oproti jednoduchému Eulerova metoda.
Základní Störmer – Verlet
Pro diferenciální rovnice druhého řádu typu s počátečními podmínkami a , přibližné numerické řešení v té době s velikostí kroku lze získat následující metodou:
- soubor ,
- pro n = 1, 2, ... iterovat
Pohybové rovnice
Newtonova pohybová rovnice pro konzervativní fyzikální systémy je
nebo jednotlivě
kde
- t je čas,
- je soubor vektoru polohy N předměty,
- PROTI je funkce skalárního potenciálu,
- F je negativní gradient potenciálu, dávající soubor sil na částice,
- M je hmotnostní matice, obvykle diagonální s bloky s hmotou pro každou částici.
Tato rovnice pro různé možnosti potenciální funkce PROTI, lze použít k popisu vývoje různých fyzikálních systémů od pohybu interagující molekuly do oběžná dráha planet.
Po transformaci, která přivede hmotu na pravou stranu a zapomene na strukturu více částic, lze rovnici zjednodušit
s nějakou vhodnou funkcí s vektorovou hodnotou A představující zrychlení závislé na poloze. Obvykle počáteční poloha a počáteční rychlost jsou také uvedeny.
Integrace verletů (bez rychlostí)
To diskretizovat a číselně vyřešit problém počáteční hodnoty, časový krok je vybrána sekvence bodu vzorkování považováno. Úkolem je sestrojit posloupnost bodů které přesně sledují body na trajektorii přesného řešení.
Kde Eulerova metoda používá vpřed rozdíl aproximace první derivace v diferenciálních rovnicích prvního řádu, lze Verletovu integraci považovat za použití centrální rozdíl aproximace druhé derivace:
Integrace verletů ve formě použité jako Störmerova metoda[3] používá tuto rovnici k získání dalšího pozičního vektoru z předchozích dvou bez použití rychlosti jako
Chyba diskretizace
Časová symetrie vlastní metodě snižuje úroveň lokálních chyb zavedených do integrace diskretizací odstraněním všech lichých stupňů, zde jsou podmínky v stupně tři. Místní chyba se kvantifikuje vložením přesných hodnot do iterace a výpočtu Taylorovy expanze v čase vektoru polohy v různých časových směrech:
kde je pozice, rychlost, zrychlení a the blbec (třetí derivace pozice s ohledem na čas).
Sčítání těchto dvou rozšíření dává
Vidíme, že termíny prvního a třetího řádu z Taylorovy expanze se ruší, čímž se Verletův integrátor stává objednávkou přesnější než integrace samotnou Taylorovou expanzí.
Je třeba věnovat pozornost skutečnosti, že zrychlení je zde počítáno z přesného řešení, vzhledem k tomu, že v iteraci se počítá v centrálním iteračním bodě, . Při výpočtu globální chyby, tj. Vzdálenosti mezi přesným řešením a posloupností aproximace, se tyto dva pojmy nezruší přesně, což ovlivňuje pořadí globální chyby.
Jednoduchý příklad
Chcete-li získat přehled o vztahu místních a globálních chyb, je užitečné prozkoumat jednoduché příklady, kde přesné řešení i přibližné řešení lze vyjádřit v explicitních vzorcích. Standardní příklad pro tento úkol je exponenciální funkce.
Zvažte lineární diferenciální rovnici s konstantou w. Jeho přesná základní řešení jsou a .
Störmerova metoda použitá na tuto diferenciální rovnici vede k lineární relace opakování
nebo
To lze vyřešit nalezením kořenů jeho charakteristického polynomu. Tyto jsou
Základní řešení lineární rekurence jsou a . Aby bylo možné je porovnat s přesnými řešeními, počítají se Taylorovy expanze:
Kvocient této řady s exponenciálním začíná s , tak
Odtud vyplývá, že pro první základní řešení lze chybu vypočítat jako
To znamená, že i když je lokální diskretizační chyba řádu 4, kvůli druhému řádu diferenciální rovnice je globální chyba řádu 2 s konstantou, která v čase roste exponenciálně.
Spuštění iterace
Všimněte si, že na začátku Verletovy iterace v kroku , čas , výpočetní , jeden již potřebuje poziční vektor v čase . Na první pohled by to mohlo způsobit problémy, protože počáteční podmínky jsou známy pouze v počáteční době . Z nich však zrychlení je známa a vhodnou aproximaci polohy v prvním kroku lze získat pomocí Taylorův polynom stupně dva:
Chyba v prvním kroku je pak v pořádku . To se nepovažuje za problém, protože při simulaci ve velkém počtu časových kroků je chyba v prvním časovém kroku pouze zanedbatelně malým množstvím celkové chyby, která v čase je řádu , oba pro vzdálenost polohových vektorů na pokud jde o vzdálenost dělených rozdílů na . Navíc k získání této globální chyby druhého řádu musí být počáteční chyba alespoň třetího řádu.
Nekonstantní časové rozdíly
Nevýhodou metody Störmer-Verlet je, že pokud je časový krok () změny, metoda nepřibližuje řešení diferenciální rovnici. To lze opravit pomocí vzorce[4]
Přesnější derivace používá Taylorovu řadu (do druhého řádu) v na časy a získat po vyřazení
aby se stal iterační vzorec
Výpočetní rychlosti - metoda Störmer – Verlet
Rychlosti nejsou výslovně uvedeny v základní Störmerově rovnici, ale často jsou nezbytné pro výpočet určitých fyzikálních veličin, jako je kinetická energie. To může vytvářet technické problémy v systému Windows molekulární dynamika simulace, protože kinetická energie a okamžité teploty v čase nelze vypočítat pro systém, dokud nejsou pozice známy v čase . Tento nedostatek lze řešit buď pomocí rychlost Verlet algoritmus nebo odhadem rychlosti pomocí polohových členů a věta o střední hodnotě:
Všimněte si, že tento rychlostní člen je krokem za pozičním členem, protože se jedná o rychlost v čase , ne , znamenající, že je aproximace druhého řádu na . Se stejným argumentem, ale s polovičním časovým krokem, je aproximace druhého řádu na , s .
Lze zkrátit interval, aby se přiblížila rychlost v čase za cenu přesnosti:
Rychlost Verlet
Příbuzným a běžněji používaným algoritmem je rychlost Verlet algoritmus,[5] podobně jako skoková metoda, až na to, že rychlost a poloha se počítají při stejné hodnotě časové proměnné (přeskočit nikoli, jak název napovídá). Toto používá podobný přístup, ale explicitně zahrnuje rychlost, což řeší problém prvního kroku v základním Verletově algoritmu:
Je možné ukázat, že chyba rychlosti Verletu je stejného řádu jako v základním Verletu. Všimněte si, že algoritmus rychlosti nemusí být nutně náročnější na paměť, protože v základním Verletu sledujeme dva vektory polohy, zatímco ve Verletu rychlosti sledujeme jeden vektor polohy a jeden vektor rychlosti. Standardní implementační schéma tohoto algoritmu je:
- Vypočítat .
- Vypočítat .
- Odvodit z využití potenciálu interakce .
- Vypočítat .
Eliminováním rychlosti půl kroku lze tento algoritmus zkrátit na
- Vypočítat .
- Odvodit z využití potenciálu interakce .
- Vypočítat .
Všimněte si však, že tento algoritmus předpokládá tuto akceleraci záleží jen na poloze a nezávisí na rychlosti .
Jeden by mohl poznamenat, že dlouhodobé výsledky rychlosti Verlet, a podobně jako skok přeskočit jsou o jeden řád lepší než částečně implicitní Eulerova metoda. Algoritmy jsou téměř identické až do posunu rychlosti o poloviční časový krok. To se snadno prokáže otočením výše uvedené smyčky tak, aby začala v kroku 3, a poté si všimne, že člen zrychlení v kroku 1 lze eliminovat kombinací kroků 2 a 4. Jediný rozdíl je v tom, že rychlost středu v rychlosti Verlet je považována za konečnou rychlost v částečně implicitní Eulerově metodě.
Globální chyba všech metod Euler je řádu jedna, zatímco globální chyba této metody je, podobně jako metoda středního bodu, objednávky dva. Navíc, pokud zrychlení skutečně vyplývá ze sil v konzervativním mechanickém nebo Hamiltonovský systém „energie aproximace v podstatě osciluje kolem konstantní energie přesně vyřešeného systému, přičemž globální chyba je opět vázána na první objednávku pro semi-explicitní Euler a druhou objednávku pro Verlet-leapfrog. Totéž platí pro všechny ostatní konzervované veličiny systému, jako je lineární nebo moment hybnosti, které jsou vždy zachovány nebo téměř zachovány v symplektický integrátor.[6]
Metoda rychlosti Verlet je zvláštním případem Metoda Newmark-beta s a .
Algoritmická reprezentace
Od té doby rychlost Verlet je obecně užitečný algoritmus v 3D aplikacích, obecné řešení napsané v C ++ může vypadat níže. Zjednodušená tažná síla se používá k předvedení změny zrychlení, je však nutná pouze v případě, že zrychlení není konstantní.
1 struktur Tělo 2 { 3 Vec3d poz { 0.0, 0.0, 0.0 }; 4 Vec3d vel { 2.0, 0.0, 0.0 }; // 2 m / s podél osy x 5 Vec3d dle { 0.0, 0.0, 0.0 }; // zpočátku žádné zrychlení 6 dvojnásobek Hmotnost = 1.0; // 1 kg 7 dvojnásobek táhnout = 0.1; // rho * C * Area - pro tento příklad zjednodušené tažení 8 9 /**10 * Aktualizujte pos a vel pomocí integrace "Velocity Verlet"11 * @param dt DeltaTime / časový krok [např .: 0,01]12 */13 prázdnota Aktualizace(dvojnásobek dt)14 {15 Vec3d new_pos = poz + vel*dt + dle*(dt*dt*0.5);16 Vec3d new_acc = apply_forces(); // potřebné pouze v případě, že zrychlení není konstantní17 Vec3d new_vel = vel + (dle+new_acc)*(dt*0.5);18 poz = new_pos;19 vel = new_vel;20 dle = new_acc;21 }22 23 Vec3d apply_forces() konst24 {25 Vec3d grav_acc = Vec3d{0.0, 0.0, -9.81 }; // 9,81 m / s ^ 2 dolů v ose Z.26 Vec3d drag_force = 0.5 * táhnout * (vel * břišní svaly(vel)); // D = 0,5 * (rho * C * plocha * vel ^ 2)27 Vec3d drag_acc = drag_force / Hmotnost; // a = F / m28 vrátit se grav_acc - drag_acc;29 }30 };
Chybové podmínky
Místní chyba v poloze integrátoru Verlet je jak je popsáno výše, a lokální chyba rychlosti je .
Globální chyba v poloze je naopak a globální chyba rychlosti je . Ty lze odvodit poznamenáním následujícího:
a
Proto
Podobně:
které lze zobecnit (lze to ukázat indukcí, ale je to zde uvedeno bez důkazu):
Pokud vezmeme v úvahu globální chybu v pozici mezi a , kde , je jasné že
a proto je globální (kumulativní) chyba za konstantní časový interval dána vztahem
Protože rychlost je určována nekumulativně z pozic ve Verletově integrátoru, je globální chyba rychlosti také .
V simulacích molekulární dynamiky je globální chyba obvykle mnohem důležitější než lokální chyba a integrátor Verlet je proto známý jako integrátor druhého řádu.
Omezení
Systémy více částic s omezeními je jednodušší řešit pomocí Verletovy integrace než pomocí Eulerových metod. Omezením mezi body mohou být například potenciály, které je omezují na určitou vzdálenost nebo atraktivní síly. Mohou být modelovány jako pružiny spojování částic. Pomocí pružin s nekonečnou tuhostí lze potom model vyřešit pomocí Verletova algoritmu.
V jedné dimenzi je vztah mezi neomezenými pozicemi a skutečné pozice bodů i v čase t lze nalézt pomocí algoritmu
Verletová integrace je užitečná, protože přímo souvisí síla s pozicí, místo aby řešila problém pomocí rychlostí.
Problémy však nastávají, když na každou částici působí více omezujících sil. Jedním ze způsobů, jak to vyřešit, je procházet každým bodem v simulaci, takže v každém bodě se již používá omezení uvolnění posledního k urychlení šíření informací. V simulaci to může být implementováno použitím malých časových kroků pro simulaci, použitím pevného počtu kroků řešení omezení na časový krok nebo řešením omezení, dokud nejsou splněny určitou odchylkou.
Při lokální aproximaci omezení prvního řádu je to stejné jako Gauss – Seidelova metoda. Pro malé matice je známo že LU rozklad je rychlejší. Velké systémy lze rozdělit do klastrů (například každý ragdoll = shluk). Uvnitř klastrů se používá metoda LU, mezi klastry Gauss – Seidelova metoda se používá. Kód matice lze znovu použít: Závislost sil na pozicích lze lokálně aproximovat na první řád a integraci Verlet lze učinit implicitnější.
Sofistikovaný software, jako je SuperLU[7] existuje řešení složitých problémů pomocí řídkých matic. Specifické techniky, jako je použití (shluků) matric, mohou být použity k řešení konkrétního problému, jako je například síla šířící se přes plátno látky bez vytvoření zvuková vlna.[8]
Další způsob řešení holonomická omezení je použít omezovací algoritmy.
Kolizní reakce
Jedním ze způsobů reakce na kolize je použití systému založeného na penalizaci, který v podstatě aplikuje nastavenou sílu na bod při kontaktu. Problém je v tom, že je velmi obtížné zvolit předanou sílu. Použijte příliš silnou sílu a objekty se stanou nestabilními, příliš slabými a objekty budou navzájem pronikat. Dalším způsobem je použití kolizních reakcí projekce, při nichž se uráží bod a pokusí se jej posunout na co nejkratší vzdálenost, aby se dostal z jiného objektu.
Verletová integrace by v druhém případě automaticky zvládla rychlost přenášenou srážkou; Nezapomeňte však, že to není zaručeno způsobem, který je v souladu s kolizní fyzika (to znamená, že změny hybnosti nejsou zaručeně realistické). Místo implicitní změny termínu rychlosti je třeba explicitně řídit konečné rychlosti kolizních objektů (změnou zaznamenané polohy z předchozího časového kroku).
Dvě nejjednodušší metody rozhodování o nové rychlosti jsou perfektní elastický a nepružné srážky. Trochu složitější strategie, která nabízí větší kontrolu, by zahrnovala použití koeficient restituce.
Viz také
- Courant – Friedrichs – Lewy stav
- Energetický drift
- Symplektický integrátor
- Integrace přeskočení
- Beemanův algoritmus
Literatura
- ^ Verlet, Loup (1967). "Počítačové" experimenty "s klasickými tekutinami. I. Termodynamické vlastnosti molekul Lennard-Jones". Fyzický přehled. 159 (1): 98–103. Bibcode:1967PhRv..159 ... 98V. doi:10.1103 / PhysRev.159,98.
- ^ Press, W. H .; Teukolsky, S. A .; Vetterling, W. T .; Flannery, B. P. (2007). „Oddíl 17.4. Konzervativní rovnice druhého řádu“. Numerické recepty: Umění vědecké práce na počítači (3. vyd.). New York: Cambridge University Press. ISBN 978-0-521-88068-8.
- ^ webová stránka Archivováno 03.08.2004 na Wayback Machine s popisem Störmerovy metody.
- ^ Dummer, Jonathane. „Jednoduchá časově opravená metoda integrace Verlet“.
- ^ Swope, William C .; H. C. Andersen; P. H. Berens; K. R. Wilson (1. ledna 1982). "Metoda počítačové simulace pro výpočet rovnovážných konstant pro tvorbu fyzikálních shluků molekul: Aplikace na malé vodní shluky". The Journal of Chemical Physics. 76 (1): 648 (dodatek). Bibcode:1982JChPh..76..637S. doi:10.1063/1.442716.
- ^ Hairer, Ernst; Lubich, Christian; Wanner, Gerhard (2003). Msgstr "Geometrická numerická integrace ilustrovaná metodou Störmer / Verlet". Acta Numerica. 12: 399–450. Bibcode:2003AcNum..12..399H. CiteSeerX 10.1.1.7.7106. doi:10.1017 / S0962492902000144.
- ^ Uživatelská příručka SuperLU.
- ^ Baraff, D .; Witkin, A. (1998). „Velké kroky v simulaci látky“ (PDF). Sborník z počítačové grafiky. Série výročních konferencí: 43–54.