Skip to main content

შემომსაზღვრელი ყუთების იერარქია

BVH
მარცხენა მხარეს ნაჩვენებია პრიმიტივები(სამკუთხედები) და მასზე აგებული BVH ვიზუალურად, მარჯვენა მხარეს ნაჩვენებია იგივე BVH ხის სახით
        როგორც სახელწოდებიდან ჩანს, შემომსაზღვრელი ყუთების იერარქია წარმოადგენს ისეთ ხეს, რომელშიც შემომსაზღვრელი ყუთები არის ჩალაგებული იერარქიულად, ხოლო ფოთლებში მოთავსებულია ერთი ან რამდენიმე პრიმიტივი. შემოკლებით ხშირად BVH-ს უწოდებენ, რაც ინგლისური სახელწოდების აბრევიატურას წარმოადგენს, სიმარტივისათვიშ შემდგომში ამ სახელს გამოვიყენებთ.
BVH-ის აგების პროცესში ხდება პრიმიტივების გადანაწილება ყუთებში, რის გამოც ერთი პრიმიტივი ერთ რომელიმე ყუთში ხვდება.
        სანამ ხის აგებაზე გადავალთ, განვიხილოთ ერთი მნიშვნელოვანი საკითხი. ვთქვათ გვაქვს რაიმე ევრისტიკული ფუნქცია f(i,j), რომელიც კვანძების ნებისმიერი (i,j) წყვილისთვის, სადაც i≠j, ახდევს მათი დაჯგუფების ხარისხის შეფასებას. ასეთ შემთხვევაში ჩვენ შეგვიძლია განვიხილოთ დაჯგუფების სხვადასხვა ვარიანტი, მოვახდინოთ მათი ევრისტიკული შეფასება და ამოვირჩიოთ ევრისტიკულად ყველაზე მომგებიანი ვარიანტი(ის, რომელიც ყველაზე მაღალი ხარისხის ხეს მოქვცემს).
        არსებობს მეთოდი, რომელიც ხეს აგებს ქვემოდან ზემოთ: ჯერ ქმნის ფოთლებს არსებული პრიმიტივებით, შემდეგ აჯგუფებს მათ და ქმნის მათ მშობელ შიდა კვანძებს, და ასე სანამ არ მიიღებს ხის ძირს. როგორც ზემოთ ვთქვით, იმისათვის რომ მოვახდინოთ კვანძების დაჯგუფება, დაჯგუფების სხვადასხვა ვარიანტებიდან უნდა შევარჩიოთ ევრისტიკულად ყველაზე მომგებიანი. აგების ეს მეთოდი არის O(n^3) სირთულის, სადაც n პრიმიტივების რაოდენობაა. კუბური სირთულიდან გამოყვანა შესაძლებელია თუ გამოვიყენებთ გროვებს, თუმცა მეთოდი მაინც იმდენად რთულია, რომ პრაქტიკაში მისი გამოყენება თითქმის არ ხდება მისი გამოთვლითი სირთულის გამო.
        ახლა განვიხილოთ მეთოდები, რომლებიც ხეს აგებენ ზემოდან ქვემოთ: ჯერ აგებენ ხის ძირს, შემდეგ შვილობილ, შიდა კვანძებს და ჩადიან ფოთლებამდე. ხის აგების რამოდენიმე, ასეთი მეთოდი არსებობს, მოვიყვანოთ მაგალითი: საწყის ეტაპზე ყველა პრიმიტივი მოვათავსოთ ერთ ყუთში, შემდეგ განვსაზღვროთ ყუთის ყველაზე გრძელი მხარე და შესაბამისი ღერძის გასწვრივ დავალაგოთ პრიმიტივები მათი ცენტრის კოორდინატების მიხედვით. ამის შემდგომ დალაგებული პრიმიტივების პირველი ნახევარი მოვათავსოთ ერთ შვილობილ კვანძში, ხოლო მეორე ნახევარი მეორეში. ეს პროცესი გავიმეოროთ რეკურსიულად, სანამ ფოთლებში სასურველი რაოდენობის პრიმიტივები არ დაგვრჩება. ასეთი სახით აგებული ხე სრულად ბალანსირებულია, რადგან ყოველი კვანძისთვის შვილობილ კვანძებში პრიმიტივების რაოდენობის ნახევარ-ნახევარს ვათავსებთ, თუმცა თავად აგების პროცესი საკმაოდ რთულია, რადგან გვიწევს პრიმიტივების დალაგებები შუაზე გასაყოფად.
        განვიხილოთ კიდევ ერთი მეთოდი: წინასგან განსხვავებით ეს მეთოდი თავიდან იცილებს პრიმიტივების დალაგებას. ამის მაგივრად მას შემოაქვს გამყოფი სიბრტყე(ყველაზე მარტივ შემხვევაში შეიძლება ავიღოთ ის სიბრტყე, რომელიც შუაზე ყოფს ყუთს მისი გრძელი გვერდის მიმართ) და ის პრიმიტივები, რომელთა ცენტრის კოორდინატებიც მოექცევიან გამყოფის ერთ მხარეს მოვათავსოთ ერთ შვილში, ხოლო დანარჩენები მეორეში. პრიმიტივის ცენტრის კოორდინატი სიბრტყის ან ერთ მხარეს ექცევა, ან მეორე, განსხვავებით თავად პრიმიტივისაგან, რომელიც შეიძლება თანაიკვეთოს კიდეც. ამ მეთოდით აგებული ხე გამოვა არაბალანსირებული, რადგან გამყოფის სხვადასხვა მხარეს სხვადასხვა რაოდენობის პრიმიტივები შეიძლება მოექცნენ. რაც შეეხება თავად აგების პროცესის სირთულეს წინა მეთოდთან შედარებით ბევრად სწრაფად ხდება, რადგან ყოველ კვანძში პრიმიტივებზე ერთი გარბენით ვახდენთ მათ გადასანაწილებლად შვილობილ კვანძებში.

