--- author: - Wojciech Kubiak - Piotr Józefowicz - Sebastian Wawrzyn title: - Dokument wizji dla projektu Awionika do rakiet --- # Executive summary Dokument dotyczy projektu realizowanego w ramach przedmiotu projekt inżynierski. Niniejszy dokument służy przedstawieniu przeznaczenia tworzonego systemu, jego głównych cech i przyjętych założeń. Grupa docelowa dla projektu jest koło naukowe na politechnice poznańskiej PUT RocketLab, zajmujące się budowa rakiet i silników rakietowych. Potrzebny jest komputer pokładowy do rakiety oraz aplikacje ułatwiające obsługę testów rakiet i silników. Nasz projekt ma dostarczyć:Dokument dotyczy projektu realizowanego w ramach przedmiotu projekt inżynierski. Niniejszy dokument służy przedstawieniu przeznaczenia tworzonego systemu, jego głównych cech i przyjętych założeń. Grupa docelowa dla projektu jest koło naukowe na politechnice poznańskiej PUT RocketLab, zajmujące się budowa rakiet i silników rakietowych. Potrzebny jest komputer pokładowy do rakiety oraz aplikacje ułatwiające obsługę testów rakiet i silników. Nasz projekt ma dostarczyć: - Aplikację desktopową pozwalająca wyświetlać dane na żywo z testów, konfigurować ustawienia modułów komputera pokładowego oraz zapisywać/usuwać dane z pamięci podręcznej modułów. - Komputer pokładowy posiadający układ wyzwolenie separacji oraz zbierający dane telemetryczne o locie, które będą mogły być przekazywane na żywo do aplikacji poprzez nadajnik i odbiornik. - Aplikację webową służącą jako baza danych testów oraz odgrywającą rolę wizytówki koła # Cel i grupa docelowa Grupą docelową dla projektu jest koło naukowe na Politechnice Poznańskiej PUT RocketLab. Koło zajmuje się budową rakiet i silników rakietowych oraz rozwija systemy awioniczne i naziemne do ich testowania. Potrzebny jest komputer pokładowy do rakiety, który będzie odpowiadał za jej lot, zapisywanie danych z tego lotu, oraz lokalizację rakiety po jej wylądowaniu. Potrzebna jest również aplikacja, która będzie pełniła funkcję kontrolera lotów/testów. Takie testy generują dużą liczbę danych, które ciężko uporządkować więc potrzebne jest też miejsce, w którym będzie można je porządkować i wyświetlać w przejrzysty sposób. Koło nie posiada też strony internetowej-tak zwanej wizytówki, która ma budować rozpoznawalność w internecie i pomóc w kontakcie przyszłym kandydatom na członków koła.\ Projekt oprócz komputera pokładowego będzie się składał z dwóch aplikacji -- aplikacji webowej oraz aplikacji desktopowej. Aplikacja desktopowa ma odgrywać rolę kontrolera testów. To, że aplikacja jest desktopowa, wynika z faktu, że testy zazwyczaj wykonywane są w miejscach bez dostępu do internetu. Aplikacja webowa będzie pełniła funkcję wizytówki oraz bazy danych testów. Członkowie koła będą posiadali login i hasło do aplikacji, gdzie będą katalogowane dane historyczne z testów. Dane będzie można eksportować w wygodnym formacie, a także wyświetlać w formie wykresów i tabelek z danymi. Strona będzie miała możliwość wprowadzenia danych ręcznie, jednak preferowaną opcją będzie dodawanie danych przez aplikację desktopowa, która to zrobi w sposób zautomatyzowany. Aplikacja desktopowa będzie umożliwiała wyświetlanie danych z testów rakiet oraz silników na żywo. Po teście dane będą przekazywane do aplikacji webowej, jeśli będzie dostęp do internetu. Jeśli nie będzie dostępu, to dane zostaną zapisane w pamięci komputera i przekazane od razu po podłączeniu komputera do Internetu. Aplikacja desktopowa ma również dać możliwość konfiguracji modułów elektroniki komputera pokładowego rakiety oraz odczytywania i zapisywania z nich danych. Pobrane dane będą od razu przekazywane do chmury tak jak w przypadku testu na żywo. Będzie również możliwa zmiana konfiguracji tych modułów-zmiany ustawień parametrów programu na danym module (np. ilość bitów na sekundę podczas wysyła danych, częstotliwość, moc anteny), są to parametry, które muszą być zmieniane podczas czasu życia modułu. Ta funkcjonalność ma na celu zapewnić większe bezpieczeństwo podczas zmiany tych parametrów. Parametry nie będą zmieniane poprzez wgranie nowego kodu tylko przez aplikacje, dzięki temu na samym urządzeniu nie trzeba będzie zmieniać kodu źródłowego.\ Klientowi zależy na tym, aby pozyskać z rakiety dane, które pozwolą sprawdzić, czy rakieta osiągnęła oczekiwane parametry lotu zgodne z wcześniejszą symulacją takie jak apogeum, prędkość, liczba macha czy przyspieszenie. W tym celu muszą dokonać pomiarów fizycznych za pomocą odpowiednich czujników takich jak akcelerometr, barometr, magnetometr czy żyroskop, a następnie zapisać te dane i wyświetlić je w czytelnej formie w celu ich analizy. Komputer pokładowy będzie umożliwiał zebranie powyższych danych, a także wyzwolenie separacji/spadochronu w dwóch różnych konfiguracjach: poprzez automatyczne wykrycie spadku swobodnego oraz poprzez użycie timera (ustawienie odpowiedniego opóźnienia, po którym zostanie wyzwolona separacja/spadochron). Rakieta będzie też wyposażona w lokalizator, który będzie umożliwiał odnalezienie rakiety po lokalizacji GPS wysłanej za pomocą komunikacji bezprzewodowej LORA. # Rynek Wyposażenie pokładowe rakiety (awionika) składa się głównie z dwóch części: komputera pokładowego i lokalizatora. Komputery pokładowe znajdujące się na rynku mają wysoką cenę i większość z nich, nie oferuje, aplikacji do zbierania danych, przez co robi się z nimi bałagan i trzeba dbać samemu o to, by te dane katalogować. Gotowe lokalizatory, mimo że zaawansowane również są bardzo drogie. ## Przykłady produktów na rynku: - Dużym zainteresowaniem na świecie cieszą się amerykańskie [EggTimery](http://eggtimerrocketry.com/home/altimeters-av-bay/). Posiadają one wiele różnych konfiguracji komputerów oraz lokalizatorów. Mają jednak one dość wysokie ceny modułów i nie oferują zintegrowanej aplikacji, która umożliwiałaby analizę danych, musimy korzystać z osobnych programów. - Dostępne są [niemieckie komputery pokładowe](https://www.rocketronics.de/shop/de/altimax-g3-standard.html?fbclid=IwAR2Btg-xkFvGJoPM6sU9-zkdCB5SZMVawdttTxnr6m8iG2iS46GtkmWs8Fc) firmy Rocketronics oferujące wysoką jakość danych oraz dokładną separację. Ich aplikacja nie umożliwia podglądu danych na żywo. Nie ma w nich lokalizatorów i mają wysoką cenę. - [Lokalizator Featherweight](https://www.featherweightaltimeters.com/featherweight-gps-tracker.html) (koszt to 610-2000 zł) - wysoka cena, zawiera aplikację, ale do tego potrzebny jest jeszcze komputer pokładowy. - Jeden z najtańszych i najpopularniejszych sposobów (przynajmniej w Polsce) na lokalizację rakiety polega na używaniu taniego [lokalizatora](https://abc-rc.pl/product-pol-7625-Lokalizator-GPS-TK102B-Tracker-GPS-Sledzenie-w-WWW.html), który wysyła podstawowe dane telemetryczne dzięki modułowi GPS i GSM. Nie są to jednak produkty przeznaczone konkretnie do rakiet i nie mogą zostać zintegrowane z komputerem pokładowym. - Nowością jest komputer pokładowy [Signal-R2](https://bps.space/shop/signal-r2) z aplikacją na telefon (koszt to ok 1400 zł). Aplikacja dostępna na platformy android oraz iOS jest zintegrowana z komputerem pokładowym. Cały system komunikacji jest oparty na Bluetooth, co daje zasięg 10 metrów, dlatego nie można używać aplikacji do odczytów danych na żywo podczas lotu. Aby uzyskać szerszy dostęp do dokumentacji, kodów źródłowych i informacji na temat projektu trzeba dodatkowo miesięczne płacić za subskrypcje na specjalnej platformie Patronite. # Opis produkt ## Aplikacja webowa: - wizytówka koła - możliwością wgrania avatara - dane z testów będzie można zapisywać na serwerze w celu stworzenia historii testów - eksport danych GPS w formacie NMEA - eksport danych telemetrycznych do Excel'a - import danych pomiarowych z pliku - wyświetlenie danych historycznych (z testów) - wyszukiwanie testu po nazwie i dacie - kategoryzacja danych telemetrycznych (historia testów) przypisana do testu ## Aplikacja desktopowa: - pomiary z rakiety obrazowane na żywo: - wykres prędkości od czasu, - wykres przyspieszenia od czasu, - wykresy orientacji XYZ, - wykres wysokości i wychylenia w osiach XYZ od czasu, - wyświetlenie lokalizacji GPS na mapie (Google Maps) - obrazowane danych z hamowni na żywo - wykres ciągu do czasu - wykres ciśnienia do czasu - dane po teście rakiety czy silnika będą zapisywane na serwerze - zgrywania/usuwanie danych z modułów elektronicznych - zmiana konfiguracji modułów elektronicznych ## Elektronika: - dokonywanie pomiarów podczas lotu (prędkość, przyspieszenie, wysokość, wychylenia w osiach XYZ) - lokalizacja GPS oraz pomiary wysyłane do stacji naziemnej za pośrednictwem komunikacji bezprzewodowej LORA - wykrycie apogeum (spadku swobodnego) pozwalające wyzwolić separacje/spadochron - timer pozwalający wyzwolić separacje/spadochron - wyzwolenie separacji, spadochronu poprzez odpalenie zapalnika elektrycznego - przesyłanie danych do stacji naziemnej przez moduł komunikacyjny - odbieranie danych przez odbiornik - przekazywanie danych do aplikacji desktopowej - zapisywania danych do pamięci modułu - odczytywanie danych z pamięci modułu - zmiana konfiguracji modułu # Zakres i ograniczenia ## Skład zespołu: - Wojciech Kubiak - systemy wbudowane - arduino, c++, python - Sebastian Wawrzyn - backend - .NET Core, C#, Docker, baza danych - Piotr Józefowicz - frontend - Vue.js, typescript ## Kamienie milowe: - I faza, I semestr (02.2020 - 07.2020): - Przygotowanie prototypu aplikacji - Przygotowanie backlogu dla projektu w systemie Trello, opracowanie funkcjonalności, user stories - Rozpoczęcie prac programistycznych nad aplikacją - Rozpoczęcie prac programistycznych nad komputerem pokładowym 1.0 - Testowanie komputera pokładowego - Ukończenie MVP aplikacji i komputera pokładowego - Poddanie MVP testom funkcjonalnym - II faza, II semestr(10.2020 - 12.2020): - Uaktualnienie dekumentacji i Trello - Rozpoczęcie prac programistycznych nad aplikacjami - Kontynuacje prac programistycznych nad komputerem pokładowym oraz rozpoczęcie prac nad nadajnikiem i odbiornikiem - Testowanie komputera pokładowego oraz elektroniki naziemnej - Ukończenie aplikacji wraz ze wszystkimi zdefiniowanymi funkcjonalnościami - Integracja aplikacji z elektroniką - Testy integracyjne - Wdrożenie aplikacji na publiczną domenę ## Harmonogram: MVP produktu zostanie wypracowane i przedstawione do końca czerwca 2020 roku, zawierać będzie funkcjonalności takie jak: - Komputer pokładowy 1.0: - Dokonywanie pomiarów telemetrycznych - Zapis danych na kartę SD - Wyzwolenie separacji za pomocą timera - Odpalenie zapalnika elektrycznego - Aplikacja internetowa (frontend): - Stworzenie konta użytkownika, logowanie - Dodawanie testów z pliku - Wyświetlanie danych z testów - Przegląd danych historycznych - Zintegrowania aplikacji webowej z REST API - Aplikacja serwerowa, REST API: - Dodanie serwisów REST pozwalających na operacje wymienione w punkcie "Aplikacja internetowa" - Zintegrowania API z bazą danych - Wdrożenie aplikacji na środowisko testowe Pierwsza wersja produktu wypracowana i oddana do grudnia 2020 roku, obejmować będzie: - Wszystkie funkcjonalności zdefiniowane w MVP - Komputer pokładowy 2.0: - Układ wyzwolenia separacji - Komunikacja z nadajnikiem - Konfiguracja modułu - Nadajnik/Lokalizator: - Lokalizacja GPS oraz redundantny system prędkości wysokości przyspieszenia - Komunikacja bezprzewodowa LORA - Konfiguracja modułu - Elektronika naziemna/Odbiornik: - Odbieranie danych od komputera pokładowego (LORA) - Przekazywanie danych do serwera za pomocą REST API - Przekazywanie danych do kolejnych urządzeń za pomocą Seriala - Przekazywanie danych do kolejnych urządzeń za pomocą Bluetooth - Aplikacja internetowa (frontend): - Wyświetlanie i gromadzenie danych historycznych testów - Profil użytkownika - Aplikacja desktopowa: - Wyświetlanie danych z testów live (wykresy) - Wyświetlanie lokalizacji za pośrednictwem Google Maps - Konfigurowanie płytki - Odczyt danych z płytki - Usuwanie danych z płytki - Aplikacja serwerowa, REST API: - Dodanie serwisów REST pozwalających na operacje wymienione w punkcie "Aplikacja internetowa" - Dodanie serwisów REST pozwalających na operacje wymienione w punkcie "Aplikacja desktopowa" - Wdrożenie aplikacji na środowisko produkcyjne Ograniczeniem projektu jest hosting, nie wiadomo czy politechnika udostępni nam domenę oraz otworzy porty na zewnątrz.