Ich habe an einer Implementierung von GPU-basierten Geo-Clip-Maps gearbeitet, aber es gibt einen Abschnitt des GPU Gems 2-Artikels , den ich einfach nicht verstehen kann, insbesondere diesen Absatz und genauer den fettgedruckten Teil:
Die Wahl der Gittergröße n = 2k - 1 hat den weiteren Vorteil, dass die feinere Ebene niemals genau in Bezug auf die übergeordnete gröbere Ebene zentriert ist. Mit anderen Worten, es wird je nach Position des Ansichtspunkts immer um 1 Rastereinheit entweder links oder rechts sowie oben oder unten versetzt (siehe Abbildung 2-4). Tatsächlich ist es notwendig, zuzulassen, dass sich ein feineres Niveau verschiebt, während sein nächst gröberes Niveau fest bleibt, und daher muss das feinere Niveau manchmal in Bezug auf das nächst gröbere Niveau außermittig sein. Eine alternative Wahl der Gittergröße wie n = 2k - 3 würde die Möglichkeit einer exakten Zentrierung bieten
Nehmen wir ein Beispielbild aus dem Artikel:
Mein "Verständnis" für die Art und Weise, wie die Clip-Maps aktualisiert wurden, bestand darin, dass Sie die Position des Ansichtspunkts auf ein Int setzen und als solches den zentralen Scheitelpunkt erhalten. Wenn dies nicht mit dem vorherigen Mittelpunkt übereinstimmt, aktualisieren Sie die gesamte Karte. Dies ist offensichtlich nicht der Fall. Was ich nicht verstehe, ist Folgendes:
Wenn Sie sich das Bild oben ansehen und der Ansichtspunkt eine Einheit nach rechts bewegen würde, würde der innere Ring (der direkt um den Ansichtspunkt + das weiße mittlere Quadrat) sowohl links als auch links einen Abstand von 1 Einheit erhalten rechte Seite von sich. Aber es gibt nichts in der Zeitung, was sich damit befasst. Was ich damit meine ist, dass es am Ende so aussehen würde: (entschuldigen Sie meine miese Bearbeitung des obigen Bildes durch Ausschneiden und Einfügen):
Dies ist offensichtlich kein gültiger Zustand. Wäre die Lösung also, dass sich ein Clipring (Ebene) nur in Schritten des Rings / der Ebene bewegen kann, in dem er enthalten ist? Wäre das nicht sehr restriktiv? Ich habe das Gefühl, dass mir ein entscheidendes Verständnis für Teile des Algorithmus fehlt, aber ich habe sowohl dieses als auch das Originalpapier von 2004 durchgesehen und kann einfach nicht sehen, was ich nicht bekomme.