TI/Programowanie dla Fizyków Medycznych:Kolokwium2
Z Brain-wiki
powrót: Programowanie dla fizyków medycznych
Kolokwium 2
19.01.2018
Zdefiniuj klasę opisującą wektor magnetyzacji woksela w trzech wymiarach.
Parametry nieobowiązkowe konstruktora: Bezwzględna wartość wektora magnetyzacji [math]M[/math], domyślna wartość to 1; kąt [math]\theta[/math] odchylenia od pionu, domyślna wartość to 0; kąt [math]\phi[/math] obrócenia wokół osi Z, domyślna wartość to 0. (czyli wektor magnetyzacji we współrzędnych sferycznych)
Pozostałe metody:
- Metoda bez parametrów zwracająca współrzędne magnetyzacji w układzie sferycznym [math]M, \theta, \phi[/math].
- Metoda bez parametrów zwracająca współrzędne magnetyzacji w układzie kartezjańskim, [math]M_x=M \cos \theta \cos \phi, M_y=M \cos \theta \sin \phi, M_z=M \sin \theta[/math].
- Metoda zwiększająca kąt [math]\theta[/math] o wartość [math]\alpha[/math] podaną jako parametr (w stopniach), jednocześnie ustawiająca kąt [math]\phi[/math] na zero.
- Metoda zwiększająca kąt [math]\phi[/math] o wartość podaną jako parametr.
- Metoda rysująca (wykorzystując cv2) na macierzy tła przekazanej jako parametr rzut wektora magnetyzacji (w żółtym kolorze) o współrzędnych [math](M_x, M_z)[/math], przyjmując jako swój początek współrzędne na obrazie przekazane jako drugi parametr.
- Metoda magiczna, która pozwala wykonać polecenie m3=m1+m2, gdzie m1, m2 i m3 byłyby obiektami wektora magnetyzacji.
- Metoda magiczna pozwalająca wypisać w eleganckiej formie współrzędne wektora magnetyzacji poleceniem print(m), gdzie m jest obiektem wektora magnetyzacji.
Program:
- Stworzyć trzy obiekty zdefiniowanej klasy. Wyświetlić je obok siebie na wspólnym granatowym tle.
- W nieskończonej pętli obracać wektory magnetyzacji w każdym kroku o kąt 10 stopni - pierwszy, o kąt 11 stopni - drugi, o kąt 12 stopni - trzeci i po każdym obrocie wyświetlać na nowo. Przed kolejnym krokiem pętli odczekać 100 milisekund.
- Pod spodem powinien być wyświetlany wektor magnetyzacji będący sumą trzech poprzednich.
- Jeśli użytkownik naciśnie Escape, program powinien zakończyć działanie, zamykając wszystkie okna graficzne.
- Naciśnięcie "+" lub "-" powinno zwiększyć lub zmniejszyć kąt \theta o 10 stopni, synchronizując na nowo wektory do kąta \phi =0