Μετάβαση στο περιεχόμενο

Αλγόριθμος του ντε Καστελζώ

Από τη Βικιπαίδεια, την ελεύθερη εγκυκλοπαίδεια
(Ανακατεύθυνση από Αλγόριθμος του de Casteljau)

Στο μαθηματικό πεδίο της αριθμητικής ανάλυσης, ο αλγόριθμος του ντε Καστελζώ (de Casteljau) αποτελεί μία αναδρομική μέθοδο εκτίμησης πολυωνύμων Μπέρνσταϊν ή καμπυλών Μπεζιέ. Ο αλγόριθμος του ντε Καστελζώ μπορεί επίσης να χρησιμοποιηθεί για το "σπάσιμο" μίας καμπύλης Μπεζιέ σε δύο για μία αυθαίρετη παραμετρική τιμή.Το όνομά του το πήρε από τον εφευρέτη του Πωλ ντε Καστελζώ.

Παρόλο που θεωρείται αργός ως αλγόριθμος, εμφανίζει ιδιαίτερη αριθμητική ευστάθεια.

Έστω ένα πολυώνυμο B σε μορφή Μπέρνσταϊν βαθμού n

όπου b ένα πολυώνυμο βάσης Μπέρνσταϊν, το πολυώνυμο στο σημείο t0 μπορεί να εκτκιμηθεί με την αναδρομική σχέση

Τότε, η εκτίμηση του σε σημείο μπορεί να εκτιμηθεί σε βήματα του αλγορίθμου. Το αποτέλεσμα δίνεται από :

Επιπλέον, η καμπύλη Μπεζιέ μπορεί να διασπαστεί σε σημείο σε δύο καμπύλες με αντίστοιχα σημεία ελέγχου :

Ανάπτυξη παραδείγματος του αλγόριθμου του ντε Καστελζώ σε Haskell:

deCasteljau :: Double -> [(Double, Double)] -> (Double, Double)
deCasteljau t [b] = b
deCasteljau t coefs = deCasteljau t reduced
  where
    reduced = zipWith (lerpP t) coefs (tail coefs)
    lerpP t (x0, y0) (x1, y1) = (lerp t x0 x1, lerp t y0 y1)
    lerp t a b = t * b + (1 - t) * a

Όταν γίνεται ο υπολογισμός με το χέρι είναι χρήσιμο να καταγράφονται οι συντελεστές σχηματίζοντας ένα τρίγωνο όπως αυτό που ακολουθεί:

Όταν επιλέγεται ένα σημείο t0 για την εκτίμηση ενός πολυωνύμου Μπέρνσταϊν χρησιμοποιούνται οι δύο διαγώνιες του τριγώνου για την κατασκευή τμήματος αυτού

σε

και

Έστω ότι θέλουμε να υπολογίσουμε το πολυώνυμο Μπέρνσταϊν δευτέρου βαθμού με συντελεστές Μπέρνσταϊν

στο σημείο t0.

Ξεκινάμε την αναδρομική σχέση με

και με τη δεύτερη επανάληψη η αναδρομή σταματάει με

που είναι το αναμενόμενο πολυώνυμο Μπέρνσταϊν βαθμού n.

Όταν εκτιμάται μία καμπύλη Μπεζιέ βαθμού n στο τριδιάστατο χώρο, με n+1 σημεία ελέγχου Pi

με

.

Χωρίζουμε την καμπύλη Μπεζιέ σε τρεις ισότητες:

τις οποίες εκτιμάμε ξεχωριστά, χρησιμοποιώντας τον αλγόριθμο του ντε Καστελζώ.

Γεωμετρική Ερμηνεία

[Επεξεργασία | επεξεργασία κώδικα]

Η γεωμετρική ερμηνεία του αλγόριθμου του ντε Καστελζώ είναι απλή.

  • Θεωρούμε μία καμπύλη Μπεζιέ με σημεία ελέγχου . Ενώνοντας τα συνεχόμενα σημεία δημιουργείται το πολύγωνο ελέγχου της καμπύλης.
  • Στη συνέχεια, υποδιαιρούμε κάθε ευθύγραμμο τμήμα του πολυγώνου αυτού με ρυθμό και συνδέουμε τα σημεία που παίρνουμε. Με το τρόπο αυτό φτάνουμε σε ένα νέο πολύγωνο το οποίο έχει ένα τμήμα λιγότερο.
  • Η διαδικασία επαναλαμβάνεται μέχρι να φτάσουμε στο ενιαίο σημείο - αυτό είναι το σημείο της καμπύλης που αντιστοιχεί στην παράμετρο .

Η ακόλουθη εικόνα δείχνει αυτήν τη διαδικασία για μία κυβική καμπύλη Μπεζιέ:

Σημειώστε ότι τα ενδιάμεσα σημεία που δημιουργήθηκαν είναι στην ουσία τα σημεία ελέγχου των δύο νέων καμπυλών Μπεζιέ, οι οποίες συμπίπτουν ακριβώς με την αρχική. Ο αλγόριθμος αυτός δεν υπολογίζει μόνο την καμπύλη στο , αλλά επίσης σπάει την καμπύλη σε δύο κομμάτια στο , και παρέχει τις εξισώσεις των δύο υποκαμπυλών σε μορφή Μπεζιέ.

Η παραπάνω ερμηνεία ισχύει και για μη λογικές καμπύλες Μπεζιέ. Για να εκτιμήσουμε μία λογική καμπύλη Μπεζιέ σε , μπορούμε να προβάλλουμε το σημείο στο . Για παράδειγμα, μία καμπύλη σε τρεις διαστάσεις μπορεί να έχει τα σημεία ελέγχου της και βάρη προβαλλόμενα στα σταθμισμένα σημεία ελέγχου . Τότε ο αλγόριθμος συνεχίζει με το συνήθει τρόπο, παρεμβάλλοντας στα . Τα τετραδιάστατα σημεία που προκύπτουν μπορούν να προβληθούν πίσω στον τρισδιάστατο χώρο με ένα προβολικό μετασχηματισμό.

Γενικά, εφαρμογές σε μία λογική καμπύλη (ή επιφάνεια) ισοδυναμεί με εφαρμογές σε μία μή λογική καμπύλη σε ένα προβολικό χώρο. Η αναπαράσταση ως "σταθμισμένα σημεία ελέγχου" και βάρη συχνά βολεύει στις περιπτώσεις που έχουμε να εκτιμήσουμε λογικές καμπύλες.

  • Farin, Gerald & Hansford, Dianne (2000). The Essentials of CAGD. Natic, MA: A K Peters, Ltd. ISBN 1-56881-123-3