Comments

Popular posts from this blog

რუსული რულეტკის მეთოდი

Russian Roulette Technique რუსული რულეტკის მეთოდი არის ფართოდ გავრცელებული ტექნიკა მონტე-კარლოს ინტეგრირების პროცესის შესაწყვეტად(სახელწოდება მოდის ცნობილი რუსული თამაშიდან). იმის მაგივრად, რომ პროცესი შევწყვითოთ ხისტად, მაგალითად შერჩევების რაოდენობის რაიმე მაქსიმალურ რაოდენობაზე, რუსული რულექტკის მეთოდი გვეხმარება ინტეგრირების პროცესის მიუკერძოვებლად შეწყვეტაში. მთავარი იდეა რუსული რულეტკის მეთოდისა არის ის, რომ რუსული რულეტკა წყვეტს მონტე კარლოს მეთოდს რაიმე არანულოვანი p ალბათობით(ალბათობა შეიზლება შეირჩეს ერთხელ ან მონტე კარლოს მეთოდის ყოველ ბიჯზე სათითაოდ რაიმე მნიშვნელოვნობით) ან აგრძელებს მას და შემდგომი პროცესიდან მიღებულ შედეგს ამრავლებს 1/p - ზე. რადგან რუსული რულეტკის მეთოდი პროცესის შეწყვეტას ახდენს რაიმე არანულოვანი p ალბათობით ყოველთვის რჩება იმის შანსი, რომ პროცესი გაგრძელდეს რაც იმას ნიშნავს, რომ მონტე კარლოს ინტეგრირების პროცესისათვის ნებისმიერი სიღრმე მიღწევადი ხდება. სწორედ ამიტომ ხისტი შეზღუდვით მიღებული მიკერძოება( სისტემატიური შეცდომა ) ქრება რუსული რ...

ფერების RGB მოდელი

RGB Color Model         ფერების RGB მოდელი წარმოადგენს ისეთ მოდელს რომელშიც სამი ძრირითადი ფერის წითელი, მწვანე და ლურჯის საშუალებით მიიღება ფერების ფართო სპექტრი. მისი დასახელებაც მოდის სწორედ ძირითადი ფერების ინგლისური სახელწოდების ინიციალებიდან(Red, Green, Blue).         ფერთა სპექტრის ამდაგვარი წარმოდგენა დაკავშირებულია იმასთან, რომ გამოსახულების გამოტანის მოწყობილობებში რომელიც გააჩნიათ კომპიუტერებს, ტელევიზორებს ფერის მიღება ფიზიკურად ხდება სწორედ ამ სამი ძირითადი ფერის შეზავებით. დღესდღეობით ყველაზე გავრცელებული არის 24 ბიტიანი RGB მოდელი, სადაც თითოეულ კომპონენტს ეთმობა ერთი ბაიტი და შესაბამისად შეუძლია მიიღოს ნებისმიერი მნიშვნელობა [0, 255] დიაპაზონში, რაც საბოლოოდ გვაძლევს 16777216 განსხვავებულ ფერს.

CPU GPU და ჰიბრიდული რენდერერები

წყარო         დღემდე აქტუალურია თემა CPU რენდერერი ჯობია თუ GPU . იმისათვის რომ ამ კითხვას მეტნაკლებად ამომწურავი პასუხი გავცეთ განვიხილოთ რენდერერის სტრუქტურა და მოცემულ პლათფორმებზე იპმლემენტაციასთან დაკავშირებული პრობლემები. რენდერერი შედგება რამოდენიმე დიდი კომპონენტისგან როგორიცაა ხილვადობის ამოცანა შეფერადება ინტეგრატორები ფუნქციონალი ხილვადობის ამოცანა         ხილვადობის ამოცანა ერთერთი ყველაზე რთულია გამოთვლითი რესურსის კუთხით. გარდა იმისა, რომ სხივის გეომეტრიასთან თანაკვეთის დათვლას საკმაოდ დიდი დრო ჭირდება, ასევე საჭიროა ამაჩქარებელ სტრუქტურების განახლება კადრიდან კადრზე დინამიური სცენებისათვის. კარგი ისაა, რომ რენდერერის ეს ნაწილი საკმაოდ ადვილად ენკაპსულირებადია და შესაბამისად გვხვდება ბიბლიოთეკები მაგალითად embree(intel), fireRays(AMD), OptiX prime(nvidia), ... რომლებიც ამ ამოცანას საკმაოდ ეფექტურად ხსნიან და რენდერერებშიც მეტნაკლებად ადვილად ინტეგრირდებიან.  სხივების მიდევნების პროცესში ძალიან მნიშვნელოვანია მსგ...