Lab 16.

Slides:



Advertisements
Panašios pateiktys
Laisvės ir kalnų šauksmas
Advertisements

“Ieškosiu Tavo veido...” pagal Isabel Guerra.
Lakštingala, čiulbanti 100 metų
Gėlių horoskopas MOTERIMS
Juozas Aputis (g. 1936) – rašytojas, bandantis surankioti ir savaip sudėlioti pasaulio grožį ir neįžvelgiamą jo gelmę reiškiančius žodžius. Parengė Vilniaus.
ATRASK DIEVO PAŠAUKIMĄ
III klasių viktorina Paruošė G.Baublienė ir L.Venskutė
Pateikties kopija:

Lab 16

Хөвөгч таслалтай тооны харьцуулах командууд MIPS процессорын хөвөгч таслалтай тоотой ажилладаг FPA чип нь хөвөгч таслалтай тоон дээр нөхцөл шалгах үйлдлийг гүйцэтгэж чадах ба хэрэв тухайн нөхцөл үнэн эсвэл худлаа тохиолдолд төлвийн битийг логик 1 эсвэл 0 болгодог. Бид энэ лабораторийн хичээлээр хөвөгч таслалтай тоон дээр нөхцөл шалгалт хийдэг командуудтай танилцах болно.

Агуулга Харьцуулах командууд: c.eq.s, c.lt.s, c.le.s Удирдлага шилжүүлэх командууд: bc1f, bc1t Төлвийн бит Нъютоны арга

Асуулт FPA (floating point accelerator) болон coprocessor 1 хоорондоо ялгаатай юу?

Хариулт Ялгаагүй. Адилхан нэг юм.

FPA чип Дээхэн үеийн MIPS процессорууд хөвөгч таслалтай тоон дээрх үйлдлүүдээ coprocessor 1 гэж нэрлэгдэх хөвөгч таслалтай тооны боловсруулалт хийдэг гадаад чипний тусламжтай гүйцэтгэдэг байжээ.MIPS процессор coprocessor 1 чиптэй холбогдож ажиллахдаа тусгай командууд хэрэглэдэг. Тухайлбал өгөдөл дамжуулахын тулд mtc1, mfc1 командуудыг ашиглана. Харин өнөө үед MIPS процессор өөртөө хөвөгч таслалтай тооны боловсруулалт хийдэг байгууламжийг агуулдаг болсон. Хөвөгч таслалтай тооны үйлдлийг тусгай чипийн тусламжгүйгээр өөрөө бие даан хийдэг болсон ч хэрэглэгдэж буй командууд нь адилхан хэвээр үлдсэн.

MIPS процессор хөвөгч таслалтай тооны үйлдлийг coprocessor 1 гэж нэрлэгдэх тусгай чипний тусламжтай гүйцэтгэдэг байжээ.

Асуулт Хөвөгч таслалтай хоёр тоог тэнцүү эсэхийг шалгах нь ямар ч асуудалгүй юу?

Харьцуулах командууд Хөвөгч таслалтай хоёр тоо хоорондоо яг тэнцүү эсэхийг шалгах нь тийм ч сайн санаа биш юм. Учир нь хөвөгч таслалтай тооны тооцоолол нь ЯГ найдвартай байж чаддагүй. Зарим тохиолдолд математик талаасаа тэнцүү байсан ч компъютерт тийм байж чаддагүй.

Удирдлага шилжүүлэх командууд Хөвөгч таслалтай тооны удирдлага шилжүүлэх командууд coprocessor –ийн condition төлвийн битийн утгаар шийдвэр гаргадаг. bc1t команд хэрэв condition бит ==1 буюу нөхцөл үнэн гэсэн тохиолдолд програмын удирдлагыг шилжүүлнэ. Харин bc1f командын хувьд condition төлийн бит утга ==0 буюу нөхцөл худал гэсэн тохиолдолд биелж програмын удирдлагыг шилжүүлнэ.

Команд Үйлдэл bc1t label Coprocessor 1 –ийн condition төлвийн бит ==1 буюу нөхцөл үнэн тохиолдолд label хаяг руу үсрэнэ.  bc1f label Coprocessor 1 –ийн condition төлвийн бит ==0 буюу нөхцөл худал тохиолдолд label хаяг руу үсрэнэ. 

Удирдлага шилжүүлэх командын хойноос нэг команд биелэх хугацаа буюу нэг командын branch delay шаардагддаг. Техник хангамжийн хувьд удирдлага шилжүүлэх команд бүрийн хойноос нэг nop команд шаарддаг. Харин SPIM програмын хувьд бид setting menu –> branch delay –-ээс branch delay –г disable болгоод branch delay –г тооцохгүй байж болно.

Асуулт bc1t команд хаана биелэгддэг бэ? FPU эсвэл CPU ?

Хариулт CPU. Хэдийгээр команд битийг FPU –д шалгадаг ч үр дүн нь CPU –ын програмын тоолуур регистрт нөлөөлдөг тул уг командыг CPU –д биелэдэг гэж үзэж болно.

Жишээ Дараах програм хөвөгч таслалтай A, B хоёр тооны аль багийг хэвлэнэ. Ингэхдээ эхлээд A B тоонуудын утгыг регистрүүдэд ачаална.

Үүний дараа A<B эсвэл B<A гэдгийг шалгана Үүний дараа A<B эсвэл B<A гэдгийг шалгана. Хэрэв дээрх хоёр нөхцлийн аль аль нь худал бол A==B гэсэн үг юм.

Хоосон дөрвөлжингүүдийг нөхөж бичээрэй. Асуулт Ялгаатай харьцуулах үйлдлүүдээс болж дараах гурван боломж байна. Хоосон дөрвөлжингүүдийг нөхөж бичээрэй.

Хариулт

Бүтэн програм

Асуулт FPU –ын condition төлвийн битийн утга дараагийн харьцуулах команд биелэгдтэл өөрчлөгдөхгүй хэвээр хадгалагдаж чадах уу?

Хариулт Тийм.

Condition төлвийн бит Condition төлвийн битийг нэг бит хэмжээтэй регистр –тэй адилхан гэж төсөөлж болно. Тиймд уг төлвийн бит нь дараагийн харьцуулах команд биелэтэл өмнөх утгаа алдалгүй хадгалж байдаг. Дараах програм нь $f12 регистрт $f0 $f2 регистрүүдийн аль бага утгатайнх нь утгыг хуулна. Хэрэв эдгээр регистрүүдийн утгууд хоорондоо тэнцүү байвал аль альных нь утгыг $f12 –т хуулна.

Асуулт c.eq.s командыг ашилган нөхцөлт давталт хийж болох уу?

Хариулт Үгүй. Хөвөгч таслалтай тооны тооцоолол ЯГ найдвартай байж чаддагүй учир үл дуусах давталт үүсэх эрсдэлтэй.

Нютонын арга Тооны квадрат язгуурыг Нютоны алгоритмыг ашиглан олдог. Дараах програмын кодыг харъя.

Лабораторын даалгавар Гарнаас тойргийн радиус өгөхөд тойргийн урт, талбайг олдог програм бич.