/tags/V2.02b/FlightCtrl.aps |
---|
0,0 → 1,0 |
<AVRStudio><MANAGEMENT><ProjectName>FlightCtrl</ProjectName><Created>15-May-2007 11:20:41</Created><LastEdit>11-Oct-2007 22:58:54</LastEdit><ICON>241</ICON><ProjectType>0</ProjectType><Created>15-May-2007 11:20:41</Created><Version>4</Version><Build>4, 13, 0, 528</Build><ProjectTypeName>AVR GCC</ProjectTypeName></MANAGEMENT><CODE_CREATION><ObjectFile>default\Flight-Ctrl.elf</ObjectFile><EntryFile></EntryFile><SaveFolder>F:\SVN\MikroKopter\FlightCtrl\branches\V0.64_ZeroWarnings\</SaveFolder></CODE_CREATION><DEBUG_TARGET><CURRENT_TARGET>AVR Simulator</CURRENT_TARGET><CURRENT_PART>ATmega644.xml</CURRENT_PART><BREAKPOINTS></BREAKPOINTS><IO_EXPAND><HIDE>false</HIDE></IO_EXPAND><REGISTERNAMES><Register>R00</Register><Register>R01</Register><Register>R02</Register><Register>R03</Register><Register>R04</Register><Register>R05</Register><Register>R06</Register><Register>R07</Register><Register>R08</Register><Register>R09</Register><Register>R10</Register><Register>R11</Register><Register>R12</Register><Register>R13</Register><Register>R14</Register><Register>R15</Register><Register>R16</Register><Register>R17</Register><Register>R18</Register><Register>R19</Register><Register>R20</Register><Register>R21</Register><Register>R22</Register><Register>R23</Register><Register>R24</Register><Register>R25</Register><Register>R26</Register><Register>R27</Register><Register>R28</Register><Register>R29</Register><Register>R30</Register><Register>R31</Register></REGISTERNAMES><COM>Auto</COM><COMType>0</COMType><WATCHNUM>0</WATCHNUM><WATCHNAMES><Pane0></Pane0><Pane1></Pane1><Pane2></Pane2><Pane3></Pane3></WATCHNAMES><BreakOnTrcaeFull>0</BreakOnTrcaeFull></DEBUG_TARGET><Debugger><Triggers></Triggers></Debugger><AVRGCCPLUGIN><FILES><SOURCEFILE>uart.c</SOURCEFILE><SOURCEFILE>analog.c</SOURCEFILE><SOURCEFILE>eeprom.c</SOURCEFILE><SOURCEFILE>fc.c</SOURCEFILE><SOURCEFILE>GPS.c</SOURCEFILE><SOURCEFILE>main.c</SOURCEFILE><SOURCEFILE>menu.c</SOURCEFILE><SOURCEFILE>printf_P.c</SOURCEFILE><SOURCEFILE>rc.c</SOURCEFILE><SOURCEFILE>timer0.c</SOURCEFILE><SOURCEFILE>twimaster.c</SOURCEFILE><HEADERFILE>uart.h</HEADERFILE><HEADERFILE>_Settings.h</HEADERFILE><HEADERFILE>analog.h</HEADERFILE><HEADERFILE>fc.h</HEADERFILE><HEADERFILE>gps.h</HEADERFILE><HEADERFILE>main.h</HEADERFILE><HEADERFILE>menu.h</HEADERFILE><HEADERFILE>old_macros.h</HEADERFILE><HEADERFILE>printf_P.h</HEADERFILE><HEADERFILE>rc.h</HEADERFILE><HEADERFILE>Settings.h</HEADERFILE><HEADERFILE>timer0.h</HEADERFILE><HEADERFILE>twimaster.h</HEADERFILE></FILES><CONFIGS><CONFIG><NAME>default</NAME><USESEXTERNALMAKEFILE>NO</USESEXTERNALMAKEFILE><EXTERNALMAKEFILE></EXTERNALMAKEFILE><PART>atmega644</PART><HEX>1</HEX><LIST>1</LIST><MAP>1</MAP><OUTPUTFILENAME>Flight-Ctrl.elf</OUTPUTFILENAME><OUTPUTDIR>default\</OUTPUTDIR><ISDIRTY>1</ISDIRTY><OPTIONS><OPTION><FILE>GPS.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>analog.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>eeprom.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>fc.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>main.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>menu.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>printf_P.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>rc.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>timer0.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>twimaster.c</FILE><OPTIONLIST></OPTIONLIST></OPTION><OPTION><FILE>uart.c</FILE><OPTIONLIST></OPTIONLIST></OPTION></OPTIONS><INCDIRS/><LIBDIRS/><LIBS><LIB>libc.a</LIB><LIB>libm.a</LIB></LIBS><LINKOBJECTS/><OPTIONSFORALL>-Wall -gdwarf-2 -Wstrict-prototypes -std=gnu99 -Os -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums -DVERSION_HAUPTVERSION=0 -DVERSION_NEBENVERSION=64 -DVERSION_KOMPATIBEL=5</OPTIONSFORALL><LINKEROPTIONS></LINKEROPTIONS><SEGMENTS/></CONFIG></CONFIGS><LASTCONFIG>default</LASTCONFIG><USES_WINAVR>1</USES_WINAVR><GCC_LOC>C:\Program Files\WinAVR\bin\avr-gcc.exe</GCC_LOC><MAKE_LOC>C:\Program Files\WinAVR\utils\bin\make.exe</MAKE_LOC></AVRGCCPLUGIN><IOView><usergroups/></IOView><Files><File00000><FileId>00000</FileId><FileName>main.c</FileName><Status>1</Status></File00000><File00001><FileId>00001</FileId><FileName>uart.c</FileName><Status>1</Status></File00001><File00002><FileId>00002</FileId><FileName>menu.c</FileName><Status>1</Status></File00002><File00003><FileId>00003</FileId><FileName>timer0.c</FileName><Status>1</Status></File00003><File00004><FileId>00004</FileId><FileName>fc.c</FileName><Status>1</Status></File00004><File00005><FileId>00005</FileId><FileName>fc.h</FileName><Status>1</Status></File00005><File00006><FileId>00006</FileId><FileName>menu.h</FileName><Status>1</Status></File00006><File00007><FileId>00007</FileId><FileName>TWIMASTER.C</FileName><Status>1</Status></File00007><File00008><FileId>00008</FileId><FileName>twimaster.h</FileName><Status>1</Status></File00008><File00009><FileId>00009</FileId><FileName>uart.h</FileName><Status>1</Status></File00009><File00010><FileId>00010</FileId><FileName>_Settings.h</FileName><Status>1</Status></File00010><File00011><FileId>00011</FileId><FileName>analog.h</FileName><Status>1</Status></File00011><File00012><FileId>00012</FileId><FileName>gps.h</FileName><Status>1</Status></File00012><File00013><FileId>00013</FileId><FileName>main.h</FileName><Status>1</Status></File00013><File00014><FileId>00014</FileId><FileName>old_macros.h</FileName><Status>1</Status></File00014><File00015><FileId>00015</FileId><FileName>printf_P.h</FileName><Status>1</Status></File00015><File00016><FileId>00016</FileId><FileName>rc.h</FileName><Status>1</Status></File00016><File00017><FileId>00017</FileId><FileName>Settings.h</FileName><Status>1</Status></File00017><File00018><FileId>00018</FileId><FileName>timer0.h</FileName><Status>1</Status></File00018></Files><Events><Bookmarks></Bookmarks></Events><Trace><Filters></Filters></Trace></AVRStudio> |
/tags/V2.02b/GPS.c |
---|
0,0 → 1,16 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Copyright (c) Holger Buss, Ingo Busker |
// + only for non-profit use |
// + www.MikroKopter.com |
// + see the File "License.txt" for further Informations |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "main.h" |
signed int GPS_Nick = 0; |
signed int GPS_Roll = 0; |
unsigned char GPS_Aid_StickMultiplikator = 0; // 64 = 100% |
/tags/V2.02b/Hex-Files/Flight-Ctrl_MEGA1284p_V2_02b_SVN722.hex |
---|
0,0 → 1,5166 |
:100000000C94C4090C94210A0C94210A0C94210A22 |
:100010000C94210A0C94210A0C94210A0C94210AB4 |
:100020000C94210A0C946A1D0C94210A0C94210A48 |
:100030000C94E5380C94210A0C94210A0C94210AA2 |
:100040000C94210A0C94210A0C9488190C94210A0E |
:100050000C9428100C94210A0C94F20F0C94210A91 |
:100060000C94B0200C94210A0C940A340C94210AAC |
:100070000C94F69C0C94210A0C9447920C94210A3F |
:100080000C94210A0C94210A0C94210AD920DE2018 |
:10009000E320EC2003211A212A213A21752106248C |
:1000A0001A219122A222D222F1220E236823C323F5 |
:1000B00076265727ED276E28A62856291D2A7E2A40 |
:1000C000F02A302B882BB62BE32B482C932CDE2CDC |
:1000D000422D3E2E29345D349E3410352835683546 |
:1000E0002E363237323732373237323732373237CD |
:1000F0003237323732373237E736E936EE360637BF |
:100100000837B972AD73327459738674B674F87265 |
:100110008873B8835C84E1844385978500867E8DEF |
:100120008186B386B386B386B386B386B386B38639 |
:10013000B386B386E1865C87ED8712885588AD88E3 |
:1001400043894E8AB58AB58AB58AB58AB58AB58A91 |
:10015000B58AB58AB58AED8A0B8B308B8C8BC88BB0 |
:100160002C8C598CF98C7E8D598D598D598D598DCA |
:10017000598D598D598D598D059B089B089B089B5E |
:10018000119B149B179B299B269B0A0D3D3D3D3DD2 |
:100190003D3D3D3D3D3D3D3D3D3D3D3D3D3D3D3D8F |
:1001A0003D3D3D3D3D3D3D3D3D3D3D3D3D3D3D00BC |
:1001B0000A0D426174743A002025642043656C6C1A |
:1001C000732000204C6F77207761726E696E673AFA |
:1001D0002025642E25640020204175746F6C616EAB |
:1001E00064696E673A2025642E2564000A0D466F07 |
:1001F000756E6420424C2D4374726C3A2000256465 |
:10020000000A0D0A0D2121204D495353494E472024 |
:10021000424C2D4354524C3A202564202121000A9F |
:100220000D43616C6962726174696E6720707265FA |
:1002300073737572652073656E736F722E2E004F27 |
:100240004B0A0D000A0D466C696768742D74696D60 |
:1002500065202575206D696E20546F74616C3A2598 |
:1002600075206D696E00416E676C654E69636B2029 |
:10027000202020202020416E676C65526F6C6C201E |
:100280002020202020204163634E69636B202020C2 |
:10029000202020202020416363526F6C6C2020209E |
:1002A0002020202020205961774779726F2020205C |
:1002B000202020202020416C746974756465205BC7 |
:1002C000302E316D5D204163635A20202020202094 |
:1002D0002020202020204761732020202020202063 |
:1002E000202020202020436F6D70617373205661A1 |
:1002F0006C7565202020566F6C74616765205B30DB |
:100300002E31565D20205265636569766572204CFA |
:100310006576656C20204779726F20436F6D706140 |
:100320007373202020204D6F746F722031202020A5 |
:100330002020202020204D6F746F7220322020203A |
:100340002020202020204D6F746F72203320202029 |
:100350002020202020204D6F746F72203420202018 |
:100360002020202020203136202020202020202066 |
:100370002020202020203137202020202020202055 |
:100380002020202020203138202020202020202044 |
:100390002020202020203139202020202020202033 |
:1003A000202020202020536572766F2020202020DE |
:1003B000202020202020486F7665726761732020FE |
:1003C00020202020202043757272656E74205B30DF |
:1003D0002E31415D20204361706163697479205B37 |
:1003E0006D41685D202048656967687420536574B5 |
:1003F000706F696E7420323520202020202020204C |
:1004000020202020202032362020202020202020C4 |
:10041000202020202020436F6D706173732053656E |
:1004200074706F696E744932432D4572726F722019 |
:10043000202020202020424C204C696D697420200F |
:100440002020202020204750535F4E69636B2020DE |
:100450002020202020204750535F526F6C6C2020BA |
:1004600020202020202021212120494E434F4D5083 |
:10047000415449424C4520212121002E000A0D20E3 |
:10048000444143206F7220493243204552524F521B |
:100490002120436865636B204932432C2033567218 |
:1004A00065662C2044414320616E6420424C2D43FC |
:1004B00074726C005B25695D005B25695D002B2013 |
:1004C0004D696B726F4B6F70746572202B004857CB |
:1004D0003A5625642E25642053573A25642E25303C |
:1004E00032642563200053657474696E673A25642D |
:1004F000202573004D69786572204572726F7221F4 |
:10050000004552522532643A004861726477617244 |
:1005100065204572726F7220313A256420212100D6 |
:100520004D697373696E6720424C2D4374726C3A47 |
:10053000256420212100493243204552524F522147 |
:10054000212100424C2D53656C66746573742045FF |
:1005500072723A253264004865696768743A2020EF |
:1005600025356900536574706F696E743A25356975 |
:100570000050726573737572653A253569004F6670 |
:10058000667365743A2020253569002841290025C5 |
:1005900069006163742E2062656172696E67004E46 |
:1005A00069636B3A20202020202025356900526F96 |
:1005B0006C6C3A20202020202025356900436F6D87 |
:1005C000706173733A202020253569004B25693A04 |
:1005D00025346920204B25693A25346920004E696D |
:1005E0003A2534692020526F3A2534692000477338 |
:1005F0003A253469202047693A2534692000503172 |
:100600003A253469202050323A253469200050338D |
:100610003A253469202050343A253469200047793E |
:10062000726F202D2053656E736F72004E69636B7D |
:100630002025346920282533692E25782900526F1A |
:100640006C6C2025346920282533692E25782900F3 |
:1006500059617720202534692028253369290041F4 |
:100660004343202D2053656E736F72004E69636B98 |
:100670002025346920282533692900526F6C6C20AD |
:10068000253469202825336929005A202020202577 |
:10069000346920282533692900566F6C74616765B9 |
:1006A0003A2020202533692E253169560043757282 |
:1006B00072656E743A2020202533692E25316941F8 |
:1006C00000506F7765723A2020202020253469572A |
:1006D000004469736368617267653A202535696D06 |
:1006E00041680052656365697665720052432D5119 |
:1006F00075616C6974793A202534690052432D4341 |
:1007000068616E6E656C733A25346900436F6D7075 |
:10071000617373004D61676E65743A202020253542 |
:1007200069004779726F3A20202020202535690022 |
:10073000536574706F696E743A2025356900506F87 |
:10074000746925693A202025336900506F74692542 |
:10075000693A202025336900536572766F202000A6 |
:10076000536574706F696E74202025336900506F73 |
:10077000736974696F6E3A202533690052616E6740 |
:10078000653A2533692D25336900424C2D43747237 |
:100790006C204572726F72732000253364202533FC |
:1007A0006420253364202533642000424C205465A6 |
:1007B0006D70657261747572650025336420253330 |
:1007C0006420253364202533642000424C20437587 |
:1007D0007272656E740028696E20302E31412900D6 |
:1007E0002533642025336420253364202533642099 |
:1007F00000424C2D4374726C20666F756E6420004D |
:100800002025632020202563202020256320202010 |
:10081000256320002025632020202563202020251B |
:1008200063202020256320002025632020202D2008 |
:1008300020202D2020202D200031300031310031AA |
:100840003200466C696768742D54696D652020001C |
:10085000546F74616C3A2535756D696E004163742F |
:100860003A20202535756D696E00287265736574B0 |
:1008700029000A0D2D2D3E20486172647761726552 |
:100880002056657273696F6E2042797465204368E3 |
:10089000616E676564203C2D2D000A0D47656E650D |
:1008A000726174696E672064656661756C7420504E |
:1008B0006172616D657465722053657420256400F2 |
:1008C0000A0D5573696E6720506172616D657465BC |
:1008D0007220536574202564000A0D47656E6572A9 |
:1008E0006174696E672064656661756C74204D691A |
:1008F000786572205461626C65000A0D4D697865F7 |
:10090000722D436F6E6669673A202725732720286A |
:100910002575204D6F746F727329000A0D41434392 |
:10092000206E6F742063616C69627261746564210A |
:100930000D0A0000008F001E01AD013B02CA0258E3 |
:1009400003E603740402058F051B06A7063307BEE2 |
:10095000074808D2085B09E3096B0AF20A780BFD25 |
:100960000B810C040D860D070E870E060F840F00F9 |
:10097000107B10F5106E11E5115B12CF124213B30C |
:100980001323149214FE146A15D3153B16A11605F1 |
:10099000176717C81727188318DE1837198E19E339 |
:1009A00019361A871AD61A231B6E1BB61BFD1B415C |
:1009B0001C831CC31C001D3C1D751DAB1DE01D12BE |
:1009C0001E421E6F1E9A1EC31EE91E0D1F2E1F4DB6 |
:1009D0001F691F841F9B1FB01FC31FD31FE11FEC84 |
:1009E0001FF51FFB1FFF1F002004010000187A00E5 |
:1009F0000201015E7B01030202F27B020403039AFF |
:100A00007C030004044F7C2532692E253169560091 |
:100A1000253364256320253033646D2563005374CA |
:100A200061747573004552524F523A20253264204A |
:100A30000053657425643A2573202000253469200D |
:100A40002532693A25303269002534696D25630005 |
:100A50002533692025336920253369202533690032 |
:100A60002533692025336920253369202533690022 |
:100A700054656D70657261747572657320202020F5 |
:100A8000002563432020202020002532692E2531B7 |
:100A90006956202533692E2531694100253469576F |
:100AA000202536696D4168004D61676E65743A2591 |
:100AB0003369252520253369256300496E636C69F8 |
:100AC0002E3A2533692563202825692920002532FF |
:100AD000756D2F73205361743A25642000202033F4 |
:100AE00044004E6F4678004447505300486F6D6590 |
:100AF0003A2533646D202533642563202563004E39 |
:100B00006F204E6176694374726C2100000005000D |
:100B100005000401060108000601020004000400AB |
:100B20000700070007000700070007000700030190 |
:100B30000301050017010F01060009010A0119014F |
:100B40000501050119011A010F01010009004E6F8D |
:100B5000204572726F722020202020202020004E1D |
:100B60006F7420636F6D70617469626C6520200022 |
:100B70004D4B334D6167206E6F7420636F6D7061F4 |
:100B8000004E6F20464320636F6D6D756E69636123 |
:100B90007400436F6D7061737320636F6D6D756E5C |
:100BA00069630047505320636F6D6D756E696361B3 |
:100BB00074696F00636F6D706173732076616C751B |
:100BC00065202020005243205369676E616C206CC1 |
:100BD0006F73742020004643207370692072782060 |
:100BE0006572726F7220004E6F204E4320636F6DEE |
:100BF0006D756E69636174004643204E69636B20B6 |
:100C00004779726F2020202000464320526F6C6C81 |
:100C1000204779726F2020202000464320596177B9 |
:100C2000204779726F2020202020004643204E6903 |
:100C3000636B204143432020202020004643205264 |
:100C40006F6C6C204143432020202020004643202D |
:100C50005A2D414343202020202020202000507284 |
:100C60006573737572652073656E736F72200049CA |
:100C700032432046432D3E424C2D4374726C20007B |
:100C8000426C204D697373696E67202020202020FC |
:100C9000004D69786572204572726F7220202020A5 |
:100CA00020004361726566726565204572726F72DD |
:100CB00020200047505320466978206C6F737420C1 |
:100CC000202020004D61676E6574204572726F723E |
:100CD00020202020004D6F746F7220726573746144 |
:100CE000727420202000424C204C696D697461743C |
:100CF000696F6E202020004750532052616E676557 |
:100D000020202020202020004E6F2053442D4361BE |
:100D100072642020202020200053442D4C6F6767F0 |
:100D2000696E67206572726F7200466C79696E67D2 |
:100D30002072616E676521202020004D617820417E |
:100D40006C74697475646521202020004E6F204703 |
:100D500050532066697820202020202000636F6D8A |
:100D600070617373206E6F742063616C2E00424C4F |
:100D70002D53656C66746573742020202020005309 |
:100D8000657420203A002021212020204C414E442F |
:100D9000494E4720202020212120200020212120F1 |
:100DA0004C69506F20766F6C74616765202121203B |
:100DB000200020202020204D696B726F4B6F7074D3 |
:100DC00065722020202020002020202020202020AC |
:100DD0002020202020202020202020202000202033 |
:100DE0002532692E253169562020002020253269C0 |
:100DF0002E25316956202000414C543A2534696D26 |
:100E000020256300414C543A2534696D202000416F |
:100E10004C543A2D2D2D2D200020202532693A25C5 |
:100E200030326920200020202532693A253032698D |
:100E30002020004449523A202533642563004300B2 |
:100E4000200020202535692020002020253569201C |
:100E50002000493A2532692E2531694120003A00A7 |
:100E60003A003A002D2D2D2D2D2D2D2D2D2B2D2DF4 |
:100E70002D2D2D2D2D2D2D2D2D002D2D2D2D2D2DCF |
:100E80002D2D2D2D2D2D2D2D2D2D2D2D2D2D2D00BF |
:100E90003A005341543A2532642000444953543AAD |
:100EA0002533646D004420003344002121004D416E |
:100EB000473A25337525252000484D3A25336425CA |
:100EC0006320256300696E636C3A253264256328CC |
:100ED0002532692900202020202532756D2F733A94 |
:100EE0002020484D3A253364256320256300455270 |
:100EF000523A202532642021004552523A200021E6 |
:100F000021204C69506F20766F6C746167652021D9 |
:100F10002100207777772E4D696B726F4B6F70745D |
:100F200065722E6465202000202532693A25303212 |
:100F30006920202532692E25316956202534696DB6 |
:100F4000416800202532693A253032692020253257 |
:100F5000692E25316956202534696D416800444960 |
:100F6000523A253364256300414C543A2534696D67 |
:100F700000414C543A2534696D00414C543A2D2DB2 |
:100F80002D2D2000256300484D3A2533642563202C |
:100F900020444953543A2533646D2025630050574B |
:100FA000523A2532692E2531694120282569572971 |
:100FB00020004346002020004750533A2532756DEB |
:100FC0002F73205341543A256420002020334420BD |
:100FD000004E4F46495800444750532000202020DF |
:100FE0004E6F204E6176694374726C202020202061 |
:100FF0002020002532692E2569202532692E256999 |
:10100000202532692E2569202532692E2569410067 |
:101010002533692025336920253369202533692547 |
:101020006343002532692E2569202532692E256902 |
:1010300041002532692E2569202532692E25692037 |
:101040002532692E2569202532692E256941002522 |
:101050003369202533692563432020202020202068 |
:101060002000253369202533692025336920253365 |
:1010700069256343004552523A20253264202100FD |
:101080004552523A20002121204C69506F20766F42 |
:101090006C7461676520212100207777772E4D6978 |
:1010A0006B726F4B6F707465722E646520200053F5 |
:1010B000657474696E673A257520257320004D6943 |
:1010C0006E3A2532692E253169562025732000415C |
:1010D0004C543A00504F54493A2533752000284F5C |
:1010E0004E29202000284F46462920004C494D49D2 |
:1010F0005400564152494F0044495341424C4544E3 |
:101100000043463A0044495341424C45440020289C |
:101110004F4E29200020284F4646290020544541A3 |
:101120004348004750533A0044495341424C4544D8 |
:10113000002846524545290028484F4D452900289A |
:1011400041494429200028484F4C44290020465357 |
:101150003A257573656B2000484F4D4520414C542E |
:101160003A0025756D00484F4C4420004E693A25E1 |
:10117000346920526F3A25346920433A2533690097 |
:1011800047733A2534692059613A25346920005063 |
:10119000313A2534692050323A25346920333A25D2 |
:1011A00033690050343A2534692050353A25346982 |
:1011B00020363A25336900434F55504C494E47205D |
:1011C0004F46462120004C4F4F50494E47212000AA |
:1011D0004848212000434F4D50415353204F46462D |
:1011E000212000004F505152535453565748005835 |
:1011F00059005A5545464748410049424A4A00006D |
:10120000000000000000000000444C4D0000000001 |
:10121000004E0000004B00430A0D7777772E4D6992 |
:101220006B726F4B6F707465722E64652028632932 |
:1012300020486953797374656D7320476D62480067 |
:101240000A0D74686520757365206F66207468697F |
:101250007320736F667477617265206973206F6E97 |
:101260006C79207065726D6974746564200A0D6F05 |
:101270006E206F726967696E616C204D696B726F69 |
:101280004B6F707465722D4861726477617265008E |
:101290005573657200486F545420563400414354CE |
:1012A0002044534C004A657469005370656B747236 |
:1012B000756D0050504D000A0D5265636569766585 |
:1012C000723A2000532E42757300756E6B6E6F7705 |
:1012D0006E2E205573696E672050504D2E2E2E00B5 |
:1012E0006E6F7420737570706F72746564206279AC |
:1012F00020686172647761726521000A0D202D20DB |
:101300004C4942204E4F5420434F4D504154494286 |
:101310004C452021212121000A0D0A0D21212042C6 |
:101320006F6F746C6F61646572206E6F7420636F91 |
:101330006D70617469626C6520746F2048617264BD |
:1013400077617265203E20322E322021210A0D0A5B |
:101350000D000A0D466C69676874436F6E74726F96 |
:101360006C0A0D48617264776172653A25642E25B6 |
:10137000640A0D536F6674776172653A5625642E60 |
:10138000253032642563200011241FBECFEFD0E446 |
:10139000DEBFCDBF12E0A0E0B1E0EEECF0E401E092 |
:1013A0000BBF02C007900D92A83EB107D9F71CE011 |
:1013B000A8EEB2E001C01D92A73BB107E1F77AEABF |
:1013C000E2E0F0E081E280935700D4907E0108943F |
:1013D000E11CF11C20EF37EF41E050E087016FE0A6 |
:1013E000DA01C9012F5F3F4F4F4F5F4FABBFFC0189 |
:1013F0008791F80181938F01615067FFF1CF84EEEF |
:101400008ABD898580936D05893138F086E08093A7 |
:10141000140187E0809313017BEAF7016EE081916C |
:1014200078277095615067FFFACF8889781729F07F |
:10143000F7E9DF1611F40000FECF0E940A0B0C94AE |
:1014400066A00C9400008AE891E09F938F938EE948 |
:1014500096E19F938F93E0919C05F0919D050995EE |
:101460000F900F900F900F90089580914108E82FF2 |
:10147000FF27EE0FFF1FE858F64F808191818D5EA8 |
:101480009F4F14F010920401808191818A5B9F4FDD |
:10149000CCF4809104018823A9F481E080930401B5 |
:1014A0008091D0058F5F8093D005853038F088EE2D |
:1014B00093E090931E0380931D03089566E970E006 |
:1014C0000E942B3C0895CF93DF93C82F882389F087 |
:1014D00080EB91E09F938F938EE996E19F938F939A |
:1014E000E0919C05F0919D0509950F900F900F904C |
:1014F0000F9080912601909127016BE270E00E948D |
:10150000D99F962F9F5F909300018091640882334A |
:1015100018F5989F802D112480930201CC23F1F0BF |
:1015200068EC70E0892F0E942B3C80910001992784 |
:101530009F938F9388EB91E09F938F938EE996E131 |
:101540009F938F93E0919C05F0919D0509958DB730 |
:101550009EB706968DBF02C0809302019091AF089E |
:10156000923338F480910001899F802D112480935B |
:10157000AF088091AF0890910201981720F4915024 |
:101580009093AF089F5FCC2309F441C0892F6AE094 |
:101590000E94B99F892F99279F938F938091020171 |
:1015A0000E94B99F99279F938F9383EC91E09F931B |
:1015B0008F93CEE9D6E1DF93CF93E0919C05F09134 |
:1015C0009D0509958DB79EB708968DBF8091AF0890 |
:1015D0008823E9F06AE00E94B99F892F99279F9399 |
:1015E0008F938091AF080E94B99F99279F938F9303 |
:1015F00087ED91E09F938F93DF93CF93E0919C05CC |
:10160000F0919D0509958DB79EB708968DBFDF9126 |
:10161000CF910895CFEFD0E4DEBFCDBF88249924C9 |
:10162000C1E07C2E14B815B88AE08AB98FE58BB971 |
:10163000B7EECB2EB3E0DB2E2EEC3FEFC20ED31E67 |
:10164000D7FEFACF6624199B08C04C9B04C085E1E5 |
:101650008093030108C086E101C089E18093030102 |
:1016600081E08093080481E887B93E9A8FEF88B9BA |
:101670008BE184B981E085B9469A84B7877F84BFBE |
:10168000809160008861809360001092600084EC1B |
:1016900099E090931E0380931D03109256041092BC |
:1016A000550410927D0910927C09109258041092F2 |
:1016B000570410925A0410925904209103012431C6 |
:1016C00028F084EC94E0A0E0B0E004C08BE095E06A |
:1016D000A0E0B0E08093420190934301A0934401C5 |
:1016E000B09345012A3011F0243110F0289801C040 |
:1016F000289A2C3010F0293111F4299A01C0299828 |
:101700000E94D91A0E94AA1A0E94A6160E94AC38FA |
:101710000E94EB1E81E00E94BE330E945F710E9416 |
:10172000927D85E00E947D9B809103018C3010F0BA |
:10173000893111F4299A01C0299878940E94A53220 |
:1017400080916A03826080936A0310926D030E9405 |
:10175000384884EF91E00E94701A6C0180916A030E |
:1017600080FD05C0C6010E94791A8823B9F38CEE6A |
:1017700091E09F938F93AEE9AA2EA6E1BA2EBF9275 |
:10178000AF92E0919C05F0919D05099580EA9FE05C |
:101790000E94701A6C01C0E0D0E00F900F900F9083 |
:1017A0000F900AE119E0FEECEF2EF8E0FF2E0E9408 |
:1017B000384880916A0380FD05C0C6010E94791AED |
:1017C0008823B9F3F70180811816ACF40BC00E948E |
:1017D000384880916A0380FD05C0C6010E94791ACD |
:1017E0008823B9F3C6010E94791A882321F4F801ED |
:1017F0008081882364F7F801808187FF19C02196D2 |
:10180000DF93CF9321978EEF91E09F938F93BF92B9 |
:10181000AF92E0919C05F0919D0509958091E902B8 |
:101820008F5F8093E9022DB73EB72A5F3F4F2DBFF0 |
:10183000219684E090E0E80EF91E085F1F4FCC303F |
:10184000D10508F4B4CFC0E0D0E007E119E0EEEC38 |
:10185000EE2EE8E0FE2EF801838187FD1DC0F70122 |
:1018600080811816CCF42196DF93CF93219781E0E5 |
:1018700092E09F938F938EE996E19F938F93E091EF |
:101880009C05F0919D05099582E080931B032DB77F |
:101890003EB72A5F3F4F2DBFF80183818078838355 |
:1018A000219624E030E0E20EF31E085F1F4FCC309B |
:1018B000D10588F20E94230A90913F088091E902A5 |
:1018C000981728F48091B60580618093B6058FE162 |
:1018D00092E09F938F93CEE9D6E1DF93CF93E0918F |
:1018E0009C05F0919D05099588EE93E00E94701A81 |
:1018F0006C010E94291F0F900F900F900F90C6014E |
:101900000E94791A8823D9F38FE392E09F938F93F3 |
:10191000DF93CF93E0919C05F0919D05099580E0C0 |
:101920000E940F3D809103010F900F900F900F9038 |
:101930008A3011F0843110F0289801C0289A80ED87 |
:1019400097E090931E0380931D0385E58093D20555 |
:101950008EE090E00E94C5309927182F00278FE075 |
:1019600090E00E94C530080F111D1093EF02009304 |
:10197000EE028AE090E00E94C5309927182F0027D8 |
:101980008BE090E00E94C530080F111D1093ED020E |
:101990000093EC020F5F1F4F39F08091EE0290919F |
:1019A000EF028F5F9F4F41F41092EF021092EE0210 |
:1019B0001092ED021092EC028091EC029091ED02F7 |
:1019C0009F938F938091EE029091EF029F938F935C |
:1019D00084E492E09F938F93DF93CF93E0919C05F3 |
:1019E000F0919D0509950E94EE2588E893E190937A |
:1019F0003D0180933C01C1E0C093D1058C2F0E9432 |
:101A0000630A809167080E94C99A0E94230A80EDA8 |
:101A100097E00E94701A6C018AEF90E00E94701AA1 |
:101A200083E0809399071092E8028091B2082DB765 |
:101A30003EB7285F3F4F2DBF84FF02C0C093F00226 |
:101A400012BC11BC8091F202882311F04798FECF9E |
:101A500080912103882309F4B4C28091180188235E |
:101A600009F4AFC2F894809121038150809321033F |
:101A700078948091D005882319F00E94350A02C01D |
:101A80000E94BF4B0E943848209103012A3011F078 |
:101A9000243110F0289801C0289A809149048823A5 |
:101AA00031F0809149048150809349040EC08091A7 |
:101AB0006F00806280936F0010927909109278090C |
:101AC0008091B60588608093B60580913C01909125 |
:101AD0003D01019790933D0180933C0180913C0131 |
:101AE00090913D01892B21F080916B038823C9F1EE |
:101AF00080913C0190913D01892BD9F40E94E833FB |
:101B000085E090E090933D0180933C018091D30764 |
:101B10009091D40701969093D4078093D307809136 |
:101B2000B60581608093B60580919A0782608093A4 |
:101B30009A0780910B0190910C018F5F9F4FC1F428 |
:101B4000809148048823A1F088EA91E690931E03CF |
:101B500080931D0380E890E090930C0180930B012B |
:101B600007C02A3011F0243110F0289801C0289ABB |
:101B70000E94799C80912103882309F020C28091E2 |
:101B80006805882319F00E94FE8D19C280911C03FC |
:101B9000882311F40E94807180911101882311F033 |
:101BA0000E94331B0E94F0160E947D12C6010E9403 |
:101BB000791A882309F4FFC184E190E0C80ED91E88 |
:101BC0000E94F11A80916708863019F40E947C8384 |
:101BD00004C0843011F40E94CE8E809108048823C2 |
:101BE00031F18091E0079091E1078C52914074F0BF |
:101BF0008091A9079091AA0780509240C4F48091E7 |
:101C0000E0079091E107835593408CF0639432E3B1 |
:101C1000361570F480914804882331F08091B50521 |
:101C200080628093B50504C08093340401C06624AB |
:101C300080916B03882329F48091F10A8E3150F44E |
:101C400005C08091B60582608093B60580919A07A1 |
:101C500082600FC080911D0390911E03892B59F45F |
:101C600080913C0190913D01079728F080919A075F |
:101C70008D7F80939A078091F002882361F0809194 |
:101C80004904873940F01092F00288E893E190937C |
:101C90001E0380931D0380910601882321F081504B |
:101CA000809306012EC08093DC0510921C041092D4 |
:101CB0001B0410921A041092190410921804109226 |
:101CC0001704809149048823E1F480910B019091DD |
:101CD0000C018F5F9F4FA9F42091F002223089F010 |
:101CE00088E99AE390931E0380931D0380E09CE0B3 |
:101CF00090930C0180930B01222319F082E08093D2 |
:101D0000F0028091A401893C70F081508093A4017D |
:101D10008091B6058B7F8093B6058091B90581606F |
:101D20008093B90551C080917E0A8823F9F0809193 |
:101D3000B60584608093B60589E080932A0580917A |
:101D40000B0190910C018F5F9F4F81F480914804AB |
:101D5000882361F088E99AE390931E0380931D0322 |
:101D600080E098EA90930C0180930B0110921C057F |
:101D700010921B0510921A05109219051092180561 |
:101D80001092710A8FEF8093E60A1092B00A1092B7 |
:101D9000AF0A1092B20A1092B10A8FEF9FEF9093A0 |
:101DA000AE0A8093AD0A1092380410923904109252 |
:101DB0003A0410923B0410923C048091B9058E7F46 |
:101DC0008093B9051092A40160910201262F332758 |
:101DD000809126019091270128173907F4F080910E |
:101DE000100480628093100480910B0190910C018B |
:101DF0008F5F9F4F91F480912601909127010B975F |
:101E000064F080E797E190931E0380931D0380E0C8 |
:101E100093E090930C0180930B0112BC11BC809154 |
:101E2000F1028F5F8093F102813309F07BC0109241 |
:101E3000F10280915205882319F081508093520558 |
:101E40008091100481FF0AC08091EA029091EB0218 |
:101E500001969093EB028093EA0204C05AEA852E21 |
:101E600055E0952E80911104909112048050944079 |
:101E700008F049C02091E2073091E3074091E40760 |
:101E80005091E50780911E0190911F01A0912001C2 |
:101E9000B0912101281739074A075B0764F4809144 |
:101EA000E2079091E307A091E407B091E50705965A |
:101EB000A11DB11D20C02091E2073091E3074091A0 |
:101EC000E4075091E50780911E0190911F01A091B8 |
:101ED0002001B091210182179307A407B5079CF454 |
:101EE0008091E2079091E307A091E407B091E507A4 |
:101EF0000597A109B1098093E2079093E307A093A6 |
:101F0000E407B093E507862F9927019620912601D3 |
:101F100030912701821793072CF4809110048F7D54 |
:101F2000809310040894811C911C82E788168BE032 |
:101F3000980609F040C0882499242091EE0230913F |
:101F4000EF022F5F3F4F3093EF022093EE0280911C |
:101F5000EC029091ED0201969093ED028093EC02D9 |
:101F6000832F9927682F8EE090E00E94CD308091DA |
:101F7000EE029091EF029070682F8FE090E00E9447 |
:101F8000CD308091EC029091ED02892F9927682F36 |
:101F90008AE090E00E94CD308091EC029091ED02B9 |
:101FA0009070682F8BE090E00E94CD3084E190E04B |
:101FB0000E94701A6C010E94AD760E94C57D71105E |
:101FC0007A94772039F40E947176882319F08CE096 |
:101FD000782E38CD80911C03882309F033CD0E94E0 |
:101FE000807130CD1F920F920FB60F9211248F93F4 |
:101FF0009F93EF93FF93809108018823E1F48091F0 |
:102000000C0390910D03019690930D0380930C03A4 |
:10201000FC01E354F94FE081ED3019F08C3D91055E |
:1020200039F410920D0310920C0381E080930801A3 |
:10203000E093C60004C010920D0310920C03FF91B0 |
:10204000EF919F918F910F900FBE0F901F90189559 |
:102050001F920F920FB60F9211242F933F934F931D |
:102060005F936F937F938F939F93AF93BF93CF9320 |
:10207000EF93FF9390E08091F202813029F48091F8 |
:10208000C6008093CE00D1C08091F202823029F444 |
:102090008091C6008093DF05C8C08091C600809300 |
:1020A0000403509112035C3D10F090931303809150 |
:1020B00004038D3009F06AC080911303823009F067 |
:1020C00065C090931303852F992781529A4FFC0185 |
:1020D0003297408120910E0330910F03241B310968 |
:1020E000DC0111978C91281B3109C9019F709093D5 |
:1020F0000F0380930E0346E0969587954A95E1F786 |
:10210000982F935C909310032F733070235C20936F |
:1021100011038081981729F48C91281711F491E00C |
:1021200006C090E0809101038F5F8093010380914E |
:102130000303882309F079C0992309F476C081E06C |
:1021400080930303580F509300035150E52FFF274E |
:10215000E152FA4F8DE080838091E105823509F0EC |
:1021600064C0C0914804CC2309F05FC00E94EE25F2 |
:1021700088E190E02CE00FB6F894A8958093600079 |
:102180000FBE20936000C0931B034FC02091130328 |
:10219000822F992781309105F9F0823091051CF446 |
:1021A000892B21F040C0029711F13DC080910403BA |
:1021B000833239F480910303882319F481E08093FA |
:1021C0001303809104038093DF0581E08093120361 |
:1021D00080910403992722C02F5F20931303E52FDA |
:1021E000FF27E152FA4F80910403808309C0E52F55 |
:1021F000FF27E152FA4F8091040380835C3D20F475 |
:102200005F5F5093120302C01092130320910403E6 |
:1022100080910E0390910F03820F911D90930F03F5 |
:1022200080930E0302C010921303FF91EF91CF91A0 |
:10223000BF91AF919F918F917F916F915F914F91DE |
:102240003F912F910F900FBE0F901F901895AC01EA |
:10225000A0E0B0E09D01A817B90748F4EDEBF6E067 |
:102260008191280F311D1196A417B507C8F33F704F |
:10227000FD01E354F94FC90156E0969587955A95AB |
:10228000E1F7835C80831196FD01E354F94F2F73CE |
:102290003070822F835C8083A254B94F8DE08C9381 |
:1022A000109208018091BD068093C6000895A0E0B9 |
:1022B000B0E0EDE5F1E10C9432A02C859D850E8512 |
:1022C000BB2483E28093BD069F599093BE06209362 |
:1022D000BF0633E0E32EF12C002309F49EC0CF8427 |
:1022E000D888BE016D5E7F4FA989BA8901501097C9 |
:1022F00009F493C01097B9F0F601EB0DF11DB394FA |
:102300009081119791F4002349F1FB016E5F7F4F9B |
:10231000DB01C080D1806E5F7F4F0D90BC91A02DFE |
:10232000BB24015002C090E019C01097B9F0F6012B |
:10233000EB0DF11DB3944081119791F4002341F10D |
:10234000FB016E5F7F4FDB01C080D1806E5F7F4FEE |
:102350000D90BC91A02DBB24015002C040E018C0DC |
:102360001097B1F0F601EB0DF11DB39410811197A8 |
:1023700081F4002371F0FB013296DB01CD90DC90FB |
:10238000BF016E5F7F4FA081B181BB24015001C0AE |
:1023900010E0F701E354F94F892F86958695835C09 |
:1023A00080830894E11CF11CF701E354F94F892F55 |
:1023B00099278370907024E0880F991F2A95E1F780 |
:1023C00055279A0194E0369527959A95E1F7822B47 |
:1023D000835C80830894E11CF11CF701E354F94FFE |
:1023E0004F705070440F551F440F551F812F992770 |
:1023F00026E0969587952A95E1F7842B835C808368 |
:102400000894E11CF11CF701E354F94F1F73135CAE |
:1024100010830894E11CF11C6ACFC7010E942711A8 |
:10242000E9E00C944EA0A3E07A2F409100034650BF |
:10243000442309F458C0E72FFF27E152FA4F808167 |
:102440008D537F5FE72FFF27E152FA4F20812D53F5 |
:102450007F5FE72FFF27E152FA4F30813D537F5FC7 |
:10246000E72FFF27E152FA4F60816D537F5F992775 |
:10247000880F991F880F991F522F52955F70582B04 |
:10248000822F99278F709070F4E0880F991FFA952A |
:10249000E1F7232F26952695282B832F99278370E4 |
:1024A0009070E6E0880F991FEA95E1F7682B41509C |
:1024B0004F3FC9F0EA2FFF27E152FA4F5083AF5F39 |
:1024C00041504F3F81F0EA2FFF27E152FA4F20831E |
:1024D000AF5F41504F3F39F0EA2FFF27E152FA4FEB |
:1024E0006083AF5FA5CF82EE95E09093FF0280936B |
:1024F000FE02A350A093FD020895A2E0B0E0E3E83D |
:10250000F2E10C9438A080910303882309F412C4EB |
:102510000E9413128091E005823609F0DEC280919C |
:10252000E10599278037910509F4AFC081379105FE |
:10253000C4F48A36910509F43BC28B36910544F404 |
:102540008B34910571F18636910509F464C1C5C2D9 |
:102550008D36910509F469C08E36910509F44DC098 |
:10256000BCC28437910541F1853791054CF4813720 |
:10257000910509F491C08337910509F4E4C0ADC217 |
:102580008737910509F4D6C1883791052CF4853732 |
:10259000910509F492C1A1C28937910509F477C167 |
:1025A0009CC2E091FE02F091FF02808191819093A4 |
:1025B00091018093900191C280910003A091FE024D |
:1025C000B091FF02853140F080E1EAEBF5E00D903B |
:1025D00001928A95E1F70DC08D919D910D90BC916E |
:1025E000A02D8093BA059093BB05A093BC05B09332 |
:1025F000BD0580EF8093FB024BC0809108018823CA |
:10260000E1F38DE490E09F938F9381EC98E09F93AA |
:102610008F9381E08F938F938EE48F930E94571155 |
:102620008DB79EB707968DBF58C2A091FE02B0919C |
:10263000FF021C91113081F48DE4E1ECF8E00D9083 |
:1026400001928A95E1F70E94E03119838091B605E5 |
:102650008F7E8093B60501C019828091080188237E |
:10266000E1F381E090E09F938F93CE0101969F93D9 |
:102670008F9381E08F938F938DE48F930E945711F6 |
:10268000ADB7BEB71796ADBF28C281E080930603F1 |
:102690008FEF8093060121C280914804882309F0BE |
:1026A0001CC2E091FE02F091FF02E0818E2F8A5061 |
:1026B0008A3058F48983882311F481E003C086307E |
:1026C00010F085E0898361E00EC08E2F84518A303E |
:1026D00070F48983882311F481E003C0863010F000 |
:1026E00085E0898360E089810E94623212C0E983BB |
:1026F000EF3F19F40E94433289838981882311F4C2 |
:1027000081E003C0863010F085E0898389810E94D2 |
:10271000E330809108018823E1F380E890E09F9303 |
:102720008F9380E498E09F938F9381E090E09F9354 |
:102730008F93CE0101969F938F9382E08F9381E0D8 |
:102740008F9381E52DC12091FE023091FF02D901C6 |
:102750008C918150853008F045C0F9018181813626 |
:1027600009F040C0809148048823E1F52F5F3F4F76 |
:1027700080E8E0E4F8E0D9010D9001928A95E1F754 |
:10278000F90182910E945031809181089927AA27EE |
:10279000BB27BC01CD0124EC39E040E050E00E94B1 |
:1027A0009A9FDC01CB018093880190938901A093CB |
:1027B0008A01B0938B01809182089927AA27BB27B1 |
:1027C000BC01CD010E949A9FDC01CB018093840162 |
:1027D00090938501A0938601B09387010E944332B4 |
:1027E000898301C01982809108018823E1F381E087 |
:1027F00090E09F938F93CE0101969F938F9381E0FA |
:102800008F938F9383E58F930E9457118DB79EB757 |
:1028100007968DBF2BC080914804882309F05DC1C5 |
:10282000E091FE02F091FF02E0818E2F8150853011 |
:1028300018F48E2F0E94E3300E94433289838091E6 |
:1028400008018823E1F381E090E09F938F93CE010C |
:1028500001969F938F9381E08F938F9386E48F935C |
:102860000E945711ADB7BEB71796ADBF109148047F |
:10287000112341F46EE670E089810E942B3C812F88 |
:102880000E94630A809167080E94C99A26C1198232 |
:102890002981A091FE02B091FF02E8E7F9E08D9155 |
:1028A000992787FD909593A382A3822F8F5F8983B9 |
:1028B000282F32968C3098F310C1E091FE02F091EF |
:1028C000FF0280810E9402388A83882319F481E004 |
:1028D000898301C01982809108018823E1F388E08F |
:1028E00090E09F938F938FE099E09F938F9321E0E7 |
:1028F00030E03F932F938091FE029091FF029F93CF |
:102900008F933F932F93CE0102969F938F933F9384 |
:102910002F93CE01820F931F9F938F9384E08F9309 |
:1029200081E08F9385E58F930E945711EDB7FEB735 |
:1029300073963CC08091FD02893008F4CEC020918E |
:10294000FE023091FF022F5F3F4F88E0AFE0B9E019 |
:10295000F90101900D928A95E1F7D9018E910E94BB |
:1029600055378A83882319F481E0898301C019824D |
:10297000809108018823E1F321E030E03F932F9319 |
:10298000CE0102969F938F933F932F93CE01820F98 |
:10299000931F9F938F9382E08F9381E08F9387E5BE |
:1029A0008F930E945711EDB7FEB73B96EDBF95C0D0 |
:1029B00080914804882309F090C00E94809A8983FE |
:1029C000823019F0843009F088C020E430E0F894B7 |
:1029D0008091C1008F738093C1008091C9008F7373 |
:1029E0008093C9008091C100877E8093C10080914F |
:1029F000C900877E8093C9008091C80087FF03C00B |
:102A00008091CE00F9CF8091C00087FF03C08091F4 |
:102A1000C600F9CFE091FE02F091FF02E081E130C3 |
:102A200021F482E08093F2022EC0E43611F421E812 |
:102A300030E081E08093F202832F99278093CD00CC |
:102A40002093CC008091CD008093C5008091CC0074 |
:102A50008093C4008091CA008F7D8093CA008091CA |
:102A6000CA008F7E8093CA008091C9008B7F8093BB |
:102A7000C9008091CA0084608093CA008091CA0016 |
:102A800082608093CA008091CA00877F8093CA00C9 |
:102A90008091C200877F8093C2008091C9008E7FA1 |
:102AA0008093C9008091C10088618093C1008091AA |
:102AB000C90088618093C9008091C10080688093BB |
:102AC000C1008091C90080688093C90010926E0097 |
:102AD00010926F001092700078948091E105992710 |
:102AE0008436910509F4BBC085369105ACF4813676 |
:102AF000910509F46FC0823691052CF48B34910551 |
:102B000009F45DC00FC18236910509F470C08336A7 |
:102B1000910509F47FC006C18C36910509F4EDC01A |
:102B20008D3691054CF48736910509F4F8C0883646 |
:102B3000910509F4B2C0F6C08437910529F08637B3 |
:102B4000910509F4E8C0EEC080910003A091FE0257 |
:102B5000B091FF02803140F080E1EAEBF5E00D90AA |
:102B600001928A95E1F70DC08D919D910D90BC91D8 |
:102B7000A02D8093BA059093BB05A093BC05B0939C |
:102B8000BD05809108018823E1F31F928091050122 |
:102B90008F9384E58F930E9457118AEF8093FB02F5 |
:102BA0008FEF8093060180EA9FE00E94701A909355 |
:102BB000F4028093F3020F900F900F90B3C0E09156 |
:102BC000FE02F091FF0280819181909391018093A8 |
:102BD0009001A8C0E091FE02F091FF0280818093F5 |
:102BE0000701803298F08FE1809307010FC0A09118 |
:102BF000FE02B091FF028BE0E2EDF5E00D90019254 |
:102C00008A95E1F78091DB058093DB078FEF809356 |
:102C1000060188C08091F7029091F802892B89F40F |
:102C2000E091FE02F091FF02E081EE2351F08AE094 |
:102C3000E89FC00111240E94701A9093AD05809303 |
:102C4000AC05E091FE02F091FF0290818AE0989F2E |
:102C5000C00111249093F8028093F70215C08FEF02 |
:102C600080930601E091FE02F091FF0290818AE0DC |
:102C7000989FC00111249093FA028093F902892B46 |
:102C800019F081E08093080380EA9FE00E94701AA7 |
:102C90009093F4028093F30245C08FEF8093060176 |
:102CA000E091FE02F091FF02908197FD08C082E062 |
:102CB000809305031092F6021092F5021AC09095C7 |
:102CC00080916303892B8093630391818AE0989FAD |
:102CD000C00111249093F6028093F50284E0809362 |
:102CE000050380EA9FE00E94701A9093F40280939B |
:102CF000F30281E08093090315C08FEF80930601F2 |
:102D0000E091FE02F091FF0280818093640381E0F4 |
:102D100080930A0307C081E08093070303C081E02A |
:102D200080930B03109203031092FF021092FE0295 |
:102D30001092FD02E3E0CE5F0C9454A0982F809196 |
:102D4000C00085FFFCCF9093C60008950F931F939A |
:102D500088E18093C1008091C00082608093C000B0 |
:102D60008091C10080688093C1008091C10080641F |
:102D70008093C10000E010E00093C5008AE290E07B |
:102D80008093C4008091F9029091FA020E94701A17 |
:102D90009093AF058093AE058CED90E00E94701A81 |
:102DA0009093DE058093DD0582E08093B0058093EB |
:102DB000B10581E08093B4058BE08093B205109259 |
:102DC000B3051092B805809103018093B705109365 |
:102DD000FF020093FE021092FD021F910F910895D1 |
:102DE000A0E1B0E0E6EFF6E10C9437A08091080195 |
:102DF000882309F489C28091F3029091F4020E9421 |
:102E0000791A882361F01092F6021092F50210925E |
:102E1000FA021092F9021092F8021092F7028091D1 |
:102E2000F5029091F602892B41F08091BB069091BA |
:102E3000BC060E94791A882329F48091090388230B |
:102E400009F460C080910801882309F45BC0809177 |
:102E500005030FEE17E08430A8F00E94042680E5F9 |
:102E600090E09F938F931F930F9381E08F938F93A5 |
:102E700088E48F930E9457112DB73EB7295F3F4FCB |
:102E80002DBF34C01092650386E694E09F938F9324 |
:102E900087EF95E29F938F93E0919C05F0919D05BC |
:102EA000099584E190E09F938F931F930F9381E0A6 |
:102EB00090E09F938F9385E093E09F938F9382E0C0 |
:102EC0008F9381E08F9388E48F930E9457118091B4 |
:102ED0000503982F8F5F809305032DB73EB7215FC1 |
:102EE0003F4F2DBF943010F0109205038091F502F2 |
:102EF0009091F6020E94701A9093BC068093BB06D4 |
:102F00001092090380910A03882351F180910801EE |
:102F1000882331F10E94042680E590E09F938F93EF |
:102F20008FEE97E09F938F9321E030E03F932F93B4 |
:102F300088E291E09F938F933F932F9384E693E0F1 |
:102F40009F938F9383E08F9381E08F938CE48F9393 |
:102F50000E94571110920A038DB79EB70F968DBF2E |
:102F6000809107038823D1F0809108018823B1F074 |
:102F70008AE090E09F938F9380EB95E09F938F93EF |
:102F800081E08F938F9386E58F930E945711109263 |
:102F900007032DB73EB7295F3F4F2DBF80910B032D |
:102FA0008823D9F0809108018823B9F08BE090E064 |
:102FB0009F938F9382ED95E09F938F9381E08F9302 |
:102FC000809105018F9387E48F930E94571110928F |
:102FD0000B038DB79EB707968DBF8091F902909134 |
:102FE000FA02892B41F08091AE059091AF050E94C5 |
:102FF000791A882321F480910803882341F1809174 |
:103000000801882321F10E94353B82E490E09F93E0 |
:103010008F9389E997E09F938F9381E08F938F93AC |
:1030200084E48F930E945711109208032DB73EB786 |
:10303000295F3F4F2DBF8091F9029091FA020097CE |
:1030400031F00E94701A9093AF058093AE05809185 |
:10305000F7029091F802892B09F497C08091AC0592 |
:103060009091AD050E94791A882309F48EC0809151 |
:103070000801882309F489C08091840A9091850A07 |
:1030800090939F0580939E058091860A9091870A70 |
:103090009093A1058093A0052091660A3091670A5C |
:1030A0004091680A5091690ADA01C90163E0880F0A |
:1030B000991FAA1FBB1F6A95D1F7820F931FA41FE8 |
:1030C000B51F820F931FA41FB51F2091420130919D |
:1030D00043014091440150914501BC01CD010E9442 |
:1030E0000EA03093A3052093A20580916B049091CC |
:1030F0006C04A0916D04B0916E0449E0B595A7955C |
:10310000979587954A95D1F78093A4058091670498 |
:1031100090916804A0916904B0916A0439E0B59572 |
:10312000A795979587953A95D1F78093A5058091B6 |
:10313000730490917404A0917504B091760429E011 |
:10314000B595A795979587952A95D1F78093A6056C |
:103150008EE090E09F938F938EE995E09F938F93FD |
:1031600081E08F938F9383E48F930E945711809116 |
:10317000F7029091F8020E94701A9093AD05809327 |
:10318000AC058DB79EB707968DBF809107018F3F25 |
:1031900079F1992704E0880F991F0A95E1F78A5978 |
:1031A0009D4F40E150E0BC01CE0101960E94E49D9C |
:1031B00080E190E09F938F93CE0101969F938F9330 |
:1031C00081E090E09F938F9387E091E09F938F93AE |
:1031D00082E08F9381E08F9381E48F930E94571157 |
:1031E0008FEF809307012DB73EB7255F3F4F2DBF6F |
:1031F0008091DB078823C9F0809108018823A9F01A |
:1032000081E090E09F938F938BED97E09F938F9356 |
:1032100081E08F938F9382E48F930E9457111092D5 |
:10322000DB078DB79EB707968DBF80910603882375 |
:10323000D1F0809108018823B1F086E490E09F935B |
:103240008F9388E799E09F938F9381E08F938F937B |
:1032500080E58F930E945711109206032DB73EB759 |
:10326000295F3F4F2DBF8091DD059091DE050E94C3 |
:10327000791A882309F448C080910801882309F449 |
:1032800043C08091840A9091850A9093CB058093E6 |
:10329000CA058091860A9091870A9093CD05809304 |
:1032A000CC05809125048093CE05809124048093E1 |
:1032B000CF0588E090E09F938F938AEC95E09F93F1 |
:1032C0008F9381E08F9383E08F938BE68F930E949F |
:1032D00057118091D0052DB73EB7295F3F4F2DBFC5 |
:1032E000853018F086E08093D0058091A401882372 |
:1032F00019F483E690E002C087EE93E00E94701A12 |
:103300009093DE058093DD05E4E0C05F0C9453A04C |
:103310001F920F920FB60F9211242F933F935F933A |
:103320006F937F938F939F93AF93BF93EF93FF938D |
:1033300080911C03882329F080911C038150809385 |
:103340001C0380913D05882319F0815080933D0531 |
:10335000809124038150809324038F3F09F051C052 |
:1033600089E08093240380912203909123030196A6 |
:103370009093230380932203809112018F5F8170C9 |
:1033800080931201882349F480912103843028F42A |
:10339000809121038F5F80932103349903C081E0E2 |
:1033A00080931A0380911D0390911E03892B11F1C4 |
:1033B00080911D0390911E030B9750F080911D0387 |
:1033C00090911E030A9790931E0380931D0304C0DF |
:1033D00010921E0310921D0380911D0390911E03F5 |
:1033E00020910B0130910C0182239323892B41F012 |
:1033F000479A07C08FEF9FEF90930C0180930B01CA |
:10340000479880911A03882309F45AC02091A40197 |
:10341000222309F055C08091560A83FF51C086B11E |
:103420009927FC01E071F07084FF13C080911F03A5 |
:103430009091200301969093200380931F03809125 |
:103440001F0390912003895E9340D0F120931A03CB |
:1034500037C080911F0390912003892B69F18091DF |
:103460001F03909120038A56914030F580911F03ED |
:103470009091200369E270E00E94C59F80911F0334 |
:1034800090912003860F971F9093200380931F0332 |
:1034900080911F03909120030B9750F080911F03A0 |
:1034A000909120030A97909391018093900104C01A |
:1034B000F0939101E09390011092200310921F036A |
:1034C000FF91EF91BF91AF919F918F917F916F91FC |
:1034D0005F913F912F910F900FBE0F901F90189505 |
:1034E0002091220330912303280F391FC90101962F |
:1034F00008952091220330912303821B930B892F7F |
:1035000099278695807490700895CF93DF930E94D9 |
:10351000701AEC01CE010E94791A8823D9F3DF9149 |
:10352000CF910895CF93DF930E94701AEC0109C0E8 |
:1035300080911801882329F0909318018FEC8093D3 |
:103540007A00CE010E94791A982F882389F3DF919F |
:10355000CF9108959FB7F8945F983E9A469A8091CC |
:10356000B0008F708093B0008091B0008360809332 |
:10357000B0008091B1008B738093B1008091B10055 |
:103580008B608093B1001092B2008FEF8093B300F4 |
:103590008091B00080688093B000809170008A7F35 |
:1035A00080937000809170008260809370009FBF54 |
:1035B00008958AE090E00E94701A9093DD0780934E |
:1035C000DC0782E085BD83EB84BD8FEF88BD84EB93 |
:1035D00087BD86E086BD80916E00816080936E001D |
:1035E00008958091B10820916F0182FF30C09091C1 |
:1035F00070088CE3989FB001112490916F0880E5CA |
:10360000989FA0011124922F905897FD9D5F95954A |
:10361000959586E09802C00111242091090130910E |
:103620000A01281B390B30930A0120930901421724 |
:1036300053072CF050930A0140930901089526176F |
:10364000370784F070930A01609309010895822F6F |
:10365000992736E0880F991F3A95E1F790930A0170 |
:10366000809309010895EF92FF920F931F93CF93D8 |
:10367000DF9380917708E82FFF27E85BFE4F968164 |
:10368000C08180911101813009F026C18091B30879 |
:1036900087FF05C0C0E0D0E0E0E0F0E046C0892F41 |
:1036A000992787FD9095A92FB92F2091A3043091D8 |
:1036B000A4044091A5045091A604BC01CD010E9430 |
:1036C0009A9F97FF04C061587F4F8F4F9F4F7B0198 |
:1036D0008C0187E015950795F794E7948A95D1F7C3 |
:1036E0008C2F992787FD9095A92FB92F20919B04A6 |
:1036F00030919C0440919D0450919E04BC01CD01E9 |
:103700000E949A9F97FF04C061587F4F8F4F9F4F31 |
:10371000B7E09595879577956795BA95D1F7F801B4 |
:10372000E701C61BD70BE80BF90B2091230530915D |
:103730002405C901A3E0880F991FAA95E1F7821B10 |
:10374000930BAA2797FDA095BA2FC81BD90BEA0B9C |
:10375000FB0B80916D019927AA27BB27BC01CD01E6 |
:103760009E01AF010E949A9F97FF04C061507E4F57 |
:103770008F4F9F4FFC01EB0179E0F595E795D795C9 |
:10378000C7957A95D1F71091B108609109017091B0 |
:103790000A0112FF05C07093100160930F0118C059 |
:1037A00040910F015091100180917608282F332706 |
:1037B000CB01841B950BB9010E94D99F80910F0109 |
:1037C00090911001860F971F9093100180930F0125 |
:1037D00010FF14C080910F019091100197FD0F967A |
:1037E00064E0959587956A95E1F7AA2797FDA095DE |
:1037F000BA2FC80FD91FEA1FFB1F15C080910F01F8 |
:103800009091100197FD0F9654E0959587955A95E4 |
:10381000E1F7AA2797FDA095BA2F8C1B9D0BAE0B45 |
:10382000BF0BFD01EC012091AA08222321F13327CF |
:103830008091160390911703829FA001839F500DE2 |
:10384000929F500D1124CA01AA2797FDA095BA2F67 |
:103850008C0F9D1FAE1FBF1F2F5F3F4F442737FDAB |
:103860004095542FBC01CD010E940EA03093170348 |
:103870002093160304C0D0931703C09316038091BE |
:103880006F08282F3327220F331F220F331F8091F9 |
:10389000160390911703821793077CF080917008AC |
:1038A000282F3327220F331F220F331F8091160337 |
:1038B000909117032817390724F4309317032093A6 |
:1038C000160380910301843108F4FDC08091110139 |
:1038D0008F5F80931101F9C0892F992787FD9095FB |
:1038E000A92FB92F20919B0430919C0440919D04F5 |
:1038F00050919E04BC01CD010E949A9F97FF04C085 |
:1039000061587F4F8F4F9F4F7B018C0187E015954A |
:103910000795F794E7948A95D1F78C2F992787FD1F |
:103920009095A92FB92F2091A3043091A404409120 |
:10393000A5045091A604BC01CD010E949A9F9B0151 |
:10394000AC0197FF04C021583F4F4F4F5F4FC7E076 |
:103950005595479537952795CA95D1F72E0D3F1D5B |
:10396000401F511F80916C019927AA27BB27BC01DA |
:10397000CD010E949A9F97FF04C061507E4F8F4FE8 |
:103980009F4FFC01EB01B9E0F595E795D795C795F9 |
:10399000BA95D1F780916E019927A6E0880F991FFB |
:1039A000AA95E1F740910D0150910E012091760802 |
:1039B0003327841B950BB9010E94D99F80910D017B |
:1039C00090910E01860F971F90930E0180930D0129 |
:1039D0008091B10881FF14C080910D0190910E017A |
:1039E00097FD0F9674E0959587957A95E1F7AA274C |
:1039F00097FDA095BA2FC80FD91FEA1FFB1F15C04E |
:103A000080910D0190910E0197FD0F9664E09595C0 |
:103A100087956A95E1F7AA2797FDA095BA2F8C1B89 |
:103A20009D0BAE0BBF0BFD01EC012091AB082223D7 |
:103A300021F133278091140390911503829FA001F7 |
:103A4000839F500D929F500D1124CA01AA2797FD04 |
:103A5000A095BA2F8C0F9D1FAE1FBF1F2F5F3F4F2A |
:103A6000442737FD4095542FBC01CD010E940EA084 |
:103A7000309315032093140304C0D0931503C0930F |
:103A8000140380917308282F3327220F331F220F2E |
:103A9000331F8091140390911503821793077CF0D4 |
:103AA00080917408282F3327220F331F220F331FD2 |
:103AB00080911403909115032817390724F430934B |
:103AC00015032093140310921101E6E0CDB7DEB781 |
:103AD0000C9451A01F920F920FB60F9211242F93A6 |
:103AE0003F934F935F938F939F93EF93FF938091B7 |
:103AF000030190912503843108F04CC0992309F00B |
:103B000029C18091B00086FF24C08091B0008F7BD6 |
:103B10008093B000809116039091170387559E4FB4 |
:103B2000909319038093180325E08D3D920718F0B8 |
:103B30008CED95E005C08757914030F487E791E020 |
:103B4000909319038093180380911803909119039F |
:103B5000C2C08091B00080648093B00080917508ED |
:103B6000282F33278DED96E0289FA001299F500D27 |
:103B7000389F500D1124CA0120912603309127034C |
:103B8000821B930B909319038093180381E0809319 |
:103B90001101DDC0992309F0DDC08091B00086FFDE |
:103BA0009FC08091B0008F7B8093B000E09128038C |
:103BB00020917508EE23D9F433278DED96E0289FE8 |
:103BC000A001299F500D389F500D1124CA0120914A |
:103BD000260330912703821B930B90931903809344 |
:103BE00018031092270310922603469AB0C02E178E |
:103BF00038F48AE090E09093190380931803A7C0EB |
:103C000089EA93E090931903809318038E2F9927E4 |
:103C100083309105D9F08430910534F481309105D9 |
:103C200049F0029761F020C08430910591F005972A |
:103C300099F01AC0809116039091170304C08091E7 |
:103C400014039091150387559E4F1DC08091310A32 |
:103C500005C080910A0A02C080913A0A9927880F0C |
:103C6000991F880F991FEFCFFF27EE0FFF1FE8580E |
:103C7000F64F20813181220F331F809118039091DC |
:103C80001903820F931F9093190380931803809157 |
:103C900018039091190355E08D3D950718F08CEDB0 |
:103CA00095E005C08757914030F487E791E0909305 |
:103CB00019038093180320911803309119032C5B8A |
:103CC000304030931903209318038091260390917C |
:103CD0002703820F931F909327038093260337C0F7 |
:103CE0008091B00080648093B0008CEB90E0909362 |
:103CF000190380931803809126039091270384541D |
:103D00009F4F909327038093260380911B03882362 |
:103D100021F080914904882321F480911B03823093 |
:103D200011F4469801C0469A809128038F5F8093D2 |
:103D30002803282F33278091750899270196821729 |
:103D400093072CF481E0809311011092280381E005 |
:103D500080932503209118033091190341E02F37F8 |
:103D6000340730F08FEF8093B3002F5F30400FC0E7 |
:103D70002F3F3105C9F0C0F0A9014F5F50404F37C8 |
:103D8000510550F480E88093B300205830403093C0 |
:103D900019032093180312C08FEF8093B300509340 |
:103DA0001903409318030AC0809118038093B3004D |
:103DB000109219031092180310922503FF91EF91AE |
:103DC0009F918F915F914F913F912F910F900FBED7 |
:103DD0000F901F90189510927C008FEC80937A00C2 |
:103DE0000895809108046091160170911701209147 |
:103DF0003503882379F0CB01AA27BB27332727FD7A |
:103E00003095432F532FBC01CD010E949A9FDC01B6 |
:103E1000CB0116C084E0660F771F8A95E1F7CB01CE |
:103E2000AA27BB27332727FD3095432F532FBC01EB |
:103E3000CD010E949A9FDC01CB010497A109B10931 |
:103E400080932D0390932E03A0932F03B093300300 |
:103E50000895CF93DF93109235030E94F11E83E003 |
:103E600090E00E94C530C82FDD27C03FD10508F47F |
:103E70002A96C7BD8C2F809588BD86E990E00E9468 |
:103E8000921A80911C0190911D018152934010F073 |
:103E9000C0EFD0E0C630D10510F1C7BD8C2F8095A2 |
:103EA00088BD84E690E00E94921A8BE794E09F938D |
:103EB0008F938EE996E19F938F93E0919C05F0910B |
:103EC0009D05099580911C0190911D010F900F9007 |
:103ED0000F900F908152934010F42197DBCFC09345 |
:103EE000EC076C2F83E090E00E94CD3080914D086C |
:103EF00080FF0AC08091EC078A508C3D28F08091A9 |
:103F0000B50580648093B50580E1809315018091AB |
:103F100008048823E9F080910301873150F4CC38FC |
:103F2000D105B0F480EA90E08C1B9D0B6AE170E053 |
:103F300009C0CA3AD10560F48CEB90E08C1B9D0B54 |
:103F400063E170E00E94C59FCB01805F8093150103 |
:103F500080911501282F332780911C0190911D011C |
:103F6000829FA001839F500D929F500D1124CA0182 |
:103F7000AA27BB2780931E0190931F01A0932001C5 |
:103F8000B09321018CE291E00E94921ADF91CF91CF |
:103F90000895EF92FF921F93CF9310E080ED97E08A |
:103FA0000E94701A7C01CCE8133019F4CB3008F071 |
:103FB000C9E010E080914403909145038C5F9340E9 |
:103FC00024F480911B0181500AC080914403909198 |
:103FD00045038750944034F080911B018F5F80939C |
:103FE0001B0101C011E080914203909143038C5F5B |
:103FF000934024F480911A0181500AC080914203B9 |
:10400000909143038750944034F080911A018F5F60 |
:1040100080931A0101C01F5F80914003909141037A |
:104020008C5F934024F48091190181500AC08091E3 |
:1040300040039091410387509440C4F0809119014E |
:104040008F5F8093190113C08DE794E09F938F9346 |
:104050008EE996E19F938F93E0919C05F0919D05E9 |
:1040600009950F900F900F900F905FC01F5F82E136 |
:104070008093700380916A038E7F80936A0385EA40 |
:104080008093BC0080911B018A3040F48091B5057B |
:1040900081608093B5058AE080931B0180911B01AC |
:1040A000863F40F08091B50581608093B50585EF2E |
:1040B00080931B0180911A018A3040F48091B505EC |
:1040C00082608093B5058AE080931A0180911A017D |
:1040D000863F40F08091B50582608093B50585EFFD |
:1040E00080931A01809119018A3040F48091B505BE |
:1040F00084608093B5058AE080931901809119014D |
:10410000863F40F08091B50584608093B50585EFCA |
:104110008093190180917003882339F0C7010E94B0 |
:10412000791A882309F090CFF5CF109218018FECFF |
:1041300080937A00809118018823E1F3CA3020F43B |
:104140008AE090E00E94921AC15009F02DCF86E4D7 |
:1041500090E00E94921ACF911F91FF90EF900895E6 |
:104160001F920F920FB60F921124EF92FF920F93AE |
:104170001F932F933F934F935F936F937F938F93EF |
:104180009F93AF93BF93CF93DF93EF93FF93809170 |
:104190004D03282F3327442755278F5F80934D03E6 |
:1041A000F9012231310508F0F2C4EA5BFF4F0C94AB |
:1041B00060A0809178009091790046C0809178004D |
:1041C00090917900B8C18091780090917900909396 |
:1041D000510380935003E3C18091AD049091AE04EC |
:1041E0002091780030917900821B930B9093DF0728 |
:1041F0008093DE078091DE079091DF0790935B0349 |
:1042000080935A03EBC180917800909179002091BE |
:10421000AF043091B004821B930B9093EB07809313 |
:10422000EA078091EA079091EB0790935D038093F2 |
:104230005C03AFC4809154039091550320917800A2 |
:1042400030917900820F931F90935503809354030C |
:1042500081E0A0C480915203909153032091780093 |
:1042600030917900820F931F9093530380935203F0 |
:1042700084E090C48091B20883FF1AC08091260127 |
:10428000909127019C01220F331F280F391F409165 |
:104290007800509179008BE090E0489FB001499FF1 |
:1042A000700D589F700D1124CB016EE170E00FC0AE |
:1042B00080912601909127019C01220F331F280F26 |
:1042C000391F809178009091790063E070E00E943E |
:1042D000C59F260F371F369527953695279530931E |
:1042E00027012093260185E055C4809178009091A4 |
:1042F00079009093E1078093E0078091E007909127 |
:10430000E1074091A9045091AA04841B950B609188 |
:10431000A804262F332727FD3095821B930B9093FB |
:104320003B0380933A0380910804882309F071C00D |
:1043300080913A0390913B0302977CF172E04E3EEC |
:1043400057070CF0A7C020914E0330914F032B5F0D |
:104350003F4F30934F0320934E03255030408091C0 |
:10436000110490911204845F914030F4215F3F4F1B |
:1043700030934F0320934E0380914E0390914F034F |
:10438000853691050CF486C04F5F5F4F5093AA04A9 |
:104390004093A9048456904037C080913A0390918D |
:1043A0003B038F5F9F4F0CF075C082E04732580788 |
:1043B0000CF470C020914E0330914F0325503040D3 |
:1043C00030934F0320934E032B5F3F4F8091110496 |
:1043D00090911204845F914030F42F50304030931C |
:1043E0004F0320934E0380914E0390914F037FEF34 |
:1043F0008C3997070CF04EC0415050405093AA049E |
:104400004093A9048C599F4F90934F0380934E0380 |
:1044100041C08091260A9091270A8F5C9F41D4F178 |
:1044200080913A0390913B030297ACF020914E03A8 |
:1044300030914F03C901019690934F0380934E032F |
:10444000895893413CF166301CF46F5F6093A80477 |
:10445000275833411BC080913A0390913B038F5FF3 |
:104460009F4FC4F420914E0330914F03C90101972F |
:1044700090934F0380934E0388579C4E5CF46B3FA0 |
:104480001CF061506093A80429573C4E30934F03B1 |
:1044900020934E0380913A0390913B039C01442763 |
:1044A00037FD4095542F8091630490916404A0914E |
:1044B0006504B0916604820F931FA41FB51F8093FB |
:1044C000630490936404A0936504B0936604209100 |
:1044D000630430916404409165045091660457FF71 |
:1044E00004C021503C4F4F4F5F4F6AE055954795B0 |
:1044F000379527956A95D1F780916304909164046C |
:10450000A0916504B0916604821B930BA40BB50BBC |
:104510008093630490936404A0936504B09366044D |
:1045200030C18091520390915303209178003091D3 |
:104530007900820F931F909353038093520310923C |
:104540004C032AC3809103018A3071F48091780072 |
:10455000909179002091500330915103820F931F65 |
:1045600001969695879517C040915003509151033D |
:10457000843158F02091780030917900240F351F54 |
:104580008FEF97E0821B930B06C08091780090918B |
:104590007900840F951F909341038093400380918D |
:1045A0001401F8C28091AD049091AE04209178007E |
:1045B00030917900821B930B9093DF078093DE0785 |
:1045C0008091DE079091DF0720915A0330915B03C1 |
:1045D000820F931F90933F0380933E0380911301BA |
:1045E000D9C280917800909179002091AF043091E8 |
:1045F000B004821B930B9093EB078093EA078091A2 |
:10460000EA079091EB0720915C0330915D03820FE4 |
:10461000931F90933D0380933C03BBC220915403AE |
:10462000309155038091780090917900280F391FBF |
:104630003093550320935403809103018A3019F479 |
:10464000220F331F04C0220F331F220F331F30935A |
:104650005503209354032091540330915503C9010D |
:1046600037FD079603E0959587950A95E1F79093B6 |
:104670004503809344038091560390915703820F22 |
:10468000931F97FD01969595879590935703809377 |
:1046900056032091B9043091BA04821B930B909376 |
:1046A00025018093240120914A0330914B0380918E |
:1046B000240190912501280F391F37FF02C02F5F79 |
:1046C0003F4F3595279530934B0320934A03C0CD38 |
:1046D000209152033091530380917800909179009A |
:1046E000280F391F30935303209352038091030105 |
:1046F0008A3019F4220F331F04C0220F331F220FF8 |
:10470000331F30935303209352032091520330916F |
:104710005303C90137FD0796A3E095958795AA95A0 |
:10472000E1F7909343038093420380915803909163 |
:104730005903820F931F97FD019695958795909346 |
:104740005903809358032091B7043091B804821B19 |
:10475000930B909323018093220120914803309181 |
:1047600049038091220190912301280F391F37FFBF |
:1047700002C02F5F3F4F3595279530934903209313 |
:10478000480383E007C280910804882309F180E090 |
:104790000E9401999B01AC0120503F4F4F4F5F4F4A |
:1047A00057FF06C09B01AC0121503D4F4F4F5F4F5B |
:1047B00079E055954795379527957A95D1F72093C8 |
:1047C000290330932A0340932B0350932C0310C0EA |
:1047D0008091430490914404A0914504B091460413 |
:1047E0008093290390932A03A0932B03B0932C0367 |
:1047F00010924D0381E080931801809131039091D4 |
:1048000032030196909332038093310380917800B4 |
:104810009091790090931D0180931C018091080470 |
:10482000882309F472C080911C0190911D017C01C4 |
:104830000027112780912D0390912E03A0912F0323 |
:10484000B0913003E81AF90A0A0B1B0BE0925E03E1 |
:10485000F0925F0300936003109361038091150150 |
:10486000282F33274427552780911E0190911F013F |
:10487000A0912001B0912101BC01CD010E940EA0A8 |
:1048800080911E0190911F01A0912001B091210102 |
:10489000821B930BA40BB50B80931E0190931F01F9 |
:1048A000A0932001B093210180911E0190911F01DE |
:1048B000A0912001B09121018E0D9F1DA01FB11F5D |
:1048C00080931E0190931F01A0932001B0932101BA |
:1048D0008091E2079091E307A091E407B091E5078A |
:1048E00020911E0130911F01409120015091210122 |
:1048F000821B930BA40BB50B809343049093440449 |
:10490000A0934504B093460444C180911C0190914A |
:104910001D01AA27BB27C0915E03D0915F03E091E0 |
:104920006003F0916103C80FD91FEA1FFB1FC093FA |
:104930005E03D0935F03E0936003F0936103809183 |
:1049400062038F5F80936203803108F422C18091FB |
:104950001E0190911F01A0912001B09121019C01A5 |
:10496000AD0163E0220F331F441F551F6A95D1F735 |
:10497000281B390B4A0B5B0B2C0F3D1F4E1F5F1F73 |
:1049800080912D0390912E03A0912F03B0913003BD |
:10499000281B390B4A0B5B0B57FF04C0295F3F4FA5 |
:1049A0004F4F5F4F03E055954795379527950A95EB |
:1049B000D1F720931E0130931F01409320015093A3 |
:1049C0002101C091E207D091E307E091E407F09163 |
:1049D000E50780911E0190911F01A0912001B091E7 |
:1049E0002101C81BD90BEA0BFB0BC0934304D093E6 |
:1049F0004404E0934504F09346042091360330913B |
:104A00003703409138035091390357FF04C0215FA9 |
:104A10003F4F4F4F5F4F14E055954795379527957A |
:104A20001A95D1F78091360390913703A0913803FE |
:104A3000B0913903821B930BA40BB50B8093360303 |
:104A400090933703A0933803B093390380913603D2 |
:104A500090913703A0913803B09139038C0F9D1FBB |
:104A6000AE1FBF1F8093360390933703A093380384 |
:104A7000B09339038091360390913703A0913803A6 |
:104A8000B0913903B7FF03C00F96A11DB11DC4E05B |
:104A9000B595A79597958795CA95D1F72091430429 |
:104AA00030914404281B390B64E0213036071CF098 |
:104AB00020E034E006C07CEF2030370714F420E01B |
:104AC0003CEF8091330390913403809133039091B4 |
:104AD000340397FF03C0909581959F4FA901F3E0A0 |
:104AE000440F551FFA95E1F78D5B9240C4F0809119 |
:104AF0003303909134039C01E4E0220F331FEA95C5 |
:104B0000E1F7281B390B240F351F37FF02C0215F47 |
:104B10003F4F74E0359527957A95E1F717C080915E |
:104B20003303909134039C0165E0220F331F6A9593 |
:104B3000E1F7281B390B240F351F37FF02C0215E18 |
:104B40003F4F45E0359527954A95E1F7309334037B |
:104B50002093330380915E0390915F03A0916003E3 |
:104B6000B0916103B7FF03C00196A11DB11DB595BA |
:104B7000A7959795879580935E0390935F03A09385 |
:104B80006003B093610388E08093620302C01092D7 |
:104B90004D0382E080934C0380914C0380937C0012 |
:104BA00080914D03882319F08FEC80937A00FF9158 |
:104BB000EF91DF91CF91BF91AF919F918F917F91B5 |
:104BC0006F915F914F913F912F911F910F91FF90A6 |
:104BD000EF900F900FBE0F901F90189590E2EFEEA0 |
:104BE000F7E08FE49193815087FFFCCF0895909177 |
:104BF0006503903540F4E92FFF27E151F84F80839A |
:104C00009F5F909365030895A0E0B0E0EAE0F6E2CC |
:104C10000C9433A02091630320FF0AC080916403A9 |
:104C2000882311F0815002C0809128018093640391 |
:104C300021FF0CC09091640380912801981719F40A |
:104C40001092640303C09F5F90936403822F99279F |
:104C500080FF04C081FF02C0109264030E94EE2511 |
:104C600080916403282F332707EF15E2C0919C053C |
:104C7000D0919D058A3098F481E1809365033F933C |
:104C80002F9384EB94E09F938F931F930F93FE01D8 |
:104C900009952DB73EB72A5F3F4F2DBF12C080E167 |
:104CA000809365033F932F9389EB94E09F938F93B9 |
:104CB0001F930F93FE0109954DB75EB74A5F5F4F93 |
:104CC0004DBF20916403822F9927AA27BB27FC019F |
:104CD000429710F00C949F2EE85AFF4F07EF15E211 |
:104CE000C0919C05D0919D050C9460A01092650325 |
:104CF0008EEB94E09F938F9357EFE52E55E2F52EC0 |
:104D00001F930F93FE01099584E1809365030F9033 |
:104D10000F900F900F9082E690E09F938F9382E028 |
:104D200090E09F938F939F938F93809103016AE00C |
:104D30000E94B99F892F99279F938F938091030198 |
:104D40000E94B99F99279F938F938EEC94E09F9335 |
:104D50008F931F930F93E0919C05F0919D0509950A |
:104D600088E2809365038DB79EB70E968DBF82EC67 |
:104D700098E09F938F938091010199279F938F9340 |
:104D800086EE94E09F938F931F930F93E0919C0581 |
:104D9000F0919D0509958091B6059927EDB7FEB76D |
:104DA0003896EDBFEC01C071D07084FF0AC08CE36F |
:104DB0008093650384EF94E09F938F931F930F93E9 |
:104DC00053C790912A05992351F18CE38093650391 |
:104DD000892F99279F938F9381E095E09F938F93DD |
:104DE000FF92EF92E0919C05F0919D050995DF936C |
:104DF000CF9390912A0581E1989FC0011124825B95 |
:104E0000944F9F938F93FF92EF92E0919C05F091C6 |
:104E10009D0509952DB73EB7245F3F4F77C490910C |
:104E2000B505992371F08CE380936503892F992749 |
:104E30009F938F9389E095E09F938F93FF92EF92DA |
:104E400004C490916B039923B9F08CE380936503BC |
:104E5000892F99279F938F9380E295E09F938F935B |
:104E6000FF92EF92E0919C05F0919D0509958DB719 |
:104E70009EB706968DBF6CC780913C0190913D0115 |
:104E8000069730F48CE38093650386E395E0E8C6EB |
:104E90009091F10A9E3108F05BC78CE38093650323 |
:104EA000892F99279F938F9383E495E00AC11092ED |
:104EB00065038091430490914404A0914504B0910E |
:104EC0004604BC01CD0125E030E040E050E00E9406 |
:104ED0000EA03F932F9387E595E09F938F931F93A9 |
:104EE0000F93FE01099584E1809365032DB73EB7CA |
:104EF0002A5F3F4F2DBF80913F0490914004A091C5 |
:104F00004104B0914204BC01CD0125E030E040E015 |
:104F100050E00E940EA03F932F9384E695E09F936C |
:104F20008F931F930F93E0919C05F0919D05099538 |
:104F300088E2809365034DB75EB74A5F5F4F4DBF10 |
:104F400080911C0190911D019F938F9381E795E0C3 |
:104F50009F938F931F930F93E0919C05F0919D0574 |
:104F600009958CE3809365038DB79EB706968DBF38 |
:104F700087B599279F938F938EE795E09F938F93A3 |
:104F80001F930F93E0919C05F0919D050995EDB756 |
:104F9000FEB73696EDBF80910804882309F4D8C681 |
:104FA00089E3809365038BE895E09F938F931F932C |
:104FB0000F93E0919C05F0919D0509958DE48093F8 |
:104FC00065030F900F900F900F9080911501992716 |
:104FD0009F938F938FE895E08CC31092650382E9CD |
:104FE00095E09F938F9347EFE42E45E2F42E1F93B5 |
:104FF0000F93FE01099584E1809365030F900F9054 |
:105000000F900F908091A3049091A404A091A50407 |
:10501000B091A604B7FF04C081509C4FAF4FBF4F63 |
:105020003AE0B595A795979587953A95D1F7BF93AF |
:10503000AF939F938F938FE995E09F938F93FF9208 |
:10504000EF92E0919C05F0919D05099588E280938F |
:1050500065034DB75EB7485F5F4F4DBF80919B04BE |
:1050600090919C04A0919D04B0919E04B7FF04C050 |
:1050700081509C4FAF4FBF4F2AE0B595A7959795AC |
:1050800087952A95D1F7BF93AF939F938F938EEA1D |
:1050900095E09F938F93FF92EF92E0919C05F091A2 |
:1050A0009D0509958CE3809365038DB79EB708969F |
:1050B0008DBF8091120A9091130A9F938F938DEB6D |
:1050C00095E09F938F93FF92EF92E0919C05F09172 |
:1050D0009D050995EDB7FEB73696D8C391E0F92E38 |
:1050E000C1E0D0E00AE719E09F2D969584E1989FF2 |
:1050F000C001112480936503F801828193819F93FD |
:105100008F932196DF93CF932197808191819F93F5 |
:105110008F93DF93CF938CEC95E09F938F9387EFE2 |
:1051200095E29F938F93E0919C05F0919D050995E1 |
:105130002DB73EB7245F3F4F2DBF32E0F30E2296CE |
:105140000C5F1F4F48E04F1578F602C610926503BA |
:1051500080914208E82FFF27EE0FFF1FE858F64F17 |
:10516000808191819F938F9380914108E82FFF2741 |
:10517000EE0FFF1FE858F64F808191819F938F9328 |
:105180008EED95E09F938F931F930F93FE010995EA |
:1051900084E1809365038DB79EB708968DBF80919B |
:1051A0004408E82FFF27EE0FFF1FE858F64F8081D5 |
:1051B00091819F938F9380914308E82FFF27EE0FF3 |
:1051C000FF1FE858F64F8081918181589F4F9F9330 |
:1051D0008F938EEE95E09F938F931F930F93E091A3 |
:1051E0009C05F0919D05099588E280936503EDB7D4 |
:1051F000FEB73896EDBF80914608E82FFF27EE0FE7 |
:10520000FF1FE858F64F8081918181589F4F9F93EF |
:105210008F9380914508E82FFF27EE0FFF1FE85876 |
:10522000F64F8081918181589F4F9F938F938EEF8E |
:1052300095E09F938F931F930F93E0919C05F091BE |
:105240009D0509958CE3809365032DB73EB7285FD4 |
:105250003F4F2DBF80914808E82FFF27EE0FFF1F1B |
:10526000E858F64F8081918181589F4F9F938F938B |
:1052700080914708E82FFF27EE0FFF1FE858F64FF1 |
:105280008081918181589F4F9F938F938EE096E00C |
:105290009F938F931F930F93E0919C05F0919D0531 |
:1052A00009954DB75EB7485F5F4FD8C1109265034F |
:1052B0008EE196E09F938F9387EFE82E85E2F82E9C |
:1052C0001F930F93FE01099584E1809365030F906E |
:1052D0000F900F900F908091B9049091BA049C01A7 |
:1052E00097FF02C0215F3F4F207F821B930B97FDEA |
:1052F0000196959587959F938F938091B90490918E |
:10530000BA0497FD0F96B4E095958795BA95E1F7A5 |
:105310009F938F932091B9043091BA0437FF02C054 |
:10532000295F3F4FA3E035952795AA95E1F7809136 |
:10533000440390914503821B930B9F938F938CE2C0 |
:1053400096E09F938F93FF92EF92E0919C05F091EE |
:105350009D05099588E2809365038DB79EB70A96EF |
:105360008DBF8091B7049091B8049C0197FF02C053 |
:10537000215F3F4F207F821B930B97FD01969595F0 |
:1053800087959F938F938091B7049091B80497FD70 |
:105390000F96E4E095958795EA95E1F79F938F93B3 |
:1053A0002091B7043091B80437FF02C0295F3F4F06 |
:1053B00073E0359527957A95E1F7809142039091B6 |
:1053C0004303821B930B9F938F938EE396E09F93EF |
:1053D0008F93FF92EF92E0919C05F0919D050995C6 |
:1053E0008CE380936503EDB7FEB73A96EDBF8091ED |
:1053F000B5049091B60497FD0196959587959F9376 |
:105400008F938091B5049091B60420914003309120 |
:105410004103821B930B9F938F9380E596E09F93AC |
:105420008F93FF92EF92E0919C05F0919D05099575 |
:105430002DB73EB7285F3F4F69C1109265038FE5D6 |
:1054400096E09F938F931F930F93FE01099584E13C |
:10545000809365030F900F900F900F908091AF0491 |
:105460009091B0049F938F9380913C0390913D0362 |
:105470009F938F938CE696E09F938F931F930F9348 |
:10548000E0919C05F0919D05099588E28093650364 |
:105490004DB75EB7485F5F4F4DBF8091AD049091AF |
:1054A000AE049F938F9380913E0390913F039F930F |
:1054B0008F938BE796E09F938F931F930F93E091C9 |
:1054C0009C05F0919D0509958CE3809365038DB74C |
:1054D0009EB708968DBF8091A9049091AA049F93CE |
:1054E0008F9380913A0390913B039F938F938AE827 |
:1054F00096E09F938F931F930F93C0C11092650303 |
:1055000080912601909127016AE070E00E94D99F66 |
:105510009F938F9380912601909127016AE070E01C |
:105520000E94D99F7F936F9389E996E09F938F9311 |
:105530001F930F93FE01099584E1809365032DB7B6 |
:105540003EB7285F3F4F2DBF8091EB0A9091EC0A48 |
:105550006AE070E00E94C59F9F938F938091EB0A51 |
:105560009091EC0A6AE070E00E94C59F7F936F9370 |
:105570008DEA96E09F938F931F930F93E0919C0584 |
:10558000F0919D05099588E2809365034DB75EB75C |
:10559000485F5F4F4DBF8091ED0A9091EE0A9F9357 |
:1055A0008F9381EC96E09F938F931F930F93E091DD |
:1055B0009C05F0919D0509958CE3809365038DB75B |
:1055C0009EB706968DBF8091EF0A9091F00A9F9347 |
:1055D0008F9381ED96E09F938F931F930F9375CDDB |
:1055E0001092650383EE96E09F938F931F930F9322 |
:1055F000FE01099588E2809365030F900F900F904C |
:105600000F908091490499279F938F938CEE96E099 |
:105610009F938F931F930F93E0919C05F0919D05AD |
:1056200009958CE3809365032DB73EB72A5F3F4F02 |
:105630002DBF80917709992701979F938F938CEFC6 |
:1056400096E09F938F931F930F93E0919C05F091A9 |
:105650009D0509954DB75EB74A5F5F4F4DBF78C353 |
:10566000109265038CE097E09F938F931F930F93A5 |
:10567000FE01099584E1809365030F900F900F90D0 |
:105680000F9080919001909191019F938F9384E16D |
:1056900097E09F938F931F930F93E0919C05F09158 |
:1056A0009D05099588E2809365038DB79EB70696A0 |
:1056B0008DBF8091120A9091130A9F938F9382E27B |
:1056C00097E09F938F931F930F93E0919C05F09128 |
:1056D0009D0509958CE380936503EDB7FEB736967B |
:1056E000EDBF80916104909162049F938F9380E35A |
:1056F00097E09F938F931F930F93E0919C05F091F8 |
:105700009D0509952DB73EB72A5F3F4F2DBF20C39A |
:105710005AE4C52E54E0D52E20E030E0E90143E004 |
:10572000F42EC0936503F60181916F0199279F9331 |
:105730008F9389010F5F1F4F1F930F938EE397E0A5 |
:105740009F938F9387EF95E29F938F93E0919C05B2 |
:10575000F0919D0509952DB73EB7285F3F4F2DBFAE |
:10576000FA9464969801F7FEDCCFF2C29EE4C92E4B |
:1057700094E0D92EC0E0D0E08E0183E0F82E0093B3 |
:105780006503F60181916F0199279F938F93259669 |
:10579000DF93CF938BE497E09F938F9387EF95E20E |
:1057A0009F938F93E0919C05F0919D0509952DB7EE |
:1057B0003EB7285F3F4F2DBFFA940C5E1F4F2497D2 |
:1057C000F7FEDDCFC5C21092650388E597E09F9391 |
:1057D0008F93B7EFEB2EB5E2FB2E1F930F93FE01D5 |
:1057E000099584E1809365030F900F900F900F90BF |
:1057F00080916F0199279F938F9380E697E09F9305 |
:105800008F931F930F93E0919C05F0919D0509954F |
:1058100088E2809365034DB75EB74A5F5F4F4DBF27 |
:10582000809116039091170397FD039695958795A0 |
:10583000959587959F938F938EE697E09F938F938F |
:10584000FF92EF92E0919C05F0919D0509958CE304 |
:10585000809365038DB79EB706968DBF80917008C3 |
:1058600099279F938F9380916F0899279F938F9388 |
:105870008CE797E09F938F93FF92EF92E0919C05C6 |
:10588000F0919D050995EDB7FEB73896EDBF60C262 |
:10589000109265038AE897E09F938F93F7EFCF2EDE |
:1058A000F5E2DF2E1F930F93FE0109950F900F90E5 |
:1058B0000F900F90C7E1D9E000E010E0E2E0FE2E8B |
:1058C000802F8C5E809365038B8D99278F779070E6 |
:1058D0009F938F938B8999278F7790709F938F9346 |
:1058E0008B8599278F7790709F938F938B819927C2 |
:1058F0008F7790709F938F938AE997E09F938F9310 |
:10590000DF92CF92E0919C05F0919D0509952DB70E |
:105910003EB7245F3F4F2DBFFA940C5E1F4FA096F9 |
:10592000F7FECECF15C2109265038BEA97E09F93E6 |
:105930008F9377EFC72E75E2D72E1F930F93FE013B |
:1059400009950F900F900F900F90C7E1D9E000E0FC |
:1059500010E062E0F62E802F8C5E809365038F8DC1 |
:10596000992787FD90959F938F938F89992787FD1E |
:1059700090959F938F938F85992787FD90959F93FF |
:105980008F938F81992787FD90959F938F938AEBB3 |
:1059900097E09F938F93DF92CF92E0919C05F091D7 |
:1059A0009D0509954DB75EB7445F5F4F4DBFFA94B3 |
:1059B0000C5E1F4FA096F7FECECFCAC110926503B2 |
:1059C0008BEC97E09F938F9357EFC52E55E2D52E22 |
:1059D0001F930F93FE01099587E4809365030F9051 |
:1059E0000F900F900F9086ED97E09F938F931F93EA |
:1059F0000F93E0919C05F0919D050995FF240F9070 |
:105A00000F900F900F90C0E0D0E08E01802F8C5E41 |
:105A1000809365038C2F8D5F0E94A97D9F938F9348 |
:105A20008C2F8E5F0E94A97D9F938F938C2F8F5F09 |
:105A30000E94A97D9F938F938C2F0E94A97D9F9395 |
:105A40008F9380EE97E09F938F93DF92CF92E091B8 |
:105A50009C05F0919D0509959E012C5F3F4F80911B |
:105A60003F089927EDB7FEB73C96EDBF28173907D9 |
:105A70000CF06EC1F3940C5E1F4FE901F2E0FF15CC |
:105A800028F666C11092650381EF97E09F938F938C |
:105A900047EFE42E45E2F42E1F930F93FE01099584 |
:105AA00084E1809365030F900F900F900F90809189 |
:105AB0003209881F8827881F97E0899FC001112419 |
:105AC0008D969F938F9380912A09881F8827881F1E |
:105AD00096E0899FC00111248D969F938F938091AA |
:105AE0002209881F8827881F95E0899FC0011124FB |
:105AF0008D969F938F9380911A09881F8827881FFE |
:105B00009927880F991F880F991F8D969F938F93C0 |
:105B100080E098E09F938F931F930F93E0919C05F3 |
:105B2000F0919D05099588E2809365032DB73EB7F6 |
:105B3000245F3F4F2DBF80915209881F8827881FFF |
:105B40009BE0899FC00111248D969F938F93809134 |
:105B50004A09881F8827881F9AE0899FC00111245D |
:105B60008D969F938F9380914209881F8827881F65 |
:105B700099E0899FC00111248D969F938F93809106 |
:105B80003A09881F8827881F992723E0880F991FC3 |
:105B90002A95E1F78D969F938F9384E198E09F93E8 |
:105BA0008F931F930F93E0919C05F0919D050995AC |
:105BB0008CE3809365034DB75EB7445F5F4F4DBF85 |
:105BC00080915A09881F8827881F9CE0899FC001FF |
:105BD00011248D969F938F9388E298E09F938F93E3 |
:105BE0001F930F93E0919C05F0919D05099580917D |
:105BF0006209EDB7FEB73696EDBF87FF12C080E4AD |
:105C00008093650389E398E09F938F931F930F938D |
:105C1000E0919C05F0919D0509950F900F900F90D4 |
:105C20000F9080916A0987FF12C084E48093650316 |
:105C30008CE398E09F938F93FF92EF92E0919C0505 |
:105C4000F0919D0509950F900F900F900F90809106 |
:105C5000720987FF7DC088E4809365038FE398E035 |
:105C60009F938F93FF92EF92E0919C05F0919D0599 |
:105C700009950F900F900F900F906AC010926503D6 |
:105C800082E498E09F938F931F930F93FE010995F1 |
:105C900084E1809365030F900F900F900F90809197 |
:105CA000EC029091ED029F938F9380E598E09F9393 |
:105CB0008F931F930F93E0919C05F0919D0509959B |
:105CC00088E2809365032DB73EB72A5F3F4F2DBF13 |
:105CD0008091EE029091EF029F938F938DE598E073 |
:105CE0009F938F931F930F93E0919C05F0919D05D7 |
:105CF000099589E4809365034DB75EB74A5F5F4FAE |
:105D00004DBF8AE698E09F938F931F930F93E09186 |
:105D10009C05F0919D050995809163030F900F906C |
:105D20000F900F9083FF14C01092EF021092EE02BA |
:105D300060E070E08EE090E00E94DE3009C080916B |
:105D40002801281719F42150209328011092640388 |
:105D500010926303E8E0CDB7DEB70C944FA0F99939 |
:105D6000FECF92BD81BDF89A80B599270895F99923 |
:105D7000FECF1FBA92BD81BD60BD0FB6F894FA9AEE |
:105D8000F99A0FBE08954AEA20E030E02617370757 |
:105D900040F4FC018191480F2F5F3F4F26173707D2 |
:105DA000C8F3842F99270895EAEA40E050E04617A7 |
:105DB000570778F49C01F999FECF32BD21BDF89ABE |
:105DC00080B5E80F4F5F5F4F2F5F3F4F4617570774 |
:105DD00090F38E2F9927089581E08093430882E005 |
:105DE0008093420883E08093410884E080934408D4 |
:105DF00085E08093450886E08093460887E080939D |
:105E0000470888E08093480889E0809349088AE041 |
:105E100080934A088BE080934B088CE080934C0879 |
:105E2000089581E6809340088CE0E4EBF8E011925D |
:105E30008A95E9F780910301843150F08AE08093DC |
:105E40006008109284088BE180935C088EE40AC09D |
:105E500083E08093600880E2809384088EE18093E1 |
:105E60005C0885E5809381088093820880E28093B6 |
:105E700083081092B0088AE680934D0882E78093E9 |
:105E8000B20880E58093B30886E08093670810929B |
:105E9000A4081092A10838E030935A0886EE809347 |
:105EA0005B0880E480935D0885E0809350082EE1D4 |
:105EB00020934E0890910804992399F084E18093EF |
:105EC000510888E280934F082093530881E0809323 |
:105ED0005408109255088FE7809356082093A7081E |
:105EE00010C08FE08093510820934F08909353087F |
:105EF0003093540884E1809355089093560890930A |
:105F0000A7088FE0809352081092AC088CE0809331 |
:105F1000AD081092690810926A0810926B081092EE |
:105F20006C081092860810928708109288081092C8 |
:105F3000890890E890936D0842E340936E0872E000 |
:105F40007093B10888E180936F0886EE80937008A3 |
:105F500083E0809375085DE7509378085093790843 |
:105F600050937A089093710865E56093720886E40F |
:105F7000809373088CED809374088CE3809376088B |
:105F8000109277089AEA90938A088CEC80938C0898 |
:105F900010928E0890938F0898E290938B089093BC |
:105FA0008D081092900840937B082AE520937C0886 |
:105FB00040937D0836E03093910884E68093920800 |
:105FC000809393082093940888E780939508909392 |
:105FD00099088BE4809396086093970880939808BB |
:105FE00030939A0888E080939B0840939C088AE24B |
:105FF00080939D0885EF80939E088CE880939F088E |
:106000007093A0081092A2081092A30881E28093D6 |
:10601000640881E480936508209366081092A508BF |
:106020001092A60886E98093A80850937E0884E31E |
:1060300080937F081092A9081092AA081092AB08CA |
:106040001092AE088FE18093AF0808950E94112F3F |
:106050008AE08093570880E18093580826E02093D7 |
:1060600059089AE590935E0888E780935F089093BB |
:106070006108809362082093630880E28093680837 |
:106080008CE3809380088BE48093850886E491E616 |
:10609000A3E7B4E78093B4089093B508A093B6083B |
:1060A000B093B70860E870E080E498E00E94C32EE7 |
:1060B0008093C0080895CF93DF930E94112F88E04A |
:1060C0008093570830E13093580826E02093590810 |
:1060D00094E690935E0888E780935F089093610848 |
:1060E00080936208209363083093680886E4809365 |
:1060F000800880938508A4EBB8E085E0E9E2F1E050 |
:10610000ED01019009928A95E1F760E870E0CD0118 |
:10611000845790400E94C32E8093C008DF91CF9196 |
:1061200008950E94112F26E0209357088AE080935B |
:10613000580884E08093590894E690935E0888E7B5 |
:1061400080935F08909361088093620820936308AE |
:1061500080E18093680886E48093800880938508B6 |
:1061600085E491E6A3E7B9E78093B4089093B50876 |
:10617000A093B608B093B70860E870E080E498E0B8 |
:106180000E94C32E8093C0080895F999FECF92BD56 |
:1061900081BDF89A80B599270895F999FECF1FBA65 |
:1061A00092BD81BD60BD0FB6F894FA9AF99A0FBE00 |
:1061B00008956FEA7EE20E94289E089547EB5EE212 |
:1061C0000E94629E0895EF92FF920F931F93CF93C8 |
:1061D000C82F8150853008F0C3E081E8C89F800156 |
:1061E000112483EEE82E8FEFF82EE00EF11E60E80A |
:1061F00070E0C7010E94D42E682F98012D593F4F9F |
:106200008FB39927AC014270507081FDF9CF32BD38 |
:1062100021BDF89A80B5861711F0CA0123C08FB34B |
:1062200099279C012270307081FDF9CFF2BCE1BC4E |
:10623000F89A80B5813611F0C90114C081E8C89F71 |
:10624000C00111244D972FEA3EE241E850E0BC0125 |
:1062500080E498E00E94039E0E949E760E949C9794 |
:1062600081E090E0CF911F910F91FF90EF90089502 |
:10627000282F863010F025E003C0882309F421E0A0 |
:1062800020930101F999FECF1FBA82E090E092BD00 |
:1062900081BD20BD0FB6F894FA9AF99A0FBE089501 |
:1062A000CF93C82F80914008813609F051C0C63085 |
:1062B00010F0C5E003C0CC2309F44AC00E94639CDF |
:1062C0008091B30882FF07C080916508843618F07A |
:1062D00080E58093650860E870E080E498E00E94C3 |
:1062E000C32E8093C00881E8C89FC001112427EB0A |
:1062F0003EE241E850E060E478E04D970E94409E25 |
:1063000027EB3EE24CE050E061E478E080E590E08D |
:106310000E94409E6CE070E081E498E00E94C32EF1 |
:10632000282FF999FECF1FBA8CE590E092BD81BD70 |
:1063300020BD0FB6F894FA9AF99A0FBE8C2F0E94DE |
:1063400038310E949E760E949C9781E090E002C0C6 |
:1063500080E090E0CF9108956DE470E088EE93E0E6 |
:106360000E94D42E482F8FB399279C012270307041 |
:1063700081FDF9CF85E394E092BD81BDF89A80B5A7 |
:10638000841779F48FB399279C012270307081FDB6 |
:10639000F9CF88EE93E092BD81BDF89A80B5813047 |
:1063A00011F0C90108952FEA3EE24EE450E068EE94 |
:1063B00073E081EC98E00E94039E81E090E00895F4 |
:1063C0008091C1088130A9F46DE470E081EC98E01F |
:1063D0000E94C32E80930E0927EB3EE24EE450E06C |
:1063E00061EC78E088EE93E00E94409E81E090E0CE |
:1063F000089580E090E00895CF93DF9381E080934B |
:10640000C108E1ECF8E08FE0158616861786108A41 |
:106410008150349687FFF8CF80E48093CE08809334 |
:10642000CF081092D0088093D1088093D20890ECC6 |
:106430009093D3081092D4088093D5088093D608FF |
:106440001092D7089093D8089093D9088093DA08CF |
:106450001092DB088093DC089093DD08A2ECB8E092 |
:106460008CE0EFE2F1E0ED01019009928A95E1F70D |
:106470006DE470E0CD0101970E94C32E80930E0958 |
:10648000DF91CF910895F999FECF82E090E092BD1F |
:1064900081BDF89A80B5282F863078F023E0322F1E |
:1064A000F999FECF1FBA82E090E092BD81BD30BD68 |
:1064B0000FB6F894FA9AF99A0FBE20930101822F31 |
:1064C000992708951F93CF93C82F162F863010F069 |
:1064D000C5E003C0882309F4C1E08C2F99278230DE |
:1064E000910541F08330910544F4019731F40E9405 |
:1064F000263005C00E945B3002C00E9491301123FB |
:10650000E1F06CE070E080E590E00E94D42E282F4E |
:10651000F999FECF8CE590E092BD81BDF89A80B5E7 |
:10652000821759F42FEA3EE24CE050E060E570E05B |
:1065300081E498E00E94039E02C00E94EC2E8C2F02 |
:106540000E945031CF911F910895DF92EF92FF92F8 |
:106550000F931F93CF93FF24DF2CEF2C81E190E06A |
:106560000E94C53090910301981791F1963169F41A |
:1065700081E190E00E94C530853139F44C9905C025 |
:106580006F2D81E090E00E94CD306091030181E1A8 |
:1065900090E00E94CD3088E190E028E00FB6F894BA |
:1065A000A895809360000FBE2093600082E798E07A |
:1065B0009F938F938EE996E19F938F93E0919C0533 |
:1065C000F0919D0509950F900F900F900F90FFCFC0 |
:1065D00081E090E00E94C530813611F031E0E32E79 |
:1065E0006CE070E080E590E00E94D42EC82FF9990D |
:1065F000FECF8CE590E092BD81BDF89A80B58C17F6 |
:1066000011F421E0D22EC1E001E010E0EE2029F4E7 |
:106610008C2F0E94E3308823B9F591E0F92E1F9367 |
:106620000F938AE998E09F938F938EE996E19F9369 |
:106630008F93E0919C05F0919D0509952DB73EB78C |
:106640002A5F3F4F2DBF0130110521F002301105A7 |
:1066500021F006C00E94263005C00E945B3002C0B7 |
:106660000E949130DD2059F02FEA3EE24CE050E0EC |
:1066700060E570E081E498E00E94039E02C00E9401 |
:10668000EC2E8C2F0E945031CF5F0F5F1F4FC63012 |
:1066900008F4BCCFFF2019F083E00E9438310E943B |
:1066A0004332C82F0E94E3308C2F99279F938F93FA |
:1066B00080EC98E09F938F930EE916E11F930F9360 |
:1066C000E0919C05F0919D05099581E090E00E9484 |
:1066D000C5302DB73EB72A5F3F4F2DBF8F3F21F00A |
:1066E0000E94AC31882399F489ED98E09F938F93B1 |
:1066F0001F930F93E0919C05F0919D0509950E94D1 |
:10670000FC310E94E0310F900F900F900F90EE201F |
:1067100029F061E681E090E00E94CD3010923F08C0 |
:1067200090E0EEECF8E0CFE08081349618160CF49F |
:106730009F5FC150C7FFF8CF90933F08892F9927DB |
:106740009F938F9382EC98E09F938F938AEF98E0CA |
:106750009F938F931F930F93E0919C05F0919D055C |
:1067600009950E94230A8DB79EB708968DBFCF91D9 |
:106770001F910F91FF90EF90DF900895982F2FB702 |
:10678000F8943998389A88B1836088B98091B900B3 |
:106790008C7F8093B9008AE28093B80010927003D6 |
:1067A00010926E0310926D03992379F0E7E1F9E0FE |
:1067B0008BE010821182128213821482158216825B |
:1067C00017828150389687FFF4CF78942FBF0895B1 |
:1067D0001092700384E98093BC0080E88093BC0031 |
:1067E0001092BD001092BA001092BB001092B90036 |
:1067F0001092B80010926C0380E00E94BE33109299 |
:10680000BB0085E88093BC0080916A03826080931E |
:106810006A0308951F920F920FB60F9211242F93BF |
:106820003F934F935F938F939F93EF93FF93809149 |
:106830007003282F3327442755278F5F80937003D9 |
:10684000F9012731310508F00DC3E659FF4F0C94CB |
:1068500060A081E080936C0309C080916E038C304E |
:1068600090F480916E038F5F80936E0380916E032E |
:10687000E82FFF27EE0FFF1FEE0FFF1FEF53F74F1D |
:106880008585181654F780916E038C3070F0109245 |
:1068900069031092680310926E0385E08093700381 |
:1068A00080916D03880F8D5A04C080916E03880F0C |
:1068B0008E5A8093BB0085E8CAC280916E03E82F90 |
:1068C000FF2723E0EE0FFF1F2A95E1F7E95EF64F61 |
:1068D00081818093BB0085E88093BC0080916E032A |
:1068E000E82FFF2793E0EE0FFF1F9A95E1F7E95E8F |
:1068F000F64F808180FF92C080916E03E82FFF27C2 |
:1069000083E0EE0FFF1F8A95E1F7E95EF64F828183 |
:10691000882329F080913F08873008F4B9C280911C |
:10692000680390916903892B09F0B2C280916603D4 |
:1069300090916703892B09F0ABC270C080916E0300 |
:1069400021E030E002C0220F331F8A95E2F78091E8 |
:1069500066039091670328233923232B79F08091D4 |
:106960006E03E82FFF27EE0FFF1FEE0FFF1FEE0F46 |
:10697000FF1FE95EF64F80E184830DC080916E03B6 |
:10698000E82FFF27EE0FFF1FEE0FFF1FEE0FFF1F79 |
:10699000E95EF64F148280916E03E82FFF27EE0F19 |
:1069A000FF1FEE0FFF1FEE0FFF1FE95EF64F848102 |
:1069B000282F3327220F331F220F331F220F331F9D |
:1069C00080916E03E82FFF2753E0EE0FFF1F5A95CB |
:1069D000E1F7E95EF64F82818770822B8093BB00DE |
:1069E00085E88093BC0020916E0381E090E002C0B6 |
:1069F000880F991F2A95E2F7209168033091690367 |
:106A000082239323892B51F08FE099E090937403B4 |
:106A10008093730388E0809375033AC284E0D4C105 |
:106A2000E0917303F091740381918093BB0085E83A |
:106A30008093BC00F0937403E0937303809175031B |
:106A4000815080937503882309F422C283E0BCC17E |
:106A50008091B900803349F580917103882329F42E |
:106A600080916E038F5F8093710380916E03E82F96 |
:106A7000FF2743E0EE0FFF1F4A95E1F7E95EF64F6F |
:106A8000838199278F7790708F37910574F4809167 |
:106A90006E03E82FFF2733E0EE0FFF1F3A95E1F773 |
:106AA000E95EF64F83818F5F83831092700384E9E0 |
:106AB0008093BC008AE090E090933D0180933C017C |
:106AC00080916E038F5F80936E0310927003B9C143 |
:106AD0008091B9008034C1F180916D03E82FFF27C8 |
:106AE00023E0EE0FFF1F2A95E1F7E95EF64F838161 |
:106AF0008F77838380916D038F5F80936D03809187 |
:106B00006D038C30A0F010926D0310926703109209 |
:106B10006603809172038F5F809372038C3038F02C |
:106B20001092720380916A038D7F80936A03809133 |
:106B30006A03816080936A031092700384E98093F2 |
:106B4000BC0010926C0383C080916D03E82FFF2777 |
:106B500093E0EE0FFF1F9A95E1F7E95EF64F838110 |
:106B60008068838380916D03E82FFF2783E0EE0F19 |
:106B7000FF1F8A95E1F7E95EF64F808180FF40C0F4 |
:106B800080916D03E82FFF27EE0FFF1FEE0FFF1F11 |
:106B9000EE0FFF1FE95EF64F848199270097D1F031 |
:106BA000409709F04BC08FE099E090937403809375 |
:106BB000730388E08093750380916D03E82FFF27AE |
:106BC000EE0FFF1FEE0FFF1FEE0FFF1FE95EF64FE8 |
:106BD000148234C080916D039927E3E0880F991FD8 |
:106BE000EA95E1F7845E964F909374038093730364 |
:106BF00090916D03809172039817E9F483E01CC0B3 |
:106C000080916D039927880F991F880F991F880F0E |
:106C1000991F845E964F90937403809373038091C1 |
:106C20006A0381FD06C090916D03809172039817ED |
:106C300011F482E001C081E08093750380917503B7 |
:106C4000813011F485E801C085EC8093BC0080910F |
:106C5000710380936B03109271031AC1E091730367 |
:106C6000F09174038091BB008083809173039091B5 |
:106C7000740301969093740380937303809175035A |
:106C8000815080937503823010F085EC9AC081307A |
:106C900011F485E896C080916A0381FF6AC08091F3 |
:106CA000100480FD66C080916D03E82FFF27EE0F72 |
:106CB000FF1FEE0FFF1FEE0FFF1FE95EF64F8681ED |
:106CC00099278C7F9070883F910579F480916D03AE |
:106CD000E82FFF2753E0EE0FFF1F5A95E1F7E95E1B |
:106CE000F64F8081816080830CC080916D03E82F16 |
:106CF000FF2743E0EE0FFF1F4A95E1F7E95EF64FED |
:106D0000108280916D03E82FFF2733E0EE0FFF1F05 |
:106D10003A95E1F7E95EF64F8681883F71F48091FC |
:106D20006D03E82FFF2723E0EE0FFF1F2A95E1F701 |
:106D3000E95EF64F808186601BC080916D03E82F6D |
:106D4000FF2793E0EE0FFF1F9A95E1F7E95EF64FFC |
:106D50008681893F71F480916D03E82FFF2783E0DE |
:106D6000EE0FFF1F8A95E1F7E95EF64F80818460A0 |
:106D7000808380916D038F5F80936D0380916D039D |
:106D80008C30A0F010926D0310926703109266038E |
:106D9000809172038F5F809372038C3038F0109271 |
:106DA000720380916A038D7F80936A03109270034F |
:106DB00084E98093BC0080916A03816080936A03B8 |
:106DC00065C08093BC0086E08093700361C088E951 |
:106DD00070CD80916F03880F805F6BCD80916F03C2 |
:106DE00099278130910561F0823091051CF4892B3F |
:106DF00021F04EC0029739F04BC080911B0159CD54 |
:106E000080911A0156CD8091190153CD80E851CD62 |
:106E10001092700384E98093BC0010926C038AE0A6 |
:106E200090E090933D0180933C0180916F0382300C |
:106E300088F480916F038F5F80936F0382E180936A |
:106E4000700380916A038E7F80936A0385EA809342 |
:106E5000BC001EC010926F0380916A038160809312 |
:106E60006A0316C01092700384E98093BC0080917D |
:106E70006A03816080936A038AE090E090933D0109 |
:106E800080933C0110926E0310926D0310926C037C |
:106E9000FF91EF919F918F915F914F913F912F9132 |
:106EA0000F900FBE0F901F9018951F93CF93DF93F5 |
:106EB000182F80914804882321F48091FB028823B5 |
:106EC00019F081E090E09AC01D3008F095C01123C0 |
:106ED000B1F0E12FFF2743E0EE0FFF1F4A95E1F7E6 |
:106EE000E95EF64F35978081359688230CF084C093 |
:106EF0003897808180FD03C083E090E07FC080915F |
:106F00000F0999278B709070029719F084E090E038 |
:106F100075C067E070E08FE099E00E94C32E909109 |
:106F20001609891719F085E090E068C080ED97E0B8 |
:106F30000E94701AEC0180916A0380FD05C0CE01A9 |
:106F40000E94791A8823B9F3112319F48FEF90E086 |
:106F50000BC0212F33272150304081E090E002C048 |
:106F6000880F991F2A95E2F790936903809368032D |
:106F7000A1E0B0E0E7E1F9E040E050E06BE0CD01F6 |
:106F8000042E02C0880F991F0A94E2F7209168032B |
:106F90003091690382239323892B11F0118212828D |
:106FA00061504F5F5F4F389667FFE9CF10926E03D5 |
:106FB0001092700380916A038E7F80936A0385EA42 |
:106FC0008093BC0080916A0380FD05C0CE010E94C1 |
:106FD000791A8823B9F38091680390916903892B0A |
:106FE00029F0CE010E94791A882311F38091680359 |
:106FF00090916903009711F082E090E0DF91CF91CA |
:107000001F9108950F931F93CF93DF93982F809133 |
:107010004804882321F48091FB02882319F081E041 |
:1070200090E095C09D30A0F4992319F486E090E09B |
:107030008EC0C92FDD27FE0153E0EE0FFF1F5A95CA |
:10704000E1F7E95EF64F35978081359687FD03C0FD |
:1070500082E090E07CC03897808180FD03C083E0AF |
:1070600090E075C080ED97E00E94701A8C018091CD |
:107070006A0380FD05C0C8010E94791A8823B9F30C |
:10708000219721E030E0C90102C0880F991FCA95FD |
:10709000E2F79093670380936603D901E7E1F9E093 |
:1070A00040E050E06BE0CD01042E02C0880F991F34 |
:1070B0000A94E2F7209166033091670382239323B9 |
:1070C000892B11F01182128261504F5F5F4F389609 |
:1070D00067FFE9CF10926D0310920F091092160905 |
:1070E0001092700380916A038E7F80936A0385EA11 |
:1070F0008093BC0080916A0380FD05C0C8010E9496 |
:10710000791A8823B9F38091660390916703892BDC |
:1071100029F0C8010E94791A882311F380910F0980 |
:1071200099278B709070029719F084E090E00FC05F |
:1071300067E070E08FE099E00E94C32E90911609FD |
:10714000891719F085E090E002C080E090E0DF91BF |
:10715000CF911F910F910895CF93DF9380E021E8A5 |
:107160003FEFCEEBD9E0E8E7F9E0DF01853020F42E |
:1071700011961C921E9202C03183208319821882BC |
:1071800022968F5F12963296833280F38FE790E0DB |
:107190009093B7098093B60981E89FEF9093B50962 |
:1071A0008093B4091092B9091092B8091092B604EC |
:1071B0001092B5041092B8041092B7041092BA0459 |
:1071C0001092B904DF91CF9108951F920F920FB6DC |
:1071D0000F9211240F931F932F933F934F935F931D |
:1071E0006F937F938F939F93AF93BF93CF93DF93CF |
:1071F000EF93FF938091B20882FDC2C04091860058 |
:10720000509187008091770390917803481B590B28 |
:107210008091860090918700909378038093770304 |
:10722000CA018D549440A0917903B0917A03835F91 |
:107230009A4158F48091790380937709149714F058 |
:107240001092400181E090E096C0A131B1050CF0B0 |
:10725000F7C1CA018B5F9040845B914008F086C003 |
:1072600080913E0190913F01481B590BE091A90884 |
:10727000EE2351F0FF27EE0FFF1FE858F64F8081F5 |
:10728000918184369105ECF4FD01EA0FFB1FE8586B |
:10729000F64F80819181FA01E81BF90BCF01F7FFCE |
:1072A00003C0909581959F4F06975CF480914904A7 |
:1072B000883C20F480914904865F01C088EC80936B |
:1072C0004904FD01EA0FFB1FE858F64F80819181C8 |
:1072D0009C01220F331F280F391F240F351F37FF42 |
:1072E00002C02D5F3F4FE901D595C795D595C7954C |
:1072F000CA0101968C179D0714F4219706C04150CE |
:107300005040C417D5070CF4219680914904833C62 |
:10731000E0F08D010A0F1B1FF801E858F64F80813D |
:1073200091819E01281B390BC90163E070E00E9426 |
:10733000D99FCB01880F991F860F971F0254164FB4 |
:10734000D80111969C938E9307C0AA0FBB1FA2541D |
:10735000B64F11961C921E92E0917903F0917A0338 |
:10736000EE0FFF1FE858F64FD183C0838091790359 |
:1073700090917A03019690937A038093790360C188 |
:10738000409186005091870080917B0390917C030F |
:10739000481B590B809186009091870090937C0345 |
:1073A00080937B03CA018D54944060910504835FF0 |
:1073B0009A4108F07AC06093760380917603843016 |
:1073C00008F453C09091770980917603981709F0DB |
:1073D0004CC0509106045B3008F43FC0109240014D |
:1073E0001092050440E05F31C0F0E42FFF27EE0F5C |
:1073F000FF1F9F012F533C4FDF01A858B64F8D91BF |
:107400009C91D9018D939C93DF01A254B64F8D912D |
:107410009C91ED51FC4F91838083E42FFF27EE0F69 |
:10742000FF1F9F012858364FDF01A358BC4F8D9195 |
:107430009C91D90111969C938E93DF01A156BC4F6C |
:107440008D919C91E254F64F91838083842F8F5FBE |
:10745000482F813140F280930504809106048F3FCC |
:10746000B9F08F5F8093060413C0809106048536BF |
:1074700020F08AE08093060402C0109206048091F6 |
:1074800003018A3011F0843110F0289A01C0289845 |
:1074900081E08093050480914804882309F0D0C0DE |
:1074A0008091760380937709CBC0613108F0A0C04A |
:1074B000CA018B5F9040845B914008F090C080913E |
:1074C0003E0190913F01481B590BE62FFF27EE0F1D |
:1074D000FF1FE358FC4F80819181FA01E81BF90BF3 |
:1074E000CF0105960B9720F5E091A908EE2351F006 |
:1074F000FF27EE0FFF1FE858F64F808191818436F9 |
:107500009105B4F4809106048A3120F080914904F9 |
:10751000865F05C08B3028F0809149048E5F809390 |
:10752000490480914904893C18F088EC809349040F |
:10753000E62FFF27EE0FFF1FE358FC4F808191815C |
:107540009C01220F331F280F391F240F351F37FFCF |
:1075500002C02D5F3F4FE901D595C795D595C795D9 |
:10756000CA0101968C179D0714F4219706C041505B |
:107570005040C417D5070CF42196809149048E3BE6 |
:10758000D8F0E62FFF27EE0FFF1FDF01A358BC4FF7 |
:107590008D919C919E01281B390BC90163E070E01D |
:1075A0000E94D99FCB01880F991F860F971FE15624 |
:1075B000FC4F9183808308C0E62FFF27EE0FFF1F4B |
:1075C000E156FC4F1182108280910504E82FFF27BD |
:1075D000EE0FFF1FE358FC4FD183C08309C0809199 |
:1075E00003018A3011F0843110F0289A01C02898E4 |
:1075F00080910504843120F48F5F8093050420C0BE |
:107600008431F1F4809103018A3011F0843110F05B |
:10761000289A01C028988EE18093050420E1CEEBE2 |
:10762000D9E0A1ECB3E0E8E7F9E08D919D91918379 |
:1076300080833296198218822296215027FFF5CF37 |
:10764000FF91EF91DF91CF91BF91AF919F918F917A |
:107650007F916F915F914F913F912F911F910F916A |
:107660000F900FBE0F901F9018958091840A9091F3 |
:10767000850A90939C0780939B078091860A90913E |
:10768000870A90939E0780939D0780915A0A909154 |
:107690005B0A97FD039695958795959587959093A9 |
:1076A000A00780939F0780916A0A90916B0A97FDCB |
:1076B000039695958795959587959093A2078093C6 |
:1076C000A1078091B5049091B604209140033091B8 |
:1076D0004103821B930B9093A4078093A30780918F |
:1076E000430490914404A0914504B0914604BC0128 |
:1076F000CD012AE030E040E050E00E940EA030933F |
:10770000A6072093A5078091E0079091E107909349 |
:10771000A8078093A7078091900190919101909381 |
:10772000AC078093AB07809126019091270190933D |
:10773000AE078093AD078091490499279093B007D5 |
:107740008093AF078091120A9091130A9093B20729 |
:107750008093B1078091180999279093B40780937B |
:10776000B3078091200999279093B6078093B507B6 |
:107770008091280999279093B8078093B707809143 |
:10778000300999279093BA078093B907809116031F |
:10779000909117039093C4078093C30780912D04A1 |
:1077A00090912E049093C6078093C5078091EB0AB1 |
:1077B0009091EC0A9093C8078093C7078091EF0AD5 |
:1077C0009091F00A9093CA078093C90780913F0473 |
:1077D00090914004A0914104B0914204BC01CD01BC |
:1077E0002AE030E040E050E00E940EA03093CC0749 |
:1077F0002093CB0780916104909162049093D2070B |
:107800008093D1078091F10A99279093D6078093AE |
:10781000D50780911B0590911C059093D807809304 |
:10782000D7078091190590911A059093DA078093F4 |
:10783000D9078091B505882321F48091B605882366 |
:1078400021F080919A07816003C080919A078E7F12 |
:1078500080939A070895EF92FF921F93CF93DF933F |
:10786000182F7B0180914804882391F580910301B2 |
:107870008C3010F0893111F4299801C0299A1150E7 |
:107880001F3FE9F0F0921E03E0921D03E701809193 |
:107890001D0390911E03892B11F4209781F3809191 |
:1078A00021038823A1F31092210380911D0390915D |
:1078B0001E03892B09F421970E94799CE8CF8091BF |
:1078C00003018C3010F0893111F4299A01C02998F4 |
:1078D000DF91CF911F91FF90EF900895CF93DF93A9 |
:1078E000809103018D3011F40E94C91F10927A001B |
:1078F000809144039091450390931D0A80931C0A44 |
:10790000809142039091430390930E0A80930D0A55 |
:1079100080914003909141039093600A80935F0AA5 |
:1079200020913C0330913D03C901880F991F880FB6 |
:10793000991F820F931F820F931F90935B0A80936E |
:107940005A0A20913E0330913F03C901880F991FC5 |
:10795000880F991F820F931F820F931F90936B0ABA |
:1079600080936A0A8FEC80937A00AAE4B4E0C5E4BD |
:10797000D8E097E08991E82FFF27EE0FFF1FE85826 |
:10798000F64F0190F081E02DE158FF4F1E161F06C3 |
:107990001CF0E0E0F0E005C0EF3FF10514F0EFEF80 |
:1079A000F0E08C91282F3327E217F30714F481506D |
:1079B00004C02E173F0714F48F5F8C9391501196DB |
:1079C00097FFD8CF809181089927AA27BB27BC01B0 |
:1079D000CD0124EC39E040E050E00E949A9FDC01A8 |
:1079E000CB018093880190938901A0938A01B09381 |
:1079F0008B01809182089927AA27BB27BC01CD0162 |
:107A00000E949A9FDC01CB018093840190938501B1 |
:107A1000A0938601B0938701DF91CF910895A0E0F4 |
:107A2000B0E0E5E1FDE30C942DA0782E91E0692E05 |
:107A3000CC24DD2456014601E6011092B505D09212 |
:107A4000B004C092AF04D092AE04C092AD04D09204 |
:107A5000AA04C092A9041092A804D092BA04C092B9 |
:107A6000B904D092B804C092B704D092B604C092C0 |
:107A7000B50410926A0110926901109235030E94B8 |
:107A80006E3C84E690E00E94921A0E946E3C8091C7 |
:107A90004D0880FF14C080911C0190911D01875BEF |
:107AA000934058F480911C0190911D018E5E92408C |
:107AB00020F080913503882311F00E94291F009146 |
:107AC0001C0110911D0187B58B5F87BD87B580951F |
:107AD00088BD8FE1E82E8AE090E00E94921A8091A2 |
:107AE000400390914103C80ED91E809144039091A8 |
:107AF0004503A80EB91E8091420390914303880E5E |
:107B0000991E8091E0079091E107C80FD91FEA9470 |
:107B1000E7FEE1CF80911C0190911D01825F9340AF |
:107B200080F480911C0190911D01459750F0809147 |
:107B30001C0190911D01081B190B10931701009354 |
:107B4000160187B5855087BD87B5809588BD95019D |
:107B5000205F3F4F36952795369527953093BA0489 |
:107B60002093B904C401409696958795969587957C |
:107B70009093B8048093B70440E150E0C40ED51E42 |
:107B8000B5E0D694C794BA95E1F7D092B604C09206 |
:107B9000B504C40FD51FA5E0D695C795AA95E1F702 |
:107BA000D093AA04C093A9049093B4048093B3041F |
:107BB0003093B2042093B10452E07516C9F5809158 |
:107BC0005A0A90915B0A97FF03C0909581959F4F49 |
:107BD0006CE070E00E94D99F9B017093B0046093A9 |
:107BE000AF0480916A0A90916B0A97FF03C0909549 |
:107BF00081959F4F6CE070E00E94D99F7093AE0416 |
:107C00006093AD04B90184E090E00E94DE306091A1 |
:107C1000AD047091AE0486E090E00E94DE30609189 |
:107C2000A9047091AA0488E090E00E94DE304FC061 |
:107C300084E090E00E94D9309093B0048093AF0428 |
:107C400086E090E00E94D9309C019093AE0480932E |
:107C5000AD048091AF049091B0048150984018F425 |
:107C600021503840A0F18BE199E09F938F938EE9EA |
:107C700096E19F938F93E0919C05F0919D05099566 |
:107C800080915A0A90915B0A97FF03C09095819565 |
:107C90009F4F6CE070E00E94D99F7093B004609396 |
:107CA000AF0480916A0A90916B0A97FF03C0909588 |
:107CB00081959F4F6CE070E00E94D99F7093AE0455 |
:107CC0006093AD0466240F900F900F900F9012BC3C |
:107CD00011BC10921D0A10921C0A10920E0A1092EA |
:107CE0000D0A1092600A10925F0A88EC90E00E94E0 |
:107CF000921A80913C0390913D039C01220F331F07 |
:107D0000220F331F280F391F280F391F30935B0AAA |
:107D100020935A0A80913E0390913F038C01000FFB |
:107D2000111F000F111F080F191F080F191F1093A3 |
:107D30006B0A00936A0A80915C08C82EDD24EE2449 |
:107D4000FF24442737FD4095542FC701B6010E94F8 |
:107D50009A9F4B015C016093A3047093A4048093E9 |
:107D6000A5049093A6049801442737FD4095542F0D |
:107D7000C701B6010E949A9FDC01CB0180939B044E |
:107D800090939C04A0939D04B0939E0480928304DE |
:107D900090928404A0928504B092860480937B0420 |
:107DA00090937C04A0937D04B0937E04109273049E |
:107DB0001092740410927504109276040091900150 |
:107DC00010919101109362040093610484E690E0A5 |
:107DD00090938D0180938C0182E390E090931E0339 |
:107DE00080931D03809181089927AA27BB27BC0196 |
:107DF000CD0124EC39E040E050E00E949A9FDC0184 |
:107E0000CB018856954CAF4FBF4F8093880190931C |
:107E10008901A0938A01B0938B01809182089927F0 |
:107E2000AA27BB27BC01CD010E949A9FDC01CB0190 |
:107E30008856954CAF4FBF4F809384019093850136 |
:107E4000A0938601B09387011092470110924601DA |
:107E5000C801AA2797FDA095BA2F20914201309121 |
:107E600043014091440150914501BC01CD010E9464 |
:107E70009A9FDC01CB018093660A9093670AA093D6 |
:107E8000680AB093690A10925E0410925D040E9421 |
:107E90009E76772029F080911004846080931004EE |
:107EA0008FEF8093E60A1092E70A80E28093E80A57 |
:107EB000CAE4D4E0A5E4B8E077E0E72E8D91E82F9E |
:107EC000FF27EE0FFF1FE858F64F80819181815800 |
:107ED0008993EA94E7FEF2CF84E680934904809187 |
:107EE0001B03882311F0579A17C08091B108992776 |
:107EF00080FF05C082FF03C080EE9EE202C080E0EA |
:107F000091E190930A018093090181E0809311012E |
:107F10000E94331B0E94331B8091A3049091A40400 |
:107F2000A091A504B091A604E0904201F090430115 |
:107F30000091440110914501BC01CD01A8019701B8 |
:107F40000E940EA059016A0180919B0490919C04AB |
:107F5000A0919D04B0919E04BC01CD01A8019701A0 |
:107F60000E940EA0B901C5010E94BA9D8C010E9419 |
:107F7000107A9C019093270A8093260A8091A90485 |
:107F80009091AA04AA2797FDA095BA2F6DE0880FBB |
:107F9000991FAA1FBB1F6A95D1F78050904FAF431E |
:107FA000B040442737FD4095542FBC01CD010E94BD |
:107FB0000EA0C90180509E4F9093AA048093A904FB |
:107FC000053111050CF06624772079F080910804C2 |
:107FD000882359F0C90181599040C39730F08091AE |
:107FE000B50580628093B50566248091B9049091AF |
:107FF000BA0480569940815C9B4228F08091B50577 |
:1080000081608093B5058091B7049091B804805643 |
:108010009940815C9B4228F08091B50582608093F5 |
:10802000B5058091B5049091B6048C529140895762 |
:10803000954028F08091B50584608093B5058091C6 |
:10804000AF049091B0048C529140835C914028F031 |
:108050008091B50588608093B5058091AD049091BD |
:10806000AE048C529140835C914028F08091B5051C |
:1080700080618093B5058091A9049091AA048050F5 |
:1080800092408355914028F08091B505806280939D |
:10809000B5058091B5058111662486E480937F0142 |
:1080A0000E949C9782E00E94019980911E0190910C |
:1080B0001F01A0912001B09121018093E2079093CC |
:1080C000E307A093E407B093E507109234031092FE |
:1080D0003303109236031092370310923803109234 |
:1080E0003903109263041092640410926504109294 |
:1080F00066041092D4071092D3070E94F11E862DB9 |
:108100009927EEE0CDB7DEB70C9449A0A3E1B0E02B |
:10811000ECE8F0E40C9429A08091B5049091B604A9 |
:108120002091400330914103821B930B9093600A8E |
:1081300080935F0A80914A0390914B0397FD0796C5 |
:108140009C0153E0359527955A95E1F730931D0A28 |
:1081500020931C0A809148039091490397FD07964C |
:1081600043E0959587954A95E1F790930E0A8093A1 |
:108170000D0A3093290A2093280A9093200A8093AD |
:108180001F0A80915A0A90915B0AAC01440F551F57 |
:10819000480F591F20913C0330913D03C901880FBE |
:1081A000991F880F991F820F931F820F931F480FEB |
:1081B000591F57FF02C04D5F5F4F55954795559525 |
:1081C000479550935B0A40935A0A80916A0A9091AE |
:1081D0006B0AAC01440F551F480F591F20913E03F5 |
:1081E00030913F03C901880F991F880F991F820F93 |
:1081F000931F820F931F480F591F57FF02C04D5FF7 |
:108200005F4F559547955595479550936B0A409309 |
:108210006A0A20913C0330913D03C901880F991FE0 |
:10822000880F991F820F931F820F931F9C01442771 |
:1082300037FD4095542F8091930490919404A09120 |
:108240009504B0919604820F931FA41FB51F8093CD |
:10825000930490939404A0939504B0939604209172 |
:108260003E0330913F03C901880F991F880F991F62 |
:10827000820F931F820F931F9C01442737FD409567 |
:10828000542F80918F0490919004A0919104B0910B |
:108290009204820F931FA41FB51F80938F049093A5 |
:1082A0009004A0939104B09392048091320A90912B |
:1082B000330A20913C0330913D03820F931F90932A |
:1082C000330A8093320A8091620A9091630A209166 |
:1082D0003E0330913F03820F931F9093630A809374 |
:1082E000620A8091AB049091AC0401969093AC0427 |
:1082F0008093AB048091E0079091E1072091A9045D |
:108300003091AA04821B930B9C01442737FD4095B2 |
:10831000542F80918B0490918C04A0918D04B09186 |
:108320008E04820F931FA41FB51F80938B0490931C |
:108330008C04A0938D04B0938E048FEC80937A000C |
:108340001092180120917B0430917C0440917D04AF |
:1083500050917E0429873A874B875C8729543B4696 |
:10836000414050402CF028E43BE641E050E00DC095 |
:1083700089859A85AB85BC85885B9449AE4FBF4F94 |
:108380004CF428EB34E94EEF5FEF2D833E834F83AF |
:10839000588708C089859A85AB85BC858D839E8367 |
:1083A000AF83B88720918304309184044091850481 |
:1083B000509186042D873E874F87588B29543B4622 |
:1083C000414050402CF028E43BE641E050E00DC035 |
:1083D0008D859E85AF85B889885B9449AE4FBF4F28 |
:1083E0004CF428EB34E94EEF5FEF29833A834B835B |
:1083F0005C8308C08D859E85AF85B88989839A8303 |
:10840000AB83BC83A0915F0AB091600ABB8BAA8B3F |
:10841000FD01CF01AA2797FDA095BA2FA090730464 |
:10842000B0907404C0907504D0907604A80EB91E64 |
:10843000CA1EDB1EA0927304B0927404C09275042D |
:10844000D0927604E090660AF090670A0091680A7C |
:108450001091690AE80EF91E0A1F1B1FE092660AB6 |
:10846000F092670A0093680A1093690AF0912C044D |
:10847000F98BFF2309F098C180912B04882309F020 |
:1084800093C18091560A86FF8FC180910D0A909109 |
:108490000E0AAA2797FDA095BA2FBC01CD0129810C |
:1084A0003A814B815C810E949A9F9B01AC0197FFAE |
:1084B00004C02150384F4F4F5F4F6BE055954795A3 |
:1084C000379527956A95D1F780916901682E7724B1 |
:1084D00088249924CA01B901A40193010E949A9F9A |
:1084E000DC01CB018093C5049093C604A093C7041C |
:1084F000B093C804B7FF04C08150904FAF4FBF4F37 |
:108500001C012D013CE055944794379427943A95EB |
:10851000D1F72092C5043092C6044092C70450920D |
:10852000C80480911C0A90911D0AAA2797FDA09566 |
:10853000BA2FBC01CD012D813E814F8158850E940B |
:108540009A9F97FF04C06150784F8F4F9F4F2BE049 |
:1085500095958795779567952A95D1F7A40193010D |
:108560000E949A9FDC01CB018093C9049093CA04B6 |
:10857000A093CB04B093CC04B7FF04C08150904FBC |
:10858000AF4FBF4F9C01AD018CE055954795379596 |
:1085900027958A95D1F72093C9043093CA04409354 |
:1085A000CB045093CC048091C5049091C604909361 |
:1085B000050A8093040A8091C9049091CA0490939B |
:1085C000090A8093080A221933094409550920939E |
:1085D000C9043093CA044093CB045093CC04E20EF8 |
:1085E000F31E041F151FE092660AF092670A0093BB |
:1085F000680A1093690A809168018823B1F457FFD3 |
:1086000004C02F5F3F4F4F4F5F4F559547953795AC |
:108610002795A21AB30AC40AD50AA0927304B0928D |
:108620007404C0927504D09276042A893B8979013A |
:108630000027F7FC0095102F8091C9049091CA047F |
:10864000A091CB04B091CC04E80EF91E0A1F1B1FA9 |
:10865000C801B70129813A814B815C810E949A9FB0 |
:108660009B01AC0197FF04C02150384F4F4F5F4F23 |
:10867000BBE05595479537952795BA95D1F78091E9 |
:108680006A01A82EBB24CC24DD24CA01B901A601AD |
:1086900095010E949A9FDC01CB018093BD049093C9 |
:1086A000BE04A093BF04B093C004B7FF04C08150C0 |
:1086B000904FAF4FBF4F3C014D01ACE09594879474 |
:1086C00077946794AA95D1F76092BD047092BE0426 |
:1086D0008092BF049092C004C801B7012D813E81F1 |
:1086E0004F8158850E949A9F97FF04C06150784F30 |
:1086F0008F4F9F4FFBE09595879577956795FA95F6 |
:10870000D1F7A60195010E949A9FDC01CB018093CD |
:10871000C1049093C204A093C304B093C404B7FFF0 |
:1087200004C08150904FAF4FBF4FAC01BD01ECE092 |
:108730007595679557954795EA95D1F74093C1048C |
:108740005093C2046093C3047093C4042A893B8984 |
:1087500037FF03C0309521953F4F21343105E4F1B7 |
:10876000D401C30197FE07C0B095A095909581955F |
:108770009F4FAF4FBF4F81389105A105B10584F4DC |
:10878000DB01CA0177FF07C0B095A0959095819550 |
:108790009F4FAF4FBF4F81389105A105B105E4F060 |
:1087A00081E080935F0418C01092090A1092080AB1 |
:1087B0001092050A1092040A1092C1041092C20489 |
:1087C0001092C3041092C4041092BD041092BE040F |
:1087D0001092BF041092C0048091C1049091C20411 |
:1087E000A091C304B091C404BC01CD0124E630E0E3 |
:1087F00040E050E00E940EA0E090BD04F090BE0466 |
:10880000E21AF30AF0921B0AE0921A0A8091BD0460 |
:108810009091BE04A091BF04B091C004BC01CD01F1 |
:1088200024E630E040E050E00E940EA0DA01C901E9 |
:108830002091C1043091C2048C01021B130B1093D0 |
:10884000100A00930F0A8091420190914301A09178 |
:108850004401B0914501BC01CD0128E631E040E082 |
:1088600050E00E949A9F2091660A3091670A4091D9 |
:10887000680A5091690A261737074807590764F0B4 |
:10888000261B370B480B590B2093660A3093670A57 |
:108890004093680A5093690A2091660A3091670AEA |
:1088A0004091680A5091690A57FF0CC0260F371F84 |
:1088B000481F591F2093660A3093670A4093680A3D |
:1088C0005093690A60910D0A70910E0A6E0D7F1D1A |
:1088D0009B01442737FD4095542F80917704909158 |
:1088E0007804A0917904B0917A04820F931FA41F99 |
:1088F000B51F8093770490937804A0937904B09384 |
:108900007A048091310490913204681B790BCB0179 |
:10891000AA2797FDA095BA2F29853A854B855C85B6 |
:10892000820F931FA41FB51F80937B0490937C0438 |
:10893000A0937D04B0937E04C0908401D090850103 |
:10894000E0908601F0908701C816D906EA06FB067A |
:10895000C4F488EA91E6A0E0B0E08C199D09AE0964 |
:10896000BF0980937B0490937C04A0937D04B09313 |
:108970007E048093770490937804A0937904B09355 |
:108980007A0422273327A9012C193D094E095F09D2 |
:1089900080917B0490917C04A0917D04B0917E0431 |
:1089A00082179307A407B507B4F4D701C601885A04 |
:1089B0009146A040B04080937B0490937C04A093A8 |
:1089C0007D04B0937E048093770490937804A09301 |
:1089D0007904B0937A0460911C0A70911D0A600FAB |
:1089E000711F9B01442737FD4095542F80917F04D0 |
:1089F00090918004A0918104B0918204820F931F12 |
:108A0000A41FB51F80937F0490938004A0938104DA |
:108A1000B093820480912F0490913004681B790BED |
:108A2000CB01AA2797FDA095BA2F2D853E854F85AE |
:108A30005889820F931FA41FB51F809383049093BE |
:108A40008404A0938504B0938604E0908801F0909C |
:108A5000890100918A0110918B01E816F9060A0735 |
:108A60001B07C4F488EA91E6A0E0B0E08E199F09E4 |
:108A7000A00BB10B8093830490938404A09385048E |
:108A8000B093860480937F0490938004A093810424 |
:108A9000B093820422273327A9012E193F09400BE6 |
:108AA000510B8091830490918404A0918504B0912E |
:108AB000860482179307A407B507B4F4D801C70149 |
:108AC000885A9146A040B0408093830490938404D8 |
:108AD000A0938504B093860480937F0490938004D0 |
:108AE000A0938104B09382048091730490917404E4 |
:108AF000A0917504B09176048093870490938804C4 |
:108B0000A0938904B0938A04809183049091840493 |
:108B1000A0918504B09186048093A3049093A4044B |
:108B2000A093A504B093A60480917B0490917C044B |
:108B3000A0917D04B0917E0480939B0490939C044B |
:108B4000A0939D04B0939E0480917F049091800433 |
:108B5000A0918104B091820480939F049093A0041B |
:108B6000A093A104B093A20480917704909178041B |
:108B7000A0917904B0917A0480939704909398041B |
:108B8000A0939904B0939A048091240190912501B7 |
:108B900097FD079633E0959587953A95E1F7909381 |
:108BA0001D0A80931C0A809122019091230197FD58 |
:108BB000079623E0959587952A95E1F790930E0AFD |
:108BC00080930D0A80914403909145030F9734F4EC |
:108BD00088E19CEF90931D0A80931C0A80914403C6 |
:108BE00090914503079734F480E398EF90931D0A22 |
:108BF00080931C0A209103012A30A9F48091440338 |
:108C000090914503835F934034F088EE93E0909316 |
:108C10001D0A80931C0A80914403909145038A5F4A |
:108C20009340DCF014C08091440390914503815D32 |
:108C3000974034F088EE93E090931D0A80931C0ACD |
:108C40008091440390914503805E974034F080ED1D |
:108C500097E090931D0A80931C0A809142039091A3 |
:108C600043030F9734F488E19CEF90930E0A8093AE |
:108C70000D0A8091420390914303079734F480E3F7 |
:108C800098EF90930E0A80930D0A2A30A9F48091F0 |
:108C9000420390914303835F934034F088EE93E066 |
:108CA00090930E0A80930D0A8091420390914303A2 |
:108CB0008A5F9340DCF014C080914203909143039B |
:108CC000815D974034F088EE93E090930E0A809394 |
:108CD0000D0A8091420390914303805E974034F0E7 |
:108CE00080ED97E090930E0A80930D0A60917701D2 |
:108CF000662309F4AFC04091240150912501809171 |
:108D0000CD049091CE04481B590B5093D40440934A |
:108D1000D3042091240130912501280F391F37FFFA |
:108D200002C02F5F3F4F359527953093CE04209397 |
:108D3000CD04413851051CF080E890E005C0405852 |
:108D40005F4F34F480E89FEF9093D4048093D30472 |
:108D500040912201509123018091CF049091D00441 |
:108D6000481B590B5093D2044093D1042091220107 |
:108D700030912301280F391F37FF02C02F5F3F4F6B |
:108D8000359527953093D0042093CF044138510571 |
:108D90001CF080E890E005C040585F4F34F480E854 |
:108DA0009FEF9093D2048093D104462F5527809152 |
:108DB000D3049091D404849FB001859F700D949F3B |
:108DC000700D11249B0177FF02C0215F3F4FB4E07B |
:108DD00035952795BA95E1F780911C0A90911D0A67 |
:108DE000820F931F90931D0A80931C0A8091D104D7 |
:108DF0009091D204849FD001859FB00D949FB00DB7 |
:108E00001124AD019D01B7FF02C0215F3F4FA4E0D7 |
:108E100035952795AA95E1F780910D0A90910E0A54 |
:108E2000820F931F90930E0A80930D0A8091240164 |
:108E300090912501860F971F90932501809324011F |
:108E40008091220190912301840F951F909323011B |
:108E50008093220100911F0A1091200A8091040A38 |
:108E60009091050A101611065CF59C0197FF04C04D |
:108E700022273327281B390BC901AA2797FDA09564 |
:108E8000BA2F20916801332744275527BC01CD0113 |
:108E90000E949A9F9B01AC0197FF04C0215C3F4F49 |
:108EA0004F4F5F4FF6E05595479537952795FA95C3 |
:108EB000D1F780911A0A90911B0A820F931F27C045 |
:108EC00097FF03C0909581959F4FAA2797FDA09586 |
:108ED000BA2F20916801332744275527BC01CD01C3 |
:108EE0000E949A9F9B01AC0197FF04C0215C3F4FF9 |
:108EF0004F4F5F4FE6E05595479537952795EA9593 |
:108F0000D1F780911A0A90911B0A821B930B9093C0 |
:108F10001B0A80931A0AE090280AF090290A80918F |
:108F2000080A9091090A1E141F045CF59C0197FF22 |
:108F300004C022273327281B390BC901AA2797FD14 |
:108F4000A095BA2F20916801332744275527BC01EB |
:108F5000CD010E949A9F9B01AC0197FF04C0215C48 |
:108F60003F4F4F4F5F4F76E0559547953795279583 |
:108F70007A95D1F780910F0A9091100A820F931F72 |
:108F800027C097FF03C0909581959F4FAA2797FD13 |
:108F9000A095BA2F20916801332744275527BC019B |
:108FA000CD010E949A9F9B01AC0197FF04C0215CF8 |
:108FB0003F4F4F4F5F4F66E0559547953795279543 |
:108FC0006A95D1F780910F0A9091100A821B930B3A |
:108FD0009093100A80930F0A8091560A87FF44C02D |
:108FE000B989BB2309F040C080912B048823E1F5A7 |
:108FF000E1E0EE16E1E0FE064CF080911C0A909153 |
:109000001D0A8E0D9F1D805091400DC0F0E0EF169F |
:10901000FFEFFF0664F480911C0A90911D0A8E0DEB |
:109020009F1D80509F4F90931D0A80931C0A21E042 |
:10903000013012074CF080910D0A90910E0A800FBA |
:10904000911F805091400CC03FEF0030130764F433 |
:1090500080910D0A90910E0A800F911F80509F4FB2 |
:1090600090930E0A80930D0AE2E1CD5E0C9445A028 |
:1090700080914804882329F5809110048C7F809387 |
:10908000100480910F048F7D80930F04AAEBB5E04C |
:10909000E7E1F9E09BE08091FB02882309F48C93DF |
:1090A0008D91818312829150389697FFF4CF8091F1 |
:1090B000FB02882359F08091FB0281508093FB02D0 |
:1090C00005C08091100481608093100480916C032E |
:1090D000882319F010926C03089580936E03809397 |
:1090E000700380916A038E7F80936A0385EA809380 |
:1090F000BC000895882319F480E090E00895E82FDB |
:10910000FF27EE0FFF1FE858F64F808191818158AD |
:109110009F4F8F3F910521F01CF08FEF90E004C02E |
:1091200097FF02C080E090E099270895CF93DF93E6 |
:10913000AAE4B4E0C5E4D8E057E08991E82FFF271E |
:10914000EE0FFF1FE858F64F0190F081E02DE15837 |
:10915000FF4FEF3FF10521F01CF0EFEFF0E004C00E |
:10916000F7FF02C0E0E0F0E0893111F4EC931BC09E |
:109170004C91242F3327E217F307A9F0CF01821B6C |
:10918000930B97FD03969595879595958795242F35 |
:10919000280F2C93822F9927E817F90714F42150F0 |
:1091A00001C02F5F2C935150119657FFC6CF80916D |
:1091B0004F08883F38F0EFEFF0E0E81BF109E65B7D |
:1091C000FB4F808180937C0180917C01882329F072 |
:1091D000843618F084E680937C0180915108883FA2 |
:1091E00038F0EFEFF0E0E81BF109E65BFB4F808120 |
:1091F00080937B0180917B01882329F0843618F0CD |
:1092000084E680937B0180915E08883F38F0EFEF21 |
:10921000F0E0E81BF109E65BFB4F8081809376016B |
:10922000809176018B3010F48AE002C08F3F11F4F8 |
:109230008093760180918B08883F38F0EFEFF0E063 |
:10924000E81BF109E65BFB4F80818093340A809133 |
:10925000340A863010F485E002C08F3F11F4809309 |
:10926000340A80918D08883F38F0EFEFF0E0E81B7A |
:10927000F109E65BFB4F808180935D0A80915D0A76 |
:10928000863010F485E002C08F3F11F480935D0AB0 |
:1092900080917808873F19F4429905C006C0863F3F |
:1092A00031F4439B02C08CE815C086E413C0883FAC |
:1092B00038F0EFEFF0E0E81BF109E65BFB4F80814F |
:1092C0008093310A8091310A893110F488E102C01B |
:1092D0008F3F11F48093310A80917908873F19F408 |
:1092E000429905C006C0863F31F4439B02C08CE81A |
:1092F00015C086E413C0883F38F0EFEFF0E0E81BBC |
:10930000F109E65BFB4F808180930A0A80910A0A8B |
:10931000893110F488E102C08F3F11F480930A0A6A |
:1093200080917A08883F38F0EFEFF0E0E81BF10910 |
:10933000E65BFB4F808180933A0A80913A0A89313B |
:1093400010F488E102C08F3F11F480933A0A8091B3 |
:1093500050080E947A488093260480915308883FE1 |
:1093600038F0EFEFF0E0E81BF109E65BFB4F80819E |
:1093700080937A0180915508883F38F0EFEFF0E054 |
:10938000E81BF109E65BFB4F8081809378018091B7 |
:109390005D08883F38F0EFEFF0E0E81BF109E65B8D |
:1093A000FB4F80818093790180915F08883F38F07E |
:1093B000EFEFF0E0E81BF109E65BFB4F8081809363 |
:1093C000750180916008883F38F0EFEFF0E0E81B0E |
:1093D000F109E65BFB4F8081809377018091610802 |
:1093E000883F38F0EFEFF0E0E81BF109E65BFB4F58 |
:1093F00080818093740180916208883F38F0EFEF9C |
:10940000F0E0E81BF109E65BFB4F8081809373017C |
:1094100080916808883F38F0EFEFF0E0E81BF10931 |
:10942000E65BFB4F80818093710180916908883FE2 |
:1094300038F0EFEFF0E0E81BF109E65BFB4F8081CD |
:109440008093250480916A08883F38F0EFEFF0E0C0 |
:10945000E81BF109E65BFB4F808180932404809137 |
:109460006B08883F38F0EFEFF0E0E81BF109E65BAE |
:10947000FB4F80818093230480916C08883F38F0F3 |
:10948000EFEFF0E0E81BF109E65BFB4F8081809392 |
:10949000220480918608883F38F0EFEFF0E0E81B67 |
:1094A000F109E65BFB4F808180932104809187085E |
:1094B000883F38F0EFEFF0E0E81BF109E65BFB4F87 |
:1094C00080818093200480918808883F38F0EFEFF6 |
:1094D000F0E0E81BF109E65BFB4F808180931F04FD |
:1094E00080918908883F38F0EFEFF0E0E81BF10940 |
:1094F000E65BFB4F808180931E0480916D08883F5E |
:1095000038F0EFEFF0E0E81BF109E65BFB4F8081FC |
:1095100080936F0180917108883F38F0EFEFF0E0A1 |
:10952000E81BF109E65BFB4F808180936E0180911F |
:109530006E08883F38F0EFEFF0E0E81BF109E65BDA |
:10954000FB4F808180936D0180917208883F38F0D5 |
:10955000EFEFF0E0E81BF109E65BFB4F80818093C1 |
:109560006C0180917B08883F38F0EFEFF0E0E81B5A |
:10957000F109E65BFB4F808180936B0180917E084F |
:10958000883F38F0EFEFF0E0E81BF109E65BFB4FB6 |
:10959000808180936A0180917F08883F38F0EFEFE7 |
:1095A000F0E0E81BF109E65BFB4F808180936901E5 |
:1095B00080918008883F38F0EFEFF0E0E81BF10978 |
:1095C000E65BFB4F8081809368018091A808883F0B |
:1095D00038F0EFEFF0E0E81BF109E65BFB4F80812C |
:1095E0008093190A90912505992321F08091190AF9 |
:1095F000981720F08091190A882311F49093190A82 |
:1096000080914D088093560A8091B2088093390A60 |
:1096100080918508883F38F0EFEFF0E0E81BF10912 |
:10962000E65BFB4F8081809367018091A108883FB2 |
:1096300038F0EFEFF0E0E81BF109E65BFB4F8081CB |
:1096400080936D0A80917101282F33272F5F3F4F40 |
:109650008CE398E2B9010E94D99F70937E016093D8 |
:109660007D0180915B0880935E0A80915A08809307 |
:10967000210AE091A308EE2309F449C081E0809318 |
:109680001D04FF27EE0FFF1FE858F64F80819181E0 |
:10969000805C9F4F14F410921D0480917F012091F3 |
:1096A0001D04821721F18330F8F43091AC0122239C |
:1096B00051F08CED95E090931E0380931D033323AE |
:1096C00069F48EE209C088EC90E090931E038093C9 |
:1096D0001D03332319F487E18093AC0185E0809367 |
:1096E000330420937F0103C0815080937F018091D8 |
:1096F000AD0A9091AE0A97FF0FC080911D04882398 |
:1097000059F08091B50580688093B50505C0E09358 |
:109710001D048AE080937F018091AD0A9091AE0A8A |
:1097200097FF1DC0809148048823C9F080911D04D3 |
:109730008823A9F080910B0190910C018F5F9F4FBE |
:1097400071F488E99AE390931E0380931D0380E0EF |
:1097500094EA90930C0180930B0110921D04809168 |
:109760001D04882321F080910F04816003C0809143 |
:109770000F048E7F80930F04DF91CF910895A8E1AD |
:10978000B0E0E5ECFBE40C9429A00E9486408091B7 |
:109790001004992784719070892B91F58091B308FA |
:1097A00082FF27C080912D0490912E040097F1F044 |
:1097B00002E088359007D4F49C0197FF02C02D5F2A |
:1097C0003F4F3595279535952795809165089927C1 |
:1097D000289FA001299F500D389F500D1124CA01C8 |
:1097E00064E670E00E94D99FCB0106C08DE290E054 |
:1097F00003C080916508992790930E0480930D040F |
:1098000020910B0430910C0455E72033350759F4AF |
:1098100010925404109253048091210A9927909336 |
:109820000E0480930D0460915304709154047A8364 |
:1098300069838091210A99270A966817790714F499 |
:109840009A83898380914904843608F06AC08091A4 |
:109850000F0482FD66C08091E9049091EA040097AC |
:1098600031F001979093EA048093E9040BC01092C1 |
:1098700048049093120480931104809110048D7E0B |
:1098800080931004809103018A3011F0843110F02C |
:10989000289A01C028988091110490911204895E41 |
:1098A0009340E0F18091F10A8536C0F180910D047A |
:1098B00090910E049A838983809110048061809333 |
:1098C000100480914108A82FBB27AA0FBB1FFD01E0 |
:1098D000E254F64F1182108280914208282F3327DC |
:1098E000220F331FC9018254964FFC01118210824E |
:1098F000A858B64F11961C921E922858364FD9017F |
:1099000011961C921E9280914408E82FFF27EE0FBB |
:10991000FF1FE858F64F11821082B4C51092480418 |
:10992000B1C5809149048D3808F482C59091AC0886 |
:10993000992309F445C08091AD08882309F440C0FB |
:10994000E92FFF27EE0FFF1FE858F64F8081918126 |
:10995000C397BCF080919401823361F480910F042D |
:1099600085FF08C080910F04806480930F0480E31A |
:109970008093AC0180910F048F7780930F0486E968 |
:1099800017C0808191818E5C9F4FACF480919401CF |
:10999000863941F480910F04806880930F048FE230 |
:1099A0008093AC0180910F048F7B80930F0482E33E |
:1099B0008093940105C080910F048F7380930F04EE |
:1099C000809110048F7E809310049091660882E34A |
:1099D000989FC00111249093EA048093E904E981DF |
:1099E000FA81B9978CF080914804882369F08091BE |
:1099F000110490911204FFEF8F3F9F0729F0019609 |
:109A00009093120480931104409111045091120418 |
:109A10004F3F510509F048F510926B0410926C0409 |
:109A200010926D0410926E041092670410926804F4 |
:109A30001092690410926A041092D5041092D60410 |
:109A40001092D7041092D8041092730410927404E8 |
:109A5000109275041092760480910F0480628093B6 |
:109A60000F0484E68093940135C1809110048260D4 |
:109A70008093100480910F0485FF98C08091260583 |
:109A800099279C012470307082FD04C080910F04DE |
:109A900086FF2AC0809141018D3331F58091080401 |
:109AA000882311F180E58093380484EF91E0A0E0F1 |
:109AB000B0E08093390490933A04A0933B04B093B0 |
:109AC0003C0480933F0490934004A0934104B093DE |
:109AD000420488EE93E09093930180939201232BAC |
:109AE00019F08DE08093AC018091290390912A03B5 |
:109AF000A0912B03B0912C0387399105A105B105E5 |
:109B00008CF48091430490914404A0914504B09159 |
:109B10004604825A9E4FAF4FBF4F24F08091560AA1 |
:109B200080FD21C088EE93E0909393018093920191 |
:109B300080910F0486FF0FC0109238048CE291E0F0 |
:109B4000A0E0B0E080933F0490934004A0934104D0 |
:109B5000B093420403C080E38093AC0180910F0472 |
:109B60008F7180930F0410926B0410926C0410920A |
:109B70006D0410926E0410926704109268041092A3 |
:109B8000690410926A041092730410927404109283 |
:109B9000750410927604495E534008F49BC088EE29 |
:109BA00093E0909312048093110494C080910F0469 |
:109BB00087FF1AC080914101863711F08D33A1F4DF |
:109BC00080910804882381F08091AD088093380447 |
:109BD00080EE91EBAFEFBFEF8093390490933A049E |
:109BE000A0933B04B0933C042091920130919301E7 |
:109BF00043E0283E340708F048C02F5F3F4F3093C2 |
:109C000093012093920110926B0410926C041092B5 |
:109C10006D0410926E041092670410926804109202 |
:109C2000690410926A0410927304109274041092E2 |
:109C30007504109276048091290390912A03A091D3 |
:109C40002B03B0912C038C529140A040B0408093E4 |
:109C50003F0490934004A0934104B0934204285ED3 |
:109C60003340C1F580910F0487FF34C080914101DA |
:109C70008B3281F180910F048F7780930F04809154 |
:109C80000F04806280930F0425C08091080488230C |
:109C900009F180914101863711F08D32D9F480911C |
:109CA000430490914404A0914504B0914604885E19 |
:109CB0009340A040B04074F48091E0079091E10798 |
:109CC0008D5A93403CF010929301109292018EE0D5 |
:109CD0008093AC0180914308E82FFF27EE0FFF1F10 |
:109CE000E858F64F80819181813591050CF454C17B |
:109CF00020914804222309F04FC180914408E82FA5 |
:109D0000FF27EE0FFF1FE858F64F808191818C34BA |
:109D100091050CF411C18091EB048F5F8093EB04EB |
:109D2000893C08F439C12093EB041092120410927C |
:109D3000110430914108E32FFF27EE0FFF1FE85871 |
:109D4000F64F8081918187349105B4F48091420867 |
:109D5000E82FFF27EE0FFF1FE858F64F8081918113 |
:109D60000190F081E02DF7FF03C0F095E195FF4FE2 |
:109D7000E734F1050CF478C041E020914208A22FAD |
:109D8000BB27AA0FBB1FA858B64F8D919C91119766 |
:109D90008734910544F0E32FFF27EE0FFF1FE858AB |
:109DA000F64F808191818D919C918734910574F05B |
:109DB00080914108E82FFF27EE0FFF1FE858F64F6C |
:109DC00080819181873491050CF042E0E22FFF27DA |
:109DD000EE0FFF1FE858F64F808191818634910580 |
:109DE00074F480914108E82FFF27EE0FFF1FE85819 |
:109DF000F64F80819181873491050CF043E0E22F8A |
:109E0000FF27EE0FFF1FE858F64F808191818A5B94 |
:109E10009F4F74F480914108E82FFF27EE0FFF1F3A |
:109E2000E858F64F80819181873491050CF044E029 |
:109E3000E22FFF27EE0FFF1FE858F64F8081918138 |
:109E40008A5B9F4F74F480914108E82FFF27EE0F43 |
:109E5000FF1FE858F64F80819181863491050CF4FC |
:109E600045E0842F0E94383180914208E82FFF2777 |
:109E7000EE0FFF1FE858F64F808191810190F0812D |
:109E8000E02DF7FF03C0F095E195FF4F7E97CCF4EE |
:109E900080914108E82FFF27EE0FFF1FE858F64F8B |
:109EA000808191818A5B9F4F64F481E08093D0052B |
:109EB0001092340488EE93E090931E0380931D0368 |
:109EC0006BC0809101010E94E33080E00E94630A30 |
:109ED000809167080E94C99A8091560A80FF10C03D |
:109EE00080911C0190911D01875B934038F4809113 |
:109EF0001C0190911D018E5E924010F40E94291F5A |
:109F000081E00E940F3D982F8093340421E020933C |
:109F10001B03579A8091B505882311F087E006C08E |
:109F2000992319F42093AC0103C088E18093AC011C |
:109F300085E08093520527C080819181855B9F4F8A |
:109F40004CF58091EB048F5F8093EB04893C20F10A |
:109F5000209348042093EB041092120410921104F1 |
:109F600082E00E940F3D982F809334048091B505C4 |
:109F7000882311F087E005C0992311F481E001C026 |
:109F800088E18093AC0168E770E0809101010E9454 |
:109F90002B3C02C02093EB0480914308E82FFF275D |
:109FA000EE0FFF1FE858F64F808191818C599F4F2B |
:109FB0000CF037C22091A408E22FFF27EF77F07052 |
:109FC000EE0FFF1FE254F64F80819181069714F047 |
:109FD00084E606C0808191818B5F9F4F1CF48CE9E1 |
:109FE0008093EE0480914804E0914408882309F0AE |
:109FF00063C1FF27EE0FFF1FE858F64F8081918164 |
:10A000008C599F4F9CF48091B30883FD0BC0E22FC5 |
:10A01000FF27EE0FFF1FE858F64F80819181855B87 |
:10A020009F4FDCF08091A4088823B9F08091B30899 |
:10A0300083FF3FC18091A408E82FFF27EE0FFF1F89 |
:10A04000E858F64F80819181875F9F4F0CF431C1B2 |
:10A050008091EE04843609F02CC180913404882369 |
:10A0600029F08091100488608093100480911E0173 |
:10A0700090911F01A0912001B09121018093E207EE |
:10A080009093E307A093E407B093E50710922903A8 |
:10A0900010922A0310922B0310922C031092430467 |
:10A0A0001092440410924504109246041092360314 |
:10A0B00010923703109238031092390380914108AF |
:10A0C000E82FFF27EE0FFF1FE858F64F80819181A0 |
:10A0D0008D599F4FACF480914208E82FFF27EE0F77 |
:10A0E000FF1FE858F64F808191810190F081E02DAB |
:10A0F000F7FF03C0F095E195FF4FE436F10534F426 |
:10A100008091A408882311F48093EC048091EC04DE |
:10A110008F5F8093EC048E3F08F466C180915F0AE4 |
:10A120009091600A97FF03C0909581959F4F81970A |
:10A13000B4F480911C0A90911D0A97FF03C090957A |
:10A1400081959F4F45975CF480910D0A90910E0A7E |
:10A1500097FF03C0909581959F4F459714F01092FB |
:10A1600034041092EC048091B505882309F094C062 |
:10A1700080913404882309F48FC080912A058823B4 |
:10A1800009F08AC081E090E090931204809311045A |
:10A1900081E0809348041092D5041092D604109266 |
:10A1A000D7041092D8041092730410927404109281 |
:10A1B00075041092760410926F041092700410923D |
:10A1C00071041092720480915C08E82EFF2400272D |
:10A1D000112780915A0A90915B0A9C01442737FD10 |
:10A1E0004095542FC801B7010E949A9FDC01CB0112 |
:10A1F0008093830490938404A0938504B093860491 |
:10A2000080916A0A90916B0A9C01442737FD409522 |
:10A21000542FC801B7010E949A9FDC01CB018093A3 |
:10A220007B0490937C04A0937D04B0937E04809182 |
:10A23000A3049091A404A091A504B091A6048093D6 |
:10A240007F0490938004A0938104B0938204809152 |
:10A250009B0490919C04A0919D04B0919E048093D6 |
:10A26000770490937804A0937904B0937A041092C1 |
:10A270006B0410926C0410926D0410926E04109294 |
:10A280006704109268041092690410926A0484E6CC |
:10A290008093330484E39AC08CED95E090931E0381 |
:10A2A00080931D0380913404882309F09DC081E0D0 |
:10A2B0008DC01092EC0498C0FF27EE0FFF1FE858E6 |
:10A2C000F64F80819181853691059CF08091B3088D |
:10A2D00083FD0BC0E22FFF27EE0FFF1FE858F64F5C |
:10A2E00080819181855B9F4FDCF08091A408882359 |
:10A2F000B9F08091B30883FF75C08091A408E82F5E |
:10A30000FF27EE0FFF1FE858F64F808191818E5C8A |
:10A310009F4F0CF067C08091EE048C3909F062C049 |
:10A3200080914108E82FFF27EE0FFF1FE858F64FF6 |
:10A33000808191818D599F4FACF480914208E82F24 |
:10A34000FF27EE0FFF1FE858F64F808191810190A3 |
:10A35000F081E02DF7FF03C0F095E195FF4FE43663 |
:10A36000F1053CF48091A408882319F48093ED044E |
:10A3700018C010926B0410926C0410926D0410922D |
:10A380006E0410926704109268041092690410928F |
:10A390006A0410925A0410925904109258041092B0 |
:10A3A00057048091ED048F5F8093ED048B3F88F01C |
:10A3B000109248041092ED041092120410921104AD |
:10A3C00080910F048F7180930F0486E28093AC011B |
:10A3D0000BC0843649F48CEA9DE090931E03809371 |
:10A3E0001D0302C01092ED0420910B0430910C0467 |
:10A3F000F3E0283E3F0708F045C080913303909179 |
:10A4000034038B569F4F1CF02F5F3F4F05C0211523 |
:10A410003105C1F12150304030930C0420930B04DE |
:10A4200031C01092EE0410920C0410920B042AC05A |
:10A430002E5E324038F18091750A9091760A8059EB |
:10A44000914000F58091430490914404A09145040B |
:10A45000B09146048C5D9540A040B0409CF480E3F0 |
:10A4600095E790930C0480930B04809111049091D4 |
:10A4700012048A5E934030F089EE93E090931204C8 |
:10A48000809311048091400181508093400180911C |
:10A4900040018F3F21F08091100484FFDFC30E94B0 |
:10A4A0009648B09057088091F7049091F8049C0169 |
:10A4B000220F331F280F391FC0904108AC2DBB2736 |
:10A4C000AA0FBB1FFD01E858F64F4B2D5527808181 |
:10A4D0009181849FB001859F700D949F700D112410 |
:10A4E000260F371F37FF02C02D5F3F4FB90175950B |
:10A4F000679575956795A254B64F80915808082FB7 |
:10A5000011278D919C91809FD001819FB00D909FCC |
:10A51000B00D11246A0F7B1F7093F8046093F70449 |
:10A520008091F9049091FA049C01220F331F280FA7 |
:10A53000391FD0904208AD2DBB27AA0FBB1FFD01CC |
:10A54000E858F64F80819181849FF001859FF00D3E |
:10A55000949FF00D11242E0F3F1F37FF02C02D5F77 |
:10A560003F4FA9015595479555954795A254B64F2C |
:10A570008D919C91809F7001819FF00C909FF00CB9 |
:10A5800011244E0D5F1D5093FA044093F9048091FD |
:10A590001D04882309F448C0CB0177FD0396DC0134 |
:10A5A000B595A795B595A795CA0157FD0396FC01EA |
:10A5B000F595E795F595E7958091A501682F7727A3 |
:10A5C00067FD70956A9F90016B9F300D7A9F300DEB |
:10A5D000112480912C05482F552747FD50954E9FFB |
:10A5E000C0014F9F900D5E9F900D1124280F391FC1 |
:10A5F00037FF02C0295F3F4F03E0359527950A9545 |
:10A60000E1F730935A04209359046E9F90016F9F95 |
:10A61000300D7E9F300D11244A9FC0014B9F900D3D |
:10A620005A9F900D11243FC08091A208E82FFF2768 |
:10A63000E85BFE4F86818093A501908190932C0565 |
:10A64000A82FBB27A7FDB095A69F9001A79F300D0F |
:10A65000B69F300D1124E92FFF27E7FDF095E49F09 |
:10A66000C001E59F900DF49F900D1124280F391F14 |
:10A6700037FF02C0295F3F4F13E0359527951A95A4 |
:10A68000E1F730935A0420935904A49F9001A59FA9 |
:10A69000300DB49F300D1124E69FC001E79F900D4F |
:10A6A000F69F900D1124281B390B37FF02C0295F3C |
:10A6B0003F4F43E0359527954A95E1F7309358048D |
:10A6C0002093570480914408E82FFF27EE0FFF1FC7 |
:10A6D000E858F64F80819181909581959F4F909396 |
:10A6E0005604809355048530910514F0049705C0F5 |
:10A6F0000FEF8C3F900734F40496909356048093A8 |
:10A70000550404C0109256041092550480910B0415 |
:10A7100090910C048150924078F18091590490916D |
:10A720005A0497FD079623E0959587952A95E1F7BA |
:10A7300090935A048093590480915704909158043F |
:10A7400097FD079603E0959587950A95E1F7909315 |
:10A7500058048093570410926B0410926C0410926A |
:10A760006D0410926E0410926704109268041092A7 |
:10A77000690410926A0443C080911805882309F483 |
:10A780003EC0282F33278091590490915A0497FD99 |
:10A79000079613E0959587951A95E1F7289FA001F4 |
:10A7A000299F500D389F500D1124CA0157FD0F9657 |
:10A7B000B4E095958795BA95E1F790935A04809304 |
:10A7C0005904809157049091580497FD0796A3E08F |
:10A7D00095958795AA95E1F7289FB001299F700D5F |
:10A7E000389F700D1124CB0177FD0F96F4E09595FD |
:10A7F0008795FA95E1F790935804809357048090D9 |
:10A80000590490905A0480911B0590911C05881A58 |
:10A81000990A90925A048092590400915704109119 |
:10A8200058048091190590911A05081B190B109373 |
:10A8300058040093570480914308E82FFF27EE0F38 |
:10A84000FF1FE858F64FE080F1808FE790E0E80EB8 |
:10A85000F91EF0925404E0925304809176019927F6 |
:10A86000AA2797FDA095BA2FBC01CD010E940E9F8B |
:10A87000DC01CB0120E030E040E251E4BC01CD013D |
:10A880000E947C9EDC01CB01BC01CD010E94E09EB8 |
:10A89000DC01CB018093640A8091750180933B0AAF |
:10A8A000809174019927AA2797FDA095BA2FBC0122 |
:10A8B000CD010E940E9FDC01CB0120E030E040E2A0 |
:10A8C00051E4BC01CD010E947C9EDC01CB01BC01A6 |
:10A8D000CD010E94E09EDC01CB018093140A80919F |
:10A8E000730180932A0A8091DC0580FF59C0809112 |
:10A8F0006D0A813808F454C08091D505992787FDE9 |
:10A9000090952B2D3327829FD001839FB00D929F6E |
:10A91000B00D11248A0E9B1E90925A048092590405 |
:10A920008091D605992787FD9095829FF001839F9E |
:10A93000F00D929FF00D11240E0F1F1F109358045D |
:10A94000009357048091D705282F332727FD309592 |
:10A950008091550490915604820F931F9093560452 |
:10A96000809355048091D905282F332727FD3095F2 |
:10A97000809152089927289F8001299F100D389FA8 |
:10A98000100D112410934701009346018091D805C2 |
:10A9900099278E159F0524F49093540480935304B3 |
:10A9A000809153049091540497FF04C01092540472 |
:10A9B000109253048091560A82FF02C010923B0A03 |
:10A9C0004091590450915A04CA0157FD03969C01C5 |
:10A9D000359527953595279537FF03C030952195F7 |
:10A9E0003F4F809115049091160482179307B4F499 |
:10A9F000CA0157FF03C0909581959F4F97FD03961D |
:10AA00009595879595958795909316048093150451 |
:10AA10008536910544F084E690E001C0019790935B |
:10AA20001604809315044091570450915804CA01AC |
:10AA300057FD03969C01359527953595279537FF4A |
:10AA400003C0309521953F4F8091130490911404D9 |
:10AA500082179307B4F4CA0157FF03C090958195FC |
:10AA60009F4F97FD0396959587959595879590931C |
:10AA70001404809313048536910544F084E690E035 |
:10AA800001C00197909314048093130480911004E3 |
:10AA900084FF08C01092160410921504109214043A |
:10AAA00010921304ED2DFF27EE0FFF1FE858F64F0D |
:10AAB00040917C08242F3327808191812817390702 |
:10AAC00044F48091B00882FF04C081E080932A049E |
:10AAD00013C0ED2DFF27EE0FFF1FE858F64F842F10 |
:10AAE000992720917D08821B9109208131812817A7 |
:10AAF000390714F410922A0440914208E42FFF27EA |
:10AB0000EE0FFF1FE858F64F50917C08852F9927CC |
:10AB100022273327281B390B8081918182179307C5 |
:10AB200044F48091B00883FF04C081E0809329043D |
:10AB300016C080912904882391F0E42FFF27EE0F9F |
:10AB4000FF1FE858F64F80917D089927851B9109D2 |
:10AB5000208131818217930714F410922904EC2D7F |
:10AB6000FF27EE0FFF1FE858F64F40917C08242F77 |
:10AB70003327808191812817390744F48091B008E8 |
:10AB800080FF04C081E08093270417C080912704D0 |
:10AB9000882399F0EC2DFF27EE0FFF1FE858F64FA2 |
:10ABA000842F992720917D08821B91092081318172 |
:10ABB0002817390714F41092270440914108E42F14 |
:10ABC000FF27EE0FFF1FE858F64F50917C08852FA6 |
:10ABD000992722273327281B390B808191818217DF |
:10ABE000930744F48091B00881FF04C081E0809312 |
:10ABF000280416C080912804882391F0E42FFF27B1 |
:10AC0000EE0FFF1FE858F64F80917D089927851BAE |
:10AC10009109208131818217930714F4109228043E |
:10AC200080912A04882319F480912904811181E0FC |
:10AC300080932B0480912704882321F48091280499 |
:10AC4000882351F081E080932C0410922B04109201 |
:10AC50002A041092290402C080932C0480912B04B2 |
:10AC6000882321F480912C04882369F080917B084B |
:10AC7000992729813A818217930714F49A8389834B |
:10AC800081E080935F0480910F0499279C012470D8 |
:10AC9000307082FF2DC080911B0590911C0590950E |
:10ACA00081959F4F90935A04809359048091190580 |
:10ACB00090911A05909581959F4F90935804809399 |
:10ACC0005704809182019091830190935404809362 |
:10ACD00053048091560A8B778B668093560A809135 |
:10ACE000390A8C7B8093390A88EC809326041EC035 |
:10ACF0008091100484FF1AC03093560420935504A9 |
:10AD000030935A04209359043093580420935704E5 |
:10AD10009AE59093640A88E780933B0A9093140A1B |
:10AD200080932A0A10922B0410922C0480912D0AF1 |
:10AD300090912E0AA0912F0AB091300A2091A3047D |
:10AD40003091A4044091A5045091A604820F931F52 |
:10AD5000A41FB51F80932D0A90932E0AA0932F0A4B |
:10AD6000B093300A8091350A9091360AA091370A43 |
:10AD7000B091380AE0909B04F0909C0400919D04EF |
:10AD800010919E04EB82FC820D831E838E0D9F1D0D |
:10AD9000A01FB11F8093350A9093360AA093370AFB |
:10ADA000B093380A8091220A9091230AA091240A34 |
:10ADB000B091250AE0909F04F090A0040091A104B6 |
:10ADC0001091A204EF82F88609871A878E0D9F1DC5 |
:10ADD000A01FB11F8093220A9093230AA093240AF4 |
:10ADE000B093250A8091150A9091160AA091170A2E |
:10ADF000B091180AE0909704F0909804009199049B |
:10AE000010919A04EB86FC860D871E878E0D9F1D80 |
:10AE1000A01FB11F8093150A9093160AA093170ADA |
:10AE2000B093180AF0902C04FF86FF2029F480913B |
:10AE30002B04882309F460C01092930410929404A8 |
:10AE4000109295041092960410928F041092900420 |
:10AE5000109291041092920410922D0A10922E0AD0 |
:10AE600010922F0A1092300A1092350A1092360A68 |
:10AE70001092370A1092380A1092220A1092230A6E |
:10AE80001092240A1092250A1092150A1092160A9E |
:10AE90001092170A1092180A8091830490918404EA |
:10AEA000A0918504B091860480937F0490938004E0 |
:10AEB000A0938104B093820480917B0490917C04E0 |
:10AEC000A0917D04B0917E048093770490937804E0 |
:10AED000A0937904B0937A04109232031092310354 |
:10AEE0001092300410922F04109232041092310408 |
:10AEF0000F85002309F0D0C180912B04882309F02D |
:10AF0000CBC18091E0079091E107815092402CF4F1 |
:10AF100080914804882309F4BFC19090E60AA0906C |
:10AF20005C0820905A0A30905B0A40906A0A509060 |
:10AF30006B0A19140CF0BBC0BB24CC24DD24CA015D |
:10AF4000B901A60195010E940EA079018A018091A4 |
:10AF5000AF0A9091B00A281A390AC101AA2797FDB1 |
:10AF6000A095BA2FE81AF90A0A0B1B0B6B817C819A |
:10AF70008D819E81A60195010E940EA059016A0152 |
:10AF80008091B10A9091B20A481A590AC201AA27BF |
:10AF900097FDA095BA2FA81AB90ACA0ADB0A292C6C |
:10AFA000332427FC3094432C532CC801B701A20151 |
:10AFB00091010E949A9F97FF04C061507E4F8F4F6E |
:10AFC0009F4F3B014C0109E09594879477946794D7 |
:10AFD0000A95D1F7C601B501A20191010E949A9F7D |
:10AFE00097FF04C061507E4F8F4F9F4F5B016C01F4 |
:10AFF00019E0D594C794B794A7941A95D1F7809186 |
:10B00000150490911604813491053CF48091130449 |
:10B010009091140481349105D4F0D401C30197FEBA |
:10B0200003C00196A11DB11D3C014D01959487946B |
:10B0300077946794D601C501D7FE03C00196A11D80 |
:10B04000B11D5C016D01D594C794B794A79480910C |
:10B05000E80A282F332727FD3095432F532F261535 |
:10B0600037054805590514F439014A01992787FD28 |
:10B070009095909581959F4FAA2797FDA095BA2FFF |
:10B08000681679068A069B0614F43C014D012A15C0 |
:10B090003B054C055D0514F459016A01A816B90673 |
:10B0A000CA06DB060CF0D0C05C016D01CDC0EA2CF5 |
:10B0B000FF2400271127CA01B901A80197010E94A6 |
:10B0C0000EA039014A01C101AA2797FDA095BA2F08 |
:10B0D000681A790A8A0A9B0A6B817C818D819E811C |
:10B0E000A80197010E940EA059016A01C201AA2776 |
:10B0F00097FDA095BA2FA81AB90ACA0ADB0AD4018B |
:10B10000C30197FE03C00F96A11DB11D3C014D0167 |
:10B11000F4E09594879477946794FA95D1F7D601E3 |
:10B12000C501D7FE03C00F96A11DB11D5C016D01C5 |
:10B13000E4E0D594C794B794A794EA95D1F78091A9 |
:10B14000150490911604813491053CF48091130408 |
:10B150009091140481349105A4F0C401B30123E05B |
:10B1600030E040E050E00E940EA039014A01C601E3 |
:10B17000B50123E030E040E050E00E940EA059010C |
:10B180006A0180914408E82FFF27EE0FFF1FE8585F |
:10B19000F64F808191810190F081E02DF7FF03C08F |
:10B1A000F095E195FF4F7A97A4F0C401B30123E035 |
:10B1B00030E040E050E00E940EA039014A01C60193 |
:10B1C000B50123E030E040E050E00E940EA05901BC |
:10B1D0006A0189E180938E0121E262167104810483 |
:10B1E00091042CF070E2672E712C812C912C30EEA2 |
:10B1F00063163FEF73063FEF83063FEF930644F479 |
:10B2000060EE662E6FEF762E6FEF862E6FEF962E26 |
:10B2100041E2A416B104C104D1042CF050E2A52EE1 |
:10B22000B12CC12CD12C50EEA5165FEFB5065FEF07 |
:10B23000C5065FEFD50644F440EEA42E4FEFB42EC2 |
:10B240004FEFC42E4FEFD42E80918304909184044D |
:10B25000A0918504B091860486199709A809B909B7 |
:10B260008093830490938404A0938504B093860410 |
:10B2700080917B0490917C04A0917D04B0917E0428 |
:10B280008A199B09AC09BD0980937B0490937C04C7 |
:10B29000A0937D04B0937E0480913103909132039A |
:10B2A0008F3F910509F008F4C4C56F85662309F046 |
:10B2B0004EC580912B04882309F049C580915F0415 |
:10B2C000882309F044C570918408788B772309F4AA |
:10B2D0003EC580912D0A90912E0AA0912F0AB0911F |
:10B2E000300AB7FF04C081509F4FAF4FBF4FE92EC8 |
:10B2F000FA2E0B2F112707FD1A95E0922D0AF092D6 |
:10B300002E0A00932F0A1093300A8091350A9091EB |
:10B31000360AA091370AB091380AB7FF04C08150AD |
:10B320009F4FAF4FBF4F892F9A2FAB2FBB27A7FD42 |
:10B33000BA95898B9A8BAB8BBC8B8093350A909393 |
:10B34000360AA093370AB093380A80915C08A82E79 |
:10B35000BB24CC24DD2420919304309194044091AB |
:10B36000950450919604C601B5010E949A9F97FFDB |
:10B3700004C061507F4F8F4F9F4F672E782E892ECC |
:10B38000992487FC9A94609293047092940480921A |
:10B3900095049092960420918F04309190044091EE |
:10B3A000910450919204C601B5010E949A9F97FFA3 |
:10B3B00004C061507F4F8F4F9F4F272E382E492E4C |
:10B3C000552447FC5A9420928F0430929004409266 |
:10B3D00091045092920480918B0490918C04A091DE |
:10B3E0008D04B0918E04B7FF04C081509F4FAF4FC2 |
:10B3F000BF4F892F9A2FAB2FBB27A7FDBA958093FC |
:10B400008B0490938C04A0938D04B0938E04D80188 |
:10B41000C70186199709A809B9098093E104909397 |
:10B42000E204A093E304B093E40420918308E22EA5 |
:10B43000FF2400271127BC01CD01A80197010E941C |
:10B440000EA059016A012093EF043093F004409359 |
:10B45000F1045093F20489899A89AB89BC898219D5 |
:10B460009309A409B5098093E5049093E604A09399 |
:10B47000E704B093E804BC01CD01A80197010E9444 |
:10B480000EA02093F3043093F4044093F5045093FA |
:10B49000F604D601C501D7FE04C081509F4FAF4FBF |
:10B4A000BF4F892F9A2FAB2FBB27A7FDBA9590933B |
:10B4B000300480932F0457FF04C021503F4F4F4F5B |
:10B4C0005F4FBB2757FDBA95A52F942F832F9093DD |
:10B4D00032048093310480911504909116048134D4 |
:10B4E0009105DCF48091130490911404813491054A |
:10B4F000A4F480914408E82FFF27EE0FFF1FE858BF |
:10B50000F64F808191810190F081E02DF7FF03C01B |
:10B51000F095E195FF4F7A97E4F08091E60A8F3F2E |
:10B52000C1F480912F049091300497FD0196959578 |
:10B5300087959093300480932F04809131049091EB |
:10B54000320497FD019695958795909332048093E8 |
:10B5500031048091220A9091230AA091240AB0918B |
:10B56000250AB7FF04C081509F4FAF4FBF4F892FAF |
:10B570009A2FAB2FBB27A7FDBA958093220A9093F1 |
:10B58000230AA093240AB093250A8091150A90916A |
:10B59000160AA091170AB091180AB7FF04C081508B |
:10B5A0009F4FAF4FBF4F892F9A2FAB2FBB27A7FDC0 |
:10B5B000BA958093150A9093160AA093170AB09330 |
:10B5C000180A8091A3049091A404A091A504B091BD |
:10B5D000A6042F81388549855A85281B390B4A0BCB |
:10B5E0005B0B2093D9043093DA044093DB0450932F |
:10B5F000DC0480919B0490919C04A0919D04B091E7 |
:10B600009E04EB84FC840D851E85E81AF90A0A0B5A |
:10B610001B0BE092DD04F092DE040093DF04109334 |
:10B62000E0042093E1043093E2044093E304509358 |
:10B63000E404E092E504F092E6040093E70410933A |
:10B64000E80480917F0490918004A0918104B091DE |
:10B650008204821B930BA40BB50B80937F04909301 |
:10B660008004A0938104B093820480917704909128 |
:10B670007804A0917904B0917A048E199F09A00BE7 |
:10B68000B10B8093770490937804A0937904B093DE |
:10B690007A0488898823E1F020915D0430915E046A |
:10B6A000213831054CF08091B5049091B604019693 |
:10B6B0009093B6048093B50420583F4F4CF480918A |
:10B6C000B5049091B60401979093B6048093B504A5 |
:10B6D00010925E0410925D0481E090E09093FC046F |
:10B6E0008093FB04E090E104F090E2040091E30415 |
:10B6F0001091E404D801C70117FF07C088279927D4 |
:10B70000DC018E199F09A00BB10B81509240A04023 |
:10B71000B04034F084E090E09093FC048093FB040C |
:10B720008091010590910205A0910305B091040557 |
:10B7300020912D0A30912E0A40912F0A5091300A03 |
:10B74000821B930BA40BB50B815E914BAF4FBF4F88 |
:10B750008F539C49A040B04028F08091E70A89317E |
:10B760000CF4FFC021E0E21620E1F20620E002071F |
:10B7700020E012070CF473C08091FD04882309F4C3 |
:10B780006AC0D801C70117FF07C088279927DC01C5 |
:10B790008E199F09A00BB10B9C01AD01B7FF04C02E |
:10B7A00021503E4F4F4F5F4FF9E0559547953795E4 |
:10B7B0002795FA95D1F78091FB049091FC04820FB4 |
:10B7C000931F9093FC048093FB04D801C70117FFDB |
:10B7D00003C00796A11DB11DE3E0B595A795979508 |
:10B7E0008795EA95D1F78093EF049093F004A093A6 |
:10B7F000F104B093F20489589341A040B04064F042 |
:10B8000088E893E1A0E0B0E08093EF049093F00427 |
:10B81000A093F104B093F2042091EF043091F0046E |
:10B820004091F1045091F20457FF04C021503F4F62 |
:10B830004F4F5F4F232F342F452F552747FD5A95E4 |
:10B8400080912F0490913004820F931F90933004C5 |
:10B8500080932F0406C081E08093FD0402C0109203 |
:10B86000FD0440E0E41640EFF4064FEF04074FEF0D |
:10B8700014070CF073C08091FE04882309F46AC099 |
:10B88000D801C70117FF07C088279927DC018E1947 |
:10B890009F09A00BB10B9C01AD01B7FF04C0215063 |
:10B8A0003E4F4F4F5F4F69E0559547953795279528 |
:10B8B0006A95D1F78091FB049091FC04820F931F4D |
:10B8C0009093FC048093FB04D801C70117FF03C0C9 |
:10B8D0000796A11DB11D23E0B595A795979587956E |
:10B8E0002A95D1F78093EF049093F004A093F1048C |
:10B8F000B093F20488579C4EAF4FBF4F64F488E773 |
:10B900009CEEAFEFBFEF8093EF049093F004A09311 |
:10B91000F104B093F2042091EF043091F0044091CF |
:10B92000F1045091F20457FF04C021503F4F4F4F94 |
:10B930005F4F232F342F452F552747FD5A95809170 |
:10B940002F0490913004820F931F909330048093C2 |
:10B950002F0411C081E08093FE040DC01092FE04FC |
:10B960000AC01092FC041092FB0484E690E09093CD |
:10B970008D0180938C016889262F33278091FB04E9 |
:10B980009091FC042817390724F43093FC04209389 |
:10B99000FB041091E70A112379F0212F332727FDAB |
:10B9A00030958091FB049091FC042817390724F40A |
:10B9B0003093FC042093FB044091E1045091E20495 |
:10B9C0006091E3047091E40441385105610571050B |
:10B9D00074F08091B9049091BA042091FB043091E5 |
:10B9E000FC04820F931F9093BA048093B9044058CB |
:10B9F0005F4F6F4F7F4F74F48091B9049091BA04F8 |
:10BA00002091FB043091FC04821B930B9093BA04A9 |
:10BA10008093B90481E090E09093FC048093FB0450 |
:10BA2000C090E504D090E604E090E704F090E804CC |
:10BA3000D701C601F7FE07C088279927DC018C19BA |
:10BA40009D09AE09BF0981509240A040B04034F03A |
:10BA500084E090E09093FC048093FB0480910505C2 |
:10BA600090910605A0910705B09108052091350A2F |
:10BA70003091360A4091370A5091380A821B930B55 |
:10BA8000A40BB50B815E914BAF4FBF4F8F539C49B9 |
:10BA9000A040B04018F019310CF4FFC001E0C0160E |
:10BAA00000E1D00600E0E00600E0F0060CF473C010 |
:10BAB0008091FF04882309F46AC0D701C601F7FE0C |
:10BAC00007C088279927DC018C199D09AE09BF0999 |
:10BAD0009C01AD01B7FF04C021503E4F4F4F5F4F57 |
:10BAE00009E055954795379527950A95D1F78091A7 |
:10BAF000FB049091FC04820F931F9093FC048093AD |
:10BB0000FB04D701C601F7FE03C00796A11DB11DB6 |
:10BB100013E0B595A795979587951A95D1F78093DA |
:10BB2000F3049093F404A093F504B093F6048958B9 |
:10BB30009341A040B04064F088E893E1A0E0B0E019 |
:10BB40008093F3049093F404A093F504B093F60467 |
:10BB50002091F3043091F4044091F5045091F604DF |
:10BB600057FF04C021503F4F4F4F5F4F232F342FBB |
:10BB7000452F552747FD5A95809131049091320405 |
:10BB8000820F931F909332048093310406C081E0AA |
:10BB90008093FF0402C01092FF0420E0C21620EF41 |
:10BBA000D2062FEFE2062FEFF2060CF073C0809161 |
:10BBB0000005882309F46AC0D701C601F7FE07C053 |
:10BBC00088279927DC018C199D09AE09BF099C01C2 |
:10BBD000AD01B7FF04C021503E4F4F4F5F4FE9E02A |
:10BBE0005595479537952795EA95D1F78091FB04B0 |
:10BBF0009091FC04820F931F9093FC048093FB04AC |
:10BC0000D701C601F7FE03C00796A11DB11D73E061 |
:10BC1000B595A795979587957A95D1F78093F30475 |
:10BC20009093F404A093F504B093F60488579C4EC7 |
:10BC3000AF4FBF4F64F488E79CEEAFEFBFEF809348 |
:10BC4000F3049093F404A093F504B093F6042091C8 |
:10BC5000F3043091F4044091F5045091F60457FF39 |
:10BC600004C021503F4F4F4F5F4F232F342F452F9C |
:10BC7000552747FD5A958091310490913204820FE7 |
:10BC8000931F909332048093310411C081E080931C |
:10BC900000050DC0109200050AC01092FC0410921D |
:10BCA000FB0484E690E090938D0180938C01488999 |
:10BCB000242F33278091FB049091FC042817390727 |
:10BCC00024F43093FC042093FB048091E70A88233A |
:10BCD00079F0282F332727FD30958091FB04909130 |
:10BCE000FC042817390724F43093FC042093FB0448 |
:10BCF0004091E5045091E6046091E7047091E804F6 |
:10BD0000413851056105710574F08091B704909137 |
:10BD1000B8042091FB043091FC04820F931F909390 |
:10BD2000B8048093B70440585F4F6F4F7F4FCCF4F7 |
:10BD30008091B7049091B8042091FB043091FC04E9 |
:10BD4000821B930B9093B8048093B7040AC010929F |
:10BD50003204109231041092300410922F04109289 |
:10BD60005F0480913B0A882341F4109232041092C0 |
:10BD700031041092300410922F0480912D0A90917A |
:10BD80002E0AA0912F0AB091300A8093010590935A |
:10BD90000205A0930305B09304058091350A9091A4 |
:10BDA000360AA091370AB091380A8093050590931E |
:10BDB0000605A0930705B09308051092930410920E |
:10BDC0009404109295041092960410928F0410928D |
:10BDD0009004109291041092920410928B0410928D |
:10BDE0008C0410928D0410928E0410922D0A1092E1 |
:10BDF0002E0A10922F0A1092300A1092350A1092D1 |
:10BE0000360A1092370A1092380A1092220A1092BB |
:10BE1000230A1092240A1092250A1092150A1092F1 |
:10BE2000160A1092170A1092180A109232031092F2 |
:10BE30003103E0905504F0905604C701F7FE04C0AA |
:10BE4000882799278E199F0904973CF08091560AFC |
:10BE500084FD03C082E38093330410915908A12E1E |
:10BE6000BB24CC24DD24B701882777FD8095982F4B |
:10BE70009701F7FE04C0222733272E193F094427D4 |
:10BE800037FD4095542F0E949A9F9B01AC01C6013B |
:10BE9000B5010E949A9F97FF04C061507E4F8F4F5B |
:10BEA0009F4F59E095958795779567955A95D1F766 |
:10BEB0009B01812F99278E9DD0018F9DB00D9E9D56 |
:10BEC000B00D1124CD01B7FD0396959587959595F5 |
:10BED0008795280F391F80910B0490910C04815095 |
:10BEE000924010F020E030E08091350490913604CB |
:10BEF000280F391F442737FD4095542F2093D50430 |
:10BF00003093D6044093D7045093D804809173049F |
:10BF100090917404A0917504B0917604821B930BE8 |
:10BF2000A40BB50B8093730490937404A0937504D1 |
:10BF3000B09376048155934CA040B04064F080E506 |
:10BF400093ECA0E0B0E08093730490937404A0930A |
:10BF50007504B09376048091730490917404A09159 |
:10BF60007504B0917604805B9C43AF4FBF4F64F47F |
:10BF700080EB9CE3AFEFBFEF809373049093740466 |
:10BF8000A0937504B09376040091900110919101F3 |
:10BF900017FDFCC08091560A83FFF8C080918F0185 |
:10BFA000815080938F01882309F0F4C08DE0809345 |
:10BFB0008F018091A3049091A404A091A504B09155 |
:10BFC000A604B7FF04C081509E4FAF4FBF4F39E06A |
:10BFD000B595A795979587953A95D1F77C0197FFE9 |
:10BFE00004C0F094E194F108F39480919B04909143 |
:10BFF0009C04A0919D04B0919E04B7FF04C08150A1 |
:10C000009E4FAF4FBF4F29E0B595A7959795879560 |
:10C010002A95D1F79C0197FF03C0309521953F4F9A |
:10C02000E216F3060CF47901B701F7FE02C0695F6E |
:10C030007F4F2B0183E0559447948A95E1F722E0E6 |
:10C0400030E0420E531E6090660A7090670A80903E |
:10C05000680A9090690A2091420130914301409111 |
:10C06000440150914501C401B3010E940EA0590141 |
:10C070006A013093130A2093120A021B130BC801A2 |
:10C08000845E9D4F68E671E00E94D99F9C01245B0D |
:10C09000304080918C0190918D01009731F0019793 |
:10C0A00090938D0180938C011BC049E1E416F1044B |
:10C0B000BCF480915D0490915E04820F931F909375 |
:10C0C0005E0480935D0480913304882349F081509D |
:10C0D00080933304882321F4B0926204A092610417 |
:10C0E00080918C0190918D01892BF9F480918E01C2 |
:10C0F0009927289FB001299F700D389F700D11243A |
:10C10000CB01B2010E94D99FCB01AA2797FDA09530 |
:10C11000BA2F680E791E8A1E9B1E6092660A709264 |
:10C12000670A8092680A9092690A80913304882392 |
:10C1300069F580916104909162042091120A309116 |
:10C14000130A821B930B845E9D4F68E671E00E9488 |
:10C15000D99F9C01245B3040809179018695992775 |
:10C16000289FD001299FB00D389FB00D11249D014B |
:10C17000B7FF02C0215F3F4F04E0359527950A9530 |
:10C18000E1F7309336042093350404C0109236044E |
:10C190001092350480915F04882381F01092670427 |
:10C1A000109268041092690410926A0410926B0451 |
:10C1B00010926C0410926D0410926E0480912C0405 |
:10C1C0008823F1F480913B0A282F332744275527F1 |
:10C1D0008091A3049091A404A091A504B091A60419 |
:10C1E000BC01CD010E949A9FDC01CB01BC01CD01B5 |
:10C1F00028EF3AE240E050E00E940EA0290102C080 |
:10C200004424552480912B048823F1F480913B0A27 |
:10C21000282F33274427552780919B0490919C0415 |
:10C22000A0919D04B0919E04BC01CD010E949A9FF3 |
:10C23000DC01CB01BC01CD0128EF3AE240E050E047 |
:10C240000E940EA0190102C02224332480910F0AFB |
:10C250009091100A893C91051CF088EC90E005C093 |
:10C2600088539F4F34F488E39FEF9093100A809394 |
:10C270000F0A80911A0A90911B0A893C91051CF0C3 |
:10C2800088EC90E005C088539F4F34F488E39FEF1B |
:10C2900090931B0A80931A0A80911C0A90911D0AA0 |
:10C2A000AA2797FDA095BA2F2091640AA22EBB243D |
:10C2B000CC24DD24BC01CD01A60195010E949A9FEA |
:10C2C0009B01AC0180910F0A9091100AAA2797FD5B |
:10C2D000A095BA2F17E0880F991FAA1FBB1F1A95A8 |
:10C2E000D1F7280F391F4A1F5B1F57FF04C0215C7D |
:10C2F0003F4F4F4F5F4FA6E0559547953795279590 |
:10C30000AA95D1F78201020F131F10931D0A009303 |
:10C310001C0A80910D0A90910E0AAA2797FDA095FC |
:10C32000BA2FBC01CD01A60195010E949A9F9B01E5 |
:10C33000AC0180911A0A90911B0AAA2797FDA0953B |
:10C34000BA2FF7E0880F991FAA1FBB1FFA95D1F7E4 |
:10C35000280F391F4A1F5B1F57FF04C0215C3F4F46 |
:10C360004F4F5F4FE6E05595479537952795EA95EE |
:10C37000D1F77101E20EF31EF0920E0AE0920D0A5F |
:10C3800080915F0A9091600A880F991FAA2797FDF4 |
:10C39000A095BA2F2091140A332744275527BC01B2 |
:10C3A000CD010E949A9F5B016C0197FF08C02FE3AB |
:10C3B00030E040E050E0A20EB31EC41ED51E76E071 |
:10C3C000D594C794B794A7947A95D1F780912A0A07 |
:10C3D000282F33274427552780918704909188047C |
:10C3E000A0918904B0918A04BC01CD010E949A9F5A |
:10C3F000DC01CB01BC01CD0120EF35E540E050E090 |
:10C400000E940EA0B501620F731F7093600A6093C3 |
:10C410005F0A0150104134F080E090E190931D0AD2 |
:10C4200080931C0A80911C0A90911D0A8050904FA5 |
:10C4300034F480E090EF90931D0A80931C0A51E041 |
:10C44000E51650E1F50634F080E090E190930E0A95 |
:10C4500080930D0A80910D0A90910E0A8050904FA2 |
:10C4600034F480E090EF90930E0A80930D0A6150AF |
:10C47000704134F080E090E19093600A80935F0A0D |
:10C4800080915F0A9091600A8050904F34F480E070 |
:10C4900090EF9093600A80935F0A8091100485FD6D |
:10C4A00016C0809102019927209126013091270121 |
:10C4B00009811A81089F7001099FF00C189FF00CE8 |
:10C4C0001124C701B9010E94C59F7A8369838091B5 |
:10C4D00009058150809309058F3F09F047C080917D |
:10C4E0000A0590910B05892B41F4809126019091CA |
:10C4F000270190930B0580930A0580912601909166 |
:10C50000270120910A0530910B052817390718F4E7 |
:10C510002F5F3F4F09C0809126019091270182171C |
:10C52000930730F42150304030930B0520930A05D7 |
:10C5300084E6809309058091AF08282F3327409126 |
:10C540000A0550910B054217530710F48AE00CC0FE |
:10C5500080910001280F311D2417350738F4809190 |
:10C560000704882319F08150809307048091070401 |
:10C570008823D1F08091390490913A04A0913B0432 |
:10C58000B0913C04B7FD10C08091AD088093380491 |
:10C5900080EE91EBAFEFBFEF8093390490933A04B4 |
:10C5A000A0933B04B0933C0480911C03882311F4B6 |
:10C5B0000E94807129813A81220F331F220F331F7D |
:10C5C0003A8329838091560A80FD02C00C94606DE5 |
:10C5D00080912B04882311F00C94606D20912C0421 |
:10C5E000222311F00C94606D8091B50599278F7707 |
:10C5F0009070009711F00C94606D3C018091BB0429 |
:10C600009091BC04892B09F044C080911C01909149 |
:10C610001D018959934058F087B58A3F20F48091D5 |
:10C620003503815011C081E0809317055EC0809171 |
:10C630001C0190911D018436910530F587B5863037 |
:10C64000F8F0809135038F5F8093350395E0890280 |
:10C65000900111248091EC07821B87BD87B58095DE |
:10C6600088BD8CE291E090931E0380931D038EE5BC |
:10C6700091E09093BC048093BB040E94F11E35C0EE |
:10C6800081E08093160531C020931605209317058D |
:10C690002CC0709234036092330380910804882385 |
:10C6A00021F081E00E94019917C08091430490918C |
:10C6B0004404A0914504B091460454E0880F991FAA |
:10C6C000AA1FBB1F5A95D1F7809336039093370367 |
:10C6D000A0933803B09339038091BB049091BC04BC |
:10C6E00001979093BC048093BB048091560A2091DB |
:10C6F000260481FF3CC0223348F58091950181508A |
:10C70000809395018F3F09F052C08091AC0188233E |
:10C7100039F480916004882319F088E28093AC0199 |
:10C72000109260048091430490914404A0914504C8 |
:10C73000B091460480933F0490934004A093410439 |
:10C74000B093420481E08093950131C0273478F1A1 |
:10C750008091AC01882339F480916004882319F416 |
:10C7600087E28093AC0188EC809395011DC0809195 |
:10C77000460190914701820F911D20915208332765 |
:10C78000829FA001839F500D929F500D1124CA01DA |
:10C79000AA2797FDA095BA2F80933F049093400459 |
:10C7A000A0934104B093420481E08093600480919F |
:10C7B000A3049091A404A091A504B091A604E090D4 |
:10C7C0004201F09043010091440110914501BC01E8 |
:10C7D000CD01A80197010E940EA059016A01809124 |
:10C7E0009B0490919C04A0919D04B0919E04BC0177 |
:10C7F000CD01A80197010E940EA0B901C5010E94B8 |
:10C80000BA9D9093270A8093260ACC9734F08CE344 |
:10C8100090E09093270A8093260A8091260A9091AF |
:10C82000270A0E94107A9093270A8093260A80E2B2 |
:10C830008093410110923E0410923D048091600467 |
:10C84000882309F4A1C78091100499279C012071C5 |
:10C85000307084FD99C780910F04826080930F042B |
:10C860007091390A872F992741E0842E912C8822D4 |
:10C87000992280FD04C08091560A81FD10C0E98094 |
:10C88000FA8030930D0520930C0530933E042093DD |
:10C890003D0480911004806C8093100410C380913B |
:10C8A000100481FFDFC20091820110918301C80151 |
:10C8B0000F96A0915304B0915404B88FAF8B8A1790 |
:10C8C0009B070CF09AC080911605882309F095C04B |
:10C8D0008091100487FF15C0809110048F7780939A |
:10C8E00010048091290390912A03A0912B03B09109 |
:10C8F0002C0380933F0490934004A0934104B09391 |
:10C900004204E090190AEE20D9F180913F04909101 |
:10C910004004A0914104B0914204BC01CD0124E641 |
:10C9200030E040E050E00E940EA0AE2CBB24CC24AE |
:10C93000DD24A216B306C406D50614F590923E0473 |
:10C9400080923D048091AC018823C1F4809143041E |
:10C9500090914404A0914504B0914604BC01CD01DE |
:10C960002FE530E040E050E00E940EA0A216B30692 |
:10C97000C406D5061CF48AE18093AC018DE338C06F |
:10C9800080910E0590910F05459784F080912903C1 |
:10C9900090912A03A0912B03B0912C0380933F0424 |
:10C9A00090934004A0934104B093420480911004FA |
:10C9B0008064809310042F89388D201B310B2F50F9 |
:10C9C000304037FF03C0309521953F4F30933E04F0 |
:10C9D00020933D0480910704882349F0C90163E056 |
:10C9E00070E00E94D99F70933E0460933D048BE2F7 |
:10C9F000809341011092370437C1C8010F97EF8926 |
:10CA0000F88DE817F907CCF5209117052223A9F531 |
:10CA10008091100486FF15C0809110048F7B809355 |
:10CA200010048091290390912A03A0912B03B091C7 |
:10CA30002C0380933F0490934004A0934104B0934F |
:10CA40004204809110048068809310048F89988D2F |
:10CA5000801B910B0F9697FF03C0909581959F4F78 |
:10CA6000909581959F4F90933E0480933D048DE275 |
:10CA70008093410120933704F7C08DE380934101F7 |
:10CA800060913804662371F12091390430913A04A1 |
:10CA900040913B0450913C0480913F0490914004AC |
:10CAA000A0914104B091420482179307A407B507EF |
:10CAB000CCF480911004806480931004862F992711 |
:10CAC00090933E0480933D048AE0809337048EE582 |
:10CAD000809341018091100487FFC6C080911004AB |
:10CAE0008F7733C0662309F443C020913904309115 |
:10CAF0003A0440913B0450913C0480913F04909152 |
:10CB00004004A0914104B0914204281739074A0714 |
:10CB10005B0774F580911004806880931004862F61 |
:10CB20009927909581959F4F90933E0480933D0463 |
:10CB300086EF8093370486E780934101809110044B |
:10CB400086FF92C0809110048F7B809310048091A7 |
:10CB5000290390912A03A0912B03B0912C03809379 |
:10CB60003F0490934004A0934104B09342047CC0DE |
:10CB700080911004807C09F477C080913704882369 |
:10CB800009F04CC08091290390912A03A0912B03B6 |
:10CB9000B0912C03885C9040A040B04020913F04AD |
:10CBA0003091400440914104509142048217930710 |
:10CBB000A407B5076CF08091290390912A03A091F6 |
:10CBC0002B03B0912C03885C9040A040B0401DC066 |
:10CBD0008091290390912A03A0912B03B0912C03FB |
:10CBE00088539F4FAF4FBF4F281739074A075B073E |
:10CBF000BCF08091290390912A03A0912B03B0915E |
:10CC00002C0388539F4FAF4FBF4F80933F049093A7 |
:10CC10004004A0934104B093420402C01092370430 |
:10CC2000809110048F738093100410920D05109260 |
:10CC30000C0571FF06C084EF91E090931E03809372 |
:10CC40001D0380914704882379F4809143049091D7 |
:10CC50004404A0914504B0914604C397A105B105D1 |
:10CC60001CF081E08093470460910C0570910D05E4 |
:10CC700080913D0490913E04680F791F70930D05DB |
:10CC800060930C05CB0177FF04C088279927861B8A |
:10CC9000970B855F91400CF4CEC04091370444233C |
:10CCA00089F18091390490913A0420913F043091A8 |
:10CCB0004004821B930B0996439748F480913904F2 |
:10CCC00090913A04A0913B04B0913C0412C0242FEF |
:10CCD000332727FD3095432F532F80913F049091A8 |
:10CCE0004004A0914104B0914204820F931FA41FFD |
:10CCF000B51F80933F0490934004A0934104B093E8 |
:10CD0000420424C020913F043091400440914104EA |
:10CD100050914204809152081616170644F463E0BD |
:10CD20000E94B99F280F311D411D511D07C063E0AE |
:10CD30000E94B99F281B31094109510920933F04E2 |
:10CD400030934004409341045093420410920D05E7 |
:10CD500010920C05E0904304F090440400914504C7 |
:10CD600010914604D801C70180509440A040B040C3 |
:10CD700020913F043091400440914104509142047D |
:10CD800082179307A407B5075CF4D801C701805048 |
:10CD90009C4FAF4FBF4F281739074A075B0744F036 |
:10CDA00080933F0490934004A0934104B0934204C5 |
:10CDB0008091390A81FF06C084E690E090931E03BB |
:10CDC00080931D03809156088823A9F5809138042B |
:10CDD000882389F540912D0450912E0457FF02C0FD |
:10CDE0004D5F5F4F55954795559547958091260125 |
:10CDF00090912701209102013327489F7001499F9C |
:10CE0000F00C589FF00C1124C701B9010E94D99F62 |
:10CE10007093830160938201663471051CF486E48B |
:10CE200090E005C06739710534F086E990E0909391 |
:10CE30008301809382018091BB049091BC04892B73 |
:10CE4000D1F18091290390912A03A0912B03B091F5 |
:10CE50002C0380933F0490934004A0934104B0932B |
:10CE6000420429C08091430490914404A091450458 |
:10CE7000B091460480599140A040B04080933F0457 |
:10CE800090934004A0934104B093420480915608CB |
:10CE9000882311F0992702C088E790E090938301DE |
:10CEA0008093820109811A8110932E0400932D042E |
:10CEB0008EE280934101E0902D04F0902E04809149 |
:10CEC000290390912A03A0912B03B0912C03209168 |
:10CED0003F0430914004409141045091420428178E |
:10CEE00039074A075B0724F08091390A80FD98C40E |
:10CEF000809108046091BB047091BC04882309F000 |
:10CF00007CC2672B49F0E0902D04F0902E04109223 |
:10CF10000F0510920E05E1C08091290390912A031C |
:10CF2000A0912B03B0912C03821B930BA40BB50B88 |
:10CF30008093D9049093DA04A093DB04B093DC04CB |
:10CF4000823010E891071FEFA1071FEFB1072CF403 |
:10CF500081E090E8AFEFBFEF09C08F5F9F47A0402F |
:10CF6000B04064F08FEF9FE7A0E0B0E08093D90479 |
:10CF70009093DA04A093DB04B093DC048091D9048D |
:10CF80009091DA0490930F0580930E0580917B01B8 |
:10CF9000282F3327442755278091D9049091DA040C |
:10CFA000A091DB04B091DC04BC01CD010E949A9FEA |
:10CFB00097FF04C0615E7F4F8F4F9F4F25E095958F |
:10CFC0008795779567952A95D1F76093D9047093E3 |
:10CFD000DA048093DB049093DC0465303EEF730742 |
:10CFE0003FEF83073FEF93072CF484E09EEFAFEF12 |
:10CFF000BFEF09C0605074408040904064F080E012 |
:10D0000094E0A0E0B0E08093D9049093DA04A09378 |
:10D01000DB04B093DC046090D9047090DA042091B2 |
:10D0200033033091340337FF02C0295F3F4F03E0E1 |
:10D03000359527950A95E1F75FEF223835071CF4FF |
:10D0400021E83FEF05C02038310514F020E830E03A |
:10D05000C901AA2797FDA095BA2F20917C013327FB |
:10D0600044275527BC01CD010E949A9F97FF04C019 |
:10D070006D5F7F4F8F4F9F4F12E095958795779506 |
:10D0800067951A95D1F79B016FEF213036071CF495 |
:10D0900020E03FEF06C02F3F310519F014F020E0EB |
:10D0A00031E080911004807C49F0C90137FD03967E |
:10D0B0009C0135952795359527950DC08091390AA6 |
:10D0C00080FF09C0C90137FD07969C01A3E0359593 |
:10D0D0002795AA95E1F7620E731E20917A0122230B |
:10D0E00009F454C0609163047091640480916504F4 |
:10D0F0009091660497FF04C061587F4F8F4F9F4FF8 |
:10D10000F7E09595879577956795FA95D1F7332749 |
:10D11000442755270E949A9F97FF04C0615E7F4F66 |
:10D120008F4F9F4FE5E09595879577956795EA95A1 |
:10D13000D1F76093D9047093DA048093DB04909361 |
:10D14000DC046138AFEF7A07AFEF8A07AFEF9A07D9 |
:10D150002CF480E89FEFAFEFBFEF0AC06F3F71057F |
:10D160008105910569F064F080E091E0A0E0B0E015 |
:10D170008093D9049093DA04A093DB04B093DC0489 |
:10D180008091D9049091DA04680E791E809178011B |
:10D19000282F33278091EA0A992787FD9095289FA9 |
:10D1A000F001299FF00D389FF00D11249F01F7FF2A |
:10D1B00002C021583F4F220F232F221F330BFFEFB6 |
:10D1C00021383F071CF420E83FEF06C02F3F310510 |
:10D1D00019F014F020E031E0260D371DC901AA270F |
:10D1E00097FDA095BA2F00912D0410912E0498015F |
:10D1F000442737FD4095542FBC01CD010E949A9FD2 |
:10D2000097FF04C061507E4F8F4F9F4F59E0959517 |
:10D210008795779567955A95D1F7E61AF70A809121 |
:10D220003D0490913E04892B09F064C0101611064C |
:10D230000CF060C020910E0530910F05C90137FF39 |
:10D2400003C0309521953F4F2D33310540F4809137 |
:10D250005B0490915C048E159F0574F526C02C53D9 |
:10D26000304045E0369527954A95E1F72031310564 |
:10D2700010F02FE030E040915B0450915C041816F0 |
:10D280001906E4F480E190E0821B930B489F900123 |
:10D29000499F300D589F300D1124B4E036952795E5 |
:10D2A000BA95E1F72E153F0520F580918001909108 |
:10D2B0008101E816F906F4F07C011CC0205F3F4FA5 |
:10D2C0008091800190918101829FB001839F700DB8 |
:10D2D000929F700D11249B01A4E036952795AA9585 |
:10D2E000E1F74E155F0514F07A0104C0E216F3066B |
:10D2F00008F07901C701AA2797FDA095BA2FFDE094 |
:10D30000880F991FAA1FBB1FFA95D1F72091260AF3 |
:10D310003091270A442737FD4095542FBC01CD0199 |
:10D320000E940EA02093DD043093DE044093DF04BE |
:10D330005093E004E090DD04F090DE04809110054D |
:10D34000909111059C01220F331F280F391F2E0DBC |
:10D350003F1D37FF02C02D5F3F4FA90155954795EF |
:10D3600055954795509311054093100580914E08AF |
:10D37000282F3327220F331F220F331F241735077F |
:10D380006CF480915E0A282F3327220F331F220F5F |
:10D39000331F205530404217530724F030931105B6 |
:10D3A000209310058091390A80FF14C080911005E8 |
:10D3B00090911105A981BA818A179B0724F0B09337 |
:10D3C0001105A0931005E0911005F0911105FA8365 |
:10D3D000E98326C229813A81201B310B37FF02C025 |
:10D3E0002D5F3F4F3595279535952795E090100592 |
:10D3F000F0901105E20EF31EC1C1672B49F0E090D9 |
:10D400002D04F0902E0410920F0510920E0538C1D5 |
:10D410008091290390912A03A0912B03B0912C03B2 |
:10D42000821B930BA40BB50B8093D9049093DA0461 |
:10D43000A093DB04B093DC04823000E890070FEF88 |
:10D44000A0070FEFB0072CF481E090E8AFEFBFEF3B |
:10D4500009C08F5F9F47A040B04064F08FEF9FE707 |
:10D46000A0E0B0E08093D9049093DA04A093DB04A9 |
:10D47000B093DC048091D9049091DA0490930F0565 |
:10D4800080930E0580917B01282F33274427552751 |
:10D490008091D9049091DA04A091DB04B091DC046E |
:10D4A000BC01CD010E949A9F97FF04C0615E7F4F2F |
:10D4B0008F4F9F4F05E095958795779567950A95CE |
:10D4C000D1F76093D9047093DA048093DB049093CE |
:10D4D000DC04653028EF72072FEF82072FEF9207E9 |
:10D4E0002CF484E098EFAFEFBFEF09C060507840B4 |
:10D4F0008040904064F080E098E0A0E0B0E080934D |
:10D50000D9049093DA04A093DB04B093DC04609018 |
:10D51000D9047090DA0480917A01282F3327809102 |
:10D520003A0390913B03829FA001839F500D929FED |
:10D53000500D11249A0157FF02C021503F4F232F55 |
:10D54000330F330B8091330390913403820F931F79 |
:10D55000AA2797FDA095BA2F8093D9049093DA0457 |
:10D56000A093DB04B093DC048091370420913D0448 |
:10D5700030913E04882331F0B3E0220F331FBA9577 |
:10D58000E1F71BC0809152089927289FB001299F7D |
:10D59000700D389F700D11249B01A3E0220F331FE3 |
:10D5A000AA95E1F7260F371F37FF02C0215E3F4FD4 |
:10D5B000F5E035952795FA95E1F730930A04209325 |
:10D5C00009048091090490910A049C01442737FDC5 |
:10D5D0004095542F8091D9049091DA04A091DB04F6 |
:10D5E000B091DC04821B930BA40BB50B8093D90480 |
:10D5F0009093DA04A093DB04B093DC0420917C01C7 |
:10D60000332744275527BC01CD010E949A9F97FFDD |
:10D6100004C0615E7F4F8F4F9F4FE5E095958795E2 |
:10D6200077956795EA95D1F76093D9047093DA04FA |
:10D630008093DB049093DC046530A8EF7A07AFEFAA |
:10D640008A07AFEF9A072CF484E098EFAFEFBFEFB3 |
:10D6500009C0605078408040904064F080E098E0DD |
:10D66000A0E0B0E08093D9049093DA04A093DB04A7 |
:10D67000B093DC048091D9049091DA04680E791E8D |
:10D68000E618F70880915B0490915C048E159F0565 |
:10D690003CF48091800190918101E816F9060CF02C |
:10D6A0007C01C701AA2797FDA095BA2F5DE0880FDE |
:10D6B000991FAA1FBB1F5A95D1F72091260A3091B6 |
:10D6C000270A442737FD4095542FBC01CD010E9405 |
:10D6D0000EA02093DD043093DE044093DF045093CA |
:10D6E000E004E090DD04F090DE048091100590915C |
:10D6F00011059C01220F331F280F391F2E0D3F1DCE |
:10D7000037FF02C02D5F3F4FA901559547955595AD |
:10D710004795509311054093100580914E08282F8E |
:10D720003327220F331F220F331F241735076CF4C2 |
:10D7300080915E0A282F3327220F331F220F331FB9 |
:10D74000205530404217530724F0309311052093A1 |
:10D7500010058091390A209110053091110580FF44 |
:10D7600010C0E981FA812E173F0724F0F0931105CC |
:10D77000E0931005E0901005F0901105FA82E9821F |
:10D780004FC03A8329834CC080915608882301F505 |
:10D7900060912D0470912E0477FF02C06D5F7F4F62 |
:10D7A000759567957595679540912601509127016C |
:10D7B00080910201282F3327649FC001659F900D3F |
:10D7C000749F900D1124B9010E94D99FCB0101C013 |
:10D7D0009927909383018093820180918201909197 |
:10D7E0008301873491051CF486E490E005C08639F6 |
:10D7F000910534F086E990E0909383018093820153 |
:10D8000009811A811093110500931005809110046D |
:10D81000806C8093100480910F048D7F80930F049F |
:10D820008091100499279C012270307081FF39C1CA |
:10D830008091120590911305A0911405B0911505E2 |
:10D840000097A105B10521F0809147048130B9F41A |
:10D8500080912D0490912E04AA2797FDA095BA2FB0 |
:10D860001EE0880F991FAA1FBB1F1A95D1F780933E |
:10D87000120590931305A0931405B093150580919C |
:10D880004704813019F482E08093470429813A816A |
:10D8900079010027F7FC0095102F8091260A9091BE |
:10D8A000270A9C01442737FD4095542FC801B70132 |
:10D8B0000E949A9FDC01CB018093DD049093DE04EB |
:10D8C000A093DF04B093E004B7FF04C08150904EF2 |
:10D8D000AF4FBF4F7C018D01ADE015950795F794D3 |
:10D8E000E794AA95D1F7E092DD04F092DE0400936C |
:10D8F000DF041093E00460911104709112043FE082 |
:10D90000603A730750F58091120590911305A0912C |
:10D910001405B09115059C01AD01FAE056954795A7 |
:10D9200037952795FA95D1F7821B930BA40BB50B6E |
:10D93000A8019701E4E0220F331F441F551FEA9509 |
:10D94000D1F7820F931FA41FB51F809312059093E8 |
:10D950001305A0931405B093150560547F4118F585 |
:10D960008091120590911305A0911405B0911505B1 |
:10D970009C01AD016CE056954795379527956A95C2 |
:10D98000D1F7821B930BA40BB50BA8019701F2E012 |
:10D99000220F331F441F551FFA95D1F7820F931F93 |
:10D9A000A41FB51F41C0809133039091340380912F |
:10D9B00033039091340397FF03C0909581959F4F57 |
:10D9C00084369105CCF58091290390912A03A0918A |
:10D9D0002B03B0912C039C0180913F049091400453 |
:10D9E000281B390B37FF03C0309521953F4F2F3F40 |
:10D9F000310509F00CF58091120590911305A09165 |
:10DA00001405B09115059C01AD01EEE056954795C2 |
:10DA100037952795EA95D1F7821B930BA40BB50B8D |
:10DA20008E0D9F1DA01FB11F8093120590931305AB |
:10DA3000A0931405B09315058091120590911305DC |
:10DA4000A0911405B09115057EE0B695A795979520 |
:10DA500087957A95D1F790932E0480932D04409169 |
:10DA60005408442399F055279C01BA010E94D99F7C |
:10DA7000C901861B970B90935C0480935B04260F6F |
:10DA8000371F30938101209380011FC010925C04E6 |
:10DA900010925B048FEF93E090938101809380015B |
:10DAA00014C01092470410921205109213051092A0 |
:10DAB00014051092150530932E0420932D0405C0F3 |
:10DAC00080911004806C809310048091260581FF62 |
:10DAD00037C089819A8197FD03969595879595958D |
:10DAE000879520910D0430910E042817390760F4B2 |
:10DAF00080912D0490912E04892B31F0220F331F39 |
:10DB0000220F331F3A8329838091290390912A039E |
:10DB1000A0912B03B0912C0380933F049093400479 |
:10DB2000A0934104B093420488E99AE390931E03C2 |
:10DB300080931D0380E09EE090930C0180930B0185 |
:10DB4000A091210A8A2F9927880F991F880F991F62 |
:10DB5000889669817A818617970714F09A8389835A |
:10DB600020915E0A822F9927880F991F880F991F8D |
:10DB700080559040E981FA818E179F0714F49A83AB |
:10DB8000898380916B03882341F48091F10A8F3F50 |
:10DB900021F480912A05882319F180911104909134 |
:10DBA00012040297C097E0F4E980FA801E141F0463 |
:10DBB000BCF481E090E090931204809311040A2F4A |
:10DBC0001127000F111F000F111F085D1F4F1A832F |
:10DBD00009838091F10A883218F489E08093AC01BE |
:10DBE00049815A815093AA074093A9078091D5048F |
:10DBF0009091D604A091D704B091D80412E0880F78 |
:10DC0000991FAA1FBB1F1A95D1F700915F0A1091A7 |
:10DC1000600A081B190B413A51058CF0CA0157FDE7 |
:10DC2000019695958795801791070CF48C01909536 |
:10DC300081959F4F081719076CF48C010BC00135B3 |
:10DC4000110514F000E510E05FEF003B150714F438 |
:10DC500000EB1FEF3327220F331F220F331FC901A1 |
:10DC600069817A81861B970B801791070CF48C01D0 |
:10DC700089819A81821B930B081719070CF48C0178 |
:10DC800080911C0A90911D0A6091590470915A0468 |
:10DC9000861B970B90932C0A80932B0AD0903B0AFB |
:10DCA00020916B0430916C0440916D0450916E048E |
:10DCB000DD2041F0461A570AC201AA2797FDA09518 |
:10DCC000BA2F04C0AA2797FDA095BA2F280F391F95 |
:10DCD0004A1F5B1F20936B0430936C0440936D04C8 |
:10DCE00050936E0480916B0490916C04A0916D042C |
:10DCF000B0916E0481509A4FA040B04064F080E033 |
:10DD00009AEFA0E0B0E080936B0490936C04A09332 |
:10DD10006D04B0936E0480916B0490916C04A0919B |
:10DD20006D04B0916E0480509640AF4FBF4F64F4C5 |
:10DD300080E096E0AFEFBFEF80936B0490936C04AC |
:10DD4000A0936D04B0936E04C090630820912B0AD9 |
:10DD500030912C0A78E0E72EEC1498F08C2D99275E |
:10DD6000829FA001839F500D929F500D1124CA01E4 |
:10DD700057FD07967C0163E0F594E7946A95E1F717 |
:10DD800012C08C2D86959927829FB001839F700DBC |
:10DD9000929F700D1124CB0177FD03967C01F594C1 |
:10DDA000E794F594E794A0907D01B0907E019501F1 |
:10DDB000442737FD4095542F80916B0490916C045B |
:10DDC000A0916D04B0916E04BC01CD010E940EA023 |
:10DDD000E20EF31E90906701692D77278827992717 |
:10DDE000980117FF04C022273327201B310B37FF70 |
:10DDF00002C02F5F3F4F35952795A981BA812A0F21 |
:10DE00003B1F442737FD4095542F0E949A9F97FF50 |
:10DE100004C0615C7F4F8F4F9F4F26E0959587959B |
:10DE2000779567952A95D1F79B016E157F050CF4C0 |
:10DE30007B01309521953F4FE216F3060CF47901F2 |
:10DE400080910D0A90910E0A6091570470915804C8 |
:10DE5000861B970B90930C0A80930B0A2091670402 |
:10DE6000309168044091690450916A04DD2041F0CA |
:10DE7000261A370AC101AA2797FDA095BA2F04C018 |
:10DE8000AA2797FDA095BA2F280F391F4A1F5B1F9D |
:10DE900020936704309368044093690450936A04A4 |
:10DEA0008091670490916804A0916904B0916A041C |
:10DEB00081509A4FA040B04064F080E09AEFA0E01B |
:10DEC000B0E08093670490936804A0936904B093D2 |
:10DED0006A048091670490916804A0916904B091EC |
:10DEE0006A0480509640AF4FBF4F64F480E096E0E4 |
:10DEF000AFEFBFEF8093670490936804A093690429 |
:10DF0000B0936A0420910B0A30910C0A48E04C153A |
:10DF100098F08C2D9927829FB001839F700D929F5E |
:10DF2000700D1124CB0177FD07966C0193E0D59419 |
:10DF3000C7949A95E1F712C0C6948C2D9927829FB9 |
:10DF4000D001839FB00D929FB00D1124CD01B7FD7C |
:10DF500003966C01D594C794D594C7949501442732 |
:10DF600037FD4095542F8091670490916804A091EB |
:10DF70006904B0916A04BC01CD010E940EA0C20EDA |
:10DF8000D31E692D772788279927980117FF04C08A |
:10DF900022273327201B310B37FF02C02F5F3F4F53 |
:10DFA00035952795E981FA812E0F3F1F442737FDCC |
:10DFB0004095542F0E949A9F97FF04C0615C7F4F49 |
:10DFC0008F4F9F4FA6E09595879577956795AA9572 |
:10DFD000D1F79B016C157D050CF46B0130952195F3 |
:10DFE0003F4FC216D3060CF4690180911C038823AD |
:10DFF00011F40E9480718091210A282F33273E8BD3 |
:10E000002D8B80915E0A282E33245090A508F7E1CD |
:10E01000AF2EF9E0BF2EEEEC8E2EE8E09E2E7BE0D8 |
:10E02000472E6CE3662E6AE0762ED4012C911216F0 |
:10E030000CF02FC1203429F4E981FA81F88FEF8B9D |
:10E040001FC049815A81CA01AA2797FDA095BA2FFE |
:10E05000332727FD3095432F532FBC01CD010E945C |
:10E060009A9F97FF04C0615C7F4F8F4F9F4F56E090 |
:10E0700095958795779567955A95D1F7788F6F8B9A |
:10E08000F4012181203439F42F89388D2E0D3F1D64 |
:10E09000388F2F8B2AC0203C39F44F89588D4E1968 |
:10E0A0005F09588F4F8B21C0C701AA2797FDA09504 |
:10E0B000BA2F332727FD3095432F532FBC01CD01B5 |
:10E0C0000E949A9F97FF04C0615C7F4F8F4F9F4FC4 |
:10E0D00046E095958795779567954A95D1F7AF89ED |
:10E0E000B88DA60FB71FB88FAF8BF40122812034F3 |
:10E0F00039F42F89388D2C0D3D1D388F2F8B2AC078 |
:10E10000203C39F44F89588D4C195D09588F4F8B3D |
:10E1100021C0C601AA2797FDA095BA2F332727FD56 |
:10E120003095432F532FBC01CD010E949A9F97FF3A |
:10E1300004C0615C7F4F8F4F9F4F36E09595879568 |
:10E14000779567953A95D1F7AF89B88DA60FB71F28 |
:10E15000B88FAF8BF4012381203439F42F89388DA7 |
:10E16000200F311F388F2F8B2AC0203C39F44F8964 |
:10E17000588D401B510B588F4F8B21C0C801AA27C7 |
:10E1800097FDA095BA2F332727FD3095432F532FA6 |
:10E19000BC01CD010E949A9F97FF04C0615C7F4F34 |
:10E1A0008F4F9F4F26E095958795779567952A9590 |
:10E1B000D1F7AF89B88DA60FB71FB88FAF8BF50118 |
:10E1C000808181FD08C0D3018D919C91EF89F88DEC |
:10E1D0008E179F0774F4D3018D919C91EF89F88D70 |
:10E1E0008E0F9F1F97FD019695958795988F8F8B22 |
:10E1F0001EC0552049F42F89388D220F331F281B4C |
:10E20000390B388F2F8B13C031E0351580F4252D55 |
:10E2100033274F89588D841B950BB9010E94D99FD4 |
:10E22000CB016F89788D680F791F788F6F8B8D89FF |
:10E230009E89880F991F880F991FAF89B88D8A17FB |
:10E240009B0754F4C101880F991F880F991FEF890C |
:10E25000F88DE817F90714F0988F8F8B8F89988DB8 |
:10E2600097FD03969595879595958795F5018183FB |
:10E27000880F991F880F991F2F89388D281B390BFC |
:10E28000C901880F8283EF89F88DD301ED93FC9348 |
:10E2900003C0F501118212824A9422E030E0620E3E |
:10E2A000731E44E050E0840E951E68E070E0A60EF8 |
:10E2B000B71E47FEBACEE2E1C85E0C9445A084B119 |
:10E2C000806A84B93D9A82E58CBD1DBC459A81E087 |
:10E2D0008093700A8AEA8093810A83E88093820A95 |
:10E2E0008AE08093830A1092850A1092840A109221 |
:10E2F000870A1092860A1092E90A1092A50A0895D8 |
:10E300003091700A332309F070C00DB407FE6DC060 |
:10E3100083E080931C03459A2EB580912D059927A3 |
:10E320008130910589F0823091051CF4892B21F010 |
:10E330003EC00297B9F03BC03093A40A20932E054B |
:10E340002138A9F581E008C0253549F480912E05D2 |
:10E35000820F80932E0582E080932D0528C0309394 |
:10E360002D0525C08091A40AE82FFF27EA53F54F19 |
:10E3700020838F5F8093A40A90912E058032A0F0B5 |
:10E38000291769F480E2A6ECBAE0E6EAFAE00D901B |
:10E3900001928A95E1F781E08093A50A02C030934B |
:10E3A000A50A10922D0503C0920F90932E0520917F |
:10E3B000800A2232A0F4459800000000000000000E |
:10E3C000E091790AF0917A0AE20FF11D80818EBD09 |
:10E3D0008091A20A9081890F8093A20A03C081E0F4 |
:10E3E0008093700A2F5F2093800A0895EF92FF9226 |
:10E3F0000F931F9380915C089927880F991F880FAE |
:10E40000991F7C010027F7FC0095102F8091A30431 |
:10E410009091A404A091A504B091A604BC01CD01E3 |
:10E42000A80197010E940EA03093850A2093840AC8 |
:10E4300080919B0490919C04A0919D04B0919E04B6 |
:10E44000BC01CD01A80197010E940EA03093870A5C |
:10E450002093860A2091660A3091670A4091680AE3 |
:10E460005091690ADA01C90173E0880F991FAA1F48 |
:10E47000BB1F7A95D1F7820F931FA41FB51F820F80 |
:10E48000931FA41FB51F2091420130914301409179 |
:10E49000440150914501BC01CD010E940EA0309372 |
:10E4A0008D0A20938C0A8091B5049091B604209136 |
:10E4B000400330914103821B930B9093930A809306 |
:10E4C000920AE091AB04F091AC048091320A9091F1 |
:10E4D000330ABF010E94D99FCB019B01220F331F3A |
:10E4E000220F331F280F391F280F391F37FF02C093 |
:10E4F0002D5F3F4F35952795359527953093890AA0 |
:10E500002093880A8091620A9091630ABF010E9459 |
:10E51000D99F9B01220F331F220F331F260F371F56 |
:10E52000260F371F37FF02C02D5F3F4F35952795C8 |
:10E530003595279530938B0A20938A0A1092AC0464 |
:10E540001092AB041092330A1092320A1092630AAE |
:10E550001092620A8091830A9927AA27BB27FC019F |
:10E560003A97E830F10508F031C2EF57FF4F0C94AD |
:10E5700060A0809125048093960A80912404809362 |
:10E58000970A809123048093980A809122048093B3 |
:10E59000990A8091210480939A0A809120048093A3 |
:10E5A0009B0A80911F0480939C0A80911E04809393 |
:10E5B0009D0A8091100480939E0A80911004837FAD |
:10E5C000809310048091010180939F0A809126011D |
:10E5D000909127018093A00A80910F048093A10A53 |
:10E5E0004299F4C180910F04877F80930F04EEC19C |
:10E5F0008091EB0A9091EC0A9093970A8093960A87 |
:10E600008091EF0A9091F00A9093990A8093980A6A |
:10E61000809191080E947A4880939A0A80914101E2 |
:10E6200080939B0A90912F0590939C0AE92FFF27D6 |
:10E6300013E0EE0FFF1F1A95E1F7E95EF64F8081B8 |
:10E6400080939D0A868180939E0A838180939F0A8E |
:10E6500087818093A00A85818093A10A9F5F909310 |
:10E660002F05E92FFF27EE0FFF1FEE0FFF1FEF53C0 |
:10E67000F74F858518160CF4A9C1992309F4A6C192 |
:10E68000892F992701966DE070E00E94D99F9C0127 |
:10E69000982FE82FFF27EE0FFF1FEE0FFF1FEF53FE |
:10E6A000F74F8585181614F0222351F720932F0574 |
:10E6B0008DC1809102018093960A80919208809387 |
:10E6C000970A809193088093980A80919408809388 |
:10E6D000990A8091950880939A0A8091990880936D |
:10E6E0009B0A80919A0880939C0A80919B08809352 |
:10E6F0009D0A80919E0880939E0A80919C08809339 |
:10E700009F0A80919D088093A00A80919F085CC118 |
:10E71000809190088093960A80916708863081F0F6 |
:10E720008091E802823451F00E94F77EE82FFF27A3 |
:10E73000ED51FE4E84918093E80202C00E94F77E64 |
:10E74000809153058093970A8091AD088093980A31 |
:10E750008091A6088093990A39C1F8948091430862 |
:10E76000E82FFF27EE0FFF1FE858F64F0190F081CA |
:10E77000E02DE038F1051CF0EFE7F0E006C02FEFE8 |
:10E78000E138F20714F4E1E8FFEFE093960A809194 |
:10E790004408E82FFF27EE0FFF1FE858F64F0190BF |
:10E7A000F081E02DE038F1051CF0EFE7F0E006C065 |
:10E7B0007FEFE138F70714F4E1E8FFEFE093970A01 |
:10E7C00080914208E82FFF27EE0FFF1FE858F64F11 |
:10E7D0000190F081E02DE038F1051CF0EFE7F0E06A |
:10E7E00006C08FEFE138F80714F4E1E8FFEFE0939B |
:10E7F000980A80914108E82FFF27EE0FFF1FE85885 |
:10E80000F64F0190F081E02DE038F1051CF0EFE7C4 |
:10E81000F0E006C02FEFE138F20714F4E1E8FFEF73 |
:10E820007894E093990A80914A0480939A0A80919F |
:10E830004B0480939B0A80914C0480939C0A8091A6 |
:10E840004D0480939D0A80914E0480939E0A80918E |
:10E850004F0480939F0A809150048093A00A809176 |
:10E860005104B2C08091D005863018F01092D005C6 |
:10E8700085E08093960A8091A0088093970A809102 |
:10E88000430490914404A0914504B0914604BC0116 |
:10E89000CD0125E030E040E050E00E940EA0309332 |
:10E8A000990A2093980A80913F0490914004A09186 |
:10E8B0004104B0914204BC01CD0125E030E040E0CC |
:10E8C00050E00E940EA030939B0A20939A0A8091F8 |
:10E8D000960880939C0A8091970880939D0A809166 |
:10E8E000980880939E0A8091490480939F0A8091A2 |
:10E8F00030058093A00A8091A9079091AA0797FDFF |
:10E90000039695958795959587955EC082E080934F |
:10E91000960A8093970A81E08093980A89E380930E |
:10E92000990A8091030180939A0A8091B50580939A |
:10E930009B0A9091B60590939C0A8F778093B505BA |
:10E9400090719093B6058091AE0880939D0A809156 |
:10E95000560A80939E0A8091390A80939F0A80917B |
:10E96000A2088093A00A8091B3082EC080917508F8 |
:10E970008093960A8091B1088093970A80916F01E5 |
:10E980008093980A80916E088093990A80916F080D |
:10E9900080939A0A8091700880939B0A80916E01FF |
:10E9A00080939C0A8091720880939D0A80917308DD |
:10E9B00080939E0A8091740880939F0A8091F10A47 |
:10E9C0008093A00A8091D3078093A10A8091A50A21 |
:10E9D000882309F479C16091A60A8091A60168177D |
:10E9E00019F08AEF8093A4016093A60181E08093DF |
:10E9F0008F014091A70A5091A80ACA0181509E4FE9 |
:10EA00008F5F9340B0F42091A90A3091AA0AC901FE |
:10EA100081509E4F8F5F934060F480914D0885FF39 |
:10EA200008C050931C0540931B0530931A05209392 |
:10EA300019058091AD0A9091AE0A21E089369207BE |
:10EA400024F490939101809390012091B70A309122 |
:10EA5000B80A80911D0390911E038217930740F41A |
:10EA60008091F002882321F430931E0320931D032C |
:10EA7000862F99278936910509F4A5C08A36910514 |
:10EA800044F48736910571F08836910509F462C027 |
:10EA900023C18A36910509F414C18B36910509F416 |
:10EAA000E2C01AC18091B90A8093E60A8091BA0A3D |
:10EAB0008093E80A8091BB0A8093E70A8091BC0AA0 |
:10EAC00080938E018091BD0A8093EA0A8091BE0AEC |
:10EAD0008093A5018091BF0A80932C058091C00A84 |
:10EAE0008093180580911D048823F9F02091C10AB4 |
:10EAF0003091C20A37FD19C030936204209361043B |
:10EB000090917708992389F08FE0989FC001112494 |
:10EB1000281B390BC90188599E4F68E671E00E9495 |
:10EB2000D99F9093620480936104209123053091D2 |
:10EB300024058091C30A9091C40A280F391F37FF1A |
:10EB400002C02F5F3F4F35952795309324052093C2 |
:10EB50002305C2C08091B90A80937B0A8091BA0ACA |
:10EB600080937C0A8091BB0A80937D0A8091BC0AC5 |
:10EB700080937E0A8091BD0A80937F0A80919907D5 |
:10EB80009091BE0A892B8093990790919A07937070 |
:10EB90008091BF0A8C70982B90939A078091C00A3D |
:10EBA00080932A058091C10A809396018091C20AC0 |
:10EBB0008093E90A8091C30A809326058091C40A54 |
:10EBC0008093250589C08091B90A8093710A80914C |
:10EBD000BA0A8093720A8091BB0A8093730A80916B |
:10EBE000BC0A8093740A8091BD0A9091BE0A9093EA |
:10EBF000760A8093750A8091BF0A9091C00A90931B |
:10EC0000780A8093770A8091C10A992787FD9095A9 |
:10EC10009093B3098093B2098091C20A809338041B |
:10EC20008091C30A9091C40A9C01442737FD409506 |
:10EC3000542FDA01C90163E0880F991FAA1FBB1F77 |
:10EC40006A95D1F7820F931FA41FB51F820F931FE0 |
:10EC5000A41FB51F8093390490933A04A0933B04FA |
:10EC6000B0933C0439C08091B90A80932905809102 |
:10EC7000BA0A809328058091BB0A8093270590915A |
:10EC8000BC0A992349F08091AC01882319F0815185 |
:10EC9000833010F49093AC018091BD0A80935B05A2 |
:10ECA0008091BE0A80935A058091BF0A9091C00A54 |
:10ECB00090935805809357058091C10A8093590518 |
:10ECC0000BC00E945E7F08C010921C0510921B05AD |
:10ECD00010921A05109219051F910F91FF90EF9055 |
:10ECE00008958091700A882319F480E090E00895D7 |
:10ECF000459881E89AE090937A0A8093790A9091F6 |
:10ED00002B05E92FFF27E956FE4F9F5F90932B05B8 |
:10ED100080818093830A9D3010F010922B05109211 |
:10ED2000700A0E94F67181E08093800A8091810AC6 |
:10ED30008093A20A8EBD81E090E0089587B18C6037 |
:10ED400087B9429843981092320580E88093A801D1 |
:10ED5000109231058093A70108958091B209909196 |
:10ED6000B30981589F4F39F08091B2099091B3094E |
:10ED7000815880933C0580913705815080933705F9 |
:10ED80008F3F09F052C180918A08809338058091A5 |
:10ED90008C088093390589E08093370580911004B1 |
:10EDA000992780739070892B21F48091B60580FF9C |
:10EDB0001DC080918E08882351F080913A058823E8 |
:10EDC00019F484E08093320581E080933A058091C4 |
:10EDD0008F08882379F080913B05882319F484E01B |
:10EDE0008093310581E080933B0504C010923A0581 |
:10EDF00010923B0580913A05882309F082C08091EA |
:10EE0000B008282F332724FF07C0809148048823A7 |
:10EE100019F425FD8FC090C090918B08983F48F061 |
:10EE20008091340A8D3D28F08091380588236CF05C |
:10EE30000AC0983F78F08091340A853059F4809167 |
:10EE4000380587FF02C0429A01C0429881E0809352 |
:10EE5000A80154C0809132058150809332058F3FC4 |
:10EE600009F06BC08091B30885FF2FC090913C05DD |
:10EE7000892F869580933205992361F4909330050C |
:10EE80008091380587FF02C0429A01C042981092D3 |
:10EE9000A80153C081E0809330058091A801909132 |
:10EEA0003805882349F480933C0580E48093A801C9 |
:10EEB00099230CF43FC040C0982311F0429A01C03E |
:10EEC000429886958093A80138C08091340A86952F |
:10EED000809332058091A801813021F410923C0585 |
:10EEE00080E401C086958093A8018091A80190914B |
:10EEF0003805892311F0429A01C0429810923005DA |
:10EF00001CC0809132058150809332058F3FA9F457 |
:10EF100089E0809332058091A801813011F480E866 |
:10EF200001C086958093A8018091A80190918E08D8 |
:10EF3000892311F0429A01C0429880913B058823B1 |
:10EF400009F043C09091B00897FF07C08091480432 |
:10EF5000882319F496FD52C053C090918D08983FB4 |
:10EF600048F080915D0A8D3D28F080913905882315 |
:10EF70006CF00AC0983F78F080915D0A853059F4B2 |
:10EF80008091390587FF02C0439A01C0439881E010 |
:10EF90008093A70136C0809131058150809331055F |
:10EFA0008F3F79F580915D0A869580933105809138 |
:10EFB000A701813011F480E401C086958093A701F8 |
:10EFC0008091A7019091390517C08091310581503A |
:10EFD000809331058F3FA9F489E0809331058091BA |
:10EFE000A701813011F480E801C086958093A701C4 |
:10EFF0008091A70190918F08892311F0439A01C055 |
:10F000004398429B05C080910F04886080930F0451 |
:10F01000439B06C080910F04806180930F04089584 |
:10F0200080910F048F7E80930F0408954FB724E1E1 |
:10F0300030E0F8948091C9008F778093C900809167 |
:10F04000C9008F7B8093C9008091C9008F7D809318 |
:10F05000C900832F99278093CD002093CC00809105 |
:10F06000C80082608093C80080E18093C9008091CD |
:10F07000CA008F778093CA008091CA008F7B8093EB |
:10F08000CA008091CA008F7D8093CA008091CA0017 |
:10F090008F7E8093CA008091CA00877F8093CA00C8 |
:10F0A0008091C9008B7F8093C9008091CA008460E1 |
:10F0B0008093CA008091CA0082608093CA008091C8 |
:10F0C000C80087FF03C08091CE00F9CF8091C900AE |
:10F0D00080688093C9004FBF0895EF92FF920F930D |
:10F0E0001F93CF93DF93482F00E010E08091A90198 |
:10F0F000813061F41092A90184E480933D0510925F |
:10F100003F0510923E051092400539C180913D05A2 |
:10F11000882319F421E030E001C0980190913E0568 |
:10F12000992371F4232B11F081E010C084E48093C3 |
:10F130003D0590933F0590933E059093400508C18F |
:10F14000913069F4232B09F0F9C082E080933E05E9 |
:10F1500080913F058F5F80933F0583E0F7C0923039 |
:10F16000D1F4232B09F0EAC083E080933D0540935E |
:10F17000400590913F05923039F41092410547FFC8 |
:10F1800003C081E08093410583E080933E059F5F4B |
:10F1900090933F05DDC0933009F0D0C0232B09F0D8 |
:10F1A000CDC090933D0582E080933E0580913F0560 |
:10F1B0008F5F80933F0520914005822F9927782FFC |
:10F1C0006627842F9927682B792B809167088130D7 |
:10F1D00049F47370CB018050924063E070E00E946C |
:10F1E000D99F17C0823061F47770CB018050944072 |
:10F1F00066E070E00E94D99F2695269526950BC063 |
:10F20000737068567140CB0177FD0196BC0175950E |
:10F21000679526952695022F11270F7010700F5FA6 |
:10F220001F4F0D30110508F082C07801E00EF11E6D |
:10F23000F701E858F64F808191819B01281B390B1B |
:10F24000C90137FF03C0909581959F4F069704F53C |
:10F25000E091A908EE2351F0FF27EE0FFF1FE858B9 |
:10F26000F64F808191818436910594F48091490410 |
:10F27000883C30F480914904865F8093490408C03B |
:10F2800088EC8093490480916F008F7D80936F009C |
:10F29000F701E858F64F808191819C01220F331FBE |
:10F2A000280F391F260F371F37FF02C02D5F3F4F32 |
:10F2B000E901D595C795D595C795CB0101968C17D2 |
:10F2C0009D0714F4219706C061507040C617D707F8 |
:10F2D0000CF4219680914904843BD0F0F701E85862 |
:10F2E000F64F80819181FE01E81BF90BCF0163E0AD |
:10F2F00070E00E94D99FCB01880F991F860F971F3E |
:10F300002EEB39E0E20EF31EF7019183808307C0F4 |
:10F310002EEB39E0E20EF31EF70111821082000F8E |
:10F32000111F0858164FF801D183C08311C0023154 |
:10F33000110570F081E08093A9010AC081E08093FB |
:10F34000A90110923F051092410584E480933D0588 |
:10F3500080913F05803198F080914105882331F4F8 |
:10F360008091A901882311F48093400110923F05F8 |
:10F370001092410510923E0584E480933D05E6E03D |
:10F38000CDB7DEB70C9451A0CF93FC0197FF05C019 |
:10F39000CFEFF095E195FF4F01C0C1E028E631E0E5 |
:10F3A000CF01B9010E94D99FFC018B35910554F022 |
:10F3B0008B5590408A35910538F484EB90E08E1B94 |
:10F3C0009F0BFC0141E00DC0CF01855B90408A3569 |
:10F3D000910518F4E45BF04003C02E1B3F0BF901CC |
:10F3E0004FEFEE0FFF1FED5CF64F259134918C2F00 |
:10F3F000992787FD9095289FB001299F700D389F10 |
:10F40000700D1124842F992787FD9095689FA00186 |
:10F41000699F500D789F500D1124CA01CF91089516 |
:10F420002AE530E0281B390BC9010E94C4790895F0 |
:10F43000CF93DF9380E00E94CB9180912601909141 |
:10F4400027016AE070E00E94D99F9F938F9380917B |
:10F450002601909127016AE070E00E94D99F7F9376 |
:10F460006F9387E09AE09F938F93CEEBD1E9DF9380 |
:10F47000CF93E0919C05F0919D0509952DB73EB77E |
:10F48000285F3F4F2DBF8091A401882361F186E062 |
:10F490000E94CB918091960199279F938F938091A1 |
:10F4A000750A9091760A6AE070E00E94C59F7F938A |
:10F4B0006F938FED90E09F938F938091120A9091BC |
:10F4C000130A9F938F9380E19AE09F938F93DF932A |
:10F4D000CF93E0919C05F0919D0509958DB79EB75E |
:10F4E0000C968DBF12C086E00E94CB918EE19AE00F |
:10F4F0009F938F93DF93CF93E0919C05F0919D05AF |
:10F5000009950F900F900F900F9080912A058823F6 |
:10F5100009F452C080914205909143050E94791AE6 |
:10F52000882391F08091AA01882319F01092AA01F2 |
:10F5300003C081E08093AA018CED95E00E94701ACF |
:10F5400090934305809342058091AA018823E1F0BE |
:10F5500080E00E94CB911F921F9290912A0581E139 |
:10F56000989FC0011124825B944F9F938F93DF93E8 |
:10F57000CF93E0919C05F0919D0509952DB73EB77D |
:10F580002A5F3F4F2DBF3BC086E00E94CB91809108 |
:10F590002A0599279F938F9385E29AE09F938F93F3 |
:10F5A000DF93CF93E0919C05F0919D0509958DB770 |
:10F5B0009EB706968DBF23C0809152058823F9F02F |
:10F5C0000E94D19180E10E94CB9184EB98E09F93BF |
:10F5D0008F938091010199279F938F9381E39AE004 |
:10F5E0009F938F93DF93CF93E0919C05F0919D05BE |
:10F5F00009952DB73EB7285F3F4F2DBF5CC080E116 |
:10F600000E94CB918091EA029091EB026CE370E052 |
:10F610000E94C59F9F938F938091EA029091EB0285 |
:10F620006CE370E00E94C59F7F936F938091EF0A17 |
:10F630009091F00A9F938F938CE39AE09F938F931E |
:10F64000CEEBD1E9DF93CF93E0919C05F0919D053E |
:10F6500009958091560A2DB73EB7265F3F4F2DBFC3 |
:10F6600080FF29C08AE10E94CB91809141019927B6 |
:10F670009F938F938091430490914404A0914504FB |
:10F68000B0914604BC01CD0124E630E040E050E0FA |
:10F690000E940EA03F932F9389E49AE09F938F934B |
:10F6A000DF93CF93E0919C05F0919D0509958DB76F |
:10F6B0009EB708968DBFDF91CF910895CF93DF93CA |
:10F6C00080E00E94CB9180913609992787FD909523 |
:10F6D0009F938F9380912E09992787FD90959F93F3 |
:10F6E0008F9380912609992787FD90959F938F93FB |
:10F6F00080911E09992787FD90959F938F9380E5B0 |
:10F700009AE09F938F93CEEBD1E9DF93CF93E09173 |
:10F710009C05F0919D05099580E10E94CB912DB744 |
:10F720003EB7245F3F4F2DBF80915609992787FD33 |
:10F7300090959F938F9380914E09992787FD90957F |
:10F740009F938F9380914609992787FD90959F936A |
:10F750008F9380913E09992787FD90959F938F9372 |
:10F7600080E69AE09F938F93DF93CF93E0919C057F |
:10F77000F0919D05099580913F082DB73EB7245F14 |
:10F780003F4F2DBF853098F480E10E94CB9180E7F8 |
:10F790009AE09F938F93DF93CF93E0919C05F09134 |
:10F7A0009D0509950F900F900F900F9018C087300E |
:10F7B000B0F488E10E94CB918FED90E09F938F93FE |
:10F7C00081E89AE09F938F93DF93CF93E0919C051C |
:10F7D000F0919D0509958DB79EB706968DBFDF9177 |
:10F7E000CF9108950F931F9380E00E94CB912AE060 |
:10F7F00030E08091EB0A9091EC0AB9010E94C59F1C |
:10F800009F938F938091EB0A9091EC0AB9010E942B |
:10F81000C59F7F936F938091260190912701B90135 |
:10F820000E94D99F9F938F938091260190912701E9 |
:10F83000B9010E94D99F7F936F938AE89AE09F93C2 |
:10F840008F930EEB11E91F930F93E0919C05F091BC |
:10F850009D05099580E10E94CB918DB79EB70C96CE |
:10F860008DBF8091EF0A9091F00A9F938F938091C2 |
:10F87000ED0A9091EE0A9F938F938CE99AE09F9303 |
:10F880008F931F930F93E0919C05F0919D0509952F |
:10F890008DB79EB708968DBF1F910F910895EF9277 |
:10F8A000FF920F931F9380E00E94CB918FEDE82E83 |
:10F8B000F12CFF92EF9280919001909191019F9392 |
:10F8C0008F938091290599279F938F9388EA9AE0D7 |
:10F8D0009F938F930EEB11E91F930F93E0919C057B |
:10F8E000F0919D05099580E10E94CB918DB79EB75F |
:10F8F0000A968DBF8091270599279F938F93FF923A |
:10F90000EF928091280599279F938F938BEB9AE034 |
:10F910009F938F931F930F93E0919C05F0919D050A |
:10F9200009958DB79EB70A968DBF1F910F91FF90D5 |
:10F93000EF9008950F931F93CF93DF938091A401CD |
:10F94000CEEBD1E9882309F47DC080E00E94CB9101 |
:10F950008091720A99279F938F938091740A9927B7 |
:10F960009F938F938EEC9AE09F938F938E01DF93FA |
:10F97000CF93E0919C05F0919D0509958DB79EB7B9 |
:10F9800008968DBF8091730A833031F48CE00E9419 |
:10F99000CB918DED9AE005C08CE00E94CB9182EE78 |
:10F9A0009AE09F938F93DF93CF93E0919C05F09122 |
:10F9B0009D0509950F900F900F900F908091710AFF |
:10F9C00081FF12C08CE00E94CB9187EE9AE09F935A |
:10F9D0008F931F930F93E0919C05F0919D050995DE |
:10F9E0000F900F900F900F9080E10E94CB9180912B |
:10F9F000960199279F938F938FED90E09F938F931C |
:10FA00008091770A9091780A9F938F938091750ADD |
:10FA10009091760A6AE070E00E94C59F7F936F9391 |
:10FA20008CEE9AE09F938F938EEB91E99F938F9347 |
:10FA3000E0919C05F0919D0509958DB79EB70C96B8 |
:10FA40008DBF12C082E00E94CB918FEF9AE09F930E |
:10FA50008F93DF93CF93E0919C05F0919D050995DD |
:10FA60000F900F900F900F90DF91CF911F910F91FA |
:10FA70000895CF93C82F20914405209345059927D9 |
:10FA80008F329105E1F0803391051CF44F9779F0A6 |
:10FA900027C08F349105D9F08F38910509F586E09C |
:10FAA000289FF0011124E751F64F849117C086E09A |
:10FAB000289FF0011124E651F64F84910FC086E093 |
:10FAC000289FF0011124E551F64F849107C086E08C |
:10FAD000289FF0011124E451F64F8491809344054E |
:10FAE00090914405809145059813C0E08091AB0149 |
:10FAF000282F33278F5F8093AB0120FF0FC00E9418 |
:10FB0000D1919091440586E0989FF0011124E35132 |
:10FB1000F64F259134918C2FF901099580E090E002 |
:10FB2000CF9108951092EC0A1092EB0A1092F00A0D |
:10FB30001092EF0A1092EE0A1092ED0A1092F10A5A |
:10FB400082E390E00E94701A9093470580934605E7 |
:10FB50000895E82FFF2783E0EE0FFF1F8A95E1F756 |
:10FB6000E95EF64F9581993C18F4892F99270895FD |
:10FB7000808182FF07C08AE0989FC00111248850CD |
:10FB800097400895892F99270895A0E0B0E0EBEC05 |
:10FB9000FDE70C9432A080914605909147050E94A4 |
:10FBA000791A882309F4C0C08091460590914705D1 |
:10FBB000C2969093470580934605C0E0D0E07E0151 |
:10FBC000BB247FEFC72EDB2C07E119E0F80183810E |
:10FBD00087FF14C0B3948581893C30F08D2D0E943D |
:10FBE000A97DC80FD91F02C0C80FD11DF80181819E |
:10FBF000E80EF11C86818C1508F4C82ED394085F9A |
:10FC00001F4FFBE0FD1510F7C092F10AEF2841F5F8 |
:10FC100020914C0530914D0540914E0550914F0576 |
:10FC2000BB27A52F942F832F90934B0580934A05D4 |
:10FC3000AA27BB27281B390B4A0B5B0BCE01AA272F |
:10FC4000BB27280F391F4A1F5B1F20934C05309399 |
:10FC50004D0540934E0550934F05C5E0D0E013C0CD |
:10FC600080914A0590914B058C179D0718F4C81B8D |
:10FC7000D90B02C0C0E0D0E08B2D9927880F991FC7 |
:10FC8000C80FD91F2596D093EC0AC093EB0ACF3F3B |
:10FC9000D10578F480912601909127018C9F9001E5 |
:10FCA0008D9F300D9C9F300D1124C90164E670E0DA |
:10FCB00013C0CE019695879596958795209126013C |
:10FCC00030912701289FA001299F500D389F500D8A |
:10FCD0001124CA0169E170E00E94C59F7093EE0A89 |
:10FCE0006093ED0A80914805909149058C0F9D1F06 |
:10FCF000909349058093480552E0813D9507A0F017 |
:10FD00002091EF0A3091F00A2F5F3F4F805D9240C3 |
:10FD1000E2E0813D9E07C0F7909349058093480536 |
:10FD20003093F00A2093EF0AE9E0CDB7DEB70C94E8 |
:10FD30004EA030915C05E32FFF2783E0EE0FFF1FFD |
:10FD40008A95E1F7E95EF64F2781422F552747FD57 |
:10FD5000509580915D059927841795072CF4209381 |
:10FD60005D0530935F050AC0222341F080915E0556 |
:10FD700099274817590714F420935E05832F8F5F46 |
:10FD800080935C058C30D0F010925C0580915E050C |
:10FD90008F3F19F08093550502C010925505809150 |
:10FDA0005D058093560580915F05809354058FEF24 |
:10FDB00080935E0510925D0510925F05089595E1B0 |
:10FDC000899F802D11240E94979788EC9DE09F9336 |
:10FDD0008F9389E697E99F938F93E0919C05F0912B |
:10FDE0009D0509950F900F900F900F900895CF9358 |
:10FDF000C0E04091AC01409353058091100485FF11 |
:10FE00000CC080910704882331F080916708863008 |
:10FE100011F4CEE029C0C0E127C080912A058823D3 |
:10FE2000D1F0282F3327C90101968197A4F480913E |
:10FE30004804882341F4F901E20FF31FE35FF44F14 |
:10FE40008491882341F4220F331F245F344FF9013A |
:10FE5000C491CC2349F48091B30886FD03C010926D |
:10FE6000AC0104C0C42F02C0C0935305809160054B |
:10FE70008C1771F480916105909162050E94791A46 |
:10FE8000882319F480E090E017C080EA9FE002C068 |
:10FE900080ED97E00E94701A90936205809361054F |
:10FEA000CC2331F08091AC01C81711F41092AC0151 |
:10FEB000C09360058C2F9927CF91089520E030E002 |
:10FEC00050E08091C40A992789389105B9F08A38A1 |
:10FED000910534F481309105F1F00297F9F021C0D9 |
:10FEE0008D389105A1F08E38910524F48A3891055A |
:10FEF00041F017C08E38910539F013C02AE43BE079 |
:10FF000008C022E23CE005C022EF3AE002C02EE148 |
:10FF10003BE05CE206C025EC32E002C028ED32E0B6 |
:10FF200054E09091B90A40E08091BA0A481770F401 |
:10FF3000951760F4D901A90FB11DE42FFF27EA55E9 |
:10FF4000F54F85898C939F5F4F5FEECF089520E337 |
:10FF500035E7809141018B3211F08D32F9F48091B7 |
:10FF60005208282F332780913D0490913E04829FB0 |
:10FF7000A001839F500D929F500D1124CA0163E090 |
:10FF800070E00E94D99FCB019B01205D3A48C19649 |
:10FF9000C19708F03FC02EEF34E73CC0803229F50E |
:10FFA0008091100481FF36C0209150053091510599 |
:10FFB000205D3A4855E72133350748F085E7243975 |
:10FFC000380718F420E335E702C02456304045E7EF |
:10FFD00020333407F8F454E72D3C350718F020E3BC |
:10FFE00035E718C02C593F4F15C08E3549F4909114 |
:10FFF00038048AE0989F90011124205D3A480AC095 |
:020000021000EC |
:10000000863741F4909138048AE0989FC00111240A |
:10001000281B390BC90108951F9399278A38910528 |
:1000200009F4A5C18B38910524F48938910551F064 |
:100030005EC38D38910509F491C28E38910509F49B |
:10004000EAC155C30E94F77E182F8093240C80913B |
:10005000430490914404A0914504B0914604BC012E |
:10006000CD0124E630E040E050E00E940EA0DA012D |
:10007000C9018C509E4F9093500B80934F0B1123CE |
:1000800019F40E94A77F02C080E395E79093560B76 |
:100090008093550B8091550B9091560B9093580B74 |
:1000A0008093570B90935A0B8093590B20914F0BD1 |
:1000B0003091500B8091530B9091540B28173907B6 |
:1000C00024F43093540B2093530B8091510B909157 |
:1000D000520B8217930724F43093520B2093510B49 |
:1000E00010924C0B8AE49BE0909374058093730507 |
:1000F000809141018093700B80910F0480FF02C0BA |
:1001000083E401C080E28093710B20912A052223B1 |
:1001100011F1822F6AE00E94B99F805D80935B0B92 |
:10012000822F0E94B99F892F805D80935C0B8AE3A8 |
:1001300080935D0B81E1289FF0011124AEE5BBE0C7 |
:10014000E25BF44F9FE084918D939150319697FF3D |
:10015000FACF80E241C080910704882361F0ABE5CB |
:10016000BBE0E6E8FDE094E184918D9391503196F7 |
:1001700097FFFACFB9C28091100485FF0CC0ABE5A0 |
:10018000BBE0ECE9FDE094E184918D9391503196D0 |
:1001900097FFFACFA9C280915205882301F1ABE500 |
:1001A000BBE0EFE7FDE096E084918D9391503196AE |
:1001B00097FFFACF80910101805D80935F0BA2E6EB |
:1001C000BBE0E4EBF8E09BE081918D93915097FFC9 |
:1001D000FBCF80E280936D0B80936E0BB9C03091A2 |
:1001E0005A05332309F499C087E580935B0B80E5BA |
:1001F00080935C0B40E240935D0B20915B05822F66 |
:100200006AE00E94B99F805D80935E0B822F0E94FE |
:10021000B99F892F805D80935F0B8FE28093600B85 |
:10022000832F0E94B99F805D8093610B832F0E9472 |
:10023000B99F892F805D8093620B4093630B20915F |
:1002400057053091580583E0293E380780F0C901F1 |
:1002500068EE73E00E94C59FCB01805D8093640BC4 |
:10026000C90168EE73E00E94C59F9C0102C04093E3 |
:10027000640B2536310580F0C90164E670E00E9408 |
:10028000C59FCB01805D8093650BC90164E670E07A |
:100290000E94C59F9C0103C080E28093650BC90149 |
:1002A0006AE070E00E94C59FCB01805D8093660B81 |
:1002B000C9016AE070E00E94C59F805D8093670B72 |
:1002C0008DE68093680B80E28093690B209159053D |
:1002D000253660F0822F64E60E94B99F805D80938E |
:1002E0006A0B822F0E94B99F292F02C080936A0B4C |
:1002F000822F6AE00E94B99F805D80936B0B822FF2 |
:100300000E94B99F892F805D80936C0B83E7809357 |
:100310006D0B80E280936E0BE7C1809134048823DB |
:10032000D1F4ABE5BBE0E4EBFDE090E184918D938B |
:100330009150319697FFFACF92E390936B0B8EE238 |
:1003400080936C0B80E380936D0B90936E0B82E631 |
:1003500080936F0BC9C1ABE5BBE0E2EBFDE094E13C |
:1003600084918D939150319697FFFACFBDC18091C2 |
:10037000430490914404A0914504B0914604BC010B |
:10038000CD0124E630E040E050E00E940EA0DA010A |
:10039000C9018C509E4F9093380C8093370C8091FC |
:1003A000240C882319F40E94A77F02C080E395E7FC |
:1003B00090933A0C8093390C88E780933B0C8091A2 |
:1003C000720A80933C0C8091710A81FF02C084E420 |
:1003D00007C08091730A833011F480E201C081E28A |
:1003E00080933D0C82E29CE09093740580937305AA |
:1003F000809196018093490C80913D0C80934B0C29 |
:100400008091770A9091780A97FD01969595879546 |
:1004100080933E0C69C10E94997E80914304909123 |
:100420004404A0914504B0914604BC01CD0124E6EA |
:1004300030E040E050E00E940EA0DA01C9018C508B |
:100440009E4F90930D0B80930C0B80912601909101 |
:1004500027019093070B8093060B809126019091C2 |
:1004600027019093090B8093080B8091120A9091B9 |
:10047000130A97FD0196959587958093F80A8093C6 |
:10048000FF0A2091770A3091780A37FF02C02F5F68 |
:100490003F4F359527952093FD0A8091750A9091DD |
:1004A000760A64E170E00E94C59F6093FE0A209383 |
:1004B000040B6093050B8091240C882319F40E948F |
:1004C000A77F02C080E395E79093150B8093140BF0 |
:1004D00088E78093160B80912601909127019093D5 |
:1004E000110B8093100B809155058C5E80930A0B45 |
:1004F000809156058C5E80930B0B8091EF0A909152 |
:10050000F00A6AE070E00E94C59F7093130B60933D |
:10051000120B8091240C8093F40A8091EB0A909145 |
:10052000EC0A90930F0B80930E0B82EF9AE090935E |
:100530007405809373052091EA023091EB02C901A2 |
:100540006CE370E00E94C59F6093190BC9016CE3D6 |
:1005500070E00E94C59F80931A0BC6C00E94997ECE |
:100560008091750A9091760A64E670E00E94C59FBA |
:100570007093340B6093330B8091120A9091130A9D |
:1005800097FD0196959587958093240B8091900116 |
:100590009091910197FD0196959587958093250BF4 |
:1005A0008091D3078093280B8091770A9091780AE5 |
:1005B00097FD0196959587958093290B809102016F |
:1005C000482F55279A012E5F3F4F80912601909129 |
:1005D00027012817390784F480912601909127017B |
:1005E000841B950B9C01220F331F280F391F822F6C |
:1005F00086508093300B02C01092300B8091300BEC |
:10060000853618F084E68093300B80912A0599276F |
:100610009093320B8093310B80914304909144046A |
:10062000A0914504B0914604BC01CD0124E630E020 |
:1006300040E050E00E940EA0DA01C9018C509E4FAC |
:100640009093360B8093350B809126019091270172 |
:1006500090932B0B80932A0B809126019091270178 |
:1006600090932D0B80932C0B8091240C882319F4EC |
:100670000E94A77F02C080E395E79093380B809398 |
:10068000370B8091240C88588093390B8091260178 |
:100690009091270190933D0B80933C0B80915505E1 |
:1006A0008C5E80932E0B809156058C5E80932F0B71 |
:1006B0008091EF0A9091F00A6AE070E00E94C59F75 |
:1006C00070933F0B60933E0B1092200B8091EB0ACE |
:1006D0009091EC0A90933B0B80933A0B8EE19BE058 |
:1006E00090937405809373052CE230E002C020E003 |
:1006F00030E0C9011F910895EF92FF920F931F936D |
:10070000CF93DF9380915005909151059C0153E068 |
:10071000220F331F5A95E1F7281B390B80913303C1 |
:1007200090913403280F391F37FF02C0295F3F4FD4 |
:1007300043E0359527954A95E1F73093510520938D |
:10074000500590916405992309F026C380916305B3 |
:10075000282F3327442755278F5F80936305F9019E |
:100760002131310508F015C3E757FF4F0C9460A005 |
:100770008091100485FF2AC080E00E9497978091A5 |
:100780002601909127016AE070E00E94D99F9F9313 |
:100790008F9380912601909127016AE070E00E947A |
:1007A000D99F7F936F938EED9DE09F938F938AE8FF |
:1007B00097E99F938F93E0919C05F0919D05099592 |
:1007C0002DB73EB7285F3F4F2DBF28C080E00E9465 |
:1007D000979780912601909127016AE070E00E942E |
:1007E000D99F9F938F9380912601909127016AE072 |
:1007F00070E00E94D99F7F936F938BEE9DE09F9353 |
:100800008F9389E697E99F938F93E0919C05F091F0 |
:100810009D0509958DB79EB708968DBF8091560AA4 |
:1008200080FF3FC0809160048823E9F08AE00E9445 |
:1008300097978091410199279F938F9380914304CB |
:1008400090914404A0914504B0914604BC01CD01AF |
:1008500024E630E040E050E00E940EA03F932F934A |
:1008600088EF9DE0C8C68AE00E9497978091430474 |
:1008700090914404A0914504B0914604BC01CD017F |
:1008800024E630E040E050E00E940EA03F932F931A |
:1008900084E09EE09F938F9389E697E99F938F93DF |
:1008A000D1C78AE00E9497978FE09EE09F938F9335 |
:1008B00089E697E90C944D8D8091100485FF2AC03C |
:1008C00085E10E9497978091EA029091EB026CE398 |
:1008D00070E00E94C59F9F938F938091EA02909150 |
:1008E000EB026CE370E00E94C59F7F936F9389E1F8 |
:1008F0009EE09F938F938AE897E99F938F93E0916F |
:100900009C05F0919D0509952DB73EB7285F3F4F97 |
:100910002DBF28C085E10E9497978091EA029091AF |
:10092000EB026CE370E00E94C59F9F938F938091D0 |
:10093000EA029091EB026CE370E00E94C59F7F9306 |
:100940006F9386E29EE09F938F9389E697E99F934A |
:100950008F93E0919C05F0919D0509958DB79EB709 |
:1009600008968DBF8FE10E94979780E690E09F9355 |
:100970008F938091120A9091130A9F938F9383E330 |
:100980009EE09F938F93C9E6D7E9DF93CF93E091E1 |
:100990009C05F0919D05099580910F042DB73EB7F8 |
:1009A000285F3F4F2DBF80FF06C089E20E949797C6 |
:1009B0008EE39EE06FC389E20E94979780E49EE0F9 |
:1009C000E2C68091100485FF1BC08AE20E949797BF |
:1009D0008091EF0A9091F00A9F938F9382E49EE0BA |
:1009E0009F938F938AE897E99F938F93E0919C055B |
:1009F000F0919D0509958DB79EB706968DBF1BC0DA |
:100A00008AE20E9497978091EF0A9091F00A9F9353 |
:100A10008F938AE49EE09F938F9389E697E99F9353 |
:100A20008F93E0919C05F0919D0509952DB73EB7F8 |
:100A30002A5F3F4F2DBF86E30E9497978091EB0A74 |
:100A40009091EC0A6AE070E00E94C59F9F938F939B |
:100A50008091EB0A9091EC0A6AE070E00E94C59FD9 |
:100A60007F936F9382E59EE09F938F9389E697E94A |
:100A70009F938F93E0919C05F0919D0509958DB70B |
:100A80009EB70896E7C689E00E9497978EE59EE09C |
:100A90009F938F9309E617E91F930F93E0919C05AD |
:100AA000F0919D0509958EE10E9497970F900F9008 |
:100AB0000F900F9080E69EE09F938F931F930F936C |
:100AC000E0919C05F0919D05099583E30E9497971D |
:100AD0000F900F900F900F9082E69EE09F938F9360 |
:100AE0001F930F93E0919C05F0919D0509958FE36D |
:100AF0000E9497970F900F900F900F9084E69EE0C2 |
:100B00009F938F931F930F93E0919C05F0919D0508 |
:100B100009958EE70E9497970F900F900F900F9076 |
:100B20008AE79EE09F938F931F930F93B8C780919E |
:100B3000A401882309F462C08DE50E94979780E99B |
:100B40009EE09F938F93C9E6D7E9DF93CF93E0911F |
:100B50009C05F0919D05099584E50E9497970F905B |
:100B60000F900F900F908091720A99279F938F9307 |
:100B700082E99EE09F938F93DF93CF93E0919C0552 |
:100B8000F0919D0509958EE50E9497972DB73EB788 |
:100B90002A5F3F4F2DBF8091750A9091760A6AE0D7 |
:100BA00070E00E94C59F7F936F938BE99EE09F93B7 |
:100BB0008F93DF93CF93E0919C05F0919D0509956C |
:100BC0008DB79EB706968DBF8091730A833081F4EE |
:100BD0008091710A81FF06C08BE50E94979785EA94 |
:100BE0009EE0D1C58BE50E94979788EA9EE0CBC531 |
:100BF0008BE50E9497978BEA9EE04BC784E0FCC38D |
:100C00008091A401882309F47AC08091660529E6C1 |
:100C1000E22E27E9F22E882309F44BC089E60E94D0 |
:100C200097978091290599279F938F938EEA9EE04D |
:100C30009F938F93FF92EF92E0919C05F0919D0519 |
:100C4000099585E70E9497972DB73EB72A5F3F4FDA |
:100C50002DBF8091960199279F938F9300E610E016 |
:100C60001F930F938091770A9091780A9F938F93A7 |
:100C700089EB9EE09F938F93FF92EF92E0919C050A |
:100C8000F0919D05099582E70E9497978DB79EB7D1 |
:100C90000A968DBF8091270599279F938F931F9365 |
:100CA0000F938091280599279F938F9385EC9EE061 |
:100CB00091C689E60E9497978091960199279F9304 |
:100CC0008F9380E690E09F938F938091770A909125 |
:100CD000780A9F938F938091740A99279F938F939B |
:100CE00085ED9EE09F938F93FF92EF92E0919C059C |
:100CF000F0919D0509958DB79EB70C96ABC585E023 |
:100D00007BC390912A059923D1F0809170058823A7 |
:100D100081F0913270F487E00E94DF7E83E90E94C7 |
:100D2000979780912A0599279F938F938EEE9EE047 |
:100D3000CDC383E90E94979789EF9EE0DCC3809141 |
:100D4000100499E6E92E97E9F92E85FF06C084E99B |
:100D50000E9497978FEF9EE003C483E90E949797C4 |
:100D600082E19FE0FDC38091870C863059F4809129 |
:100D70006605882319F010926605B8C681E0809355 |
:100D80006605B4C6883009F0B1C60E949C9781E020 |
:100D900004C490936305B2C6913009F009C48091F0 |
:100DA0006305282F3327442755278F5F80936305DA |
:100DB000F9012131310508F09CC6E656FF4F0C942D |
:100DC00060A08091100485FF43C080E00E94979747 |
:100DD0008091EF0A9091F00A9F938F938091260162 |
:100DE000909127016AE070E00E94D99F9F938F93B2 |
:100DF00080912601909127016AE070E00E94D99FBE |
:100E00007F936F938091EA029091EB026CE370E024 |
:100E10000E94C59F9F938F938091EA029091EB026D |
:100E20006CE370E00E94C59F7F936F9388E29FE020 |
:100E30009F938F938AE897E99F938F93E0919C0506 |
:100E4000F0919D0509952DB73EB7225F3F4FCFC565 |
:100E500080E00E9497978091EF0A9091F00A9F930B |
:100E60008F9380912601909127016AE070E00E94A3 |
:100E7000D99F9F938F9380912601909127016AE0DB |
:100E800070E00E94D99F7F936F938091EA029091C6 |
:100E9000EB026CE370E00E94C59F9F938F9380915B |
:100EA000EA029091EB026CE370E00E94C59F7F9391 |
:100EB0006F9383E49FE0EBC285E10E94979780E601 |
:100EC00090E09F938F9380919001909191019F93D7 |
:100ED0008F938EE59FE09F938F93C9E6D7E9DF93C9 |
:100EE000CF93E0919C05F0919D0509958091560A5C |
:100EF0002DB73EB7285F3F4F2DBF80FF51C0809177 |
:100F00006004882339F18FE10E9497978091430410 |
:100F100090914404A0914504B0914604BC01CD01D8 |
:100F200024E630E040E050E00E940EA03F932F9373 |
:100F300088E69FE09F938F9389E797E99F938F932C |
:100F4000E0919C05F0919D0509958DB79EB7069699 |
:100F50008DBF38C08FE10E94979780914304909194 |
:100F60004404A0914504B0914604BC01CD0124E69F |
:100F700030E040E050E00E940EA03F932F9381E7C5 |
:100F80009FE09F938F93DF93CF93E0919C05F09127 |
:100F90009D0509952DB73EB72A5F3F4F2DBF12C063 |
:100FA0008FE10E9497978AE79FE09F938F93DF934B |
:100FB000CF93E0919C05F0919D0509950F900F90BE |
:100FC0000F900F9089E20E94979780914101992795 |
:100FD0009F938F9384E89FE031C48091A40188237C |
:100FE000F9F08BE20E9497978091960199279F9341 |
:100FF0008F938091750A9091760A6AE070E00E9462 |
:10100000C59F7F936F9380E690E09F938F9380912D |
:10101000770A9091780A9F938F9387E89FE068C141 |
:1010200082E0EAC18FE30E9497978091ED0A909148 |
:10103000EE0A9F938F938091EB0A9091EC0A6AE0FD |
:1010400070E00E94C59F9F938F938091EB0A9091CF |
:10105000EC0A6AE070E00E94C59F7F936F938EE96F |
:101060009FE09F938F93C9E6D7E9DF93CF93E091F9 |
:101070009C05F0919D05099580910F042DB73EB711 |
:10108000265F3F4F2DBF80FF0AC082E50E949797E1 |
:1010900082EB9FE09F938F9389E797E9FEC482E5F7 |
:1010A0000E94979785EB9FE06EC38091A40109E6AB |
:1010B000E02E07E9F02E882309F449C084E50E9458 |
:1010C00097978091720A99279F938F938091740AC2 |
:1010D00099279F938F9388EB9FE09F938F93E701CE |
:1010E000FF92EF92E0919C05F0919D0509958DB7D7 |
:1010F0009EB708968DBF8091730A833051F484E6C1 |
:101100000E9497978BEC9FE09F938F93FF92EF92B3 |
:101110000BC084E60E94979781ED9FE09F938F9389 |
:101120008AE897E99F938F93E0919C05F0919D0544 |
:1011300009950F900F900F900F908091710A81FF89 |
:10114000DDC484E60E94979787ED9FE01CC384E589 |
:101150000E9497978DED9FE003C28091650519E687 |
:10116000E12E17E9F12E882309F45BC089E60E947D |
:10117000979783E00E94A97D6AE070E00E94C59F76 |
:101180009F938F9383E00E94A97D6AE070E00E94A4 |
:10119000C59F7F936F9382E00E94A97D6AE070E013 |
:1011A0000E94C59F9F938F9382E00E94A97D6AE071 |
:1011B00070E00E94C59F7F936F9381E00E94A97D9C |
:1011C0006AE070E00E94C59F9F938F9381E00E9428 |
:1011D000A97D6AE070E00E94C59F7F936F9380E0D5 |
:1011E0000E94A97D6AE070E00E94C59F9F938F9343 |
:1011F00080E00E94A97D6AE070E00E94C59F7F9315 |
:101200006F9383EF9FE09F938F93FF92EF92E09114 |
:101210009C05F0919D0509952DB73EB72C5E3F4F7B |
:10122000E6C389E60E94979780E690E09F938F93AC |
:1012300080913609992787FD90959F938F93809190 |
:101240002E09992787FD90959F938F93809126096A |
:10125000992787FD90959F938F9380911E099927D9 |
:1012600087FD90959F938F9380E190E19F938F935B |
:10127000FF92EF92E0919C05F0919D0509958DB745 |
:101280009EB70E96E7C28091650590913F0888232E |
:1012900009F4AFC0943009F4AEC09630C9F58EE7BA |
:1012A0000E94979785E00E94A97D6AE070E00E9405 |
:1012B000C59F9F938F9385E00E94A97D6AE070E0AF |
:1012C0000E94C59F7F936F9384E00E94A97D6AE08E |
:1012D00070E00E94C59F9F938F9384E00E94A97D38 |
:1012E0006AE070E00E94C59F7F936F9383E290E174 |
:1012F0009F938F9389E697E99F938F93E0919C0545 |
:10130000F0919D0509952DB73EB7245F3F4F6FC300 |
:10131000973008F4F3C38EE70E94979788E00E9405 |
:10132000A97D6AE070E00E94C59F9F938F9388E03B |
:101330000E94A97D6AE070E00E94C59F7F936F9331 |
:1013400087E00E94A97D6AE070E00E94C59F9F939C |
:101350008F9387E00E94A97D6AE070E00E94C59F9C |
:101360007F936F9386E00E94A97D6AE070E00E94FF |
:10137000C59F9F938F9386E00E94A97D6AE070E0ED |
:101380000E94C59F7F936F9385E00E94A97D6AE0CC |
:1013900070E00E94C59F9F938F9385E00E94A97D76 |
:1013A0006AE070E00E94C59F7F936F9384E00E9483 |
:1013B000A97D6AE070E00E94C59F9F938F9384E0AF |
:1013C0000E94A97D6AE070E00E94C59F7F936F93A1 |
:1013D00082E390E19F938F9389E697E99F938F93A0 |
:1013E000E0919C05F0919D0509958DB79EB74896B3 |
:1013F00031C2943021F486E00E94DF7E7FC39630B4 |
:10140000F1F48EE70E94979780E690E09F938F9388 |
:1014100080914609992787FD90959F938F9380919E |
:101420003E09992787FD90959F938F938FE490E1D4 |
:101430009F938F9389E697E99F938F93CFC29730BD |
:1014400008F45CC38EE70E94979780E690E09F9334 |
:101450008F9380915609992787FD90959F938F933D |
:1014600080914E09992787FD90959F938F93809146 |
:101470004609992787FD90959F938F9380913E0908 |
:10148000992787FD90959F938F9382E690E19F9394 |
:101490008F9389E697E99F938F93ECCE90912A05DD |
:1014A000992309F44AC0809170058823F9F091329C |
:1014B000E8F487E00E94DF7E83E90E94979780919D |
:1014C0002A0599279F938F9385E790E19F938F93A8 |
:1014D00089E797E99F938F93E0919C05F0919D0593 |
:1014E00009952DB73EB72A5F3F4F81C283E90E941D |
:1014F000979780E890E19F938F9309E617E91F93F0 |
:101500000F93E0919C05F0919D0509951F921F9204 |
:1015100090912A0581E1989FC0011124825B944F2C |
:101520009F938F931F930F93E0919C05F0919D05DE |
:1015300009958DB79EB70A968DC180911004C9E6B2 |
:10154000EC2EC7E9FC2E85FF06C084E90E94979720 |
:1015500086E890E105C083E90E94979789E990E1C8 |
:101560009F938F93FF92EF929AC28091870C86305F |
:1015700079F480916505882319F01092650503C000 |
:1015800081E08093650585E00E94DF7E86E0A3C24E |
:10159000883031F40E949C9782E080936405A4C255 |
:1015A000813009F0A3C20E949C97109264059CC2EE |
:1015B000923009F0A1C280916305282F3327442778 |
:1015C00055278F5F80936305F9012131310508F0BC |
:1015D00090C2E555FF4F0C9460A080E00E94979761 |
:1015E00084EB98E09F938F938091010199279F93BB |
:1015F0008F938FEA90E19F938F9389E797E99F9369 |
:101600008F93E0919C05F0919D0509952DB73EB70C |
:10161000285F3F4FECC185E10E94979782EC98E0EC |
:101620009F938F93809102016AE00E94B99F892F56 |
:1016300099279F938F93809102010E94B99F9927C8 |
:101640009F938F938EEB90E19F938F9389E697E919 |
:101650009F938F93E0919C05F0919D05099569CF2B |
:101660008AE20E9497978FEC90E19F938F93C9E64F |
:10167000D7E9DF93CF93E0919C05F0919D05099503 |
:101680008091560A0F900F900F900F9080FF41C0ED |
:1016900080914D089091260481FD0BC0892F9927D8 |
:1016A0009F938F9384ED90E19F938F93DF93CF93DC |
:1016B00013CFE0919C05F0919D05933318F08EEDCA |
:1016C00090E102C085EE90E19F938F93DF93CF93DB |
:1016D00009950F900F900F900F908091390AE0912B |
:1016E0009C05F0919D059091260480FF0BC0892FE9 |
:1016F00099279F938F938CEE90E19F938F93DF9325 |
:10170000CF93A4C0892F99279F938F9382EF90E165 |
:10171000C4C088EF90E137C08FE30E94979781E0C3 |
:1017200091E19F938F93C9E6D7E9DF93CF93E0913F |
:101730009C05F0919D0509950F900F900F900F90CB |
:101740008091A308882319F485E091E11CC0809161 |
:101750001D04E0919C05F0919D05882319F08EE011 |
:1017600091E102C085E191E19F938F93DF93CF9345 |
:1017700009950F900F900F900F908091B20886FFFF |
:10178000BDC18CE191E19F938F93DF93CF9387C18C |
:1017900084E50E94979783E291E19F938F93C9E636 |
:1017A000D7E9DF93CF93E0919C05F0919D050995D2 |
:1017B0008091560A0F900F900F900F9085FD03C0F7 |
:1017C00088E291E108C0809191080E947A488233B2 |
:1017D00058F481E391E19F938F93DF93CF93E0914E |
:1017E0009C05F0919D0516C0843B18F088E391E1BB |
:1017F000F2CF8091B208E0919C05F0919D0585FFA4 |
:1018000003C08FE391E102C086E491E19F938F933F |
:10181000DF93CF9309950F900F900F900F908091C9 |
:10182000A708882309F46AC18EE50E9497978091E2 |
:10183000A70899279F938F938DE491E19F938F93AE |
:10184000DF93CF93E0919C05F0919D0509958DB7AD |
:101850009EB706968DBF52C189E60E94979788E58C |
:1018600091E19F938F93C9E6D7E9DF93CF93E091FE |
:101870009C05F0919D0509950F900F900F900F908A |
:101880008091A608E0919C05F0919D05882351F078 |
:1018900099279F938F9382E691E19F938F93DF9394 |
:1018A000CF931ECE86E691E19F938F93DF93CF93E4 |
:1018B000FAC080916705B9E6EB2EB7E9FB2E8823C5 |
:1018C00009F053C08EE70E94979780916F01992786 |
:1018D0009F938F9380914208E82FFF27EE0FFF1F01 |
:1018E000E858F64F808191819F938F9380914108B2 |
:1018F000E82FFF27EE0FFF1FE858F64F80819181F8 |
:101900009F938F938CE691E19F938F93FF92EF9239 |
:10191000E0919C05F0919D05099583E90E949797B8 |
:101920008DB79EB70A968DBF80914408E82FFF2798 |
:10193000EE0FFF1FE858F64F808191819F938F93A0 |
:1019400080914308E82FFF27EE0FFF1FE858F64F5E |
:101950008081918181589F4F9F938F9380E891E17F |
:101960009F938F93FF92EF924CCE8EE70E949797B2 |
:1019700080914C0499279F938F9380914B049927D2 |
:101980009F938F9380914A0499279F938F938FE819 |
:1019900091E19F938F93FF92EF92E0919C05F091DC |
:1019A0009D05099583E90E9497978DB79EB70A9682 |
:1019B0008DBF80914F0499279F938F9380914E0400 |
:1019C00099279F938F9380914D0499279F938F938D |
:1019D00083EA91E19F938F93FF92EF92E0919C05B0 |
:1019E000F0919D0509952DB73EB7265F3F4F2DBF5E |
:1019F00085C080917005882309F480C08EE70E941D |
:101A000097978091560A86FD11C087EB91E19F93CD |
:101A10008F938AE897E99F938F93E0919C05F091CB |
:101A20009D0509950F900F900F900F908091B00831 |
:101A300099278F709070892B89F086EC91E19F93A4 |
:101A40008F938AE897E99F938F93E0919C05F0919B |
:101A50009D0509950F900F900F900F908091560A59 |
:101A600082FF11C080ED91E19F938F938AE897E9FF |
:101A70009F938F93E0919C05F0919D0509950F90A0 |
:101A80000F900F900F908091560A83FD37C085ED1F |
:101A900091E19F938F938AE897E99F938F93E091C9 |
:101AA0009C05F0919D0509950F900F900F900F9058 |
:101AB00025C00091870C063089F480916705882342 |
:101AC00019F01092670503C081E08093670586E0F6 |
:101AD0000E94DF7E87E00E94DF7E08C0013031F483 |
:101AE0000E949C9700936405109263051092870CE6 |
:101AF00005C01092630502C010926405E6E0CDB700 |
:101B0000DEB70C9451A04FB728E130E0F8948091F3 |
:101B1000C9008F778093C9008091C9008F7B809323 |
:101B2000C9008091C9008F7D8093C900832F9927B8 |
:101B30008093CD002093CC008091C8008260809378 |
:101B4000C80080E18093C9008091CA008F7780939C |
:101B5000CA008091CA008F7B8093CA008091CA001E |
:101B60008091CA008F7E8093CA008091CA008860ED |
:101B70008093CA008091C9008B7F8093C9008091B7 |
:101B8000CA0084608093CA008091CA0082608093FA |
:101B9000CA008091C80087FF03C08091CE00F9CFB2 |
:101BA0008091C90080688093C9008091650C846031 |
:101BB0008093650C4FBF089590913D05992341F4A2 |
:101BC0008F3031F49093690580E580933D05089549 |
:101BD000E0916905EF5FE0936905E83121F481E068 |
:101BE000809368050895E93120F089E180936905C3 |
:101BF0000895FF27E25BF34F80830895A0E0B0E0F3 |
:101C0000E4E0FEE80C9431A091E0D92E82E0A82E09 |
:101C1000BD2CE12C01E0F02E8091650C82FDB5C059 |
:101C200080916F008F7D80936F00E091A908EE2373 |
:101C300051F0FF27EE0FFF1FE858F64F808191818A |
:101C4000843691055CF480914904883C20F48091AD |
:101C500049048C5E01C088EC8093490480914F0C4C |
:101C6000682F772780916A05815080936A058F3F9E |
:101C700031F41CE7C12E82E080936A0502C0C4E201 |
:101C8000CC2E40E04C1508F07EC0EA2DFF27E25B29 |
:101C9000F34F80818D2111F06E297F298D2D992799 |
:101CA000880F991FD82E882319F4B1E0DB2EAD0CD4 |
:101CB000EE0CFF1C20E0E21628E0F20609F061C0FD |
:101CC000A1E0EA2EF12CCB018050944065E070E059 |
:101CD0000E94D99FAB2DBB27FD01EA0FFB1FE858DF |
:101CE000F64F808191819C01220F331F280F391FED |
:101CF000260F371F37FF02C02D5F3F4FE901D595F3 |
:101D0000C795D595C795CB0101968C179D0714F4FF |
:101D1000219706C061507040C617D7070CF4219672 |
:101D200080914904833CD8F08D010A0F1B1FF801F4 |
:101D3000E858F64F80819181FE01E81BF90BCF0135 |
:101D400063E070E00E94D99FCB01880F991F860F36 |
:101D5000971F0254164FF8019183808307C0AA0F82 |
:101D6000BB1FA254B64F11961C921E92EB2DFF275B |
:101D7000EE0FFF1FE858F64FD183C08360E070E09C |
:101D8000B3944F5F7FCF1092400110926805EAE054 |
:101D9000CDB7DEB70C944DA00895089540E050E013 |
:101DA00080916B0590916C059C01220F331F280FC9 |
:101DB000391F8091330390913403280F391F37FF67 |
:101DC00002C02D5F3F4F3595279535952795309368 |
:101DD0006C0520936B05809141018B32D9F4809181 |
:101DE0005208282F332780913D0490913E04829F12 |
:101DF000A001839F500D929F500D1124CA0157FDE1 |
:101E00004F96AC0125E0559547952A95E1F74B5F34 |
:101E10005F4F3DC08D32D9F480915208282F33276F |
:101E200080913D0490913E04829FA001839F500DBC |
:101E3000929F500D1124CA0157FD4F96AC0195E0B9 |
:101E4000559547959A95E1F74550504020C080320E |
:101E500071F48091100481FF1AC0C90137FD4F96BB |
:101E6000AC0185E0559547958A95E1F710C08E3510 |
:101E700029F480913804482F552709C0863739F452 |
:101E800080913804992744275527481B590BCA01CC |
:101E9000AA2797FDA095BA2F80939F029093A00246 |
:101EA000A093A102B093A20208950F931F930E94E2 |
:101EB000997E8091260190912701AA2797FDA095F0 |
:101EC000BA2F8093CE019093CF01A093D001B0930D |
:101ED000D1018091EB0A9091EC0AAA27BB2780934D |
:101EE000E1019093E201A093E301B093E4010AE0E1 |
:101EF00010E08091EF0A9091F00AB8010E94C59F0E |
:101F0000CB01AA27BB278093F4019093F501A093FE |
:101F1000F601B093F7018091430490914404A0919D |
:101F20004504B0914604BC01CD0124E630E040E018 |
:101F300050E00E940EA020930702309308024093C5 |
:101F4000090250930A028091900190919101AA2771 |
:101F500097FDA095BA2F80931A0290931B02A0932D |
:101F60001C02B0931D028091720A9927AA27BB27F1 |
:101F700080932D0290932E02A0932F02B0933002F3 |
:101F80008091740A9927AA27BB27809340029093D7 |
:101F90004102A0934202B09343028091750A90914E |
:101FA000760AB8010E94C59FCB01AA27BB27809360 |
:101FB000530290935402A0935502B093560280911D |
:101FC000770A9091780AAA2797FDA095BA2F809357 |
:101FD000660290936702A0936802B09369028091B1 |
:101FE00056059927AA27BB278093790290937A02F6 |
:101FF000A0937B02B0937C02809129059927AA27A0 |
:10200000BB2780938C0290938D02A0938E02B09395 |
:102010008F0280912A059927AA27BB278093B202B5 |
:102020009093B302A093B402B093B5021F910F91A5 |
:1020300008954FB720E430E0F8948091C9008F777D |
:102040008093C9008091C9008F7B8093C9008091E3 |
:10205000C9008F7D8093C900832F99278093CD007D |
:102060002093CC008091C80082608093C80088E1F2 |
:102070008093C9008091CA008F778093CA008091B5 |
:10208000CA008F7B8093CA008091CA008F7D8093A5 |
:10209000CA008091CA008F7E8093CA008091CA00D6 |
:1020A000877F8093CA008091C9008B7F8093C9008D |
:1020B0008091CA0084608093CA008091CA008260C7 |
:1020C0008093CA008091C80087FF03C08091CE0032 |
:1020D000F9CF8091C90080688093C9004FBF0895EF |
:1020E0000F931F93CF93DF93482F4F5F893108F0F1 |
:1020F0008BC080917709841720F44F5F4093770954 |
:102100004150CB0183539B4268E170E00E94D99F0C |
:10211000A42FBB27FD01EA0FFB1FE858F64F808173 |
:1021200091819B01281B390BC90137FF03C0909592 |
:1021300081959F4F069794F480914904883C30F430 |
:1021400080914904865F8093490408C088EC80939D |
:10215000490480916F008F7D80936F00FD01EA0F2D |
:10216000FB1FE858F64F808191819C01220F331F9D |
:10217000280F391F260F371F37FF02C02D5F3F4F33 |
:10218000E901D595C795D595C795CB0101968C17D3 |
:102190009D0714F4219706C061507040C617D707F9 |
:1021A0000CF4219680914904843BD8F08D010A0FEC |
:1021B0001B1FF801E858F64F80819181FE01E81B52 |
:1021C000F90BCF0163E070E00E94D99FCB01880F2B |
:1021D000991F860F971F0254164FF8019183808331 |
:1021E00007C0AA0FBB1FA254B64F11961C921E9295 |
:1021F000E42FFF27EE0FFF1FE858F64FD183C0836F |
:10220000443011F410924001DF91CF911F910F9152 |
:102210000895CF93DF932091880C822F9927807F98 |
:102220009070409709F066C02F3109F040C080914E |
:10223000890C8093770590918B0C90937905809110 |
:102240008C0C80937805992309F054C08091410843 |
:10225000282F3327220F331FF901E254F64F118242 |
:10226000108280914208A82FBB27AA0FBB1FFD0137 |
:10227000E254F64F1182108280914408E82FFF2724 |
:10228000EE0FFF1FCF018254964FEC011982188286 |
:102290002858364FE90119821882A858B64F11966E |
:1022A0001C921E92E858F64F1182108223C0C22F52 |
:1022B000CF70CA30F8F48091890C8093B40C80916F |
:1022C0008A0C8093B30C80918B0C8093B60C809118 |
:1022D0008C0C8093B50C6091B30C7091B40C8C2F66 |
:1022E0000E9470906091B50C7091B60C8C2F8F5F2E |
:1022F0000E947090DF91CF910895CF93C82F8F3FA8 |
:1023000049F480917A058F3F29F410927C05109250 |
:102310007B0532C020917C05222339F4CF3111F4A2 |
:1023200085E001C084E080937D0580917D059091DA |
:102330007B058217A0F4892F809580937B058F3FC2 |
:1023400019F48EEF80937B0580917B05C81711F4FB |
:102350000E94099110927C0510927B050BC0E22F20 |
:10236000FF27E857F34FC0832F5F20937C059C0F16 |
:1023700090937B05C0937A05CF910895909176054F |
:10238000933240F4E92FFF27E057F34F80839F5F9C |
:10239000909376050895833218F48D5F80937605C7 |
:1023A000089590E2E3E9FCE08FE19193815087FF8B |
:1023B000FCCF0895CF93CFB723E031E0F89480911C |
:1023C000C9008F778093C9008091C9008F7B80936B |
:1023D000C9008091C9008F7D8093C900832F992700 |
:1023E0008093CD002093CC008091C80082608093C0 |
:1023F000C80088E18093C9008091CA008F778093DC |
:10240000CA008091CA008F7B8093CA008091CA0065 |
:1024100080628093CA008091CA0080618093CA0064 |
:102420008091CA0088608093CA008091C90084604E |
:102430008093C9008091CA0084608093CA00809113 |
:10244000CA0082608093CA008091C80087FF03C0E1 |
:102450008091CE00F9CF8091C90080688093C90037 |
:102460008091C90080648093C9000E94D191CFBF40 |
:10247000CF910895282F99278F709070892B31F470 |
:10248000209580917505822B8093750508951F9284 |
:102490000F920FB60F9211248F93EF93FF938091B9 |
:1024A000E302882309F068C0E0917F05EE2389F4F8 |
:1024B00080917E05882369F48091900C882321F017 |
:1024C00081E08093800505C08091C9008160809380 |
:1024D000C90080918005882379F4EF5FE0937F0540 |
:1024E0008091670C8E1720F481E0809380051CC0DA |
:1024F000FF27E959F34F3CC080917E05882361F4A2 |
:102500008091900C882311F483E003C0813999F401 |
:1025100081E080937E050FC0833099F48091900C08 |
:10252000882349F01092900C8091C9008E7F80938F |
:10253000C9008EEF1EC08091C90081608093C900E0 |
:102540000EC0833261F48091C9008E7F8093C900F0 |
:102550008FEF8093CE0081E08093E30218C08091DA |
:102560007E05E82FFF27E057F34F8F5F80937E05AE |
:1025700080818093CE000BC010927E0510927F0563 |
:10258000109280058091C90080618093C900FF91FD |
:10259000EF918F910F900FBE0F901F9018956827A5 |
:1025A00027E0322F67FF06C0862F9927880F991FD3 |
:1025B000832702C0862F880F682F215027FFF2CF74 |
:1025C000992708950F931F93CF93DF93062F60E011 |
:1025D000162F601740F4EC0189910E94CF92682F6A |
:1025E0001F5F1017C8F3862F9927DF91CF911F9196 |
:1025F0000F910895DC0190E0961758F48C91803289 |
:1026000041F09F5F961728F4FD01E90FF11D8081CD |
:10261000F6CF892F99270895A0E0B0E0E2E1F3E931 |
:102620000C9432A08FE98093680C80E180936A0C4F |
:1026300084EA80936B0C85E580936C0C8DE5809328 |
:102640006D0C10926E0C80918205882309F06AC08F |
:102650008091810513E1819FC001112463E08954B9 |
:102660009E4F0E94FA92082F80918105819FC001A0 |
:1026700011246AE083559E4F0E94FA92982F800F92 |
:10268000865F8093670C2EEFB22EB80EB092690C65 |
:102690002091810520936F0CE92EFF24C70113E0E0 |
:1026A000880F991F1A95E1F7802B8093700C822F69 |
:1026B0009927C3E1CC2ED12C8C9D90018D9D300D9E |
:1026C0009C9D300D1124C90183559E4FA701BC016B |
:1026D00081E79CE00E94FA9D11278091810599274E |
:1026E0008C9DE0018D9DD00D9C9DD00D1124CE01BF |
:1026F00089549E4FA801BC01C7018F58934F0E9477 |
:10270000FA9D0959134F0E0D1F1D6B2D89E69CE094 |
:102710000E94E292F8018287809182058F5F809308 |
:10272000820593C0C0906E0C1C2D0E94558F309175 |
:10273000E402303108F058C0B3E1EB2EF12C632FE6 |
:10274000812F9927FC01EE0FFF1FE80FF91FEC0DF9 |
:10275000F11DE959F34F832F99278E9DD0018F9D4D |
:10276000B00D9E9DB00D1124A355BE4FED012D85DA |
:1027700074E0880F991F7A95E1F7282B20873E3067 |
:1027800088F42E853F853F798A899927982F882755 |
:102790009295990F907E282B392B2187832F99278B |
:1027A000828716C0ED012E853F854889598921878A |
:1027B000BB27A52F942F832F8287CA01AA27BB2767 |
:1027C0008387852F9927AA27BB278487E2E0CE0E2F |
:1027D000862F8F5F682F1F5F163020F4382F8031CF |
:1027E00008F4AECF8093E40283E0189FC001112467 |
:1027F0002C2D280F285F2093670C225C2093690CF6 |
:10280000812F99278C01000F111F080F191F0C0D24 |
:10281000111D0959134F2054622F89E69CE00E9434 |
:10282000E292E80188878091E402803170F081E0D3 |
:102830008093E40210928205809181058F5F8093DE |
:102840008105803110F010928105E9E0CDB7DEB747 |
:102850000C944EA08091E302882309F447C0809134 |
:10286000100485FD04C08091E802882381F082E98C |
:102870008093900C83E28093910C8091E8028823EE |
:1028800009F485E58093920C1092E80202C08093CF |
:10289000900C8091E5028F3071F4809175050E9453 |
:1028A000397D882341F081E98093900C8093910CCD |
:1028B00081E38093920C1092E3028091C80085FF1F |
:1028C000FCCF8091C9008F7E8093C9008091C900A0 |
:1028D0008E7F8093C9000E940C938EE78093CE0078 |
:1028E000809175058093E502109275050895EF9229 |
:1028F000FF920F931F93CF93DF937C018B01EA012B |
:10290000452B39F0F80181918F01F7010995219745 |
:10291000C9F7E6E0CDB7DEB70C9451A0EF92FF9275 |
:102920000F931F93CF93DF937C018B01EA01452B1B |
:1029300041F0F8010F5F1F4F8491F701099521972E |
:10294000C1F7E6E0CDB7DEB70C9451A00F931F930B |
:10295000CF938C01C62F161634F480E2F801099546 |
:10296000C1501C16D4F3CF911F910F9108950F936E |
:102970001F93CF938C01C62F161634F480E3F80111 |
:102980000995C1501C16D4F3CF911F910F91089552 |
:10299000A5E3B0E0EEECF4E90C9429A02E96EEADA0 |
:1029A000FFAD2E9788249924540180916F058823C8 |
:1029B00021F42C961FAE1EAE2C97AEE44A2E512C5D |
:1029C0004C0E5D1E6F01B60105C0153239F008943A |
:1029D000C11CD11CF60114911123B9F7A601461BA5 |
:1029E000570B31F02C968EAD9FAD2C970E948E9494 |
:1029F000112309F46AC20894C11CD11CFF24FDA64E |
:102A0000FCA6EFEFEE2EF9A6F6010894C11CD11C2E |
:102A10001491153721F0812F80628837B1F4F0FED0 |
:102A20000AC0F20124E030E0420E531E8080918003 |
:102A3000A280B3800AC0F20142E050E0440E551E6D |
:102A4000808191814C01AA24BB24103221F489A5F4 |
:102A50008823D1F61DC0133219F458E0F52AD4CFDB |
:102A60001A3211F01D3291F41A3259F4F20182E057 |
:102A700090E0480E591EE081ECA7EE232CF6E1957C |
:102A8000ECA790E1F92AAFEDFA22BECF1B3211F488 |
:102A900019A7BACF1E32C1F5F6010894C11CD11C8A |
:102AA00014911A3279F4F20122E030E0420E531E02 |
:102AB000408151813FEF4F3F530714F44FEF5FEFD9 |
:102AC000E42EA2CF40E050E0812F80538A30A0F462 |
:102AD000CA0173E0880F991F7A95E1F7840F951F5B |
:102AE000480F591F410F511D40535040F6010894A3 |
:102AF000C11CD11C1491E8CF8FEF4F3F580714F43D |
:102B00004FEF5FEFE42E85CF103329F4F4FC7CCF38 |
:102B100090E2F92A79CF812F81538930D8F440E0AF |
:102B200050E0CA0163E0880F991F6A95E1F7840FAE |
:102B3000951F480F591F410F511D40535040F6013A |
:102B40000894C11CD11C1491812F80538A3048F302 |
:102B50004CA75FCF183619F4A4E0FA2A55CF1C36DB |
:102B600019F4B1E0FB2A50CF133661F43E0108940A |
:102B7000611C711CF20122E030E0420E531E808184 |
:102B800089833CC1143421F0143611F0193651F503 |
:102B9000143411F431E0F32AF0FE0AC0F20144E0EB |
:102BA00050E0440E551E80809180A280B3800CC0FE |
:102BB000F20182E090E0480E591E808191814C0123 |
:102BC000AA2497FCA094BA2CB7FE0AC0B094A09493 |
:102BD00090948094811C911CA11CB11C8DE289A74A |
:102BE0000AE06FC01F3411F01F3631F41F3411F4A6 |
:102BF00091E0F92A08E064C0103779F4F201A2E00C |
:102C0000B0E04A0E5B1E808191814C01AA24BB2456 |
:102C100000E1B0E4FB2A18E753C01337C1F5F20115 |
:102C200022E030E0420E531E608071806114710416 |
:102C300089F43E010894611C711C88E289838EE648 |
:102C4000F301818385E78B838CE68C838D8389E216 |
:102C50008E831F82E7FC13C08E2D992787FD9095E8 |
:102C6000AC0160E070E0C3010E94ED9D009729F087 |
:102C7000382E3618E3140CF0C3C03E2CC1C0F3014B |
:102C800001900020E9F731973E2E3618B9C015356E |
:102C900011F0153731F4153511F4F1E0FF2A0AE08F |
:102CA0000FC0183519F0183709F0A0C000E1F3FE85 |
:102CB00007C081149104A104B10411F020E4F22AA8 |
:102CC00019A6EDA6E7FC02C03FEDF32249E2642E0F |
:102CD000712C6C0E7D1E81149104A104B10421F4A9 |
:102CE0004DA5442309F47BC0802F9927AA27BB2731 |
:102CF0008EA79FA7A8ABB9AB202E332490E08916EE |
:102D000090E0990691E0A90690E0B90648F0C50167 |
:102D1000B4012EA53FA548A959A90E94EC9F17C050 |
:102D2000AFEF8A169104A104B10449F040F0C40148 |
:102D3000B1010E94C59F9B014427552708C0882DDB |
:102D4000602F0E94B99F282F3327442755272AAB8D |
:102D50003BAB4CAB5DAB0A3059F48AA9880F880FA6 |
:102D6000880F9AA9990F890F382D381B832F10C00F |
:102D7000003139F48AA98295807F482D481B842F21 |
:102D800007C08AA9880F880F880F582D581B852FD8 |
:102D900090E02EA53FA548A959A982169306A4063E |
:102DA000B50608F091E08AA89BA8ACA8BDA88A3017 |
:102DB00010F4805D04C0895A183509F48F7DD30161 |
:102DC0008E933D01992309F099CF083041F4F3FE29 |
:102DD00006C0803321F080E3FD0182933F01CE01E4 |
:102DE0000196382E3618F8E23F0E0BC0112309F475 |
:102DF0006CC03E010894611C711C198331E0332EB4 |
:102E000019A6032D2DA4231827FC222489A5882385 |
:102E100011F00F5F02C0F6FC0E5F020DEF2CFF24D5 |
:102E2000C70180739070892B49F48CA5801B682F93 |
:102E30002C968EAD9FAD2C970E94A69489A58823D1 |
:102E400031F041E050E0BE01675D7F4F0AC0E6FE11 |
:102E50000EC080E38AA71BA742E050E0BE01665D7A |
:102E60007F4F2C968EAD9FAD2C970E947794C70113 |
:102E700080739070809749F48CA5801B682F2C96E6 |
:102E80008EAD9FAD2C970E94B794622D2C968EAD7F |
:102E90009FAD2C970E94B794832D992787FD90951D |
:102EA000AC01B3012C968EAD9FAD2C970E94779408 |
:102EB000E4FE89CD2CA5201B2CA7622F2C968EAD6D |
:102EC0009FAD2C970E94A6947ECDE2E1CB5C0C9442 |
:102ED00045A0982F80918F0C883A50F480918F0CE8 |
:102EE000E82FFF27EA58F44F93838F5F80938F0C6E |
:102EF0000895982F80918F0C883A58F480918F0C08 |
:102F0000E82FFF27EA58F44F906893838F5F8093F0 |
:102F10008F0C0895982F80917005882321F0892FB8 |
:102F20000E9479970895892F0E9469970895883A99 |
:102F300010F480938F0C089580E090E2E9E7FBE0C5 |
:102F400091938F5F883AE0F308954FB721E830E01E |
:102F5000F8948091C9008F778093C9008091C9004F |
:102F60008F7B8093C9008091C9008F7D8093C900B9 |
:102F7000832F99278093CD002093CC008091C800A7 |
:102F800082608093C80088E18093C9008091CA0064 |
:102F90008F778093CA008091CA008F7B8093CA008C |
:102FA0008091CA008F7D8093CA008091CA008F7E75 |
:102FB0008093CA008091CA00877F8093CA00809165 |
:102FC000C90084608093C9008091CA0084608093A6 |
:102FD000CA008091CA0082608093CA008091C900B3 |
:102FE00081608093C9008091C80087FF03C08091F1 |
:102FF000CE00F9CF8091C90080688093C9004FBF8F |
:103000003CE73093F20A2DE720931D0B8EE8809366 |
:10301000F30A10920F0B10920E0B1092F80A80EE2A |
:103020008093F50A30934A0B2093750B1092560B40 |
:103030001092550B1092580B1092570B10925A0B7E |
:103040001092590B84EF91E09093540B8093530BA3 |
:103050009093520B8093510B9093500B80934F0B96 |
:1030600010924C0B89E880934B0B1092730B1092CB |
:10307000740B80E980934D0B3093220C20934D0C00 |
:103080001092240C8AE88093230C10922A0C109240 |
:10309000290C1092280C10922C0C10922D0C1092CE |
:1030A0002E0C10922F0C1092310C1092320C1092A8 |
:1030B000330C1092340C1092380C1092370C109282 |
:1030C000360C1092350C80EA8093250C30931E0B41 |
:1030D0002093490B1092200B8DE880931F0B1092C8 |
:1030E000480B80ED8093210B8BE78093760B80E873 |
:1030F0008093770B1092780B8091F80A90E2E9E7C1 |
:10310000FBE091938F5F883AE0F38DE78093210C89 |
:103110000895CF93C82F80918305803879F48C2F40 |
:103120000E940C808093720580917205882331F192 |
:10313000C0938E0C809172058F5F16C08F37F1F4AB |
:103140008091870C882329F48C2F80958F70809331 |
:10315000870C0E94F77E8093780B86E79BE0909324 |
:103160007405809373058DEA809372058091C90080 |
:103170008F7E8093C90082E080937105C0938305A0 |
:10318000CF91089530917105332331F0809171050D |
:10319000815080937105089580917205882381F193 |
:1031A0004091720590918405413091F4292F30931C |
:1031B00084058091C90080618093C9008091700569 |
:1031C000882319F03093700510C0409370050DC02E |
:1031D000E0917305F09174058191F0937405E0938B |
:1031E0007305282F980F909384058091C80085FF60 |
:1031F000FCCF2093CE0080917205815080937205A0 |
:1032000008956F927F928F929F92AF92BF92CF92CA |
:10321000DF92EF92FF920F931F93882361F1823028 |
:1032200041F410928D0510928E0510928F05109228 |
:1032300090052091430430914404409145045091FD |
:103240004604DA01C90119E0880F991FAA1FBB1FA4 |
:103250001A95D1F78093360390933703A0933803E0 |
:10326000B0933903209385053093860540938705F5 |
:103270005093880526C1A0904304B0904404C090A8 |
:103280004504D09046048091850590918605A091D3 |
:103290008705B091880535014601681A790A8A0ABE |
:1032A0009B0A6092890570928A0580928B059092A4 |
:1032B0008C0580913A0390913B0384559F4F7C018C |
:1032C0000027F7FC0095102F8091260A9091270A7D |
:1032D0009C01442737FD4095542FC801B7010E9437 |
:1032E0009A9F97FF04C06150704E8F4F9F4FAB0164 |
:1032F000BC01FDE07595679557954795FA95D1F70F |
:103300004C5A504060407040409391055093920554 |
:1033100060939305709394052091860A3091870AF3 |
:1033200037FF02C0215F3F4FE4E035952795EA95CE |
:10333000E1F780913E0390913F03829FD001839FEC |
:10334000B00D929FB00D1124CD01B7FF02C0815086 |
:103350009F4FE92FFF27E7FDFA952091840A3091CE |
:10336000850A37FF02C0215F3F4F84E035952795DE |
:103370008A95E1F780913C0390913D03829FD001B3 |
:10338000839FB00D929FB00D1124CD01B7FF02C0F5 |
:1033900081509F4F892F990F990BE80FF91FCF018B |
:1033A000AA2797FDA095BA2F840F951FA61FB71FB8 |
:1033B0008093910590939205A0939305B093940503 |
:1033C000BC01CD012DE030E040E050E00E949A9F2A |
:1033D0007B018C01C401B30124EF31E040E050E0F7 |
:1033E0000E949A9FDC01CB01E80EF91E0A1F1B1FE9 |
:1033F00080918D0590918E05A0918F05B0919005DB |
:10340000209195053091960540919705509198052A |
:10341000821B930BA40BB50BE80EF91E0A1F1B1F92 |
:10342000E0928D05F0928E0500938F051093900524 |
:10343000D801C70180509E4FAF4FBF4FB7FF06C0A6 |
:10344000D801C70181509A4FAF4FBF4F1AE0B595D1 |
:10345000A795979587951A95D1F7809395059093A1 |
:103460009605A0939705B0939805A0928505B09214 |
:103470008605C0928705D092880520913603309149 |
:1034800037034091380350913903E0902903F090BD |
:103490002A0300912B0310912C032E193F09400B96 |
:1034A000510B280F391F4A1F5B1F2A0D3B1D4C1D56 |
:1034B0005D1D2093360330933703409338035093B8 |
:1034C00039038091950590919605909334038093EC |
:1034D00033038091360390913703A0913803B09164 |
:1034E0003903BC01CD011F910F91FF90EF90DF9048 |
:1034F000CF90BF90AF909F908F907F906F900895E6 |
:103500002FB740E0F894E0E0F0E081E280935700CC |
:103510009491E2E0F0E0809357003491E4E0F0E031 |
:103520008093570084912FBF9E3199F4363941F42E |
:10353000893011F441E00DC08A3059F442E009C0ED |
:10354000373939F4863011F443E003C0853009F48B |
:1035500044E0842F992708959FB7F8948091C9007B |
:10356000877F8093C9008091C9008F7E8093C900B6 |
:103570008091C9008F778093C9008091C9008F7BAB |
:103580008093C9008091C9008F7D8093C9009FBF3F |
:1035900008951F93CF93DF93182F80916F05882391 |
:1035A00009F4A7C08091E202181709F4A2C0809123 |
:1035B0006E05882321F40E94809A80936E0582ED27 |
:1035C00091E090933F0180933E0187EB92E19F93BE |
:1035D0008F93CEE9D6E1DF93CF93E0919C05F091F4 |
:1035E0009D0509950F900F900F900F90812F9927AF |
:1035F000AA27BB27FC01099778F5E454FF4F2091D7 |
:103600009C0530919D050C9460A083EB92E102C073 |
:103610008AEA92E19F938F93DF93CF93F901099503 |
:1036200027C085EA92E1F6CF8DE992E1F3CF85E9F3 |
:1036300092E19F938F93DF93CF93F901099588EDE2 |
:1036400091E090933F0180933E0112C080E992E1A6 |
:10365000E1CF84EC92E1DECF8AEC92E19F938F93ED |
:10366000DF93CF93E0919C05F0919D05099510E0C3 |
:103670000F900F900F900F9080916E05843011F095 |
:10368000823011F50E94AC9A812F8150833018F45A |
:103690000E9416782CC0143019F40E94DA9127C0C9 |
:1036A000183019F40E94CC8E22C0153019F40E94F3 |
:1036B00019901DC0163019F40E94A59718C0173034 |
:1036C000B1F40E94838D13C0112389F080EE92E142 |
:1036D0009F938F938EE996E19F938F93E0919C0542 |
:1036E000F0919D0509950F900F900F900F901093FA |
:1036F000E202DF91CF911F9108950F931F93082F3E |
:1037000081E080936F054091E102E0E4F2E120E086 |
:1037100030E05FE4849199272F5F3F4F829FB00193 |
:10372000839F700D929F700D112446275150319642 |
:1037300057FFF0CF4093E102E8E1F2E120E030E012 |
:1037400057E2849199272F5F3F4F829FB001839F5B |
:10375000700D929F700D112446275150319657FFDE |
:10376000F0CF4093E10280916E05882321F40E94FE |
:10377000809A80936E0588EC94E990939D058093E0 |
:103780009C058091E102833459F088E190E029E2C0 |
:103790000FB6F894A895809360000FBE2093600048 |
:1037A000053091F08BEF92E19F938F938EE996E134 |
:1037B0009F938F93E0919C05F0919D0509950F9043 |
:1037C0000F900F900F90EECF80910301893158F147 |
:1037D00080916D058823A9F488E193E19F938F93ED |
:1037E0008EE996E19F938F93E0919C05F0919D0562 |
:1037F000099587E1809303010F900F900F900F9030 |
:1038000012C015BC873119F48093030106C087E00C |
:103810008093140186E080931301E091DF02F09120 |
:10382000E0028DEF09950E94230A82E690E09F93C3 |
:103830008F9382E090E09F938F939F938F938091DB |
:1038400003016AE00E94B99F892F99279F938F9364 |
:10385000809103010E94B99F99279F938F9382E5DE |
:1038600093E19F938F930EE916E11F930F93E091DD |
:103870009C05F0919D05099580E492E19F938F93BB |
:103880001F930F93E0919C05F0919D05099588E1A8 |
:1038900092E19F938F931F930F93E0919C05F0917A |
:1038A0009D0509950E94230A83EC809381008091F5 |
:1038B0006F00806280936F008DB79EB746968DBF74 |
:1038C0001F910F9108958091A7088D3338F0809152 |
:1038D000710A87FD03C08CE38093A7088091560886 |
:1038E000882331F08055853618F08FE7809356088D |
:1038F000089580916F05882309F477C08091990518 |
:10390000815080939905882309F059C089E18093FB |
:1039100099058091A7088E3338F08091710A87FD50 |
:1039200003C08DE38093A70880914904823820F575 |
:103930008091110490911204805D974020F0809155 |
:10394000F10A843620F410929B0510929A0580911A |
:103950009A0590919B05009739F1019790939B05EB |
:1039600080939A05419728F18091710A84FF21C0C4 |
:1039700080910F0484601BC080914904853BC8F08E |
:103980009091A70884E1989FC0011124409620914E |
:103990009A0530919B052817390730F42F5F3F4F68 |
:1039A00030939B0520939A0580910F048B7F809321 |
:1039B0000F048091E102833411F010926F05909111 |
:1039C000E202963019F40E94C29808958091E602AE |
:1039D000882321F081508093E60208958BE4809340 |
:1039E000E602943011F40E942A9408951F920F92D7 |
:1039F0000FB60F9211242F933F934F935F936F93C2 |
:103A00007F938F939F93AF93BF93EF93FF93909187 |
:103A1000CE008091F2028823B9F09093C600809185 |
:103A2000F202823009F03FC09F3FE9F58FEF94E347 |
:103A3000ACE0B0E0C297A109B109B7FFFBCF80911C |
:103A4000DF058093CE002FC02091E202822F8150AB |
:103A5000833020F4892F0E946D7825C0243021F412 |
:103A6000892F0E943A921FC0283021F4892F0E948A |
:103A7000CD8E19C080910301893120F080916D05B0 |
:103A8000882389F0253021F4892F0E947D910BC075 |
:103A9000263021F4892F0E94899805C0273019F417 |
:103AA000892F0E94DC8DFF91EF91BF91AF919F9183 |
:103AB0008F917F916F915F914F913F912F910F90D7 |
:103AC0000FBE0F901F9018950024222733274427FC |
:103AD00051E0BB27EE27FF27A0E1660F771F881F65 |
:103AE000991F001C221F331F441F660F771F881F5A |
:103AF000991F001C221F331F441F2AF4050E2B1F81 |
:103B00003E1F4F1F04C0051A2B0B3E0B4F0B550FCA |
:103B1000BB1FEE1F587F556047FD5250AA95E9F62E |
:103B2000E695B7955795E695B7955795852F9B2FB1 |
:103B300008952227332741E0552768E0880F991F11 |
:103B4000221F331F880F991F221F331F1AF4240FBF |
:103B5000351F02C0241B350B440F551F487F45609D |
:103B600037FD42506A9551F75695479556954795BA |
:103B7000842F0895AA2797FF04C0809590958A1FE7 |
:103B80009A1F77FF04C0609570956A1F7A1F669F21 |
:103B90009001779FA001679F300D411D5A1F300D86 |
:103BA000411D5A1F889FF001999F2E0F3F1F401DF6 |
:103BB000511D899F300D411D5A1F300D411D5A1F47 |
:103BC000CA01B901112480CFFB01DC0102C00590BC |
:103BD0000D9241505040D8F70895FC01415050409B |
:103BE00030F001900616D1F73197CF01089588275C |
:103BF00099270895FB01DC0102C001900D9241500C |
:103C00005040D8F70895A0E0B0E0E9E0FEE90C9458 |
:103C100031A06C017B01EA01590121978FEFCF3F61 |
:103C2000D80789F086010894C11CD11CC7010894EB |
:103C3000E11CF11CF5010995F80180832197FFEF44 |
:103C4000CF3FDF0779F7EAE0CDB7DEB70C944DA0A0 |
:103C5000CF92DF92EF92FF920F931F937C016B0143 |
:103C6000FB010995082FC7010196F6010995182F48 |
:103C7000C8011F910F91FF90EF90DF90CF900895B2 |
:103C8000A0E0B0E0E6E4FEE90C9433A08C017B01F7 |
:103C9000EA01690121978FEFCF3FD80771F0F70153 |
:103CA00021917F01C8010F5F1F4F622FF601099517 |
:103CB0002197FFEFCF3FDF0791F7E8E0CDB7DEB701 |
:103CC0000C944FA0CF92DF92EF92FF920F931F932D |
:103CD0006C018B017A01FA010995812F9927682FD0 |
:103CE000C6010196F70109951F910F91FF90EF9082 |
:103CF000DF90CF9008955058BB27AA270ED0E0C080 |
:103D0000D1D030F0D6D020F031F49F3F11F41EF422 |
:103D1000C6C00EF4E095E7FBBCC0E92FE2D080F30B |
:103D2000BA17620773078407950718F071F49EF5B8 |
:103D3000FAC00EF4E0950B2EBA2FA02D0B01B9019D |
:103D400090010C01CA01A0011124FF27591B99F011 |
:103D5000593F50F4503E68F11A16F040A22F232F1D |
:103D6000342F4427585FF3CF469537952795A7956D |
:103D7000F0405395C9F77EF41F16BA0B620B730B14 |
:103D8000840BBAF09150A1F0FF0FBB1F661F771F85 |
:103D9000881FC2F70EC0BA0F621F731F841F48F43A |
:103DA000879577956795B795F7959E3F08F0B3CFC0 |
:103DB0009395880F08F09927EE0F979587950895AA |
:103DC00098D088F09F5790F0B92F9927B751A0F05D |
:103DD000D1F0660F771F881F991F1AF0BA95C9F79F |
:103DE00012C0B13081F09FD0B1E008959CC0672F20 |
:103DF000782F8827B85F39F0B93FCCF3869577954F |
:103E00006795B395D9F73EF4909580957095619537 |
:103E10007F4F8F4F9F4F0895E89409C097FB3EF462 |
:103E200090958095709561957F4F8F4F9F4F992307 |
:103E3000A9F0F92F96E9BB279395F6958795779585 |
:103E40006795B795F111F8CFFAF4BB0F11F460FF45 |
:103E50001BC06F5F7F4F8F4F9F4F16C0882311F09D |
:103E600096E911C0772321F09EE8872F762F05C0B1 |
:103E7000662371F096E8862F70E060E02AF09A954C |
:103E8000660F771F881FDAF7880F9695879597F941 |
:103E9000089597F99F6780E870E060E008959FEFCC |
:103EA00080EC089500240A941616170618060906D1 |
:103EB000089500240A9412161306140605060895A0 |
:103EC000092E0394000C11F4882352F0BB0F40F428 |
:103ED000BF2B11F460FF04C06F5F7F4F8F4F9F4F68 |
:103EE000089557FD9058440F551F59F05F3F71F0EA |
:103EF0004795880F97FB991F61F09F3F79F0879551 |
:103F00000895121613061406551FF2CF4695F1DFD9 |
:103F100008C0161617061806991FF1CF8695710569 |
:103F2000610508940895E894BB2766277727CB019D |
:103F300097F90895629FD001739FF001829FE00D71 |
:103F4000F11D649FE00DF11D929FF00D839FF00D18 |
:103F5000749FF00D659FF00D9927729FB00DE11DC4 |
:103F6000F91F639FB00DE11DF91FBD01CF011124A1 |
:103F70000895991B79E004C0991F961708F0961BC5 |
:103F8000881F7A95C9F780950895AA1BBB1B51E13C |
:103F900007C0AA1FBB1FA617B70710F0A61BB70BB9 |
:103FA000881F991F5A95A9F780959095BC01CD015E |
:103FB000089597FB092E07260AD077FD04D0E5DF88 |
:103FC00006D000201AF4709561957F4F0895F6F79A |
:103FD000909581959F4F0895A1E21A2EAA1BBB1BB5 |
:103FE000FD010DC0AA1FBB1FEE1FFF1FA217B307C5 |
:103FF000E407F50720F0A21BB30BE40BF50B661FDB |
:10400000771F881F991F1A9469F76095709580959E |
:1040100090959B01AC01BD01CF01089597FB092E3E |
:1040200005260ED057FD04D0D7DF0AD0001C38F487 |
:1040300050954095309521953F4F4F4F5F4F0895D4 |
:10404000F6F790958095709561957F4F8F4F9F4FB4 |
:1040500008952F923F924F925F926F927F928F922C |
:104060009F92AF92BF92CF92DF92EF92FF920F9307 |
:104070001F93CF93DF93CDB7DEB7CA1BDB0B0FB611 |
:10408000F894DEBF0FBECDBF09942A8839884888CE |
:104090005F846E847D848C849B84AA84B984C88464 |
:1040A000DF80EE80FD800C811B81AA81B981CE0F5B |
:1040B000D11D0FB6F894DEBF0FBECDBFED01089540 |
:0E40C000EE0FFF1F0590F491E02D0994FFCF45 |
:1040CE0004035E0A010164FF010020FFFFC01FC050 |
:1040DE001F0101070610F40101737373FF03007DC6 |
:1040EE000000C409C4096400114167696C65005180 |
:1040FE00756164726F000000000000006400D20160 |
:10410E0001200B050000ECFF00020406070808085A |
:10411E000706040200FEFCFAF9F8F8F8F9FAFCFEBC |
:10412E00000204060708086440415A46553264648A |
:10413E00640A02969696960840403A10303801323C |
:10414E00FF037F0090D0030090D003003200206464 |
:10415E00FFFFE8036464200B0A0D0B0E100B0A0C14 |
:10416E000F0B1110FA20680101010101154D4B20B2 |
:10417E0020202020202020202020010000000000F0 |
:10418E00566F6C7461676520202056202001000058 |
:10419E0000000143757272656E742020204120204C |
:1041AE000100000000014361706163697479202091 |
:1041BE00416820010000000002416C74697475644E |
:1041CE006520206D2020010000000000436F6D70FF |
:1041DE00617373202020B0202001000000000053E6 |
:1041EE006174732020202020202020200100000058 |
:1041FE000000537065656420202020206D2F730110 |
:10420E00000000000044697374616E636520206DC8 |
:10421E002020010000000000486F6D652D4469727A |
:10422E002020B020200100000000006D61782E5487 |
:10423E00656D702E20B043200100000000004D611E |
:10424E00676E2E6669656C642520200100000000F3 |
:10425E0000566172696F202020202020202001004E |
:10426E00000000004572726F72436F64652020205B |
:10427E00200100000000004C6174697475646520B3 |
:10428E00202020200900000000004C6F6E6769742A |
:10429E0075646520202020090000000000F7FFFC57 |
:0842AE00FF70FF01010F640025 |
:00000001FF |
/tags/V2.02b/Hex-Files/License.txt |
---|
0,0 → 1,69 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + * porting the sources to other systems or using the software on other systems (except hardware from www.mikrokopter.de) is not allowed |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
// + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
// + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
// + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE |
// + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
// + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
// + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
// + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
// + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
// + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
// + POSSIBILITY OF SUCH DAMAGE. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
/tags/V2.02b/Hex-Files/WasIstWas.txt |
---|
0,0 → 1,14 |
+++++++++++++++++++++++++ |
+ Flight-Ctrl: |
+++++++++++++++++++++++++ |
Flight-Ctrl_MEGA1284_Vx_yy.hex |
Flight-Ctrl_MEGA644_Vx_yy.hex |
Aktuelle Firmware |
Wird per serielle Schnittstelle (durch den Bootloader) eingespielt |
Achtung: Die Programme für den ATMEGA1284 dürfen ausschliesslich per Bootloader, also seriell (MKUSB) eingespielt werden und NICHT per ISP |
Warning: do not program the ATMEGA1284 (FC2.1) via SPI. Only use the MKUSB and the Koptertool for update! |
/tags/V2.02b/License.txt |
---|
0,0 → 1,52 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
/tags/V2.02b/Settings.h |
---|
--- tags/V2.02b/Spektrum.c (nonexistent) |
+++ tags/V2.02b/Spektrum.c (revision 2405) |
@@ -0,0 +1,406 @@ |
+/*####################################################################################### |
+Decodieren eines RC Summen Signals oder Spektrum Empfänger-Satellit |
+#######################################################################################*/ |
+ |
+#include "Spektrum.h" |
+#include "main.h" |
+ |
+unsigned char SpektrumTimer = 0; |
+ |
+// Achtung: RECEIVER_SPEKTRUM_DX7EXP oder RECEIVER_SPEKTRUM_DX8EXP wird in der main.h gesetzt |
+#if defined (RECEIVER_SPEKTRUM_DX7EXP) || defined (RECEIVER_SPEKTRUM_DX8EXP) |
+unsigned char s_excnt = 0; // Bitcounter for Spektrum-Expander |
+unsigned char s_exparity = 0; // Parity Bit for Spektrum-Expander |
+signed char s_exdata[11]; // Data for Spektrum-Expander |
+ |
+void s_update(unsigned char channel, signed int value) // Channel-Diff numbercrunching and finally assign new stickvalue to PPM_in |
+{ |
+ if(SenderOkay >= 180) PPM_diff[channel] = ((value - PPM_in[channel]) / 3) * 3; |
+ else PPM_diff[channel] = 0; |
+ PPM_in[channel] = value; |
+} |
+#endif |
+ |
+//############################################################################ |
+// USART1 initialisation from killagreg |
+void SpektrumUartInit(void) |
+//############################################################################ |
+ { |
+ // -- Start of USART1 initialisation for Spekturm seriell-mode |
+ // USART1 Control and Status Register A, B, C and baud rate register |
+ uint8_t sreg = SREG; |
+ |
+ uint16_t ubrr = (uint16_t) ((uint32_t) SYSCLK/(8 * 115200) - 1); |
+ |
+ // disable all interrupts before reconfiguration |
+ cli(); |
+ // disable RX-Interrupt |
+ UCSR1B &= ~(1 << RXCIE1); |
+ // disable TX-Interrupt |
+ UCSR1B &= ~(1 << TXCIE1); |
+ // disable DRE-Interrupt |
+ UCSR1B &= ~(1 << UDRIE1); |
+/* |
+ // set direction of RXD1 and TXD1 pins |
+ // set RXD1 (PD2) as an input pin |
+ PORTD |= (1 << PORTD2); |
+ DDRD &= ~(1 << DDD2); |
+ // set TXD1 (PD3) as an output pin |
+ PORTD |= (1 << PORTD3); |
+ DDRD |= (1 << DDD3); |
+*/ |
+ // USART0 Baud Rate Register |
+ // set clock divider |
+ UBRR1H = (uint8_t)(ubrr>>8); |
+ UBRR1L = (uint8_t)ubrr; |
+ // enable double speed operation |
+ UCSR1A |= (1 << U2X1); |
+ // enable receiver and transmitter |
+ //UCSR1B = (1<<RXEN1)|(1<<TXEN1); |
+ |
+ UCSR1B = (1<<RXEN1); |
+ // set asynchronous mode |
+ UCSR1C &= ~(1 << UMSEL11); |
+ UCSR1C &= ~(1 << UMSEL10); |
+ // no parity |
+ UCSR1C &= ~(1 << UPM11); |
+ UCSR1C &= ~(1 << UPM10); |
+ // 1 stop bit |
+ UCSR1C &= ~(1 << USBS1); |
+ // 8-bit |
+ UCSR1B &= ~(1 << UCSZ12); |
+ UCSR1C |= (1 << UCSZ11); |
+ UCSR1C |= (1 << UCSZ10); |
+ // flush receive buffer explicit |
+ while(UCSR1A & (1<<RXC1)) UDR1; |
+ // enable RX-interrupts at the end |
+ UCSR1B |= (1 << RXCIE1); |
+ // -- End of USART1 initialisation |
+ // restore global interrupt flags |
+ |
+ SREG = sreg; |
+ return; |
+ } |
+ |
+// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
+// + Copyright (c) Rainer Walther |
+// + RC-routines from original MK rc.c (c) H&I |
+// + Useful infos from Walter: http://www.rcgroups.com/forums/showthread.php?t=714299&page=2 |
+// + only for non-profit use |
+// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
+// |
+// 20080808 rw Modified for Spektrum AR6100 (PPM) |
+// 20080823 rw Add Spektrum satellite receiver on USART1 (644P only) |
+// 20081213 rw Add support for Spektrum DS9 Air-Tx-Module (9 channels) |
+// Replace AR6100-coding with original composit-signal routines |
+// |
+// --- |
+// Entweder Summensignal ODER Spektrum-Receiver anschließen. Nicht beides gleichzeitig betreiben! |
+// Binding is not implemented. Bind with external Receiver. |
+// Servo output J3, J4, J5 not serviced |
+// |
+// Anschuß Spektrum Receiver |
+// Orange: 3V von der FC (keinesfalls an 5V anschließen!) |
+// Schwarz: GND |
+// Grau: RXD1 (Pin 3) auf 10-Pol FC-Stecker |
+// |
+// --- |
+// Satellite-Reciever connected on USART1: |
+// |
+// DX7/DX6i: One data-frame at 115200 baud every 22ms. |
+// DX7se: One data-frame at 115200 baud every 11ms. |
+// byte1: unknown |
+// byte2: unknown |
+// byte3: and byte4: channel data (FLT-Mode) |
+// byte5: and byte6: channel data (Roll) |
+// byte7: and byte8: channel data (Nick) |
+// byte9: and byte10: channel data (Gier) |
+// byte11: and byte12: channel data (Gear Switch) |
+// byte13: and byte14: channel data (Gas) |
+// byte15: and byte16: channel data (AUX2) |
+// |
+// DS9 (9 Channel): One data-frame at 115200 baud every 11ms, alternating frame 1/2 for CH1-7 / CH8-9 |
+// 1st Frame: |
+// byte1: unknown |
+// byte2: unknown |
+// byte3: and byte4: channel data |
+// byte5: and byte6: channel data |
+// byte7: and byte8: channel data |
+// byte9: and byte10: channel data |
+// byte11: and byte12: channel data |
+// byte13: and byte14: channel data |
+// byte15: and byte16: channel data |
+// 2nd Frame: |
+// byte1: unknown |
+// byte2: unknown |
+// byte3: and byte4: channel data |
+// byte5: and byte6: channel data |
+// byte7: and byte8: 0xffff |
+// byte9: and byte10: 0xffff |
+// byte11: and byte12: 0xffff |
+// byte13: and byte14: 0xffff |
+// byte15: and byte16: 0xffff |
+// |
+// Each channel data (16 bit= 2byte, first msb, second lsb) is arranged as: |
+// |
+// Bits: F 0 C3 C2 C1 C0 D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 |
+// |
+// 0 means a '0' bit |
+// F: 1 = indicates beginning of 2nd frame for CH8-9 (DS9 only) |
+// C3 to C0 is the channel number. 0 to 9 (4 bit, as assigned in the transmitter) |
+// D9 to D0 is the channel data (10 bit) 0xaa..0x200..0x356 for 100% transmitter-travel |
+// |
+// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
+ |
+#define MIN_FRAMEGAP 68 // 7ms |
+#define MAX_BYTEGAP 3 // 310us |
+ |
+ |
+//############################################################################ |
+// Wird im UART-Interrupt aufgerufen |
+//############################################################################ |
+void SpektrumParser(unsigned char c) |
+{ |
+ static unsigned char Sync=0, FrameCnt=0, ByteHigh=0, ReSync=1, Frame2=0; |
+ unsigned int Channel, index = 0; |
+ signed int signal = 0, tmp; |
+ int bCheckDelay; |
+// c = UDR1; // get data byte |
+ if(ReSync == 1) |
+ { |
+ // wait for beginning of new frame |
+ ReSync = 0; |
+ SpektrumTimer = MIN_FRAMEGAP; |
+ FrameCnt = 0; |
+ Sync = 0; |
+ ByteHigh = 0; |
+ } |
+ else |
+ { |
+ if(!SpektrumTimer) bCheckDelay = 1; else bCheckDelay = 0;//CheckDelay(FrameTimer); |
+ if ( Sync == 0 ) |
+ { |
+ if(bCheckDelay) |
+ { |
+ // nach einer Pause von mind. 7ms erstes Sync-Character gefunden |
+ // Zeichen ignorieren, da Bedeutung unbekannt |
+ Sync = 1; |
+ FrameCnt ++; |
+ SpektrumTimer = MAX_BYTEGAP; |
+ } |
+ else |
+ { |
+ // Zeichen kam vor Ablauf der 7ms Sync-Pause |
+ // warten auf erstes Sync-Zeichen |
+ SpektrumTimer = MIN_FRAMEGAP; |
+ FrameCnt = 0; |
+ Sync = 0; |
+ ByteHigh = 0; |
+ } |
+ } |
+ else if((Sync == 1) && !bCheckDelay) |
+ { |
+ // zweites Sync-Character ignorieren, Bedeutung unbekannt |
+ Sync = 2; |
+ FrameCnt ++; |
+ SpektrumTimer = MAX_BYTEGAP; |
+ } |
+ else if((Sync == 2) && !bCheckDelay) |
+ { |
+ SpektrumTimer = MAX_BYTEGAP; |
+ // Datenbyte high |
+ ByteHigh = c; |
+ if (FrameCnt == 2) |
+ { |
+ // is 1st Byte of Channel-data |
+ // Frame 1 with Channel 1-7 comming next |
+ Frame2 = 0; |
+ if(ByteHigh & 0x80) |
+ { |
+ // DS9: Frame 2 with Channel 8-9 comming next |
+ Frame2 = 1; |
+ } |
+ } |
+ Sync = 3; |
+ FrameCnt ++; |
+ } |
+ else if((Sync == 3) && !bCheckDelay) |
+ { |
+ // Datenbyte low |
+ // High-Byte for next channel comes next |
+ SpektrumTimer = MAX_BYTEGAP; |
+ Sync = 2; |
+ FrameCnt ++; |
+ Channel = ((unsigned int)ByteHigh << 8) | c; |
+ if(EE_Parameter.Receiver == RECEIVER_SPEKTRUM) |
+ { |
+ signal = Channel & 0x3ff; |
+ signal -= 0x200; // Offset, range 0x000..0x3ff? |
+ signal = signal/3; // scaling to fit PPM resolution |
+ index = (ByteHigh >> 2) & 0x0f; |
+ } |
+ else |
+ if(EE_Parameter.Receiver == RECEIVER_SPEKTRUM_HI_RES) |
+ { |
+ signal = Channel & 0x7ff; |
+ signal -= 0x400; // Offset, range 0x000..0x7ff? |
+ signal = signal/6; // scaling to fit PPM resolution |
+ index = (ByteHigh >> 3) & 0x0f; |
+ } |
+ else |
+ //if(EE_Parameter.Receiver == RECEIVER_SPEKTRUM_LOW_RES) |
+ { |
+ signal = Channel & 0x3ff; |
+ signal -= 360; // Offset, range 0x000..0x3ff? |
+ signal = signal/2; // scaling to fit PPM resolution |
+ index = (ByteHigh >> 2) & 0x0f; |
+ } |
+ |
+ index++; |
+ if(index < 13) |
+ { |
+ // Stabiles Signal |
+#if defined (RECEIVER_SPEKTRUM_DX7EXP) || defined (RECEIVER_SPEKTRUM_DX8EXP) |
+ if (index == 2) index = 4; // Analog channel reassigment (2 <-> 4) for logical numbering (1,2,3,4) |
+ else if (index == 4) index = 2; |
+#endif |
+ if(abs(signal - PPM_in[index]) < 6) |
+ { |
+ if(EE_Parameter.FailsafeChannel == 0 || PPM_in[EE_Parameter.FailsafeChannel] < 100) // forces Failsafe if the receiver doesn't have 'signal loss' on Failsafe |
+ { |
+ if(SenderOkay < 200) SenderOkay += 10; |
+ else |
+ { |
+ SenderOkay = 200; |
+ TIMSK1 &= ~_BV(ICIE1); // disable PPM-Input |
+ } |
+ } |
+ } |
+ tmp = (3 * (PPM_in[index]) + signal) / 4; |
+ if(tmp > signal+1) tmp--; else |
+ if(tmp < signal-1) tmp++; |
+ |
+#ifdef RECEIVER_SPEKTRUM_DX7EXP |
+ if(index == 6) // FLIGHT-MODE - The channel used for our data uplink |
+ { |
+ if (signal > 100) // SYNC received |
+ { |
+ if (s_exdata[s_excnt] == 125) s_exparity = ~s_exparity; // Bit = 1 -> Re-Invert parity bit |
+ if ((s_excnt == 6 && ((s_exparity != 0 && s_exdata[s_excnt] == -125) || (s_exparity == 0 && s_exdata[s_excnt] == 125))) || (s_excnt == 9 && ((s_exparity == 0 && s_exdata[s_excnt] == -125) || (s_exparity != 0 && s_exdata[s_excnt] == 125)))) // Parity check |
+ { |
+ if (s_exdata[1] == 125 && s_exdata[2] == -125) s_update(5,-125); // Reconstruct tripole Flight-Mode value (CH5) |
+ else if (s_exdata[1] == -125 && s_exdata[2] == -125) s_update(5,0); // Reconstruct tripole Flight-Mode value (CH5) |
+ else if (s_exdata[1] == -125 && s_exdata[2] == 125) s_update(5,125); // Reconstruct tripole Flight-Mode value (CH5) |
+ s_update(6,s_exdata[3]); // Elevator (CH6) |
+ s_update(11,s_exdata[4]); // Aileron (CH11) |
+ s_update(12,s_exdata[5]); // Rudder (CH12) |
+ |
+ if (s_excnt == 9) // New Mode (12 Channels) |
+ { |
+ if (s_exdata[7] == 125) s_update(8,PPM_in[8]+5); // Hover Pitch UP (CH8) |
+ if (s_exdata[8] == 125) s_update(8,PPM_in[8]-5); // Hover Pitch DN (CH8) |
+ if (PPM_in[8] < -125) PPM_in[8] = -125; // Range-Limit |
+ else if (PPM_in[8] > 125) PPM_in[8] = 125; // Range-Limit |
+ s_update(10,s_exdata[6]); // AUX2 (CH10) |
+ } |
+ } |
+ |
+ s_excnt = 0; // Reset bitcounter |
+ s_exparity = 0; // Reset parity bit |
+ } |
+ |
+ if (signal < 10) s_exdata[++s_excnt] = -125; // Bit = 0 -> value = -125 (min) |
+ if (s_excnt == 10) s_excnt = 0; // Overflow protection |
+ if (signal < -100) |
+ { |
+ s_exdata[s_excnt] = 125; // Bit = 1 -> value = 125 (max) |
+ s_exparity = ~s_exparity; // Bit = 1 -> Invert parity bit |
+ } |
+ |
+ } |
+ |
+ if (index < 5 ) s_update(index,tmp); // Update normal potis (CH1-4) |
+ else if (index == 5) s_update(7,signal); // Gear (CH7) |
+ else if (index == 7) s_update(9,signal); // Hover Throttle (CH9) |
+ |
+#elif defined RECEIVER_SPEKTRUM_DX8EXP |
+ if(index == 6) // FLIGHT-MODE - The channel used for our data uplink |
+ { |
+ if (signal > 100) // SYNC received |
+ { |
+ if (s_exdata[s_excnt] == 125) s_exparity = ~s_exparity; // Bit = 1 -> Re-Invert parity bit |
+ if (s_excnt == 9 && ((s_exparity == 0 && s_exdata[s_excnt] == -125) || (s_exparity != 0 && s_exdata[s_excnt] == 125))) // Parity check |
+ { |
+ if (s_exdata[1] == 125 && s_exdata[2] == -125) s_update(5,-125); // Reconstruct tripole Flight-Mode value (CH5) |
+ else if (s_exdata[1] == -125 && s_exdata[2] == -125) s_update(5,0); // Reconstruct tripole Flight-Mode value (CH5) |
+ else if (s_exdata[1] == -125 && s_exdata[2] == 125) s_update(5,125); // Reconstruct tripole Flight-Mode value (CH5) |
+ |
+ if (s_exdata[3] == 125 && s_exdata[6] == -125) s_update(6,125); // Reconstruct tripole Elev D/R value (CH6) |
+ else if (s_exdata[3] == -125 && s_exdata[6] == -125) s_update(6,0); // Reconstruct tripole Elev D/R value (CH6) |
+ else if (s_exdata[3] == -125 && s_exdata[6] == 125) s_update(6,-125); // Reconstruct tripole Elev D/R value (CH6) |
+ |
+ |
+ if (s_exdata[7] == 125 && s_exdata[8] == -125) s_update(9,-125); // Reconstruct tripole AIL D/R value (CH9) |
+ else if (s_exdata[7] == -125 && s_exdata[8] == -125) s_update(9,0); // Reconstruct tripole AIL D/R value (CH9) |
+ else if (s_exdata[7] == -125 && s_exdata[8] == 125) s_update(9,125); // Reconstruct tripole AIL D/R value (CH9) |
+ |
+ s_update(10,s_exdata[5]); // Gear (CH10) |
+ s_update(12,s_exdata[4]); // Mix (CH12) |
+ } |
+ |
+ s_excnt = 0; // Reset bitcounter |
+ s_exparity = 0; // Reset parity bit |
+ } |
+ |
+ if (signal < 10) s_exdata[++s_excnt] = -125; // Bit = 0 -> value = -125 (min) |
+ if (s_excnt == 10) s_excnt = 0; // Overflow protection |
+ if (signal < -100) |
+ { |
+ s_exdata[s_excnt] = 125; // Bit = 1 -> value = 125 (max) |
+ s_exparity = ~s_exparity; // Bit = 1 -> Invert parity bit |
+ } |
+ |
+ } |
+ |
+ if (index < 5 ) s_update(index,tmp); // Update normal potis (CH1-4) |
+ else if (index == 7) s_update(7,signal); // R Trim (CH7) |
+ else if (index == 5) s_update(8,signal); // AUX2 (CH8) |
+ else if (index == 8) s_update(11,signal); // AUX3 (CH11) |
+ |
+#else |
+ if(SenderOkay >= 180) PPM_diff[index] = ((tmp - PPM_in[index]) / 3) * 3; |
+ else PPM_diff[index] = 0; |
+ PPM_in[index] = tmp; |
+#endif |
+ } |
+ else if(index > 17) ReSync = 1; // hier stimmt was nicht: neu synchronisieren |
+ } |
+ else |
+ { |
+ // hier stimmt was nicht: neu synchronisieren |
+ ReSync = 1; |
+ FrameCnt = 0; |
+ Frame2 = 0; |
+ // new frame next, nach fruehestens 7ms erwartet |
+ SpektrumTimer = MIN_FRAMEGAP; |
+ } |
+ |
+ // 16 Bytes eingetroffen -> Komplett |
+ if(FrameCnt >= 16) |
+ { |
+ // Frame complete |
+ if(Frame2 == 0) |
+ { |
+ // Null bedeutet: Neue Daten |
+ // nur beim ersten Frame (CH 0-7) setzen |
+ if(!ReSync) NewPpmData = 0; |
+ } |
+ FrameCnt = 0; |
+ Frame2 = 0; |
+ Sync = 0; |
+ SpektrumTimer = MIN_FRAMEGAP; |
+ } |
+ } |
+} |
+ |
+ |
/tags/V2.02b/Spektrum.h |
---|
0,0 → 1,12 |
/*####################################################################################### |
Dekodieren eines Spektrum Signals |
#######################################################################################*/ |
#ifndef _SPEKTRUM_H |
#define _SPEKTRUM_H |
void SpektrumUartInit(void); |
void SpektrumBinding(void); |
extern unsigned char SpektrumTimer; |
extern void SpektrumParser(unsigned char c); |
#endif //_RC_H |
/tags/V2.02b/analog.c |
---|
0,0 → 1,385 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "main.h" |
#include "eeprom.h" |
volatile int Aktuell_Nick,Aktuell_Roll,Aktuell_Gier,Aktuell_ax, Aktuell_ay,Aktuell_az, UBat = 100; |
volatile int AdWertNickFilter = 0, AdWertRollFilter = 0, AdWertGierFilter = 0; |
volatile int HiResNick = 2500, HiResRoll = 2500; |
volatile int AdWertNick = 0, AdWertRoll = 0, AdWertGier = 0; |
volatile int AdWertAccRoll = 0,AdWertAccNick = 0,AdWertAccHoch = 0; |
volatile long Luftdruck = 32000; |
volatile long SummenHoehe = 0; |
volatile long StartLuftdruck; |
volatile unsigned int MessLuftdruck = 1023; |
unsigned char DruckOffsetSetting; |
signed char ExpandBaro = 0; |
volatile int VarioMeter = 0; |
volatile unsigned int ZaehlMessungen = 0; |
unsigned char AnalogOffsetNick = 115,AnalogOffsetRoll = 115,AnalogOffsetGier = 115; |
volatile unsigned char AdReady = 1; |
unsigned int BaroStep = 500; |
long ExpandBaroStep = 0; |
volatile long HoehenWertF = 0; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
unsigned char CalAthmospheare = 16; |
unsigned char AD_ACC_Y = 6; |
unsigned char AD_ACC_X = 7; |
#endif |
//####################################################################################### |
void ADC_Init(void) |
//####################################################################################### |
{ |
ADMUX = 0;//Referenz ist extern |
ANALOG_ON; |
} |
#define DESIRED_H_ADC 800 |
void CalcExpandBaroStep(void) |
{ |
if(ACC_AltitudeControl) ExpandBaroStep = BaroStep * (long)ExpandBaro; |
else ExpandBaroStep = (16 * BaroStep) * (long)ExpandBaro - 4; |
} |
void SucheLuftruckOffset(void) |
{ |
unsigned int off; |
ExpandBaro = 0; |
CalcExpandBaroStep(); |
off = GetParamByte(PID_PRESSURE_OFFSET); |
if(off < 240) off += 10; |
OCR0A = off; |
OCR0B = 255-off; |
Delay_ms_Mess(150); |
if(MessLuftdruck > DESIRED_H_ADC) off = 240; |
for(; off > 5; off--) |
{ |
OCR0A = off; |
OCR0B = 255-off; |
Delay_ms_Mess(100); |
printf("."); |
if(MessLuftdruck > DESIRED_H_ADC) break; |
} |
DruckOffsetSetting = off; |
SetParamByte(PID_PRESSURE_OFFSET, off); |
if((EE_Parameter.GlobalConfig & CFG_HOEHENREGELUNG) && (DruckOffsetSetting < 10 || DruckOffsetSetting >= 230)) VersionInfo.HardwareError[0] |= FC_ERROR0_PRESSURE; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + correction of the altitude error in higher altitudes |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
CalAthmospheare = 16; |
if(ACC_AltitudeControl) |
{ |
if(PlatinenVersion < 23) { if(off < 140) CalAthmospheare += (160 - off) / 26; } |
else { if(off < 170) CalAthmospheare += (188 - off) / 19; } |
} |
Luftdruck = MessLuftdruck * CalAthmospheare; |
#endif |
Delay_ms_Mess(300); |
} |
void SucheGyroOffset(void) |
{ |
unsigned char i, ready = 0; |
int timeout; |
timeout = SetDelay(2000); |
for(i=140; i != 0; i--) |
{ |
if(ready == 3 && i > 10) i = 9; |
ready = 0; |
if(AdWertNick < 1020) AnalogOffsetNick--; else if(AdWertNick > 1030) AnalogOffsetNick++; else ready++; |
if(AdWertRoll < 1020) AnalogOffsetRoll--; else if(AdWertRoll > 1030) AnalogOffsetRoll++; else ready++; |
if(AdWertGier < 1020) AnalogOffsetGier--; else if(AdWertGier > 1030) AnalogOffsetGier++; else ready++; |
I2C_Start(TWI_STATE_GYRO_OFFSET_TX); |
if(AnalogOffsetNick < 10) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_NICK; AnalogOffsetNick = 10;}; if(AnalogOffsetNick > 245) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_NICK; AnalogOffsetNick = 245;}; |
if(AnalogOffsetRoll < 10) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_ROLL; AnalogOffsetRoll = 10;}; if(AnalogOffsetRoll > 245) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_ROLL; AnalogOffsetRoll = 245;}; |
if(AnalogOffsetGier < 10) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_YAW; AnalogOffsetGier = 10;}; if(AnalogOffsetGier > 245) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_YAW; AnalogOffsetGier = 245;}; |
while(twi_state) if(CheckDelay(timeout)) {printf("\n\r DAC or I2C ERROR! Check I2C, 3Vref, DAC and BL-Ctrl"); break;} |
AdReady = 0; |
ANALOG_ON; |
while(!AdReady); |
if(i<10) Delay_ms_Mess(10); |
} |
Delay_ms_Mess(70); |
} |
/* |
0 n |
1 r |
2 g |
3 y |
4 x |
5 n |
6 r |
7 u |
8 z |
9 L |
10 n |
11 r |
12 g |
13 y |
14 x |
15 n |
16 r |
17 L |
*/ |
//####################################################################################### |
// |
ISR(ADC_vect) |
//####################################################################################### |
{ |
static unsigned char kanal=0,state = 0; |
static signed int subcount = 0; |
static signed int gier1, roll1, nick1, nick_filter, roll_filter; |
static signed int accy, accx; |
static long tmpLuftdruck = 0; |
static char messanzahl_Druck = 0; |
switch(state++) |
{ |
case 0: |
nick1 = ADC; |
kanal = AD_ROLL; |
break; |
case 1: |
roll1 = ADC; |
kanal = AD_GIER; |
break; |
case 2: |
gier1 = ADC; |
kanal = AD_ACC_Y; |
break; |
case 3: |
Aktuell_ay = NeutralAccY - ADC; |
accy = Aktuell_ay; |
kanal = AD_ACC_X; |
break; |
case 4: |
Aktuell_ax = ADC - NeutralAccX; |
accx = Aktuell_ax; |
kanal = AD_NICK; |
break; |
case 5: |
nick1 += ADC; |
kanal = AD_ROLL; |
break; |
case 6: |
roll1 += ADC; |
kanal = AD_UBAT; |
break; |
case 7: |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(EE_Parameter.ExtraConfig & CFG_3_3V_REFERENCE) UBat = (3 * UBat + (11 * ADC) / 30) / 4; // there were some single FC2.1 with 3.3V reference |
else |
#endif |
UBat = (3 * UBat + ADC / 3) / 4; |
kanal = AD_ACC_Z; |
break; |
case 8: |
Aktuell_az = ADC; |
AdWertAccHoch = Aktuell_az - NeutralAccZ - (int) NeutralAccZfine; |
if(!ACC_AltitudeControl) // The Offset must be corrected, because of the ACC-Drift from vibrations |
{ |
if(AdWertAccHoch > 1) |
{ |
if(NeutralAccZ < 750) |
{ |
subcount += 5; |
if(modell_fliegt < 500) subcount += 10; |
if(subcount > 100) { NeutralAccZ++; subcount -= 100;} |
} |
} |
else if(AdWertAccHoch < -1) |
{ |
if(NeutralAccZ > 550) |
{ |
subcount -= 5; |
if(modell_fliegt < 500) subcount -= 10; |
if(subcount < -100) { NeutralAccZ--; subcount += 100;} |
} |
} |
} |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
else |
if(CosAttitude > 8192 - 50) // horizontal leveled within 6° |
{ |
if(AdWertAccHoch > 1) |
{ |
if(++subcount > 5000) |
{ |
if(NeutralAccZfine < 6) NeutralAccZfine++; |
subcount -= 5000; |
} |
} |
else |
if(AdWertAccHoch < -1) |
{ |
if(--subcount < -5000) |
{ |
if(NeutralAccZfine > -6) NeutralAccZfine--; |
subcount += 5000; |
} |
} |
} |
#endif |
Mess_Integral_Hoch += AdWertAccHoch; // Integrieren |
Mess_Integral_Hoch -= Mess_Integral_Hoch / 1024; // dämfen |
kanal = AD_DRUCK; |
break; |
// "case 9:" fehlt hier absichtlich |
case 10: |
nick1 += ADC; |
kanal = AD_ROLL; |
break; |
case 11: |
roll1 += ADC; |
kanal = AD_GIER; |
break; |
case 12: |
if(PlatinenVersion == 10) AdWertGier = (ADC + gier1 + 1) / 2; |
else |
if(PlatinenVersion >= 20) AdWertGier = 2047 - (ADC + gier1); |
else AdWertGier = (ADC + gier1); |
kanal = AD_ACC_Y; |
break; |
case 13: |
Aktuell_ay = NeutralAccY - ADC; |
AdWertAccRoll = (Aktuell_ay + accy); |
kanal = AD_ACC_X; |
break; |
case 14: |
Aktuell_ax = ADC - NeutralAccX; |
AdWertAccNick = (Aktuell_ax + accx); |
kanal = AD_NICK; |
break; |
case 15: |
nick1 += ADC; |
if(PlatinenVersion == 10) nick1 *= 2; else nick1 *= 4; |
AdWertNick = nick1 / 8; |
nick_filter = (nick_filter + nick1) / 2; |
HiResNick = nick_filter - AdNeutralNick; |
AdWertNickFilter = (AdWertNickFilter + HiResNick) / 2; |
kanal = AD_ROLL; |
break; |
case 16: |
roll1 += ADC; |
if(PlatinenVersion == 10) roll1 *= 2; else roll1 *= 4; |
AdWertRoll = roll1 / 8; |
roll_filter = (roll_filter + roll1) / 2; |
HiResRoll = roll_filter - AdNeutralRoll; |
AdWertRollFilter = (AdWertRollFilter + HiResRoll) / 2; |
kanal = AD_DRUCK; |
break; |
case 17: |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(ACC_AltitudeControl) |
{ |
HoehenWertF = (ACC_AltitudeFusion(0) + SA_FILTER/2)/SA_FILTER; // cm |
} |
else HoehenWertF = HoehenWert; |
#else |
HoehenWertF = HoehenWert; |
#endif |
state = 0; |
AdReady = 1; |
ZaehlMessungen++; |
// "break" fehlt hier absichtlich |
case 9: |
MessLuftdruck = ADC; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(ACC_AltitudeControl) |
{ |
// ExpandBaroStep = BaroStep * (long)ExpandBaro; // wird in fc.c aufgerufen |
// tmpLuftdruck = MessLuftdruck - BaroStep * (long)ExpandBaro; // -523 counts per offset step |
tmpLuftdruck = MessLuftdruck - ExpandBaroStep; // -523 counts per offset step |
Luftdruck -= Luftdruck / CalAthmospheare; // 16 |
Luftdruck += tmpLuftdruck; |
HoehenWert = StartLuftdruck - Luftdruck; // cm |
} |
else |
#endif |
{ // old version (until FC V2.1) |
tmpLuftdruck += MessLuftdruck; |
if(++messanzahl_Druck >= 16) // war bis 0.86 "18" |
{ |
signed int tmp; |
// Luftdruck = (7 * Luftdruck + tmpLuftdruck - (16 * BaroStep) * (long)ExpandBaro + 4) / 8; // -523.19 counts per 10 counts offset step |
// ExpandBaroStep = (16 * BaroStep) * (long)ExpandBaro - 4; // wird in fc.c aufgerufen |
Luftdruck = (7 * Luftdruck + tmpLuftdruck - ExpandBaroStep) / 8; // -523.19 counts per 10 counts offset step |
HoehenWert = StartLuftdruck - Luftdruck; |
SummenHoehe -= SummenHoehe/SM_FILTER; |
SummenHoehe += HoehenWert; |
tmp = (HoehenWert - SummenHoehe/SM_FILTER); |
if(tmp > 1024) tmp = 1024; else if(tmp < -1024) tmp = -1024; |
if(abs(VarioMeter) > 700) VarioMeter = (15 * VarioMeter + 8 * tmp)/16; |
else VarioMeter = (31 * VarioMeter + 8 * tmp)/32; |
tmpLuftdruck /= 2; |
messanzahl_Druck = 16/2; |
} |
} |
kanal = AD_NICK; |
break; |
default: |
kanal = 0; state = 0; kanal = AD_NICK; |
break; |
} |
ADMUX = kanal; |
if(state != 0) ANALOG_ON; |
} |
/tags/V2.02b/analog.h |
---|
0,0 → 1,58 |
#ifndef _ANALOG_H |
#define _ANALOG_H |
/*####################################################################################### |
#######################################################################################*/ |
#define SM_FILTER 16 |
#define SA_FILTER 512 |
extern volatile int UBat; |
extern volatile int AdWertNick, AdWertRoll, AdWertGier; |
extern volatile int AdWertAccRoll,AdWertAccNick,AdWertAccHoch; |
extern volatile int HiResNick, HiResRoll; |
extern volatile int AdWertNickFilter, AdWertRollFilter, AdWertGierFilter; |
extern volatile int Aktuell_Nick,Aktuell_Roll,Aktuell_Gier,Aktuell_ax, Aktuell_ay,Aktuell_az; |
extern volatile long Luftdruck; |
extern volatile long SummenHoehe; |
extern volatile char messanzahl_Druck; |
extern volatile unsigned int ZaehlMessungen; |
extern unsigned char DruckOffsetSetting; |
extern signed char ExpandBaro; |
extern volatile int VarioMeter; |
extern volatile unsigned int MessLuftdruck; |
extern volatile long StartLuftdruck; |
extern volatile char MessanzahlNick; |
extern unsigned char AnalogOffsetNick,AnalogOffsetRoll,AnalogOffsetGier; |
extern volatile unsigned char AdReady; |
extern unsigned int BaroStep; |
volatile long HoehenWertF; |
unsigned int ReadADC(unsigned char adc_input); |
void ADC_Init(void); |
void SucheLuftruckOffset(void); |
void SucheGyroOffset(void); |
void CalcExpandBaroStep(void); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
extern unsigned char CalAthmospheare; |
#endif |
#define AD_GIER 0 |
#define AD_ROLL 1 |
#define AD_NICK 2 |
#define AD_DRUCK 3 |
#define AD_UBAT 4 |
#define AD_ACC_Z 5 |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
extern unsigned char AD_ACC_Y; |
extern unsigned char AD_ACC_X; |
#else |
#define AD_ACC_Y 6 |
#define AD_ACC_X 7 |
#endif |
#define ANALOG_OFF ADCSRA=0 |
#define ANALOG_ON ADCSRA=(1<<ADEN)|(1<<ADSC)|(0<<ADATE)|(1<<ADPS2)|(1<<ADPS1)|(1<<ADPS0)|(1<<ADIE) |
//Signle trigger Mode, Interrupt on |
#endif //_ANALOG_H |
/tags/V2.02b/capacity.c |
---|
0,0 → 1,162 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "capacity.h" |
#include "twimaster.h" |
#include "main.h" |
#include "timer0.h" |
#include "analog.h" |
//#define CAPACITY_UPDATE_INTERVAL 10 // 10 ms |
#define CAPACITY_UPDATE_INTERVAL 50 // 50 ms |
#define FC_OFFSET_CURRENT 5 // calculate with a current of 0.5A |
#define BL_OFFSET_CURRENT 2 // calculate with a current of 0.2A |
// global varialbles |
unsigned short update_timer = 0; |
Capacity_t Capacity; |
// initialize capacity calculation |
void Capacity_Init(void) |
{ |
Capacity.ActualCurrent = 0; |
Capacity.UsedCapacity = 0; |
Capacity.ActualPower = 0; |
Capacity.MinOfMaxPWM = 0; |
update_timer = SetDelay(CAPACITY_UPDATE_INTERVAL); |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + extended Current measurement -> 200 = 20A 201 = 21A 255 = 75A (20+55) |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
unsigned int BL3_Current(unsigned char who) // in 0,1A |
{ |
if(Motor[who].Current == 255) return(0); // invalid |
if(Motor[who].Current <= 200) return(Motor[who].Current); |
else |
{ |
if(Motor[who].Version & MOTOR_STATE_BL30) return(200 + 10 * ((unsigned int)Motor[who].Current-200)); |
else return(Motor[who].Current); |
} |
} |
// called in main loop at a regular interval |
void Capacity_Update(void) |
{ |
unsigned short Current, SetSum; // max value will be 255 * 12 = 3060 |
static unsigned short SubCounter = 0; |
static unsigned short CurrentOffset = 0; |
static unsigned long SumCurrentOffset = 0; |
unsigned char i, NumOfMotors, MinOfMaxPWM; |
if(CheckDelay(update_timer)) |
{ |
update_timer += CAPACITY_UPDATE_INTERVAL; // do not use SetDelay to avoid timing leaks |
// determine sum of all present BL currents and setpoints |
Current = 0; |
SetSum = 0; |
NumOfMotors = 0; |
MinOfMaxPWM = 255; |
for(i = 0; i < MAX_MOTORS; i++) |
{ |
if(Motor[i].State & MOTOR_STATE_PRESENT_MASK/* && Mixer.Motor[i][MIX_GAS]*/) |
{ |
NumOfMotors++; |
if(Motor[i].Current > 200) |
{ |
Current += BL3_Current(i); // extended Current measurement -> 200 = 20A 201 = 21A 255 = 75A (20+55) |
} |
else Current += (unsigned int)(Motor[i].Current); |
SetSum += (unsigned int)(Motor[i].SetPoint); |
if(Motor[i].MaxPWM < MinOfMaxPWM) MinOfMaxPWM = Motor[i].MaxPWM; |
} |
} |
Capacity.MinOfMaxPWM = MinOfMaxPWM; |
if(SetSum == 0) // if all setpoints are 0 |
{ // determine offsets of motor currents |
#define CURRENT_AVERAGE 8 // 8bit = 256 * 10 ms = 2.56s average time |
CurrentOffset = (unsigned int)(SumCurrentOffset>>CURRENT_AVERAGE); |
SumCurrentOffset -= CurrentOffset; |
SumCurrentOffset += Current; |
// after averaging set current to static offset |
Current = FC_OFFSET_CURRENT; |
} |
else // some motors are running, includes also motor test condition, where "MotorRunning" is false |
{ // subtract offset |
if(Current > CurrentOffset) Current -= CurrentOffset; |
else Current = 0; |
// add the FC and BL Offsets |
Current += FC_OFFSET_CURRENT + NumOfMotors * BL_OFFSET_CURRENT; |
} |
// update actual Current |
Capacity.ActualCurrent = Current; |
// update actual Power |
if(Current < 255) Capacity.ActualPower = (UBat * Current) / 100; // in W higher resolution |
else Capacity.ActualPower = (UBat * (Current/4)) / 25; // in W |
// update used capacity |
SubCounter += Current; |
// 100mA * 1ms * CAPACITY_UPDATE_INTERVAL = 1 mA * 100 ms * CAPACITY_UPDATE_INTERVAL |
// = 1mA * 0.1s * CAPACITY_UPDATE_INTERVAL = 1mA * 1min / (600 / CAPACITY_UPDATE_INTERVAL) |
// = 1mAh / (36000 / CAPACITY_UPDATE_INTERVAL) |
#define SUB_COUNTER_LIMIT (36000 / CAPACITY_UPDATE_INTERVAL) |
while(SubCounter > SUB_COUNTER_LIMIT) |
{ |
Capacity.UsedCapacity++; // we have one mAh more |
SubCounter -= SUB_COUNTER_LIMIT; // keep the remaining sub part |
} |
} // EOF check delay update timer |
} |
/tags/V2.02b/capacity.h |
---|
0,0 → 1,18 |
#ifndef _CAPACITY_H |
#define _CAPACITY_H |
typedef struct |
{ |
unsigned short ActualCurrent; // in 0.1A Steps |
unsigned short ActualPower; // in 0.1W |
unsigned short UsedCapacity; // in mAh |
unsigned char MinOfMaxPWM; // BL Power Limit |
} __attribute__((packed)) Capacity_t; |
extern Capacity_t Capacity; |
void Capacity_Init(void); |
void Capacity_Update(void); |
#endif //_CAPACITY_H |
/tags/V2.02b/debug.c |
---|
0,0 → 1,48 |
#include "main.h" |
#include "debug.h" |
#ifdef DEBUG // only include functions if DEBUG is defined in main.h |
#warning : "### DEBUG-Funktion aktiv ###" |
unsigned char Debug_BufPtr = 0; |
struct str_Debug tDebug; |
unsigned char SendDebugOutput = 0; |
// function called from _printf_P to output character |
void Debug_Putchar(char c) |
{ |
if (!SendDebugOutput) |
{ |
tDebug.Text[Debug_BufPtr++] = c; // copy character to buffer |
if (Debug_BufPtr > 30) Debug_BufPtr = 30; // avoid buffer overflow |
} |
} |
void DebugSend(unsigned char cmd) |
{ |
if (!SendDebugOutput) |
{ |
tDebug.Cmd = cmd; |
tDebug.Text[Debug_BufPtr] = '\0'; // end of text marker |
Debug_BufPtr = 0; // set bufferindex to 0 |
SendDebugOutput = 1; // set flag to trasmit data the next time in serial transmit function |
} |
} |
#endif |
/* |
add the following code block to the serial transmit function |
#ifdef DEBUG // only include functions if DEBUG is defined |
if(SendDebugOutput && UebertragungAbgeschlossen) |
{ |
SendOutData('0', FC_ADDRESS, 1, (unsigned char *) &tDebug, sizeof(tDebug)); |
SendDebugOutput = 0; |
} |
#endif |
*/ |
/tags/V2.02b/debug.h |
---|
0,0 → 1,60 |
#ifndef _DEBUG_H |
#define _DEBUG_H |
// ---------------------------------------------- |
#define CMD_NONE 0x00 |
#define CMD_RAW_OUTPUT 0x01 |
#define CMD_ERROR_MSG 0x02 |
#define CMD_WARNING_MSG 0x04 |
#define CMD_GREEN_MSG 0x08 |
// debug console in MK-Tool can also handle ANSI ESC seq. |
#define ANSI_ATTRIBUTE_OFF "\033[0m" |
#define ANSI_BOLD "\033[1m" |
#define ANSI_UNDERSCORE "\033[4m" |
#define ANSI_BLINK "\033[5m" |
#define ANSI_INVERSE "\033[7m" |
#define ANSI_INVISIBLE "\033[8m" |
#define ANSI_COLOR_BLACK "\033[30m" |
#define ANSI_COLOR_RED "\033[31m" |
#define ANSI_COLOR_GREEN "\033[32m" |
#define ANSI_COLOR_YELLOW "\033[33m" |
#define ANSI_COLOR_BLUE "\033[34m" |
#define ANSI_COLOR_VIOLETT "\033[35m" |
#define ANSI_COLOR_KOBALTBLUE "\033[36m" |
#define ANSI_COLOR_WHITE "\033[37m" |
#define ANSI_CLEAR "\033[2J" |
#define ANSI_HOME "\033[H" |
// macros for easier use |
#ifdef DEBUG // only include functions if DEBUG is defined in main.h |
#define Debug(format, args...) { _printf_P(&Debug_Putchar, PSTR(format) , ## args); DebugSend(CMD_NONE); } |
#define Debug_Raw(format, args...) { _printf_P(&Debug_Putchar, PSTR(format) , ## args); DebugSend(CMD_RAW_OUTPUT); } |
#define Debug_Warning(format, args...) { _printf_P(&Debug_Putchar, PSTR(format) , ## args); DebugSend(CMD_WARNING_MSG); } |
#define Debug_Error(format, args...) { _printf_P(&Debug_Putchar, PSTR(format) , ## args); DebugSend(CMD_ERROR_MSG); } |
#define Debug_OK(format, args...) { _printf_P(&Debug_Putchar, PSTR(format) , ## args); DebugSend(CMD_GREEN_MSG); } |
struct str_Debug |
{ |
unsigned char Cmd; // bitcoded command |
char Text[32]; |
}; |
extern struct str_Debug tDebug; |
unsigned char SendDebugOutput; |
void Debug_Putchar(char c); |
void DebugSend(unsigned char cmd); |
#else // dummy macros (won't waste flash, if #DEBUG is disabled) |
#define Debug(format, args...) ; |
#define Debug_Raw(format, args...) ; |
#define Debug_Warning(format, args...) ; |
#define Debug_Error(format, args...) ; |
#define Debug_OK(format, args...) ; |
#endif |
// ---------------------------------------------- |
#endif |
/tags/V2.02b/eeprom.c |
---|
0,0 → 1,655 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#ifndef EEMEM |
#define EEMEM __attribute__ ((section (".eeprom"))) |
#endif |
#include <avr/eeprom.h> |
#include <string.h> |
#include "eeprom.h" |
#include "uart.h" |
#include "led.h" |
#include "main.h" |
#include "fc.h" |
#include "twimaster.h" |
paramset_t EE_Parameter; |
MixerTable_t Mixer; |
uint8_t RequiredMotors; |
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len) |
{ |
uint8_t crc = 0xAA; |
uint16_t i; |
for(i=0; i<len; i++) |
{ |
crc += pBuffer[i]; |
} |
return crc; |
} |
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len) |
{ |
uint8_t crc = 0xAA; |
uint16_t off; |
for(off=0; off<len; off++) |
{ |
crc += eeprom_read_byte((uint8_t*)(EEAddr + off));; |
} |
return crc; |
} |
void ParamSet_DefaultStickMapping(void) |
{ |
EE_Parameter.Kanalbelegung[K_GAS] = 1; |
EE_Parameter.Kanalbelegung[K_ROLL] = 2; |
EE_Parameter.Kanalbelegung[K_NICK] = 3; |
EE_Parameter.Kanalbelegung[K_GIER] = 4; |
EE_Parameter.Kanalbelegung[K_POTI1] = 5; |
EE_Parameter.Kanalbelegung[K_POTI2] = 6; |
EE_Parameter.Kanalbelegung[K_POTI3] = 7; |
EE_Parameter.Kanalbelegung[K_POTI4] = 8; |
EE_Parameter.Kanalbelegung[K_POTI5] = 9; |
EE_Parameter.Kanalbelegung[K_POTI6] = 10; |
EE_Parameter.Kanalbelegung[K_POTI7] = 11; |
EE_Parameter.Kanalbelegung[K_POTI8] = 12; |
} |
/***************************************************/ |
/* Default Values for parameter set 1 */ |
/***************************************************/ |
void CommonDefaults(void) |
{ |
EE_Parameter.Revision = EEPARAM_REVISION; |
memset(EE_Parameter.Name,0,12); // delete name |
if(PlatinenVersion >= 20) |
{ |
EE_Parameter.Gyro_D = 10; |
EE_Parameter.Driftkomp = 0; |
EE_Parameter.GyroAccFaktor = 27; |
EE_Parameter.WinkelUmschlagNick = 78; |
EE_Parameter.WinkelUmschlagRoll = 78; |
} |
else |
{ |
EE_Parameter.Gyro_D = 3; |
EE_Parameter.Driftkomp = 32; |
EE_Parameter.GyroAccFaktor = 30; |
EE_Parameter.WinkelUmschlagNick = 85; |
EE_Parameter.WinkelUmschlagRoll = 85; |
} |
EE_Parameter.GyroAccAbgleich = 32; // 1/k |
EE_Parameter.BitConfig = 0; // Looping usw. |
EE_Parameter.GlobalConfig = CFG_ACHSENKOPPLUNG_AKTIV | CFG_KOMPASS_AKTIV | CFG_GPS_AKTIV | CFG_HOEHEN_SCHALTER; |
EE_Parameter.ExtraConfig = CFG_GPS_AID | CFG2_VARIO_BEEP | CFG_LEARNABLE_CAREFREE | CFG_NO_RCOFF_BEEPING; |
EE_Parameter.GlobalConfig3 = CFG3_SPEAK_ALL | CFG3_NO_GPSFIX_NO_START;// |
EE_Parameter.Receiver = RECEIVER_HOTT; |
EE_Parameter.MotorSafetySwitch = 0; |
EE_Parameter.ExternalControl = 0; |
EE_Parameter.Gas_Min = 8; // Wert : 0-32 |
EE_Parameter.Gas_Max = 230; // Wert : 33-247 |
EE_Parameter.KompassWirkung = 64; // Wert : 0-247 |
EE_Parameter.HoeheChannel = 5; // Wert : 0-32 |
EE_Parameter.Hoehe_MinGas = 30; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(ACC_AltitudeControl) |
{ |
EE_Parameter.Hoehe_P = 20; // Wert : 0-32 |
EE_Parameter.Luftdruck_D = 40; // Wert : 0-247 |
EE_Parameter.Hoehe_ACC_Wirkung = 30; // Wert : 0-247 |
EE_Parameter.Hoehe_HoverBand = 1; // Wert : 0-247 |
EE_Parameter.Hoehe_GPS_Z = 0; // Wert : 0-247 |
EE_Parameter.Hoehe_StickNeutralPoint = 127;// Wert : 0-247 (0 = Hover-Estimation) |
EE_Parameter.FailSafeTime = 30; // 0 = off |
} |
else |
#endif |
{ |
EE_Parameter.Hoehe_P = 15; // Wert : 0-32 |
EE_Parameter.Luftdruck_D = 30; // Wert : 0-247 |
EE_Parameter.Hoehe_ACC_Wirkung = 0; // Wert : 0-247 |
EE_Parameter.Hoehe_HoverBand = 8; // Wert : 0-247 |
EE_Parameter.Hoehe_GPS_Z = 20; // Wert : 0-247 |
EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation) |
EE_Parameter.FailSafeTime = 0; // 0 = off |
} |
EE_Parameter.Hoehe_Verstaerkung = 15; // Wert : 0-50 (15 -> ca. +/- 5m/sek bei Stick-Voll-Ausschlag) |
EE_Parameter.StartLandChannel = 0; |
EE_Parameter.LandingSpeed = 12; |
EE_Parameter.UserParam1 = 0; // zur freien Verwendung |
EE_Parameter.UserParam2 = 0; // zur freien Verwendung |
EE_Parameter.UserParam3 = 0; // zur freien Verwendung |
EE_Parameter.UserParam4 = 0; // zur freien Verwendung |
EE_Parameter.UserParam5 = 0; // zur freien Verwendung |
EE_Parameter.UserParam6 = 0; // zur freien Verwendung |
EE_Parameter.UserParam7 = 0; // zur freien Verwendung |
EE_Parameter.UserParam8 = 0; // zur freien Verwendung |
EE_Parameter.ServoNickControl = 128; // Wert : 0-247 // Stellung des Servos |
EE_Parameter.ServoNickComp = 50; // Wert : 0-247 // Einfluss Gyro/Servo |
EE_Parameter.ServoCompInvert = 2; // Wert : 0-247 // Richtung Einfluss Gyro/Servo |
EE_Parameter.ServoNickMin = 24; // Wert : 0-247 // Anschlag |
EE_Parameter.ServoNickMax = 230; // Wert : 0-247 // Anschlag |
EE_Parameter.ServoNickRefresh = 3; |
EE_Parameter.Servo3 = 125; |
EE_Parameter.Servo4 = 125; |
EE_Parameter.Servo5 = 125; |
EE_Parameter.ServoRollControl = 128; // Wert : 0-247 // Stellung des Servos |
EE_Parameter.ServoRollComp = 85; // Wert : 0-247 // Einfluss Gyro/Servo |
EE_Parameter.ServoRollMin = 70; // Wert : 0-247 // Anschlag |
EE_Parameter.ServoRollMax = 220; // Wert : 0-247 // Anschlag |
EE_Parameter.ServoManualControlSpeed = 60; |
EE_Parameter.CamOrientation = 0; // Wert : 0-24 -> 0-360 -> 15° steps |
EE_Parameter.J16Bitmask = 0xAA; |
EE_Parameter.J17Bitmask = 0xCC; |
EE_Parameter.WARN_J16_Bitmask = 0x00; |
EE_Parameter.WARN_J17_Bitmask = 0xAA; |
EE_Parameter.J16Timing = 40; |
EE_Parameter.J17Timing = 40; |
EE_Parameter.NaviOut1Parameter = 0; // Photo release in meter |
EE_Parameter.LoopGasLimit = 50; |
EE_Parameter.LoopThreshold = 90; // Wert: 0-247 Schwelle für Stickausschlag |
EE_Parameter.LoopHysterese = 50; |
EE_Parameter.NaviGpsModeChannel = 6; // Kanal 6 |
EE_Parameter.NaviGpsGain = 100; |
EE_Parameter.NaviGpsP = 100; |
EE_Parameter.NaviGpsI = 90; |
EE_Parameter.NaviGpsD = 120; |
EE_Parameter.NaviGpsA = 40; |
EE_Parameter.NaviGpsPLimit = 75; |
EE_Parameter.NaviGpsILimit = 85; |
EE_Parameter.NaviGpsDLimit = 75; |
EE_Parameter.NaviGpsMinSat = 6; |
EE_Parameter.NaviStickThreshold = 8; |
EE_Parameter.NaviWindCorrection = 50; |
EE_Parameter.NaviAccCompensation = 42; |
EE_Parameter.NaviOperatingRadius = 245; |
EE_Parameter.NaviAngleLimitation = 140; |
EE_Parameter.NaviPH_LoginTime = 2; |
EE_Parameter.OrientationAngle = 0; |
EE_Parameter.CareFreeChannel = 0; |
EE_Parameter.UnterspannungsWarnung = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50) |
EE_Parameter.NotGas = 65; // Wert : 0-247 // Gaswert bei Empangsverlust (ggf. in Prozent) |
EE_Parameter.NotGasZeit = 90; // Wert : 0-247 // Zeit bis auf NotGas geschaltet wird, wg. Rx-Problemen |
EE_Parameter.MotorSmooth = 0; |
EE_Parameter.ComingHomeAltitude = 0; // 0 = don't change |
EE_Parameter.MaxAltitude = 150; // 0 = off |
EE_Parameter.AchsKopplung1 = 125; |
EE_Parameter.AchsKopplung2 = 52; |
EE_Parameter.FailsafeChannel = 0; |
EE_Parameter.ServoFilterNick = 0; |
EE_Parameter.ServoFilterRoll = 0; |
EE_Parameter.CompassOffset = 0; |
EE_Parameter.AutoLandingVoltage = 31; |
} |
/* |
void ParamSet_DefaultSet1(void) // sport |
{ |
CommonDefaults(); |
EE_Parameter.Stick_P = 14; // Wert : 1-20 |
EE_Parameter.Stick_D = 16; // Wert : 0-20 |
EE_Parameter.StickGier_P = 12; // Wert : 1-20 |
EE_Parameter.Gyro_P = 80; // Wert : 0-247 |
EE_Parameter.Gyro_I = 150; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_P = 80; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_I = 150; // Wert : 0-247 |
EE_Parameter.Gyro_Stability = 6; // Wert : 1-8 |
EE_Parameter.I_Faktor = 32; |
EE_Parameter.CouplingYawCorrection = 1; |
EE_Parameter.GyroAccAbgleich = 16; // 1/k; |
EE_Parameter.DynamicStability = 100; |
memcpy(EE_Parameter.Name, "Sport\0", 12); |
EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1); |
} |
*/ |
/***************************************************/ |
/* Default Values for parameter set 1 */ |
/***************************************************/ |
void ParamSet_DefaultSet1(void) // normal |
{ |
CommonDefaults(); |
EE_Parameter.Stick_P = 10; // Wert : 1-20 |
EE_Parameter.Stick_D = 16; // Wert : 0-20 |
EE_Parameter.StickGier_P = 6; // Wert : 1-20 |
EE_Parameter.Gyro_P = 90; // Wert : 0-247 |
EE_Parameter.Gyro_I = 120; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_P = 90; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_I = 120; // Wert : 0-247 |
EE_Parameter.Gyro_Stability = 6; // Wert : 1-8 |
EE_Parameter.I_Faktor = 32; |
EE_Parameter.CouplingYawCorrection = 60; |
EE_Parameter.DynamicStability = 75; |
memcpy(EE_Parameter.Name, "Fast",4); |
EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1); |
} |
/***************************************************/ |
/* Default Values for parameter set 2 */ |
/***************************************************/ |
void ParamSet_DefaultSet2(void) // Agil |
{ |
CommonDefaults(); |
EE_Parameter.Stick_P = 8; // Wert : 1-20 |
EE_Parameter.Stick_D = 16; // Wert : 0-20 |
EE_Parameter.StickGier_P = 6; // Wert : 1-20 |
EE_Parameter.Gyro_P = 100; // Wert : 0-247 |
EE_Parameter.Gyro_I = 120; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_P = 100; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_I = 120; // Wert : 0-247 |
EE_Parameter.Gyro_Stability = 6; // Wert : 1-8 |
EE_Parameter.I_Faktor = 16; |
EE_Parameter.CouplingYawCorrection = 70; |
EE_Parameter.DynamicStability = 70; |
memcpy(EE_Parameter.Name, "Agile",5); |
EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1); |
} |
/***************************************************/ |
/* Default Values for parameter set 3 */ |
/***************************************************/ |
void ParamSet_DefaultSet3(void) // Easy |
{ |
CommonDefaults(); |
EE_Parameter.Stick_P = 6; // Wert : 1-20 |
EE_Parameter.Stick_D = 10; // Wert : 0-20 |
EE_Parameter.StickGier_P = 4; // Wert : 1-20 |
EE_Parameter.Gyro_P = 100; // Wert : 0-247 |
EE_Parameter.Gyro_I = 120; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_P = 100; // Wert : 0-247 |
EE_Parameter.Gyro_Gier_I = 120; // Wert : 0-247 |
EE_Parameter.Gyro_Stability = 6; // Wert : 1-8 |
EE_Parameter.I_Faktor = 16; |
EE_Parameter.CouplingYawCorrection = 70; |
EE_Parameter.DynamicStability = 70; |
memcpy(EE_Parameter.Name, "Easy", 4); |
EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1); |
} |
/***************************************************/ |
/* Read Parameter from EEPROM as byte */ |
/***************************************************/ |
uint8_t GetParamByte(uint16_t param_id) |
{ |
return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id)); |
} |
/***************************************************/ |
/* Write Parameter to EEPROM as byte */ |
/***************************************************/ |
void SetParamByte(uint16_t param_id, uint8_t value) |
{ |
eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value); |
} |
/***************************************************/ |
/* Read Parameter from EEPROM as word */ |
/***************************************************/ |
uint16_t GetParamWord(uint16_t param_id) |
{ |
return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id)); |
} |
/***************************************************/ |
/* Write Parameter to EEPROM as word */ |
/***************************************************/ |
void SetParamWord(uint16_t param_id, uint16_t value) |
{ |
eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value); |
} |
/***************************************************/ |
/* Read Parameter Set from EEPROM */ |
/***************************************************/ |
// number [1..5] |
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber) |
{ |
uint8_t crc; |
uint16_t eeaddr; |
// range the setnumber |
if((1 > setnumber) || (setnumber > 5)) setnumber = 3; |
// calculate eeprom addr |
eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1); |
// calculate checksum from eeprom |
crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1); |
// check crc |
if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0; |
// check revision |
if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0; |
// read paramset from eeprom |
eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN); |
LED_Init(); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
LIBFC_HoTT_Clear(); |
#endif |
return 1; |
} |
/***************************************************/ |
/* Write Parameter Set to EEPROM */ |
/***************************************************/ |
// number [1..5] |
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber) |
{ |
uint8_t crc; |
if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom |
{ |
if(setnumber > 5) setnumber = 5; |
if(setnumber < 1) return 0; |
LIBFC_CheckSettings(); |
if(EE_Parameter.GlobalConfig3 & CFG3_VARIO_FAILSAFE) // check the Setting: Not more than 100% emergency gas |
{ |
if(EE_Parameter.NotGas > 99) EE_Parameter.NotGas = 80; // i.e. 80% of Hovergas |
} |
// update checksum |
EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1); |
// write paramset to eeprom |
eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN); |
// backup channel settings to separate block in eeprom |
eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung)); |
// write crc of channel block to eeprom |
crc = RAM_Checksum((uint8_t*)(EE_Parameter.Kanalbelegung), sizeof(EE_Parameter.Kanalbelegung)); |
eeprom_write_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)), crc); |
// update active settings number |
SetActiveParamSet(setnumber); |
LED_Init(); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
LIBFC_HoTT_Clear(); |
#endif |
return 1; |
} |
// wrong revision |
return 0; |
} |
/***************************************************/ |
/* Read MixerTable from EEPROM */ |
/***************************************************/ |
uint8_t MixerTable_ReadFromEEProm(void) |
{ |
uint8_t crc; |
// calculate checksum in eeprom |
crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1); |
// check crc |
if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0; |
// check revision |
if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0; |
// read mixer table |
eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer)); |
return 1; |
} |
/***************************************************/ |
/* Write Mixer Table to EEPROM */ |
/***************************************************/ |
uint8_t MixerTable_WriteToEEProm(void) |
{ |
if(Mixer.Revision == EEMIXER_REVISION) |
{ |
// update crc |
Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1); |
// write to eeprom |
eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer)); |
return 1; |
} |
else return 0; |
} |
/***************************************************/ |
/* Default Values for Mixer Table */ |
/***************************************************/ |
void MixerTable_Default(void) // Quadro |
{ |
uint8_t i; |
Mixer.Revision = EEMIXER_REVISION; |
// clear mixer table |
for(i = 0; i < 16; i++) |
{ |
Mixer.Motor[i][MIX_GAS] = 0; |
Mixer.Motor[i][MIX_NICK] = 0; |
Mixer.Motor[i][MIX_ROLL] = 0; |
Mixer.Motor[i][MIX_YAW] = 0; |
} |
// default = Quadro |
Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] = 0; Mixer.Motor[0][MIX_YAW] = +64; |
Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] = 0; Mixer.Motor[1][MIX_YAW] = +64; |
Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] = 0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64; |
Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] = 0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64; |
memcpy(Mixer.Name, "Quadro\0\0\0\0\0\0", 12); |
Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1); |
} |
/***************************************************/ |
/* Get active parameter set */ |
/***************************************************/ |
uint8_t GetActiveParamSet(void) |
{ |
uint8_t setnumber; |
setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET)); |
if(setnumber > 5) |
{ |
setnumber = 3; |
eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber); |
} |
ActiveParamSet = setnumber; |
return(setnumber); |
} |
/***************************************************/ |
/* Set active parameter set */ |
/***************************************************/ |
void SetActiveParamSet(uint8_t setnumber) |
{ |
if(setnumber > 5) setnumber = 5; |
if(setnumber < 1) setnumber = 1; |
ActiveParamSet = setnumber; |
eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber); |
} |
/***************************************************/ |
/* Set default parameter set */ |
/***************************************************/ |
void SetDefaultParameter(uint8_t set, uint8_t restore_channels) |
{ |
if(set > 5) set = 5; |
else if(set < 1) set = 1; |
switch(set) |
{ |
case 1: |
ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport) |
break; |
case 2: |
ParamSet_DefaultSet2(); // Kamera |
break; |
case 3: |
ParamSet_DefaultSet3(); // Beginner |
break; |
default: |
ParamSet_DefaultSet3(); // Beginner |
break; |
} |
if(restore_channels) |
{ |
uint8_t crc; |
// 1st check for a valid channel backup in eeprom |
crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung)); |
if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) ) |
{ |
eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung)); |
} |
else ParamSet_DefaultStickMapping(); |
} |
else ParamSet_DefaultStickMapping(); |
ParamSet_WriteToEEProm(set); |
} |
/***************************************************/ |
/* Initialize EEPROM Parameter Sets */ |
/***************************************************/ |
void ParamSet_Init(void) |
{ |
uint8_t channel_backup = 0, bad_params = 0, ee_default = 0,i; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(PlatinenVersion != GetParamByte(PID_HARDWARE_VERSION)) |
{ |
if(PlatinenVersion == 22 && GetParamByte(PID_HARDWARE_VERSION) == 21 && !(PIND & 0x10)) SetParamByte(PID_EE_REVISION,0); // reset the Settings if the Version changed to V2.2 |
SetParamByte(PID_HARDWARE_VERSION,PlatinenVersion); // Remember the Version number |
wdt_enable(WDTO_15MS); // Reset-Commando |
printf("\n\r--> Hardware Version Byte Changed <--"); |
while(1); |
} |
#endif |
if((EEPARAM_REVISION) != GetParamByte(PID_EE_REVISION)) |
{ |
ee_default = 1; // software update or forced by mktool |
} |
// 1st check for a valid channel backup in eeprom |
i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung)); |
if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)))) channel_backup = 1; |
// parameter check |
// check all 5 parameter settings |
for (i = 1;i < 6; i++) |
{ |
if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom |
{ |
bad_params = 1; |
printf("\n\rGenerating default Parameter Set %d",i); |
switch(i) |
{ |
case 1: |
ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport) |
break; |
case 2: |
ParamSet_DefaultSet2(); // Normal |
break; |
default: |
ParamSet_DefaultSet3(); // Easy |
break; |
} |
if(channel_backup) // if we have an channel mapping backup in eeprom |
{ // restore it from eeprom |
eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung)); |
} |
else |
{ // use default mapping |
ParamSet_DefaultStickMapping(); |
} |
ParamSet_WriteToEEProm(i); |
} |
} |
if(bad_params) // at least one of the parameter settings were invalid |
{ |
// default-Setting is parameter set 3 |
SetActiveParamSet(3); |
} |
// read active parameter set to ParamSet stucture |
i = GetActiveParamSet(); |
ParamSet_ReadFromEEProm(i); |
printf("\n\rUsing Parameter Set %d", i); |
// load mixer table |
if(GetParamByte(PID_EE_REVISION) == 0xff || !MixerTable_ReadFromEEProm() ) |
{ |
printf("\n\rGenerating default Mixer Table"); |
MixerTable_Default(); // Quadro |
MixerTable_WriteToEEProm(); |
} |
if(ee_default) SetParamByte(PID_EE_REVISION, (EEPARAM_REVISION)); |
// determine motornumber |
RequiredMotors = 0; |
for(i = 0; i < 16; i++) |
{ |
if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++; |
} |
printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors); |
PrintLine();// ("\n\r==================================="); |
} |
/tags/V2.02b/eeprom.h |
---|
0,0 → 1,284 |
#ifndef _EEPROM_H |
#define _EEPROM_H |
#include <inttypes.h> |
#include "twimaster.h" |
#define EEPARAM_REVISION 97 // is count up, if paramater stucture has changed (compatibility) |
#define EEMIXER_REVISION 1 // is count up, if mixer stucture has changed (compatibility) |
#define EEPROM_ADR_PARAM_BEGIN 0 |
#define EE_DUMMY 0 // Byte |
#define PID_EE_REVISION 1 // byte |
#define PID_ACTIVE_SET 2 // byte |
#define PID_PRESSURE_OFFSET 3 // byte |
#define PID_ACC_NICK 4 // word |
#define PID_ACC_ROLL 6 // word |
#define PID_ACC_TOP 8 // word |
#define PID_FLIGHT_MINUTES_TOTAL 10 // word |
#define PID_FLIGHT_MINUTES 14 // word |
#define PID_SPEAK_HOTT_CFG 16 // Byte |
#define PID_HARDWARE_VERSION 17 // Byte |
#define EEPROM_ADR_CHANNELS 80 // 80 - 93, 12 bytes + 1 byte crc |
#define EEPROM_ADR_PARAMSET 100 // 100 - 725, 5 * 125 bytes |
#define EEPROM_ADR_MIXERTABLE 1000 // 1000 - 1078, 78 bytes |
#define EEPROM_ADR_BLCONFIG 1200 // 1200 - 1296, 12 * 8 bytes |
#define MIX_GAS 0 |
#define MIX_NICK 1 |
#define MIX_ROLL 2 |
#define MIX_YAW 3 |
typedef struct |
{ |
uint8_t Revision; |
int8_t Name[12]; |
int8_t Motor[16][4]; |
uint8_t crc; |
} __attribute__((packed)) MixerTable_t; |
extern MixerTable_t Mixer; |
extern uint8_t RequiredMotors; |
//GlobalConfig3 |
#define CFG3_NO_SDCARD_NO_START 0x01 |
#define CFG3_DPH_MAX_RADIUS 0x02 |
#define CFG3_VARIO_FAILSAFE 0x04 |
#define CFG3_MOTOR_SWITCH_MODE 0x08 |
#define CFG3_NO_GPSFIX_NO_START 0x10 |
#define CFG3_USE_NC_FOR_OUT1 0x20 |
#define CFG3_SPEAK_ALL 0x40 |
#define CFG3_SERVO_NICK_COMP_OFF 0x80 |
//GlobalConfig |
#define CFG_HOEHENREGELUNG 0x01 |
#define CFG_HOEHEN_SCHALTER 0x02 |
#define CFG_HEADING_HOLD 0x04 |
#define CFG_KOMPASS_AKTIV 0x08 |
#define CFG_KOMPASS_FIX 0x10 |
#define CFG_GPS_AKTIV 0x20 |
#define CFG_ACHSENKOPPLUNG_AKTIV 0x40 |
#define CFG_DREHRATEN_BEGRENZER 0x80 |
//BitConfig |
#define CFG_LOOP_OBEN 0x01 |
#define CFG_LOOP_UNTEN 0x02 |
#define CFG_LOOP_LINKS 0x04 |
#define CFG_LOOP_RECHTS 0x08 |
#define CFG_MOTOR_BLINK1 0x10 |
#define CFG_MOTOR_OFF_LED1 0x20 |
#define CFG_MOTOR_OFF_LED2 0x40 |
#define CFG_MOTOR_BLINK2 0x80 |
// ExtraConfig |
#define CFG2_HEIGHT_LIMIT 0x01 |
#define CFG2_VARIO_BEEP 0x02 |
#define CFG_SENSITIVE_RC 0x04 |
#define CFG_3_3V_REFERENCE 0x08 |
#define CFG_NO_RCOFF_BEEPING 0x10 |
#define CFG_GPS_AID 0x20 |
#define CFG_LEARNABLE_CAREFREE 0x40 |
#define CFG_IGNORE_MAG_ERR_AT_STARTUP 0x80 |
// bit mask for ParamSet.Config0 |
#define CFG0_AIRPRESS_SENSOR 0x01 |
#define CFG0_HEIGHT_SWITCH 0x02 |
#define CFG0_HEADING_HOLD 0x04 |
#define CFG0_COMPASS_ACTIVE 0x08 |
#define CFG0_COMPASS_FIX 0x10 |
#define CFG0_GPS_ACTIVE 0x20 |
#define CFG0_AXIS_COUPLING_ACTIVE 0x40 |
#define CFG0_ROTARY_RATE_LIMITER 0x80 |
// bitcoding for EE_Parameter.ServoCompInvert |
#define SERVO_NICK_INV 0x01 |
#define SERVO_ROLL_INV 0x02 |
#define SERVO_RELATIVE 0x04 // direct poti control or relative moving of the servo value |
// defines for the receiver selection |
#define RECEIVER_PPM 0 |
#define RECEIVER_SPEKTRUM 1 |
#define RECEIVER_SPEKTRUM_HI_RES 2 |
#define RECEIVER_SPEKTRUM_LOW_RES 3 |
#define RECEIVER_JETI 4 |
#define RECEIVER_ACT_DSL 5 |
#define RECEIVER_HOTT 6 |
#define RECEIVER_SBUS 7 |
#define RECEIVER_USER 8 |
#define RECEIVER_UNKNOWN 0xFF |
// defines for lookup ParamSet.ChannelAssignment |
#define K_NICK 0 |
#define K_ROLL 1 |
#define K_GAS 2 |
#define K_GIER 3 |
#define K_POTI1 4 |
#define K_POTI2 5 |
#define K_POTI3 6 |
#define K_POTI4 7 |
#define K_POTI5 8 |
#define K_POTI6 9 |
#define K_POTI7 10 |
#define K_POTI8 11 |
// values above 247 representing poti1 to poti8 |
// poti1 = 255 |
// poti2 = 254 |
// poti3 = 253 |
// poti4 = 252 |
// poti5 = 251 |
// poti6 = 250 |
// poti7 = 249 |
// poti8 = 248 |
typedef struct |
{ |
unsigned char Revision; |
unsigned char Kanalbelegung[12]; // GAS[0], GIER[1],NICK[2], ROLL[3], POTI1, POTI2, POTI3 |
unsigned char GlobalConfig; // 0x01=Höhenregler aktiv,0x02=Kompass aktiv, 0x04=GPS aktiv, 0x08=Heading Hold aktiv |
unsigned char Hoehe_MinGas; // Wert : 0-100 |
unsigned char Luftdruck_D; // Wert : 0-250 |
unsigned char HoeheChannel; // Wert : 0-32 |
unsigned char Hoehe_P; // Wert : 0-32 |
unsigned char Hoehe_Verstaerkung; // Wert : 0-50 |
unsigned char Hoehe_ACC_Wirkung; // Wert : 0-250 |
unsigned char Hoehe_HoverBand; // Wert : 0-250 |
unsigned char Hoehe_GPS_Z; // Wert : 0-250 |
unsigned char Hoehe_StickNeutralPoint;// Wert : 0-250 |
unsigned char Stick_P; // Wert : 1-6 |
unsigned char Stick_D; // Wert : 0-64 |
unsigned char StickGier_P; // Wert : 1-20 |
unsigned char Gas_Min; // Wert : 0-32 |
unsigned char Gas_Max; // Wert : 33-250 |
unsigned char GyroAccFaktor; // Wert : 1-64 |
unsigned char KompassWirkung; // Wert : 0-32 |
unsigned char Gyro_P; // Wert : 10-250 |
unsigned char Gyro_I; // Wert : 0-250 |
unsigned char Gyro_D; // Wert : 0-250 |
unsigned char Gyro_Gier_P; // Wert : 10-250 |
unsigned char Gyro_Gier_I; // Wert : 0-250 |
unsigned char Gyro_Stability; // Wert : 0-16 |
unsigned char UnterspannungsWarnung; // Wert : 0-250 |
unsigned char NotGas; // Wert : 0-250 //Gaswert bei Empängsverlust |
unsigned char NotGasZeit; // Wert : 0-250 // Zeitbis auf NotGas geschaltet wird, wg. Rx-Problemen |
unsigned char Receiver; // 0= Summensignal, 1= Spektrum, 2 =Jeti, 3=ACT DSL, 4=ACT S3D |
unsigned char I_Faktor; // Wert : 0-250 |
unsigned char UserParam1; // Wert : 0-250 |
unsigned char UserParam2; // Wert : 0-250 |
unsigned char UserParam3; // Wert : 0-250 |
unsigned char UserParam4; // Wert : 0-250 |
unsigned char ServoNickControl; // Wert : 0-250 // Stellung des Servos |
unsigned char ServoNickComp; // Wert : 0-250 // Einfluss Gyro/Servo |
unsigned char ServoNickMin; // Wert : 0-250 // Anschlag |
unsigned char ServoNickMax; // Wert : 0-250 // Anschlag |
//--- Seit V0.75 |
unsigned char ServoRollControl; // Wert : 0-250 // Stellung des Servos |
unsigned char ServoRollComp; // Wert : 0-250 |
unsigned char ServoRollMin; // Wert : 0-250 |
unsigned char ServoRollMax; // Wert : 0-250 |
//--- |
unsigned char ServoNickRefresh; // Speed of the Servo |
unsigned char ServoManualControlSpeed;// |
unsigned char CamOrientation; // |
unsigned char Servo3; // Value or mapping of the Servo Output |
unsigned char Servo4; // Value or mapping of the Servo Output |
unsigned char Servo5; // Value or mapping of the Servo Output |
unsigned char LoopGasLimit; // Wert: 0-250 max. Gas während Looping |
unsigned char LoopThreshold; // Wert: 0-250 Schwelle für Stickausschlag |
unsigned char LoopHysterese; // Wert: 0-250 Hysterese für Stickausschlag |
unsigned char AchsKopplung1; // Wert: 0-250 Faktor, mit dem Gier die Achsen Roll und Nick koppelt (NickRollMitkopplung) |
unsigned char AchsKopplung2; // Wert: 0-250 Faktor, mit dem Nick und Roll verkoppelt werden |
unsigned char CouplingYawCorrection; // Wert: 0-250 Faktor, mit dem Nick und Roll verkoppelt werden |
unsigned char WinkelUmschlagNick; // Wert: 0-250 180°-Punkt |
unsigned char WinkelUmschlagRoll; // Wert: 0-250 180°-Punkt |
unsigned char GyroAccAbgleich; // 1/k (Koppel_ACC_Wirkung) |
unsigned char Driftkomp; |
unsigned char DynamicStability; |
unsigned char UserParam5; // Wert : 0-250 |
unsigned char UserParam6; // Wert : 0-250 |
unsigned char UserParam7; // Wert : 0-250 |
unsigned char UserParam8; // Wert : 0-250 |
//---Output --------------------------------------------- |
unsigned char J16Bitmask; // for the J16 Output |
unsigned char J16Timing; // for the J16 Output |
unsigned char J17Bitmask; // for the J17 Output |
unsigned char J17Timing; // for the J17 Output |
// seit version V0.75c |
unsigned char WARN_J16_Bitmask; // for the J16 Output |
unsigned char WARN_J17_Bitmask; // for the J17 Output |
//---NaviCtrl--------------------------------------------- |
unsigned char NaviOut1Parameter; // for the J16 Output |
unsigned char NaviGpsModeChannel; // Parameters for the Naviboard |
unsigned char NaviGpsGain; |
unsigned char NaviGpsP; |
unsigned char NaviGpsI; |
unsigned char NaviGpsD; |
unsigned char NaviGpsPLimit; |
unsigned char NaviGpsILimit; |
unsigned char NaviGpsDLimit; |
unsigned char NaviGpsA; |
unsigned char NaviGpsMinSat; |
unsigned char NaviStickThreshold; |
unsigned char NaviWindCorrection; |
unsigned char NaviAccCompensation; // New since 0.86 -> was: SpeedCompensation |
unsigned char NaviOperatingRadius; |
unsigned char NaviAngleLimitation; |
unsigned char NaviPH_LoginTime; |
//---Ext.Ctrl--------------------------------------------- |
unsigned char ExternalControl; // for serial Control |
//---CareFree--------------------------------------------- |
unsigned char OrientationAngle; // Where is the front-direction? |
unsigned char CareFreeChannel; // switch for CareFree |
unsigned char MotorSafetySwitch; |
unsigned char MotorSmooth; |
unsigned char ComingHomeAltitude; |
unsigned char FailSafeTime; |
unsigned char MaxAltitude; |
unsigned char FailsafeChannel; // if the value of this channel is > 100, the MK reports "RC-Lost" |
unsigned char ServoFilterNick; |
unsigned char ServoFilterRoll; |
unsigned char StartLandChannel; |
unsigned char LandingSpeed; |
unsigned char CompassOffset; |
unsigned char AutoLandingVoltage; // in 0,1V 0 -> disabled |
//------------------------------------------------ |
unsigned char BitConfig; // (war Loop-Cfg) Bitcodiert: 0x01=oben, 0x02=unten, 0x04=links, 0x08=rechts / wird getrennt behandelt |
unsigned char ServoCompInvert; // // 0x01 = Nick, 0x02 = Roll, 0x04 = relative moving // WICHTIG!!! am Ende lassen |
unsigned char ExtraConfig; // bitcodiert |
unsigned char GlobalConfig3; // bitcodiert |
char Name[12]; |
unsigned char crc; // must be the last byte! |
} paramset_t; // 127 bytes |
#define PARAMSET_STRUCT_LEN sizeof(paramset_t) |
extern paramset_t EE_Parameter; |
extern uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len); |
extern void ParamSet_Init(void); |
extern void SetDefaultParameter(uint8_t set, uint8_t restore_channels); |
extern uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber); |
extern uint8_t ParamSet_WriteToEEProm(uint8_t setnumber); |
extern uint8_t GetActiveParamSet(void); |
extern void SetActiveParamSet(uint8_t setnumber); |
extern uint8_t MixerTable_ReadFromEEProm(void); |
extern uint8_t MixerTable_WriteToEEProm(void); |
extern uint8_t GetParamByte(uint16_t param_id); |
extern void SetParamByte(uint16_t param_id, uint8_t value); |
extern uint16_t GetParamWord(uint16_t param_id); |
extern void SetParamWord(uint16_t param_id, uint16_t value); |
#endif //_EEPROM_H |
/tags/V2.02b/fc.c |
---|
0,0 → 1,2221 |
/*####################################################################################### |
Flight Control |
#######################################################################################*/ |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "main.h" |
#include "mymath.h" |
#include "isqrt.h" |
unsigned char h,m,s; |
unsigned int BaroExpandActive = 0; |
int MesswertNick,MesswertRoll,MesswertGier,MesswertGierBias, RohMesswertNick,RohMesswertRoll; |
int TrimNick, TrimRoll; |
int AdNeutralNick = 0,AdNeutralRoll = 0,AdNeutralGier = 0,StartNeutralRoll = 0,StartNeutralNick = 0; |
int Mittelwert_AccNick, Mittelwert_AccRoll; |
unsigned int NeutralAccX=0, NeutralAccY=0; |
int NaviAccNick, NaviAccRoll,NaviCntAcc = 0; |
int NeutralAccZ = 0; |
signed char NeutralAccZfine = 0; |
unsigned char ControlHeading = 0;// in 2° |
long IntegralNick = 0,IntegralNick2 = 0; |
long IntegralRoll = 0,IntegralRoll2 = 0; |
long IntegralAccNick = 0,IntegralAccRoll = 0,IntegralAccZ = 0; |
long Integral_Gier = 0; |
long Mess_IntegralNick = 0,Mess_IntegralNick2 = 0; |
long Mess_IntegralRoll = 0,Mess_IntegralRoll2 = 0; |
long Mess_Integral_Gier = 0,Mess_Integral_Gier2 = 0; |
long MittelIntegralNick,MittelIntegralRoll,MittelIntegralNick2,MittelIntegralRoll2; |
long SummeNick=0,SummeRoll=0; |
volatile long Mess_Integral_Hoch = 0; |
int KompassValue = -1; |
int KompassSollWert = 0; |
//int KompassRichtung = 0; |
char CalculateCompassTimer = 100; |
unsigned char KompassFusion = 32; |
unsigned int KompassSignalSchlecht = 50; |
unsigned char MAX_GAS,MIN_GAS; |
unsigned char HoehenReglerAktiv = 0; |
unsigned char TrichterFlug = 0; |
long Umschlag180Nick = 250000L, Umschlag180Roll = 250000L; |
long ErsatzKompass; |
int ErsatzKompassInGrad; // Kompasswert in Grad |
int GierGyroFehler = 0; |
char GyroFaktor,GyroFaktorGier; |
char IntegralFaktor,IntegralFaktorGier; |
int DiffNick,DiffRoll; |
int StickGasHover = 127, HoverGasMin = 0, HoverGasMax = 1023; |
int StickNick = 0,StickRoll = 0,StickGier = 0,StickGas = 0; |
//int Poti1 = 0, Poti2 = 0, Poti3 = 0, Poti4 = 0, Poti5 = 0, Poti6 = 0, Poti7 = 0, Poti8 = 0; |
unsigned char Poti[9] = {0,0,0,0,0,0,0,0}; |
volatile unsigned char SenderOkay = 0; |
char MotorenEin = 0,StartTrigger = 0; |
long HoehenWert = 0; |
long SollHoehe = 0; |
signed int AltitudeSetpointTrimming = 0; |
long FromNC_AltitudeSetpoint = 0; |
unsigned char FromNC_AltitudeSpeed = 0; |
unsigned char carefree_old = 50; // to make the Beep when switching |
signed char WaypointTrimming = 0; |
int CompassGierSetpoint = 0; |
unsigned char CalibrationDone = 0; |
char NeueKompassRichtungMerken = 0; |
int LageKorrekturRoll = 0,LageKorrekturNick = 0, HoverGas = 0; |
//float Ki = FAKTOR_I; |
int Ki = 10300 / 33; |
unsigned char Looping_Nick = 0,Looping_Roll = 0; |
unsigned char Looping_Links = 0, Looping_Rechts = 0, Looping_Unten = 0, Looping_Oben = 0; |
unsigned char Parameter_Luftdruck_D = 48; // Wert : 0-250 |
unsigned char Parameter_HoehenSchalter = 0; // Wert : 0-250 |
unsigned char Parameter_Hoehe_P = 16; // Wert : 0-32 |
unsigned char Parameter_Hoehe_ACC_Wirkung = 58; // Wert : 0-250 |
unsigned char Parameter_KompassWirkung = 64; // Wert : 0-250 |
unsigned char Parameter_Hoehe_GPS_Z = 64; // Wert : 0-250 |
unsigned char Parameter_Gyro_D = 8; // Wert : 0-250 |
unsigned char Parameter_Gyro_P = 150; // Wert : 10-250 |
unsigned char Parameter_Gyro_I = 150; // Wert : 0-250 |
unsigned char Parameter_Gyro_Gier_P = 150; // Wert : 10-250 |
unsigned char Parameter_Gyro_Gier_I = 150; // Wert : 10-250 |
unsigned char Parameter_Gier_P = 2; // Wert : 1-20 |
unsigned char Parameter_I_Faktor = 10; // Wert : 1-20 |
unsigned char Parameter_UserParam1 = 0; |
unsigned char Parameter_UserParam2 = 0; |
unsigned char Parameter_UserParam3 = 0; |
unsigned char Parameter_UserParam4 = 0; |
unsigned char Parameter_UserParam5 = 0; |
unsigned char Parameter_UserParam6 = 0; |
unsigned char Parameter_UserParam7 = 0; |
unsigned char Parameter_UserParam8 = 0; |
unsigned char Parameter_NickControl = 100; |
unsigned char Parameter_ServoNickControl = 100; |
unsigned char Parameter_ServoRollControl = 100; |
unsigned char Parameter_ServoNickComp = 50; |
unsigned char Parameter_ServoRollComp = 85; |
unsigned char Parameter_LoopGasLimit = 70; |
unsigned char Parameter_AchsKopplung1 = 90; |
unsigned char Parameter_AchsKopplung2 = 65; |
unsigned char Parameter_CouplingYawCorrection = 64; |
//unsigned char Parameter_AchsGegenKopplung1 = 0; |
unsigned char Parameter_DynamicStability = 100; |
unsigned char Parameter_J16Bitmask; // for the J16 Output |
unsigned char Parameter_J16Timing; // for the J16 Output |
unsigned char Parameter_J17Bitmask; // for the J17 Output |
unsigned char Parameter_J17Timing; // for the J17 Output |
unsigned char Parameter_NaviGpsGain; |
unsigned char Parameter_NaviGpsP; |
unsigned char Parameter_NaviGpsI; |
unsigned char Parameter_NaviGpsD; |
unsigned char Parameter_NaviGpsA; |
unsigned char Parameter_NaviOperatingRadius; |
unsigned char Parameter_NaviWindCorrection; |
unsigned char Parameter_NaviSpeedCompensation; |
unsigned char Parameter_ExternalControl; |
unsigned char Parameter_GlobalConfig; |
unsigned char Parameter_ExtraConfig; |
unsigned char Parameter_MaximumAltitude; |
unsigned char Parameter_Servo3,Parameter_Servo4,Parameter_Servo5; |
unsigned char CareFree = 0; |
const signed char sintab[31] = { 0, 2, 4, 6, 7, 8, 8, 8, 7, 6, 4, 2, 0, -2, -4, -6, -7, -8, -8, -8, -7, -6, -4, -2, 0, 2, 4, 6, 7, 8, 8}; // 15° steps |
signed int ExternStickNick = 0,ExternStickRoll = 0,ExternStickGier = 0, ExternHoehenValue = -20; |
int MaxStickNick = 0,MaxStickRoll = 0; |
unsigned int modell_fliegt = 0; |
volatile unsigned char FC_StatusFlags = 0, FC_StatusFlags2 = 0; |
long GIER_GRAD_FAKTOR = 1291; |
signed int KopplungsteilNickRoll,KopplungsteilRollNick; |
signed int tmp_motorwert[MAX_MOTORS]; |
char VarioCharacter = ' '; |
unsigned int HooverGasEmergencyPercent = 0; // The gas value for Emergency landing |
unsigned int GasIsZeroCnt = 0; // to detect that the gas-stick is down for a while |
signed int Variance = 0; |
signed int CosAttitude; // for projection of hoover gas |
unsigned char ACC_AltitudeControl = 0; |
unsigned char LowVoltageLandingActive = 0; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#define OPA_OFFSET_STEP 5 |
#else |
#define OPA_OFFSET_STEP 10 |
#endif |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Debugwerte zuordnen |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
void CopyDebugValues(void) |
{ |
DebugOut.Analog[0] = ToNaviCtrl.IntegralNick;//IntegralNick / (EE_Parameter.GyroAccFaktor * 4); |
DebugOut.Analog[1] = ToNaviCtrl.IntegralRoll;//IntegralRoll / (EE_Parameter.GyroAccFaktor * 4); |
DebugOut.Analog[2] = Mittelwert_AccNick / 4; |
DebugOut.Analog[3] = Mittelwert_AccRoll / 4; |
DebugOut.Analog[4] = (signed int) AdNeutralGier - AdWertGier; |
DebugOut.Analog[5] = HoehenWert/10; |
DebugOut.Analog[6] = Aktuell_az;//AdWertAccHoch;//(Mess_Integral_Hoch / 512); |
DebugOut.Analog[8] = KompassValue; |
DebugOut.Analog[9] = UBat; |
DebugOut.Analog[10] = SenderOkay; |
DebugOut.Analog[11] = ErsatzKompassInGrad; |
DebugOut.Analog[12] = Motor[0].SetPoint; |
DebugOut.Analog[13] = Motor[1].SetPoint; |
DebugOut.Analog[14] = Motor[2].SetPoint; |
DebugOut.Analog[15] = Motor[3].SetPoint; |
DebugOut.Analog[20] = ServoNickValue; |
DebugOut.Analog[21] = HoverGas; |
DebugOut.Analog[22] = Capacity.ActualCurrent; |
DebugOut.Analog[23] = Capacity.UsedCapacity; |
DebugOut.Analog[24] = SollHoehe/10; |
DebugOut.Analog[27] = KompassSollWert; |
DebugOut.Analog[29] = Capacity.MinOfMaxPWM; |
DebugOut.Analog[30] = GPS_Nick; |
DebugOut.Analog[31] = GPS_Roll; |
if(VersionInfo.HardwareError[0] || VersionInfo.HardwareError[1]) DebugOut.Status[1] |= 1; else DebugOut.Status[1] &= 0xfe; |
//DebugOut.Analog[16] = MinBlTemperture; |
//DebugOut.Analog[17] = MaxBlTemperture; |
//DebugOut.Analog[16] = Variance; |
//DebugOut.Analog[17] = VarioMeter; |
//DebugOut.Analog[16] = GasIsZeroCnt; |
//DebugOut.Analog[18] = HoehenWertF; |
//DebugOut.Analog[25] = Parameter_Hoehe_P; |
//DebugOut.Analog[26] = Parameter_Luftdruck_D; |
} |
void Piep(unsigned char Anzahl, unsigned int dauer) |
{ |
unsigned int wait = 0; |
if(MotorenEin) return; //auf keinen Fall im Flug! |
GRN_OFF; |
while(Anzahl--) |
{ |
beeptime = dauer; |
wait = dauer; |
while(beeptime || wait) |
{ |
if(UpdateMotor) |
{ |
UpdateMotor = 0; |
if(!beeptime) wait--; |
LIBFC_Polling(); |
}; |
} |
} |
GRN_ON; |
} |
//############################################################################ |
// Messwerte beim Ermitteln der Nullage |
void CalibrierMittelwert(void) |
//############################################################################ |
{ |
unsigned char i; |
if(PlatinenVersion == 13) SucheGyroOffset(); |
// ADC auschalten, damit die Werte sich nicht während der Berechnung ändern |
ANALOG_OFF; |
MesswertNick = AdWertNick; |
MesswertRoll = AdWertRoll; |
MesswertGier = AdWertGier; |
Mittelwert_AccNick = ACC_AMPLIFY * AdWertAccNick; |
Mittelwert_AccRoll = ACC_AMPLIFY * AdWertAccRoll; |
// ADC einschalten |
ANALOG_ON; |
for(i=0;i<8;i++) |
{ |
int tmp; |
tmp = PPM_in[EE_Parameter.Kanalbelegung[K_POTI1 + i]] + 127; |
LIMIT_MIN_MAX(tmp, 0, 255); |
if(Poti[i] > tmp) Poti[i]--; else if(Poti[i] < tmp) Poti[i]++; |
} |
Umschlag180Nick = (long) EE_Parameter.WinkelUmschlagNick * 2500L; |
Umschlag180Roll = (long) EE_Parameter.WinkelUmschlagRoll * 2500L; |
} |
//############################################################################ |
// Nullwerte ermitteln |
// Parameter: 0 -> after switch on (ignore ACC-Z fault) |
// Parameter: 1 -> before Start |
// Parameter: 2 -> calibrate and store ACC |
unsigned char SetNeutral(unsigned char AdjustmentMode) // retuns: "sucess" |
//############################################################################ |
{ |
unsigned char i, sucess = 1; |
unsigned int gier_neutral = 0, nick_neutral = 0, roll_neutral = 0, acc_z_neutral = 0, barotest; |
VersionInfo.HardwareError[0] = 0; |
// HEF4017Reset_ON; |
NeutralAccX = 0; |
NeutralAccY = 0; |
NeutralAccZ = 0; |
NeutralAccZfine = 0; |
AdNeutralNick = 0; |
AdNeutralRoll = 0; |
AdNeutralGier = 0; |
Parameter_AchsKopplung1 = 0; |
Parameter_AchsKopplung2 = 0; |
ExpandBaro = 0; |
CalibrierMittelwert(); |
Delay_ms_Mess(100); |
CalibrierMittelwert(); |
if((EE_Parameter.GlobalConfig & CFG_HOEHENREGELUNG)) // Höhenregelung aktiviert? |
{ |
if((MessLuftdruck > 950) || (MessLuftdruck < 750) || ExpandBaro) SucheLuftruckOffset(); |
} |
barotest = MessLuftdruck; |
#define NEUTRAL_FILTER 32 |
OCR0A += OPA_OFFSET_STEP; |
OCR0B = 255 - OCR0A; |
for(i=0; i<NEUTRAL_FILTER; i++) |
{ |
Delay_ms_Mess(10); |
gier_neutral += AdWertGier; |
nick_neutral += AdWertNick; |
roll_neutral += AdWertRoll; |
acc_z_neutral += Aktuell_az; |
} |
if(MessLuftdruck < 1010 && MessLuftdruck > 20) BaroStep = barotest - MessLuftdruck; |
OCR0A -= OPA_OFFSET_STEP; |
OCR0B = 255 - OCR0A; |
AdNeutralNick = (nick_neutral+NEUTRAL_FILTER/2) / (NEUTRAL_FILTER / 8); |
AdNeutralRoll = (roll_neutral+NEUTRAL_FILTER/2) / (NEUTRAL_FILTER / 8); |
AdNeutralGier = (gier_neutral+NEUTRAL_FILTER/2) / (NEUTRAL_FILTER); |
NeutralAccZ = (acc_z_neutral+NEUTRAL_FILTER/2) / (NEUTRAL_FILTER); |
StartNeutralRoll = AdNeutralRoll; |
StartNeutralNick = AdNeutralNick; |
if(AdjustmentMode == 2) |
{ |
NeutralAccX = abs(Mittelwert_AccNick) / (2*ACC_AMPLIFY); |
NeutralAccY = abs(Mittelwert_AccRoll) / (2*ACC_AMPLIFY); |
// Save ACC neutral settings to eeprom |
SetParamWord(PID_ACC_NICK, (uint16_t)NeutralAccX); |
SetParamWord(PID_ACC_ROLL, (uint16_t)NeutralAccY); |
SetParamWord(PID_ACC_TOP, (uint16_t)NeutralAccZ); |
} |
else |
{ |
// restore from eeprom |
NeutralAccX = (int16_t)GetParamWord(PID_ACC_NICK); |
NeutralAccY = (int16_t)GetParamWord(PID_ACC_ROLL); |
// strange settings? |
if(((unsigned int) NeutralAccX > 2048) || ((unsigned int) NeutralAccY > 2048)/* || ((unsigned int) NeutralAccZ > 1024)*/) |
{ |
printf("\n\rACC not calibrated!\r\n"); |
NeutralAccX = abs(Mittelwert_AccNick) / (2*ACC_AMPLIFY); |
NeutralAccY = abs(Mittelwert_AccRoll) / (2*ACC_AMPLIFY); |
sucess = 0; |
} |
} |
EEAR = EE_DUMMY; // Set the EEPROM Address pointer to an unused space |
MesswertNick = 0; |
MesswertRoll = 0; |
MesswertGier = 0; |
Delay_ms_Mess(200); |
Mittelwert_AccNick = ACC_AMPLIFY * AdWertAccNick; |
Mittelwert_AccRoll = ACC_AMPLIFY * AdWertAccRoll; |
IntegralNick = EE_Parameter.GyroAccFaktor * (long)Mittelwert_AccNick; |
IntegralRoll = EE_Parameter.GyroAccFaktor * (long)Mittelwert_AccRoll; |
Mess_IntegralNick = IntegralNick; |
Mess_IntegralRoll = IntegralRoll; |
Mess_Integral_Gier = 0; |
KompassSollWert = KompassValue; |
KompassSignalSchlecht = 100; |
beeptime = 50; |
Umschlag180Nick = ((long) EE_Parameter.WinkelUmschlagNick * 2500L) + 15000L; |
Umschlag180Roll = ((long) EE_Parameter.WinkelUmschlagRoll * 2500L) + 15000L; |
ExternHoehenValue = 0; |
ErsatzKompass = KompassValue * GIER_GRAD_FAKTOR; |
GierGyroFehler = 0; |
LED_Init(); |
if(AdjustmentMode != 0) FC_StatusFlags |= FC_STATUS_CALIBRATE; |
FromNaviCtrl_Value.Kalman_K = -1; |
FromNaviCtrl_Value.Kalman_MaxDrift = 0; |
FromNaviCtrl_Value.Kalman_MaxFusion = 32; |
for(i=0;i<8;i++) |
{ |
Poti[i] = PPM_in[EE_Parameter.Kanalbelegung[K_POTI1 + i]] + 127; |
} |
SenderOkay = 100; |
if(ServoActive) DDRD |=0x80; // enable J7 -> Servo signal |
else |
{ |
if((EE_Parameter.ServoCompInvert & SERVO_NICK_INV) && (EE_Parameter.ServoCompInvert & SERVO_RELATIVE)) NickServoValue = 12000;//((128 + 60) * 4 * 16); // neutral position = upper 1/4// else |
else NickServoValue = ((128 - 60) * 4 * 16); // neutral position = lower 1/4 |
CalculateServoSignals = 1; |
CalculateServo(); // nick |
CalculateServo(); // roll |
} |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
signed int tilt1, tilt2; |
tilt1 = (int)(IntegralNick/GIER_GRAD_FAKTOR); // nick angle in deg |
tilt2 = (int)(IntegralRoll/GIER_GRAD_FAKTOR); // roll angle in deg |
tilt1 = (int16_t)ihypot(tilt1,tilt2); // tilt angle over all |
CosAttitude = c_cos_8192(tilt1); |
NeutralAccZ = (long)((long) (NeutralAccZ - 512) * 8192 + 4096) / CosAttitude + 512; |
if(tilt1 > 20) sucess = 0; // calibration must be within 20° Tilt angle |
if(AdjustmentMode != 0 && ACC_AltitudeControl) if((NeutralAccZ < 682 - 25) || (NeutralAccZ > 682 + 25)) { VersionInfo.HardwareError[0] |= FC_ERROR0_ACC_TOP; sucess = 0;}; |
#else |
NeutralAccZ = (int16_t)GetParamWord(PID_ACC_TOP); |
EEAR = EE_DUMMY; // Set the EEPROM Address pointer to an unused space |
#endif |
if((AdNeutralNick < 150 * 16) || (AdNeutralNick > 850 * 16)) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_NICK; }; |
if((AdNeutralRoll < 150 * 16) || (AdNeutralRoll > 850 * 16)) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_ROLL; }; |
if((AdNeutralGier < 150 * 2) || (AdNeutralGier > 850 * 2)) { VersionInfo.HardwareError[0] |= FC_ERROR0_GYRO_YAW; }; |
if((NeutralAccX < 300) || (NeutralAccX > 750)) { VersionInfo.HardwareError[0] |= FC_ERROR0_ACC_NICK; }; |
if((NeutralAccY < 300) || (NeutralAccY > 750)) { VersionInfo.HardwareError[0] |= FC_ERROR0_ACC_ROLL; }; |
if((NeutralAccZ < 512) || (NeutralAccZ > 850)) { VersionInfo.HardwareError[0] |= FC_ERROR0_ACC_TOP; }; |
if(VersionInfo.HardwareError[0]) sucess = 0; |
carefree_old = 70; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
LIBFC_HoTT_Clear(); |
ACC_AltitudeFusion(2); // initalisation |
#endif |
StartLuftdruck = Luftdruck; |
VarioMeter = 0; |
SummenHoehe = 0; Mess_Integral_Hoch = 0; |
DebugOut.Analog[28] = 0; // I2C-Counter |
CalcExpandBaroStep(); |
return(sucess); |
} |
//############################################################################ |
// Bearbeitet die Messwerte |
void Mittelwert(void) |
//############################################################################ |
{ |
static signed long tmpl,tmpl2,tmpl3,tmpl4; |
static signed int oldNick, oldRoll, d2Roll, d2Nick; |
signed long winkel_nick, winkel_roll; |
MesswertGier = (signed int) AdNeutralGier - AdWertGier; |
MesswertNick = (signed int) AdWertNickFilter / 8; |
MesswertRoll = (signed int) AdWertRollFilter / 8; |
RohMesswertNick = MesswertNick; |
RohMesswertRoll = MesswertRoll; |
// Beschleunigungssensor ++++++++++++++++++++++++++++++++++++++++++++++++ |
Mittelwert_AccNick = (Mittelwert_AccNick * 3 + ((ACC_AMPLIFY * AdWertAccNick))) / 4L; |
Mittelwert_AccRoll = (Mittelwert_AccRoll * 3 + ((ACC_AMPLIFY * AdWertAccRoll))) / 4L; |
IntegralAccNick += ACC_AMPLIFY * AdWertAccNick; |
IntegralAccRoll += ACC_AMPLIFY * AdWertAccRoll; |
NaviAccNick += AdWertAccNick; |
NaviAccRoll += AdWertAccRoll; |
NaviCntAcc++; |
IntegralAccZ += Aktuell_az - NeutralAccZ; |
//++++++++++++++++++++++++++++++++++++++++++++++++ |
// ADC einschalten |
ANALOG_ON; |
AdReady = 0; |
//++++++++++++++++++++++++++++++++++++++++++++++++ |
if(Mess_IntegralRoll > 93000L) winkel_roll = 93000L; |
else if(Mess_IntegralRoll <-93000L) winkel_roll = -93000L; |
else winkel_roll = Mess_IntegralRoll; |
if(Mess_IntegralNick > 93000L) winkel_nick = 93000L; |
else if(Mess_IntegralNick <-93000L) winkel_nick = -93000L; |
else winkel_nick = Mess_IntegralNick; |
// Gier ++++++++++++++++++++++++++++++++++++++++++++++++ |
Mess_Integral_Gier += MesswertGier; |
ErsatzKompass += MesswertGier; |
// Kopplungsanteil +++++++++++++++++++++++++++++++++++++ |
if(!Looping_Nick && !Looping_Roll && (Parameter_GlobalConfig & CFG_ACHSENKOPPLUNG_AKTIV)) |
{ |
tmpl3 = (MesswertRoll * winkel_nick) / 2048L; |
tmpl3 *= Parameter_AchsKopplung2; //65 |
tmpl3 /= 4096L; |
tmpl4 = (MesswertNick * winkel_roll) / 2048L; |
tmpl4 *= Parameter_AchsKopplung2; //65 |
tmpl4 /= 4096L; |
KopplungsteilNickRoll = tmpl3; |
KopplungsteilRollNick = tmpl4; |
tmpl4 -= tmpl3; |
ErsatzKompass += tmpl4; |
if(!Parameter_CouplingYawCorrection) Mess_Integral_Gier -= tmpl4/2; // Gier nachhelfen |
tmpl = ((MesswertGier + tmpl4) * winkel_nick) / 2048L; |
tmpl *= Parameter_AchsKopplung1; // 90 |
tmpl /= 4096L; |
tmpl2 = ((MesswertGier + tmpl4) * winkel_roll) / 2048L; |
tmpl2 *= Parameter_AchsKopplung1; |
tmpl2 /= 4096L; |
if(abs(MesswertGier) > 64) if(labs(tmpl) > 128 || labs(tmpl2) > 128) TrichterFlug = 1; |
//MesswertGier += (Parameter_CouplingYawCorrection * tmpl4) / 256; |
} |
else tmpl = tmpl2 = KopplungsteilNickRoll = KopplungsteilRollNick = 0; |
TrimRoll = tmpl - tmpl2 / 100L; |
TrimNick = -tmpl2 + tmpl / 100L; |
// Kompasswert begrenzen ++++++++++++++++++++++++++++++++++++++++++++++++ |
if(ErsatzKompass >= (360L * GIER_GRAD_FAKTOR)) ErsatzKompass -= 360L * GIER_GRAD_FAKTOR; // 360° Umschlag |
if(ErsatzKompass < 0) ErsatzKompass += 360L * GIER_GRAD_FAKTOR; |
// Roll ++++++++++++++++++++++++++++++++++++++++++++++++ |
Mess_IntegralRoll2 += MesswertRoll + TrimRoll; |
Mess_IntegralRoll += MesswertRoll + TrimRoll - LageKorrekturRoll; |
if(Mess_IntegralRoll > Umschlag180Roll) |
{ |
Mess_IntegralRoll = -(Umschlag180Roll - 25000L); |
Mess_IntegralRoll2 = Mess_IntegralRoll; |
} |
if(Mess_IntegralRoll <-Umschlag180Roll) |
{ |
Mess_IntegralRoll = (Umschlag180Roll - 25000L); |
Mess_IntegralRoll2 = Mess_IntegralRoll; |
} |
// Nick ++++++++++++++++++++++++++++++++++++++++++++++++ |
Mess_IntegralNick2 += MesswertNick + TrimNick; |
Mess_IntegralNick += MesswertNick + TrimNick - LageKorrekturNick; |
if(Mess_IntegralNick > Umschlag180Nick) |
{ |
Mess_IntegralNick = -(Umschlag180Nick - 25000L); |
Mess_IntegralNick2 = Mess_IntegralNick; |
} |
if(Mess_IntegralNick <-Umschlag180Nick) |
{ |
Mess_IntegralNick = (Umschlag180Nick - 25000L); |
Mess_IntegralNick2 = Mess_IntegralNick; |
} |
Integral_Gier = Mess_Integral_Gier; |
IntegralNick = Mess_IntegralNick; |
IntegralRoll = Mess_IntegralRoll; |
IntegralNick2 = Mess_IntegralNick2; |
IntegralRoll2 = Mess_IntegralRoll2; |
#define D_LIMIT 128 |
MesswertNick = HiResNick / 8; |
MesswertRoll = HiResRoll / 8; |
if(AdWertNick < 15) MesswertNick = -1000; if(AdWertNick < 7) MesswertNick = -2000; |
if(PlatinenVersion == 10) { if(AdWertNick > 1010) MesswertNick = +1000; if(AdWertNick > 1017) MesswertNick = +2000; } |
else { if(AdWertNick > 2000) MesswertNick = +1000; if(AdWertNick > 2015) MesswertNick = +2000; } |
if(AdWertRoll < 15) MesswertRoll = -1000; if(AdWertRoll < 7) MesswertRoll = -2000; |
if(PlatinenVersion == 10) { if(AdWertRoll > 1010) MesswertRoll = +1000; if(AdWertRoll > 1017) MesswertRoll = +2000; } |
else { if(AdWertRoll > 2000) MesswertRoll = +1000; if(AdWertRoll > 2015) MesswertRoll = +2000; } |
if(Parameter_Gyro_D) |
{ |
d2Nick = HiResNick - oldNick; |
oldNick = (oldNick + HiResNick)/2; |
if(d2Nick > D_LIMIT) d2Nick = D_LIMIT; |
else if(d2Nick < -D_LIMIT) d2Nick = -D_LIMIT; |
d2Roll = HiResRoll - oldRoll; |
oldRoll = (oldRoll + HiResRoll)/2; |
if(d2Roll > D_LIMIT) d2Roll = D_LIMIT; |
else if(d2Roll < -D_LIMIT) d2Roll = -D_LIMIT; |
MesswertNick += (d2Nick * (signed int) Parameter_Gyro_D) / 16; |
MesswertRoll += (d2Roll * (signed int) Parameter_Gyro_D) / 16; |
HiResNick += (d2Nick * (signed int) Parameter_Gyro_D); |
HiResRoll += (d2Roll * (signed int) Parameter_Gyro_D); |
} |
if(RohMesswertRoll > 0) TrimRoll += ((long) abs(KopplungsteilNickRoll) * Parameter_CouplingYawCorrection) / 64L; |
else TrimRoll -= ((long) abs(KopplungsteilNickRoll) * Parameter_CouplingYawCorrection) / 64L; |
if(RohMesswertNick > 0) TrimNick += ((long) abs(KopplungsteilRollNick) * Parameter_CouplingYawCorrection) / 64L; |
else TrimNick -= ((long) abs(KopplungsteilRollNick) * Parameter_CouplingYawCorrection) / 64L; |
if(Parameter_GlobalConfig & CFG_DREHRATEN_BEGRENZER && !Looping_Nick && !Looping_Roll) |
{ |
if(RohMesswertNick > 256) MesswertNick += 1 * (RohMesswertNick - 256); |
else if(RohMesswertNick < -256) MesswertNick += 1 * (RohMesswertNick + 256); |
if(RohMesswertRoll > 256) MesswertRoll += 1 * (RohMesswertRoll - 256); |
else if(RohMesswertRoll < -256) MesswertRoll += 1 * (RohMesswertRoll + 256); |
} |
} |
//############################################################################ |
// Senden der Motorwerte per I2C-Bus |
void SendMotorData(void) |
//############################################################################ |
{ |
unsigned char i; |
if(!MotorenEin) |
{ |
FC_StatusFlags &= ~(FC_STATUS_MOTOR_RUN | FC_STATUS_FLY); |
FC_StatusFlags2 &= ~FC_STATUS2_WAIT_FOR_TAKEOFF; |
for(i=0;i<MAX_MOTORS;i++) |
{ |
if(!PC_MotortestActive) MotorTest[i] = 0; |
Motor[i].SetPoint = MotorTest[i]; |
Motor[i].SetPointLowerBits = 0; |
/* |
Motor[i].SetPoint = MotorTest[i] / 4; // testing the high resolution |
Motor[i].SetPointLowerBits = MotorTest[i] % 4; |
*/ |
} |
if(PC_MotortestActive) PC_MotortestActive--; |
} |
else FC_StatusFlags |= FC_STATUS_MOTOR_RUN; |
if(I2C_TransferActive) |
{ |
I2C_TransferActive = 0; // enable for the next time |
} |
else |
{ |
motor_write = 0; |
I2C_Start(TWI_STATE_MOTOR_TX); //Start I2C Interrupt Mode |
} |
} |
unsigned char GetChannelValue(unsigned char ch) // gives the unsigned value of the channel |
{ |
int tmp2; |
if(ch == 0) return(0); |
tmp2 = PPM_in[ch] + 127; |
if(tmp2 > 255) tmp2 = 255; else if(tmp2 < 0) tmp2 = 0; |
return(tmp2); |
} |
//############################################################################ |
// Trägt ggf. das Poti als Parameter ein |
void ParameterZuordnung(void) |
//############################################################################ |
{ |
unsigned char tmp,i; |
for(i=0;i<8;i++) |
{ |
int tmp2; |
tmp = EE_Parameter.Kanalbelegung[K_POTI1 + i]; |
tmp2 = PPM_in[tmp] + 127; |
if(tmp2 > 255) tmp2 = 255; else if(tmp2 < 0) tmp2 = 0; |
if(tmp == 25) Poti[i] = tmp2; // 25 = WaypointEvent channel -> no filter |
else |
if(tmp2 != Poti[i]) |
{ |
Poti[i] += (tmp2 - Poti[i]) / 4; |
if(Poti[i] > tmp2) Poti[i]--; |
else Poti[i]++; |
} |
} |
CHK_POTI_MM(Parameter_Luftdruck_D,EE_Parameter.Luftdruck_D,0,100); |
CHK_POTI_MM(Parameter_Hoehe_P,EE_Parameter.Hoehe_P,0,100); |
CHK_POTI_MM(Parameter_Gyro_P,EE_Parameter.Gyro_P,10,255); |
CHK_POTI_MM(Parameter_J16Timing,EE_Parameter.J16Timing,5,255); |
CHK_POTI_MM(Parameter_J17Timing,EE_Parameter.J17Timing,5,255); |
if(EE_Parameter.Servo3 == 247) { if(PORTC & (1<<PORTC2)) Parameter_Servo3 = 140; else Parameter_Servo3 = 70;} // Out1 (J16) |
else if(EE_Parameter.Servo3 == 246) { if(PORTC & (1<<PORTC3)) Parameter_Servo3 = 140; else Parameter_Servo3 = 70;} |
else CHK_POTI_MM(Parameter_Servo3,EE_Parameter.Servo3, 24, 255); |
if(EE_Parameter.Servo4 == 247) { if(PORTC & (1<<PORTC2)) Parameter_Servo4 = 140; else Parameter_Servo4 = 70;} |
else if(EE_Parameter.Servo4 == 246) { if(PORTC & (1<<PORTC3)) Parameter_Servo4 = 140; else Parameter_Servo4 = 70;} // Out2 (J17) |
else CHK_POTI_MM(Parameter_Servo4,EE_Parameter.Servo4, 24, 255); |
CHK_POTI_MM(Parameter_Servo5,EE_Parameter.Servo5, 24, 255); |
Parameter_HoehenSchalter = GetChannelValue(EE_Parameter.HoeheChannel); |
CHK_POTI(Parameter_Hoehe_ACC_Wirkung,EE_Parameter.Hoehe_ACC_Wirkung); |
CHK_POTI(Parameter_Hoehe_GPS_Z,EE_Parameter.Hoehe_GPS_Z); |
CHK_POTI(Parameter_KompassWirkung,EE_Parameter.KompassWirkung); |
CHK_POTI(Parameter_Gyro_I,EE_Parameter.Gyro_I); |
CHK_POTI(Parameter_Gyro_D,EE_Parameter.Gyro_D); |
CHK_POTI(Parameter_Gyro_Gier_P,EE_Parameter.Gyro_Gier_P); |
CHK_POTI(Parameter_Gyro_Gier_I,EE_Parameter.Gyro_Gier_I); |
CHK_POTI(Parameter_I_Faktor,EE_Parameter.I_Faktor); |
CHK_POTI(Parameter_UserParam1,EE_Parameter.UserParam1); |
CHK_POTI(Parameter_UserParam2,EE_Parameter.UserParam2); |
CHK_POTI(Parameter_UserParam3,EE_Parameter.UserParam3); |
CHK_POTI(Parameter_UserParam4,EE_Parameter.UserParam4); |
CHK_POTI(Parameter_UserParam5,EE_Parameter.UserParam5); |
CHK_POTI(Parameter_UserParam6,EE_Parameter.UserParam6); |
CHK_POTI(Parameter_UserParam7,EE_Parameter.UserParam7); |
CHK_POTI(Parameter_UserParam8,EE_Parameter.UserParam8); |
CHK_POTI(Parameter_ServoNickControl,EE_Parameter.ServoNickControl); |
CHK_POTI(Parameter_ServoRollControl,EE_Parameter.ServoRollControl); |
CHK_POTI(Parameter_ServoNickComp,EE_Parameter.ServoNickComp); |
CHK_POTI(Parameter_ServoRollComp,EE_Parameter.ServoRollComp); |
CHK_POTI(Parameter_LoopGasLimit,EE_Parameter.LoopGasLimit); |
CHK_POTI(Parameter_AchsKopplung1,EE_Parameter.AchsKopplung1); |
CHK_POTI(Parameter_AchsKopplung2,EE_Parameter.AchsKopplung2); |
CHK_POTI(Parameter_CouplingYawCorrection,EE_Parameter.CouplingYawCorrection); |
CHK_POTI(Parameter_MaximumAltitude,EE_Parameter.MaxAltitude); |
if((NC_To_FC_MaxAltitude && NC_To_FC_MaxAltitude < Parameter_MaximumAltitude) || Parameter_MaximumAltitude == 0) Parameter_MaximumAltitude = NC_To_FC_MaxAltitude; |
Parameter_GlobalConfig = EE_Parameter.GlobalConfig; |
Parameter_ExtraConfig = EE_Parameter.ExtraConfig; |
// CHK_POTI(Parameter_AchsGegenKopplung1,EE_Parameter.AchsGegenKopplung1,0,255); |
CHK_POTI(Parameter_DynamicStability,EE_Parameter.DynamicStability); |
CHK_POTI(Parameter_ExternalControl,EE_Parameter.ExternalControl); |
Ki = 10300 / (Parameter_I_Faktor + 1); |
MAX_GAS = EE_Parameter.Gas_Max; |
MIN_GAS = EE_Parameter.Gas_Min; |
if(EE_Parameter.CareFreeChannel) |
{ |
CareFree = 1; |
if(PPM_in[EE_Parameter.CareFreeChannel] < -64) CareFree = 0; |
// if(tmp >= 248 && Poti[255 - tmp] < 50) CareFree = 0; |
if(carefree_old != CareFree) |
{ |
if(carefree_old < 3) |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(CareFree) { beeptime = 1500; if(!SpeakHoTT) SpeakHoTT = SPEAK_CF_ON; } |
else { beeptime = 200; if(!SpeakHoTT) SpeakHoTT = SPEAK_CF_OFF; } |
#else |
if(CareFree) beeptime = 1500; |
else beeptime = 200; |
#endif |
NeueKompassRichtungMerken = 5; |
carefree_old = CareFree; |
} else carefree_old--; |
} |
if(FromNaviCtrl.CompassValue < 0 && CareFree) VersionInfo.HardwareError[0] |= FC_ERROR0_CAREFREE; //else VersionInfo.HardwareError[0] &= ~FC_ERROR0_CAREFREE; |
} |
else |
{ |
CareFree = 0; |
carefree_old = 10; |
} |
if(FromNaviCtrl.CompassValue < 0 && MotorenEin && CareFree && BeepMuster == 0xffff) // ungültiger Kompasswert |
{ |
beeptime = 15000; |
BeepMuster = 0xA400; |
CareFree = 0; |
} |
if(CareFree) { FC_StatusFlags2 |= FC_STATUS2_CAREFREE; /*if(Parameter_AchsKopplung1 < 210) Parameter_AchsKopplung1 += 30;*/} else FC_StatusFlags2 &= ~FC_STATUS2_CAREFREE; |
} |
//############################################################################ |
// |
void MotorRegler(void) |
//############################################################################ |
{ |
int pd_ergebnis_nick,pd_ergebnis_roll,tmp_int, tmp_int2; |
int GierMischanteil,GasMischanteil; |
static long sollGier = 0,tmp_long,tmp_long2; |
static long IntegralFehlerNick = 0; |
static long IntegralFehlerRoll = 0; |
static unsigned int RcLostTimer; |
static unsigned char delay_neutral = 0; |
static unsigned char delay_einschalten = 0,delay_ausschalten = 0; |
static signed char move_safety_switch = 0; |
static long ausgleichNick, ausgleichRoll; |
int IntegralNickMalFaktor,IntegralRollMalFaktor; |
unsigned char i; |
Mittelwert(); |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Gaswert ermitteln |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(!(FC_StatusFlags & (FC_STATUS_EMERGENCY_LANDING | FC_STATUS2_RC_FAILSAVE_ACTIVE))) |
{ |
if(EE_Parameter.GlobalConfig3 & CFG3_VARIO_FAILSAFE) |
{ |
if(HoverGas && HoverGas < 150 * STICK_GAIN) |
{ |
HooverGasEmergencyPercent = (HoverGas/(STICK_GAIN) * EE_Parameter.NotGas) / 100; // i.e. 80% of Hovergas |
} |
else HooverGasEmergencyPercent = 45; // default if the Hoovergas was could not calculated yet |
} else HooverGasEmergencyPercent = EE_Parameter.NotGas; |
} |
if(GasIsZeroCnt == 30000) // in that case we have RC-Lost, but the MK is probably landed |
{ |
StickGas = 0; // Hold Gas down in that case |
HooverGasEmergencyPercent = MIN_GAS; |
} |
GasMischanteil = StickGas; |
if(GasMischanteil < MIN_GAS + 10) GasMischanteil = MIN_GAS + 10; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Empfang schlecht |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(SenderOkay < 100 && !(FC_StatusFlags2 & FC_STATUS2_RC_FAILSAVE_ACTIVE)) |
{ |
if(RcLostTimer) RcLostTimer--; |
else |
{ |
MotorenEin = 0; |
modell_fliegt = 0; |
FC_StatusFlags &= ~(FC_STATUS_EMERGENCY_LANDING | FC_STATUS_FLY); |
} |
ROT_ON; |
if(modell_fliegt > 1000 && Capacity.MinOfMaxPWM > 100) // wahrscheinlich in der Luft --> langsam absenken |
{ |
GasMischanteil = HooverGasEmergencyPercent; |
FC_StatusFlags |= FC_STATUS_EMERGENCY_LANDING; |
PPM_diff[EE_Parameter.Kanalbelegung[K_NICK]] = 0; |
PPM_diff[EE_Parameter.Kanalbelegung[K_ROLL]] = 0; |
PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] = 0; |
PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] = 0; |
PPM_in[EE_Parameter.Kanalbelegung[K_GIER]] = 0; |
} |
else |
{ |
MotorenEin = 0; |
} |
} |
else |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Emfang gut |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(SenderOkay > 140) |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
static unsigned int trigger = 1000; |
static unsigned char old_switch = 100; |
if(EE_Parameter.StartLandChannel && EE_Parameter.LandingSpeed) |
{ |
if(PPM_in[EE_Parameter.StartLandChannel] > 50) |
{ |
if(old_switch == 50) if(FC_StatusFlags2 & FC_STATUS2_WAIT_FOR_TAKEOFF) { FC_StatusFlags2 |= FC_STATUS2_AUTO_STARTING; SpeakHoTT = SPEAK_RISING;} |
FC_StatusFlags2 &= ~FC_STATUS2_AUTO_LANDING; |
old_switch = 150; |
} |
else |
if(PPM_in[EE_Parameter.StartLandChannel] < -50) |
{ |
if(old_switch == 150) { FC_StatusFlags2 |= FC_STATUS2_AUTO_LANDING; SpeakHoTT = SPEAK_SINKING;} |
FC_StatusFlags2 &= ~FC_STATUS2_AUTO_STARTING; |
old_switch = 50; |
} |
else |
{ |
FC_StatusFlags2 &= ~(FC_STATUS2_AUTO_STARTING | FC_STATUS2_AUTO_LANDING); |
} |
} |
#endif |
FC_StatusFlags &= ~FC_STATUS_EMERGENCY_LANDING; |
RcLostTimer = EE_Parameter.NotGasZeit * 50; |
if(GasMischanteil > 40 && MotorenEin) |
{ |
if(modell_fliegt < 0xffff) modell_fliegt++; |
} |
if((modell_fliegt < 256)) |
{ |
SummeNick = 0; |
SummeRoll = 0; |
sollGier = 0; |
Mess_Integral_Gier = 0; |
FC_StatusFlags2 |= FC_STATUS2_WAIT_FOR_TAKEOFF; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
old_switch = 100; |
#endif |
} |
else |
{ |
FC_StatusFlags |= FC_STATUS_FLY; |
if(FC_StatusFlags2 & FC_STATUS2_WAIT_FOR_TAKEOFF) |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if((NC_To_FC_Flags & NC_TO_FC_AUTOSTART || FC_StatusFlags2 & FC_STATUS2_AUTO_STARTING) && (VarioCharacter == '=') && ACC_AltitudeControl) |
{ |
FromNC_AltitudeSpeed = 80; |
FromNC_AltitudeSetpoint = 500; |
SollHoehe = 500; |
trigger = 1000; |
if(NC_To_FC_Flags & NC_TO_FC_AUTOSTART) SpeakHoTT = SPEAK_NEXT_WP; |
/* if(StartTrigger != 2) |
{ |
StartTrigger = 1; |
if(HoverGas < STICK_GAIN * 35) HoverGas = STICK_GAIN * 35; |
} |
*/ |
} |
// else FC_StatusFlags2 &= ~(FC_STATUS2_AUTO_STARTING); |
#endif |
if(HoehenWertF > 150 || HoehenWert < -350 || !(Parameter_GlobalConfig & CFG_HOEHENREGELUNG)) |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
trigger = 1000; |
if(FC_StatusFlags2 & FC_STATUS2_AUTO_STARTING) { FromNC_AltitudeSpeed = 0; SollHoehe = 300;/*HoehenWertF + 100;*/} |
else SpeakHoTT = SPEAK_RISING; |
#endif |
FC_StatusFlags2 &= ~(FC_STATUS2_WAIT_FOR_TAKEOFF | FC_STATUS2_AUTO_STARTING | FC_STATUS2_AUTO_LANDING); |
} |
SummeNick = 0; |
SummeRoll = 0; |
Mess_Integral_Gier = 0; |
// sollGier = 0; |
if(modell_fliegt > 1000) modell_fliegt = 1000; // for the Hooverpoint-Estimation |
} |
else // Flying mode |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if((FC_StatusFlags2 & FC_STATUS2_AUTO_LANDING) && (VarioCharacter == 'v' || VarioCharacter == '=') && ACC_AltitudeControl) |
{ |
FromNC_AltitudeSpeed = EE_Parameter.LandingSpeed; |
FromNC_AltitudeSetpoint = -20000; |
} |
if(trigger < 1000) |
{ |
trigger++; |
SummeNick = 0; |
SummeRoll = 0; |
Mess_Integral_Gier = 0; |
SollHoehe = HoehenWertF - 300; |
if(trigger == 1000 && FC_StatusFlags2 & FC_STATUS2_AUTO_LANDING && VarioCharacter != '+') |
{ |
FC_StatusFlags2 &= ~FC_STATUS2_AUTO_LANDING; |
FC_StatusFlags2 |= FC_STATUS2_WAIT_FOR_TAKEOFF; // go back into starting state |
} |
} |
else |
if(ACC_AltitudeControl && (VarioCharacter == 'v' || VarioCharacter == '-') && HoehenWert < 1000 /*&& FromNC_AltitudeSetpoint < 0*/) |
{ |
if(Aktuell_az > 940) |
{ |
trigger = 0; |
SpeakHoTT = SPEAK_LANDING; |
}; |
} |
#endif |
} |
} // end of: modell_fliegt > 256 |
if((PPM_in[EE_Parameter.Kanalbelegung[K_GAS]] > 80) && MotorenEin == 0) |
{ |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// auf Nullwerte kalibrieren |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(PPM_in[EE_Parameter.Kanalbelegung[K_GIER]] > 75) // Neutralwerte |
{ |
if(++delay_neutral > 200) // nicht sofort |
{ |
delay_neutral = 0; |
modell_fliegt = 0; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > 70 || abs(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]) > 70) |
{ |
unsigned char setting=1; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] > 70 && PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] < 70) setting = 1; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] > 70 && PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > 70) setting = 2; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] < 70 && PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > 70) setting = 3; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] <-70 && PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > 70) setting = 4; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] <-70 && PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] < 70) setting = 5; |
SetActiveParamSet(setting); // aktiven Datensatz merken |
} |
if(abs(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]) < 30 && PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] < -70) |
{ |
WinkelOut.CalcState = 1; |
CalibrationDone = 0; |
beeptime = 1000; |
} |
else |
{ |
ParamSet_ReadFromEEProm(ActiveParamSet); |
LipoDetection(0); |
LIBFC_ReceiverInit(EE_Parameter.Receiver); |
if((Parameter_GlobalConfig & CFG_HOEHENREGELUNG)) // Höhenregelung aktiviert? |
{ |
if((MessLuftdruck > 950) || (MessLuftdruck < 750)) SucheLuftruckOffset(); |
} |
CalibrationDone = SetNeutral(1); |
ServoActive = 1; |
DDRD |=0x80; // enable J7 -> Servo signal |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(VersionInfo.HardwareError[0]) SpeakHoTT = SPEAK_ERR_SENSOR; |
else |
if(!CalibrationDone) SpeakHoTT = SPEAK_ERR_CALIBARTION; |
else SpeakHoTT = SPEAK_CALIBRATE; |
ShowSettingNameTime = 5; // for HoTT & Jeti |
#endif |
Piep(ActiveParamSet,120); |
} |
} |
} |
else |
if(PPM_in[EE_Parameter.Kanalbelegung[K_GIER]] < -75) // ACC Neutralwerte speichern |
{ |
if(++delay_neutral > 200) // nicht sofort |
{ |
MotorenEin = 0; |
delay_neutral = 0; |
modell_fliegt = 0; |
CalibrationDone = SetNeutral(2); // store ACC values into EEPROM |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(VersionInfo.HardwareError[0]) SpeakHoTT = SPEAK_ERR_SENSOR; |
else |
if(!CalibrationDone) SpeakHoTT = SPEAK_ERR_CALIBARTION; |
else SpeakHoTT = SPEAK_CALIBRATE; |
#endif |
Piep(ActiveParamSet,120); |
} |
} |
else delay_neutral = 0; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Gas ist unten |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(PPM_in[EE_Parameter.Kanalbelegung[K_GAS]] < -100) |
{ |
if(PPM_diff[EE_Parameter.MotorSafetySwitch & 127] > 5) move_safety_switch = 100; |
else |
if(PPM_diff[EE_Parameter.MotorSafetySwitch & 127] < -5) move_safety_switch = -100; |
// Motoren Starten |
if(!MotorenEin) |
{ |
if((((PPM_in[EE_Parameter.Kanalbelegung[K_GIER]] < -100) && ((!(EE_Parameter.GlobalConfig3 & CFG3_MOTOR_SWITCH_MODE) && PPM_in[EE_Parameter.MotorSafetySwitch] < -75) || EE_Parameter.MotorSafetySwitch == 0))) |
|| (((EE_Parameter.GlobalConfig3 & CFG3_MOTOR_SWITCH_MODE) && PPM_in[EE_Parameter.MotorSafetySwitch] > -10 && move_safety_switch == 100))) |
{ |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Einschalten |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(CalibrationDone) FC_StatusFlags |= FC_STATUS_START; |
StartLuftdruck = Luftdruck; |
HoehenWertF = 0; |
HoehenWert = 0; |
SummenHoehe = 0; |
if((PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > -100 || abs(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]) < 100) && EE_Parameter.MotorSafetySwitch == 0) delay_einschalten = 0; |
if(++delay_einschalten > 253) |
{ |
if((abs(MesswertGier) > 32 || abs(MesswertNick) > 20) || abs(MesswertRoll) > 20) CalibrationDone = 0; // dann ist der Gyro defekt, schlecht kalibriert oder der MK dreht sich |
delay_einschalten = 0; |
if(!VersionInfo.HardwareError[0] && CalibrationDone && !NC_ErrorCode) |
{ |
modell_fliegt = 1; |
MotorenEin = 1; |
sollGier = 0; |
Mess_Integral_Gier = 0; |
Mess_Integral_Gier2 = 0; |
Mess_IntegralNick = EE_Parameter.GyroAccFaktor * (long)Mittelwert_AccNick; |
Mess_IntegralRoll = EE_Parameter.GyroAccFaktor * (long)Mittelwert_AccRoll; |
Mess_IntegralNick2 = IntegralNick; |
Mess_IntegralRoll2 = IntegralRoll; |
SummeNick = 0; |
SummeRoll = 0; |
// ControlHeading = (((int) EE_Parameter.OrientationAngle * 15 + KompassValue) % 360) / 2; |
NeueKompassRichtungMerken = 100; // 2 sekunden |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
SpeakHoTT = SPEAK_STARTING; |
#endif |
} |
else |
{ |
beeptime = 1500; // indicate missing calibration |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(!CalibrationDone) SpeakHoTT = SPEAK_ERR_CALIBARTION; |
#endif |
} |
} |
} |
else delay_einschalten = 0; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Auschalten |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
else // only if motors are running |
{ |
// if((PPM_in[EE_Parameter.Kanalbelegung[K_GIER]] > 75) && (PPM_in[EE_Parameter.MotorSafetySwitch] < -75 || EE_Parameter.MotorSafetySwitch == 0)) |
if((((PPM_in[EE_Parameter.Kanalbelegung[K_GIER]] > 100) && ((!(EE_Parameter.GlobalConfig3 & CFG3_MOTOR_SWITCH_MODE) && PPM_in[EE_Parameter.MotorSafetySwitch] < -75) || EE_Parameter.MotorSafetySwitch == 0))) |
|| (((EE_Parameter.GlobalConfig3 & CFG3_MOTOR_SWITCH_MODE) && PPM_in[EE_Parameter.MotorSafetySwitch] < -50 && move_safety_switch == -100))) |
{ |
if((PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > -100 || abs(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]) < 100) && EE_Parameter.MotorSafetySwitch == 0) |
{ |
delay_ausschalten = 0; |
} |
else |
{ |
SummeNick = 0; |
SummeRoll = 0; |
StickNick = 0; |
StickRoll = 0; |
} |
if(++delay_ausschalten > 250) // nicht sofort |
{ |
MotorenEin = 0; |
delay_ausschalten = 0; |
modell_fliegt = 0; |
FC_StatusFlags2 &= ~(FC_STATUS2_WAIT_FOR_TAKEOFF | FC_STATUS2_AUTO_STARTING | FC_STATUS2_AUTO_LANDING); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
SpeakHoTT = SPEAK_MK_OFF; |
#endif |
} |
else |
if(delay_ausschalten == 100) beeptime = 3500; |
} |
else delay_ausschalten = 0; |
} |
if(GasIsZeroCnt < 1000) |
{ |
if(VarioMeter > -150) GasIsZeroCnt++; |
else if(GasIsZeroCnt) GasIsZeroCnt--; |
} |
} |
else // gas not at minimum |
{ |
move_safety_switch = 0; |
GasIsZeroCnt = 0; |
} |
} |
else // Empfang zwischen 100 und 140 -> schlecht |
{ |
if(GasIsZeroCnt >= 750) // gas-stick was down for 1.5 seconds before RC-Lost |
{ |
if((GPSInfo.HomeDistance < 40 * 10) && (HoehenWert < 15 * 100)) // and we are at the starting point -> maybe landed? |
{ |
GasIsZeroCnt = 30000; |
if(modell_fliegt > 1001) modell_fliegt = 1001; |
} |
} |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// neue Werte von der Funke |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(!NewPpmData-- || (FC_StatusFlags & FC_STATUS_EMERGENCY_LANDING)) |
{ |
static int stick_nick,stick_roll; |
unsigned char stick_p; |
ParameterZuordnung(); |
stick_p = EE_Parameter.Stick_P; |
stick_nick = (stick_nick * 3 + PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] * stick_p) / 4; |
stick_nick += PPM_diff[EE_Parameter.Kanalbelegung[K_NICK]] * EE_Parameter.Stick_D; |
stick_roll = (stick_roll * 3 + PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] * stick_p) / 4; |
stick_roll += PPM_diff[EE_Parameter.Kanalbelegung[K_ROLL]] * EE_Parameter.Stick_D; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// CareFree und freie Wahl der vorderen Richtung |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(CareFree) |
{ |
signed int nick, roll; |
nick = stick_nick / 4; |
roll = stick_roll / 4; |
StickNick = ((FromNC_Rotate_C * nick) + (FromNC_Rotate_S * roll)) / (32 / 4); |
StickRoll = ((FromNC_Rotate_C * roll) - (FromNC_Rotate_S * nick)) / (32 / 4); |
} |
else |
{ |
FromNC_Rotate_C = sintab[EE_Parameter.OrientationAngle + 6]; |
FromNC_Rotate_S = sintab[EE_Parameter.OrientationAngle]; |
StickNick = ((FromNC_Rotate_C * stick_nick) + (FromNC_Rotate_S * stick_roll)) / 8; |
StickRoll = ((FromNC_Rotate_C * stick_roll) - (FromNC_Rotate_S * stick_nick)) / 8; |
} |
StickGier = -PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]; |
if(StickGier > 4) StickGier -= 4; else |
if(StickGier < -4) StickGier += 4; else StickGier = 0; |
if(GasIsZeroCnt > 512) // About to switch - off |
{ |
StickNick = StickNick/8; |
StickRoll = StickRoll/8; |
SummeNick = 0; |
SummeRoll = 0; |
} |
else |
if(GPS_Aid_StickMultiplikator) // in that case the GPS controls stronger |
{ |
StickNick = (GPS_Aid_StickMultiplikator * (StickNick / 8)) / 16; |
StickRoll = (GPS_Aid_StickMultiplikator * (StickRoll / 8)) / 16; |
} |
StickNick -= GPS_Nick; |
StickRoll -= GPS_Roll; |
StickGas = PPM_in[EE_Parameter.Kanalbelegung[K_GAS]] + 127; |
GyroFaktor = (Parameter_Gyro_P + 10.0); |
IntegralFaktor = Parameter_Gyro_I; |
GyroFaktorGier = (Parameter_Gyro_Gier_P + 10.0); |
IntegralFaktorGier = Parameter_Gyro_Gier_I; |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
//+ Analoge Steuerung per Seriell |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(ExternControl.Config & 0x01 && Parameter_ExternalControl > 128) |
{ |
StickNick += (int) ExternControl.Nick * (int) EE_Parameter.Stick_P; |
StickRoll += (int) ExternControl.Roll * (int) EE_Parameter.Stick_P; |
StickGier += ExternControl.Gier; |
ExternHoehenValue = (int) ExternControl.Hight * (int)EE_Parameter.Hoehe_Verstaerkung; |
if(ExternControl.Gas < StickGas) StickGas = ExternControl.Gas; |
} |
if(StickGas < 0) StickGas = 0; |
if(Parameter_GlobalConfig & CFG_HEADING_HOLD) IntegralFaktor = 0; |
if(abs(StickNick/STICK_GAIN) > MaxStickNick) |
{ |
MaxStickNick = abs(StickNick)/STICK_GAIN; |
if(MaxStickNick > 100) MaxStickNick = 100; |
} |
else MaxStickNick--; |
if(abs(StickRoll/STICK_GAIN) > MaxStickRoll) |
{ |
MaxStickRoll = abs(StickRoll)/STICK_GAIN; |
if(MaxStickRoll > 100) MaxStickRoll = 100; |
} |
else MaxStickRoll--; |
if(FC_StatusFlags & FC_STATUS_EMERGENCY_LANDING) {MaxStickNick = 0; MaxStickRoll = 0;} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Looping? |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if((PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] > EE_Parameter.LoopThreshold) && EE_Parameter.BitConfig & CFG_LOOP_LINKS) Looping_Links = 1; |
else |
{ |
{ |
if((PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] < (EE_Parameter.LoopThreshold - EE_Parameter.LoopHysterese))) Looping_Links = 0; |
} |
} |
if((PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] < -EE_Parameter.LoopThreshold) && EE_Parameter.BitConfig & CFG_LOOP_RECHTS) Looping_Rechts = 1; |
else |
{ |
if(Looping_Rechts) // Hysterese |
{ |
if(PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]] > -(EE_Parameter.LoopThreshold - EE_Parameter.LoopHysterese)) Looping_Rechts = 0; |
} |
} |
if((PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > EE_Parameter.LoopThreshold) && EE_Parameter.BitConfig & CFG_LOOP_OBEN) Looping_Oben = 1; |
else |
{ |
if(Looping_Oben) // Hysterese |
{ |
if((PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] < (EE_Parameter.LoopThreshold - EE_Parameter.LoopHysterese))) Looping_Oben = 0; |
} |
} |
if((PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] < -EE_Parameter.LoopThreshold) && EE_Parameter.BitConfig & CFG_LOOP_UNTEN) Looping_Unten = 1; |
else |
{ |
if(Looping_Unten) // Hysterese |
{ |
if(PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > -(EE_Parameter.LoopThreshold - EE_Parameter.LoopHysterese)) Looping_Unten = 0; |
} |
} |
if(Looping_Links || Looping_Rechts) Looping_Roll = 1; else Looping_Roll = 0; |
if(Looping_Oben || Looping_Unten) { Looping_Nick = 1; Looping_Roll = 0; Looping_Links = 0; Looping_Rechts = 0;} else Looping_Nick = 0; |
} // Ende neue Funken-Werte |
if(Looping_Roll || Looping_Nick) |
{ |
if(GasMischanteil > EE_Parameter.LoopGasLimit) GasMischanteil = EE_Parameter.LoopGasLimit; |
TrichterFlug = 1; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Bei Empfangsausfall im Flug |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(FC_StatusFlags2 & FC_STATUS2_RC_FAILSAVE_ACTIVE) |
{ |
StickNick = -GPS_Nick; |
StickRoll = -GPS_Roll; |
StickGas = StickGasHover; |
Parameter_GlobalConfig &= ~(CFG_HEADING_HOLD | CFG_DREHRATEN_BEGRENZER); |
Parameter_GlobalConfig |= CFG_HOEHENREGELUNG | CFG_ACHSENKOPPLUNG_AKTIV | CFG_KOMPASS_AKTIV | CFG_GPS_AKTIV | CFG_HOEHEN_SCHALTER | CFG_GPS_AKTIV; |
Parameter_ExtraConfig &= ~(CFG2_HEIGHT_LIMIT | CFG_LEARNABLE_CAREFREE | CFG2_VARIO_BEEP); |
Parameter_HoehenSchalter = 200; // switch on |
} |
else |
if(FC_StatusFlags & FC_STATUS_EMERGENCY_LANDING) |
{ |
StickGier = 0; |
StickNick = 0; |
StickRoll = 0; |
GyroFaktor = 90; |
IntegralFaktor = 120; |
GyroFaktorGier = 90; |
IntegralFaktorGier = 120; |
Looping_Roll = 0; |
Looping_Nick = 0; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Integrale auf ACC-Signal abgleichen |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#define ABGLEICH_ANZAHL 256L |
MittelIntegralNick += IntegralNick; // Für die Mittelwertbildung aufsummieren |
MittelIntegralRoll += IntegralRoll; |
MittelIntegralNick2 += IntegralNick2; |
MittelIntegralRoll2 += IntegralRoll2; |
if(Looping_Nick || Looping_Roll) |
{ |
IntegralAccNick = 0; |
IntegralAccRoll = 0; |
MittelIntegralNick = 0; |
MittelIntegralRoll = 0; |
MittelIntegralNick2 = 0; |
MittelIntegralRoll2 = 0; |
Mess_IntegralNick2 = Mess_IntegralNick; |
Mess_IntegralRoll2 = Mess_IntegralRoll; |
ZaehlMessungen = 0; |
LageKorrekturNick = 0; |
LageKorrekturRoll = 0; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(!Looping_Nick && !Looping_Roll && (Aktuell_az > 512 || MotorenEin)) |
{ |
long tmp_long, tmp_long2; |
if(FromNaviCtrl_Value.Kalman_K > 0 /*&& !TrichterFlug*/) |
{ |
tmp_long = (long)(IntegralNick / EE_Parameter.GyroAccFaktor - (long)(Mittelwert_AccNick - FromNaviCtrl.AccErrorN)); |
tmp_long2 = (long)(IntegralRoll / EE_Parameter.GyroAccFaktor - (long)(Mittelwert_AccRoll - FromNaviCtrl.AccErrorR)); |
tmp_long = (tmp_long * FromNaviCtrl_Value.Kalman_K) / (32 * 16); |
tmp_long2 = (tmp_long2 * FromNaviCtrl_Value.Kalman_K) / (32 * 16); |
if((MaxStickNick > 64) || (MaxStickRoll > 64)) |
{ |
tmp_long /= 2; |
tmp_long2 /= 2; |
} |
if(tmp_long > (long) FromNaviCtrl_Value.Kalman_MaxFusion) tmp_long = (long) FromNaviCtrl_Value.Kalman_MaxFusion; |
if(tmp_long < (long)-FromNaviCtrl_Value.Kalman_MaxFusion) tmp_long = (long)-FromNaviCtrl_Value.Kalman_MaxFusion; |
if(tmp_long2 > (long) FromNaviCtrl_Value.Kalman_MaxFusion) tmp_long2 = (long) FromNaviCtrl_Value.Kalman_MaxFusion; |
if(tmp_long2 < (long)-FromNaviCtrl_Value.Kalman_MaxFusion) tmp_long2 = (long)-FromNaviCtrl_Value.Kalman_MaxFusion; |
} |
else |
{ |
tmp_long = (long)(IntegralNick / EE_Parameter.GyroAccFaktor - (long)Mittelwert_AccNick); |
tmp_long2 = (long)(IntegralRoll / EE_Parameter.GyroAccFaktor - (long)Mittelwert_AccRoll); |
tmp_long /= 16; |
tmp_long2 /= 16; |
if((MaxStickNick > 64) || (MaxStickRoll > 64)) |
{ |
tmp_long /= 3; |
tmp_long2 /= 3; |
} |
if(abs(PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]) > 25) |
{ |
tmp_long /= 3; |
tmp_long2 /= 3; |
} |
KompassFusion = 25; |
#define AUSGLEICH 32 |
if(tmp_long > AUSGLEICH) tmp_long = AUSGLEICH; |
if(tmp_long < -AUSGLEICH) tmp_long =-AUSGLEICH; |
if(tmp_long2 > AUSGLEICH) tmp_long2 = AUSGLEICH; |
if(tmp_long2 <-AUSGLEICH) tmp_long2 =-AUSGLEICH; |
} |
Mess_IntegralNick -= tmp_long; |
Mess_IntegralRoll -= tmp_long2; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(ZaehlMessungen >= ABGLEICH_ANZAHL) |
{ |
static int cnt = 0; |
static char last_n_p,last_n_n,last_r_p,last_r_n; |
static long MittelIntegralNick_Alt,MittelIntegralRoll_Alt; |
if(!Looping_Nick && !Looping_Roll && !TrichterFlug && EE_Parameter.Driftkomp) |
{ |
MittelIntegralNick /= ABGLEICH_ANZAHL; |
MittelIntegralRoll /= ABGLEICH_ANZAHL; |
IntegralAccNick = (EE_Parameter.GyroAccFaktor * IntegralAccNick) / ABGLEICH_ANZAHL; |
IntegralAccRoll = (EE_Parameter.GyroAccFaktor * IntegralAccRoll) / ABGLEICH_ANZAHL; |
IntegralAccZ = IntegralAccZ / ABGLEICH_ANZAHL; |
#define MAX_I 0 |
// Nick ++++++++++++++++++++++++++++++++++++++++++++++++ |
IntegralFehlerNick = (long)(MittelIntegralNick - (long)IntegralAccNick); |
ausgleichNick = IntegralFehlerNick / EE_Parameter.GyroAccAbgleich; |
// Roll ++++++++++++++++++++++++++++++++++++++++++++++++ |
IntegralFehlerRoll = (long)(MittelIntegralRoll - (long)IntegralAccRoll); |
ausgleichRoll = IntegralFehlerRoll / EE_Parameter.GyroAccAbgleich; |
LageKorrekturNick = ausgleichNick / ABGLEICH_ANZAHL; |
LageKorrekturRoll = ausgleichRoll / ABGLEICH_ANZAHL; |
if(((MaxStickNick > 64) || (MaxStickRoll > 64) || (abs(PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]) > 25)) && (FromNaviCtrl_Value.Kalman_K == -1)) |
{ |
LageKorrekturNick /= 2; |
LageKorrekturRoll /= 2; |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Gyro-Drift ermitteln |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
MittelIntegralNick2 /= ABGLEICH_ANZAHL; |
MittelIntegralRoll2 /= ABGLEICH_ANZAHL; |
tmp_long = IntegralNick2 - IntegralNick; |
tmp_long2 = IntegralRoll2 - IntegralRoll; |
IntegralFehlerNick = tmp_long; |
IntegralFehlerRoll = tmp_long2; |
Mess_IntegralNick2 -= IntegralFehlerNick; |
Mess_IntegralRoll2 -= IntegralFehlerRoll; |
if(EE_Parameter.Driftkomp) |
{ |
if(GierGyroFehler > ABGLEICH_ANZAHL/2) { AdNeutralGier++; } |
if(GierGyroFehler <-ABGLEICH_ANZAHL/2) { AdNeutralGier--; } |
} |
GierGyroFehler = 0; |
#define FEHLER_LIMIT (ABGLEICH_ANZAHL / 2) |
#define FEHLER_LIMIT1 (ABGLEICH_ANZAHL * 2) //4 |
#define FEHLER_LIMIT2 (ABGLEICH_ANZAHL * 16) //16 |
#define BEWEGUNGS_LIMIT 20000 |
// Nick +++++++++++++++++++++++++++++++++++++++++++++++++ |
cnt = 1;// + labs(IntegralFehlerNick) / 4096; |
if(labs(IntegralFehlerNick) > FEHLER_LIMIT1) cnt = 4; |
if(labs(MittelIntegralNick_Alt - MittelIntegralNick) < BEWEGUNGS_LIMIT || (FromNaviCtrl_Value.Kalman_MaxDrift > 3*8)) |
{ |
if(IntegralFehlerNick > FEHLER_LIMIT2) |
{ |
if(last_n_p) |
{ |
cnt += labs(IntegralFehlerNick) / (FEHLER_LIMIT2 / 8); |
ausgleichNick = IntegralFehlerNick / 8; |
if(ausgleichNick > 5000) ausgleichNick = 5000; |
LageKorrekturNick += ausgleichNick / ABGLEICH_ANZAHL; |
} |
else last_n_p = 1; |
} else last_n_p = 0; |
if(IntegralFehlerNick < -FEHLER_LIMIT2) |
{ |
if(last_n_n) |
{ |
cnt += labs(IntegralFehlerNick) / (FEHLER_LIMIT2 / 8); |
ausgleichNick = IntegralFehlerNick / 8; |
if(ausgleichNick < -5000) ausgleichNick = -5000; |
LageKorrekturNick += ausgleichNick / ABGLEICH_ANZAHL; |
} |
else last_n_n = 1; |
} else last_n_n = 0; |
} |
else |
{ |
cnt = 0; |
KompassSignalSchlecht = 100; |
} |
if(cnt > EE_Parameter.Driftkomp) cnt = EE_Parameter.Driftkomp; |
if(FromNaviCtrl_Value.Kalman_MaxDrift) if(cnt > FromNaviCtrl_Value.Kalman_MaxDrift) cnt = FromNaviCtrl_Value.Kalman_MaxDrift; |
if(IntegralFehlerNick > FEHLER_LIMIT) AdNeutralNick += cnt; |
if(IntegralFehlerNick < -FEHLER_LIMIT) AdNeutralNick -= cnt; |
// Roll +++++++++++++++++++++++++++++++++++++++++++++++++ |
cnt = 1;// + labs(IntegralFehlerRoll) / 4096; |
if(labs(IntegralFehlerRoll) > FEHLER_LIMIT1) cnt = 4; |
if(labs(MittelIntegralRoll_Alt - MittelIntegralRoll) < BEWEGUNGS_LIMIT || (FromNaviCtrl_Value.Kalman_MaxDrift > 3*8)) |
{ |
if(IntegralFehlerRoll > FEHLER_LIMIT2) |
{ |
if(last_r_p) |
{ |
cnt += labs(IntegralFehlerRoll) / (FEHLER_LIMIT2 / 8); |
ausgleichRoll = IntegralFehlerRoll / 8; |
if(ausgleichRoll > 5000) ausgleichRoll = 5000; |
LageKorrekturRoll += ausgleichRoll / ABGLEICH_ANZAHL; |
} |
else last_r_p = 1; |
} else last_r_p = 0; |
if(IntegralFehlerRoll < -FEHLER_LIMIT2) |
{ |
if(last_r_n) |
{ |
cnt += labs(IntegralFehlerRoll) / (FEHLER_LIMIT2 / 8); |
ausgleichRoll = IntegralFehlerRoll / 8; |
if(ausgleichRoll < -5000) ausgleichRoll = -5000; |
LageKorrekturRoll += ausgleichRoll / ABGLEICH_ANZAHL; |
} |
else last_r_n = 1; |
} else last_r_n = 0; |
} else |
{ |
cnt = 0; |
KompassSignalSchlecht = 100; |
} |
if(cnt > EE_Parameter.Driftkomp) cnt = EE_Parameter.Driftkomp; |
if(FromNaviCtrl_Value.Kalman_MaxDrift) if(cnt > FromNaviCtrl_Value.Kalman_MaxDrift) cnt = FromNaviCtrl_Value.Kalman_MaxDrift; |
if(IntegralFehlerRoll > FEHLER_LIMIT) AdNeutralRoll += cnt; |
if(IntegralFehlerRoll < -FEHLER_LIMIT) AdNeutralRoll -= cnt; |
} |
else |
{ |
LageKorrekturRoll = 0; |
LageKorrekturNick = 0; |
TrichterFlug = 0; |
} |
if(!IntegralFaktor) { LageKorrekturRoll = 0; LageKorrekturNick = 0;} // z.B. bei HH |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++ |
MittelIntegralNick_Alt = MittelIntegralNick; |
MittelIntegralRoll_Alt = MittelIntegralRoll; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++ |
IntegralAccNick = 0; |
IntegralAccRoll = 0; |
IntegralAccZ = 0; |
MittelIntegralNick = 0; |
MittelIntegralRoll = 0; |
MittelIntegralNick2 = 0; |
MittelIntegralRoll2 = 0; |
ZaehlMessungen = 0; |
} // ZaehlMessungen >= ABGLEICH_ANZAHL |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Gieren |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(abs(StickGier) > 3) // war 15 |
{ |
// KompassSignalSchlecht = 1000; |
if(!(Parameter_GlobalConfig & CFG_KOMPASS_FIX)) |
{ |
NeueKompassRichtungMerken = 50; // eine Sekunde zum Einloggen |
}; |
} |
tmp_int = (long) EE_Parameter.StickGier_P * ((long)StickGier * abs(StickGier)) / 512L; // expo y = ax + bx² |
tmp_int += (EE_Parameter.StickGier_P * StickGier) / 4; |
if(GasIsZeroCnt > 512) tmp_int = 0; // disable Yawing when Gas-Stick is to Zero |
tmp_int += CompassGierSetpoint; |
sollGier = tmp_int; |
Mess_Integral_Gier -= tmp_int; |
if(Mess_Integral_Gier > 50000) Mess_Integral_Gier = 50000; // begrenzen |
if(Mess_Integral_Gier <-50000) Mess_Integral_Gier =-50000; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Kompass |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(KompassValue >= 0 && (Parameter_GlobalConfig & CFG_KOMPASS_AKTIV)) |
{ |
if(CalculateCompassTimer-- == 1) |
{ |
int w,v,r,fehler,korrektur; // wird von der SPI-Routine auf 1 gesetzt |
CalculateCompassTimer = 13; // falls keine Navi-Daten |
// max. Korrekturwert schätzen |
w = abs(IntegralNick /512); // mit zunehmender Neigung den Einfluss drosseln |
v = abs(IntegralRoll /512); |
if(v > w) w = v; // grösste Neigung ermitteln |
// korrektur = w / 4 + 1; |
korrektur = w / 8 + 2; |
ErsatzKompassInGrad = ErsatzKompass/GIER_GRAD_FAKTOR; |
// Kompassfehlerwert bestimmen |
fehler = ((540 + KompassValue - ErsatzKompassInGrad) % 360) - 180; |
// GIER_GRAD_FAKTOR ist ca. 1200 |
// Kompasswert einloggen |
if(KompassSignalSchlecht) KompassSignalSchlecht--; |
else |
if(w < 25) |
{ |
GierGyroFehler += fehler; |
if(NeueKompassRichtungMerken) |
{ |
if(--NeueKompassRichtungMerken == 0) |
{ |
KompassSollWert = ErsatzKompassInGrad; |
} |
} |
} |
// Kompass fusionieren |
if(!KompassSignalSchlecht) ErsatzKompass += (fehler * KompassFusion) / korrektur; |
// MK Gieren |
if(!NeueKompassRichtungMerken) |
{ |
r = ((540 + (KompassSollWert - ErsatzKompassInGrad)) % 360) - 180; |
v = r * (Parameter_KompassWirkung/2); // nach Kompass ausrichten |
CompassGierSetpoint = v / 16; |
} |
else CompassGierSetpoint = 0; |
} // CalculateCompassTimer |
} |
else CompassGierSetpoint = 0; |
//DebugOut.Analog[16] = KompassFusion; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Drehgeschwindigkeit und -winkel zu einem Istwert zusammenfassen |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(TrichterFlug) { SummeRoll = 0; SummeNick = 0;}; |
if(!Looping_Nick) IntegralNickMalFaktor = (IntegralNick * IntegralFaktor) / (44000 / STICK_GAIN); else IntegralNickMalFaktor = 0; |
if(!Looping_Roll) IntegralRollMalFaktor = (IntegralRoll * IntegralFaktor) / (44000 / STICK_GAIN); else IntegralRollMalFaktor = 0; |
#define TRIM_MAX 200 |
if(TrimNick > TRIM_MAX) TrimNick = TRIM_MAX; else if(TrimNick <-TRIM_MAX) TrimNick =-TRIM_MAX; |
if(TrimRoll > TRIM_MAX) TrimRoll = TRIM_MAX; else if(TrimRoll <-TRIM_MAX) TrimRoll =-TRIM_MAX; |
MesswertNick = IntegralNickMalFaktor + (long)((long)MesswertNick * GyroFaktor + (long)TrimNick * 128L) / (256L / STICK_GAIN); |
MesswertRoll = IntegralRollMalFaktor + (long)((long)MesswertRoll * GyroFaktor + (long)TrimRoll * 128L) / (256L / STICK_GAIN); |
MesswertGier = (long)(MesswertGier * 2 * (long)GyroFaktorGier) / (256L / STICK_GAIN) + (long)(Integral_Gier * IntegralFaktorGier) / (2 * (44000 / STICK_GAIN)); |
// Maximalwerte abfangen |
#define MAX_SENSOR (4096) |
if(MesswertNick > MAX_SENSOR) MesswertNick = MAX_SENSOR; |
if(MesswertNick < -MAX_SENSOR) MesswertNick = -MAX_SENSOR; |
if(MesswertRoll > MAX_SENSOR) MesswertRoll = MAX_SENSOR; |
if(MesswertRoll < -MAX_SENSOR) MesswertRoll = -MAX_SENSOR; |
if(MesswertGier > MAX_SENSOR) MesswertGier = MAX_SENSOR; |
if(MesswertGier < -MAX_SENSOR) MesswertGier = -MAX_SENSOR; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Undervoltage |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(!(FC_StatusFlags & FC_STATUS_LOWBAT)) |
{ |
GasMischanteil = ((unsigned int)GasMischanteil * BattLowVoltageWarning) / UBat; // Gas auf das aktuelle Spannungvieveau beziehen |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Auto-Landing |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
static unsigned char slower; |
if(!slower--) |
{ |
static unsigned int u_filter = 0; |
if(!u_filter) u_filter = UBat; |
if(UBat > u_filter) u_filter++; else |
if(UBat < u_filter) u_filter--; |
slower = 100; // 5Hz |
// if(FromNC_AltitudeSetpoint >= 0) hysteresis *= 2; |
if(u_filter < EE_Parameter.AutoLandingVoltage) |
{ |
LowVoltageLandingActive = 10; // 2 sek |
} |
else if(u_filter > EE_Parameter.AutoLandingVoltage + LipoCells && LowVoltageLandingActive) LowVoltageLandingActive--; |
} |
if(LowVoltageLandingActive && FromNC_AltitudeSetpoint >= 0) |
{ |
FromNC_AltitudeSpeed = EE_Parameter.LandingSpeed; |
FromNC_AltitudeSetpoint = -20000; |
} |
#endif |
//DebugOut.Analog[16] = StickGasMiddle; |
if(BytegapSPI == 0) SPI_TransmitByte(); |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Höhenregelung |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
GasMischanteil *= STICK_GAIN; |
// if height control is activated |
if((Parameter_GlobalConfig & CFG_HOEHENREGELUNG) && !(Looping_Roll || Looping_Nick) && !(VersionInfo.HardwareError[0] & 0x7F)) // Höhenregelung |
{ |
#define HOVER_GAS_AVERAGE 16384L // 16384 * 2ms = 32s averaging |
#define HC_GAS_AVERAGE 4 // 4 * 2ms= 8ms averaging |
int HCGas, GasReduction = 0; |
static int HeightTrimming = 0; // rate for change of height setpoint |
static int HeightDeviation = 0, FilterHCGas = 0; |
static unsigned long HoverGasFilter = 0; |
static unsigned char delay = 100, BaroAtUpperLimit = 0, BaroAtLowerLimit = 0; |
// Expand the measurement |
// measurement of air pressure close to upper limit and no overflow in correction of the new OCR0A value occurs |
if(!BaroExpandActive) |
{ |
if(MessLuftdruck > 920) |
{ // increase offset |
if(OCR0A < (255 - OPA_OFFSET_STEP)) |
{ |
ExpandBaro -= 1; |
OCR0A = DruckOffsetSetting - OPA_OFFSET_STEP * ExpandBaro; // increase offset to shift ADC down |
OCR0B = 255 - OCR0A; |
beeptime = 300; |
BaroExpandActive = 350; |
CalcExpandBaroStep(); |
} |
else |
{ |
BaroAtLowerLimit = 1; |
} |
} |
// measurement of air pressure close to lower limit and |
else |
if(MessLuftdruck < 100) |
{ // decrease offset |
if(OCR0A > OPA_OFFSET_STEP) |
{ |
ExpandBaro += 1; |
OCR0A = DruckOffsetSetting - OPA_OFFSET_STEP * ExpandBaro; // decrease offset to shift ADC up |
OCR0B = 255 - OCR0A; |
beeptime = 300; |
BaroExpandActive = 350; |
CalcExpandBaroStep(); |
} |
else |
{ |
BaroAtUpperLimit = 1; |
} |
} |
else |
{ |
BaroAtUpperLimit = 0; |
BaroAtLowerLimit = 0; |
} |
} |
else // delay, because of expanding the Baro-Range |
{ |
// now clear the D-values |
VarioMeter = 0; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(ACC_AltitudeControl) ACC_AltitudeFusion(1); // init |
else SummenHoehe = HoehenWert * SM_FILTER; |
#else |
SummenHoehe = HoehenWert * SM_FILTER; |
#endif |
BaroExpandActive--; |
} |
// if height control is activated by an rc channel |
if(Parameter_GlobalConfig & CFG_HOEHEN_SCHALTER) // Regler wird über Schalter gesteuert |
{ // check if parameter is less than activation threshold |
if(Parameter_HoehenSchalter < 50) // for 3 or 2-state switch height control is disabled in lowest position |
{ //height control not active |
if(!delay--) |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(!SpeakHoTT && HoehenReglerAktiv) SpeakHoTT = SPEAK_ALTITUDE_OFF; |
#endif |
HoehenReglerAktiv = 0; // disable height control |
SollHoehe = HoehenWert; // update SetPoint with current reading |
delay = 1; |
} |
} |
else |
if(Parameter_HoehenSchalter > 70) |
{ //height control is activated |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(!SpeakHoTT && !HoehenReglerAktiv) SpeakHoTT = SPEAK_ALTITUDE_ON; |
#endif |
delay = 200; |
HoehenReglerAktiv = 1; // enable height control |
} |
} |
else // no switchable height control |
{ |
SollHoehe = ((int16_t) ExternHoehenValue + (int16_t) Parameter_HoehenSchalter) * (int)EE_Parameter.Hoehe_Verstaerkung; |
HoehenReglerAktiv = 1; |
} |
// calculate cos of nick and roll angle used for projection of the vertical hoover gas |
tmp_int = (int)(IntegralNick/GIER_GRAD_FAKTOR); // nick angle in deg |
tmp_int2 = (int)(IntegralRoll/GIER_GRAD_FAKTOR); // roll angle in deg |
CosAttitude = (int16_t)ihypot(tmp_int, tmp_int2); // phytagoras gives effective attitude angle in deg |
LIMIT_MAX(CosAttitude, 60); // limit effective attitude angle |
CosAttitude = c_cos_8192(CosAttitude); // cos of actual attitude |
VarioCharacter = ' '; |
AltitudeSetpointTrimming = 0; |
if(HoehenReglerAktiv && !(FC_StatusFlags & FC_STATUS_EMERGENCY_LANDING)) |
{ |
// Holger original version |
// start of height control algorithm |
// the height control is only an attenuation of the actual gas stick. |
// I.e. it will work only if the gas stick is higher than the hover gas |
// and the hover height will be allways larger than height setpoint. |
FC_StatusFlags2 |= FC_STATUS2_ALTITUDE_CONTROL; |
if((Parameter_ExtraConfig & CFG2_HEIGHT_LIMIT) || !(Parameter_GlobalConfig & CFG_HOEHEN_SCHALTER)) // Regler wird über Schalter gesteuert) |
{ // old version |
HCGas = GasMischanteil; // take current stick gas as neutral point for the height control |
HeightTrimming = 0; |
AltitudeSetpointTrimming = 0; |
// set both flags to indicate no vario mode |
FC_StatusFlags |= (FC_STATUS_VARIO_TRIM_UP|FC_STATUS_VARIO_TRIM_DOWN); |
} |
else |
{ |
// alternative height control |
// PD-Control with respect to hoover point |
// the thrust loss out of horizontal attitude is compensated |
// the setpoint will be fine adjusted with the gas stick position |
if(/*1 || */FC_StatusFlags & FC_STATUS_FLY) // trim setpoint only when flying |
{ // gas stick is above hoover point |
if(StickGas > (StickGasHover + HEIGHT_CONTROL_STICKTHRESHOLD) && !BaroAtUpperLimit) |
{ |
if(FC_StatusFlags & FC_STATUS_VARIO_TRIM_DOWN) |
{ |
FC_StatusFlags &= ~FC_STATUS_VARIO_TRIM_DOWN; |
SollHoehe = HoehenWertF; // update setpoint to current heigth |
} |
// Limit the maximum Altitude |
if(Parameter_MaximumAltitude && (SollHoehe/100 > Parameter_MaximumAltitude)) |
{ |
AltitudeSetpointTrimming = 0; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(!SpeakHoTT && HoehenWert/95 > Parameter_MaximumAltitude) SpeakHoTT = SPEAK_MAX_ALTITUD; |
#endif |
VarioCharacter = '='; |
} |
else |
{ |
if(HeightDeviation > 20) SollHoehe = HoehenWertF; // update setpoint to current heigth |
FC_StatusFlags |= FC_STATUS_VARIO_TRIM_UP; |
AltitudeSetpointTrimming = abs(StickGas - (StickGasHover + HEIGHT_CONTROL_STICKTHRESHOLD)); |
if(LowVoltageLandingActive) AltitudeSetpointTrimming /= 3; // only 33% rising |
VarioCharacter = '+'; |
} |
WaypointTrimming = 0; |
} // gas stick is below hoover point |
else if(StickGas < (StickGasHover - HEIGHT_CONTROL_STICKTHRESHOLD) && !BaroAtLowerLimit ) // Minus |
{ |
if(FC_StatusFlags & FC_STATUS_VARIO_TRIM_UP) |
{ |
FC_StatusFlags &= ~FC_STATUS_VARIO_TRIM_UP; |
SollHoehe = HoehenWertF; // update setpoint to current heigth |
} |
FC_StatusFlags |= FC_STATUS_VARIO_TRIM_DOWN; |
AltitudeSetpointTrimming = -abs(StickGas - (StickGasHover - HEIGHT_CONTROL_STICKTHRESHOLD)); |
VarioCharacter = '-'; |
WaypointTrimming = 0; |
} |
else // Gas Stick in Hover Range |
{ |
VarioCharacter = '='; |
if(FromNC_AltitudeSpeed && FromNC_AltitudeSetpoint > SollHoehe) // von NC gesteuert -> Steigen |
{ |
FC_StatusFlags |= FC_STATUS_VARIO_TRIM_UP; |
AltitudeSetpointTrimming = FromNC_AltitudeSpeed; |
//HeightTrimming += FromNC_AltitudeSpeed; |
WaypointTrimming = 10; |
VarioCharacter = '^'; |
if(FC_StatusFlags & FC_STATUS_VARIO_TRIM_DOWN) // changed from sinking to rising |
{ |
FC_StatusFlags &= ~FC_STATUS_VARIO_TRIM_DOWN; |
SollHoehe = HoehenWertF; // update setpoint to current heigth |
} |
} |
else |
if(FromNC_AltitudeSpeed && FromNC_AltitudeSetpoint < SollHoehe) // von NC gesteuert -> sinken |
{ |
FC_StatusFlags |= FC_STATUS_VARIO_TRIM_DOWN; |
AltitudeSetpointTrimming = -FromNC_AltitudeSpeed; |
//HeightTrimming -= FromNC_AltitudeSpeed; |
WaypointTrimming = -10; |
VarioCharacter = 'v'; |
if(FC_StatusFlags & FC_STATUS_VARIO_TRIM_UP) // changed from rising to sinking |
{ |
FC_StatusFlags &= ~FC_STATUS_VARIO_TRIM_UP; |
SollHoehe = HoehenWertF; // update setpoint to current heigth |
} |
} |
else |
if(FC_StatusFlags & (FC_STATUS_VARIO_TRIM_UP|FC_STATUS_VARIO_TRIM_DOWN)) |
{ |
if(!WaypointTrimming) LIMIT_MIN_MAX(SollHoehe, (HoehenWertF-200), (HoehenWertF+200)) // max. 2m Unterschied |
else WaypointTrimming = 0; |
FC_StatusFlags &= ~(FC_STATUS_VARIO_TRIM_UP|FC_STATUS_VARIO_TRIM_DOWN); |
HeightTrimming = 0; |
if(Parameter_ExtraConfig & CFG2_VARIO_BEEP) beeptime = 500; |
if(!StartTrigger && HoehenWert > 50) |
{ |
StartTrigger = 1; |
} |
} |
} |
// Trim height set point |
HeightTrimming += AltitudeSetpointTrimming; |
if(abs(HeightTrimming) > 500) // bei Waypoint-Flug ist das ca. die 500Hz |
{ |
if(WaypointTrimming) |
{ |
if(abs(FromNC_AltitudeSetpoint - SollHoehe) < 10) SollHoehe = FromNC_AltitudeSetpoint; |
else SollHoehe += WaypointTrimming; |
} |
else |
{ |
if(HeightTrimming > 0) SollHoehe += EE_Parameter.Hoehe_Verstaerkung / 3; |
else SollHoehe -= EE_Parameter.Hoehe_Verstaerkung / 3; |
} |
HeightTrimming = 0; |
LIMIT_MIN_MAX(SollHoehe, (HoehenWert-1024), (HoehenWert+1024)); // max. 10m Unterschied |
if(Parameter_ExtraConfig & CFG2_VARIO_BEEP) beeptime = 100; |
//update hoover gas stick value when setpoint is shifted |
if(!EE_Parameter.Hoehe_StickNeutralPoint && FromNC_AltitudeSpeed == 0) |
{ |
StickGasHover = HoverGas/STICK_GAIN; //rescale back to stick value |
StickGasHover = (StickGasHover * UBat) / BattLowVoltageWarning; |
if(StickGasHover < 70) StickGasHover = 70; |
else if(StickGasHover > 150) StickGasHover = 150; |
} |
} |
if(BaroExpandActive) SollHoehe = HoehenWertF; // update setpoint to current altitude if Expanding is active |
} //if FCFlags & MKFCFLAG_FLY |
else |
{ |
SollHoehe = HoehenWert - 400; |
if(EE_Parameter.Hoehe_StickNeutralPoint) StickGasHover = EE_Parameter.Hoehe_StickNeutralPoint; |
else StickGasHover = 120; |
HoverGas = GasMischanteil; |
VarioCharacter = '.'; |
} |
HCGas = HoverGas; // take hover gas (neutral point) |
} |
if(HoehenWertF > SollHoehe || !(Parameter_ExtraConfig & CFG2_HEIGHT_LIMIT)) |
{ |
if(!ACC_AltitudeControl) |
{ |
// from this point the Heigth Control Algorithm is identical for both versions |
if(BaroExpandActive) // baro range expanding active |
{ |
HCGas = HoverGas; // hover while expanding baro adc range |
HeightDeviation = 0; |
} // EOF // baro range expanding active |
else // valid data from air pressure sensor |
{ |
// ------------------------- P-Part ---------------------------- |
tmp_long = (HoehenWertF - SollHoehe); // positive when too high |
LIMIT_MIN_MAX(tmp_long, -32767L, 32767L); // avoid overflov when casting to int16_t |
HeightDeviation = (int)(tmp_long); // positive when too high |
tmp_long = (tmp_long * (long)Parameter_Hoehe_P) / 32L; // p-part |
LIMIT_MIN_MAX(tmp_long, -127 * STICK_GAIN, 256 * STICK_GAIN); // more than the full range makes no sense |
GasReduction = tmp_long; |
// ------------------------- D-Part 1: Vario Meter ---------------------------- |
tmp_int = VarioMeter / 8; |
LIMIT_MIN_MAX(tmp_int, -127, 128); |
tmp_int = (tmp_int * (long)Parameter_Luftdruck_D) / 4L; // scale to d-gain parameter |
LIMIT_MIN_MAX(tmp_int,-64 * STICK_GAIN, 64 * STICK_GAIN); |
if(FC_StatusFlags & (FC_STATUS_VARIO_TRIM_UP|FC_STATUS_VARIO_TRIM_DOWN)) tmp_int /= 4; // reduce d-part while trimming setpoint |
else |
if(Parameter_ExtraConfig & CFG2_HEIGHT_LIMIT) tmp_int /= 8; // reduce d-part in "Deckel" mode |
GasReduction += tmp_int; |
} // EOF no baro range expanding |
// ------------------------ D-Part 2: ACC-Z Integral ------------------------ |
if(Parameter_Hoehe_ACC_Wirkung) |
{ |
tmp_long = ((Mess_Integral_Hoch / 128L) * (int32_t) Parameter_Hoehe_ACC_Wirkung) / (128L / STICK_GAIN); |
LIMIT_MIN_MAX(tmp_long, -32 * STICK_GAIN, 64 * STICK_GAIN); |
GasReduction += tmp_long; |
} |
// ------------------------ D-Part 3: GpsZ ---------------------------------- |
tmp_int = (Parameter_Hoehe_GPS_Z * (int)FromNaviCtrl_Value.GpsZ)/128L; |
LIMIT_MIN_MAX(tmp_int, -32 * STICK_GAIN, 64 * STICK_GAIN); |
GasReduction += tmp_int; |
GasReduction = (long)((long)GasReduction * HoverGas) / 512; // scale to the gas value |
// ------------------------ ---------------------------------- |
HCGas -= GasReduction; |
// limit deviation from hoover point within the target region |
if(!AltitudeSetpointTrimming && HoverGas > 0) // height setpoint is not changed and hoover gas not zero |
{ |
unsigned int tmp; |
tmp = abs(HeightDeviation); |
if(tmp <= 60) |
{ |
LIMIT_MIN_MAX(HCGas, HoverGasMin, HoverGasMax); // limit gas around the hoover point |
} |
else |
{ |
tmp = (tmp - 60) / 32; |
if(tmp > 15) tmp = 15; |
if(HeightDeviation > 0) |
{ |
tmp = (HoverGasMin * (16 - tmp)) / 16; |
LIMIT_MIN_MAX(HCGas, tmp, HoverGasMax); // limit gas around the hoover point |
} |
else |
{ |
tmp = (HoverGasMax * (tmp + 16)) / 16; |
LIMIT_MIN_MAX(HCGas, HoverGasMin, tmp); // limit gas around the hoover point |
} |
} |
} |
// strech control output by inverse attitude projection 1/cos |
// + 1/cos(angle) ++++++++++++++++++++++++++ |
tmp_long2 = (int32_t)HCGas; |
tmp_long2 *= 8192L; |
tmp_long2 /= CosAttitude; |
HCGas = (int16_t)tmp_long2; |
// update height control gas averaging |
FilterHCGas = (FilterHCGas * (HC_GAS_AVERAGE - 1) + HCGas) / HC_GAS_AVERAGE; |
// limit height control gas pd-control output |
LIMIT_MIN_MAX(FilterHCGas, EE_Parameter.Hoehe_MinGas * STICK_GAIN, (MAX_GAS - 20) * STICK_GAIN); |
// set GasMischanteil to HeightControlGasFilter |
if(Parameter_ExtraConfig & CFG2_HEIGHT_LIMIT) |
{ // old version |
LIMIT_MAX(FilterHCGas, GasMischanteil); // nicht mehr als Gas |
GasMischanteil = FilterHCGas; |
} |
else GasMischanteil = FilterHCGas + (GasMischanteil - HoverGas) / 4; // only in Vario-Mode |
} |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
else // ACC-Altitude control |
{ |
// from this point the Heigth Control Algorithm is identical for both versions |
if(BaroExpandActive) // baro range expanding active |
{ |
HCGas = HoverGas; // hover while expanding baro adc range |
HeightDeviation = 0; |
} // EOF // baro range expanding active |
else // valid data from air pressure sensor |
{ |
// ------------------------- P-Part ---------------------------- |
tmp_long = (HoehenWertF - SollHoehe); // positive when too high |
LIMIT_MIN_MAX(tmp_long, -32767L, 32767L); // avoid overflov when casting to int16_t |
HeightDeviation = (int)(tmp_long); // positive when too high |
tmp_long = (tmp_long * (long)Parameter_Hoehe_P) / 32L; // p-part |
LIMIT_MIN_MAX(tmp_long, -511 * STICK_GAIN, 512 * STICK_GAIN); // more than full range makes sense |
GasReduction = tmp_long; |
// ------------------------ D-Part: ACC-Z Integral ------------------------ |
tmp_long = VarioMeter + (AdWertAccHoch * Parameter_Hoehe_ACC_Wirkung)/256; |
// ------------------------- D-Part: Vario Meter ---------------------------- |
if(WaypointTrimming) { |
Variance = AltitudeSetpointTrimming * 8; |
} else { |
Variance = AltitudeSetpointTrimming * EE_Parameter.Hoehe_Verstaerkung*9/32; |
} |
tmp_long -= (long)Variance; |
tmp_long = (tmp_long * (long)Parameter_Luftdruck_D) / 32; // scale to d-gain parameter |
LIMIT_MIN_MAX(tmp_long,-511 * STICK_GAIN, 512 * STICK_GAIN); |
GasReduction += tmp_long; |
} // EOF no baro range expanding |
HCGas -= GasReduction; |
LIMIT_MIN_MAX(HCGas, HoverGasMin, HoverGasMax); // limits gas around hover point |
// strech control output by inverse attitude projection 1/cos |
// + 1/cos(angle) ++++++++++++++++++++++++++ |
tmp_long2 = (int32_t)HCGas; |
tmp_long2 *= 8192L; |
tmp_long2 /= CosAttitude; |
HCGas = (int16_t)tmp_long2; |
// update height control gas averaging |
FilterHCGas = (FilterHCGas * (HC_GAS_AVERAGE - 1) + HCGas) / HC_GAS_AVERAGE; |
// limit height control gas pd-control output |
LIMIT_MIN_MAX(FilterHCGas, EE_Parameter.Hoehe_MinGas * STICK_GAIN, (MAX_GAS - 20) * STICK_GAIN); |
// set GasMischanteil to HeightControlGasFilter |
if(Parameter_ExtraConfig & CFG2_HEIGHT_LIMIT) |
{ // old version |
LIMIT_MAX(FilterHCGas, GasMischanteil); // nicht mehr als Gas |
GasMischanteil = FilterHCGas; |
} |
else GasMischanteil = FilterHCGas; |
} // end of ACC-Altitude control |
#endif |
} |
}// EOF height control active |
else // HC not active |
{ |
//update hoover gas stick value when HC is not active |
if(!EE_Parameter.Hoehe_StickNeutralPoint) |
{ |
StickGasHover = HoverGas/STICK_GAIN; // rescale back to stick value |
StickGasHover = (StickGasHover * UBat) / BattLowVoltageWarning; |
} |
else StickGasHover = EE_Parameter.Hoehe_StickNeutralPoint; |
LIMIT_MIN_MAX(StickGasHover, 70, 150); // reserve some range for trim up and down |
FilterHCGas = GasMischanteil; |
// set both flags to indicate no vario mode |
FC_StatusFlags |= (FC_STATUS_VARIO_TRIM_UP|FC_STATUS_VARIO_TRIM_DOWN); |
FC_StatusFlags2 &= ~FC_STATUS2_ALTITUDE_CONTROL; |
} |
// Hover gas estimation by averaging gas control output on small z-velocities |
// this is done only if height contol option is selected in global config and aircraft is flying |
if((FC_StatusFlags & FC_STATUS_FLY))// && !(FC_SatusFlags & FC_STATUS_EMERGENCY_LANDING)) |
{ |
//if(HoverGasFilter == 0 || StartTrigger == 1) HoverGasFilter = HOVER_GAS_AVERAGE * (unsigned long)(GasMischanteil); // init estimation |
if(HoverGasFilter == 0 || StartTrigger == 1) HoverGasFilter = HOVER_GAS_AVERAGE * (unsigned long)(HoverGas); // 0.90f: geändert |
if(StartTrigger == 1) StartTrigger = 2; |
tmp_long2 = (int32_t)GasMischanteil; // take current thrust |
tmp_long2 *= CosAttitude; // apply attitude projection |
tmp_long2 /= 8192; |
// average vertical projected thrust |
if(modell_fliegt < 4000) // the first 8 seconds |
{ // reduce the time constant of averaging by factor of 4 to get much faster a stable value |
HoverGasFilter -= HoverGasFilter/(HOVER_GAS_AVERAGE/16L); |
HoverGasFilter += 16L * tmp_long2; |
} |
if(modell_fliegt < 8000) // the first 16 seconds |
{ // reduce the time constant of averaging by factor of 2 to get much faster a stable value |
HoverGasFilter -= HoverGasFilter/(HOVER_GAS_AVERAGE/4L); |
HoverGasFilter += 4L * tmp_long2; |
} |
else //later |
if(abs(VarioMeter) < 100 && abs(HoehenWertF - SollHoehe) < 256) // only on small vertical speed & difference is small (only descending) |
{ |
HoverGasFilter -= HoverGasFilter/HOVER_GAS_AVERAGE; |
HoverGasFilter += tmp_long2; |
} |
HoverGas = (int16_t)(HoverGasFilter/HOVER_GAS_AVERAGE); |
if(EE_Parameter.Hoehe_HoverBand) |
{ |
int16_t band; |
band = HoverGas / EE_Parameter.Hoehe_HoverBand; // the higher the parameter the smaller the range |
HoverGasMin = HoverGas - band; |
HoverGasMax = HoverGas + band; |
} |
else |
{ // no limit |
HoverGasMin = 0; |
HoverGasMax = 1023; |
} |
} |
else |
{ |
StartTrigger = 0; |
HoverGasFilter = 0; |
HoverGas = 0; |
} |
}// EOF Parameter_GlobalConfig & CFG_HEIGHT_CONTROL |
else |
{ |
// set undefined state to indicate vario off |
FC_StatusFlags |= (FC_STATUS_VARIO_TRIM_UP|FC_STATUS_VARIO_TRIM_DOWN); |
} // EOF no height control |
// Limits the maximum gas in case of "Out of Range emergency landing" |
if(NC_To_FC_Flags & NC_TO_FC_EMERGENCY_LANDING) |
{ |
if(GasMischanteil/STICK_GAIN > HooverGasEmergencyPercent && HoverGas) GasMischanteil = HooverGasEmergencyPercent * STICK_GAIN; |
SollHoehe = HoehenWertF; // update setpoint to current heigth |
beeptime = 15000; |
BeepMuster = 0x0E00; |
} |
// limit gas to parameter setting |
LIMIT_MIN(GasMischanteil, (MIN_GAS + 10) * STICK_GAIN); |
if(GasMischanteil > (MAX_GAS - 20) * STICK_GAIN) GasMischanteil = (MAX_GAS - 20) * STICK_GAIN; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// all BL-Ctrl connected? |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(MissingMotor || Capacity.MinOfMaxPWM != 255 || NC_ErrorCode) // wait until all BL-Ctrls started and no Errors |
if(modell_fliegt > 1 && modell_fliegt < 50 && GasMischanteil > 0) // only during start-phase |
{ |
modell_fliegt = 1; |
GasMischanteil = (MIN_GAS + 10) * STICK_GAIN; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(Capacity.MinOfMaxPWM < 40) SpeakHoTT = SPEAK_ERR_MOTOR; |
#endif |
} |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Mischer und PI-Regler |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
DebugOut.Analog[7] = GasMischanteil; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Gier-Anteil |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
GierMischanteil = MesswertGier - sollGier * STICK_GAIN; // Regler für Gier |
#define MIN_GIERGAS (40*STICK_GAIN) // unter diesem Gaswert trotzdem Gieren |
if(GasMischanteil > MIN_GIERGAS) |
{ |
if(GierMischanteil > (GasMischanteil / 2)) GierMischanteil = GasMischanteil / 2; |
if(GierMischanteil < -(GasMischanteil / 2)) GierMischanteil = -(GasMischanteil / 2); |
} |
else |
{ |
if(GierMischanteil > (MIN_GIERGAS / 2)) GierMischanteil = MIN_GIERGAS / 2; |
if(GierMischanteil < -(MIN_GIERGAS / 2)) GierMischanteil = -(MIN_GIERGAS / 2); |
} |
tmp_int = MAX_GAS*STICK_GAIN; |
if(GierMischanteil > ((tmp_int - GasMischanteil))) GierMischanteil = ((tmp_int - GasMischanteil)); |
if(GierMischanteil < -((tmp_int - GasMischanteil))) GierMischanteil = -((tmp_int - GasMischanteil)); |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Nick-Achse |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
DiffNick = MesswertNick - StickNick; // Differenz bestimmen |
if(IntegralFaktor) SummeNick += IntegralNickMalFaktor - StickNick; // I-Anteil bei Winkelregelung |
else SummeNick += DiffNick; // I-Anteil bei HH |
if(SummeNick > (STICK_GAIN * 16000L)) SummeNick = (STICK_GAIN * 16000L); |
if(SummeNick < -(16000L * STICK_GAIN)) SummeNick = -(16000L * STICK_GAIN); |
if(EE_Parameter.Gyro_Stability <= 8) pd_ergebnis_nick = (EE_Parameter.Gyro_Stability * DiffNick) / 8; // PI-Regler für Nick |
else pd_ergebnis_nick = ((EE_Parameter.Gyro_Stability / 2) * DiffNick) / 4; // Überlauf verhindern |
pd_ergebnis_nick += SummeNick / Ki; |
tmp_int = (long)((long)Parameter_DynamicStability * (long)(GasMischanteil + abs(GierMischanteil)/2)) / 64; |
if(pd_ergebnis_nick > tmp_int) pd_ergebnis_nick = tmp_int; |
if(pd_ergebnis_nick < -tmp_int) pd_ergebnis_nick = -tmp_int; |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Roll-Achse |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
DiffRoll = MesswertRoll - StickRoll; // Differenz bestimmen |
if(IntegralFaktor) SummeRoll += IntegralRollMalFaktor - StickRoll;// I-Anteil bei Winkelregelung |
else SummeRoll += DiffRoll; // I-Anteil bei HH |
if(SummeRoll > (STICK_GAIN * 16000L)) SummeRoll = (STICK_GAIN * 16000L); |
if(SummeRoll < -(16000L * STICK_GAIN)) SummeRoll = -(16000L * STICK_GAIN); |
if(EE_Parameter.Gyro_Stability <= 8) pd_ergebnis_roll = (EE_Parameter.Gyro_Stability * DiffRoll) / 8; // PI-Regler für Roll |
else pd_ergebnis_roll = ((EE_Parameter.Gyro_Stability / 2) * DiffRoll) / 4; // Überlauf verhindern |
pd_ergebnis_roll += SummeRoll / Ki; |
tmp_int = (long)((long)Parameter_DynamicStability * (long)(GasMischanteil + abs(GierMischanteil)/2)) / 64; |
if(pd_ergebnis_roll > tmp_int) pd_ergebnis_roll = tmp_int; |
if(pd_ergebnis_roll < -tmp_int) pd_ergebnis_roll = -tmp_int; |
if(BytegapSPI == 0) SPI_TransmitByte(); |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Universal Mixer |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
for(i=0; i<MAX_MOTORS; i++) |
{ |
signed int tmp_int; |
if(Mixer.Motor[i][0] > 0) |
{ |
// Gas |
if(Mixer.Motor[i][0] == 64) tmp_int = GasMischanteil; else tmp_int = ((long)GasMischanteil * Mixer.Motor[i][0]) / 64L; |
// Nick |
if(Mixer.Motor[i][1] == 64) tmp_int += pd_ergebnis_nick; |
else if(Mixer.Motor[i][1] == -64) tmp_int -= pd_ergebnis_nick; |
else tmp_int += ((long)pd_ergebnis_nick * Mixer.Motor[i][1]) / 64L; |
// Roll |
if(Mixer.Motor[i][2] == 64) tmp_int += pd_ergebnis_roll; |
else if(Mixer.Motor[i][2] == -64) tmp_int -= pd_ergebnis_roll; |
else tmp_int += ((long)pd_ergebnis_roll * Mixer.Motor[i][2]) / 64L; |
// Gier |
if(Mixer.Motor[i][3] == 64) tmp_int += GierMischanteil; |
else if(Mixer.Motor[i][3] == -64) tmp_int -= GierMischanteil; |
else tmp_int += ((long)GierMischanteil * Mixer.Motor[i][3]) / 64L; |
if(Motor[i].Version & MOTOR_STATE_FAST_MODE || tmp_int > tmp_motorwert[i]) tmp_int = (tmp_motorwert[i] + tmp_int) / 2; // Beschleunigen |
else |
{ // BL-Ctrl 1.0 or 2.0 |
if(EE_Parameter.MotorSmooth == 0) |
{ |
tmp_int = 2 * tmp_int - tmp_motorwert[i]; // original MotorSmoothing |
} |
else // 1 means tmp_int = tmp_int; |
if(EE_Parameter.MotorSmooth > 1) |
{ |
// If >= 2 then allow >= 50% of the intended step down to rapidly reach the intended value. |
tmp_int = tmp_int + ((tmp_motorwert[i] - tmp_int) / EE_Parameter.MotorSmooth); |
} |
} |
LIMIT_MIN_MAX(tmp_int,(int) MIN_GAS * 4,(int) MAX_GAS * 4); |
Motor[i].SetPoint = tmp_int / 4; |
Motor[i].SetPointLowerBits = (tmp_int % 4)<<1; // (3 bits total) |
tmp_motorwert[i] = tmp_int; |
} |
else |
{ |
Motor[i].SetPoint = 0; |
Motor[i].SetPointLowerBits = 0; |
} |
} |
} |
//DebugOut.Analog[16] |
/tags/V2.02b/fc.h |
---|
0,0 → 1,153 |
/*####################################################################################### |
Flight Control |
#######################################################################################*/ |
#ifndef _FC_H |
#define _FC_H |
//#define GIER_GRAD_FAKTOR 1291L // Abhängigkeit zwischen GyroIntegral und Winkel |
//#define GIER_GRAD_FAKTOR 1160L |
extern long GIER_GRAD_FAKTOR; // Abhängigkeit zwischen GyroIntegral und Winkel |
#define STICK_GAIN 4 |
#define ACC_AMPLIFY 6 |
#define HEIGHT_CONTROL_STICKTHRESHOLD 15 |
// FC_StatusFlags |
#define FC_STATUS_MOTOR_RUN 0x01 |
#define FC_STATUS_FLY 0x02 |
#define FC_STATUS_CALIBRATE 0x04 |
#define FC_STATUS_START 0x08 |
#define FC_STATUS_EMERGENCY_LANDING 0x10 |
#define FC_STATUS_LOWBAT 0x20 |
#define FC_STATUS_VARIO_TRIM_UP 0x40 |
#define FC_STATUS_VARIO_TRIM_DOWN 0x80 |
// FC_StatusFlags2 |
#define FC_STATUS2_CAREFREE 0x01 |
#define FC_STATUS2_ALTITUDE_CONTROL 0x02 |
#define FC_STATUS2_RC_FAILSAVE_ACTIVE 0x04 |
#define FC_STATUS2_OUT1_ACTIVE 0x08 |
#define FC_STATUS2_OUT2_ACTIVE 0x10 |
#define FC_STATUS2_WAIT_FOR_TAKEOFF 0x20 // Motor Running, but still on the ground |
#define FC_STATUS2_AUTO_STARTING 0x40 |
#define FC_STATUS2_AUTO_LANDING 0x80 |
//NC_To_FC_Flags |
#define NC_TO_FC_FLYING_RANGE 0x01 |
#define NC_TO_FC_EMERGENCY_LANDING 0x02 |
#define NC_TO_FC_AUTOSTART 0x04 |
#define NC_TO_FC_AUTOLANDING 0x08 // not used |
extern volatile unsigned char FC_StatusFlags, FC_StatusFlags2; |
extern void ParameterZuordnung(void); |
extern unsigned char GetChannelValue(unsigned char ch); // gives the unsigned value of the channel |
#define Poti1 Poti[0] |
#define Poti2 Poti[1] |
#define Poti3 Poti[2] |
#define Poti4 Poti[3] |
#define Poti5 Poti[4] |
#define Poti6 Poti[5] |
#define Poti7 Poti[6] |
#define Poti8 Poti[7] |
#define LIMIT_MIN(value, min) {if(value <= min) value = min;} |
#define LIMIT_MAX(value, max) {if(value >= max) value = max;} |
#define LIMIT_MIN_MAX(value, min, max) {if(value <= min) value = min; else if(value >= max) value = max;} |
#define CHK_POTI(b,a) {if(a < 248) b = a; else b = Poti[255 - a];} |
#define CHK_POTI_OFF(b,a,off) {if(a < 248) b = a; else b = Poti[255 - a] - off;} |
#define CHK_POTI_MM(b,a,min,max) {CHK_POTI(b,a); LIMIT_MIN_MAX(b, min, max);} |
#define CHK_POTI_MM_OFF(b,a,min,max,off) {CHK_POTI_OFF(b,a,off); LIMIT_MIN_MAX(b, min, max);} |
extern unsigned char Sekunde,Minute; |
extern unsigned int BaroExpandActive; |
extern long IntegralNick,IntegralNick2; |
extern long IntegralRoll,IntegralRoll2; |
//extern int IntegralNick,IntegralNick2; |
//extern int IntegralRoll,IntegralRoll2; |
extern unsigned char Poti[9]; |
extern long Mess_IntegralNick,Mess_IntegralNick2; |
extern long Mess_IntegralRoll,Mess_IntegralRoll2; |
extern long IntegralAccNick,IntegralAccRoll; |
extern long SummeNick,SummeRoll; |
extern volatile long Mess_Integral_Hoch; |
extern long Integral_Gier,Mess_Integral_Gier,Mess_Integral_Gier2; |
extern int KompassValue; |
extern int KompassSollWert; |
extern int KompassRichtung; |
extern char CalculateCompassTimer; |
extern unsigned char KompassFusion; |
extern unsigned char ControlHeading; |
extern int TrimNick, TrimRoll; |
extern long ErsatzKompass; |
extern int ErsatzKompassInGrad; // Kompasswert in Grad |
extern long HoehenWert; |
extern long SollHoehe; |
extern long FromNC_AltitudeSetpoint; |
extern unsigned char FromNC_AltitudeSpeed; |
extern unsigned char Parameter_HoehenSchalter; // Wert : 0-250 |
extern unsigned char CareFree; |
extern int MesswertNick,MesswertRoll,MesswertGier; |
extern int AdNeutralNick,AdNeutralRoll,AdNeutralGier, Mittelwert_AccNick, Mittelwert_AccRoll; |
extern unsigned int NeutralAccX, NeutralAccY; |
extern unsigned char HoehenReglerAktiv; |
extern int NeutralAccZ; |
extern signed char NeutralAccZfine; |
extern long Umschlag180Nick, Umschlag180Roll; |
extern signed int ExternStickNick,ExternStickRoll,ExternStickGier; |
extern unsigned char Parameter_UserParam1,Parameter_UserParam2,Parameter_UserParam3,Parameter_UserParam4,Parameter_UserParam5,Parameter_UserParam6,Parameter_UserParam7,Parameter_UserParam8; |
extern int NaviAccNick,NaviAccRoll,NaviCntAcc; |
extern unsigned int modell_fliegt; |
extern void MotorRegler(void); |
extern void SendMotorData(void); |
//void CalibrierMittelwert(void); |
//void Mittelwert(void); |
extern unsigned char SetNeutral(unsigned char AccAdjustment); // retuns: "sucess" |
extern void Piep(unsigned char Anzahl, unsigned int dauer); |
extern void CopyDebugValues(void); |
extern unsigned char ACC_AltitudeControl; |
extern signed int CosAttitude; // for projection of hoover gas |
extern unsigned char h,m,s; |
extern int StickNick,StickRoll,StickGier,StickGas; |
extern volatile unsigned char Timeout ; |
extern unsigned char CosinusNickWinkel, CosinusRollWinkel; |
extern int DiffNick,DiffRoll; |
//extern int Poti1, Poti2, Poti3, Poti4; |
extern volatile unsigned char SenderOkay; |
extern int StickNick,StickRoll,StickGier; |
extern char MotorenEin; |
extern unsigned char CalibrationDone; |
extern unsigned char Parameter_Servo3,Parameter_Servo4,Parameter_Servo5; |
extern char VarioCharacter; |
extern signed int AltitudeSetpointTrimming; |
extern signed char WaypointTrimming; |
extern int HoverGas; |
extern unsigned char Parameter_Luftdruck_D; |
//extern unsigned char Parameter_MaxHoehe; |
extern unsigned char Parameter_Hoehe_P; |
extern unsigned char Parameter_Hoehe_ACC_Wirkung; |
extern unsigned char Parameter_KompassWirkung; |
extern unsigned char Parameter_Gyro_P; |
extern unsigned char Parameter_Gyro_I; |
extern unsigned char Parameter_Gier_P; |
extern unsigned char Parameter_ServoNickControl; |
extern unsigned char Parameter_ServoRollControl; |
extern unsigned char Parameter_ServoNickComp; |
extern unsigned char Parameter_ServoRollComp; |
extern unsigned char Parameter_AchsKopplung1; |
extern unsigned char Parameter_AchsKopplung2; |
//extern unsigned char Parameter_AchsGegenKopplung1; |
extern unsigned char Parameter_J16Bitmask; // for the J16 Output |
extern unsigned char Parameter_J16Timing; // for the J16 Output |
extern unsigned char Parameter_J17Bitmask; // for the J17 Output |
extern unsigned char Parameter_J17Timing; // for the J17 Output |
extern unsigned char Parameter_GlobalConfig; |
extern unsigned char Parameter_ExtraConfig; |
extern signed char MixerTable[MAX_MOTORS][4]; |
extern const signed char sintab[31]; |
extern unsigned char LowVoltageLandingActive; |
#endif //_FC_H |
/tags/V2.02b/flight.pnproj |
---|
0,0 → 1,0 |
<Project name="Flight-Ctrl"><File path="uart.h"></File><File path="jeti.h"></File><File path="main.c"></File><File path="main.h"></File><File path="makefile"></File><File path="uart.c"></File><File path="printf_P.h"></File><File path="timer0.c"></File><File path="timer0.h"></File><File path="old_macros.h"></File><File path="twimaster.c"></File><File path="version.txt"></File><File path="twimaster.h"></File><File path="rc.c"></File><File path="rc.h"></File><File path="fc.h"></File><File path="menu.h"></File><File path="menu.c"></File><File path="_Settings.h"></File><File path="analog.c"></File><File path="analog.h"></File><File path="GPS.c"></File><File path="gps.h"></File><File path="License.txt"></File><File path="spi.h"></File><File path="spi.c"></File><File path="led.h"></File><File path="led.c"></File><File path="fc.c"></File><File path="mymath.c"></File><File path="mymath.h"></File><File path="isqrt.S"></File><File path="Spektrum.c"></File><File path="Spektrum.h"></File><File path="eeprom.h"></File><File path="eeprom.c"></File><File path="libfc.h"></File><File path="debug.c"></File><File path="debug.h"></File><File path="hottmenu.c"></File><File path="hottmenu.h"></File></Project> |
/tags/V2.02b/flight.pnps |
---|
0,0 → 1,0 |
<pd><ViewState><e p="Flight-Ctrl" x="true"></e></ViewState></pd> |
/tags/V2.02b/gps.h |
---|
0,0 → 1,3 |
extern signed int GPS_Nick; |
extern signed int GPS_Roll; |
extern unsigned char GPS_Aid_StickMultiplikator; |
/tags/V2.02b/hottmenu.c |
---|
0,0 → 1,859 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "libfc.h" |
#include "printf_P.h" |
#include "main.h" |
#include "spi.h" |
#include "capacity.h" |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#define HoTT_printf(format, args...) { _printf_P(&LIBFC_HoTT_Putchar, PSTR(format) , ## args);} |
#define HoTT_printfxy(x,y,format, args...) { LIBFC_HoTT_SetPos(y * 21 + x); _printf_P(&LIBFC_HoTT_Putchar, PSTR(format) , ## args);} |
#define HoTT_printfxy_INV(x,y,format, args...) { LIBFC_HoTT_SetPos(y * 21 + x); _printf_P(&LIBFC_HoTT_Putchar_INV, PSTR(format) , ## args);} |
#define HoTT_printfxy_BLINK(x,y,format, args...) { LIBFC_HoTT_SetPos(y * 21 + x); _printf_P(&LIBFC_HoTT_Putchar_BLINK, PSTR(format) , ## args);} |
#define HoTT_printf_BLINK(format, args...) { _printf_P(&LIBFC_HoTT_Putchar_BLINK, PSTR(format) , ## args);} |
#define HoTT_printf_INV(format, args...) { _printf_P(&LIBFC_HoTT_Putchar_INV, PSTR(format) , ## args);} |
#define VOICE_MINIMALE_EINGANSSPANNUNG 16 |
#define VOICE_BEEP 5 |
#define HoTT_GRAD 96 |
#define HoTT_LINKS 123 |
#define HoTT_RECHTS 124 |
#define HoTT_OBEN 125 |
#define HoTT_UNTEN 126 |
#define HOTT_KEY_RIGHT 1 |
#define HOTT_KEY_DOWN 2 |
#define HOTT_KEY_UP 4 |
#define HOTT_KEY_SET 6 |
#define HOTT_KEY_LEFT 8 |
#define VARIO_ZERO 30000 |
unsigned char NaviData_WaypointIndex = 0, NaviData_WaypointNumber = 0, NaviData_TargetHoldTime = 0; |
unsigned int NaviData_TargetDistance = 0; |
unsigned char MaxBlTemperture = 0; |
unsigned char MinBlTemperture = 0; |
unsigned char HottestBl = 0; |
GPSPacket_t GPSPacket; |
VarioPacket_t VarioPacket; |
ASCIIPacket_t ASCIIPacket; |
ElectricAirPacket_t ElectricAirPacket; |
HoTTGeneral_t HoTTGeneral; |
unsigned char SpeakHoTT = SPEAK_MIKROKOPTER; |
unsigned char ToNC_SpeakHoTT = 0, ShowSettingNameTime = 0; |
int HoTTVarioMeter = 0; |
const char PROGMEM MIKROKOPTER[] = {" MikroKopter "}; |
const char PROGMEM UNDERVOLTAGE[] = {" !! LiPo voltage !! "}; |
const char PROGMEM LANDING[] = {" !! LANDING !! "}; |
const char PROGMEM SETTING[] = {"Set :"}; |
const char PROGMEM NC_ERROR_TEXT[MAX_ERR_NUMBER][17] = |
{ |
//0123456789123456 |
"No Error \0", // 0 |
"Not compatible \0", // 1 |
"MK3Mag not compa\0", // 2 |
"No FC communicat\0", // 3 |
"Compass communic\0", // 4 |
"GPS communicatio\0", // 5 |
"compass value \0", // 6 |
"RC Signal lost \0", // 7 |
"FC spi rx error \0", // 8 |
"No NC communicat\0", // 9 |
"FC Nick Gyro \0", // 10 |
"FC Roll Gyro \0", // 11 |
"FC Yaw Gyro \0", // 12 |
"FC Nick ACC \0", // 13 |
"FC Roll ACC \0", // 14 |
"FC Z-ACC \0", // 15 |
"Pressure sensor \0", // 16 |
"I2C FC->BL-Ctrl \0", // 17 |
"Bl Missing \0", // 18 |
"Mixer Error \0", // 19 |
"Carefree Error \0", // 20 |
"GPS Fix lost \0", // 21 |
"Magnet Error \0", // 22 |
"Motor restart \0", // 23 |
"BL Limitation \0", // 24 |
"GPS Range \0", // 25 |
"No SD-Card \0", // 26 |
"SD-Logging error\0", // 27 |
"Flying range! \0", // 28 |
"Max Altitude! \0", // 29 |
"No GPS fix \0", // 30 |
"compass not cal.\0", // 31 |
"BL-Selftest \0" // 32 |
}; |
const char PROGMEM HOTT_ERROR[MAX_ERR_NUMBER][2] = |
{ // 1 -> only in flight 0 -> also on ground |
//0123456789123456 |
{0,0},// "No Error \0", // 0 |
{SPEAK_ERROR,0}, // "Not compatible \0", // 1 |
{SPEAK_ERROR,0}, // "MK3Mag not compa\0", // 2 |
{SPEAK_ERR_NAVI,1}, // "No FC communicat\0", // 3 |
{SPEAK_ERR_COMPASS,1}, // "MK3Mag communica\0", // 4 |
{SPEAK_ERR_GPS,0}, // "GPS communicatio\0", // 5 |
{SPEAK_ERR_COMPASS,1}, // "compass value \0", // 6 |
{SPEAK_ERR_RECEICER,0},// "RC Signal lost \0", // 7 |
{SPEAK_ERR_NAVI,0}, // "FC spi rx error \0", // 8 |
{SPEAK_ERR_NAVI,0}, // "No NC communicat\0", // 9 |
{SPEAK_ERR_SENSOR,0}, // "FC Nick Gyro \0", // 10 |
{SPEAK_ERR_SENSOR,0}, // "FC Roll Gyro \0", // 11 |
{SPEAK_ERR_SENSOR,0}, // "FC Yaw Gyro \0", // 12 |
{SPEAK_ERR_SENSOR,0}, // "FC Nick ACC \0", // 13 |
{SPEAK_ERR_SENSOR,0}, // "FC Roll ACC \0", // 14 |
{SPEAK_ERR_SENSOR,0}, // "FC Z-ACC \0", // 15 |
{SPEAK_ERR_SENSOR,0}, // "Pressure sensor \0", // 16 |
{SPEAK_ERR_DATABUS,1}, // "I2C FC->BL-Ctrl \0", // 17 |
{SPEAK_ERR_DATABUS,1}, // "Bl Missing \0", // 18 |
{SPEAK_ERROR,0}, // "Mixer Error \0", // 19 |
{SPEAK_CF_OFF,1}, // "Carefree Error \0", // 20 |
{SPEAK_GPS_FIX,1}, // "GPS Fix lost \0", // 21 |
{SPEAK_ERR_COMPASS,0}, // "Magnet Error \0", // 22 |
{SPEAK_ERR_MOTOR,1}, // "Motor restart \0", // 23 |
{SPEAK_MAX_TEMPERAT,1},// "BL Limitation \0", // 24 |
{SPEAK_MAX_RANGE,1}, // "GPS Range \0", // 25 |
{SPEAK_ERROR,1}, // "No SD-Card \0", // 26 |
{SPEAK_ERROR,1}, // "SD-Logging error\0", // 27 |
{SPEAK_MAX_RANGE,1}, // "Flying range! \0", // 28 |
{SPEAK_MAX_ALTITUD,1}, // "Max Altitude! \0" // 29 |
{SPEAK_GPS_FIX,1}, // "No GPS fix \0" // 30 |
{SPEAK_ERR_CALIBARTION,0},// "compass not cal." // 31 |
{SPEAK_ERR_MOTOR,0} // "BL-Selftest \0" // 32 |
}; |
void GetHottestBl(void) |
{ |
static unsigned char search = 0,tmp_max,tmp_min,who; |
if(Motor[search].Temperature > tmp_max) { tmp_max = Motor[search].Temperature; who = search;} |
else |
if(Motor[search].Temperature) if(Motor[search].Temperature < tmp_min) tmp_min = Motor[search].Temperature; |
if(++search >= MAX_MOTORS) |
{ |
search = 0; |
if(tmp_min != 255) MinBlTemperture = tmp_min; else MinBlTemperture = 0; |
MaxBlTemperture = tmp_max; |
HottestBl = who; |
tmp_min = 255; |
tmp_max = 0; |
who = 0; |
} |
} |
//--------------------------------------------------------------- |
void Hott_ClearLine(unsigned char line) |
{ |
HoTT_printfxy(0,line," "); |
} |
//--------------------------------------------------------------- |
unsigned char HoTT_Waring(void) |
{ |
unsigned char status = 0; |
static char old_status = 0; |
static int repeat; |
//if(Parameter_UserParam1) return(Parameter_UserParam1); |
ToNC_SpeakHoTT = SpeakHoTT; |
if(FC_StatusFlags & FC_STATUS_LOWBAT) |
{ |
if(LowVoltageLandingActive && (EE_Parameter.Receiver == RECEIVER_HOTT)) status = SPEAK_LANDING; |
else status = VOICE_MINIMALE_EINGANSSPANNUNG; // Jeti hat kein wort: "LANDEN" |
} |
else |
if(NC_ErrorCode && NC_ErrorCode+1 < MAX_ERR_NUMBER) // Fehlercodes |
{ |
if(MotorenEin || !pgm_read_byte(&HOTT_ERROR[NC_ErrorCode][1])) status = pgm_read_byte(&HOTT_ERROR[NC_ErrorCode][0]); |
} |
if(!status) // Sprachansagen |
{ |
// if(!(GetParamByte(PID_SPEAK_HOTT_CFG) & 0x01)) SpeakHoTT = 0; // is the voice wanted? |
if(!(EE_Parameter.GlobalConfig3 & CFG3_SPEAK_ALL)) SpeakHoTT = 0; // is the voice wanted? |
else status = SpeakHoTT; |
} |
else ToNC_SpeakHoTT = status; |
if(old_status == status) // Gleichen Fehler nur alle 4 sek bringen |
{ |
if(!CheckDelay(repeat)) return(0); |
repeat = SetDelay(4000); |
} |
else repeat = SetDelay(2000); |
if(status) |
{ |
if(status == SpeakHoTT) SpeakHoTT = 0; |
} |
old_status = status; |
// DebugOut.Analog[16] = status; |
return(status); |
} |
/* |
unsigned char HoTTErrorCode(void) |
{ |
return(NC_ErrorCode); |
} |
*/ |
//--------------------------------------------------------------- |
void NC_Fills_HoTT_Telemety(void) |
{ |
unsigned char *ptr = NULL; |
unsigned char max = 0,i,z; |
switch(FromNaviCtrl.Param.Byte[11]) |
{ |
case HOTT_VARIO_PACKET_ID: |
ptr = (unsigned char *) &VarioPacket; |
max = sizeof(VarioPacket); |
break; |
case HOTT_GPS_PACKET_ID: |
ptr = (unsigned char *) &GPSPacket; |
max = sizeof(GPSPacket); |
break; |
case HOTT_ELECTRIC_AIR_PACKET_ID: |
ptr = (unsigned char *) &ElectricAirPacket; |
max = sizeof(ElectricAirPacket); |
break; |
case HOTT_GENERAL_PACKET_ID: |
ptr = (unsigned char *) &HoTTGeneral; |
max = sizeof(HoTTGeneral); |
break; |
case JETI_GPS_PACKET_ID1: |
ptr = (unsigned char *) &JetiExData[14].Value; |
max = sizeof(JetiExData[14].Value); |
break; |
case JETI_GPS_PACKET_ID2: |
ptr = (unsigned char *) &JetiExData[15].Value; |
max = sizeof(JetiExData[15].Value); |
break; |
} |
z = FromNaviCtrl.Param.Byte[0]; // Data allocation |
for(i=0; i < FromNaviCtrl.Param.Byte[1]; i++) |
{ |
if(z >= max) break; |
ptr[z] = FromNaviCtrl.Param.Byte[2+i]; |
z++; |
} |
} |
unsigned int BuildHoTT_Vario(void) |
{ |
unsigned int tmp = VARIO_ZERO; |
if(VarioCharacter == '+' || VarioCharacter == '-') |
{ |
tmp = VARIO_ZERO + (AltitudeSetpointTrimming * EE_Parameter.Hoehe_Verstaerkung) / 3; |
if(tmp < VARIO_ZERO && tmp > VARIO_ZERO - 50) tmp = VARIO_ZERO - 50; // weil es sonst erst bei < 0,5m/sek piept |
} |
else |
if((VarioCharacter == ' ') && (FC_StatusFlags & FC_STATUS_FLY)) |
{ |
tmp = VARIO_ZERO + HoTTVarioMeter; |
if(tmp > VARIO_ZERO) |
{ |
if(tmp < VARIO_ZERO + 100) tmp = VARIO_ZERO; |
else tmp -= 100; |
} |
if(tmp < VARIO_ZERO) |
{ |
if(tmp > VARIO_ZERO - 100) tmp = VARIO_ZERO; |
else tmp += 100; |
} |
} |
else |
if(VarioCharacter == '^') tmp = VARIO_ZERO + FromNC_AltitudeSpeed * 10; |
else |
if(VarioCharacter == 'v') tmp = VARIO_ZERO - FromNC_AltitudeSpeed * 10; |
return(tmp); |
} |
//--------------------------------------------------------------- |
unsigned char HoTT_Telemety(unsigned char packet_request) |
{ |
unsigned char i; |
//Debug("rqst: %02X",packet_request); |
switch(packet_request) |
{ |
case HOTT_VARIO_PACKET_ID: |
GPSPacket.WarnBeep = HoTT_Waring(); // Achtung: das ist richtig hier, damit der Varioton schon vorher abgestellt wird |
VarioPacket.Altitude = HoehenWert/100 + 500; |
if(!GPSPacket.WarnBeep) VarioPacket.m_sec = BuildHoTT_Vario(); else VarioPacket.m_sec = VARIO_ZERO; |
VarioPacket.m_3sec = VarioPacket.m_sec; |
VarioPacket.m_10sec = VarioPacket.m_sec; |
if (VarioPacket.Altitude < VarioPacket.MinAltitude) VarioPacket.MinAltitude = VarioPacket.Altitude; |
if (VarioPacket.Altitude > VarioPacket.MaxAltitude) VarioPacket.MaxAltitude = VarioPacket.Altitude; |
VarioPacket.WarnBeep = 0;//HoTT_Waring(); |
HoTT_DataPointer = (unsigned char *) &VarioPacket; |
VarioPacket.FreeCharacters[0] = VarioCharacter; |
if(FC_StatusFlags2 & FC_STATUS2_CAREFREE) VarioPacket.FreeCharacters[1] = 'C'; else VarioPacket.FreeCharacters[1] = ' '; |
// VarioPacket.FreeCharacters[2] = ' '; |
if(NC_ErrorCode) |
{ |
VarioPacket.Text[0] = NC_ErrorCode/10 + '0'; |
VarioPacket.Text[1] = NC_ErrorCode%10 + '0'; |
VarioPacket.Text[2] = ':'; |
for(i=0; i<16;i++) VarioPacket.Text[i+3] = pgm_read_byte(&NC_ERROR_TEXT[NC_ErrorCode][i]); |
VarioPacket.Text[19] = ' '; |
VarioPacket.Text[20] = ' '; |
} |
else |
if(LowVoltageLandingActive) for(i=0; i<21;i++) VarioPacket.Text[i] = pgm_read_byte(&LANDING[i]); // no Error |
else |
if(FC_StatusFlags & FC_STATUS_LOWBAT) for(i=0; i<21;i++) VarioPacket.Text[i] = pgm_read_byte(&UNDERVOLTAGE[i]); // no Error |
else |
if(ShowSettingNameTime) // no Error |
{ |
for(i=0; i<sizeof(SETTING);i++) VarioPacket.Text[i] = pgm_read_byte(&SETTING[i]); |
VarioPacket.Text[4] = '0' + ActiveParamSet; |
for(i=0; i<sizeof(EE_Parameter.Name);i++) VarioPacket.Text[i+7] = EE_Parameter.Name[i]; // no Error |
VarioPacket.Text[18] = ' '; |
VarioPacket.Text[19] = ' '; |
VarioPacket.Text[20] = ' '; |
} |
else |
if(NaviData_WaypointNumber) |
{ |
unsigned int tmp_int; |
unsigned char tmp; |
VarioPacket.Text[0] = 'W'; VarioPacket.Text[1] = 'P'; |
VarioPacket.Text[2] = ' '; |
VarioPacket.Text[3] = '0'+(NaviData_WaypointIndex) / 10; |
VarioPacket.Text[4] = '0'+(NaviData_WaypointIndex) % 10; |
VarioPacket.Text[5] = '/'; |
VarioPacket.Text[6] = '0'+(NaviData_WaypointNumber) / 10; |
VarioPacket.Text[7] = '0'+(NaviData_WaypointNumber) % 10; |
VarioPacket.Text[8] = ' '; |
tmp_int = NaviData_TargetDistance; |
if(tmp_int > 1000) { VarioPacket.Text[9] = '0'+(tmp_int) / 1000; tmp_int %= 1000;} |
else VarioPacket.Text[9] = ' '; |
if(tmp_int > 100) { VarioPacket.Text[10] = '0'+(tmp_int) / 100; tmp_int %= 100;} |
else VarioPacket.Text[10] = ' '; |
VarioPacket.Text[11] = '0'+(tmp_int) / 10; |
VarioPacket.Text[12] = '0'+(tmp_int) % 10; |
VarioPacket.Text[13] = 'm'; |
VarioPacket.Text[14] = ' '; |
tmp = NaviData_TargetHoldTime; |
if(tmp > 100) { VarioPacket.Text[15] = '0'+(tmp) / 100; tmp %= 100;} else VarioPacket.Text[15] = ' '; |
VarioPacket.Text[16] = '0'+(tmp) / 10; |
VarioPacket.Text[17] = '0'+(tmp) % 10; |
VarioPacket.Text[18] = 's'; |
VarioPacket.Text[19] = ' '; |
} |
else |
if(!CalibrationDone) |
{ |
for(i=0; i<17;i++) VarioPacket.Text[i] = pgm_read_byte(&MIKROKOPTER[i+2]); // no Error and not calibrated |
VarioPacket.Text[16] = '0'+VERSION_MAJOR; |
VarioPacket.Text[17] = '.'; |
VarioPacket.Text[18] = '0'+VERSION_MINOR/10; |
VarioPacket.Text[19] = '0'+VERSION_MINOR%10; |
VarioPacket.Text[20] = 'a'+VERSION_PATCH; |
} |
else |
{ |
for(i=0; i<21;i++) VarioPacket.Text[i] = pgm_read_byte(&MIKROKOPTER[i]); // no Error |
} |
return(sizeof(VarioPacket)); |
break; |
case HOTT_GPS_PACKET_ID: |
GPSPacket.Altitude = HoehenWert/100 + 500; |
// GPSPacket.Distance = GPSInfo.HomeDistance/10; // macht die NC |
// GPSPacket.Heading = GPSInfo.HomeBearing/2; // macht die NC |
// GPSPacket.Speed = (GPSInfo.Speed * 36) / 10; // macht die NC |
// GPSPacket.WarnBeep = HoTT_Waring(); //(wird jetzt weiter oben gemacht) |
if(!GPSPacket.WarnBeep) GPSPacket.m_sec = BuildHoTT_Vario(); else GPSPacket.m_sec = VARIO_ZERO; |
GPSPacket.m_3sec = 120; |
GPSPacket.NumOfSats = GPSInfo.NumOfSats; |
if(GPSInfo.Flags & FLAG_DIFFSOLN) GPSPacket.SatFix = 'D'; |
else |
if(GPSInfo.SatFix == SATFIX_3D) GPSPacket.SatFix = ' '; |
else GPSPacket.SatFix = '!'; |
HoTT_DataPointer = (unsigned char *) &GPSPacket; |
GPSPacket.FreeCharacters[0] = NC_GPS_ModeCharacter; |
GPSPacket.FreeCharacters[2] = GPSPacket.SatFix; |
GPSPacket.HomeDirection = GPSInfo.HomeBearing / 2;//230; |
return(sizeof(GPSPacket)); |
break; |
case HOTT_ELECTRIC_AIR_PACKET_ID: |
GetHottestBl(); |
ElectricAirPacket.Altitude = HoehenWert/100 + 500; |
ElectricAirPacket.Battery1 = UBat; |
ElectricAirPacket.Battery2 = UBat; |
ElectricAirPacket.VoltageCell1 = ErsatzKompassInGrad / 2; |
ElectricAirPacket.VoltageCell8 = ElectricAirPacket.VoltageCell1; |
ElectricAirPacket.VoltageCell6 = GPSInfo.HomeBearing / 2; |
ElectricAirPacket.VoltageCell7 = GPSInfo.HomeDistance/20; |
ElectricAirPacket.VoltageCell13 = ElectricAirPacket.VoltageCell6; |
ElectricAirPacket.VoltageCell14 = ElectricAirPacket.VoltageCell7; |
if(!GPSPacket.WarnBeep) ElectricAirPacket.m_sec = BuildHoTT_Vario(); else ElectricAirPacket.m_sec = VARIO_ZERO; |
ElectricAirPacket.m_3sec = 120; |
ElectricAirPacket.InputVoltage = UBat; |
ElectricAirPacket.Temperature1 = MinBlTemperture + 20; |
ElectricAirPacket.Temperature2 = MaxBlTemperture + 20; |
ElectricAirPacket.Capacity = Capacity.UsedCapacity/10; |
// ElectricAirPacket.WarnBeep = 0;//HoTT_Waring(); |
ElectricAirPacket.WarnBeep = GPSPacket.WarnBeep; |
ElectricAirPacket.Current = Capacity.ActualCurrent; |
HoTT_DataPointer = (unsigned char *) &ElectricAirPacket; |
ElectricAirPacket.FlightTimeMinutes = FlugSekunden / 60; |
ElectricAirPacket.FlightTimeSeconds = FlugSekunden % 60; |
return(sizeof(ElectricAirPacket)); |
break; |
case HOTT_GENERAL_PACKET_ID: |
GetHottestBl(); |
HoTTGeneral.Rpm = GPSInfo.HomeDistance/100; |
HoTTGeneral.VoltageCell1 = ErsatzKompassInGrad / 2; |
HoTTGeneral.VoltageCell2 = KompassValue / 2; |
//HoTTGeneral.VoltageCell3 = Magnetstaerke -> macht NC |
//HoTTGeneral.VoltageCell4 = Inclinition -> macht NC |
HoTTGeneral.VoltageCell5 = DebugOut.Analog[28]; // I2C ErrorCounter |
HoTTGeneral.VoltageCell6 = GPSInfo.HomeBearing / 2; |
if(UBat > BattLowVoltageWarning + 2) HoTTGeneral.FuelPercent = (UBat - (BattLowVoltageWarning + 2)) * 3; |
else HoTTGeneral.FuelPercent = 0; |
if(HoTTGeneral.FuelPercent > 100) HoTTGeneral.FuelPercent = 100; |
HoTTGeneral.FuelCapacity = NC_ErrorCode;//HoehenWert/100; // Oelpegel |
// if(HoTTGeneral.FuelCapacity < 0) HoTTGeneral.FuelCapacity = 0; |
HoTTGeneral.Altitude = HoehenWert/100 + 500; |
HoTTGeneral.Battery1 = UBat; |
HoTTGeneral.Battery2 = UBat; |
if(!GPSPacket.WarnBeep) HoTTGeneral.m_sec = BuildHoTT_Vario(); else HoTTGeneral.m_sec = VARIO_ZERO; |
HoTTGeneral.m_3sec = 120 + GPSPacket.WarnBeep; |
HoTTGeneral.InputVoltage = UBat; |
HoTTGeneral.Temperature1 = MinBlTemperture + 20; |
HoTTGeneral.Temperature2 = MaxBlTemperture + 20; |
HoTTGeneral.Capacity = Capacity.UsedCapacity/10; |
HoTTGeneral.WarnBeep = 0;//HoTT_Waring(); |
HoTTGeneral.Current = Capacity.ActualCurrent; |
//HoTTGeneral.ErrorNumber = HoTTErrorCode(); |
HoTT_DataPointer = (unsigned char *) &HoTTGeneral; |
return(sizeof(HoTTGeneral)); |
break; |
default: return(0); |
} |
} |
//--------------------------------------------------------------- |
void HoTT_Menu(void) |
{ |
static unsigned char line, page = 0,show_current = 0,show_mag = 0, show_poti = 0; |
unsigned char tmp; |
HoTTVarioMeter = (HoTTVarioMeter * 7 + VarioMeter) / 8; |
if(page == 0) |
switch(line++) |
{ |
case 0: |
if(FC_StatusFlags & FC_STATUS_LOWBAT) |
HoTT_printfxy_BLINK(0,0," %2i.%1iV ",UBat/10, UBat%10) |
else |
HoTT_printfxy(0,0," %2i.%1iV ",UBat/10, UBat%10) |
if(Parameter_GlobalConfig & CFG_HOEHENREGELUNG) |
{ |
if(HoehenReglerAktiv) HoTT_printfxy_INV(10,0,"ALT:%4im %c", (int16_t)(HoehenWert/100),VarioCharacter) |
else HoTT_printfxy(10,0,"ALT:%4im ", (int16_t)(HoehenWert/100)) |
} |
else HoTT_printfxy(10,0,"ALT:---- "); |
break; |
case 1: |
if(FC_StatusFlags & FC_STATUS_LOWBAT) |
HoTT_printfxy_BLINK(0,1," %2i:%02i ",FlugSekunden/60,FlugSekunden%60) |
else HoTT_printfxy(0,1," %2i:%02i ",FlugSekunden/60,FlugSekunden%60); |
HoTT_printfxy(10,1,"DIR: %3d%c",ErsatzKompassInGrad, HoTT_GRAD); |
if(FC_StatusFlags2 & FC_STATUS2_CAREFREE) HoTT_printfxy_INV(20,1,"C") else HoTT_printfxy(20,1," "); |
break; |
case 2: |
if(FC_StatusFlags & FC_STATUS_LOWBAT) |
HoTT_printfxy_BLINK(0,2," %5i ",Capacity.UsedCapacity) |
else HoTT_printfxy(0,2," %5i ",Capacity.UsedCapacity); |
HoTT_printfxy(12,2,"I:%2i.%1iA ",Capacity.ActualCurrent/10, Capacity.ActualCurrent%10); |
break; |
case 3: |
HoTT_printfxy(9,0,":"); |
HoTT_printfxy(9,1,":"); |
HoTT_printfxy(9,2,":"); |
HoTT_printfxy(0,3,"---------+-----------"); |
// HoTT_printfxy(0,3,"---------------------"); |
HoTT_printfxy(0,6,"---------------------"); |
break; |
case 4: |
if(NaviDataOkay) |
{ |
HoTT_printfxy(9,4,":"); |
HoTT_printfxy(0,4,"SAT:%2d ",GPSInfo.NumOfSats); |
HoTT_printfxy(10,4,"DIST:%3dm",GPSInfo.HomeDistance/10); |
switch (GPSInfo.SatFix) |
{ |
case SATFIX_3D: |
if(GPSInfo.Flags & FLAG_DIFFSOLN) HoTT_printfxy(7,4,"D ") |
else HoTT_printfxy(7,4,"3D"); |
break; |
default: |
HoTT_printfxy_BLINK(7,4,"!!"); |
break; |
} |
} |
else |
{ |
Hott_ClearLine(4); |
} |
break; |
case 5: |
if(NaviDataOkay) |
{ |
if(show_mag) |
{ |
HoTT_printfxy(0,5,"MAG:%3u%% ",EarthMagneticField); |
HoTT_printfxy(12,5,"HM:%3d%c %c", GPSInfo.HomeBearing, HoTT_GRAD, NC_GPS_ModeCharacter); |
HoTT_printfxy(9,5,"incl:%2d%c(%2i)",EarthMagneticInclination, HoTT_GRAD,EarthMagneticInclinationTheoretic); |
} |
else |
{ |
HoTT_printfxy(0,5," %2um/s: HM:%3d%c %c",GPSInfo.Speed, GPSInfo.HomeBearing, HoTT_GRAD, NC_GPS_ModeCharacter); |
} |
} |
else Hott_ClearLine(5); |
break; |
case 6: |
break; |
case 7: if(NC_ErrorCode) |
{ |
if(HoTTBlink && NC_ErrorCode < MAX_ERR_NUMBER) |
{ |
Hott_ClearLine(7); |
HoTT_printfxy_INV(0,7,"ERR: %2d !",NC_ErrorCode); |
} |
else |
{ |
HoTT_printfxy(0,7,"ERR: "); _printf_P(&LIBFC_HoTT_Putchar, NC_ERROR_TEXT[NC_ErrorCode] , 0);}; |
} |
else |
if(FC_StatusFlags & FC_STATUS_LOWBAT) HoTT_printfxy(1,7,"!! LiPo voltage !!") |
else HoTT_printfxy(0,7," www.MikroKopter.de "); |
break; |
case 8: //ASCIIPacket.WarnBeep = HoTT_Waring(); |
// ASCIIPacket.WarnBeep = Parameter_UserParam1; |
case 9: |
case 10: |
case 11: |
case 12: |
case 13: |
case 14: |
case 15: |
case 16: |
if(HottKeyboard == HOTT_KEY_SET) { if(show_mag) show_mag = 0; else show_mag = 1;} |
else |
if(HottKeyboard == HOTT_KEY_LEFT) { LIBFC_HoTT_Clear(); page = 1; line = 0;}; |
HottKeyboard = 0; |
break; |
default: line = 0; |
break; |
} |
else |
if(page == 1) |
switch(line++) |
{ |
case 0: |
if(FC_StatusFlags & FC_STATUS_LOWBAT) |
HoTT_printfxy_BLINK(0,0," %2i:%02i %2i.%1iV %4imAh",FlugSekunden/60,FlugSekunden%60,UBat/10, UBat%10,Capacity.UsedCapacity) |
else HoTT_printfxy(0,0," %2i:%02i %2i.%1iV %4imAh",FlugSekunden/60,FlugSekunden%60,UBat/10, UBat%10,Capacity.UsedCapacity); |
break; |
case 1: |
HoTT_printfxy(0,1,"DIR:%3d%c",KompassValue, HoTT_GRAD); |
if(Parameter_GlobalConfig & CFG_HOEHENREGELUNG) |
{ |
if(HoehenReglerAktiv) HoTT_printfxy_INV(10,1,"ALT:%4im", (int16_t)(HoehenWert/100)) |
else HoTT_printfxy(10,1,"ALT:%4im", (int16_t)(HoehenWert/100)) |
} |
else HoTT_printfxy(10,1,"ALT:---- "); |
HoTT_printfxy(20,1,"%c",VarioCharacter); |
break; |
case 2: |
if(NaviDataOkay) |
{ |
HoTT_printfxy(1,2,"HM:%3d%c DIST:%3dm %c", GPSInfo.HomeBearing, HoTT_GRAD, GPSInfo.HomeDistance/10, NC_GPS_ModeCharacter); |
} |
else |
{ |
Hott_ClearLine(2); |
} |
break; |
case 3: |
HoTT_printfxy(0,3,"PWR:%2i.%1iA (%iW) ",Capacity.ActualCurrent/10, Capacity.ActualCurrent%10,Capacity.ActualPower); |
if(FC_StatusFlags2 & FC_STATUS2_CAREFREE) HoTT_printfxy_INV(19,3,"CF") else HoTT_printfxy(19,3," "); |
break; |
case 4: |
if(NaviDataOkay) |
{ |
HoTT_printfxy(0,4,"GPS:%2um/s SAT:%d ",GPSInfo.Speed,GPSInfo.NumOfSats); |
switch (GPSInfo.SatFix) |
{ |
case SATFIX_3D: |
HoTT_printfxy(16,4," 3D "); |
break; |
//case SATFIX_2D: |
//case SATFIX_NONE: |
default: |
HoTT_printfxy_BLINK(16,4,"NOFIX"); |
break; |
} |
if(GPSInfo.Flags & FLAG_DIFFSOLN) |
{ |
HoTT_printfxy(16,4,"DGPS "); |
} |
} |
else |
{ //012345678901234567890 |
HoTT_printfxy(0,4," No NaviCtrl "); |
} |
break; |
case 5: |
if(show_current) |
{ |
// HoTT_printfxy(0,5,"%2i.%i %2i.%i %2i.%i %2i.%iA", Motor[0].Current/10,Motor[0].Current%10,Motor[1].Current/10,Motor[1].Current%10,Motor[2].Current/10,Motor[2].Current%10,Motor[3].Current/10,Motor[3].Current%10); |
HoTT_printfxy(0,5,"%2i.%i %2i.%i %2i.%i %2i.%iA", BL3_Current(0)/10,BL3_Current(0)%10,BL3_Current(1)/10,BL3_Current(1)%10,BL3_Current(2)/10,BL3_Current(2)%10,BL3_Current(3)/10,BL3_Current(3)%10); |
} |
else |
{ |
HoTT_printfxy(0,5,"%3i %3i %3i %3i%cC", Motor[0].Temperature, Motor[1].Temperature, Motor[2].Temperature, Motor[3].Temperature,HoTT_GRAD); |
} |
break; |
case 6: |
if(show_current) |
{ |
if(RequiredMotors == 4) Hott_ClearLine(6); |
else |
// if(RequiredMotors == 6) HoTT_printfxy(0,6,"%2i.%i %2i.%iA", Motor[4].Current/10,Motor[4].Current%10,Motor[5].Current/10,Motor[5].Current%10) |
if(RequiredMotors == 6) HoTT_printfxy(0,6,"%2i.%i %2i.%iA", BL3_Current(4)/10,BL3_Current(4)%10, BL3_Current(5)/10,BL3_Current(5)%10) |
else |
// if(RequiredMotors > 6) HoTT_printfxy(0,6,"%2i.%i %2i.%i %2i.%i %2i.%iA", Motor[4].Current/10,Motor[4].Current%10,Motor[5].Current/10,Motor[5].Current%10,Motor[6].Current/10,Motor[6].Current%10,Motor[7].Current/10,Motor[7].Current%10); |
if(RequiredMotors > 6) HoTT_printfxy(0,6,"%2i.%i %2i.%i %2i.%i %2i.%iA", BL3_Current(4)/10,BL3_Current(4)%10,BL3_Current(5)/10,BL3_Current(5)%10,BL3_Current(6)/10,BL3_Current(6)%10,BL3_Current(7)/10,BL3_Current(7)%10,BL3_Current(8)/10,BL3_Current(8)%10); |
} |
else |
{ |
if(RequiredMotors == 4) Hott_ClearLine(6); |
else |
if(RequiredMotors == 6) HoTT_printfxy(0,6,"%3i %3i%cC ", Motor[4].Temperature, Motor[5].Temperature,HoTT_GRAD) |
else |
if(RequiredMotors > 6) HoTT_printfxy(0,6,"%3i %3i %3i %3i%cC", Motor[4].Temperature, Motor[5].Temperature, Motor[6].Temperature, Motor[7].Temperature,HoTT_GRAD); |
} |
break; |
case 7: if(NC_ErrorCode) |
{ |
if(HoTTBlink && NC_ErrorCode < MAX_ERR_NUMBER) |
{ |
Hott_ClearLine(7); |
HoTT_printfxy_INV(0,7,"ERR: %2d !",NC_ErrorCode); |
} |
else |
{ |
HoTT_printfxy(0,7,"ERR: "); _printf_P(&LIBFC_HoTT_Putchar, NC_ERROR_TEXT[NC_ErrorCode] , 0);}; |
} |
else |
if(FC_StatusFlags & FC_STATUS_LOWBAT) HoTT_printfxy(1,7,"!! LiPo voltage !!") |
else HoTT_printfxy(0,7," www.MikroKopter.de "); |
break; |
case 8: // ASCIIPacket.WarnBeep = HoTT_Waring(); |
// ASCIIPacket.WarnBeep = Parameter_UserParam1; |
case 9: |
case 10: |
case 11: |
case 12: |
case 13: |
case 14: |
case 15: |
case 16: |
if(HottKeyboard == HOTT_KEY_SET) { if(show_current) show_current = 0; else show_current = 1; Hott_ClearLine(5); Hott_ClearLine(6);} |
else |
if(HottKeyboard == HOTT_KEY_LEFT) { LIBFC_HoTT_Clear(); page = 2; line = 0;} |
else |
if(HottKeyboard == HOTT_KEY_RIGHT) { LIBFC_HoTT_Clear(); page = 0; line = 0;} |
//if(HottKeyboard) HoTT_printfxy(15,6,"%KEY:%02x ",HottKeyboard); |
HottKeyboard = 0; |
break; |
default: line = 0; |
break; |
} |
else |
if(page == 2) |
switch(line++) |
{ |
case 0: |
HoTT_printfxy_INV(0,0,"Setting:%u %s ",ActiveParamSet,EE_Parameter.Name); |
break; |
case 1: HoTT_printfxy(0,1,"Min:%2i.%1iV %s ",BattLowVoltageWarning/10, BattLowVoltageWarning%10, Mixer.Name); |
break; |
case 2: HoTT_printfxy(0,2,"ALT:"); |
if(Parameter_GlobalConfig & CFG_HOEHENREGELUNG) |
{ |
if(!(EE_Parameter.GlobalConfig & CFG_HOEHEN_SCHALTER)) HoTT_printf("POTI:%3u ", Parameter_HoehenSchalter) |
else |
{ |
if(Parameter_HoehenSchalter > 50) HoTT_printf("(ON) ") else HoTT_printf("(OFF) "); |
if((Parameter_ExtraConfig & CFG2_HEIGHT_LIMIT)) HoTT_printf("LIMIT", Parameter_HoehenSchalter) |
else HoTT_printf("VARIO", Parameter_HoehenSchalter); |
} |
} |
else |
HoTT_printf("DISABLED"); |
break; |
case 3: HoTT_printfxy(0,3,"CF:"); |
if(!EE_Parameter.CareFreeChannel) HoTT_printf("DISABLED") |
else |
{ |
if(CareFree) HoTT_printf(" (ON) ") else HoTT_printf(" (OFF)"); |
if(EE_Parameter.ExtraConfig & CFG_LEARNABLE_CAREFREE) HoTT_printf(" TEACH"); |
} |
break; |
case 4: HoTT_printfxy(0,4,"GPS:"); |
if(!(Parameter_GlobalConfig & CFG_GPS_AKTIV)) HoTT_printf("DISABLED") |
else |
{ |
tmp = GetChannelValue(EE_Parameter.NaviGpsModeChannel); |
if(tmp < 50) HoTT_printf("(FREE)") |
else |
if(tmp >= 180) HoTT_printf("(HOME)") |
else |
if(EE_Parameter.ExtraConfig & CFG_GPS_AID) HoTT_printf("(AID) ") |
else HoTT_printf("(HOLD)") |
} |
if(EE_Parameter.FailSafeTime) HoTT_printfxy(10,4," FS:%usek ",EE_Parameter.FailSafeTime) |
break; |
case 5: HoTT_printfxy(0,5,"HOME ALT:"); |
if(EE_Parameter.ComingHomeAltitude) HoTT_printf("%um",EE_Parameter.ComingHomeAltitude) else HoTT_printf("HOLD "); |
break; |
case 6: |
if(!show_poti) |
{ |
HoTT_printfxy(0,6,"Ni:%4i Ro:%4i C:%3i",PPM_in[EE_Parameter.Kanalbelegung[K_NICK]],PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]], Parameter_ServoNickControl); |
HoTT_printfxy(0,7,"Gs:%4i Ya:%4i ",PPM_in[EE_Parameter.Kanalbelegung[K_GAS]]+127,PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]); |
} |
else |
{ |
HoTT_printfxy(0,6,"P1:%4i P2:%4i 3:%3i",Poti1,Poti2, Poti3); |
HoTT_printfxy(0,7,"P4:%4i P5:%4i 6:%3i",Poti4,Poti5, Poti6); |
} |
break; |
case 7: //HoTT_printfxy(0,6,"WARNINGS:"); |
if(HoTTBlink) |
{ |
LIBFC_HoTT_SetPos(6 * 21); |
if(!(Parameter_GlobalConfig & CFG_ACHSENKOPPLUNG_AKTIV)) HoTT_printf_BLINK("COUPLING OFF! "); |
if(EE_Parameter.BitConfig & (CFG_LOOP_LINKS | CFG_LOOP_RECHTS | CFG_LOOP_UNTEN | CFG_LOOP_OBEN)) HoTT_printf_BLINK("LOOPING! "); |
if(Parameter_GlobalConfig & CFG_HEADING_HOLD) HoTT_printf_BLINK("HH! "); |
if(!(Parameter_GlobalConfig & CFG_KOMPASS_AKTIV)) HoTT_printf_BLINK("COMPASS OFF! "); |
} |
break; |
case 8: //ASCIIPacket.WarnBeep = HoTT_Waring(); |
break; |
case 9: |
case 10: |
case 11: |
case 12: |
case 13: |
case 14: |
case 15: |
case 16: |
if(HottKeyboard == HOTT_KEY_SET) { if(show_poti) show_poti = 0; else show_poti = 1; Hott_ClearLine(6); Hott_ClearLine(7);} |
// else |
// if(HottKeyboard == HOTT_KEY_LEFT) { LIBFC_HoTT_Clear(); page = 3; line = 0;} |
else |
if(HottKeyboard == HOTT_KEY_RIGHT) { LIBFC_HoTT_Clear(); page = 1; line = 0;}; |
HottKeyboard = 0; |
break; |
default: line = 0; |
break; |
} |
/* else |
if(page == 3) |
switch(line++) |
{ |
case 0: |
HoTT_printfxy(0,2,"Speak:"); |
break; |
case 1: |
// if(GetParamByte(PID_SPEAK_HOTT_CFG) & 0x01) |
if(!(GlobalConfig3 & CFG3_SPEAK_ALL) & 0x01)) HoTT_printfxy_INV(7,2,"All Messages ") |
else HoTT_printfxy_INV(7,2,"Warnings only"); |
break; |
case 2: |
HoTT_printfxy(1,4,"Use (set) to select"); |
break; |
default: |
if(HottKeyboard == HOTT_KEY_SET) |
{ |
SetParamByte(PID_SPEAK_HOTT_CFG, GetParamByte(PID_SPEAK_HOTT_CFG) ^ 0x01); |
} |
else |
if(HottKeyboard == HOTT_KEY_RIGHT) { LIBFC_HoTT_Clear(); page = 2; line = 0;}; |
HottKeyboard = 0; |
line = 0; |
break; |
} |
*/ |
else page = 0; |
} |
#endif |
/tags/V2.02b/hottmenu.h |
---|
0,0 → 1,234 |
#ifndef _HOTTMENU_H |
#define _HOTTMENU_H |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#define SPEAK_ERR_CALIBARTION 1 |
#define SPEAK_ERR_RECEICER 2 |
#define SPEAK_ERR_DATABUS 3 |
#define SPEAK_ERR_NAVI 4 |
#define SPEAK_ERROR 5 |
#define SPEAK_ERR_COMPASS 6 |
#define SPEAK_ERR_SENSOR 7 |
#define SPEAK_ERR_GPS 8 |
#define SPEAK_ERR_MOTOR 9 |
#define SPEAK_MAX_TEMPERAT 10 |
#define SPEAK_ALTI_REACHED 11 |
#define SPEAK_WP_REACHED 12 |
#define SPEAK_NEXT_WP 13 |
#define SPEAK_LANDING 14 |
#define SPEAK_GPS_FIX 15 |
#define SPEAK_UNDERVOLTAGE 16 |
#define SPEAK_GPS_HOLD 17 |
#define SPEAK_GPS_HOME 18 |
#define SPEAK_GPS_OFF 19 |
#define SPEAK_BEEP 20 |
#define SPEAK_MIKROKOPTER 21 |
#define SPEAK_CAPACITY 22 |
#define SPEAK_CF_OFF 23 |
#define SPEAK_CALIBRATE 24 |
#define SPEAK_MAX_RANGE 25 |
#define SPEAK_MAX_ALTITUD 26 |
#define SPEAK_MK_OFF 38 |
#define SPEAK_ALTITUDE_ON 39 |
#define SPEAK_ALTITUDE_OFF 40 |
#define SPEAK_CF_ON 46 |
#define SPEAK_SINKING 47 |
#define SPEAK_RISING 48 |
#define SPEAK_HOLDING 49 |
#define SPEAK_GPS_ON 50 |
#define SPEAK_FOLLWING 51 |
#define SPEAK_STARTING 52 |
#define MAX_ERR_NUMBER (32+1) |
extern const char PROGMEM NC_ERROR_TEXT[MAX_ERR_NUMBER][17]; |
extern unsigned char NaviData_WaypointIndex, NaviData_WaypointNumber, NaviData_TargetHoldTime; |
extern unsigned int NaviData_TargetDistance; |
extern unsigned char MaxBlTemperture; |
extern unsigned char MinBlTemperture; |
extern unsigned char HottestBl; |
extern unsigned char HottKeyboard,HoTT_RequestedSensor; |
extern unsigned char HottUpdate(unsigned char key); |
extern unsigned char SpeakHoTT,ShowSettingNameTime; |
extern unsigned char ToNC_SpeakHoTT; |
extern volatile unsigned char *HoTT_DataPointer; |
extern void CreateHoTT_Menu(void); |
extern void LIBFC_HoTT_Putchar(char); |
extern void LIBFC_HoTT_Putchar_INV(char); // print Invers |
extern void LIBFC_HoTT_Putchar_BLINK(char); |
extern void LIBFC_HoTT_SetPos(unsigned char); |
extern void LIBFC_HoTT_Clear(void); |
extern void NC_Fills_HoTT_Telemety(void); |
extern void HoTT_Menu(void); |
extern unsigned char HoTT_Telemety(unsigned char); |
extern unsigned char HoTT_Waring(void); |
extern volatile unsigned char HoTTBlink; |
extern void GetHottestBl(void); |
typedef struct |
{ |
unsigned char StartByte; // 0x7C |
unsigned char Packet_ID; // HOTT_GENERAL_PACKET_ID |
unsigned char WarnBeep; // 3 Anzahl der Töne 0..36 |
unsigned char SensorID; // 4 0xD0 |
unsigned char InverseStatus1; // 5 |
unsigned char InverseStatus2; // 6 |
unsigned char VoltageCell1; // 7 208 = 4,16V (Voltage * 50 = Wert) |
unsigned char VoltageCell2; // 8 209 = 4,18V |
unsigned char VoltageCell3; // 9 |
unsigned char VoltageCell4; // 10 |
unsigned char VoltageCell5; // 11 |
unsigned char VoltageCell6; // 12 |
unsigned int Battery1; // 13+14 51 = 5,1V |
unsigned int Battery2; // 15+16 51 = 5,1V |
unsigned char Temperature1; // 17 44 = 24°C, 0 = -20°C |
unsigned char Temperature2; // 18 44 = 24°C, 0 = -20°C |
unsigned char FuelPercent; // 19 |
signed int FuelCapacity; // 20+21 |
unsigned int Rpm; // 22+23 |
signed int Altitude; // 24+25 |
unsigned int m_sec; // 26+27 3000 = 0 |
unsigned char m_3sec; // 28 120 = 0 |
unsigned int Current; // 29+30 1 = 0.1A |
unsigned int InputVoltage; // 31+32 66 = 6,6V |
unsigned int Capacity; // 33+34 1 = 10mAh |
unsigned int Speed; // 35+36 |
unsigned char LowestCellVoltage; // 37 |
unsigned char LowestCellNumber; // 38 |
unsigned int Rpm2; // 39+40 |
unsigned char ErrorNumber; // 41 |
unsigned char Pressure; // 42 in 0,1bar 20=2,0bar |
unsigned char Version; // 43 |
unsigned char EndByte; // 0x7D |
} HoTTGeneral_t; |
typedef struct |
{ |
unsigned char StartByte; // 0x7C |
unsigned char Packet_ID; // HOTT_ELECTRIC_AIR_PACKET_ID |
unsigned char WarnBeep; // Anzahl der Töne 0..36 |
unsigned char SensorID; // 4 0xE0 |
unsigned char InverseStatus1; // 5 |
unsigned char InverseStatus2; // 6 |
unsigned char VoltageCell1; // 7 208 = 4,16V (Voltage * 50 = Wert) |
unsigned char VoltageCell2; // 209 = 4,18V |
unsigned char VoltageCell3; // |
unsigned char VoltageCell4; // |
unsigned char VoltageCell5; // |
unsigned char VoltageCell6; // |
unsigned char VoltageCell7; // |
unsigned char VoltageCell8; // |
unsigned char VoltageCell9; // |
unsigned char VoltageCell10; // |
unsigned char VoltageCell11; // |
unsigned char VoltageCell12; // |
unsigned char VoltageCell13; // |
unsigned char VoltageCell14; // 20 |
unsigned int Battery1; // 21+22 51 = 5,1V |
unsigned int Battery2; // 23+24 51 = 5,1V |
unsigned char Temperature1; // 25 44 = 24°C, 0 = -20°C |
unsigned char Temperature2; // 26 44 = 24°C, 0 = -20°C |
signed int Altitude; // 27+28 |
unsigned int Current; // 29+30 1 = 0.1A |
unsigned int InputVoltage; // 31+32 66 = 6,6V |
unsigned int Capacity; // 33+34 1 = 10mAh |
unsigned int m_sec; // 35+36 30000 = 0 |
unsigned char m_3sec; // 37 120 = 0 |
unsigned int Rpm; // 38+39 |
unsigned char FlightTimeMinutes; // 40 |
unsigned char FlightTimeSeconds; // 41 |
unsigned char Speed; // 42 1=2km |
unsigned char Version; // 43 0x00 |
unsigned char EndByte; // 0x7D |
} ElectricAirPacket_t; |
typedef struct |
{ |
unsigned char StartByte; // 0x7C |
unsigned char Packet_ID; // 0x89 - Vario ID |
unsigned char WarnBeep; //3 // Anzahl der Töne 0..36 |
unsigned char SensorID; // 0x90 |
unsigned char InverseStatus; |
signed int Altitude; //6+7 // 500 = 0m |
signed int MaxAltitude; //8+9 // 500 = 0m |
signed int MinAltitude; //10+11 // 500 = 0m |
unsigned int m_sec; //12+13 // 3000 = 0 |
unsigned int m_3sec; //14+15 |
unsigned int m_10sec; //26+17 |
char Text[21]; //18-38 |
char FreeCharacters[3]; // 39-41 |
unsigned char NullByte; // 42 0x00 |
unsigned char Version; // 43 |
unsigned char EndByte; // 0x7D |
} VarioPacket_t; |
typedef struct |
{ |
unsigned char StartByte; //0 // 0x7C |
unsigned char Packet_ID; //1 // 0x8A - GPS ID |
unsigned char WarnBeep; //2 // Anzahl der Töne 0..36 |
unsigned char SensorID; // 4 0xA0 |
unsigned char InverseStatus1; // 5 |
unsigned char InverseStatus2; // 6 |
unsigned char Heading; //7 // 1 = 2° |
unsigned int Speed; //8+9 // in km/h |
unsigned char Lat_North; //10 |
unsigned char Lat_G; //11 |
unsigned char Lat_M; //12 |
unsigned char Lat_Sek1; //13 |
unsigned char Lat_Sek2; //14 |
unsigned char Lon_East; //15 |
unsigned char Lon_G; //16 |
unsigned char Lon_M; //17 |
unsigned char Lon_Sek1; //18 |
unsigned char Lon_Sek2; //19 |
unsigned int Distance; //20+21 // 9000 = 0m |
signed int Altitude; //22+23 // 500 = 0m |
unsigned int m_sec; //24+25 // 3000 = 0 |
unsigned char m_3sec; //26 120 = 0 |
unsigned char NumOfSats; //27 |
unsigned char SatFix; //28 |
unsigned char HomeDirection; // 29 |
unsigned char AngleX; // 30 |
unsigned char AngleY; // 31 |
unsigned char AngleZ; // 32 |
signed int GyroX; //33+34 |
signed int GyroY; //35+36 |
signed int GyroZ; //37+38 |
unsigned char Vibration; // 39 |
char FreeCharacters[3]; // 40-42 |
unsigned char Version; // 43 |
unsigned char EndByte; // 0x7D |
} GPSPacket_t; |
typedef struct |
{ |
unsigned char StartByte; // 0x7B |
unsigned char Packet_ID; // |
unsigned char WarnBeep; // Anzahl der Töne 0..36 |
char Text[8*21]; |
unsigned char EndByte; // 0x7D |
} ASCIIPacket_t; |
extern GPSPacket_t GPSPacket; |
extern VarioPacket_t VarioPacket; |
extern ASCIIPacket_t ASCIIPacket; |
extern ElectricAirPacket_t ElectricAirPacket; |
extern HoTTGeneral_t HoTTGeneral; |
#define HOTT_VARIO_PACKET_ID 0x89 |
#define HOTT_GPS_PACKET_ID 0x8A |
#define HOTT_ELECTRIC_AIR_PACKET_ID 0x8E |
#define HOTT_GENERAL_PACKET_ID 0x8D |
#define JETI_GPS_PACKET_ID1 0x01 |
#define JETI_GPS_PACKET_ID2 0x02 |
#endif |
#endif |
/tags/V2.02b/isqrt.S |
---|
0,0 → 1,203 |
;-----------------------------------------------------------------------------; |
; Fast integer squareroot routines for avr-gcc project (C)ChaN, 2008 |
; http://elm-chan.org/docs/avrlib/sqrt32.S |
;-----------------------------------------------------------------------------; |
; uint16_t isqrt32 (uint32_t n); |
; uint8_t isqrt16 (uint16_t n); |
; uint16_t ihypot (int16_t x, int16_t y); |
;-----------------------------------------------------------------------------: |
; 32bit integer squareroot |
;-----------------------------------------------------------------------------; |
; uint16_t isqrt32 ( |
; uint32_t n |
; ); |
; |
; Return Value: |
; Squareroot of n. |
; |
; Size = 53 words |
; Clock = 532..548 cycles |
; Stack = 0 byte |
.global isqrt32 |
.func isqrt32 |
isqrt32: |
clr r0 |
clr r18 |
clr r19 |
clr r20 |
ldi r21, 1 |
clr r27 |
clr r30 |
clr r31 |
ldi r26, 16 |
1: lsl r22 |
rol r23 |
rol r24 |
rol r25 |
rol r0 |
rol r18 |
rol r19 |
rol r20 |
lsl r22 |
rol r23 |
rol r24 |
rol r25 |
rol r0 |
rol r18 |
rol r19 |
rol r20 |
brpl 2f |
add r0, r21 |
adc r18, r27 |
adc r19, r30 |
adc r20, r31 |
rjmp 3f |
2: sub r0, r21 |
sbc r18, r27 |
sbc r19, r30 |
sbc r20, r31 |
3: lsl r21 |
rol r27 |
rol r30 |
andi r21, 0b11111000 |
ori r21, 0b00000101 |
sbrc r20, 7 |
subi r21, 2 |
dec r26 |
brne 1b |
lsr r30 |
ror r27 |
ror r21 |
lsr r30 |
ror r27 |
ror r21 |
mov r24, r21 |
mov r25, r27 |
ret |
.endfunc |
;-----------------------------------------------------------------------------: |
; 16bit integer squareroot |
;-----------------------------------------------------------------------------; |
; uint8_t isqrt16 ( |
; uint16_t n |
; ); |
; |
; Return Value: |
; Squareroot of n. |
; |
; Size = 33 words |
; Clock = 181..189 cycles |
; Stack = 0 byte |
.global isqrt16 |
.func isqrt16 |
isqrt16: |
clr r18 |
clr r19 |
ldi r20, 1 |
clr r21 |
ldi r22, 8 |
1: lsl r24 |
rol r25 |
rol r18 |
rol r19 |
lsl r24 |
rol r25 |
rol r18 |
rol r19 |
brpl 2f |
add r18, r20 |
adc r19, r21 |
rjmp 3f |
2: sub r18, r20 |
sbc r19, r21 |
3: lsl r20 |
rol r21 |
andi r20, 0b11111000 |
ori r20, 0b00000101 |
sbrc r19, 7 |
subi r20, 2 |
dec r22 |
brne 1b |
lsr r21 |
ror r20 |
lsr r21 |
ror r20 |
mov r24, r20 |
ret |
.endfunc |
;-----------------------------------------------------------------------------: |
; 16bit integer hypot (megaAVR is required) |
;-----------------------------------------------------------------------------; |
; uint16_t ihypot ( |
; int16_t x, |
; int16_t y |
; ); |
; |
; Return Value: |
; Squareroot of (x*x + y*y) |
; |
; Size = 42 words |
; Clock = 581..597 cycles |
; Stack = 0 byte |
.global ihypot |
.func ihypot |
ihypot: |
clr r26 |
sbrs r25, 7 |
rjmp 1f |
com r24 |
com r25 |
adc r24, r26 |
adc r25, r26 |
1: sbrs r23, 7 |
rjmp 2f |
com r22 |
com r23 |
adc r22, r26 |
adc r23, r26 |
2: mul r22, r22 |
movw r18, r0 |
mul r23, r23 |
movw r20, r0 |
mul r22, r23 |
add r19, r0 |
adc r20, r1 |
adc r21, r26 |
add r19, r0 |
adc r20, r1 |
adc r21, r26 |
mul r24, r24 |
movw r30, r0 |
mul r25, r25 |
add r18, r30 |
adc r19, r31 |
adc r20, r0 |
adc r21, r1 |
mul r24, r25 |
add r19, r0 |
adc r20, r1 |
adc r21, r26 |
add r19, r0 |
adc r20, r1 |
adc r21, r26 |
movw r24, r20 |
movw r22, r18 |
clr r1 |
rjmp isqrt32 |
.endfunc |
/tags/V2.02b/isqrt.h |
---|
0,0 → 1,11 |
#ifndef _ISQRT_H |
#define _ISQRT_H |
#include <inttypes.h> |
// coded in assembler file |
extern uint16_t isqrt32(uint32_t n); |
extern uint8_t isqrt16(uint16_t n); |
extern uint16_t ihypot(int16_t x, int16_t y); |
#endif // _ISQRT_H |
/tags/V2.02b/jeti_ex.c |
---|
0,0 → 1,144 |
#include "libfc.h" |
#include "printf_P.h" |
#include "main.h" |
#include "spi.h" |
#include "capacity.h" |
#include "jeti_ex.h" |
#include "hottmenu.h" |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
const char PROGMEM JETI_CODE[53] = |
{ |
0, // 0 |
'O', // SPEAK_ERR_CALIBARTION 1 |
'P', // SPEAK_ERR_RECEICER 2 |
'Q', // SPEAK_ERR_DATABUS 3 |
'R', // SPEAK_ERR_NAVI 4 |
'S', // SPEAK_ERROR 5 |
'T', // SPEAK_ERR_COMPASS 6 |
'S', // SPEAK_ERR_SENSOR 7 |
'V', // SPEAK_ERR_GPS 8 |
'W', // SPEAK_ERR_MOTOR 9 |
'H', // SPEAK_MAX_TEMPERAT 10 |
0, // SPEAK_ALTI_REACHED 11 |
'X', // SPEAK_WP_REACHED 12 |
'Y', // SPEAK_NEXT_WP 13 |
0, // SPEAK_LANDING 14 |
'Z', // SPEAK_GPS_FIX 15 |
'U', // SPEAK_UNDERVOLTAGE 16 |
'E', // SPEAK_GPS_HOLD 17 |
'F', // SPEAK_GPS_HOME 18 |
'G', // SPEAK_GPS_OFF 19 |
'H', // SPEAK_BEEP 20 |
'A', // SPEAK_MIKROKOPTER 21 |
0, // SPEAK_CAPACITY 22 |
'I', // SPEAK_CF_OFF 23 |
'B', // SPEAK_CALIBRATE 24 |
'J', // SPEAK_MAX_RANGE 25 |
'J', // SPEAK_MAX_ALTITUD 26 |
0, // 27 |
0, // 28 |
0, // 29 |
0, // 30 |
0, // 31 |
0, // 32 |
0, // 33 |
0, // 34 |
0, // 35 |
0, // 36 |
0, // 37 |
'D', // SPEAK_MK_OFF 38 |
'L', // SPEAK_ALTITUDE_ON 39 |
'M', // SPEAK_ALTITUDE_OFF 40 |
0, // 41 |
0, // 42 |
0, // 43 |
0, // 44 |
0, // 45 |
'N', // SPEAK_CF_ON 46 |
0, // SPEAK_SINKING 47 |
0, // SPEAK_RISING 48 |
0, // SPEAK_HOLDING 49 |
'K', // SPEAK_GPS_ON 50 |
0, // SPEAK_FOLLWING 51 |
'C' // SPEAK_STARTING 52 |
}; |
JetiExPacket_t JetiExData[JETI_EX_PARAMETER_COUNT + 1] = // Parameter count + DeviceName (ID0) |
{ |
// Label[10] unit[3], data type, Data , position of decimal point |
// "1234567890", "123", |
// { "-=.M_K.=-" , " ", 1, 0 , 0 }, // first one is device name // datatype 1 = -8192...8192 |
{ "MK " , " ", 1, 0 , 0 }, // first one is device name // datatype 1 = -8192...8192 |
{ "Voltage " , "V ", 1, 0 , 1 }, // ID 1 |
{ "Current " , "A ", 1, 0 , 1 }, // ID 2 |
{ "Capacity " , "Ah ", 1, 0 , 2 }, // ID 3 |
{ "Altitude " , "m ", 1, 0 , 0 }, // ID 4 |
{ "Compass " , "° ", 1, 0 , 0 }, // ID 5 |
{ "Sats " , " ", 1, 0 , 0 }, // ID 6 |
{ "Speed " , "m/s", 1, 0 , 0 }, // ID 7 |
{ "Distance " , "m ", 1, 0 , 0 }, // ID 8 |
{ "Home-Dir " , "° ", 1, 0 , 0 }, // ID 9 |
{ "max.Temp. " , "°C ", 1, 0 , 0 }, // ID 10 |
{ "Magn.field" , "% ", 1, 0 , 0 }, // ID 11 |
{ "Vario " , " ", 1, 0 , 0 }, // ID 12 |
{ "ErrorCode " , " ", 1, 0 , 0 }, // ID 13 |
{ "Latitude " , " ", 9, 0 , 0 }, // ID 14 special data type for coordinates Import: fixed position in list ID 14 - DO NOT MOVE !!! |
{ "Longitude " , " ", 9, 0 , 0 }, // ID 15 special data type for coordinates Import: fixed position in list ID 15 - DO NOT MOVE !!! |
}; |
void BuildJeti_Vario(void) |
{ |
signed int tmp = 0; |
static signed int JetiVarioMeter = 0; |
JetiVarioMeter = (JetiVarioMeter * 3 + VarioMeter) / 4; |
if(VarioCharacter == '+') |
{ |
tmp = (AltitudeSetpointTrimming * EE_Parameter.Hoehe_Verstaerkung) / 32 + 5; |
} |
else |
if(VarioCharacter == '-') |
{ |
tmp = (AltitudeSetpointTrimming * EE_Parameter.Hoehe_Verstaerkung) / 32 - 5; |
} |
else |
if((VarioCharacter == ' ') && (FC_StatusFlags & FC_STATUS_FLY)) |
{ |
tmp = (JetiVarioMeter/32); |
} |
else |
if(VarioCharacter == '^') tmp = FromNC_AltitudeSpeed; |
else |
if(VarioCharacter == 'v') tmp = tmp - FromNC_AltitudeSpeed; |
JetiExData[12].Value = tmp; |
} |
// -------------------------------------------------------------------------------------------------- |
void JetiEX_Update(void) |
{ |
GetHottestBl(); |
JetiExData[1].Value = UBat; |
JetiExData[2].Value = Capacity.ActualCurrent; |
JetiExData[3].Value = Capacity.UsedCapacity / 10; |
JetiExData[4].Value = HoehenWert / 100; |
JetiExData[5].Value = KompassValue; |
JetiExData[6].Value = GPSInfo.NumOfSats; |
JetiExData[7].Value = GPSInfo.Speed; |
JetiExData[8].Value = GPSInfo.HomeDistance / 10; |
JetiExData[9].Value = GPSInfo.HomeBearing; |
JetiExData[10].Value = MaxBlTemperture; |
JetiExData[11].Value = EarthMagneticField; |
// JetiExData[12].Value = Vario; // wird in BuildJeti_Vario() gemacht |
JetiExData[13].Value = NC_ErrorCode; |
//JetiExData[14].Value = 53 * 0x10000 + 23467; // GPS-Latitude (macht NC_Fills_HoTT_Telemety() ) |
//JetiExData[15].Value = 7 * 0x10000 + 23467; // GPS-Longitude (macht NC_Fills_HoTT_Telemety() ) |
} |
#endif |
/tags/V2.02b/jeti_ex.h |
---|
0,0 → 1,37 |
#ifndef _JETI_EX_H |
#define _JETI_EX_H |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
extern void BuildJeti_Vario(void); |
// define here how many Jeti EX parameters should be transmitted (max. = 15) |
// |
#define JETI_EX_PARAMETER_COUNT 15 |
// |
// ------------------------------------------------------------------------- |
extern const char PROGMEM JETI_CODE[53]; |
typedef struct |
{ |
char Label[10]; |
char Unit[3]; |
unsigned char DataType; |
long Value; |
unsigned char DecimalPointPos; |
} JetiExPacket_t; |
extern JetiExPacket_t JetiExData[]; |
extern void JetiEX_Update(void); |
#if (JETI_EX_PARAMETER_COUNT > 15) |
#error "ERROR: Too many Jeti EX parameters (max. allowed 15)" |
#endif |
#endif |
#endif //_JETI_EX_H |
/tags/V2.02b/jetimenu.c |
---|
0,0 → 1,267 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "jetimenu.h" |
#include "libfc.h" |
#include "printf_P.h" |
#include "main.h" |
#include "spi.h" |
#include "capacity.h" |
#include "hottmenu.h" |
#define JETIBOX_KEY_RIGHT 0x1F |
#define JETIBOX_KEY_UP 0x2F |
#define JETIBOX_KEY_DOWN 0x4F |
#define JETIBOX_KEY_LEFT 0x8F |
#define JETIBOX_KEY_NONE 0x0F |
#define JETIBOX_KEY_UNDEF 0x00 |
#define JetiBox_printfxy(x,y,format, args...) { LIBFC_JetiBox_SetPos(y * 16 + x); _printf_P(&LIBFC_JetiBox_Putchar, PSTR(format) , ## args);} |
#define JetiBox_printf(format, args...) { _printf_P(&LIBFC_JetiBox_Putchar, PSTR(format) , ## args);} |
// ----------------------------------------------------------- |
// the menu functions |
// ----------------------------------------------------------- |
void Menu_Status(uint8_t key) |
{ //0123456789ABCDEF |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
JetiBox_printfxy(0,0,"%2i.%1iV",UBat/10, UBat%10); |
if(NaviDataOkay) |
{ |
JetiBox_printfxy(6,0,"%3d%c %03dm%c",ErsatzKompassInGrad, 0xDF, GPSInfo.HomeDistance/10,NC_GPS_ModeCharacter); |
} |
else |
{ |
JetiBox_printfxy(6,0,"Status"); |
} |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(NC_ErrorCode) |
{ |
static unsigned int timer; |
static char toggle = 1; |
if(CheckDelay(timer)) { if(toggle) toggle = 0; else toggle = 1; timer = SetDelay(1500);}; |
if(toggle) |
{ |
LIBFC_JetiBox_SetPos(0); |
_printf_P(&LIBFC_JetiBox_Putchar, NC_ERROR_TEXT[NC_ErrorCode] , 0); |
} |
else |
{ |
JetiBox_printfxy(6,0,"ERROR: %2d ",NC_ErrorCode); |
// if(MotorenEin) JetiBeep = 'O'; |
} |
} |
else |
if(ShowSettingNameTime) |
{ |
LIBFC_JetiBox_Clear(); |
JetiBox_printfxy(0,1,"Set%d:%s ",ActiveParamSet,EE_Parameter.Name); |
return; // nichts weiter ausgeben |
} |
#else |
if(NC_ErrorCode) { JetiBox_printfxy(6,0,"ERROR: %2d ",NC_ErrorCode); if(MotorenEin) JetiBeep = 'S';}; |
#endif |
JetiBox_printfxy(0,1,"%4i %2i:%02i",Capacity.UsedCapacity,FlugSekunden/60,FlugSekunden%60); |
if(Parameter_GlobalConfig & CFG_HOEHENREGELUNG) |
{ |
JetiBox_printfxy(10,1,"%4im%c", (int16_t)(HoehenWert/100),VarioCharacter); |
} |
#endif |
} |
void Menu_Temperature(uint8_t key) |
{ //0123456789ABCDEF |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
JetiBox_printfxy(0,0,"%3i %3i %3i %3i", Motor[0].Temperature, Motor[1].Temperature, Motor[2].Temperature, Motor[3].Temperature); |
JetiBox_printfxy(0,1,"%3i %3i %3i %3i", Motor[4].Temperature, Motor[5].Temperature, Motor[6].Temperature, Motor[7].Temperature); |
if(RequiredMotors <= 4) |
{ |
JetiBox_printfxy(0,1,"Temperatures "); |
} |
else |
if(RequiredMotors <= 6) |
{ |
JetiBox_printfxy(8,1,"\%cC ",0xdf); |
} |
#endif |
} |
void Menu_Battery(uint8_t key) |
{ //0123456789ABCDEF |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
JetiBox_printfxy(0,0,"%2i.%1iV %3i.%1iA", UBat/10, UBat%10, Capacity.ActualCurrent/10, Capacity.ActualCurrent%10); |
JetiBox_printfxy(0,1,"%4iW %6imAh",Capacity.ActualPower, Capacity.UsedCapacity); |
#endif |
} |
void Magnet_Values(uint8_t key) |
{ //0123456789ABCDEF |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
JetiBox_printfxy(0,0,"Magnet:%3i%% %3i%c",EarthMagneticField, KompassValue,0xDF); |
JetiBox_printfxy(0,1,"Incli.:%3i%c (%i) ",EarthMagneticInclination, 0xDF,EarthMagneticInclinationTheoretic); |
#endif |
} |
void Menu_PosInfo(uint8_t key) |
{ |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
if(NaviDataOkay) |
{ |
JetiBox_printfxy(0,0,"%2um/s Sat:%d ",GPSInfo.Speed,GPSInfo.NumOfSats); |
switch (GPSInfo.SatFix) |
{ |
case SATFIX_3D: |
JetiBox_printfxy(12,0," 3D"); |
break; |
// case SATFIX_2D: |
// case SATFIX_NONE: |
default: |
JetiBox_printfxy(12,0,"NoFx"); |
break; |
} |
if(GPSInfo.Flags & FLAG_DIFFSOLN) |
{ |
JetiBox_printfxy(12,0,"DGPS"); |
} |
JetiBox_printfxy(0,1,"Home:%3dm %3d%c %c", GPSInfo.HomeDistance/10, GPSInfo.HomeBearing, 0xDF,NC_GPS_ModeCharacter); |
} |
else |
{ //0123456789ABCDEF |
JetiBox_printfxy(2,0,"No NaviCtrl!"); |
} |
#endif |
} |
// ----------------------------------------------------------- |
// the menu topology |
// ----------------------------------------------------------- |
typedef void (*pFctMenu) (uint8_t); // the menu item handler function pointer |
typedef struct{ |
int8_t left; |
int8_t right; |
int8_t up; |
int8_t down; |
pFctMenu pHandler; |
} MENU_ENTRY; |
// the menu navigation structure |
/* | |
3 - 0 - 1 - 2 - 3 - 0 |
*/ |
const MENU_ENTRY JetiBox_Menu[] PROGMEM= |
{ // l r u d pHandler |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
{4, 1, 0, 0, &Menu_Status }, // 0 |
{0, 2, 1, 1, &Menu_Temperature }, // 1 |
{1, 3, 2, 2, &Menu_Battery }, // 2 |
{2, 4, 3, 3, &Menu_PosInfo }, // 3 |
{3, 0, 4, 4, &Magnet_Values } // 4 |
#endif |
}; |
// ----------------------------------------------------------- |
// Update display buffer |
// ----------------------------------------------------------- |
unsigned char JetiBox_Update(unsigned char key) |
{ |
#if !defined (RECEIVER_SPEKTRUM_DX7EXP) && !defined (RECEIVER_SPEKTRUM_DX8EXP) |
static uint8_t item = 0, last_item = 0; // the menu item |
static uint8_t updateDelay = 1; |
// navigate within the menu by key action |
last_item = item; |
switch(key) |
{ |
case JETIBOX_KEY_LEFT: |
//if (item == 0) return (1); // switch back to jeti expander menu |
// else |
item = pgm_read_byte(&JetiBox_Menu[item].left); //trigger to left menu item |
break; |
case JETIBOX_KEY_RIGHT: |
item = pgm_read_byte(&JetiBox_Menu[item].right); //trigger to right menu item |
break; |
case JETIBOX_KEY_UP: |
item = pgm_read_byte(&JetiBox_Menu[item].up); //trigger to up menu item |
break; |
case JETIBOX_KEY_DOWN: |
item = pgm_read_byte(&JetiBox_Menu[item].down); //trigger to down menu item |
break; |
default: |
break; |
} |
// if the menu item has been changed, do not pass the key to the item handler |
// to avoid jumping over to items |
if(item != last_item) key = JETIBOX_KEY_UNDEF; |
if (updateDelay++ & 0x01) |
{ |
LIBFC_JetiBox_Clear(); |
//execute menu item handler |
((pFctMenu)(pgm_read_word(&(JetiBox_Menu[item].pHandler))))(key); |
} |
#endif |
return (0); |
} |
/tags/V2.02b/jetimenu.h |
---|
0,0 → 1,6 |
#ifndef _JETIMENU_H |
#define _JETIMENU_H |
extern unsigned char JetiBox_Update(unsigned char key); |
#endif //_JETIMENU_H |
/tags/V2.02b/led.c |
---|
0,0 → 1,132 |
#include <inttypes.h> |
#include "main.h" |
uint16_t LED1_Timing = 0; |
uint16_t LED2_Timing = 0; |
unsigned char J16Blinkcount = 0, J16Mask = 1; |
unsigned char J17Blinkcount = 0, J17Mask = 1; |
unsigned char NC_Wait_for_LED = 0; // signal to NC: Wait for the LAD PAtter before switching to the next WP |
// initializes the LED control outputs J16, J17 |
void LED_Init(void) |
{ |
// set PC2 & PC3 as output (control of J16 & J17) |
DDRC |= (1<<DDC2)|(1<<DDC3); |
J16_OFF; |
J17_OFF; |
J16Blinkcount = 0; J16Mask = 128; |
J17Blinkcount = 0; J17Mask = 128; |
} |
// called in UpdateMotors() every 2ms |
void LED_Update(void) |
{ |
static char delay = 0; |
static unsigned char J16Bitmask = 0; |
static unsigned char J17Bitmask = 0; |
static unsigned char J16Warn = 0, J17Warn = 0; |
static unsigned char from_nc = 0; |
if(FromNC_WP_EventChannel != -127) { from_nc = (unsigned char) FromNC_WP_EventChannel + 127; /*beeptime = 300;*/}; |
if(!delay--) // 20ms Intervall |
{ |
J16Bitmask = EE_Parameter.J16Bitmask; |
J17Bitmask = EE_Parameter.J17Bitmask; |
delay = 9; |
if(FC_StatusFlags & (FC_STATUS_LOWBAT | FC_STATUS_EMERGENCY_LANDING) || (VersionInfo.HardwareError[1] & FC_ERROR1_I2C)) |
{ |
if(EE_Parameter.WARN_J16_Bitmask) |
{ |
if(!J16Warn) J16Blinkcount = 4; |
J16Warn = 1; |
} |
if(EE_Parameter.WARN_J17_Bitmask) |
{ |
if(!J17Warn) J17Blinkcount = 4; |
J17Warn = 1; |
} |
} |
else |
{ |
J16Warn = 0; |
J17Warn = 0; |
} |
//DebugOut.Analog[29] = EE_Parameter.GlobalConfig3; |
// Output 1 |
if(!J16Warn) |
{ |
if((EE_Parameter.BitConfig & CFG_MOTOR_BLINK1) && !MotorenEin) {if(EE_Parameter.BitConfig & CFG_MOTOR_OFF_LED1) J16_ON; else J16_OFF;} |
else |
if((EE_Parameter.J16Timing > 247) && (Parameter_J16Timing > 220)) {if(J16Bitmask & 128) J16_OFF; else J16_ON; J16Mask = 1; NC_Wait_for_LED = 0;} // Manual overwrite |
else |
if((EE_Parameter.J16Timing > 247) && (Parameter_J16Timing == 5)) {if(J16Bitmask & 128) J16_ON; else J16_OFF; J16Mask = 1; NC_Wait_for_LED = 0;} // Manual overwrite |
else |
if(!J16Blinkcount--) |
{ |
if(EE_Parameter.GlobalConfig3 & CFG3_USE_NC_FOR_OUT1) |
{ |
J16Blinkcount = from_nc / 2; |
if(!from_nc) { NC_Wait_for_LED = 0; if(J16Bitmask & 128) J16_ON; else J16_OFF; J16Mask = 0; } // Ausschalten |
else |
{ |
NC_Wait_for_LED = 1; |
if(J16Mask == 0) |
{ |
from_nc = 0; |
J16Mask = 64; |
if(J16Bitmask & 128) J16_ON; else J16_OFF; // Ausschalten |
} |
else |
{ |
//if(FromNC_WP_EventChannel != -127) |
if(J16Mask & J16Bitmask) J16_ON; else J16_OFF; |
J16Mask /= 2; |
} |
} |
} |
else |
{ |
J16Blinkcount = Parameter_J16Timing / 2; |
if(J16Mask == 1) { from_nc = 0; J16Mask = 64; } else J16Mask /= 2; |
if(J16Mask & J16Bitmask) J16_ON; else J16_OFF; |
NC_Wait_for_LED = 0; |
} |
} |
} |
else // warning case |
if(!J16Blinkcount--) |
{ |
J16Blinkcount = 10-1; |
if(J16Mask == 1) J16Mask = 128; else J16Mask /= 2; |
if(J16Mask & EE_Parameter.WARN_J16_Bitmask) J16_ON; else J16_OFF; |
} |
// Output 2 |
if(!J17Warn) |
{ |
if((EE_Parameter.BitConfig & CFG_MOTOR_BLINK2) && !MotorenEin) {if(EE_Parameter.BitConfig & CFG_MOTOR_OFF_LED2) J17_ON; else J17_OFF;} |
else |
if((EE_Parameter.J17Timing > 247) && (Parameter_J17Timing > 220)) {if(J17Bitmask & 128) J17_OFF; else J17_ON; J17Mask = 1;} |
else |
if((EE_Parameter.J17Timing > 247) && (Parameter_J17Timing == 5)) {if(J17Bitmask & 128) J17_ON; else J17_OFF; J17Mask = 1;} |
else |
if(!J17Blinkcount--) |
{ |
J17Blinkcount = Parameter_J17Timing / 2; |
if(J17Mask == 1) J17Mask = 64; else J17Mask /= 2; |
if(J17Mask & J17Bitmask) J17_ON; else J17_OFF; |
} |
} |
else // warning case |
if(!J17Blinkcount--) |
{ |
J17Blinkcount = 10-1; |
if(J17Mask == 1) J17Mask = 128; else J17Mask /= 2; |
if(J17Mask & EE_Parameter.WARN_J17_Bitmask) J17_ON; else J17_OFF; |
} |
if(PORTC & (1<<PORTC2)) FC_StatusFlags2 |= FC_STATUS2_OUT1_ACTIVE; //else FC_StatusFlags2 &= ~FC_STATUS2_OUT1_ACTIVE; // Out1 (J16) -> wird in der SPI zurück gesetzt |
if(PORTC & (1<<PORTC3)) FC_StatusFlags2 |= FC_STATUS2_OUT2_ACTIVE; else FC_StatusFlags2 &= ~FC_STATUS2_OUT2_ACTIVE; // Out2 (J17) |
} |
} |
/tags/V2.02b/led.h |
---|
0,0 → 1,12 |
#include <avr/io.h> |
#define J16_ON PORTC |= (1<<PORTC2) |
#define J16_OFF PORTC &= ~(1<<PORTC2) |
#define J16_TOGGLE PORTC ^= (1<<PORTC2) |
#define J17_ON PORTC |= (1<<PORTC3) |
#define J17_OFF PORTC &= ~(1<<PORTC3) |
#define J17_TOGGLE PORTC ^= (1<<PORTC3) |
extern void LED_Init(void); |
extern void LED_Update(void); |
extern unsigned char NC_Wait_for_LED; |
/tags/V2.02b/libfc.h |
---|
0,0 → 1,24 |
#ifndef _LIBFC_H |
#define _LIBFC_H |
#define CPU_UNKNOWN 0 |
#define CPU_ATMEGA644 1 |
#define CPU_ATMEGA644P 2 |
#define CPU_ATMEGA1284 3 |
#define CPU_ATMEGA1284P 4 |
extern void LIBFC_Init(unsigned char); |
extern void LIBFC_Polling(void); |
extern void LIBFC_ReceiverInit(unsigned char rtype); |
extern void LIBFC_JetiBox_Putchar(char c); |
extern void LIBFC_JetiBox_SetPos(unsigned char index); |
extern void LIBFC_JetiBox_Clear(void); |
extern void LIBFC_CheckSettings(void); |
extern unsigned char LIBFC_GetCPUType(void); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
extern long ACC_AltitudeFusion(unsigned char init); |
#endif |
#endif //_LIBFC_H |
/tags/V2.02b/libfc1284.a |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/tags/V2.02b/libfc644.a |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/tags/V2.02b/main.c |
---|
0,0 → 1,480 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "main.h" |
unsigned char DisableRcOffBeeping = 0; |
unsigned char PlatinenVersion = 10; |
unsigned char BattLowVoltageWarning = 94; |
unsigned int FlugMinuten = 0,FlugMinutenGesamt = 0; |
unsigned int FlugSekunden = 0; |
pVoidFnct_pVoidFnctChar_const_fmt _printf_P; |
unsigned char FoundMotors = 0; |
unsigned char JetiBeep = 0; // to allow any Morse-Beeping of the Jeti-Box |
unsigned char ActiveParamSet = 3; |
unsigned char LipoCells = 4; |
void PrintLine(void) |
{ |
printf("\n\r==================================="); |
} |
void CalMk3Mag(void) |
{ |
static unsigned char stick = 1; |
if(PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] > -20) stick = 0; |
if((PPM_in[EE_Parameter.Kanalbelegung[K_NICK]] < -70) && !stick) |
{ |
stick = 1; |
WinkelOut.CalcState++; |
if(WinkelOut.CalcState > 4) |
{ |
// WinkelOut.CalcState = 0; // in Uart.c |
beeptime = 1000; |
} |
else Piep(WinkelOut.CalcState,150); |
} |
} |
void LipoDetection(unsigned char print) |
{ |
#define MAX_CELL_VOLTAGE 43 // max cell volatage for LiPO |
if(print) printf("\n\rBatt:"); |
// timer = SetDelay(100); |
// if(print) while (!CheckDelay(timer)); |
// up to 6s LiPo, less than 2s is technical impossible |
// for(cells = 2; cells < 7; cells++) if(UBat < cells * MAX_CELL_VOLTAGE) break; |
LipoCells = 1 + UBat / MAX_CELL_VOLTAGE; |
if(EE_Parameter.UnterspannungsWarnung < 50) |
{ |
BattLowVoltageWarning = LipoCells * EE_Parameter.UnterspannungsWarnung; |
if(print) |
{ |
Piep(LipoCells, 200); |
printf(" %d Cells ", LipoCells); |
} |
} |
else BattLowVoltageWarning = EE_Parameter.UnterspannungsWarnung; |
// automatische Zellenerkennung |
if(EE_Parameter.AutoLandingVoltage < 50) EE_Parameter.AutoLandingVoltage = LipoCells * EE_Parameter.AutoLandingVoltage; |
if(EE_Parameter.AutoLandingVoltage > BattLowVoltageWarning) EE_Parameter.AutoLandingVoltage = BattLowVoltageWarning - 1; |
if(print) |
{ |
printf(" Low warning: %d.%d",BattLowVoltageWarning/10,BattLowVoltageWarning%10); |
if(EE_Parameter.AutoLandingVoltage) printf(" Autolanding: %d.%d",EE_Parameter.AutoLandingVoltage/10,EE_Parameter.AutoLandingVoltage%10); |
} |
} |
//############################################################################ |
//Hauptprogramm |
int main (void) |
//############################################################################ |
{ |
unsigned int timer,i,timer2 = 0, timerPolling; |
unsigned char update_spi = 1; |
DDRB = 0x00; |
PORTB = 0x00; |
DDRD = 0x0A; // UART & J3 J4 J5 |
PORTD = 0x5F; // PPM-Input & UART |
for(timer = 0; timer < 1000; timer++); // verzögern |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
unsigned char AccZ_ErrorCnt = 0; |
if(PINB & 0x02) |
{ |
if(PIND & 0x10) PlatinenVersion = 21; // No Bridge from J4 to GND |
else { PlatinenVersion = 22; ACC_AltitudeControl = 1;}; |
} |
else |
{ |
PlatinenVersion = 25; ACC_AltitudeControl = 1; |
} |
#else |
if(PINB & 0x01) |
{ |
if(PINB & 0x02) PlatinenVersion = 13; |
else PlatinenVersion = 11; |
} |
else |
{ |
if(PINB & 0x02) PlatinenVersion = 20; |
else |
{ |
PlatinenVersion = 10; |
DDRD = 0x3E; // Speaker & TXD & J3 J4 J5 |
PORTD = 0x47; // |
} |
} |
#endif |
DDRC = 0x81; // I2C, Spaker |
DDRC |=0x40; // HEF4017 Reset |
PORTC = 0xff; // Pullup SDA |
DDRB = 0x1B; // LEDs und Druckoffset |
PORTB = 0x01; // LED_Rot |
HEF4017Reset_ON; |
MCUSR &=~(1<<WDRF); |
WDTCSR |= (1<<WDCE)|(1<<WDE); |
WDTCSR = 0; |
beeptime = 2500; |
StickGier = 0; PPM_in[K_GAS] = 0; StickRoll = 0; StickNick = 0; |
if(PlatinenVersion >= 20) GIER_GRAD_FAKTOR = 1220; else GIER_GRAD_FAKTOR = 1291; // unterschiedlich für ME und ENC |
ROT_OFF; |
GRN_ON; |
Timer_Init(); |
TIMER2_Init(); |
UART_Init(); |
rc_sum_init(); |
ADC_Init(); |
I2C_Init(1); |
SPI_MasterInit(); |
Capacity_Init(); |
LIBFC_Init(LIB_FC_COMPATIBLE); |
GRN_ON; |
sei(); |
ParamSet_Init(); |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Check connected BL-Ctrls |
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// Check connected BL-Ctrls |
BLFlags |= BLFLAG_READ_VERSION; |
motor_read = 0; // read the first I2C-Data |
SendMotorData(); |
timer = SetDelay(500); |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
printf("\n\rFound BL-Ctrl: "); |
timer = SetDelay(4000); |
for(i=0; i < MAX_MOTORS; i++) |
{ |
SendMotorData(); |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
if(Mixer.Motor[i][0] > 0) // wait max 4 sec for the BL-Ctrls to wake up |
{ |
while(!CheckDelay(timer) && !(Motor[i].State & MOTOR_STATE_PRESENT_MASK) ) |
{ |
SendMotorData(); |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
} |
} |
if(Motor[i].State & MOTOR_STATE_PRESENT_MASK) |
{ |
printf("%d",i+1); |
FoundMotors++; |
// if(Motor[i].Version & MOTOR_STATE_FAST_MODE) printf("(fast)\n\r"); |
// else if(Motor[i].Version & MOTOR_STATE_NEW_PROTOCOL_MASK) printf("(new)\n\r"); |
} |
} |
for(i=0; i < MAX_MOTORS; i++) |
{ |
if(!(Motor[i].State & MOTOR_STATE_PRESENT_MASK) && Mixer.Motor[i][0] > 0) |
{ |
printf("\n\r\n\r!! MISSING BL-CTRL: %d !!",i+1); |
ServoActive = 2; // just in case the FC would be used as camera-stabilizer |
} |
Motor[i].State &= ~MOTOR_STATE_ERROR_MASK; // clear error counter |
} |
PrintLine();// ("\n\r==================================="); |
if(RequiredMotors < FoundMotors) VersionInfo.HardwareError[1] |= FC_ERROR1_MIXER; |
//if(EE_Parameter.GlobalConfig & CFG_HOEHENREGELUNG) |
{ |
printf("\n\rCalibrating pressure sensor.."); |
timer = SetDelay(1000); |
SucheLuftruckOffset(); |
while (!CheckDelay(timer)); |
printf("OK\n\r"); |
} |
SetNeutral(0); |
ROT_OFF; |
beeptime = 2000; |
ExternControl.Digital[0] = 0x55; |
FlugMinuten = (unsigned int)GetParamByte(PID_FLIGHT_MINUTES) * 256 + (unsigned int)GetParamByte(PID_FLIGHT_MINUTES + 1); |
FlugMinutenGesamt = (unsigned int)GetParamByte(PID_FLIGHT_MINUTES_TOTAL) * 256 + (unsigned int)GetParamByte(PID_FLIGHT_MINUTES_TOTAL + 1); |
if((FlugMinutenGesamt == 0xFFFF) || (FlugMinuten == 0xFFFF)) |
{ |
FlugMinuten = 0; |
FlugMinutenGesamt = 0; |
} |
printf("\n\rFlight-time %u min Total:%u min", FlugMinuten, FlugMinutenGesamt); |
LcdClear(); |
I2CTimeout = 5000; |
WinkelOut.Orientation = 1; |
LipoDetection(1); |
LIBFC_ReceiverInit(EE_Parameter.Receiver); |
PrintLine();// ("\n\r==================================="); |
//SpektrumBinding(); |
timer = SetDelay(2000); |
timerPolling = SetDelay(250); |
Debug(ANSI_CLEAR "FC-Start!\n\rFlugzeit: %d min", FlugMinutenGesamt); // Note: this won't waste flash memory, if #DEBUG is not active |
//printf("\n\rEE_Parameter size:%i\n\r", PARAMSET_STRUCT_LEN); |
DebugOut.Status[0] = 0x01 | 0x02; |
JetiBeep = 0; |
if(EE_Parameter.ExtraConfig & CFG_NO_RCOFF_BEEPING) DisableRcOffBeeping = 1; |
EEAR = EE_DUMMY; // Set the EEPROM Address pointer to an unused space |
while(1) |
{ |
if(ReceiverUpdateModeActive) while (1) PORTC &= ~(1<<7); // Beeper off |
//GRN_ON; |
if(UpdateMotor && AdReady) // ReglerIntervall |
{ |
//GRN_OFF; |
cli(); |
UpdateMotor--; |
sei(); |
if(WinkelOut.CalcState) CalMk3Mag(); |
else MotorRegler(); |
SendMotorData(); |
ROT_OFF; |
if(SenderOkay) { SenderOkay--; /*VersionInfo.HardwareError[1] &= ~FC_ERROR1_PPM;*/ } |
else |
{ |
TIMSK1 |= _BV(ICIE1); // enable PPM-Input |
PPM_in[0] = 0; // set RSSI to zero on data timeout |
VersionInfo.HardwareError[1] |= FC_ERROR1_PPM; |
} |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
//if(HoehenReglerAktiv && NaviDataOkay && SenderOkay < 160 && SenderOkay > 10 && FromNaviCtrl_Value.SerialDataOkay > 220) SenderOkay = 160; |
//if(HoehenReglerAktiv && NaviDataOkay && SenderOkay < 101 && SenderOkay > 10 && FromNaviCtrl_Value.SerialDataOkay > 1) SenderOkay = 101; |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
if(!--I2CTimeout || MissingMotor) |
{ |
if(!I2CTimeout) |
{ |
I2C_Reset(); |
I2CTimeout = 5; |
DebugOut.Analog[28]++; // I2C-Error |
VersionInfo.HardwareError[1] |= FC_ERROR1_I2C; |
DebugOut.Status[1] |= 0x02; // BL-Error-Status |
} |
if((BeepMuster == 0xffff) && MotorenEin) |
{ |
beeptime = 25000; |
BeepMuster = 0x0080; |
} |
} |
else |
{ |
ROT_OFF; |
} |
LIBFC_Polling(); |
if(!UpdateMotor) |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(NewSBusData) ProcessSBus(); |
else |
#endif |
{ |
if(BytegapSPI == 0) SPI_TransmitByte(); |
if(CalculateServoSignals) CalculateServo(); |
DatenUebertragung(); |
BearbeiteRxDaten(); |
if(CheckDelay(timer)) |
{ |
static unsigned char second; |
timer += 20; // 20 ms interval |
CalcNickServoValue(); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(EE_Parameter.Receiver == RECEIVER_HOTT) HoTT_Menu(); |
else |
if(EE_Parameter.Receiver == RECEIVER_JETI) BuildJeti_Vario(); |
// ++++++++++++++++++++++++++++ |
// + check the ACC-Z range |
if(ACC_AltitudeControl && ((Aktuell_az < 300) || (DebugOut.Analog[7] < (128 * 4) && Aktuell_az > 850))) // DebugOut.Analog[7] = GasMischanteil |
{ |
if(++AccZ_ErrorCnt > 50) |
{ |
if(MotorenEin) VersionInfo.HardwareError[0] |= FC_ERROR0_ACC_TOP; |
else CalibrationDone = 0; |
} |
} |
else AccZ_ErrorCnt = 0; |
// ++++++++++++++++++++++++++++ |
#endif |
if(MissingMotor || Capacity.MinOfMaxPWM < 30) |
{ |
if(MissingMotor) VersionInfo.HardwareError[1] |= FC_ERROR1_BL_MISSING; |
DebugOut.Status[1] |= 0x02; // BL-Error-Status |
} |
else |
{ |
if(!beeptime) |
{ |
if(I2CTimeout > 6) DebugOut.Status[1] &= ~0x02; // BL-Error-Status |
} |
} |
if(DisableRcOffBeeping) if(SenderOkay > 150) { DisableRcOffBeeping = 0; beeptime = 5000;}; |
if(PcZugriff) PcZugriff--; |
else |
{ |
ExternControl.Config = 0; |
ExternStickNick = 0; |
ExternStickRoll = 0; |
ExternStickGier = 0; |
if(!SenderOkay) |
{ |
if(BeepMuster == 0xffff && DisableRcOffBeeping != 2) |
{ |
beeptime = 15000; |
BeepMuster = 0x0c00; |
if(DisableRcOffBeeping) DisableRcOffBeeping = 2; |
} |
} |
} |
if(NaviDataOkay > 200) |
{ |
NaviDataOkay--; |
VersionInfo.HardwareError[1] &= ~FC_ERROR1_SPI_RX; |
VersionInfo.Flags |= FC_VERSION_FLAG_NC_PRESENT; |
} |
else |
{ |
if(NC_Version.Compatible) |
{ |
VersionInfo.HardwareError[1] |= FC_ERROR1_SPI_RX; |
NC_ErrorCode = 9; // "ERR: no NC communication" |
if(BeepMuster == 0xffff && MotorenEin) |
{ |
beeptime = 15000; |
BeepMuster = 0xA800; |
} |
} |
GPS_Nick = 0; |
GPS_Roll = 0; |
GPS_Aid_StickMultiplikator = 0; |
GPSInfo.Flags = 0; |
FromNaviCtrl_Value.Kalman_K = -1; |
FromNaviCtrl.AccErrorN = 0; |
FromNaviCtrl.AccErrorR = 0; |
FromNaviCtrl.CompassValue = -1; |
FromNC_AltitudeSpeed = 0; |
FromNC_AltitudeSetpoint = 0; |
VersionInfo.Flags &= ~FC_VERSION_FLAG_NC_PRESENT; |
NaviDataOkay = 0; |
} |
if(UBat <= BattLowVoltageWarning) |
{ |
FC_StatusFlags |= FC_STATUS_LOWBAT; |
if(BeepMuster == 0xffff && UBat > 10) // Do not beep, if the voltage reading is below 1V (Supplied via MKUSB) |
{ |
beeptime = 6000; |
BeepMuster = 0x0300; |
} |
} |
// SendSPI = SPI_BYTEGAP; |
EEAR = EE_DUMMY; // Set the EEPROM Address pointer to an unused space |
// +++++++++++++++++++++++++++++++++ |
// Sekundentakt |
if(++second == 49) |
{ |
second = 0; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(ShowSettingNameTime) ShowSettingNameTime--; |
#endif |
if(FC_StatusFlags & FC_STATUS_FLY) FlugSekunden++; |
else timer2 = 1450; // 0,5 Minuten aufrunden |
if(modell_fliegt < 1024) |
{ |
if(StartLuftdruck < Luftdruck) StartLuftdruck += 5; |
else |
if(StartLuftdruck > Luftdruck) StartLuftdruck -= 5; |
} |
if(UBat > BattLowVoltageWarning + 1) FC_StatusFlags &= ~FC_STATUS_LOWBAT; |
} |
// +++++++++++++++++++++++++++++++++ |
if(++timer2 == 2930) // eine Minute |
{ |
timer2 = 0; |
FlugMinuten++; |
FlugMinutenGesamt++; |
SetParamByte(PID_FLIGHT_MINUTES,FlugMinuten / 256); |
SetParamByte(PID_FLIGHT_MINUTES+1,FlugMinuten % 256); |
SetParamByte(PID_FLIGHT_MINUTES_TOTAL,FlugMinutenGesamt / 256); |
SetParamByte(PID_FLIGHT_MINUTES_TOTAL+1,FlugMinutenGesamt % 256); |
timer = SetDelay(20); // falls "timer += 20;" mal nicht geht |
} |
} |
LED_Update(); |
Capacity_Update(); |
} |
} //else DebugOut.Analog[18]++; |
if(update_spi) update_spi--; |
} // 500Hz |
if(update_spi == 0) // 41Hz |
{ |
if(SPI_StartTransmitPacket()) update_spi = 12; |
else |
if(BytegapSPI == 0) SPI_TransmitByte(); |
} |
else if(BytegapSPI == 0) SPI_TransmitByte(); |
} |
} |
//DebugOut.Analog[16] |
/tags/V2.02b/main.h |
---|
0,0 → 1,85 |
#ifndef _MAIN_H |
#define _MAIN_H |
//#define DEBUG // use to activate debug output to MK-Tool: use Debug(text); |
//#define ACT_S3D_SUMMENSIGNAL |
//#define UserParameter8_FAILSAFE |
//#define RECEIVER_SPEKTRUM_DX7EXP |
//#define RECEIVER_SPEKTRUM_DX8EXP |
// neue Hardware |
#define ROT_OFF {if((PlatinenVersion == 10)||(PlatinenVersion >= 20)) PORTB &=~0x01; else PORTB |= 0x01;} |
#define ROT_ON {if((PlatinenVersion == 10)||(PlatinenVersion >= 20)) PORTB |= 0x01; else PORTB &=~0x01;} |
#define ROT_FLASH PORTB ^= 0x01 |
#define GRN_OFF {if((PlatinenVersion < 12) || PlatinenVersion == 25) PORTB &=~0x02; else PORTB |= 0x02;} |
#define GRN_ON {if((PlatinenVersion < 12) || PlatinenVersion == 25) PORTB |= 0x02; else PORTB &=~0x02;} |
#define GRN_FLASH PORTB ^= 0x02 |
#define SYSCLK F_CPU |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#define J3High PORTD |= 0x20 |
#define J3Low PORTD &= ~0x20 |
#define J4High PORTD |= 0x10 |
#define J4Low PORTD &= ~0x10 |
#define J5High PORTD |= 0x08 |
#define J5Low PORTD &= ~0x08 |
extern volatile unsigned char SenderOkay; |
extern unsigned char BattLowVoltageWarning; |
extern unsigned char CosinusNickWinkel, CosinusRollWinkel; |
extern unsigned char PlatinenVersion; |
extern unsigned char FoundMotors,DisableRcOffBeeping; |
extern unsigned char JetiBeep; |
void LipoDetection(unsigned char print); |
extern unsigned int FlugMinuten,FlugMinutenGesamt,FlugSekunden; |
extern void PrintLine(void); // "=================================" |
extern unsigned char ActiveParamSet; |
extern unsigned int BL3_Current(unsigned char who); // in 0,1A |
extern unsigned char LipoCells; |
#include <avr/pgmspace.h> |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#endif |
#include <stdlib.h> |
#include <string.h> |
#include <avr/io.h> |
#include <avr/pgmspace.h> |
#include <avr/interrupt.h> |
#include <avr/eeprom.h> |
#include <avr/boot.h> |
#include <avr/wdt.h> |
#include "old_macros.h" |
#include "printf_P.h" |
#include "timer0.h" |
#include "uart.h" |
#include "analog.h" |
#include "twimaster.h" |
#include "menu.h" |
#include "rc.h" |
#include "fc.h" |
#include "gps.h" |
#include "spi.h" |
#include "led.h" |
#include "spektrum.h" |
#include "capacity.h" |
#include "eeprom.h" |
#include "libfc.h" |
#include "hottmenu.h" |
#include "debug.h" |
#include "sbus.h" |
#include "jeti_ex.h" |
#endif //_MAIN_H |
/tags/V2.02b/makefile |
---|
0,0 → 1,496 |
#-------------------------------------------------------------------- |
# MCU name |
MCU = atmega1284p |
#MCU = atmega644p |
F_CPU = 20000000 |
#------------------------------------------------------------------- |
VERSION_MAJOR = 2 |
VERSION_MINOR = 02 |
VERSION_PATCH = 1 |
VERSION_SERIAL_MAJOR = 11 # Serial Protocol |
VERSION_SERIAL_MINOR = 0 # Serial Protocol |
NC_SPI_COMPATIBLE = 57 # Navi-Kompatibilität |
LIB_FC_COMPATIBLE = 5 # Library |
#------------------------------------------------------------------- |
# ATMEGA644: 63487 is maximum |
#------------------------------------------------------------------- |
# 0 a |
# 1 b |
# 2 c |
# 3 d |
# 4 e |
# 5 f |
# 6 g |
# 7 h |
# 8 i |
# 9 j |
# 10 k |
# 11 L |
#------------------------------------------------------------------- |
# get SVN revision |
REV := $(shell sh -c "cat .svn/entries | sed -n '4p'") |
ifeq ($(MCU), atmega1284p) |
FUSE_SETTINGS = -u -U lfuse:w:0xff:m -U hfuse:w:0xdf:m |
HEX_NAME = MEGA1284P |
LIBFC_EXT = 1284 |
endif |
ifeq ($(MCU), atmega644p) |
FUSE_SETTINGS = -u -U lfuse:w:0xff:m -U hfuse:w:0xdf:m |
HEX_NAME = MEGA644 |
LIBFC_EXT = 644 |
endif |
ifeq ($(F_CPU), 16000000) |
QUARZ = 16MHZ |
endif |
ifeq ($(F_CPU), 20000000) |
QUARZ = 20MHZ |
endif |
# Output format. (can be srec, ihex, binary) |
FORMAT = ihex |
# Target file name (without extension). |
ifeq ($(VERSION_PATCH), 0) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)a_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 1) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)b_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 2) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)c_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 3) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)d_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 4) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)e_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 5) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)f_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 6) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)g_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 7) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)h_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 8) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)i_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 9) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)j_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 10) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)k_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 11) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)L_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 12) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)m_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 13) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)n_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 14) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)o_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 15) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)p_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 16) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)q_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 17) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)r_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 18) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)s_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 19) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)t_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 20) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)u_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 21) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)v_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 22) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)w_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 23) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)x_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 24) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)y_SVN$(REV) |
endif |
ifeq ($(VERSION_PATCH), 25) |
TARGET = Flight-Ctrl_$(HEX_NAME)_V$(VERSION_MAJOR)_$(VERSION_MINOR)z_SVN$(REV) |
endif |
# Optimization level, can be [0, 1, 2, 3, s]. 0 turns off optimization. |
# (Note: 3 is not always the best optimization level. See avr-libc FAQ.) |
OPT = s |
#OPT = 2 |
########################################################################################################## |
# List C source files here. (C dependencies are automatically generated.) |
SRC = main.c uart.c timer0.c analog.c menu.c eeprom.c |
SRC += twimaster.c rc.c fc.c GPS.c spi.c led.c Spektrum.c |
SRC += mymath.c jetimenu.c capacity.c debug.c |
SRC += hottmenu.c sbus.c user_receiver.c |
SRC += jeti_ex.c |
########################################################################################################## |
# List Assembler source files here. |
# Make them always end in a capital .S. Files ending in a lowercase .s |
# will not be considered source files but generated files (assembler |
# output from the compiler), and will be deleted upon "make clean"! |
# Even though the DOS/Win* filesystem matches both .s and .S the same, |
# it will preserve the spelling of the filenames, and gcc itself does |
# care about how the name is spelled on its command-line. |
ASRC = isqrt.S |
# List any extra directories to look for include files here. |
# Each directory must be seperated by a space. |
EXTRAINCDIRS = |
# Optional compiler flags. |
# -g: generate debugging information (for GDB, or for COFF conversion) |
# -O*: optimization level |
# -f...: tuning, see gcc manual and avr-libc documentation |
# -Wall...: warning level |
# -Wa,...: tell GCC to pass this to the assembler. |
# -ahlms: create assembler listing |
CFLAGS = -O$(OPT) -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums -Wall -Wstrict-prototypes -Wa,-adhlns=$(<:%.c=%.lst) $(patsubst %,-I%,$(EXTRAINCDIRS)) |
# Set a "language standard" compiler flag. |
# Unremark just one line below to set the language standard to use. |
# gnu99 = C99 + GNU extensions. See GCC manual for more information. |
#CFLAGS += -std=c89 |
#CFLAGS += -std=gnu89 |
#CFLAGS += -std=c99 |
CFLAGS += -std=gnu99 |
# shrink code size |
CFLAGS += -mtiny-stack |
#CFLAGS += -fno-inline-functions |
CFLAGS += -mcall-prologues |
CFLAGS += -DF_CPU=$(F_CPU) -DVERSION_MAJOR=$(VERSION_MAJOR) -DVERSION_MINOR=$(VERSION_MINOR) -DVERSION_PATCH=$(VERSION_PATCH) -DVERSION_SERIAL_MAJOR=$(VERSION_SERIAL_MAJOR) -DVERSION_SERIAL_MINOR=$(VERSION_SERIAL_MINOR) -DNC_SPI_COMPATIBLE=$(NC_SPI_COMPATIBLE) -DLIB_FC_COMPATIBLE=$(LIB_FC_COMPATIBLE) |
# Optional assembler flags. |
# -Wa,...: tell GCC to pass this to the assembler. |
# -ahlms: create listing |
# -gstabs: have the assembler create line number information; note that |
# for use in COFF files, additional information about filenames |
# and function names needs to be present in the assembler source |
# files -- see avr-libc docs [FIXME: not yet described there] |
ASFLAGS = -Wa,-adhlns=$(<:.S=.lst),-gstabs |
# Optional linker flags. |
# -Wl,...: tell GCC to pass this to linker. |
# -Map: create map file |
# --cref: add cross reference to map file |
LDFLAGS = -Wl,-Map=$(TARGET).map,--cref |
# Additional libraries |
# Minimalistic printf version |
#LDFLAGS += -Wl,-u,vfprintf -lprintf_min |
# Floating point printf version (requires -lm below) |
#LDFLAGS += -Wl,-u,vfprintf -lprintf_flt |
# -lm = math library |
LDFLAGS += -lm |
LDFLAGS += libfc$(LIBFC_EXT).a |
##LDFLAGS += -T./linkerfile/avr5.x |
# Programming support using avrdude. Settings and variables. |
# Programming hardware: alf avr910 avrisp bascom bsd |
# dt006 pavr picoweb pony-stk200 sp12 stk200 stk500 |
# |
# Type: avrdude -c ? |
# to get a full listing. |
# |
#AVRDUDE_PROGRAMMER = dt006 |
#AVRDUDE_PROGRAMMER = stk200 |
#AVRDUDE_PROGRAMMER = ponyser |
AVRDUDE_PROGRAMMER = avrispv2 |
#falls Ponyser ausgewählt wird, muss sich unsere avrdude-Configdatei im Bin-Verzeichnis des Compilers befinden |
#AVRDUDE_PORT = com1 # programmer connected to serial device |
#AVRDUDE_PORT = lpt1 # programmer connected to parallel port |
AVRDUDE_PORT = usb # programmer connected to USB |
#AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex |
AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex $(FUSE_SETTINGS) |
#AVRDUDE_WRITE_EEPROM = -U eeprom:w:$(TARGET).eep |
#avrdude -c avrispv2 -P usb -p m32 -U flash:w:blink.hex |
AVRDUDE_FLAGS = -p $(MCU) -P $(AVRDUDE_PORT) -c $(AVRDUDE_PROGRAMMER) |
# Uncomment the following if you want avrdude's erase cycle counter. |
# Note that this counter needs to be initialized first using -Yn, |
# see avrdude manual. |
#AVRDUDE_ERASE += -y |
# Uncomment the following if you do /not/ wish a verification to be |
# performed after programming the device. |
AVRDUDE_FLAGS += -V |
# Increase verbosity level. Please use this when submitting bug |
# reports about avrdude. See <http://savannah.nongnu.org/projects/avrdude> |
# to submit bug reports. |
#AVRDUDE_FLAGS += -v -v |
# --------------------------------------------------------------------------- |
# Define directories, if needed. |
DIRAVR = c:/winavr |
DIRAVRBIN = $(DIRAVR)/bin |
DIRAVRUTILS = $(DIRAVR)/utils/bin |
DIRINC = . |
DIRLIB = $(DIRAVR)/avr/lib |
# Define programs and commands. |
SHELL = sh |
CC = avr-gcc |
OBJCOPY = avr-objcopy |
OBJDUMP = avr-objdump |
SIZE = avr-size |
# Programming support using avrdude. |
AVRDUDE = avrdude |
REMOVE = rm -f |
COPY = cp |
HEXSIZE = $(SIZE) --target=$(FORMAT) $(TARGET).hex |
ELFSIZE = $(SIZE) -x -A $(TARGET).elf |
LIMITS = $(SIZE) --mcu=$(MCU) -C $(TARGET).elf |
# Define Messages |
# English |
MSG_ERRORS_NONE = Errors: none |
MSG_BEGIN = -------- begin -------- |
MSG_END = -------- end -------- |
MSG_SIZE_BEFORE = Size before: |
MSG_SIZE_AFTER = Size after: |
MSG_COFF = Converting to AVR COFF: |
MSG_EXTENDED_COFF = Converting to AVR Extended COFF: |
MSG_FLASH = Creating load file for Flash: |
MSG_EEPROM = Creating load file for EEPROM: |
MSG_EXTENDED_LISTING = Creating Extended Listing: |
MSG_SYMBOL_TABLE = Creating Symbol Table: |
MSG_LINKING = Linking: |
MSG_COMPILING = Compiling: |
MSG_ASSEMBLING = Assembling: |
MSG_CLEANING = Cleaning project: |
# Define all object files. |
OBJ = $(SRC:.c=.o) $(ASRC:.S=.o) |
# Define all listing files. |
LST = $(ASRC:.S=.lst) $(SRC:.c=.lst) |
# Combine all necessary flags and optional flags. |
# Add target processor to flags. |
#ALL_CFLAGS = -mmcu=$(MCU) -DF_CPU=$(F_CPU) -I. $(CFLAGS) |
ALL_CFLAGS = -mmcu=$(MCU) -I. $(CFLAGS) |
ALL_ASFLAGS = -mmcu=$(MCU) -I. -x assembler-with-cpp $(ASFLAGS) |
# Default target. |
all: begin gccversion sizebefore $(TARGET).elf $(TARGET).hex sizeafter finished end |
# Eye candy. |
# AVR Studio 3.x does not check make's exit code but relies on |
# the following magic strings to be generated by the compile job. |
begin: |
@echo |
@echo $(MSG_BEGIN) |
finished: |
@echo $(MSG_ERRORS_NONE) |
end: |
@echo $(MSG_END) |
@echo |
# Display size of file. |
sizebefore: |
@if [ -f $(TARGET).elf ]; then echo Size before:; $(ELFSIZE); $(HEXSIZE); $(LIMITS); echo; fi |
sizeafter: |
@if [ -f $(TARGET).elf ]; then echo Size after:; $(ELFSIZE); $(HEXSIZE); $(LIMITS); echo; fi |
# Display compiler version information. |
gccversion : |
@$(CC) --version |
# Convert ELF to COFF for use in debugging / simulating in |
# AVR Studio or VMLAB. |
COFFCONVERT=$(OBJCOPY) --debugging \ |
--change-section-address .data-0x800000 \ |
--change-section-address .bss-0x800000 \ |
--change-section-address .noinit-0x800000 \ |
--change-section-address .eeprom-0x810000 |
coff: $(TARGET).elf |
@echo |
@echo $(MSG_COFF) $(TARGET).cof |
$(COFFCONVERT) -O coff-avr $< $(TARGET).cof |
extcoff: $(TARGET).elf |
@echo |
@echo $(MSG_EXTENDED_COFF) $(TARGET).cof |
$(COFFCONVERT) -O coff-ext-avr $< $(TARGET).cof |
# Program the device. |
program: $(TARGET).hex $(TARGET).eep |
$(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM) |
# Create final output files (.hex, .eep) from ELF output file. |
%.hex: %.elf |
@echo |
@echo $(MSG_FLASH) $@ |
$(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@ |
%.eep: %.elf |
@echo |
@echo $(MSG_EEPROM) $@ |
-$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \ |
--change-section-lma .eeprom=0 -O $(FORMAT) $< $@ |
# Create extended listing file from ELF output file. |
%.lss: %.elf |
@echo |
@echo $(MSG_EXTENDED_LISTING) $@ |
$(OBJDUMP) -h -S $< > $@ |
# Create a symbol table from ELF output file. |
%.sym: %.elf |
@echo |
@echo $(MSG_SYMBOL_TABLE) $@ |
avr-nm -n $< > $@ |
# Link: create ELF output file from object files. |
.SECONDARY : $(TARGET).elf |
.PRECIOUS : $(OBJ) |
%.elf: $(OBJ) |
@echo |
@echo $(MSG_LINKING) $@ |
$(CC) $(ALL_CFLAGS) $(OBJ) --output $@ $(LDFLAGS) |
# Compile: create object files from C source files. |
%.o : %.c |
@echo |
@echo $(MSG_COMPILING) $< |
$(CC) -c $(ALL_CFLAGS) $< -o $@ |
# Compile: create assembler files from C source files. |
%.s : %.c |
$(CC) -S $(ALL_CFLAGS) $< -o $@ |
# Assemble: create object files from assembler source files. |
%.o : %.S |
@echo |
@echo $(MSG_ASSEMBLING) $< |
$(CC) -c $(ALL_ASFLAGS) $< -o $@ |
# Target: clean project. |
clean: begin clean_list finished end |
clean_list : |
@echo |
@echo $(MSG_CLEANING) |
$(REMOVE) Flight-Ctrl_*.hex |
$(REMOVE) Flight-Ctrl_*.eep |
$(REMOVE) $(TARGET).obj |
$(REMOVE) $(TARGET).cof |
$(REMOVE) Flight-Ctrl_*.elf |
$(REMOVE) Flight-Ctrl_*.map |
$(REMOVE) $(TARGET).obj |
$(REMOVE) $(TARGET).a90 |
$(REMOVE) Flight-Ctrl_*.sym |
$(REMOVE) $(TARGET).lnk |
$(REMOVE) $(TARGET).lss |
$(REMOVE) $(OBJ) |
$(REMOVE) $(LST) |
$(REMOVE) $(SRC:.c=.s) |
$(REMOVE) $(SRC:.c=.d) |
$(REMOVE) $(SRC:.c=.o) |
# Automatically generate C source code dependencies. |
# (Code originally taken from the GNU make user manual and modified |
# (See README.txt Credits).) |
# |
# Note that this will work with sh (bash) and sed that is shipped with WinAVR |
# (see the SHELL variable defined above). |
# This may not work with other shells or other seds. |
# |
%.d: %.c |
set -e; $(CC) -MM $(ALL_CFLAGS) $< \ |
| sed 's,\(.*\)\.o[ :]*,\1.o \1.d : ,g' > $@; \ |
[ -s $@ ] || rm -f $@ |
# Remove the '-' if you want to see the dependency files generated. |
-include $(SRC:%.c=%.d) |
# Listing of phony targets. |
.PHONY : all begin finish end sizebefore sizeafter gccversion coff extcoff \ |
clean clean_list program |
/tags/V2.02b/menu.c |
---|
0,0 → 1,282 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "main.h" |
#include "eeprom.h" |
char DisplayBuff[80]; |
unsigned char DispPtr = 0; |
unsigned char MaxMenue = 17; |
unsigned char MenuePunkt = 0; |
unsigned char RemoteKeys = 0; |
#define KEY1 0x01 |
#define KEY2 0x02 |
#define KEY3 0x04 |
#define KEY4 0x08 |
#define KEY5 0x10 |
void LcdClear(void) |
{ |
unsigned char i; |
for(i=0;i<80;i++) DisplayBuff[i] = ' '; |
} |
void Menu_Putchar(char c) |
{ |
if(DispPtr < 80) DisplayBuff[DispPtr++] = c; |
} |
void Menu(void) |
{ |
unsigned char i; |
if(RemoteKeys & KEY1) { if(MenuePunkt) MenuePunkt--; else MenuePunkt = MaxMenue;} |
if(RemoteKeys & KEY2) { if(MenuePunkt == MaxMenue) MenuePunkt = 0; else MenuePunkt++;} |
if((RemoteKeys & KEY1) && (RemoteKeys & KEY2)) MenuePunkt = 0; |
LcdClear(); |
if(MenuePunkt < 10) {LCD_printfxy(17,0,"[%i]",MenuePunkt);} |
else {LCD_printfxy(16,0,"[%i]",MenuePunkt);}; |
switch(MenuePunkt) |
{ |
case 0: |
LCD_printfxy(0,0,"+ MikroKopter +"); |
LCD_printfxy(0,1,"HW:V%d.%d SW:%d.%02d%c ",PlatinenVersion/10,PlatinenVersion%10, VERSION_MAJOR, VERSION_MINOR, VERSION_PATCH +'a'); |
LCD_printfxy(0,2,"Setting:%d %s", ActiveParamSet,Mixer.Name); |
if(VersionInfo.HardwareError[1] & FC_ERROR1_MIXER) LCD_printfxy(0,3,"Mixer Error!") |
else |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(NC_ErrorCode) |
{ |
LCD_printfxy(0,3,"ERR%2d:",NC_ErrorCode); |
_printf_P(&Menu_Putchar, NC_ERROR_TEXT[NC_ErrorCode] , 0); |
} |
else |
#endif |
if(VersionInfo.HardwareError[0]) LCD_printfxy(0,3,"Hardware Error 1:%d !!",VersionInfo.HardwareError[0]) |
else |
if(MissingMotor) LCD_printfxy(0,3,"Missing BL-Ctrl:%d !!",MissingMotor) |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#else |
else |
if(NC_ErrorCode) |
{ |
LCD_printfxy(0,3,"! NC-ERR: %2d ! ",NC_ErrorCode); |
} |
#endif |
// if(VersionInfo.HardwareError[1]) LCD_printfxy(0,3,"Error 2:%d !!",VersionInfo.HardwareError[1]) |
else |
if(I2CTimeout < 6) LCD_printfxy(0,3,"I2C ERROR!!!") |
else |
if(Capacity.MinOfMaxPWM < 30) LCD_printfxy(0,3,"BL-Selftest Err:%2d",Capacity.MinOfMaxPWM) |
break; |
case 1: |
LCD_printfxy(0,0,"Height: %5i",(int)(HoehenWert/5)); |
LCD_printfxy(0,1,"Setpoint:%5i",(int)(SollHoehe/5)); |
LCD_printfxy(0,2,"Pressure:%5i",MessLuftdruck); |
LCD_printfxy(0,3,"Offset: %5i",OCR0A); |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(ACC_AltitudeControl) |
{ |
LCD_printfxy(17,2,"(A)"); |
LCD_printfxy(17,3,"%i",CalAthmospheare); |
} |
#endif |
break; |
case 2: |
LCD_printfxy(0,0,"act. bearing"); |
LCD_printfxy(0,1,"Nick: %5i",IntegralNick/1024); |
LCD_printfxy(0,2,"Roll: %5i",IntegralRoll/1024); |
LCD_printfxy(0,3,"Compass: %5i",ErsatzKompassInGrad); |
break; |
case 3: |
for(i=1;i<9;i+=2) LCD_printfxy(0,i/2,"K%i:%4i K%i:%4i ",i,PPM_in[i],i+1,PPM_in[i+1]); |
break; |
case 4: |
LCD_printfxy(0,0,"Ni:%4i Ro:%4i ",PPM_in[EE_Parameter.Kanalbelegung[K_NICK]],PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]); |
LCD_printfxy(0,1,"Gs:%4i Gi:%4i ",PPM_in[EE_Parameter.Kanalbelegung[K_GAS]]+127,PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]); |
LCD_printfxy(0,2,"P1:%4i P2:%4i ",PPM_in[EE_Parameter.Kanalbelegung[K_POTI1]]+127,PPM_in[EE_Parameter.Kanalbelegung[K_POTI2]]+127); |
LCD_printfxy(0,3,"P3:%4i P4:%4i ",PPM_in[EE_Parameter.Kanalbelegung[K_POTI3]]+127,PPM_in[EE_Parameter.Kanalbelegung[K_POTI4]]+127); |
break; |
case 5: |
LCD_printfxy(0,0,"Gyro - Sensor"); |
LCD_printfxy(0,1,"Nick %4i (%3i.%x)",AdWertNick - AdNeutralNick/8, AdNeutralNick/16, (AdNeutralNick%16)/2); |
LCD_printfxy(0,2,"Roll %4i (%3i.%x)",AdWertRoll - AdNeutralRoll/8, AdNeutralRoll/16, (AdNeutralRoll%16)/2); |
LCD_printfxy(0,3,"Yaw %4i (%3i)",AdNeutralGier - AdWertGier, AdNeutralGier/2); |
/* |
// entfernt aus Platzmangel |
if(PlatinenVersion == 10) |
{ |
LCD_printfxy(0,1,"Nick%4i (%3i.%i)",AdWertNick - AdNeutralNick/8, AdNeutralNick/8, AdNeutralNick%8); |
LCD_printfxy(0,2,"Roll%4i (%3i.%i)",AdWertRoll - AdNeutralRoll/8, AdNeutralRoll/8, AdNeutralRoll%8); |
LCD_printfxy(0,3,"Gier%4i (%3i)",AdNeutralGier - AdWertGier, AdNeutralGier); |
} |
else |
if((PlatinenVersion == 11) || (PlatinenVersion >= 20)) |
{ |
LCD_printfxy(0,1,"Nick %4i (%3i.%x)",AdWertNick - AdNeutralNick/8, AdNeutralNick/16, (AdNeutralNick%16)/2); |
LCD_printfxy(0,2,"Roll %4i (%3i.%x)",AdWertRoll - AdNeutralRoll/8, AdNeutralRoll/16, (AdNeutralRoll%16)/2); |
LCD_printfxy(0,3,"Yaw %4i (%3i)",AdNeutralGier - AdWertGier, AdNeutralGier/2); |
} |
else |
if(PlatinenVersion == 13) |
{ |
LCD_printfxy(0,1,"Nick %4i (%3i)(%3i)",AdWertNick - AdNeutralNick/8, AdNeutralNick/16,AnalogOffsetNick); |
LCD_printfxy(0,2,"Roll %4i (%3i)(%3i)",AdWertRoll - AdNeutralRoll/8, AdNeutralRoll/16,AnalogOffsetRoll); |
LCD_printfxy(0,3,"Yaw %4i (%3i)(%3i)",AdNeutralGier - AdWertGier, AdNeutralGier/2,AnalogOffsetGier); |
} |
*/ |
break; |
case 6: |
LCD_printfxy(0,0,"ACC - Sensor"); |
LCD_printfxy(0,1,"Nick %4i (%3i)",AdWertAccNick,NeutralAccX); |
LCD_printfxy(0,2,"Roll %4i (%3i)",AdWertAccRoll,NeutralAccY); |
LCD_printfxy(0,3,"Z %4i (%3i)",AdWertAccHoch,(int)NeutralAccZ); |
break; |
case 7: |
LCD_printfxy(0,0,"Voltage: %3i.%1iV",UBat/10, UBat%10); |
LCD_printfxy(0,1,"Current: %3i.%1iA",Capacity.ActualCurrent/10, Capacity.ActualCurrent%10); |
LCD_printfxy(0,2,"Power: %4iW",Capacity.ActualPower); |
LCD_printfxy(0,3,"Discharge: %5imAh", Capacity.UsedCapacity); |
break; |
case 8: |
LCD_printfxy(0,0,"Receiver"); |
// LCD_printfxy(0,1,"RC-RSSI: %4i", PPM_in[0]); |
LCD_printfxy(0,2,"RC-Quality: %4i", SenderOkay); |
LCD_printfxy(0,3,"RC-Channels:%4i", Channels-1); |
break; |
case 9: |
LCD_printfxy(0,0,"Compass"); |
LCD_printfxy(0,1,"Magnet: %5i",KompassValue); |
LCD_printfxy(0,2,"Gyro: %5i",ErsatzKompassInGrad); |
LCD_printfxy(0,3,"Setpoint: %5i",KompassSollWert); |
break; |
case 10: |
for(i=0;i<4;i++) LCD_printfxy(0,i,"Poti%i: %3i",i+1,Poti[i]); |
break; |
case 11: |
for(i=0;i<4;i++) LCD_printfxy(0,i,"Poti%i: %3i",i+5,Poti[i+4]); |
break; |
case 12: |
//#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
LCD_printfxy(0,0,"Servo " ); |
LCD_printfxy(0,1,"Setpoint %3i",Parameter_ServoNickControl); |
LCD_printfxy(0,2,"Position: %3i",ServoNickValue/4); |
LCD_printfxy(0,3,"Range:%3i-%3i",EE_Parameter.ServoNickMin,EE_Parameter.ServoNickMax); |
break; |
/* case 13: |
LCD_printfxy(0,0,"ExternControl " ); |
LCD_printfxy(0,1,"Ni:%4i Ro:%4i ",ExternControl.Nick,ExternControl.Roll); |
LCD_printfxy(0,2,"Gs:%4i Gi:%4i ",ExternControl.Gas,ExternControl.Gier); |
LCD_printfxy(0,3,"Hi:%4i Cf:%4i ",ExternControl.Hight,ExternControl.Config); |
break; |
*/ |
//#endif |
case 13: |
LCD_printfxy(0,0,"BL-Ctrl Errors " ); |
for(i=0;i<3;i++) |
{ |
LCD_printfxy(0,i+1,"%3d %3d %3d %3d ",Motor[i*4].State & MOTOR_STATE_ERROR_MASK,Motor[i*4+1].State & MOTOR_STATE_ERROR_MASK,Motor[i*4+2].State & MOTOR_STATE_ERROR_MASK,Motor[i*4+3].State & MOTOR_STATE_ERROR_MASK); |
// if(i*4 >= RequiredMotors) break; |
} |
break; |
case 14: |
LCD_printfxy(0,0,"BL Temperature" ); |
for(i=0;i<3;i++) |
{ |
LCD_printfxy(0,i+1,"%3d %3d %3d %3d ",Motor[i*4].Temperature,Motor[i*4+1].Temperature,Motor[i*4+2].Temperature,Motor[i*4+3].Temperature); |
// if(4 + i * 4 >= RequiredMotors) break; |
} |
break; |
//#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
case 15: |
LCD_printfxy(0,0,"BL Current" ); |
LCD_printfxy(11,3,"(in 0.1A)" ); |
for(i=0;i<3;i++) |
{ |
// LCD_printfxy(0,i+1,"%3d %3d %3d %3d ",Motor[i*4].Current,Motor[i*4+1].Current,Motor[i*4+2].Current,Motor[i*4+3].Current); |
LCD_printfxy(0,i+1,"%3d %3d %3d %3d ",BL3_Current(i*4),BL3_Current(i*4+1),BL3_Current(i*4+2),BL3_Current(i*4+3)); |
// LCD_printfxy(0,i+1,"%3d %3d %3d %3d ",Motor[i*4].MaxPWM,Motor[i*4+1].MaxPWM,Motor[i*4+2].MaxPWM,Motor[i*4+3].MaxPWM); |
if(4 + i * 4 >= RequiredMotors) break; |
} |
break; |
//#endif |
case 16: |
LCD_printfxy(0,0,"BL-Ctrl found " ); |
LCD_printfxy(0,1," %c %c %c %c ",'-' + 4 * (Motor[0].State>>7),'-' + 5 * (Motor[1].State>>7),'-' + 6 * (Motor[2].State>>7),'-' + 7 * (Motor[3].State>>7)); |
LCD_printfxy(0,2," %c %c %c %c ",'-' + 8 * (Motor[4].State>>7),'-' + 9 * (Motor[5].State>>7),'-' + 10 * (Motor[6].State>>7),'-' + 11 * (Motor[7].State>>7)); |
LCD_printfxy(0,3," %c - - - ",'-' + 12 * (Motor[8].State>>7)); |
if(Motor[9].State>>7) LCD_printfxy(4,3,"10"); |
if(Motor[10].State>>7) LCD_printfxy(8,3,"11"); |
if(Motor[11].State>>7) LCD_printfxy(12,3,"12"); |
break; |
case 17: |
LCD_printfxy(0,0,"Flight-Time " ); |
LCD_printfxy(0,1,"Total:%5umin",FlugMinutenGesamt); |
LCD_printfxy(0,2,"Act: %5umin",FlugMinuten); |
LCD_printfxy(13,3,"(reset)"); |
if(RemoteKeys & KEY4) |
{ |
FlugMinuten = 0; |
SetParamWord(PID_FLIGHT_MINUTES, FlugMinuten); |
} |
break; |
default: |
if(MenuePunkt == MaxMenue) MaxMenue--; |
MenuePunkt = 0; |
break; |
} |
RemoteKeys = 0; |
} |
/tags/V2.02b/menu.h |
---|
0,0 → 1,17 |
#ifndef _MENU_H |
#define _MENU_H |
extern void Menu(void); |
extern void LcdClear(void); |
extern void Menu_Putchar(char c); |
extern char DisplayBuff[80]; |
extern unsigned char DispPtr; |
extern unsigned char MaxMenue; |
extern unsigned char MenuePunkt; |
extern unsigned char RemoteKeys; |
#define LCD_printfxy(x,y,format, args...) { DispPtr = (y) * 20 + (x); _printf_P(&Menu_Putchar,PSTR(format) , ## args);} |
#define LCD_printf(format, args...) { _printf_P(&Menu_Putchar, PSTR(format) , ## args);} |
#endif //_MENU_H |
/tags/V2.02b/mymath.c |
---|
0,0 → 1,41 |
#include <stdlib.h> |
#include <avr/pgmspace.h> |
#include "mymath.h" |
// discrete mathematics |
// Sinus with argument in degree at an angular resolution of 1 degree and a discretisation of 13 bit. |
const uint16_t pgm_sinlookup[91] PROGMEM = {0, 143, 286, 429, 571, 714, 856, 998, 1140, 1282, 1423, 1563, 1703, 1843, 1982, 2120, 2258, 2395, 2531, 2667, 2802, 2936, 3069, 3201, 3332, 3462, 3591, 3719, 3846, 3972, 4096, 4219, 4341, 4462, 4581, 4699, 4815, 4930, 5043, 5155, 5266, 5374, 5482, 5587, 5691, 5793, 5893, 5991, 6088, 6183, 6275, 6366, 6455, 6542, 6627, 6710, 6791, 6870, 6947, 7022, 7094, 7165, 7233, 7299, 7363, 7424, 7484, 7541, 7595, 7648, 7698, 7746, 7791, 7834, 7875, 7913, 7949, 7982, 8013, 8041, 8068, 8091, 8112, 8131, 8147, 8161, 8172, 8181, 8187, 8191, 8192}; |
int16_t c_sin_8192(int16_t angle) |
{ |
int8_t m,n; |
int16_t sinus; |
// avoid negative angles |
if (angle < 0) |
{ |
m = -1; |
angle = abs(angle); |
} |
else m = +1; |
// fold angle to intervall 0 to 359 |
angle %= 360; |
// check quadrant |
if (angle <= 90) n=1; // first quadrant |
else if ((angle > 90) && (angle <= 180)) {angle = 180 - angle; n = 1;} // second quadrant |
else if ((angle > 180) && (angle <= 270)) {angle = angle - 180; n = -1;} // third quadrant |
else {angle = 360 - angle; n = -1;} //fourth quadrant |
// get lookup value |
sinus = pgm_read_word(&pgm_sinlookup[angle]); |
// calculate sinus value |
return (sinus * m * n); |
} |
// Cosinus with argument in degree at an angular resolution of 1 degree and a discretisation of 13 bit. |
int16_t c_cos_8192(int16_t angle) |
{ |
return (c_sin_8192(90 - angle)); |
} |
/tags/V2.02b/mymath.h |
---|
0,0 → 1,10 |
#ifndef _MYMATH_H |
#define _MYMATH_H |
#include <inttypes.h> |
extern int16_t c_sin_8192(int16_t angle); |
extern int16_t c_cos_8192(int16_t angle); |
extern int16_t c_atan2(int16_t y, int16_t x); |
extern uint32_t c_sqrt(uint32_t a); |
#endif // _MYMATH_H |
/tags/V2.02b/old_macros.h |
---|
0,0 → 1,47 |
/* |
For backwards compatibility only. |
Ingo Busker ingo@mikrocontroller.com |
*/ |
#ifndef cbi |
#define cbi(sfr, bit) (_SFR_BYTE(sfr) &= ~_BV(bit)) |
#endif |
#ifndef sbi |
#define sbi(sfr, bit) (_SFR_BYTE(sfr) |= _BV(bit)) |
#endif |
#ifndef inb |
#define inb(sfr) _SFR_BYTE(sfr) |
#endif |
#ifndef outb |
#define outb(sfr, val) (_SFR_BYTE(sfr) = (val)) |
#endif |
#ifndef inw |
#define inw(sfr) _SFR_WORD(sfr) |
#endif |
#ifndef outw |
#define outw(sfr, val) (_SFR_WORD(sfr) = (val)) |
#endif |
#ifndef outp |
#define outp(val, sfr) outb(sfr, val) |
#endif |
#ifndef inp |
#define inp(sfr) inb(sfr) |
#endif |
#ifndef BV |
#define BV(bit) _BV(bit) |
#endif |
#ifndef PRG_RDB |
#define PRG_RDB pgm_read_byte |
#endif |
/tags/V2.02b/printf_P.h |
---|
0,0 → 1,69 |
// Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist nicht von der Lizenz für den MikroKopter-Teil unterstellt |
/* |
Copyright (C) 1993 Free Software Foundation |
This file is part of the GNU IO Library. This library is free |
software; you can redistribute it and/or modify it under the |
terms of the GNU General Public License as published by the |
Free Software Foundation; either version 2, or (at your option) |
any later version. |
This library is distributed in the hope that it will be useful, |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
GNU General Public License for more details. |
You should have received a copy of the GNU General Public License |
along with this library; see the file COPYING. If not, write to the Free |
Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
As a special exception, if you link this library with files |
compiled with a GNU compiler to produce an executable, this does not cause |
the resulting executable to be covered by the GNU General Public License. |
This exception does not however invalidate any other reasons why |
the executable file might be covered by the GNU General Public License. */ |
/* |
* Copyright (c) 1990 Regents of the University of California. |
* All rights reserved. |
* |
* Redistribution and use in source and binary forms, with or without |
* modification, are permitted provided that the following conditions |
* are met: |
* 1. Redistributions of source code must retain the above copyright |
* notice, this list of conditions and the following disclaimer. |
* 2. Redistributions in binary form must reproduce the above copyright |
* notice, this list of conditions and the following disclaimer in the |
* documentation and/or other materials provided with the distribution. |
* 3. [rescinded 22 July 1999] |
* 4. Neither the name of the University nor the names of its contributors |
* may be used to endorse or promote products derived from this software |
* without specific prior written permission. |
* |
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND |
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE |
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS |
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
* SUCH DAMAGE. |
*/ |
/******************************************************************************/ |
#ifndef _PRINTF_P_H_ |
#define _PRINTF_P_H_ |
#include <avr/pgmspace.h> |
// function pointer to external callback function |
typedef void (*pVoidFnctChar) (char ); |
typedef void (*pVoidFnct_pVoidFnctChar_const_fmt) (pVoidFnctChar, char const *fmt0, ...); |
extern pVoidFnct_pVoidFnctChar_const_fmt _printf_P; |
#endif //_PRINTF_P_H_ |
/tags/V2.02b/rc.c |
---|
0,0 → 1,283 |
/*####################################################################################### |
Decodieren eines RC Summen Signals |
#######################################################################################*/ |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "rc.h" |
#include "main.h" |
// Achtung: ACT_S3D_SUMMENSIGNAL wird in der Main.h gesetzt |
#define MAX_RC_IN 16+12+3+4 // 16ch + 12ser + 3stages + 4 reserved |
volatile int PPM_in[MAX_RC_IN]; |
volatile int PPM_diff[MAX_RC_IN]; // das differnzierte Stick-Signal |
volatile char Channels,tmpChannels = 0; |
volatile unsigned char NewPpmData = 1; |
unsigned int PPM_Neutral = 466; |
//############################################################################ |
// Clear the values |
void rc_sum_init(void) |
//############################################################################ |
{ |
unsigned char i; |
for(i=0;i<MAX_RC_IN;i++) |
{ |
if(i < 5) PPM_in[i] = 0; else PPM_in[i] = -127; |
PPM_diff[i] = 0; |
} |
PPM_in[PPM_IN_MAX] = +127; |
PPM_in[PPM_IN_OFF] = -127; |
PPM_in[PPM_IN_MID] = 0; |
AdNeutralGier = 0; |
AdNeutralRoll = 0; |
AdNeutralNick = 0; |
return; |
} |
#ifndef ACT_S3D_SUMMENSIGNAL |
//############################################################################ |
// Interrupt function for the PPM-Input |
ISR(TIMER1_CAPT_vect) |
//############################################################################ |
{ |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(!(EE_Parameter.ExtraConfig & CFG_SENSITIVE_RC)) |
#endif |
{ |
static unsigned int AltICR=0; |
signed int signal = 0,tmp; |
static int index; |
signal = (unsigned int) ICR1 - AltICR; |
AltICR = ICR1; |
//Syncronisationspause? (3.52 ms < signal < 25.6 ms) |
if((signal > 1100) && (signal < 8000)) |
{ |
Channels = index; |
if(index >= 4) NewPpmData = 0; // Null bedeutet: Neue Daten |
index = 1; |
} |
else |
{ |
if(index < 13+4) |
{ |
if((signal > 250) && (signal < 687)) |
{ |
signal -= PPM_Neutral; |
// Stabiles Signal |
if(EE_Parameter.FailsafeChannel == 0 || PPM_in[EE_Parameter.FailsafeChannel] < 100) // forces Failsafe if the receiver doesn't have 'signal loss' on Failsafe |
{ |
if(abs(signal - PPM_in[index]) < 6) { if(SenderOkay < 200) SenderOkay += 10; else SenderOkay = 200;} |
} |
tmp = (3 * (PPM_in[index]) + signal) / 4; |
if(tmp > signal+1) tmp--; else |
if(tmp < signal-1) tmp++; |
if(SenderOkay >= 195) PPM_diff[index] = ((tmp - PPM_in[index]) / 3) * 3; |
else PPM_diff[index] = 0; |
PPM_in[index] = tmp; |
} |
index++; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#else |
if(PlatinenVersion < 20) |
{ |
if(index == 5) J3High; else J3Low; // Servosignal an J3 anlegen |
if(index == 6) J4High; else J4Low; // Servosignal an J4 anlegen |
if(index == 7) J5High; else J5Low; // Servosignal an J5 anlegen |
} |
#endif |
} |
} |
} |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
else |
{ |
static unsigned int AltICR=0; |
static int ppm_in[13+4]; |
static int ppm_diff[13+4]; |
static int old_ppm_in[13+4]; |
static int old_ppm_diff[13+4]; |
signed int signal = 0,tmp; |
static unsigned char index, okay_cnt = 0; |
signal = (unsigned int) ICR1 - AltICR; |
AltICR = ICR1; |
//Syncronisationspause? (3.52 ms < signal < 25.6 ms) |
if((signal > 1100) && (signal < 8000)) |
{ |
tmpChannels = index; |
if(tmpChannels >= 4 && Channels == tmpChannels) |
{ |
if(okay_cnt > 10) |
{ |
NewPpmData = 0; // Null bedeutet: Neue Daten |
for(index = 0; index < 13+4; index++) |
{ |
if(okay_cnt > 30) |
{ |
old_ppm_in[index] = PPM_in[index]; |
old_ppm_diff[index] = PPM_diff[index]; |
} |
PPM_in[index] = ppm_in[index]; |
PPM_diff[index] = ppm_diff[index]; |
} |
} |
if(okay_cnt < 255) okay_cnt++; |
} |
else |
{ |
if(okay_cnt > 100) okay_cnt = 10; else okay_cnt = 0; |
ROT_ON; |
} |
index = 1; |
if(!MotorenEin) Channels = tmpChannels; |
} |
else |
{ |
if(index < 13+4) |
{ |
if((signal > 250) && (signal < 687)) |
{ |
signal -= PPM_Neutral; |
// Stabiles Signal |
if((abs(signal - ppm_in[index]) < 6)) |
{ |
if(EE_Parameter.FailsafeChannel == 0 || PPM_in[EE_Parameter.FailsafeChannel] < 100) // forces Failsafe if the receiver doesn't have 'signal loss' on Failsafe |
{ |
if(okay_cnt > 25) SenderOkay += 10; |
else |
if(okay_cnt > 10) SenderOkay += 2; |
if(SenderOkay > 200) SenderOkay = 200; |
} |
} |
tmp = (3 * (ppm_in[index]) + signal) / 4; |
if(tmp > signal+1) tmp--; else |
if(tmp < signal-1) tmp++; |
if(SenderOkay >= 190) ppm_diff[index] = ((tmp - ppm_in[index]) / 3) * 3; |
else ppm_diff[index] = 0; |
ppm_in[index] = tmp; |
} |
else ROT_ON; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
#else |
if(PlatinenVersion < 20) |
{ |
if(index == 5) J3High; else J3Low; // Servosignal an J3 anlegen |
if(index == 6) J4High; else J4Low; // Servosignal an J4 anlegen |
if(index == 7) J5High; else J5Low; // Servosignal an J5 anlegen |
} |
#endif |
} |
if(index < 20) index++; |
else |
if(index == 20) |
{ |
unsigned char i; |
ROT_ON; |
index = 30; |
for(i=0;i<13+4;i++) // restore from older data |
{ |
PPM_in[i] = old_ppm_in[i]; |
PPM_diff[i] = 0; |
// okay_cnt /= 2; |
} |
} |
} |
} |
#endif |
} |
#else |
//############################################################################ |
// Interrupt function for the PPM-Input |
ISR(TIMER1_CAPT_vect) |
//############################################################################ |
{ |
static unsigned int AltICR=0; |
signed int signal = 0,tmp; |
static int index; |
signal = (unsigned int) ICR1 - AltICR; |
signal /= 2; |
AltICR = ICR1; |
//Syncronisationspause? |
if((signal > 1100*2) && (signal < 8000*2)) |
{ |
if(index >= 4) NewPpmData = 0; // Null bedeutet: Neue Daten |
index = 1; |
} |
else |
{ |
if(index < 13) |
{ |
if((signal > 250) && (signal < 687*2)) |
{ |
signal -= 962; |
// Stabiles Signal |
if(abs(signal - PPM_in[index]) < 6) { if(SenderOkay < 200) SenderOkay += 10;} |
tmp = (3 * (PPM_in[index]) + signal) / 4; |
if(tmp > signal+1) tmp--; else |
if(tmp < signal-1) tmp++; |
if(SenderOkay >= 195) PPM_diff[index] = ((tmp - PPM_in[index]) / 3) * 3; |
else PPM_diff[index] = 0; |
PPM_in[index] = tmp; |
} |
index++; |
} |
} |
} |
#endif |
/tags/V2.02b/rc.h |
---|
0,0 → 1,42 |
/*####################################################################################### |
Derkodieren eines RC Summen Signals |
#######################################################################################*/ |
#ifndef _RC_H |
#define _RC_H |
#if defined (__AVR_ATmega644__) |
#define TIMER_RELOAD_VALUE 250 |
#endif |
#if defined (__AVR_ATmega644P__) |
#define TIMER_RELOAD_VALUE 250 |
#endif |
#define MAX_RC_IN 16+12+3+4 // 16ch + 12ser + 3stages + 4 reserved |
extern void rc_sum_init (void); |
extern volatile int PPM_in[MAX_RC_IN]; |
extern volatile int PPM_diff[MAX_RC_IN]; // das diffenzierte Stick-Signal |
extern volatile unsigned char NewPpmData; |
extern volatile char Channels,tmpChannels; |
extern unsigned int PPM_Neutral; |
// 0 -> frei bzw. ACT rssi |
// 1 - 16 -> 1-16 |
// 17 - 28 -> 12 Serial channels |
// 29 -> WP-Event kanal |
// 30 -> -127 |
// 31 -> 0 |
// 32 -> 128 |
#define SERIAL_POTI_START 17 |
#define WP_EVENT_PPM_IN 29 |
#define PPM_IN_OFF 30 |
#define PPM_IN_MAX 31 |
#define PPM_IN_MID 32 |
#define FromNC_WP_EventChannel PPM_in[WP_EVENT_PPM_IN] // WP_EVENT-Channel-Value |
#endif //_RC_H |
/tags/V2.02b/sbus.c |
---|
0,0 → 1,199 |
/*####################################################################################### |
Decodes the sbus protocol |
#######################################################################################*/ |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "sbus.h" |
#include "main.h" |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
unsigned char NewSBusData = 0, sBusBuffer[25]; |
//############################################################################ |
// USART1 initialisation from killagreg |
void SbusUartInit(void) |
//############################################################################ |
{ |
// -- Start of USART1 initialisation for Spekturm seriell-mode |
// USART1 Control and Status Register A, B, C and baud rate register |
uint8_t sreg = SREG; |
uint16_t ubrr = (uint16_t) ((uint32_t) SYSCLK/(8 * 100000) - 1); |
// disable all interrupts before reconfiguration |
cli(); |
// disable RX-Interrupt |
UCSR1B &= ~(1 << RXCIE1); |
// disable TX-Interrupt |
UCSR1B &= ~(1 << TXCIE1); |
// disable DRE-Interrupt |
UCSR1B &= ~(1 << UDRIE1); |
/* |
// set direction of RXD1 and TXD1 pins |
// set RXD1 (PD2) as an input pin |
PORTD |= (1 << PORTD2); |
DDRD &= ~(1 << DDD2); |
// set TXD1 (PD3) as an output pin |
PORTD |= (1 << PORTD3); |
DDRD |= (1 << DDD3); |
*/ |
// USART0 Baud Rate Register |
// set clock divider |
UBRR1H = (uint8_t)(ubrr>>8); |
UBRR1L = (uint8_t)ubrr; |
// enable double speed operation |
UCSR1A |= (1 << U2X1); |
// enable receiver and transmitter |
//UCSR1B = (1<<RXEN1)|(1<<TXEN1); |
UCSR1B = (1<<RXEN1); |
// set asynchronous mode |
UCSR1C &= ~(1 << UMSEL11); |
UCSR1C &= ~(1 << UMSEL10); |
// parity |
UCSR1C <= (1 << UPM11); // even |
UCSR1C &= ~(1 << UPM10); |
// stop bit |
UCSR1C |= (1 << USBS1); // two |
// 8-bit |
UCSR1B &= ~(1 << UCSZ12); |
UCSR1C |= (1 << UCSZ11); |
UCSR1C |= (1 << UCSZ10); |
// flush receive buffer explicit |
while(UCSR1A & (1<<RXC1)) UDR1; |
// enable RX-interrupts at the end |
UCSR1B |= (1 << RXCIE1); |
// -- End of USART1 initialisation |
// restore global interrupt flags |
sBusBuffer[23] |= 4; // This Bit contains the 'Signal loss' |
SREG = sreg; |
return; |
} |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#define MIN_FRAMEGAP 68 // 7ms |
#define MAX_BYTEGAP 3 // 310us |
//############################################################################ |
// Is called by the uart RX interrupt |
//############################################################################ |
void SbusParser(unsigned char udr) |
{ |
static unsigned char ptr = 0; |
if(!SpektrumTimer && udr == 0x0f) // wait for the start |
{ |
ptr = 0; |
SpektrumTimer = 80; // 8ms gap |
} |
else |
{ |
if(++ptr == 24) // last byte |
{ |
NewSBusData = 1; |
} |
else |
if(ptr > 24) ptr = 25; |
else |
{ |
sBusBuffer[ptr] = udr; // collect all bytes |
} |
} |
} |
void ProcessSBus(void) |
{ |
static unsigned char load = 0; |
unsigned char bitmask8 = 1, sbyte = 2, i, index = 1, process; |
unsigned int bitmask11 = 256; |
signed int signal = 0,tmp; |
if(!(sBusBuffer[23] & 4)) // This Bit contains the 'Signal loss' |
{ |
TIMSK1 &= ~_BV(ICIE1); // disable PPM-Input |
if(EE_Parameter.FailsafeChannel == 0 || PPM_in[EE_Parameter.FailsafeChannel] < 100) // forces Failsafe if the receiver doesn't have 'signal loss' on Failsafe |
{ |
if(SenderOkay < 200) SenderOkay += 20; else SenderOkay = 200; |
} |
signal = sBusBuffer[1]; |
if(!load--) { process = (12*11 - 8); load = 2;} else process = (4*11 - 8); // lowers the processor load |
for(i = 0; i < process; i++) // collect the single bits |
{ |
if(sBusBuffer[sbyte] & bitmask8) signal |= bitmask11; |
bitmask8 *= 2; |
if(!bitmask8) |
{ |
bitmask8 = 1; |
sbyte++; |
} |
bitmask11 *= 2; |
if(bitmask11 == 2048) |
{ |
bitmask11 = 1; |
signal = (signal-1024) / 5; // the resolution is higher than required |
tmp = (3 * (PPM_in[index]) + signal) / 4; |
if(tmp > signal+1) tmp--; else |
if(tmp < signal-1) tmp++; |
if(SenderOkay >= 195) PPM_diff[index] = ((tmp - PPM_in[index]) / 3) * 3; |
else PPM_diff[index] = 0; |
PPM_in[index] = tmp; |
signal = 0; |
index++; // next channel |
} |
} |
NewPpmData = 0; // Null bedeutet: Neue Daten |
} |
NewSBusData = 0; |
} |
#endif |
/tags/V2.02b/sbus.h |
---|
0,0 → 1,11 |
#ifndef _SBUS_H |
#define _SBUS_H |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
extern unsigned char NewSBusData, sBusBuffer[25]; |
extern void SbusParser(unsigned char); |
extern void SbusUartInit(void); |
extern void ProcessSBus(void); |
#endif |
#endif |
/tags/V2.02b/spi.c |
---|
0,0 → 1,403 |
// ######################## SPI - FlightCtrl ################### |
#include "main.h" |
#include "eeprom.h" |
//struct str_ToNaviCtrl_Version ToNaviCtrl_Version; |
//struct str_FromNaviCtrl_Version FromNaviCtrl_Version; |
struct str_ToNaviCtrl ToNaviCtrl; |
struct str_FromNaviCtrl FromNaviCtrl; |
struct str_FromNaviCtrl_Value FromNaviCtrl_Value; |
struct str_SPI_VersionInfo NC_Version; |
struct str_GPSInfo GPSInfo; |
unsigned char SPI_BufferIndex; |
unsigned char SPI_RxBufferIndex; |
signed char FromNC_Rotate_C = 32, FromNC_Rotate_S = 0; |
volatile unsigned char SPI_Buffer[sizeof(FromNaviCtrl)]; |
unsigned char *SPI_TX_Buffer; |
unsigned char SPITransferCompleted, SPI_ChkSum; |
unsigned char SPI_RxDataValid,NaviDataOkay = 250; |
unsigned char SPI_CommandSequence[] = { SPI_FCCMD_STICK, SPI_FCCMD_USER, SPI_FCCMD_PARAMETER1, |
SPI_FCCMD_STICK, SPI_FCCMD_VERSION, SPI_FCCMD_BL_ACCU, |
SPI_FCCMD_STICK, SPI_FCCMD_USER, SPI_FCCMD_MISC,SPI_FCCMD_SERVOS, |
SPI_FCCMD_STICK, SPI_FCCMD_PARAMETER2, SPI_FCCMD_BL_ACCU |
}; |
unsigned char SPI_CommandCounter = 0; |
unsigned char NC_ErrorCode = 0; |
unsigned char NC_GPS_ModeCharacter = ' '; |
unsigned char EarthMagneticField = 0; |
unsigned char EarthMagneticInclination = 0, EarthMagneticInclinationTheoretic = 0; |
unsigned char NC_To_FC_Flags = 0; |
unsigned char NC_To_FC_MaxAltitude = 0; // this is a Parameter on the SD-card |
signed int POI_KameraNick = 0; // in 0,1° |
vector16_t MagVec = {0,0,0}; |
#ifdef USE_SPI_COMMUNICATION |
//------------------------------------------------------ |
void SPI_MasterInit(void) |
{ |
DDR_SPI |= (1<<DD_MOSI)|(1<<DD_SCK); // Set MOSI and SCK output, all others input |
SLAVE_SELECT_DDR_PORT |= (1 << SPI_SLAVE_SELECT); |
SPCR = (1<<SPE)|(1<<MSTR)|(1<<SPR1)|(0<<SPR0)|(0<<SPIE); // Enable SPI, Master, set clock rate fck/64 |
SPSR = 0;//(1<<SPI2X); |
SLAVE_SELECT_PORT |= (1 << SPI_SLAVE_SELECT); |
SPITransferCompleted = 1; |
//SPDR = 0x00; // dummy write |
ToNaviCtrl.Sync1 = 0xAA; |
ToNaviCtrl.Sync2 = 0x83; |
ToNaviCtrl.Command = SPI_FCCMD_USER; |
ToNaviCtrl.IntegralNick = 0; |
ToNaviCtrl.IntegralRoll = 0; |
FromNaviCtrl_Value.SerialDataOkay = 0; |
SPI_RxDataValid = 0; |
} |
//------------------------------------------------------ |
unsigned char SPI_StartTransmitPacket(void) |
{ |
if(!SPITransferCompleted) return(0); |
SLAVE_SELECT_PORT &= ~(1 << SPI_SLAVE_SELECT); // SelectSlave |
SPI_TX_Buffer = (unsigned char *) &ToNaviCtrl; |
ToNaviCtrl.Command = SPI_CommandSequence[SPI_CommandCounter++]; |
if (SPI_CommandCounter >= sizeof(SPI_CommandSequence)) SPI_CommandCounter = 0; |
SPITransferCompleted = 0; |
UpdateSPI_Buffer(); // update buffer |
SPI_BufferIndex = 1; |
ToNaviCtrl.Chksum = ToNaviCtrl.Sync1; |
SPDR = ToNaviCtrl.Sync1; // Start transmission |
return(1); |
} |
//------------------------------------------------------ |
//SIGNAL(SIG_SPI) |
void SPI_TransmitByte(void) |
{ |
static unsigned char SPI_RXState = 0; |
unsigned char rxdata; |
static unsigned char rxchksum; |
if (SPITransferCompleted) return; |
if (!(SPSR & (1 << SPIF))) return; |
BytegapSPI = SPI_BYTEGAP; |
// _delay_us(30); |
SLAVE_SELECT_PORT |= (1 << SPI_SLAVE_SELECT); // DeselectSlave |
rxdata = SPDR; |
switch ( SPI_RXState) |
{ |
case 0: |
SPI_RxBufferIndex = 0; |
rxchksum = rxdata; |
if (rxdata == 0x81 ) { SPI_RXState = 1; } // 1. Syncbyte ok |
break; |
case 1: |
if (rxdata == 0x55) { rxchksum += rxdata; SPI_RXState = 2; } // 2. Syncbyte ok |
else SPI_RXState = 0; |
break; |
case 2: |
SPI_Buffer[SPI_RxBufferIndex++]= rxdata; // get data |
//DebugOut.Analog[19]++; |
if (SPI_RxBufferIndex >= sizeof(FromNaviCtrl)) |
{ |
if (rxdata == rxchksum) |
{ |
unsigned char *ptr = (unsigned char *)&FromNaviCtrl; |
memcpy(ptr, (unsigned char *) SPI_Buffer, sizeof(SPI_Buffer)); |
SPI_RxDataValid = 1; |
} |
else |
{ |
SPI_RxDataValid = 0; |
} |
SPI_RXState = 0; |
} |
else rxchksum += rxdata; |
break; |
} |
if (SPI_BufferIndex < sizeof(ToNaviCtrl)) |
{ |
SLAVE_SELECT_PORT &= ~(1 << SPI_SLAVE_SELECT); // SelectSlave |
asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); |
SPDR = SPI_TX_Buffer[SPI_BufferIndex]; |
ToNaviCtrl.Chksum += SPI_TX_Buffer[SPI_BufferIndex]; |
} |
else SPITransferCompleted = 1; |
SPI_BufferIndex++; |
} |
//------------------------------------------------------ |
void UpdateSPI_Buffer(void) |
{ |
signed int tmp; |
static unsigned char motorindex, oldcommand = SPI_NCCMD_VERSION; |
ToNaviCtrl.IntegralNick = (int) (IntegralNick / (long)(EE_Parameter.GyroAccFaktor * 4)); // etwa in 0.1 Grad |
ToNaviCtrl.IntegralRoll = (int) (IntegralRoll / (long)(EE_Parameter.GyroAccFaktor * 4)); // etwa in 0.1 Grad |
ToNaviCtrl.GyroCompass = (10 * ErsatzKompass) / GIER_GRAD_FAKTOR; |
ToNaviCtrl.GyroGier = (signed int) AdNeutralGier - AdWertGier; |
ToNaviCtrl.AccNick = ((int) ACC_AMPLIFY * (NaviAccNick / NaviCntAcc))/4; |
ToNaviCtrl.AccRoll = ((int) ACC_AMPLIFY * (NaviAccRoll / NaviCntAcc))/4; |
NaviCntAcc = 0; NaviAccNick = 0; NaviAccRoll = 0; |
// ToNaviCtrl.User8 = Parameter_UserParam8; |
// ToNaviCtrl.CalState = WinkelOut.CalcState; |
switch(ToNaviCtrl.Command) // |
{ |
case SPI_FCCMD_USER: |
ToNaviCtrl.Param.Byte[0] = Parameter_UserParam1; |
ToNaviCtrl.Param.Byte[1] = Parameter_UserParam2; |
ToNaviCtrl.Param.Byte[2] = Parameter_UserParam3; |
ToNaviCtrl.Param.Byte[3] = Parameter_UserParam4; |
ToNaviCtrl.Param.Byte[4] = Parameter_UserParam5; |
ToNaviCtrl.Param.Byte[5] = Parameter_UserParam6; |
ToNaviCtrl.Param.Byte[6] = Parameter_UserParam7; |
ToNaviCtrl.Param.Byte[7] = Parameter_UserParam8; |
ToNaviCtrl.Param.Byte[8] = FC_StatusFlags; |
//if(FC_StatusFlags2 & FC_STATUS2_WAIT_FOR_TAKEOFF) ToNaviCtrl.Param.Byte[8] &= ~FC_STATUS_FLY; |
FC_StatusFlags &= ~(FC_STATUS_CALIBRATE | FC_STATUS_START); |
ToNaviCtrl.Param.Byte[9] = ActiveParamSet; |
ToNaviCtrl.Param.Byte[10] = (unsigned char) UBat; // 0.1V |
ToNaviCtrl.Param.Byte[11] = FC_StatusFlags2; |
if(!(PORTC & (1<<PORTC2))) FC_StatusFlags2 &= ~FC_STATUS2_OUT1_ACTIVE; // Out1 (J16) |
break; |
case SPI_FCCMD_BL_ACCU: |
ToNaviCtrl.Param.Int[0] = Capacity.ActualCurrent; // 0.1A |
ToNaviCtrl.Param.Int[1] = Capacity.UsedCapacity; // mAh |
ToNaviCtrl.Param.Byte[4] = GetChannelValue(EE_Parameter.NaviGpsModeChannel); // GPS-Mode control |
ToNaviCtrl.Param.Byte[5] = VarioCharacter; |
ToNaviCtrl.Param.Byte[6] = motorindex; |
ToNaviCtrl.Param.Byte[7] = Motor[motorindex].Version; |
ToNaviCtrl.Param.Byte[8] = Motor[motorindex].MaxPWM; |
ToNaviCtrl.Param.Byte[9] = Motor[motorindex].State; |
ToNaviCtrl.Param.Byte[10] = Motor[motorindex].Temperature; |
ToNaviCtrl.Param.Byte[11] = Motor[motorindex].Current; |
if(Mixer.Motor[++motorindex][0] <= 0) // next motor is not used ? |
while(Mixer.Motor[motorindex][0] <= 0 && motorindex) motorindex = (motorindex + 1) % 13; |
break; |
case SPI_FCCMD_PARAMETER1: |
ToNaviCtrl.Param.Byte[0] = (unsigned char) BattLowVoltageWarning; //0.1V |
ToNaviCtrl.Param.Byte[1] = EE_Parameter.NaviGpsGain; // Parameters for the Naviboard |
ToNaviCtrl.Param.Byte[2] = EE_Parameter.NaviGpsP; |
ToNaviCtrl.Param.Byte[3] = EE_Parameter.NaviGpsI; |
ToNaviCtrl.Param.Byte[4] = EE_Parameter.NaviGpsD; |
ToNaviCtrl.Param.Byte[5] = EE_Parameter.NaviGpsA; |
ToNaviCtrl.Param.Byte[6] = EE_Parameter.NaviGpsMinSat; |
ToNaviCtrl.Param.Byte[7] = EE_Parameter.NaviStickThreshold; |
ToNaviCtrl.Param.Byte[8] = EE_Parameter.NaviOperatingRadius; |
ToNaviCtrl.Param.Byte[9] = EE_Parameter.NaviWindCorrection; |
ToNaviCtrl.Param.Byte[10] = EE_Parameter.NaviAccCompensation; |
ToNaviCtrl.Param.Byte[11] = EE_Parameter.NaviAngleLimitation; |
break; |
case SPI_FCCMD_PARAMETER2: |
ToNaviCtrl.Param.Byte[0] = EE_Parameter.NaviOut1Parameter; // Distance between Photo releases |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
// create the ToNC_SpeakHoTT |
if(EE_Parameter.Receiver != RECEIVER_HOTT) |
{ |
if(JetiBeep != 'B') JetiBeep = pgm_read_byte(&JETI_CODE[HoTT_Waring()]); |
else HoTT_Waring(); |
} |
ToNaviCtrl.Param.Byte[1] = ToNC_SpeakHoTT; |
#else |
ToNaviCtrl.Param.Byte[1] = 0; |
#endif |
ToNaviCtrl.Param.Byte[2] = EE_Parameter.LandingSpeed; |
ToNaviCtrl.Param.Byte[3] = EE_Parameter.ComingHomeAltitude; |
break; |
case SPI_FCCMD_STICK: |
cli(); |
tmp = PPM_in[EE_Parameter.Kanalbelegung[K_GAS]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127; |
ToNaviCtrl.Param.Byte[0] = (char) tmp; |
tmp = PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127; |
ToNaviCtrl.Param.Byte[1] = (char) tmp; |
tmp = PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127; |
ToNaviCtrl.Param.Byte[2] = (char) tmp; |
tmp = PPM_in[EE_Parameter.Kanalbelegung[K_NICK]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127; |
sei(); |
ToNaviCtrl.Param.Byte[3] = (char) tmp; |
ToNaviCtrl.Param.Byte[4] = (unsigned char) Poti[0]; |
ToNaviCtrl.Param.Byte[5] = (unsigned char) Poti[1]; |
ToNaviCtrl.Param.Byte[6] = (unsigned char) Poti[2]; |
ToNaviCtrl.Param.Byte[7] = (unsigned char) Poti[3]; |
ToNaviCtrl.Param.Byte[8] = (unsigned char) Poti[4]; |
ToNaviCtrl.Param.Byte[9] = (unsigned char) Poti[5]; |
ToNaviCtrl.Param.Byte[10] = (unsigned char) Poti[6]; |
ToNaviCtrl.Param.Byte[11] = (unsigned char) Poti[7]; |
break; |
case SPI_FCCMD_MISC: |
if(WinkelOut.CalcState > 5) |
{ |
WinkelOut.CalcState = 0; |
ToNaviCtrl.Param.Byte[0] = 5; |
} |
else ToNaviCtrl.Param.Byte[0] = WinkelOut.CalcState; |
ToNaviCtrl.Param.Byte[1] = EE_Parameter.NaviPH_LoginTime; |
ToNaviCtrl.Param.Int[1] = (int)(HoehenWert/5); |
ToNaviCtrl.Param.Int[2] = (int)(SollHoehe/5); |
ToNaviCtrl.Param.Byte[6] = EE_Parameter.NaviGpsPLimit; |
ToNaviCtrl.Param.Byte[7] = EE_Parameter.NaviGpsILimit; |
ToNaviCtrl.Param.Byte[8] = EE_Parameter.NaviGpsDLimit; |
ToNaviCtrl.Param.Byte[9] = (unsigned char) SenderOkay; |
// ToNaviCtrl.Param.Byte[10] = (unsigned char) PPM_in[0]; // ACT RSSI |
ToNaviCtrl.Param.Byte[10] = NC_Wait_for_LED; |
ToNaviCtrl.Param.Byte[11] = DebugOut.Analog[7] / 4; //GasMischanteil |
break; |
case SPI_FCCMD_VERSION: |
ToNaviCtrl.Param.Byte[0] = VERSION_MAJOR; |
ToNaviCtrl.Param.Byte[1] = VERSION_MINOR; |
ToNaviCtrl.Param.Byte[2] = VERSION_PATCH; |
ToNaviCtrl.Param.Byte[3] = NC_SPI_COMPATIBLE; |
ToNaviCtrl.Param.Byte[4] = PlatinenVersion; |
ToNaviCtrl.Param.Byte[5] = VersionInfo.HardwareError[0]; |
ToNaviCtrl.Param.Byte[6] = VersionInfo.HardwareError[1]; |
VersionInfo.HardwareError[0] &= ~FC_ERROR0_CAREFREE; // VersionInfo.HardwareError[0] = 0; |
VersionInfo.HardwareError[1] &= FC_ERROR1_MIXER; |
ToNaviCtrl.Param.Byte[7] = EE_Parameter.CompassOffset; |
ToNaviCtrl.Param.Byte[8] = Parameter_GlobalConfig; |
ToNaviCtrl.Param.Byte[9] = Parameter_ExtraConfig; |
ToNaviCtrl.Param.Byte[10] = EE_Parameter.OrientationAngle; |
ToNaviCtrl.Param.Byte[11] = EE_Parameter.GlobalConfig3; |
break; |
case SPI_FCCMD_SERVOS: |
ToNaviCtrl.Param.Byte[0] = EE_Parameter.ServoNickRefresh; // Parameters for the Servo Control |
ToNaviCtrl.Param.Byte[1] = EE_Parameter.ServoCompInvert; |
ToNaviCtrl.Param.Byte[2] = Parameter_ServoNickControl; |
ToNaviCtrl.Param.Byte[3] = EE_Parameter.ServoNickComp; |
ToNaviCtrl.Param.Byte[4] = EE_Parameter.ServoNickMin; |
ToNaviCtrl.Param.Byte[5] = EE_Parameter.ServoNickMax; |
ToNaviCtrl.Param.Byte[6] = Parameter_ServoRollControl; |
ToNaviCtrl.Param.Byte[7] = EE_Parameter.ServoRollComp; |
ToNaviCtrl.Param.Byte[8] = EE_Parameter.ServoRollMin; |
ToNaviCtrl.Param.Byte[9] = EE_Parameter.ServoRollMax; |
ToNaviCtrl.Param.Byte[10] = Capacity.MinOfMaxPWM; |
ToNaviCtrl.Param.Byte[11] = DebugOut.Analog[28]; // I2C-Error counter |
break; |
} |
if(SPI_RxDataValid) |
{ |
if(FromNaviCtrl.Command != oldcommand) NaviDataOkay = 250; |
oldcommand = FromNaviCtrl.Command; |
CalculateCompassTimer = 1; |
if(abs(FromNaviCtrl.GPS_Nick) < 512 && abs(FromNaviCtrl.GPS_Roll) < 512 && (EE_Parameter.GlobalConfig & CFG_GPS_AKTIV)) |
{ |
GPS_Nick = FromNaviCtrl.GPS_Nick; |
GPS_Roll = FromNaviCtrl.GPS_Roll; |
} |
// update compass readings |
// MagVec.x = FromNaviCtrl.MagVecX; |
// MagVec.y = FromNaviCtrl.MagVecY; |
// MagVec.z = FromNaviCtrl.MagVecZ; |
if(FromNaviCtrl.CompassValue <= 360) KompassValue = FromNaviCtrl.CompassValue; |
// KompassRichtung = ((540 + KompassValue - KompassSollWert) % 360) - 180; |
if(FromNaviCtrl.BeepTime > beeptime && !DisableRcOffBeeping) beeptime = FromNaviCtrl.BeepTime; |
switch (FromNaviCtrl.Command) |
{ |
case SPI_NCCMD_KALMAN: |
FromNaviCtrl_Value.Kalman_K = FromNaviCtrl.Param.sByte[0]; |
FromNaviCtrl_Value.Kalman_MaxFusion = FromNaviCtrl.Param.sByte[1]; |
FromNaviCtrl_Value.Kalman_MaxDrift = FromNaviCtrl.Param.sByte[2]; |
KompassFusion = FromNaviCtrl.Param.sByte[3]; |
FromNaviCtrl_Value.GpsZ = FromNaviCtrl.Param.Byte[4]; |
FromNC_Rotate_C = FromNaviCtrl.Param.Byte[5]; |
FromNC_Rotate_S = FromNaviCtrl.Param.Byte[6]; |
GPS_Aid_StickMultiplikator = FromNaviCtrl.Param.Byte[7]; |
if(CareFree && FromNaviCtrl.Param.sInt[4] >= 0) |
{ |
KompassSollWert = FromNaviCtrl.Param.sInt[4]; // bei Carefree kann NC den Kompass-Sollwinkel vorgeben |
if(EE_Parameter.CamOrientation) // Kamera angle is not front |
{ |
KompassSollWert += 360 - ((unsigned int) EE_Parameter.CamOrientation * 15); |
KompassSollWert %= 360; |
} |
} |
POI_KameraNick = (POI_KameraNick + FromNaviCtrl.Param.sInt[5]) / 2; // FromNaviCtrl.Param.sInt[5]; // Nickwinkel |
break; |
case SPI_NCCMD_VERSION: |
NC_Version.Major = FromNaviCtrl.Param.Byte[0]; |
NC_Version.Minor = FromNaviCtrl.Param.Byte[1]; |
NC_Version.Patch = FromNaviCtrl.Param.Byte[2]; |
NC_Version.Compatible = FromNaviCtrl.Param.Byte[3]; |
NC_Version.Hardware = FromNaviCtrl.Param.Byte[4]; |
DebugOut.Status[0] |= FromNaviCtrl.Param.Byte[5]; |
DebugOut.Status[1] = (DebugOut.Status[1] & (0x01|0x02)) | (FromNaviCtrl.Param.Byte[6] & (0x04 | 0x08)); |
NC_ErrorCode = FromNaviCtrl.Param.Byte[7]; |
NC_GPS_ModeCharacter = FromNaviCtrl.Param.Byte[8]; |
FromNaviCtrl_Value.SerialDataOkay = FromNaviCtrl.Param.Byte[9]; |
NC_To_FC_Flags = FromNaviCtrl.Param.Byte[10]; |
NC_To_FC_MaxAltitude = FromNaviCtrl.Param.Byte[11]; |
break; |
case SPI_NCCMD_GPSINFO: |
GPSInfo.Flags = FromNaviCtrl.Param.Byte[0]; |
GPSInfo.NumOfSats = FromNaviCtrl.Param.Byte[1]; |
GPSInfo.SatFix = FromNaviCtrl.Param.Byte[2]; |
GPSInfo.Speed = FromNaviCtrl.Param.Byte[3]; |
GPSInfo.HomeDistance = FromNaviCtrl.Param.Int[2]; |
GPSInfo.HomeBearing = FromNaviCtrl.Param.sInt[3]; |
PPM_in[WP_EVENT_PPM_IN] = (signed char) FromNaviCtrl.Param.Byte[8]; // WP_EVENT-Channel-Value (FromNC_WP_EventChannel) |
FromNC_AltitudeSpeed = FromNaviCtrl.Param.Byte[9]; |
FromNC_AltitudeSetpoint = (long) FromNaviCtrl.Param.sInt[5] * 10; // in cm |
break; |
case SPI_MISC: |
EarthMagneticField = FromNaviCtrl.Param.Byte[0]; |
EarthMagneticInclination = FromNaviCtrl.Param.Byte[1]; |
EarthMagneticInclinationTheoretic = FromNaviCtrl.Param.Byte[2]; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(FromNaviCtrl.Param.Byte[3]) |
if(!SpeakHoTT || (SpeakHoTT >= SPEAK_GPS_HOLD && SpeakHoTT <= SPEAK_GPS_OFF)) SpeakHoTT = FromNaviCtrl.Param.Byte[3]; |
NaviData_WaypointIndex = FromNaviCtrl.Param.Byte[4]; |
NaviData_WaypointNumber = FromNaviCtrl.Param.Byte[5]; |
NaviData_TargetDistance = FromNaviCtrl.Param.Int[3]; |
NaviData_TargetHoldTime = FromNaviCtrl.Param.Byte[8]; |
#endif |
break; |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
case SPI_NCCMD_HOTT_DATA: |
//if(EE_Parameter.Receiver == RECEIVER_HOTT) |
NC_Fills_HoTT_Telemety(); |
break; |
#endif |
// 0 = 0,1 |
// 1 = 2,3 |
// 2 = 4,5 |
// 3 = 6,7 |
// 4 = 8,9 |
// 5 = 10,11 |
default: |
break; |
} |
} |
else |
{ |
// KompassValue = 0; |
// KompassRichtung = 0; |
GPS_Nick = 0; |
GPS_Roll = 0; |
} |
} |
#endif |
/tags/V2.02b/spi.h |
---|
0,0 → 1,197 |
// ######################## SPI - FlightCtrl ################### |
#ifndef _SPI_H |
#define _SPI_H |
#include <util/delay.h> |
#include "vector.h" |
#define USE_SPI_COMMUNICATION |
#define SPI_BYTEGAP 3 |
//----------------------------------------- |
#define DDR_SPI DDRB |
#define SLAVE_SELECT_DDR_PORT DDRC |
#define SLAVE_SELECT_PORT PORTC |
#if defined(__AVR_ATmega1284P__) |
#define DD_SS PORTB4 |
#define DD_SCK PORTB7 |
#define DD_MOSI PORTB5 |
#define DD_MISO PORTB6 |
#define SPI_SLAVE_SELECT PORTC5 |
#else |
#define DD_SS PB4 |
#define DD_SCK PB7 |
#define DD_MOSI PB5 |
#define DD_MISO PB6 |
#define SPI_SLAVE_SELECT PC5 |
#endif |
// for compatibility reasons gcc3.x <-> gcc4.x |
#ifndef SPCR |
#define SPCR SPCR0 |
#endif |
#ifndef SPE |
#define SPE SPE0 |
#endif |
#ifndef MSTR |
#define MSTR MSTR0 |
#endif |
#ifndef SPR1 |
#define SPR1 SPR01 |
#endif |
#ifndef SPR0 |
#define SPR0 SPR00 |
#endif |
#ifndef SPIE |
#define SPIE SPIE0 |
#endif |
#ifndef SPDR |
#define SPDR SPDR0 |
#endif |
#ifndef SPIF |
#define SPIF SPIF0 |
#endif |
#ifndef SPSR |
#define SPSR SPSR0 |
#endif |
// ------------------------- |
#define SPI_FCCMD_USER 10 |
#define SPI_FCCMD_STICK 11 |
#define SPI_FCCMD_MISC 12 |
#define SPI_FCCMD_PARAMETER1 13 |
#define SPI_FCCMD_VERSION 14 |
#define SPI_FCCMD_SERVOS 15 |
#define SPI_FCCMD_BL_ACCU 16 |
#define SPI_FCCMD_PARAMETER2 17 |
struct str_ToNaviCtrl |
{ |
unsigned char Sync1, Sync2; |
unsigned char Command; |
signed int IntegralNick; |
signed int IntegralRoll; |
signed int AccNick; |
signed int AccRoll; |
signed int GyroCompass; |
signed int GyroNick; |
signed int GyroRoll; |
signed int GyroGier; |
unsigned int FCStatus; |
union |
{ |
unsigned char Byte[12]; |
char sByte[12]; |
unsigned int Int[6]; |
int sInt[6]; |
unsigned long Long[3]; |
long sLong[3]; |
float Float[3]; |
} Param; |
unsigned char Chksum; |
}; |
#define SPI_NCCMD_KALMAN 103 |
#define SPI_NCCMD_VERSION 104 |
#define SPI_NCCMD_GPSINFO 105 |
#define SPI_NCCMD_HOTT_DATA 106 |
#define SPI_MISC 107 |
struct str_FromNaviCtrl |
{ |
unsigned char Command; |
signed int GPS_Nick; |
signed int GPS_Roll; |
signed int MagVecX; |
signed int CompassValue; |
signed int AccErrorN; |
signed int AccErrorR; |
signed int MagVecY; |
signed int MagVecZ; |
unsigned int BeepTime; |
union |
{ |
unsigned char Byte[12]; |
char sByte[12]; |
unsigned int Int[6]; |
int sInt[6]; |
unsigned long Long[3]; |
long sLong[3]; |
float Float[3]; |
} Param; |
unsigned char Chksum; |
}; |
struct str_FromNaviCtrl_Value |
{ |
signed char Kalman_K; |
signed char Kalman_MaxDrift; |
signed char Kalman_MaxFusion; |
unsigned char SerialDataOkay; |
signed char GpsZ; |
}; |
struct str_SPI_VersionInfo |
{ |
unsigned char Major; |
unsigned char Minor; |
unsigned char Patch; |
unsigned char Compatible; |
unsigned char Hardware; |
}; |
// Satfix types for GPSData.SatFix |
#define SATFIX_NONE 0x00 |
#define SATFIX_DEADRECKOING 0x01 |
#define SATFIX_2D 0x02 |
#define SATFIX_3D 0x03 |
#define SATFIX_GPS_DEADRECKOING 0x04 |
#define SATFIX_TIMEONLY 0x05 |
// Flags for interpretation of the GPSData.Flags |
#define FLAG_GPSFIXOK 0x01 // (i.e. within DOP & ACC Masks) |
#define FLAG_DIFFSOLN 0x02 // (is DGPS used) |
#define FLAG_WKNSET 0x04 // (is Week Number valid) |
#define FLAG_TOWSET 0x08 // (is Time of Week valid) |
#define FLAG_GPS_NAVIGATION_ACTIVE 0x10 // NC to FC -> NC is ready to navigate |
struct str_GPSInfo |
{ |
unsigned char Flags; // Status Flags |
unsigned char NumOfSats; // number of satelites |
unsigned char SatFix; // type of satfix |
unsigned char Speed; // m/sek |
unsigned int HomeDistance; // distance to Home in dm |
int HomeBearing; // bearing to home in deg |
}; |
#ifdef USE_SPI_COMMUNICATION |
extern struct str_GPSInfo GPSInfo; |
extern struct str_SPI_VersionInfo NC_Version; |
extern struct str_FromNaviCtrl_Value FromNaviCtrl_Value; |
extern struct str_ToNaviCtrl ToNaviCtrl; |
extern struct str_FromNaviCtrl FromNaviCtrl; |
extern unsigned char SPI_CommandCounter,NaviDataOkay; |
extern signed char FromNC_Rotate_C, FromNC_Rotate_S; |
extern unsigned char NC_ErrorCode; |
extern void SPI_MasterInit(void); |
extern unsigned char SPI_StartTransmitPacket(void); |
extern void UpdateSPI_Buffer(void); |
extern void SPI_TransmitByte(void); |
extern signed int POI_KameraNick; |
extern unsigned char NC_GPS_ModeCharacter, NC_To_FC_Flags, NC_To_FC_MaxAltitude; |
extern vector16_t MagVec; |
extern unsigned char EarthMagneticField; |
extern unsigned char EarthMagneticInclination,EarthMagneticInclinationTheoretic; |
#else |
// -------------------------------- Dummy ----------------------------------------- |
#define SPI_MasterInit() ; |
//#define SPI_StartTransmitPacket() ; |
#define UpdateSPI_Buffer() ; |
#define SPI_TransmitByte() ; |
#endif |
#endif |
/tags/V2.02b/timer0.c |
---|
0,0 → 1,486 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include "main.h" |
#define MULTIPLYER 4 |
volatile unsigned int CountMilliseconds = 0; |
volatile unsigned int tim_main; |
volatile unsigned char UpdateMotor = 0; |
volatile unsigned int cntKompass = 0; |
volatile unsigned int beeptime = 0; |
volatile unsigned char BytegapSPI = 0, ServoActive = 0, CalculateServoSignals = 1; |
unsigned char JustMK3MagConnected = 0; |
uint16_t RemainingPulse = 0; |
volatile int16_t ServoNickOffset = (255 / 2) * MULTIPLYER * 16; // initial value near center positon |
volatile int16_t ServoRollOffset = (255 / 2) * MULTIPLYER * 16; // initial value near center positon |
unsigned int BeepMuster = 0xffff; |
signed int NickServoValue = 128 * MULTIPLYER * 16; |
volatile int16_t ServoNickValue = 0; |
volatile int16_t ServoRollValue = 0; |
enum { |
STOP = 0, |
CK = 1, |
CK8 = 2, |
CK64 = 3, |
CK256 = 4, |
CK1024 = 5, |
T0_FALLING_EDGE = 6, |
T0_RISING_EDGE = 7 |
}; |
ISR(TIMER0_OVF_vect) // 9,7kHz |
{ |
static unsigned char cnt_1ms = 1,cnt = 0; |
unsigned char pieper_ein = 0; |
if(BytegapSPI) BytegapSPI--; |
if(SpektrumTimer) SpektrumTimer--; |
if(!cnt--) |
{ |
cnt = 9; |
CountMilliseconds++; |
cnt_1ms++; |
cnt_1ms %= 2; |
if(!cnt_1ms) if(UpdateMotor < 4) UpdateMotor++; |
if(!(PINC & 0x10)) JustMK3MagConnected = 1; |
if(beeptime) |
{ |
if(beeptime > 10) beeptime -= 10; else beeptime = 0; |
if(beeptime & BeepMuster) |
{ |
pieper_ein = 1; |
} |
else pieper_ein = 0; |
} |
else |
{ |
pieper_ein = 0; |
BeepMuster = 0xffff; |
} |
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(pieper_ein) PORTC |= (1<<7); // Speaker an PORTC.7 |
else PORTC &= ~(1<<7); |
#else |
if(pieper_ein) |
{ |
if(PlatinenVersion == 10) PORTD |= (1<<2); // Speaker an PORTD.2 |
else PORTC |= (1<<7); // Speaker an PORTC.7 |
} |
else |
{ |
if(PlatinenVersion == 10) PORTD &= ~(1<<2); |
else PORTC &= ~(1<<7); |
} |
#endif |
} |
if(JustMK3MagConnected && !NaviDataOkay && Parameter_GlobalConfig & CFG_KOMPASS_AKTIV) |
{ |
if(PINC & 0x10) |
{ |
if(++cntKompass > 1000) JustMK3MagConnected = 0; |
} |
else |
{ |
if((cntKompass) && (cntKompass < 362)) |
{ |
cntKompass += cntKompass / 41; |
if(cntKompass > 10) KompassValue = cntKompass - 10; else KompassValue = 0; |
// KompassRichtung = ((540 + KompassValue - KompassSollWert) % 360) - 180; |
} |
cntKompass = 0; |
} |
} |
} |
// ----------------------------------------------------------------------- |
unsigned int SetDelay(unsigned int t) |
{ |
// TIMSK0 &= ~_BV(TOIE0); |
return(CountMilliseconds + t + 1); |
// TIMSK0 |= _BV(TOIE0); |
} |
// ----------------------------------------------------------------------- |
char CheckDelay(unsigned int t) |
{ |
// TIMSK0 &= ~_BV(TOIE0); |
return(((t - CountMilliseconds) & 0x8000) >> 9); |
// TIMSK0 |= _BV(TOIE0); |
} |
// ----------------------------------------------------------------------- |
void Delay_ms(unsigned int w) |
{ |
unsigned int akt; |
akt = SetDelay(w); |
while (!CheckDelay(akt)); |
} |
void Delay_ms_Mess(unsigned int w) |
{ |
unsigned int akt; |
akt = SetDelay(w); |
while (!CheckDelay(akt)) if(AdReady) {AdReady = 0; ANALOG_ON;} |
} |
/*****************************************************/ |
/* Initialize Timer 2 */ |
/*****************************************************/ |
// The timer 2 is used to generate the PWM at PD7 (J7) |
// to control a camera servo for nick compensation. |
void TIMER2_Init(void) |
{ |
uint8_t sreg = SREG; |
// disable all interrupts before reconfiguration |
cli(); |
PORTD &= ~(1<<PORTD7); // set PD7 to low |
DDRC |= (1<<DDC6); // set PC6 as output (Reset for HEF4017) |
HEF4017Reset_ON; |
// Timer/Counter 2 Control Register A |
// Timer Mode is FastPWM with timer reload at OCR2A (Bits: WGM22 = 1, WGM21 = 1, WGM20 = 1) |
// PD7: Normal port operation, OC2A disconnected, (Bits: COM2A1 = 0, COM2A0 = 0) |
// PD6: Normal port operation, OC2B disconnected, (Bits: COM2B1 = 0, COM2B0 = 0) |
TCCR2A &= ~((1<<COM2A1)|(1<<COM2A0)|(1<<COM2B1)|(1<<COM2B0)); |
TCCR2A |= (1<<WGM21)|(1<<WGM20); |
// Timer/Counter 2 Control Register B |
// Set clock divider for timer 2 to SYSKLOCK/32 = 20MHz / 32 = 625 kHz |
// The timer increments from 0x00 to 0xFF with an update rate of 625 kHz or 1.6 us |
// hence the timer overflow interrupt frequency is 625 kHz / 256 = 2.44 kHz or 0.4096 ms |
// divider 32 (Bits: CS022 = 0, CS21 = 1, CS20 = 1) |
TCCR2B &= ~((1<<FOC2A)|(1<<FOC2B)|(1<<CS22)); |
TCCR2B |= (1<<CS21)|(1<<CS20)|(1<<WGM22); |
// Initialize the Timer/Counter 2 Register |
TCNT2 = 0; |
// Initialize the Output Compare Register A used for PWM generation on port PD7. |
OCR2A = 255; |
TCCR2A |= (1<<COM2A1); // set or clear at compare match depends on value of COM2A0 |
// Timer/Counter 2 Interrupt Mask Register |
// Enable timer output compare match A Interrupt only |
TIMSK2 &= ~((1<<OCIE2B)|(1<<TOIE2)); |
TIMSK2 |= (1<<OCIE2A); |
SREG = sreg; |
} |
//---------------------------- |
void Timer_Init(void) |
{ |
tim_main = SetDelay(10); |
TCCR0B = CK8; |
// TCCR0A = (1<<COM0A1)|(1<<COM0B1)|3;//fast PWM |
TCCR0A = (1<<COM0A1)|(1<<COM0B1)|(1<<COM0B0)|3;//fast PWM |
OCR0B = 255; |
OCR0A = 180; |
TCNT0 = (unsigned char)-TIMER_RELOAD_VALUE; // reload |
//OCR1 = 0x00; |
TIMSK0 |= _BV(TOIE0); |
} |
/*****************************************************/ |
/* Control Servo Position */ |
/*****************************************************/ |
void CalcNickServoValue(void) |
{ |
signed int max, min; |
if(EE_Parameter.ServoCompInvert & SERVO_RELATIVE) // relative moving of the servo value |
{ |
max = ((unsigned int) EE_Parameter.ServoNickMax * MULTIPLYER * 15); |
min = ((unsigned int) EE_Parameter.ServoNickMin * MULTIPLYER * 20); |
NickServoValue -= ((signed char) (Parameter_ServoNickControl - 128) / 4) * 6; |
LIMIT_MIN_MAX(NickServoValue,min, max); |
} |
else NickServoValue = (int16_t)Parameter_ServoNickControl * (MULTIPLYER*16); // direct poti control |
} |
void CalculateServo(void) |
{ |
signed char cosinus, sinus; |
signed long nick, roll; |
cosinus = sintab[EE_Parameter.CamOrientation + 6]; |
sinus = sintab[EE_Parameter.CamOrientation]; |
if(CalculateServoSignals == 1) |
{ |
if(EE_Parameter.GlobalConfig3 & CFG3_SERVO_NICK_COMP_OFF) nick = 0; |
else nick = (cosinus * IntegralNick) / 128L - (sinus * IntegralRoll) / 128L; |
nick -= POI_KameraNick * 7; |
nick = ((long)Parameter_ServoNickComp * nick) / 512L; |
// offset (Range from 0 to 255 * 3 = 765) |
if(EE_Parameter.ServoCompInvert & SERVO_RELATIVE) ServoNickOffset = NickServoValue; |
else ServoNickOffset += (NickServoValue - ServoNickOffset) / EE_Parameter.ServoManualControlSpeed; |
if(EE_Parameter.ServoCompInvert & SERVO_NICK_INV) // inverting movement of servo |
{ |
nick = ServoNickOffset / 16 + nick; |
} |
else |
{ // inverting movement of servo |
nick = ServoNickOffset / 16 - nick; |
} |
if(EE_Parameter.ServoFilterNick) ServoNickValue = ((ServoNickValue * EE_Parameter.ServoFilterNick) + nick) / (EE_Parameter.ServoFilterNick + 1); |
else ServoNickValue = nick; |
// limit servo value to its parameter range definition |
if(ServoNickValue < ((int16_t)EE_Parameter.ServoNickMin * MULTIPLYER)) |
{ |
ServoNickValue = (int16_t)EE_Parameter.ServoNickMin * MULTIPLYER; |
} |
else |
if(ServoNickValue > ((int16_t)EE_Parameter.ServoNickMax * MULTIPLYER)) |
{ |
ServoNickValue = (int16_t)EE_Parameter.ServoNickMax * MULTIPLYER; |
} |
if(PlatinenVersion < 20) CalculateServoSignals = 0; else CalculateServoSignals++; |
} |
else |
{ |
roll = (cosinus * IntegralRoll) / 128L + (sinus * IntegralNick) / 128L; |
roll = ((long)Parameter_ServoRollComp * roll) / 512L; |
ServoRollOffset += ((int16_t)Parameter_ServoRollControl * (MULTIPLYER*16) - ServoRollOffset) / EE_Parameter.ServoManualControlSpeed; |
if(EE_Parameter.ServoCompInvert & SERVO_ROLL_INV) |
{ // inverting movement of servo |
roll = ServoRollOffset / 16 + roll; |
} |
else |
{ // inverting movement of servo |
roll = ServoRollOffset / 16 - roll; |
} |
if(EE_Parameter.ServoFilterRoll) ServoRollValue = ((ServoRollValue * EE_Parameter.ServoFilterRoll) + roll) / (EE_Parameter.ServoFilterRoll + 1); |
else ServoRollValue = roll; |
// limit servo value to its parameter range definition |
if(ServoRollValue < ((int16_t)EE_Parameter.ServoRollMin * MULTIPLYER)) |
{ |
ServoRollValue = (int16_t)EE_Parameter.ServoRollMin * MULTIPLYER; |
} |
else |
if(ServoRollValue > ((int16_t)EE_Parameter.ServoRollMax * MULTIPLYER)) |
{ |
ServoRollValue = (int16_t)EE_Parameter.ServoRollMax * MULTIPLYER; |
} |
CalculateServoSignals = 0; |
} |
} |
ISR(TIMER2_COMPA_vect) |
{ |
// frame len 22.5 ms = 14063 * 1.6 us |
// stop pulse: 0.3 ms = 188 * 1.6 us |
// min servo pulse: 0.6 ms = 375 * 1.6 us |
// max servo pulse: 2.4 ms = 1500 * 1.6 us |
// resolution: 1500 - 375 = 1125 steps |
#define IRS_RUNTIME 127 |
#define PPM_STOPPULSE 188 |
#define PPM_FRAMELEN (1757 * EE_Parameter.ServoNickRefresh) |
#define MINSERVOPULSE 375 |
#define MAXSERVOPULSE 1500 |
#define SERVORANGE (MAXSERVOPULSE - MINSERVOPULSE) |
static uint8_t PulseOutput = 0; |
static uint16_t ServoFrameTime = 0; |
static uint8_t ServoIndex = 0; |
if(PlatinenVersion < 20) |
{ |
//--------------------------- |
// Nick servo state machine |
//--------------------------- |
if(!PulseOutput) // pulse output complete |
{ |
if(TCCR2A & (1<<COM2A0)) // we had a low pulse |
{ |
TCCR2A &= ~(1<<COM2A0);// make a high pulse |
RemainingPulse = MINSERVOPULSE + SERVORANGE/2; // center position ~ 1.5ms |
RemainingPulse += ServoNickValue - (256 / 2) * MULTIPLYER; // shift ServoNickValue to center position |
// range servo pulse width |
if(RemainingPulse > MAXSERVOPULSE ) RemainingPulse = MAXSERVOPULSE; // upper servo pulse limit |
else if(RemainingPulse < MINSERVOPULSE ) RemainingPulse = MINSERVOPULSE; // lower servo pulse limit |
// accumulate time for correct update rate |
ServoFrameTime = RemainingPulse; |
} |
else // we had a high pulse |
{ |
TCCR2A |= (1<<COM2A0); // make a low pulse |
RemainingPulse = PPM_FRAMELEN - ServoFrameTime; |
CalculateServoSignals = 1; |
} |
// set pulse output active |
PulseOutput = 1; |
} |
} // EOF Nick servo state machine |
else |
{ |
//----------------------------------------------------- |
// PPM state machine, onboard demultiplexed by HEF4017 |
//----------------------------------------------------- |
if(!PulseOutput) // pulse output complete |
{ |
if(TCCR2A & (1<<COM2A0)) // we had a low pulse |
{ |
TCCR2A &= ~(1<<COM2A0);// make a high pulse |
if(ServoIndex == 0) // if we are at the sync gap |
{ |
RemainingPulse = PPM_FRAMELEN - ServoFrameTime; // generate sync gap by filling time to full frame time |
ServoFrameTime = 0; // reset servo frame time |
HEF4017Reset_ON; // enable HEF4017 reset |
} |
else // servo channels |
if(ServoIndex > EE_Parameter.ServoNickRefresh) |
{ |
RemainingPulse = 10; // end it here |
} |
else |
{ |
RemainingPulse = MINSERVOPULSE + SERVORANGE/2; // center position ~ 1.5ms |
switch(ServoIndex) // map servo channels |
{ |
case 1: // Nick Compensation Servo |
RemainingPulse += ServoNickValue - (256 / 2) * MULTIPLYER; // shift ServoNickValue to center position |
break; |
case 2: // Roll Compensation Servo |
RemainingPulse += ServoRollValue - (256 / 2) * MULTIPLYER; // shift ServoNickValue to center position |
break; |
case 3: |
RemainingPulse += ((int16_t)Parameter_Servo3 * MULTIPLYER) - (256 / 2) * MULTIPLYER; |
break; |
case 4: |
RemainingPulse += ((int16_t)Parameter_Servo4 * MULTIPLYER) - (256 / 2) * MULTIPLYER; |
break; |
case 5: |
RemainingPulse += ((int16_t)Parameter_Servo5 * MULTIPLYER) - (256 / 2) * MULTIPLYER; |
break; |
default: // other servo channels |
RemainingPulse += 2 * PPM_in[ServoIndex]; // add channel value, factor of 2 because timer 1 increments 3.2µs |
break; |
} |
// range servo pulse width |
if(RemainingPulse > MAXSERVOPULSE) RemainingPulse = MAXSERVOPULSE; // upper servo pulse limit |
else if(RemainingPulse < MINSERVOPULSE) RemainingPulse = MINSERVOPULSE; // lower servo pulse limit |
// substract stop pulse width |
RemainingPulse -= PPM_STOPPULSE; |
// accumulate time for correct sync gap |
ServoFrameTime += RemainingPulse; |
} |
} |
else // we had a high pulse |
{ |
TCCR2A |= (1<<COM2A0); // make a low pulse |
// set pulsewidth to stop pulse width |
RemainingPulse = PPM_STOPPULSE; |
// accumulate time for correct sync gap |
ServoFrameTime += RemainingPulse; |
if((ServoActive && SenderOkay) || ServoActive == 2) HEF4017Reset_OFF; // disable HEF4017 reset |
else HEF4017Reset_ON; |
ServoIndex++; |
if(ServoIndex > EE_Parameter.ServoNickRefresh+1) |
{ |
CalculateServoSignals = 1; |
ServoIndex = 0; // reset to the sync gap |
} |
} |
// set pulse output active |
PulseOutput = 1; |
} |
} // EOF PPM state machine |
// General pulse output generator |
if(RemainingPulse > (255 + IRS_RUNTIME)) |
{ |
OCR2A = 255; |
RemainingPulse -= 255; |
} |
else |
{ |
if(RemainingPulse > 255) // this is the 2nd last part |
{ |
if((RemainingPulse - 255) < IRS_RUNTIME) |
{ |
OCR2A = 255 - IRS_RUNTIME; |
RemainingPulse -= 255 - IRS_RUNTIME; |
} |
else // last part > ISR_RUNTIME |
{ |
OCR2A = 255; |
RemainingPulse -= 255; |
} |
} |
else // this is the last part |
{ |
OCR2A = RemainingPulse; |
RemainingPulse = 0; |
PulseOutput = 0; // trigger to stop pulse |
} |
} // EOF general pulse output generator |
} |
/tags/V2.02b/timer0.h |
---|
0,0 → 1,25 |
#define TIMER_TEILER CK8 |
#define TIMER_RELOAD_VALUE 250 |
#define HEF4017Reset_ON PORTC |= (1<<PORTC6) |
#define HEF4017Reset_OFF PORTC &= ~(1<<PORTC6) |
void Timer_Init(void); |
void TIMER2_Init(void); |
void Delay_ms(unsigned int); |
void Delay_ms_Mess(unsigned int); |
unsigned int SetDelay (unsigned int t); |
char CheckDelay (unsigned int t); |
void CalculateServo(void); |
void CalcNickServoValue(void); |
extern volatile unsigned int CountMilliseconds; |
extern volatile unsigned char UpdateMotor; |
extern volatile unsigned int beeptime; |
extern volatile unsigned int cntKompass; |
extern unsigned int BeepMuster; |
extern volatile unsigned char BytegapSPI, ServoActive, CalculateServoSignals; |
extern volatile int16_t ServoNickValue; |
extern volatile int16_t ServoRollValue; |
extern signed int NickServoValue; |
extern unsigned char JustMK3MagConnected; |
/tags/V2.02b/twimaster.c |
---|
0,0 → 1,477 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include <avr/io.h> |
#include <avr/interrupt.h> |
#include <util/twi.h> |
#include "eeprom.h" |
#include "twimaster.h" |
#include "fc.h" |
#include "analog.h" |
#include "uart.h" |
#include "timer0.h" |
volatile uint8_t twi_state = TWI_STATE_MOTOR_TX; |
volatile uint8_t dac_channel = 0; |
volatile uint8_t motor_write = 0; |
volatile uint8_t motor_read = 0; |
volatile uint8_t I2C_TransferActive = 0; |
volatile uint16_t I2CTimeout = 100; |
uint8_t MissingMotor = 0; |
volatile uint8_t BLFlags = 0; |
MotorData_t Motor[MAX_MOTORS]; |
// bit mask for witch BL the configuration should be sent |
volatile uint16_t BLConfig_WriteMask = 0; |
// bit mask for witch BL the configuration should be read |
volatile uint16_t BLConfig_ReadMask = 0; |
// buffer for BL Configuration |
BLConfig_t BLConfig; |
#define I2C_WriteByte(byte) {TWDR = byte; TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWIE);} |
#define I2C_ReceiveByte() {TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWIE) | (1<<TWEA);} |
#define I2C_ReceiveLastByte() {TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWIE);} |
#define SCL_CLOCK 200000L |
#define I2C_TIMEOUT 30000 |
#define TWI_BASE_ADDRESS 0x52 |
/**************************************************/ |
/* Initialize I2C (TWI) */ |
/**************************************************/ |
void I2C_Init(char clear) |
{ |
uint8_t i; |
uint8_t sreg = SREG; |
cli(); |
// SDA is INPUT |
DDRC &= ~(1<<DDC1); |
// SCL is output |
DDRC |= (1<<DDC0); |
// pull up SDA |
PORTC |= (1<<PORTC0)|(1<<PORTC1); |
// TWI Status Register |
// prescaler 1 (TWPS1 = 0, TWPS0 = 0) |
TWSR &= ~((1<<TWPS1)|(1<<TWPS0)); |
// set TWI Bit Rate Register |
TWBR = ((F_CPU/SCL_CLOCK)-16)/2; |
twi_state = TWI_STATE_MOTOR_TX; |
motor_write = 0; |
motor_read = 0; |
if(clear) for(i=0; i < MAX_MOTORS; i++) |
{ |
Motor[i].Version = 0; |
Motor[i].SetPoint = 0; |
Motor[i].SetPointLowerBits = 0; |
Motor[i].State = 0; |
Motor[i].ReadMode = BL_READMODE_STATUS; |
Motor[i].Current = 0; |
Motor[i].MaxPWM = 0; |
Motor[i].Temperature = 0; |
} |
sei(); |
SREG = sreg; |
} |
void I2C_Reset(void) |
{ |
// stop i2c bus |
I2C_Stop(TWI_STATE_MOTOR_TX); |
TWCR = (1<<TWINT); // reset to original state incl. interrupt flag reset |
TWAMR = 0; |
TWAR = 0; |
TWDR = 0; |
TWSR = 0; |
TWBR = 0; |
I2C_TransferActive = 0; |
I2C_Init(0); |
I2C_WriteByte(0); |
BLFlags |= BLFLAG_READ_VERSION; |
} |
/****************************************/ |
/* I2C ISR */ |
/****************************************/ |
ISR (TWI_vect) |
{ |
static uint8_t missing_motor = 0, motor_read_temperature = 0; |
static uint8_t *pBuff = 0; |
static uint8_t BuffLen = 0; |
switch (twi_state++) |
{ |
// Master Transmit |
case 0: // TWI_STATE_MOTOR_TX |
I2C_TransferActive = 1; |
// skip motor if not used in mixer |
while((Mixer.Motor[motor_write][MIX_GAS] <= 0) && (motor_write < MAX_MOTORS)) motor_write++; |
if(motor_write >= MAX_MOTORS) // writing finished, read now |
{ |
BLConfig_WriteMask = 0; // reset configuration bitmask |
motor_write = 0; // reset motor write counter for next cycle |
twi_state = TWI_STATE_MOTOR_RX; |
I2C_WriteByte(TWI_BASE_ADDRESS + TW_READ + (motor_read<<1) ); // select slave address in rx mode |
} |
else I2C_WriteByte(TWI_BASE_ADDRESS + TW_WRITE + (motor_write<<1) ); // select slave address in tx mode |
break; |
case 1: // Send Data to Slave |
I2C_WriteByte(Motor[motor_write].SetPoint); // transmit setpoint |
// if old version has been detected |
if(!(Motor[motor_write].Version & MOTOR_STATE_NEW_PROTOCOL_MASK)) |
{ |
twi_state = 4; //jump over sending more data |
} |
// the new version has been detected |
else if(!( (Motor[motor_write].SetPointLowerBits && (RequiredMotors < 7)) || BLConfig_WriteMask || BLConfig_ReadMask ) ) |
{ // or LowerBits are zero and no BlConfig should be sent (saves round trip time) |
twi_state = 4; //jump over sending more data |
} |
break; |
case 2: // lower bits of setpoint (higher resolution) |
if ((0x0001<<motor_write) & BLConfig_ReadMask) |
{ |
Motor[motor_write].ReadMode = BL_READMODE_CONFIG; // configuration request |
} |
else |
{ |
Motor[motor_write].ReadMode = BL_READMODE_STATUS; // normal status request |
} |
// send read mode and the lower bits of setpoint |
I2C_WriteByte((Motor[motor_write].ReadMode<<3)|(Motor[motor_write].SetPointLowerBits & 0x07)); |
// configuration tranmission request? |
if((0x0001<<motor_write) & BLConfig_WriteMask) |
{ // redirect tx pointer to configuration data |
pBuff = (uint8_t*)&BLConfig; // select config for motor |
BuffLen = sizeof(BLConfig_t); |
} |
else |
{ // jump to end of transmission for that motor |
twi_state = 4; |
} |
break; |
case 3: // send configuration |
I2C_WriteByte(*pBuff); |
pBuff++; |
if(--BuffLen > 0) twi_state = 3; // if there are some bytes left |
break; |
case 4: // repeat case 0-4 for all motors |
if(TWSR == TW_MT_DATA_NACK) // Data transmitted, NACK received |
{ |
if(!missing_motor) missing_motor = motor_write + 1; |
if((Motor[motor_write].State & MOTOR_STATE_ERROR_MASK) < MOTOR_STATE_ERROR_MASK) Motor[motor_write].State++; // increment error counter and handle overflow |
} |
I2C_Stop(TWI_STATE_MOTOR_TX); |
I2CTimeout = 10; |
motor_write++; // next motor |
I2C_Start(TWI_STATE_MOTOR_TX); // Repeated start -> switch slave or switch Master Transmit -> Master Receive |
break; |
// Master Receive Data |
case 5: // TWI_STATE_MOTOR_RX |
if(TWSR != TW_MR_SLA_ACK) // SLA+R transmitted but no ACK received |
{ // no response from the addressed slave received |
Motor[motor_read].State &= ~MOTOR_STATE_PRESENT_MASK; // clear present bit |
if(++motor_read >= MAX_MOTORS) |
{ // all motors read |
motor_read = 0; // restart from beginning |
BLConfig_ReadMask = 0; // reset read configuration bitmask |
if(++motor_read_temperature >= MAX_MOTORS) |
{ |
motor_read_temperature = 0; |
BLFlags &= ~BLFLAG_READ_VERSION; |
} |
} |
BLFlags |= BLFLAG_TX_COMPLETE; |
I2C_Stop(TWI_STATE_MOTOR_TX); |
I2C_TransferActive = 0; |
} |
else |
{ // motor successfully addressed |
Motor[motor_read].State |= MOTOR_STATE_PRESENT_MASK; // set present bit |
if(Motor[motor_read].Version & MOTOR_STATE_NEW_PROTOCOL_MASK) |
{ |
// new BL found |
switch(Motor[motor_read].ReadMode) |
{ |
case BL_READMODE_CONFIG: |
pBuff = (uint8_t*)&BLConfig; |
BuffLen = sizeof(BLConfig_t); |
Motor[motor_read].ReadMode = BL_READMODE_STATUS; // only once |
break; |
case BL_READMODE_STATUS: |
pBuff = (uint8_t*)&(Motor[motor_read].Current); |
if(motor_read == motor_read_temperature) BuffLen = 3; // read Current, MaxPwm & Temp |
else BuffLen = 1;// read Current only |
break; |
} |
} |
else // old BL version |
{ |
pBuff = (uint8_t*)&(Motor[motor_read].Current); |
if((BLFlags & BLFLAG_READ_VERSION) || (motor_read == motor_read_temperature)) BuffLen = 2; // Current & MaxPwm |
else BuffLen = 1; // read Current only |
} |
if(BuffLen == 1) |
{ |
I2C_ReceiveLastByte(); // read last byte |
} |
else |
{ |
I2C_ReceiveByte(); // read next byte |
} |
} |
MissingMotor = missing_motor; |
missing_motor = 0; |
break; |
case 6: // receive bytes |
*pBuff = TWDR; |
pBuff++; |
BuffLen--; |
if(BuffLen>1) |
{ |
I2C_ReceiveByte(); // read next byte |
} |
else if (BuffLen == 1) |
{ |
I2C_ReceiveLastByte(); // read last byte |
} |
else // nothing left |
{ |
if(BLFlags & BLFLAG_READ_VERSION) |
{ |
// if(!(FC_StatusFlags & FC_STATUS_MOTOR_RUN) && ((Motor[motor_read].MaxPWM & 252) == 248)) Motor[motor_read].Version |= MOTOR_STATE_NEW_PROTOCOL_MASK; |
// else Motor[motor_read].Version = 0; |
if(!(FC_StatusFlags & FC_STATUS_MOTOR_RUN)) |
{ |
if((Motor[motor_read].MaxPWM & 252) == 248) Motor[motor_read].Version |= MOTOR_STATE_NEW_PROTOCOL_MASK; |
else Motor[motor_read].Version = 0; |
if(Motor[motor_read].MaxPWM == 248) Motor[motor_read].Version |= (MOTOR_STATE_FAST_MODE | MOTOR_STATE_BL30); |
else |
if(Motor[motor_read].MaxPWM == 249) Motor[motor_read].Version |= MOTOR_STATE_BL30; |
} |
} |
if(++motor_read >= MAX_MOTORS) |
{ |
motor_read = 0; // restart from beginning |
BLConfig_ReadMask = 0; // reset read configuration bitmask |
if(++motor_read_temperature >= MAX_MOTORS) |
{ |
motor_read_temperature = 0; |
BLFlags &= ~BLFLAG_READ_VERSION; |
} |
} |
I2C_Stop(TWI_STATE_MOTOR_TX); |
BLFlags |= BLFLAG_TX_COMPLETE; |
I2C_TransferActive = 0; |
return; |
} |
twi_state = 6; // if there are some bytes left |
break; |
// writing Gyro-Offsets |
case 18: |
I2C_WriteByte(0x98); // Address the DAC |
break; |
case 19: |
I2C_WriteByte(0x10 + (dac_channel * 2)); // Select DAC Channel (0x10 = A, 0x12 = B, 0x14 = C) |
break; |
case 20: |
switch(dac_channel) |
{ |
case 0: |
I2C_WriteByte(AnalogOffsetNick); // 1st byte for Channel A |
break; |
case 1: |
I2C_WriteByte(AnalogOffsetRoll); // 1st byte for Channel B |
break; |
case 2: |
I2C_WriteByte(AnalogOffsetGier); // 1st byte for Channel C |
break; |
} |
break; |
case 21: |
I2C_WriteByte(0x80); // 2nd byte for all channels is 0x80 |
break; |
case 22: |
I2C_Stop(TWI_STATE_MOTOR_TX); |
I2C_TransferActive = 0; |
I2CTimeout = 10; |
// repeat case 18...22 until all DAC Channels are updated |
if(dac_channel < 2) |
{ |
dac_channel ++; // jump to next channel |
I2C_Start(TWI_STATE_GYRO_OFFSET_TX); // start transmission for next channel |
} |
else |
{ |
dac_channel = 0; // reset dac channel counter |
BLFlags |= BLFLAG_TX_COMPLETE; |
} |
break; |
default: |
I2C_Stop(TWI_STATE_MOTOR_TX); |
BLFlags |= BLFLAG_TX_COMPLETE; |
I2CTimeout = 10; |
motor_write = 0; |
motor_read = 0; |
I2C_TransferActive = 0; |
break; |
} |
} |
uint8_t I2C_WriteBLConfig(uint8_t motor) |
{ |
uint8_t i; |
uint16_t timer; |
if(MotorenEin || PC_MotortestActive) return(BLCONFIG_ERR_MOTOR_RUNNING); // not when motors are running! |
if(motor > MAX_MOTORS) return (BLCONFIG_ERR_MOTOR_NOT_EXIST); // motor does not exist! |
if(motor) |
{ |
if(!(Motor[motor-1].State & MOTOR_STATE_PRESENT_MASK)) return(BLCONFIG_ERR_MOTOR_NOT_EXIST); // motor does not exist! |
if(!(Motor[motor-1].Version & MOTOR_STATE_NEW_PROTOCOL_MASK)) return(BLCONFIG_ERR_HW_NOT_COMPATIBLE); // not a new BL! |
} |
// check BL configuration to send |
if((BLConfig.Revision & 0x0B) != BLCONFIG_REVISION) return (BLCONFIG_ERR_SW_NOT_COMPATIBLE); // bad revison |
i = RAM_Checksum((uint8_t*)&BLConfig, sizeof(BLConfig_t) - 1); |
if(i != BLConfig.crc) return(BLCONFIG_ERR_CHECKSUM); // bad checksum |
timer = SetDelay(2000); |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
// prepare the bitmask |
if(!motor) // 0 means all |
{ |
BLConfig_WriteMask = 0xFF; // all motors at once with the same configuration |
} |
else //only one specific motor |
{ |
BLConfig_WriteMask = 0x0001<<(motor-1); |
} |
for(i = 0; i < MAX_MOTORS; i++) |
{ |
if((0x0001<<i) & BLConfig_WriteMask) |
{ |
Motor[i].SetPoint = 0; |
Motor[i].SetPointLowerBits = 0; |
} |
} |
motor_write = 0; |
// needs at least MAX_MOTORS loops of 2 ms (12*2ms = 24ms) |
do |
{ |
I2C_Start(TWI_STATE_MOTOR_TX); // start an i2c transmission |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
}while(BLConfig_WriteMask && !CheckDelay(timer)); // repeat until the BL config has been sent |
if(BLConfig_WriteMask) return(BLCONFIG_ERR_MOTOR_NOT_EXIST); |
return(BLCONFIG_SUCCESS); |
} |
uint8_t I2C_ReadBLConfig(uint8_t motor) |
{ |
uint8_t i; |
uint16_t timer; |
if(MotorenEin || PC_MotortestActive) return(BLCONFIG_ERR_MOTOR_RUNNING); // not when motors are running! |
if(motor > MAX_MOTORS) return (BLCONFIG_ERR_MOTOR_NOT_EXIST); // motor does not exist! |
if(motor == 0) return (BLCONFIG_ERR_READ_NOT_POSSIBLE); |
if(!(Motor[motor-1].State & MOTOR_STATE_PRESENT_MASK)) return(BLCONFIG_ERR_MOTOR_NOT_EXIST); // motor does not exist! |
if(!(Motor[motor-1].Version & MOTOR_STATE_NEW_PROTOCOL_MASK)) return(BLCONFIG_ERR_HW_NOT_COMPATIBLE); // not a new BL! |
timer = SetDelay(2000); |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
// prepare the bitmask |
BLConfig_ReadMask = 0x0001<<(motor-1); |
for(i = 0; i < MAX_MOTORS; i++) |
{ |
if((0x0001<<i) & BLConfig_ReadMask) |
{ |
Motor[i].SetPoint = 0; |
Motor[i].SetPointLowerBits = 0; |
} |
} |
motor_read = 0; |
BLConfig.Revision = 0; // bad revision |
BLConfig.crc = 0; // bad checksum |
// needs at least MAX_MOTORS loops of 2 ms (12*2ms = 24ms) |
do |
{ |
I2C_Start(TWI_STATE_MOTOR_TX); // start an i2c transmission |
while(!(BLFlags & BLFLAG_TX_COMPLETE) && !CheckDelay(timer)); //wait for complete transfer |
}while(BLConfig_ReadMask && !CheckDelay(timer)); // repeat until the BL config has been received from all motors |
// validate result |
if((BLConfig.Revision & 0x0B) != BLCONFIG_REVISION) return (BLCONFIG_ERR_SW_NOT_COMPATIBLE); // bad revison |
i = RAM_Checksum((uint8_t*)&BLConfig, sizeof(BLConfig_t) - 1); |
if(i != BLConfig.crc) return(BLCONFIG_ERR_CHECKSUM); // bad checksum |
return(BLCONFIG_SUCCESS); |
} |
/tags/V2.02b/twimaster.h |
---|
0,0 → 1,102 |
#ifndef _I2C_MASTER_H |
#define _I2C_MASTER_H |
+ |
+#include <inttypes.h> |
+ |
+#define TWI_STATE_MOTOR_TX 0 |
+#define TWI_STATE_MOTOR_RX 5 |
+#define TWI_STATE_GYRO_OFFSET_TX 18 |
+ |
+extern volatile uint8_t twi_state; |
+extern volatile uint8_t motor_write; |
+extern volatile uint8_t motor_read; |
+extern volatile uint8_t I2C_TransferActive; |
+ |
+extern uint8_t MissingMotor; |
+ |
+#define MAX_MOTORS 12 |
+#define MOTOR_STATE_PRESENT_MASK 0x80 |
+#define MOTOR_STATE_ERROR_MASK 0x7F |
+ |
+//Motor[x].Version |
+#define MOTOR_STATE_NEW_PROTOCOL_MASK 0x01 |
+#define MOTOR_STATE_FAST_MODE 0x02 |
+#define MOTOR_STATE_BL30 0x04 // extended Current measurement -> 200 = 20A 201 = 21A 255 = 75A (20+55) |
+ |
+#define BLFLAG_TX_COMPLETE 0x01 |
+#define BLFLAG_READ_VERSION 0x02 |
+ |
+extern volatile uint8_t BLFlags; |
+ |
+#define BL_READMODE_STATUS 0 |
+#define BL_READMODE_CONFIG 16 |
+ |
+typedef struct |
+{ |
+ uint8_t Version; // the version of the BL (0 = old) |
+ uint8_t SetPoint; // written by attitude controller |
+ uint8_t SetPointLowerBits; // for higher Resolution of new BLs |
+ uint8_t State; // 7 bit for I2C error counter, highest bit indicates if motor is present |
+ uint8_t ReadMode; // select data to read |
+ // the following bytes must be exactly in that order! |
+ uint8_t Current; // in 0.1 A steps, read back from BL |
+ uint8_t MaxPWM; // read back from BL -> is less than 255 if BL is in current limit, not running (250) or starting (40) |
+ int8_t Temperature; // old BL-Ctrl will return a 255 here, the new version the temp. in °C |
+} __attribute__((packed)) MotorData_t; |
+ |
+extern MotorData_t Motor[MAX_MOTORS]; |
+ |
+#define BLCONFIG_REVISION 2 |
+ |
+#define MASK_SET_PWM_SCALING 0x01 |
+#define MASK_SET_CURRENT_LIMIT 0x02 |
+#define MASK_SET_TEMP_LIMIT 0x04 |
+#define MASK_SET_CURRENT_SCALING 0x08 |
+#define MASK_SET_BITCONFIG 0x10 |
+#define MASK_SET_STARTPWM 0x20 |
+#define MASK_SET_DEFAULT_PARAMS 0x40 |
+#define MASK_SET_SAVE_EEPROM 0x80 |
+ |
+#define BITCONF_REVERSE_ROTATION 0x01 |
+#define BITCONF_STARTGAS1 0x02 |
+#define BITCONF_STARTGAS2 0x04 |
+#define BITCONF_STARTGAS3 0x08 |
+#define BITCONF_RES4 0x10 |
+#define BITCONF_RES5 0x20 |
+#define BITCONF_RES6 0x40 |
+#define BITCONF_RES7 0x80 |
+ |
+typedef struct |
+{ |
+ uint8_t Revision; // must be BL_REVISION |
+ uint8_t SetMask; // settings mask |
+ uint8_t PwmScaling; // maximum value of control pwm, acts like a thrust limit |
+ uint8_t CurrentLimit; // current limit in A |
+ uint8_t TempLimit; // in °C |
+ uint8_t CurrentScaling; // scaling factor for current measurement |
+ uint8_t BitConfig; // see defines above |
+ uint8_t crc; // checksum |
+} __attribute__((packed)) BLConfig_t; |
+ |
+extern BLConfig_t BLConfig; |
+ |
+extern volatile uint16_t I2CTimeout; |
+ |
+void I2C_Init(char); // Initialize I2C |
+#define I2C_Start(start_state) {twi_state = start_state; BLFlags &= ~BLFLAG_TX_COMPLETE; TWCR = (1<<TWSTA) | (1<<TWEN) | (1<<TWINT) | (1<<TWIE);} |
+#define I2C_Stop(start_state) {twi_state = start_state; TWCR = (1<<TWEN) | (1<<TWSTO) | (1<<TWINT);} |
+void I2C_Reset(void); // Reset I2C |
+ |
+#define BLCONFIG_SUCCESS 0 |
+#define BLCONFIG_ERR_MOTOR_RUNNING 1 |
+#define BLCONFIG_ERR_MOTOR_NOT_EXIST 2 |
+#define BLCONFIG_ERR_HW_NOT_COMPATIBLE 3 |
+#define BLCONFIG_ERR_SW_NOT_COMPATIBLE 4 |
+#define BLCONFIG_ERR_CHECKSUM 5 |
+#define BLCONFIG_ERR_READ_NOT_POSSIBLE 6 |
+ |
+uint8_t I2C_WriteBLConfig(uint8_t motor); |
+uint8_t I2C_ReadBLConfig(uint8_t motor); |
+ |
+#endif |
/tags/V2.02b/uart.c |
---|
0,0 → 1,797 |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + www.MikroKopter.com |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software Nutzungsbedingungen (english version: see below) |
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt - |
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den |
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool |
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen. |
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im |
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu. |
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie |
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden. |
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren |
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren |
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand |
// + des Mitverschuldens offen. |
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet. |
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt. |
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern. |
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang |
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt. |
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software. |
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####' |
// + Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + Software LICENSING TERMS |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor - |
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware |
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*. |
// + The Software may only be used with the Licensor's products. |
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this |
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this |
// + agreement shall be the property of the Licensor. |
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other |
// + features that can be used to identify the program may not be altered or defaced by the customer. |
// + The customer shall be responsible for taking reasonable precautions |
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the |
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and |
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product |
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence. |
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test |
// + the software for his purpose before any operational usage. The customer will backup his data before using the software. |
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data |
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations. |
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range. |
// + #### END OF LICENSING TERMS #### |
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de. |
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
#include <stdarg.h> |
#include <string.h> |
#include <avr/pgmspace.h> |
#include "main.h" |
#include "uart.h" |
#include "libfc.h" |
#include "eeprom.h" |
#define FC_ADDRESS 1 |
#define NC_ADDRESS 2 |
#define MK3MAG_ADDRESS 3 |
#define BL_CTRL_ADDRESS 5 |
#define ABO_TIMEOUT 4000 // disable abo after 4 seconds |
#define MAX_SENDE_BUFF 220 |
#define MAX_EMPFANGS_BUFF 220 |
#define BLPARAM_REVISION 1 |
#define MASK_SET_PWM_SCALING 0x01 |
#define MASK_SET_CURRENT_LIMIT 0x02 |
#define MASK_SET_TEMP_LIMIT 0x04 |
#define MASK_SET_CURRENT_SCALING 0x08 |
#define MASK_SET_BITCONFIG 0x10 |
#define MASK_RESET_CAPCOUNTER 0x20 |
#define MASK_SET_DEFAULT_PARAMS 0x40 |
#define MASK_SET_SAVE_EEPROM 0x80 |
unsigned char GetExternalControl = 0,DebugDisplayAnforderung1 = 0, DebugDisplayAnforderung = 0,DebugDataAnforderung = 0,GetVersionAnforderung = 0, GetPPMChannelAnforderung = 0; |
unsigned char DisplayLine = 0; |
unsigned volatile char SioTmp = 0; |
unsigned volatile char NeuerDatensatzEmpfangen = 0; |
unsigned volatile char NeueKoordinateEmpfangen = 0; |
unsigned volatile char UebertragungAbgeschlossen = 1; |
unsigned volatile char CntCrcError = 0; |
unsigned volatile char AnzahlEmpfangsBytes = 0; |
unsigned volatile char TxdBuffer[MAX_SENDE_BUFF]; |
unsigned volatile char RxdBuffer[MAX_EMPFANGS_BUFF]; |
unsigned char *pRxData = 0; |
unsigned char RxDataLen = 0; |
unsigned volatile char PC_DebugTimeout = 0; |
unsigned volatile char PC_MotortestActive = 0; |
unsigned char DebugTextAnforderung = 255; |
unsigned char PcZugriff = 100; |
unsigned char MotorTest[16]; |
unsigned char MeineSlaveAdresse = 1; // Flight-Ctrl |
unsigned char ConfirmFrame; |
struct str_DebugOut DebugOut; |
struct str_ExternControl ExternControl; |
struct str_VersionInfo VersionInfo; |
struct str_WinkelOut WinkelOut; |
struct str_Data3D Data3D; |
int Display_Timer, Debug_Timer,Kompass_Timer,Timer3D; |
unsigned int DebugDataIntervall = 0, Intervall3D = 0, Display_Interval = 0; |
unsigned int AboTimeOut = 0; |
unsigned volatile char ReceiverUpdateModeActive = 0; // 1 = Update 2 = JetiBox-Simulation |
const unsigned char ANALOG_TEXT[32][16] PROGMEM = |
{ |
//1234567890123456 |
"AngleNick ", //0 |
"AngleRoll ", |
"AccNick ", |
"AccRoll ", |
"YawGyro ", |
"Altitude [0.1m] ", //5 |
"AccZ ", |
"Gas ", |
"Compass Value ", |
"Voltage [0.1V] ", |
"Receiver Level ", //10 |
"Gyro Compass ", |
"Motor 1 ", |
"Motor 2 ", |
"Motor 3 ", |
"Motor 4 ", //15 |
"16 ", |
"17 ", |
"18 ", |
"19 ", |
"Servo ", //20 |
"Hovergas ", |
"Current [0.1A] ", |
"Capacity [mAh] ", |
"Height Setpoint ", |
"25 ", //25 |
"26 ", //"26 CPU OverLoad ", |
"Compass Setpoint", |
"I2C-Error ", |
"BL Limit ", |
"GPS_Nick ", //30 |
"GPS_Roll " |
}; |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
//++ Sende-Part der Datenübertragung |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
ISR(USART0_TX_vect) |
{ |
static unsigned int ptr = 0; |
unsigned char tmp_tx; |
if(!UebertragungAbgeschlossen) |
{ |
ptr++; // die [0] wurde schon gesendet |
tmp_tx = TxdBuffer[ptr]; |
if((tmp_tx == '\r') || (ptr == MAX_SENDE_BUFF)) |
{ |
ptr = 0; |
UebertragungAbgeschlossen = 1; |
} |
UDR0 = tmp_tx; |
} |
else ptr = 0; |
} |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
//++ Empfangs-Part der Datenübertragung, incl. CRC-Auswertung |
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ |
ISR(USART0_RX_vect) |
{ |
static unsigned int crc; |
static unsigned char crc1,crc2,buf_ptr; |
static unsigned char UartState = 0; |
unsigned char CrcOkay = 0; |
if (ReceiverUpdateModeActive == 1) { UDR1 = UDR0; return; } // 1 = Update |
if (ReceiverUpdateModeActive == 2) { RxdBuffer[0] = UDR0; return; } // 2 = JetiBox-Simulation |
SioTmp = UDR0; |
if(buf_ptr >= MAX_SENDE_BUFF) UartState = 0; |
if(SioTmp == '\r' && UartState == 2) |
{ |
UartState = 0; |
crc -= RxdBuffer[buf_ptr-2]; |
crc -= RxdBuffer[buf_ptr-1]; |
crc %= 4096; |
crc1 = '=' + crc / 64; |
crc2 = '=' + crc % 64; |
CrcOkay = 0; |
if((crc1 == RxdBuffer[buf_ptr-2]) && (crc2 == RxdBuffer[buf_ptr-1])) CrcOkay = 1; else { CrcOkay = 0; CntCrcError++;}; |
if(!NeuerDatensatzEmpfangen && CrcOkay) // Datensatz schon verarbeitet |
{ |
NeuerDatensatzEmpfangen = 1; |
AnzahlEmpfangsBytes = buf_ptr + 1; |
RxdBuffer[buf_ptr] = '\r'; |
if(RxdBuffer[2] == 'R' && !MotorenEin) |
{ |
LcdClear(); |
wdt_enable(WDTO_250MS); // Reset-Commando |
ServoActive = 0; |
} |
} |
} |
else |
switch(UartState) |
{ |
case 0: |
if(SioTmp == '#' && !NeuerDatensatzEmpfangen) UartState = 1; // Startzeichen und Daten schon verarbeitet |
buf_ptr = 0; |
RxdBuffer[buf_ptr++] = SioTmp; |
crc = SioTmp; |
break; |
case 1: // Adresse auswerten |
UartState++; |
RxdBuffer[buf_ptr++] = SioTmp; |
crc += SioTmp; |
break; |
case 2: // Eingangsdaten sammeln |
RxdBuffer[buf_ptr] = SioTmp; |
if(buf_ptr < MAX_EMPFANGS_BUFF) buf_ptr++; |
else UartState = 0; |
crc += SioTmp; |
break; |
default: |
UartState = 0; |
break; |
} |
} |
// -------------------------------------------------------------------------- |
void AddCRC(unsigned int wieviele) |
{ |
unsigned int tmpCRC = 0,i; |
for(i = 0; i < wieviele;i++) |
{ |
tmpCRC += TxdBuffer[i]; |
} |
// if(i > MAX_SENDE_BUFF - 3) tmpCRC += 11; |
tmpCRC %= 4096; |
TxdBuffer[i++] = '=' + tmpCRC / 64; |
TxdBuffer[i++] = '=' + tmpCRC % 64; |
TxdBuffer[i++] = '\r'; |
UebertragungAbgeschlossen = 0; |
UDR0 = TxdBuffer[0]; |
//if(DebugOut.Analog[] < i) DebugOut.Analog[] = i; |
} |
// -------------------------------------------------------------------------- |
void SendOutData(unsigned char cmd,unsigned char address, unsigned char BufferAnzahl, ...) //unsigned char *snd, unsigned char len) |
{ |
va_list ap; |
unsigned int pt = 0; |
unsigned char a,b,c; |
unsigned char ptr = 0; |
unsigned char *snd = 0; |
int len = 0; |
TxdBuffer[pt++] = '#'; // Startzeichen |
TxdBuffer[pt++] = 'a' + address; // Adresse (a=0; b=1,...) |
TxdBuffer[pt++] = cmd; // Commando |
va_start(ap, BufferAnzahl); |
if(BufferAnzahl) |
{ |
snd = va_arg(ap, unsigned char*); |
len = va_arg(ap, int); |
ptr = 0; |
BufferAnzahl--; |
} |
while(len) |
{ |
if(len) |
{ |
a = snd[ptr++]; |
len--; |
if((!len) && BufferAnzahl) |
{ |
snd = va_arg(ap, unsigned char*); |
len = va_arg(ap, int); |
ptr = 0; |
BufferAnzahl--; |
} |
} |
else a = 0; |
if(len) |
{ |
b = snd[ptr++]; |
len--; |
if((!len) && BufferAnzahl) |
{ |
snd = va_arg(ap, unsigned char*); |
len = va_arg(ap, int); |
ptr = 0; |
BufferAnzahl--; |
} |
} |
else b = 0; |
if(len) |
{ |
c = snd[ptr++]; |
len--; |
if((!len) && BufferAnzahl) |
{ |
snd = va_arg(ap, unsigned char*); |
len = va_arg(ap, int); |
ptr = 0; |
BufferAnzahl--; |
} |
} |
else c = 0; |
TxdBuffer[pt++] = '=' + (a >> 2); |
TxdBuffer[pt++] = '=' + (((a & 0x03) << 4) | ((b & 0xf0) >> 4)); |
TxdBuffer[pt++] = '=' + (((b & 0x0f) << 2) | ((c & 0xc0) >> 6)); |
TxdBuffer[pt++] = '=' + ( c & 0x3f); |
} |
va_end(ap); |
AddCRC(pt); |
} |
// -------------------------------------------------------------------------- |
void Decode64(void) // die daten werden im rx buffer dekodiert, das geht nur, weil aus 4 byte immer 3 gemacht werden. |
{ |
unsigned char a,b,c,d; |
unsigned char x,y,z; |
unsigned char ptrIn = 3; // start at begin of data block |
unsigned char ptrOut = 3; |
unsigned char len = AnzahlEmpfangsBytes - 6; // von der Gesamtbytezahl eines Frames gehen 3 Bytes des Headers ('#',Addr, Cmd) und 3 Bytes des Footers (CRC1, CRC2, '\r') ab. |
while(len) |
{ |
a = RxdBuffer[ptrIn++] - '='; |
b = RxdBuffer[ptrIn++] - '='; |
c = RxdBuffer[ptrIn++] - '='; |
d = RxdBuffer[ptrIn++] - '='; |
x = (a << 2) | (b >> 4); |
y = ((b & 0x0f) << 4) | (c >> 2); |
z = ((c & 0x03) << 6) | d; |
if(len--) RxdBuffer[ptrOut++] = x; else break; |
if(len--) RxdBuffer[ptrOut++] = y; else break; |
if(len--) RxdBuffer[ptrOut++] = z; else break; |
} |
pRxData = (unsigned char*)&RxdBuffer[3]; // decodierte Daten beginnen beim 4. Byte |
RxDataLen = ptrOut - 3; // wie viele Bytes wurden dekodiert? |
} |
// -------------------------------------------------------------------------- |
void BearbeiteRxDaten(void) |
{ |
if(!NeuerDatensatzEmpfangen) return; |
unsigned char tempchar1, tempchar2; |
Decode64(); // dekodiere datenblock im Empfangsbuffer |
switch(RxdBuffer[1]-'a') // check for Slave Address |
{ |
case FC_ADDRESS: // FC special commands |
switch(RxdBuffer[2]) |
{ |
case 'K':// Kompasswert |
memcpy((unsigned char *)&KompassValue , (unsigned char *)pRxData, sizeof(KompassValue)); |
// KompassRichtung = ((540 + KompassValue - KompassSollWert) % 360) - 180; |
break; |
case 't':// Motortest |
if(AnzahlEmpfangsBytes > 20) memcpy(&MotorTest[0], (unsigned char *)pRxData, sizeof(MotorTest)); |
else memcpy(&MotorTest[0], (unsigned char *)pRxData, 4); |
PC_MotortestActive = 240; |
//while(!UebertragungAbgeschlossen); |
//SendOutData('T', MeineSlaveAdresse, 0); |
PcZugriff = 255; |
break; |
case 'n':// "Get Mixer |
while(!UebertragungAbgeschlossen); |
SendOutData('N', FC_ADDRESS, 1, (unsigned char *) &Mixer, sizeof(Mixer) - 1); |
Debug("Mixer lesen"); |
break; |
case 'm':// "Write Mixer |
if(pRxData[0] == EEMIXER_REVISION) |
{ |
memcpy(&Mixer, (unsigned char *)pRxData, sizeof(Mixer) - 1); |
MixerTable_WriteToEEProm(); |
tempchar1 = 1; |
VersionInfo.HardwareError[1] &= ~FC_ERROR1_MIXER; |
} |
else |
{ |
tempchar1 = 0; |
} |
while(!UebertragungAbgeschlossen); |
SendOutData('M', FC_ADDRESS, 1, &tempchar1, sizeof(tempchar1)); |
break; |
case 'p': // get PPM Channels |
GetPPMChannelAnforderung = 1; |
PcZugriff = 255; |
break; |
case 'q':// "Get"-Anforderung für Settings |
// Bei Get werden die vom PC einstellbaren Werte vom PC zurückgelesen |
if(MotorenEin) break; |
if((10 <= pRxData[0]) && (pRxData[0] < 20)) |
{ |
tempchar1 = pRxData[0] - 10; |
if(tempchar1< 1) tempchar1 = 1; // limit to 1 |
else if(tempchar1 > 5) tempchar1 = 5; // limit to 5 |
SetDefaultParameter(tempchar1, 1); |
} |
else if((20 <= pRxData[0]) && (pRxData[0] < 30)) |
{ |
tempchar1 = pRxData[0] - 20; |
if(tempchar1< 1) tempchar1 = 1; // limit to 1 |
else if(tempchar1 > 5) tempchar1 = 5; // limit to 5 |
SetDefaultParameter(tempchar1, 0); |
} |
else |
{ |
tempchar1 = pRxData[0]; |
if(tempchar1 == 0xFF) |
{ |
tempchar1 = GetActiveParamSet(); |
} |
if(tempchar1< 1) tempchar1 = 1; // limit to 1 |
else if(tempchar1 > 5) tempchar1 = 5; // limit to 5 |
// load requested parameter set |
ParamSet_ReadFromEEProm(tempchar1); |
} |
while(!UebertragungAbgeschlossen); |
SendOutData('Q', FC_ADDRESS, 2, &tempchar1, sizeof(tempchar1), (unsigned char *) &EE_Parameter, sizeof(EE_Parameter) - 1); |
Debug("Lese Setting %d", tempchar1); |
break; |
case 's': // Parametersatz speichern |
if((1 <= pRxData[0]) && (pRxData[0] <= 5) && (pRxData[1] == EEPARAM_REVISION) && MotorenEin == 0) // check for setting to be in range |
{ |
memcpy(&EE_Parameter, (uint8_t*)&pRxData[1], sizeof(EE_Parameter) - 1); |
ParamSet_WriteToEEProm(pRxData[0]); |
Umschlag180Nick = (long) EE_Parameter.WinkelUmschlagNick * 2500L; |
Umschlag180Roll = (long) EE_Parameter.WinkelUmschlagRoll * 2500L; |
tempchar1 = GetActiveParamSet(); |
} |
else |
{ |
tempchar1 = 0; // mark in response an invlid setting |
} |
while(!UebertragungAbgeschlossen); |
SendOutData('S', FC_ADDRESS, 1, &tempchar1, sizeof(tempchar1)); |
if(!MotorenEin) |
{ |
Piep(tempchar1,110); |
LipoDetection(0); |
} |
LIBFC_ReceiverInit(EE_Parameter.Receiver); |
break; |
case 'f': // auf anderen Parametersatz umschalten |
if(MotorenEin) break; |
if((1 <= pRxData[0]) && (pRxData[0] <= 5)) ParamSet_ReadFromEEProm(pRxData[0]); |
tempchar1 = GetActiveParamSet(); |
while(!UebertragungAbgeschlossen); |
SendOutData('F', FC_ADDRESS, 1, &tempchar1, sizeof(tempchar1)); |
if(!MotorenEin) |
{ |
Piep(tempchar1,110); |
LipoDetection(0); |
} |
LIBFC_ReceiverInit(EE_Parameter.Receiver); |
break; |
case 'y':// serial Potis |
for(tempchar1 = 0; tempchar1 < 12; tempchar1++) PPM_in[SERIAL_POTI_START + tempchar1] = (signed char) pRxData[tempchar1]; |
break; |
case 'u': // request BL parameter |
Debug("Reading BL %d", pRxData[0]); |
// try to read BL configuration |
tempchar2 = I2C_ReadBLConfig(pRxData[0]); |
if(tempchar2 == BLCONFIG_SUCCESS) tempchar1 = 1; |
else tempchar1 = 0; |
while(!UebertragungAbgeschlossen); // wait for previous frame to be sent |
SendOutData('U', FC_ADDRESS, 4, &tempchar1, sizeof(tempchar1), &tempchar2, sizeof(tempchar2), &pRxData[0], 1, &BLConfig, sizeof(BLConfig_t)); |
break; |
case 'w': // write BL parameter |
Debug("Writing BL %d", pRxData[0]); |
if(RxDataLen >= 1+sizeof(BLConfig_t)) |
{ |
memcpy(&BLConfig, (uint8_t*)(&pRxData[1]), sizeof(BLConfig_t)); |
tempchar2 = I2C_WriteBLConfig(pRxData[0]); |
if(tempchar2 == BLCONFIG_SUCCESS) tempchar1 = 1; |
else tempchar1 = 0; // indicate error |
while(!UebertragungAbgeschlossen); // wait for previous frame to be sent |
SendOutData('W', FC_ADDRESS,2, &tempchar1, sizeof(tempchar1), &tempchar2, sizeof(tempchar2)); |
} |
break; |
case 'j': |
if(MotorenEin) break; |
tempchar1 = LIBFC_GetCPUType(); |
if((tempchar1 == CPU_ATMEGA644P) || (tempchar1 == CPU_ATMEGA1284P)) |
{ |
uint16_t ubrr = (uint16_t) ((uint32_t) F_CPU/ (8 * 38400L) - 1); |
cli(); |
// UART0 & UART1 disable RX and TX-Interrupt |
UCSR0B &= ~((1 << RXCIE0)|(1 << TXCIE0)); |
UCSR1B &= ~((1 << RXCIE1)|(1 << TXCIE1)); |
// UART0 & UART1 disable receiver and transmitter |
UCSR0B &= ~((1 << TXEN0) | (1 << RXEN0)); |
UCSR1B &= ~((1 << TXEN1) | (1 << RXEN1)); |
// UART0 & UART1 flush receive buffer explicit |
while ( UCSR1A & (1<<RXC1) ) UDR1; |
while ( UCSR0A & (1<<RXC0) ) UDR0; |
if(pRxData[0] == 1) ReceiverUpdateModeActive = 2; |
else |
{ // Jeti or HoTT update |
//#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__)) |
if(pRxData[0] == 100) ubrr = (uint16_t) ((uint32_t) F_CPU/ (8 * 19200L) - 1); // HoTT |
//#endif |
ReceiverUpdateModeActive = 1; |
// UART0 & UART1 set baudrate |
UBRR1H = (uint8_t)(ubrr>>8); |
UBRR1L = (uint8_t)ubrr; |
UBRR0H = UBRR1H; |
UBRR0L = UBRR1L; |
// UART1 no parity |
UCSR1C &= ~(1 << UPM11); |
UCSR1C &= ~(1 << UPM10); |
// UART1 8-bit |
UCSR1B &= ~(1 << UCSZ12); |
UCSR1C |= (1 << UCSZ11); |
UCSR1C |= (1 << UCSZ10); |
} |
// UART0 & UART1 1 stop bit |
UCSR1C &= ~(1 << USBS1); |
UCSR0C &= ~(1 << USBS0); |
// UART1 clear 9th bit |
UCSR1B &= ~(1<<TXB81); |
// enable receiver and transmitter for UART0 and UART1 |
UCSR0B |= (1 << TXEN0) | (1 << RXEN0); |
UCSR1B |= (1 << TXEN1) | (1 << RXEN1); |
// enable RX-Interrupt for UART0 and UART1 |
UCSR0B |= (1 << RXCIE0); |
UCSR1B |= (1 << RXCIE1); |
// disable other Interrupts |
TIMSK0 = 0; |
TIMSK1 = 0; |
TIMSK2 = 0; |
sei(); |
} |
break; |
} // case FC_ADDRESS: |
default: // any Slave Address |
switch(RxdBuffer[2]) |
{ |
// 't' comand placed here only for compatibility to BL |
case 't':// Motortest |
if(AnzahlEmpfangsBytes >= sizeof(MotorTest)) memcpy(&MotorTest[0], (unsigned char *)pRxData, sizeof(MotorTest)); |
else memcpy(&MotorTest[0], (unsigned char *)pRxData, 4); |
while(!UebertragungAbgeschlossen); |
SendOutData('T', MeineSlaveAdresse, 0); |
PC_MotortestActive = 250; |
PcZugriff = 255; |
AboTimeOut = SetDelay(ABO_TIMEOUT); |
break; |
// 'K' comand placed here only for compatibility to old MK3MAG software, that does not send the right Slave Address |
case 'K':// Kompasswert |
memcpy((unsigned char *)&KompassValue , (unsigned char *)pRxData, sizeof(KompassValue)); |
// KompassRichtung = ((540 + KompassValue - KompassSollWert) % 360) - 180; |
break; |
case 'a':// Texte der Analogwerte |
DebugTextAnforderung = pRxData[0]; |
if (DebugTextAnforderung > 31) DebugTextAnforderung = 31; |
PcZugriff = 255; |
break; |
case 'b': |
memcpy((unsigned char *)&ExternControl, (unsigned char *)pRxData, sizeof(ExternControl)); |
ConfirmFrame = ExternControl.Frame; |
PcZugriff = 255; |
break; |
case 'c': // Poll the 3D-Data |
if(!Intervall3D) { if(pRxData[0]) Timer3D = SetDelay(pRxData[0] * 10);} |
Intervall3D = pRxData[0] * 10; |
AboTimeOut = SetDelay(ABO_TIMEOUT); |
break; |
case 'd': // Poll the debug data |
PcZugriff = 255; |
DebugDataIntervall = (unsigned int)pRxData[0] * 10; |
if(DebugDataIntervall > 0) DebugDataAnforderung = 1; |
AboTimeOut = SetDelay(ABO_TIMEOUT); |
break; |
case 'h':// x-1 Displayzeilen |
PcZugriff = 255; |
if((pRxData[0] & 0x80) == 0x00) // old format |
{ |
DisplayLine = 2; |
Display_Interval = 0; |
} |
else // new format |
{ |
RemoteKeys |= ~pRxData[0]; |
Display_Interval = (unsigned int)pRxData[1] * 10; |
DisplayLine = 4; |
AboTimeOut = SetDelay(ABO_TIMEOUT); |
} |
DebugDisplayAnforderung = 1; |
break; |
case 'l':// x-1 Displayzeilen |
PcZugriff = 255; |
MenuePunkt = pRxData[0]; |
DebugDisplayAnforderung1 = 1; |
break; |
case 'v': // Version-Anforderung und Ausbaustufe |
GetVersionAnforderung = 1; |
break; |
case 'g':// |
GetExternalControl = 1; |
break; |
default: |
//unsupported command received |
break; |
} |
break; // default: |
} |
NeuerDatensatzEmpfangen = 0; |
pRxData = 0; |
RxDataLen = 0; |
} |
//############################################################################ |
//Routine für die Serielle Ausgabe |
void uart_putchar (char c) |
//############################################################################ |
{ |
//Warten solange bis Zeichen gesendet wurde |
loop_until_bit_is_set(UCSR0A, UDRE0); |
//Ausgabe des Zeichens |
UDR0 = c; |
} |
//############################################################################ |
//INstallation der Seriellen Schnittstelle |
void UART_Init (void) |
//############################################################################ |
{ |
unsigned int ubrr = (unsigned int) ((unsigned long) F_CPU/(8 * USART0_BAUD) - 1); |
//Enable TXEN im Register UCR TX-Data Enable & RX Enable |
UCSR0B = (1 << TXEN0) | (1 << RXEN0); |
// UART Double Speed (U2X) |
UCSR0A |= (1 << U2X0); |
// RX-Interrupt Freigabe |
UCSR0B |= (1 << RXCIE0); |
// TX-Interrupt Freigabe |
UCSR0B |= (1 << TXCIE0); |
// USART0 Baud Rate Register |
// set clock divider |
UBRR0H = (uint8_t)(ubrr >> 8); |
UBRR0L = (uint8_t)ubrr; |
Debug_Timer = SetDelay(DebugDataIntervall); |
Kompass_Timer = SetDelay(220); |
VersionInfo.SWMajor = VERSION_MAJOR; |
VersionInfo.SWMinor = VERSION_MINOR; |
VersionInfo.SWPatch = VERSION_PATCH; |
VersionInfo.ProtoMajor = VERSION_SERIAL_MAJOR; |
VersionInfo.reserved1 = 0; |
VersionInfo.reserved2 = 0; |
VersionInfo.HWMajor = PlatinenVersion; |
pRxData = 0; |
RxDataLen = 0; |
} |
//--------------------------------------------------------------------------------------------- |
void DatenUebertragung(void) |
{ |
if(!UebertragungAbgeschlossen) return; |
if(CheckDelay(AboTimeOut)) |
{ |
Display_Interval = 0; |
DebugDataIntervall = 0; |
Intervall3D = 0; |
} |
if(((Display_Interval>0 && CheckDelay(Display_Timer)) || DebugDisplayAnforderung) && UebertragungAbgeschlossen) |
{ |
if(DisplayLine > 3)// new format |
{ |
Menu(); |
SendOutData('H', FC_ADDRESS, 1, (uint8_t *)DisplayBuff, 80); |
} |
else // old format |
{ |
LCD_printfxy(0,0,"!!! INCOMPATIBLE !!!"); |
SendOutData('H', FC_ADDRESS, 2, &DisplayLine, sizeof(DisplayLine), (uint8_t *)DisplayBuff, 20); |
if(DisplayLine++ > 3) DisplayLine = 0; |
} |
Display_Timer = SetDelay(Display_Interval); |
DebugDisplayAnforderung = 0; |
} |
if(DebugDisplayAnforderung1 && UebertragungAbgeschlossen) |
{ |
Menu(); |
SendOutData('L', FC_ADDRESS, 3, &MenuePunkt, sizeof(MenuePunkt), &MaxMenue, sizeof(MaxMenue), DisplayBuff, sizeof(DisplayBuff)); |
DebugDisplayAnforderung1 = 0; |
} |
if(GetVersionAnforderung && UebertragungAbgeschlossen) |
{ |
SendOutData('V', FC_ADDRESS, 1, (unsigned char *) &VersionInfo, sizeof(VersionInfo)); |
GetVersionAnforderung = 0; |
Debug_OK("Version gesendet"); |
} |
if(GetExternalControl && UebertragungAbgeschlossen) // Bei Get werden die vom PC einstellbaren Werte vom PC zurückgelesen |
{ |
SendOutData('G',MeineSlaveAdresse, 1, (unsigned char *) &ExternControl, sizeof(ExternControl)); |
GetExternalControl = 0; |
} |
if(((DebugDataIntervall>0 && CheckDelay(Debug_Timer)) || DebugDataAnforderung) && UebertragungAbgeschlossen) |
{ |
CopyDebugValues(); |
SendOutData('D', FC_ADDRESS, 1, (unsigned char *) &DebugOut,sizeof(DebugOut)); |
DebugDataAnforderung = 0; |
if(DebugDataIntervall>0) Debug_Timer = SetDelay(DebugDataIntervall); |
} |
if(Intervall3D > 0 && CheckDelay(Timer3D) && UebertragungAbgeschlossen) |
{ |
Data3D.Winkel[0] = ToNaviCtrl.IntegralNick;//(int) (IntegralNick / (EE_Parameter.GyroAccFaktor * 4)); // etwa in 0.1 Grad |
Data3D.Winkel[1] = ToNaviCtrl.IntegralRoll;//(int) (IntegralRoll / (EE_Parameter.GyroAccFaktor * 4)); // etwa in 0.1 Grad |
Data3D.Winkel[2] = (int) ((10 * ErsatzKompass) / GIER_GRAD_FAKTOR); |
Data3D.Centroid[0] = SummeNick >> 9; |
Data3D.Centroid[1] = SummeRoll >> 9; |
Data3D.Centroid[2] = Mess_Integral_Gier >> 9; |
SendOutData('C', FC_ADDRESS, 1, (unsigned char *) &Data3D,sizeof(Data3D)); |
Timer3D = SetDelay(Intervall3D); |
} |
if(DebugTextAnforderung != 255) // Texte für die Analogdaten |
{ |
unsigned char label[16]; // local sram buffer |
memcpy_P(label, ANALOG_TEXT[DebugTextAnforderung], 16); // read lable from flash to sra |
SendOutData('A', FC_ADDRESS, 2, (unsigned char *)&DebugTextAnforderung, sizeof(DebugTextAnforderung),label, 16); |
DebugTextAnforderung = 255; |
} |
if(ConfirmFrame && UebertragungAbgeschlossen) // Datensatz bestätigen |
{ |
SendOutData('B', FC_ADDRESS, 1, (uint8_t*)&ConfirmFrame, sizeof(ConfirmFrame)); |
ConfirmFrame = 0; |
} |
if(GetPPMChannelAnforderung && UebertragungAbgeschlossen) |
{ |
SendOutData('P', FC_ADDRESS, 1, (unsigned char *) &PPM_in, sizeof(PPM_in)); |
GetPPMChannelAnforderung = 0; |
} |
if((CheckDelay(Kompass_Timer)) && UebertragungAbgeschlossen) |
{ |
WinkelOut.Winkel[0] = ToNaviCtrl.IntegralNick;//(int) (IntegralNick / (EE_Parameter.GyroAccFaktor * 4)); // etwa in 0.1 Grad |
WinkelOut.Winkel[1] = ToNaviCtrl.IntegralRoll;//(int) (IntegralRoll / (EE_Parameter.GyroAccFaktor * 4)); // etwa in 0.1 Grad |
WinkelOut.UserParameter[0] = Parameter_UserParam1; |
WinkelOut.UserParameter[1] = Parameter_UserParam2; |
SendOutData('k', MK3MAG_ADDRESS, 1, (unsigned char *) &WinkelOut,sizeof(WinkelOut)); |
if(WinkelOut.CalcState > 4) WinkelOut.CalcState = 6; // wird dann in SPI auf Null gesetzt |
if(!NaviDataOkay) Kompass_Timer = SetDelay(99); |
else Kompass_Timer = SetDelay(999); |
} |
#ifdef DEBUG // only include functions if DEBUG is defined |
if(SendDebugOutput && UebertragungAbgeschlossen) |
{ |
SendOutData('0', FC_ADDRESS, 1, (unsigned char *) &tDebug, sizeof(tDebug)); |
SendDebugOutput = 0; |
} |
#endif |
} |
/tags/V2.02b/uart.h |
---|
0,0 → 1,117 |
#ifndef _UART_H |
#define _UART_H |
#define printf_P(format, args...) _printf_P(&uart_putchar, format , ## args) |
#define printf(format, args...) _printf_P(&uart_putchar, PSTR(format) , ## args) |
void BearbeiteRxDaten(void); |
extern unsigned char DebugGetAnforderung; |
extern unsigned volatile char ReceiverUpdateModeActive; |
extern unsigned volatile char UebertragungAbgeschlossen; |
extern unsigned volatile char PC_DebugTimeout; |
extern unsigned volatile char NeueKoordinateEmpfangen; |
extern unsigned volatile char PC_MotortestActive; |
extern unsigned char MeineSlaveAdresse; |
extern unsigned char PcZugriff; |
extern unsigned char RemotePollDisplayLine; |
extern unsigned volatile char RxdBuffer[]; |
extern int Debug_Timer,Kompass_Timer; |
extern void UART_Init (void); |
extern void uart_putchar (char c); |
//extern void boot_program_page (uint32_t page, uint8_t *buf); |
extern void DatenUebertragung(void); |
extern void Uart1Init(void); |
extern void BearbeiteRxDaten(void); |
extern unsigned char MotorTest[16]; |
struct str_DebugOut |
{ |
unsigned char Status[2]; |
signed int Analog[32]; // Debugwerte |
}; |
extern struct str_DebugOut DebugOut; |
struct str_WinkelOut |
{ |
signed int Winkel[2]; |
unsigned char UserParameter[2]; |
unsigned char CalcState; |
unsigned char Orientation; |
}; |
extern struct str_WinkelOut WinkelOut; |
struct str_Data3D |
{ |
signed int Winkel[3]; // nick, roll, compass in 0,1° |
signed char Centroid[3]; |
signed char reserve[5]; |
}; |
extern struct str_Data3D Data3D; |
struct str_ExternControl |
{ |
unsigned char Digital[2]; |
unsigned char RemoteTasten; |
signed char Nick; |
signed char Roll; |
signed char Gier; |
unsigned char Gas; |
signed char Hight; |
unsigned char free; |
unsigned char Frame; |
unsigned char Config; |
}; |
extern struct str_ExternControl ExternControl; |
// FC hardware errors |
// bitmask for UART_VersionInfo_t.HardwareError[0] |
#define FC_ERROR0_GYRO_NICK 0x01 |
#define FC_ERROR0_GYRO_ROLL 0x02 |
#define FC_ERROR0_GYRO_YAW 0x04 |
#define FC_ERROR0_ACC_NICK 0x08 |
#define FC_ERROR0_ACC_ROLL 0x10 |
#define FC_ERROR0_ACC_TOP 0x20 |
#define FC_ERROR0_PRESSURE 0x40 |
#define FC_ERROR0_CAREFREE 0x80 |
// bitmask for UART_VersionInfo_t.HardwareError[1] |
#define FC_ERROR1_I2C 0x01 |
#define FC_ERROR1_BL_MISSING 0x02 |
#define FC_ERROR1_SPI_RX 0x04 |
#define FC_ERROR1_PPM 0x08 |
#define FC_ERROR1_MIXER 0x10 |
#define FC_ERROR1_RES1 0x20 |
#define FC_ERROR1_RES2 0x40 |
#define FC_ERROR1_RES3 0x80 |
// for FlightCtrl |
//VersionInfo.Flags |
#define FC_VERSION_FLAG_NC_PRESENT 0x01 |
// for NaviCtrl |
#define NC_VERSION_FLAG_MK3MAG_PRESENT 0x01 |
struct str_VersionInfo |
{ |
unsigned char SWMajor; |
unsigned char SWMinor; |
unsigned char ProtoMajor; |
unsigned char reserved1; |
unsigned char SWPatch; |
unsigned char HardwareError[2]; |
unsigned char HWMajor; |
unsigned char reserved2; |
unsigned char Flags; |
}; |
extern struct str_VersionInfo VersionInfo; |
//#define USART0_BAUD 9600 |
//#define USART0_BAUD 14400 |
//#define USART0_BAUD 28800 |
//#define USART0_BAUD 38400 |
#define USART0_BAUD 57600 |
#endif //_UART_H |
/tags/V2.02b/user_receiver.c |
---|
0,0 → 1,23 |
//############################################################################ |
// Implement your own RC-decoding routines here |
//############################################################################ |
//############################################################################ |
// Initialize the UART here |
//############################################################################ |
void User_Receiver_Init(void) |
{ |
// SpektrumUartInit(); // or use an existing routine like this |
}; |
//############################################################################ |
// Is called by the uart RX interrupt |
// UDR contains the received byte |
//############################################################################ |
void User_RX_Parser(unsigned char udr) |
{ |
}; |
/tags/V2.02b/user_receiver.h |
---|
0,0 → 1,4 |
// for own implementations |
void User_Receiver_Init(void); |
void User_RX_Parser(unsigned char); |
/tags/V2.02b/vector.h |
---|
0,0 → 1,19 |
#ifndef _VECTOR_H |
#define _VECTOR_H |
typedef struct |
{ |
int32_t x; |
int32_t y; |
int32_t z; |
} __attribute__((packed)) vector32_t; |
typedef struct |
{ |
int16_t x; |
int16_t y; |
int16_t z; |
} __attribute__((packed)) vector16_t; |
#endif //_VECTOR_H |
/tags/V2.02b/version.txt |
---|
0,0 → 1,664 |
------- |
V0.53 27.04.2007 H.Buss |
- erste öffentliche Version |
V0.53b 29.04.2007 H.Buss |
- der FAKTOR_I war versehentlich auf Null, dann liegt der MikroKopter nicht so hart in der Luft |
V0.53c 29.04.2007 H.Buss |
- es gib ein Menü, in dem die Werte der Kanäle nach Nick, Roll, Gas,... sortiert sind. |
Die angezeigten Werte waren nicht die Werte der Funke |
V0.54 01.05.2007 H.Buss |
- die Paramtersätze können jetzt vor dem Start ausgewählt werden |
Dazu wird beim Kalibrieren der Messwerte (Gashebel oben links) der Nick-Rollhebel abgefragt: |
2 3 4 |
1 x 5 |
- - - |
Bedeutet: Nick-Rollhebel Links Mitte = Setting:1 Links Oben = Setting:2 usw. |
- der Faktor_I für den Hauptregler ist hinzugekommen. Im Heading-Hold-Modus sollte er vergössert werden, was Stabilität bringt |
V0.55 14.05.2007 H.Buss |
- es können nun Servos an J3,J4,J5 mit den Kanälen 5-7 gesteuert werden |
V0.56 14.05.2007 H.Buss |
- es gab Probleme mit Funken, die mehr als 8 Kanäle haben, wenn mehrere Kanäle dann auf Null waren |
- Funken, die nicht bis +-120 aussteuern können, sollten jetzt auch gehen |
V0.57 24.05.2007 H.Buss |
- Der Höhenregler kann nun auch mittels Schalter bedient werden |
- Bug im Gier-Algorithmus behoben; Schnelles Gieren fürhrte dazu, dass der MK zu weit gedreht hat |
- Kompass-Einfluss dämpfen bei Neigung |
- Man kann zwischen Kompass FIX (Richtung beim Kalibrieren) und Variabel (einstellbar per Gier) wählen |
- Der Motortest vom Kopter-Tool geht jetzt |
- Man kann den Parametersätzen einen Namen geben |
- Das Kamerasetting ist unter Setting 2 defaultmässig integriert |
V0.58 30.05.2007 H.Buss |
- Der Höhenregler-Algorithmus wird nun umgangen, wenn der Höhenreglerschalter aus ist |
V0.60 17.08.2007 H.Buss |
- "Schwindel-Bug" behoben |
- Die Poti-Werte werden jetzt auf Unterlauf (<0) überprüft |
- Poti4 zugefügt |
- Es werden jetzt 8 Kanäle ausgewertet |
- Kamera-Servo (an J7) |
- Die Settings müssen überschrieben werden |
V0.61 - V0.63 H.Buss 27.09.2007 |
- Poti 4 und Kanal 8 werden im Menü angezeigt |
- ein paar Kleinigkeiten bei den DefaultKonstanten2 bereinigt |
- Analog.c: Aktuell_ax korrigiert |
- auf 32 Debug-Kanäle erweitert |
- Loopings sind jetzt möglich und einzeln im KopterTool freischaltbar |
- leichte Anpassungen im Gier - Geschwindigkeit und Drift |
- die Hardwareversion V1.1 wird erkannt und das Programm stellt sich auf die geänderte Gyroverstärkung und die geänderten Portpins ein |
- die Software startet nach dem Einschalten schneller, weil der Luftdruckoffset schneller gefunden wird |
- die PPM-Ausgänge liegen wieder an den Pins an |
- Details an der Sensordatenverarbeitung -> es fliegt sich geringfügig anders |
- der MK ist bei wenig Gas nicht mehr so giftig -> soll das Landen vereinfachen |
- I2C-Bus läuft jetzt sicher nach einer Störung wieder an |
- Sticksignale werden präziser ausgewertet |
- Stick-Kanäle werden ans Kopter-Tool übertragen |
- Es muss die Version V1.47 des Kopter-Tool verwendet werden |
- Die Settings werden auf Default zurückgesetzt |
- am Piepen kann man die Fehlerart unterscheiden |
1. einzelnes Piepen beim Einschalten und Kalibrieren |
2. langsames Intervall mindestens 1 Sek -> Empfangsausfall |
3. schnelleres Intervall mindestens 1 Sek -> Akku |
4. sehr schnelles Intervall mindestens 1 Sek -> Kommunikation zu den Reglern gestört |
V0.64 H.Buss 30.09.2007 |
- beim Gieren wurden die Achsen nicht hart genug geregelt |
V0.65a H.Buss 15.10.2007 |
- Integral im Mischer wieder integriert |
- Feinabstimmung im ACC/Gyro Abgleich -> 1/32 & 100 |
- ACC/Gyro Abgleich auch bei HH |
V0.66a H.Buss 3.11.2007 |
- Messwertverarbeitung aus dem Analog-Interrupt entfernt |
- Analogmessung hängt jetzt am FC-Timing |
- Looping-Stick-Hysterese eingebaut |
- Looping-180°-Umschlag einstellbar |
- Achsenkopplung: Gierbewegung verkoppelt Nick und Roll |
- Lageregelung nach ACC-Sensor verbessert |
- zusätzlicher I-Anteil in der Lageregelung verbessert die Neutrallage |
- Gyrodriftkompensation überarbeitet |
- Bug in der Gier-Stick-Berechnung behoben |
- Gyro-Messung auf 1kHz beschleunigt |
V0.67a H.Buss 16.11.2007 |
- der Hauptregler-I-Anteil wirkt jetzt nur noch auf den Winkel (ausser im HH-Mode) |
- Gyro-Acc-Abgleich jetzt wieder in jedem Zyklus |
- Feinabstimmung |
- Beim HH-Modus gab es noch Bugs |
V0.67e H.Buss 29.11.2007 |
- Parameter: Dynamic Stability und Driftfaktor eingeführt |
- Die Namen der Analogwerte werden jetzt zum Koptertool übertragen |
- Kompatibilität zum Koptertool erhöht |
V0.67f H.Buss 04.12.2007 |
- Das Integral des Hauptreglers wird jetzt linear entladen und nicht mehr proportional |
- Schub für Gier wird jetzt auf den Gaswert begrenzt, dadurch steigt der MK nicht mehr beim Gieren. Gier ist allerdings nicht mehr so agressiv |
- Die ACC-Nullwerte können jetzt dauerhaft im EEPROM gespeichert werden (Stick:Vollgas und Gier rechts) |
V0.68a I.Busker 28.12.2007 |
- SPI.c & SPI.h ins Projekt aufgenommen |
SPI-Kommuikation kann in SPI.h aktiviert/deaktivert werden |
V0.68c H.Buss 05.01.2008 |
- Stickauswertung verbessert -> träger und präziser |
- Alle Settings angepasst |
V0.69e H.Buss 05.05.2008 |
- kleinere Bugs beseitigt |
- Schneller Sinkflug jetzt möglich |
- Min- und Maxgas in den Settings geändert |
- Lagewinkel wird jetzt in 0,1 Grad an Kompass und Navi gesendet |
- Kalibrierung für MK3Mag -> Nick unten beim Kalibrieren |
- Kompassroutine um den Ersatzkompass (Gyro unterstützt Kompasswert) erweitert |
V0.69h H.Buss 21.05.2008 |
- STICK_GAIN = 4 eingeführt. Das erhöht die Auflösung der Sollwerte. Stick_P und Stick_I müssen nun um Faktor 4 erhöht werden |
- SenderOkay auch an das Naviboard übertragen |
- Bessere Parameter bei Senderausfall |
V0.69j H.Buss 30.05.2008 |
- Höhere Präzision der Achsenkopplung |
V0.69k H.Buss 31.05.2008 |
- Bug in SPI.C behoben |
- in 0.69h war ein Bug, der zu ungewollten Loopings führen konnte |
V0.69L H.Buss 14.06.2008 |
- feinere Cam-Servo-Auflösung |
V0.70a H.Buss 01.07.2008 |
- Unterstützung der V1.3-Hardware mit automatischem Hardware-Gyro-Abgleich |
V0.70b H.Buss 14.07.2008 |
- flexible Einstellungsmöglichkeit von J16 und J17 (Transistorausgänge) |
- eigene Parameter für GPS-Naviboard |
- eigener Parameter für ExternalControl (war vorher UserParameter1 bzw. 8) |
- neue Parameter im EEPROM-Datensatz: J16Bitmask, J16Timing, ExternalControl, Navi... |
- MikroKopterFlags eingeführt, damit das Navi den Status des MKs kennt |
- KopterTool-Kompatibilität auf 8 erhöht |
V0.70c H.Buss 30.07.2008 |
- Parameter der Datenfusion leicht modifiziert |
- EEPROM-Parameter für Looping-Umschlag angepasst (von 100 auf 85) |
- MaxStick wird auf 100 begrenzt |
V0.70d H.Buss 02.08.2008 |
- Transistorausgänge: das oberste Bit der Blinkmaske (im KopterTool linkes Bit) gibt nun den Zustand des Ausgangs im Schalterbetrieb an |
0.71b: H.Buss 19.10.2008 |
Kommunikation zum Navi erweitert: |
- Beeptime jetzt 32Bit |
- Datenfusion und Driftkopensation wird durch NaviBoard unterstützt |
0.71c: H.Buss 20.10.2008 |
- LoopConfig heisst jetzt BitConfig |
- 3-Fach-Schalter für Höhensteuerung möglich -> kann man mit GPS-Schalter zusammenlegen |
- bei den Settings wurde Setting[0] mit abgespeichert, welches es nicht gab. |
- in Zukunft werden bei neuen EEPROM-Settings die Kanäle von Setting 1 übernommen |
- Variablen NaviWindCorrection, NaviSpeedCompensation, NaviOperatingRadius eingeführt |
0.71f: H.Buss 15.11.2008 |
- Ausschalten der Höhenregelung per Schalter um 0,3 sek verzögert |
- bei der seriellen Übertragung hat die FC jetzt als SlaveAdresse die 1 |
- VersionInfo.NaviKompatibel eingeführt |
- wenn manuell gegiert wird, wird der GyroKompass-Wert auf den Kompasswert gesetzt |
- Luftdruckwert wird an das Navi übertragen |
- Der Baro-Offset wird jetzt nachgeführt, um den Messbereich zu erweitern. Geht nur bei Höhenregler mit Schalter |
- Debugdaten können jetzt mit 'f' gepollt werden |
0.71g: Gregor 09.12.2008 |
- Kommunikation überarbeitet |
Infos hier: http://www.mikrokopter.de/ucwiki/en/SerialCommands |
0.71h: H.Buss 15.12.2008 |
- Freigegebene Version |
- NaviAngleLimitation als Parameter zum Navi implementiert |
- Antwort auf CMD: 't' entfernt |
0.72d: H.Buss 22.01.2009 |
- OCTO als Compilerschalter |
- Unterstützung der FC 2.0 (ME) |
- GYRO_D eingeführt |
- Achsenkopplung jetzt auch auf Nick/Roll-Bewegung |
0.72e: H.Buss 27.01.2009 |
- die 0.72d hatte kein Integral im Gier |
- Parameter eingeführt: |
EE_Parameter.NaviGpsPLimit |
EE_Parameter.NaviGpsILimit |
EE_Parameter.NaviGpsDLimit |
EE_Parameter.NaviPH_LoginTime |
EE_Parameter.AchsKopplung2 |
EE_Parameter.CouplingYawCorrection |
0.72f: H.Buss 28.01.2009 |
- Bug im Ersatzkompass entfernt |
0.72h: H.Buss 05.02.2009 |
- Algorithmen beschleunigt -> Floats durch Fixkomma ersetzt |
- Achsentkopplung weiter verbessert |
- Nick- und Roll im Octo-Mischer auf jeweils vier Motoren aufgeteilt |
0.72i: H.Buss 07.02.2009 |
- Abtastrate von 1kHz auf 2kHz erhöht |
0.72j: H.Buss 09.02.2009 |
- neue Implementierung der Servoausgänge |
0.72k: H.Buss 10.02.2009 |
- Abtastrate auf 5kHz erhöht |
0.72L: H.Buss 13.02.2009 |
- Signalfilterung überarbeitet |
- OCTO2 implementiert |
0.72M: H.Buss 13.02.2009 |
- Code Cleanup |
0.72o: H.Buss 24.02.2009 |
- Abtastrate auf 2kHz |
- HW-Version an Navi |
- neuer Datensatz 'c' -> Lagedaten für 3D-Grafik |
- Auswerteroutine für Spectrum-Satteliten implementiert |
- Kanalsettings werden beim Parameterreset nicht mehr gelöscht |
- die Driftkompensation wird jetzt feiner aufgelöst --> EE_Parameter.Driftkomp muss mal 8 genommen werden |
- die Integrale und ACC-Werte werden jetzt im Scope in ca. 0,1° angezeigt (wie beim NaviBrd) |
0.72p: H.Buss 01.03.2009 |
- Octo3 erstellt |
- Analogwerte umbenannt |
0.73a-d: H.Buss 05.04.2009 |
- MixerTabelle implementiert |
- I2C-Bus auf bis zu 12 Motoren erweitert |
- die Busfehler der BL-Regler werden im Menü angezeigt |
- Revision der MixerTabelle eingeführt |
- MixerTabelle wird bei Parameterreset neu initialisiert |
- Motortest auf [12] erweitert |
- Motorschalter nicht mehr 3-Stufig |
0.74a |
- Datenfusion im Flug auch, wenn ACC-Z < 512 |
- Wert für die Luftdruck-Messbereichserweiterung abgefangen |
0.74d |
- Die Driftkompensation ist jetzt dreistufig -> 0,5% pro sekunde zusätzlich eingeführts |
0.75a G.Stobrawa 22.5.2009 |
- Extern Control also received from NC via SPI |
0.75b H.Buss 27.05.2009 |
- Spektrum-Singale schalten den PPM-Eingang aus |
- max. 2 Sekunden nach dem Start auf die BL-Regler warten |
- Automatische Zellenerkennung, wenn Spannungswarnung < 5,0V |
- Bei automatischer Zellenerkennung piept es je nach Zellenzahl |
- EE_DATENREVISION auf 76 erhöht |
- Servo: |
- Roll-Servo für FC ME implementiert |
- Update-Cmd stoppt Servos |
- Servos werden erst nach dem ersten Kalibrieren aktiviert |
0.75c G.Stobrawa 25.7.2009 |
- Übertragung der Servo-Settings zur NC |
- RSSI wird an NC gesendet, derzeit wird der Wert nicht gesetzt |
- Bugfix Messbereichsumschaltung des Luftdrucksensors springt |
- Auflösung des Luftdrucks nun bis auf 1 cm (5mal feiner) zur genaueren Berechnung des D-Anteils |
- Unterstützung von Warnings-Bitmasks für die J16, J17-Outputs bei Unterspannung |
- Unterspannung für einzelne Zelle´n von 3.2V auf 3.3V angehoben (9.6V --> 9.9V für 3S) |
0.75d H.Buss 13.8.2009 |
- RC-Routine: Empfangsausfall soll sicherer erkannt werden |
- Zellenerkennung nun auch beim Speichern der Settings |
- Warnungs-Blinkmaske auch bei Empfangsausfall |
0.75e H.Buss 18.8.2009 |
- LED-Blinken kann an die Motoren gekoppelt werden |
- Feinabstimmung des Höhenreglers |
0.75f H.Buss 27.8.2009 |
- D-Anteil des Höhenreglers jetzt mit Quadratischer Komponente |
- Lagewinkel wirkt jetzt mit 1/Cos(x) mit in den Höhenregler |
- leichte Modifikation der RC-Empfangroutine |
0.75g H.Buss 31.08.2009 |
- die Akkuspannung geht jetzt antiproportional ins Gas ein |
0.75h H.Buss 3.09.2009 |
- im Höhenregler werden jetzt die Stellwerte begrenzt --> max +- 16% vom geschätzten Schwebegas |
0.75i H.Buss 7.09.2009 |
- GpsZ vom Navi zur FC für den Höhenregler |
- "hoovergas-Variation" als Parameter |
- Kompatibilität zu NC und PC erhöht |
0.75j H.Buss 17.09.2009 |
- Laufzeitzähler eingebaut |
0.75k H.Buss 22.09.2009 |
- zweite Variante (Gregor) der Höhenregelung implementiert |
- umschaltbare RC-Routine |
0.75L H.Buss 23.09.2009 |
- SollHoehe und Gas geht nun auch an die NC |
0.75M H.Buss 29.09.2009 |
- Spektrum-Timing wird nun überwacht |
- die FC kann nun stand-Alone als Kamera-Stabilizer eingesetzt werden, weil die Servos aktiviert werden, wenn I2C fehlt |
0.75N H.Buss 29.09.2009 |
- Hoover-Stickpunkt wird bei aktivem Höhenregler nicht nachgeführt |
- Hoover-Stickpunkt kann per Parameter fest eingestellt werden |
- Baro-Messbereichserweiterung auch bei aktiviertem Höhenregler |
- Gyro_Gier_P und Gyro_Gier_I eingeführt |
- I2C_fehler-Zähler jetzt in den Analogdaten |
0.75o H.Buss 01.10.2009 |
- der Höhenregler wird jetzt nur alle 10ms bearbeitet |
- Baro-Messbereichserweiterung auch bei Poti als Sollwert |
0.76d H.Buss 10.10.2009 |
- bei aktiver Messbereichserweiterung wird die aktuelle Höhe übernommen |
0.76e H.Buss 27.10.2009 |
- es werden beim Start einmal alle BL-Regler angesprochen, damit BL-Regler#8 auch einen Selbsttest macht |
- S3D-ACT-Summensignal als Compilerschalter |
0.76f H.Buss 05.11.2009 |
- untere Spannungsgrenze der Unterspannungswarnung (9,3V) entfernt |
0.76g H.Buss 10.11.2009 |
- Casting-Fehler in der Gas-Berechnung |
0.77a H.Buss 11.11.2009 |
- Erweiterung auf 12 Kanäle |
- Bei Koptertool-Kanalabfrage kein Empfangsausfall-Piepsen |
- serielle Kanalerweiterung eingebaut -> PPM_in auf 25 erweitert |
- Servos3-5 einstellbar |
- neues Kommando "f" -> schaltet auf anderen Parametersatz um |
0.77b H.Buss 09.12.2009 |
- JetiBox: Menü wird übertragen |
- neu: FCFlags |= FCFLAG_I2CERR; |
- LED-Warn-Blinken nun mit festem Timing und abschaltbar |
0.77c H.Buss 07.01.2010 |
- zwei weitere Spektrum-Varianten implementiert |
0.77d H.Buss 25.01.2010 |
- Strom-Messung eingebaut |
0.78a H.Buss 03.02.2010 |
- Bugfix: Settingsumschaltung im Flug |
0.78b H.Buss |
- veröffentlichte Version |
0.78c H.Buss + G.Stobrawa 22.2.2010 |
- Bewegungsbegrenzung an Servo 3 to 5 der FC 2.0 |
- Theoretischer Variablenüberlauf bei Vario-Höhenregler |
- Anzeige des "SPI RX communication error" wenn GPS Option nicht aktiv |
- LED-Schwellwerte fürs Blinken waren unterschiedlich |
0.78c H.Buss + G.Stobrawa 04.3.2010 |
- Code cosmetics |
0.78f H.Buss + I.Busker 23.3.2010 |
- Unterstützung für Jeti-Expander |
- Begrenzung des Vario-Höhenreglers auf ein 10m-Fenster um Überläufe zu verhindern |
- Einführung eines Vario-Zeichens (+/-/ ) auf der Jetibox |
- BL-Timeout beim Start erhöht |
0.80a-d H. Buss + G.Stobrawa 20.5.2010 - 22.7.2010 |
- Motoren Starten nicht ohne Kalibrierung |
- Unterstützung der BL2.0-Regler |
- statt 8 nun 10 Bit Auflösung der Lageregekung |
- Unterstützung der BL2.0-Regler Konfiguration via MK-Tool |
- Parametersätze werden per I2C an die BL-Regler durchgereicht |
- "Care-Free" implementiert |
- Freie Belegung der "Vorne"-Richtung |
- nur wenn Motoren laufen: Beepen, wenn Carefree ohne Navi oder ohne gültigen MK3Mag-Wert |
- nur wenn Motoren laufen: Beepen wenn NC plötzlich ausfällt |
- #define RECEIVER_SPEKTRUM_EXP eingeführt |
- #define SWITCH_LEARNS_CAREFREE eingeführt |
- Schwerpunktanzeige in den 3D-Daten |
- Checksummen gesicherte Datenablage im EEProm |
- Fehlerdiagnose implementiert (Wiki: ErrorCodes) |
- ErrorCode aufs Jeti-Display |
- JetiMenü: bis acht Temperaturen der BL-Regler |
- GPSInfo.Speed im Jeti-Display |
- Compass-Richtung nun im Jeti-menü |
- diverse Änderungen im Höhenregler |
- P wirkt schwächer |
- D wirkt stärker |
- Anpassung der Höhenregelung auf Level des Hoovergases |
- AccZ schneller nachführen |
Parameter modifiziert: |
- EEPROM-Kompatibilität auf 84 -> Parameter werden resettet |
- EE_Parameter.Hoehe_ACC_Wirkung = 0; // war 30 |
- EE_Parameter.Hoehe_HoverBand = 8; // war 5 |
- Notgas = 45 |
- NotgasZeit = 90 |
- Beginnersetting: EE_Parameter.DynamicStability = 70; |
- Neu: GyroStability = 6 |
- GPS-Login-Time auf 2 reduziert |
0.80e H.Buss 02.08.2010 |
- MK3Mag ohne NC ging nicht |
0.80f H.Buss 04.08.2010 |
- Beim Höhenregler "Deckel" wird das Gas wieder wie in der alten Version behandelt und der D-Anteil auf das alte Verhalten (um Faktor 8) reduziert |
0.80g H.Buss 11.08.2010 |
- erweitetern Messbereich für Luftdruck bei der FC2.1 aktiviert |
0.80h H.Buss 30.08.2010 |
- bei I2C-Fehlern wurden die Counter zurück gesetzt und für einige ms die Interrupts angehalten - das ist jetzt behoben |
- Nur I2C-Daten senden, wenn das alte Paket komplett raus ist |
0.82a H.Buss 08.11.2010 |
- MotorSafetySwitch - Verriegelt das Ein/Ausschalten |
- ServoManualControlSpeed - Verlangsamt das Cam-Servo |
- CamOrientation - für verdrehte Kamera-Servos |
- Position der Status-Bits verändert |
- "Zucken" der Servos bei kurzen Empfangsausfällen behoben |
- jeti update command 'j' added |
- Poti-Auswertung nach ParameterZuordnung() verschoben -> FC-Code schneller |
- Waypont-Events z.B. zum Triggern der Kamera |
- Gyro-Sytbility: Werte bis 16 möglich |
0.82b H.Buss 08.12.2010 |
- Unterstützung von 3,3V-Referenzspannung (nur ATMEGA128) |
0.84a H.Buss 21.03.2011 (Release: 30.03.2011) |
- nur starten, wenn NC_ErrorCode = 0 |
- Beeptime von NC auch beim Kalibrieren durchlassen |
- Varible "JetiBeep" eingeführt |
- Kompass-Winkelvorgabe von NaviControl -> POI |
- Piepen beim Umschalten von CareFree |
- Compass-Routinen überarbeitet |
- Dafaultvalues Servo-Min/MAx an MKDS18 angepasst |
- Defaultreceiver ist RECEIVER_JETI |
- GPS-Operation-Radius per default auf 245m bzw. 100% |
- Höhenvorgabe im Vario-Mode durch Waypoints |
- bei laufenden Motoren keine neuen Settings annehmen |
- immer einmal Carefree Beepen nach dem Kalibrieren |
- Kanaloffset für Potis von 110 auf 127 erhöht, damit es gleich ist mit allen anderen Kanälen |
- POI-Richtung (Soll-Himmelsrichtung) bezieht sich auf den Kamera-Winkel |
0.86a H.Buss 13.09.2011 |
- Variable "JetiBeep" wird gelöscht, wenn an den Empfänger gesendet wurde |
- wenn GPS deaktiviert ist, keinen Fehler bringen, wenn GPS fehlt. Auch dann nicht piepsen |
- GPS-Sollwertverschiebung |
- Empfangs-Piepen unterdrücken -> einstellbar |
- MotorSmooth einstellbar |
- Höhenregler: keine 'harte' IstWert-Übernahme bei Bewegen des Sticks in die Hoover-Position |
- Coming Home mit Höhenvorgabe |
- Coming Home als Failsafe |
- Einführung des GPS-Characters (- / W H D P) |
- Klartext bei den Jeti-Fehlermeldungen |
- Jeti-Beep "3*kurz" bei NC-Errors |
- Jeti-LCD-Aufruf nur noch alle 300ms, weil die Werte zu unruhig waren |
- Mixer-Settings werden nicht gelöscht, wenn sich die Parameter-Revision ändert |
- GPS-Angle limit von 100 auf 140 |
- GPS-I-Limit von 75 auf 85 |
- GAS-Offset von 120 auf 127 erhöht, damit es für alle Kanäle gleich ist |
- EE_Parameter.Hoehe_StickNeutralPoint auf Werte zwischen 80 und 180 begrenzt |
- PPM_Neutral eingeführt, um den Offset bei HoTT auszugleichen; |
- LED_Update() nun nur noch alle 20ms, weil die schnellste Ausgabe (bei Potivorgabe) ohnehin nur 40ms sind |
- Jeti & HoTT: Nur beim Fehler auch JetiBeep, wenn die Motoren laufen -> sonst nervt das bei der Fehlerbehebung (Compass-Kalibrieren usw.) |
- Error-Text auch im virtuellen Display des Koptertools |
- virtuelles LCD-Menü: |
- "ExternControl" aus Platzgründen aus dem virtuellen LCD-Menü entfernt. |
- keine BL-Temperaturen und I2C-Fehler anzeigen, wenn die BL-Regler nicht verwendet werden |
- nach dem Gieren nicht den Ersatzkompass auf den Kompasswert stellen, die Umschaltung war zu hart |
- ACC Correction eingeführt |
- I2C Fehler kamen nicht bei der NC an, weil die zu kurz waren - jetzt meldet die NC die Fehler mind. 8 Sekunden |
- Fehlermeldungen stehen jetzt mind. so lange an, bis sie an die Nc ge sendet wurden |
- neue Fehlermeldungen: |
"No NC communicat", // 9 |
"GPS Fix lost ", // 21 |
"Magnet Error ", // 22 |
"Motor restart ", // 23 |
"BL Limitation " // 24 |
- LED: Schaltfläche "nur bei Motor start" bei beiden getrennt |
- Ausbau der HoTT-Telemetrie |
- Variable "KompassRichtung" entfernt |
- ErsatzKompassInGrad sinvoll genutzt |
- HoTT-Update per Uart-Durchschleifen |
- AltitudeSetpointTrimming eingeführt |
- Vario-Anzeige für HoTT |
- Verhindern eines Überlaufs im Vario |
- echter Varioton auch ohne Vario-Höhenregler |
- Flugminuten laufen jetzt bei (FC_StatusFlags & FC_STATUS_FLY) los, weil sonst die Zeit zur NC verschieden war |
- KompassFusion wird jetzt getrennt von der NC berechnet |
- Sport-Setting entfernt und ein "Easy-Setting" eingeführt (leicht reduzierte Sticks); "Beginner" ist jetzt "Normal" |
- MagnetError kann man in der Startphase ignorieren |
- BL-Temperaturen, I2C-Fehler und BL-MaxPWM zum Loggen an NC |
- Einzelströme nun auch bei HoTT angezeigt |
0.86b H.Buss 20.09.2011 |
- Höhenbegrenzung bewirkt nur, dass im Vario-Mode der Sollwert nicht weiter nach oben geschoben werden kann |
- grüne LED ging aus - gefixt |
- K1-K8 wurden im LCD mit 0-7 bezeichnet |
0.86c H.Buss 22.09.2011 |
- Neue Anzeige: Magnetfeld und Inklination bei HoTT und Jeti |
- Neuer SPI-Block 'SPI_MISC' |
- Kompass-Fusions-Dämpfung bei Neigung leicht verringert |
- '.' im Vario-Höhenregler |
0.86d H.Buss 26.09.2011 |
- Analog.c: Vario Überlauf anders verhinden |
- Poti1-6 auch im HoTT-Display |
0.88 H.Buss 12.12.2011 - 26.03.2012 |
- Failsafe-Kanal |
- Failsafe: 5 Sekunden warten & Höhe ändern (macht die NC) |
- Option: Failsafe-Sinkflug xx% Schwebegas |
- Stopp der Motoren wenn bei Failsafe ein Motor blockiert |
- von 30 auf 60 Sekunden Failsafe-Zeit verlängert |
- Höhenwert auf cm kalibriert (zeigte ca. 10% zu viel an) |
- Neue Error-Codes: "No SD-Card", "Flying range!" und "Error SD-Logging" |
- Wenn die Motoren aus sind, den Luftduckwert langsam nachführen |
- das sbus-protokoll implementiert (nur FC2.1) |
- Schaltkanal auf Servo-Ausgang |
- Filter auf den Ausgängen der Servos |
- Option: Failsafe-Sinkflug xx% Schwebegas |
- "Max Altitude" als Parameter auf der SD-Karte im Navi -> Beeinflusst "Parameter_MaximumAltitude" (das niedrigste gilt) und es gibt eine Fehlermeldung "ERR:Max Altitude" |
- SPI-Protokoll: BL.Status eingefügt und Parameter.GlobalConfig & Parameter.ExtraConfig verschoben |
- Senden der Out1 & Out2-Zustände an die NC, damit es in der OSD-Darstellung angezeigt werden kann |
- Kompassrichtung neu merken, wenn CF geschaltet wird |
- "I" aus dem Hott-Menü entfernt und durch ":" ersetzt, weil das nur auf der mx-20 gut aussah |
- Höhenregler-Settings: GPS-Z von 64 auf 20 reduziert |
0.88M H.Buss 15.05.2012 |
- HoTT V4 |
- Kamera-Servo beim Kalibrieren weiter laufen lassen. |
- Error 30: no GPS fix bei Start |
- echter MotorSchalter |
0.88n H.Buss 06.07.2012 |
- Bugfix: Der letzte angesteuerte Servo-Puls war zu kurz |
0.90 H.Buss 04.03.2013 |
- Anzeige WP x/Y in der HoTT-Telemetrie |
- Schalter und WP-Event gleichzeitig |
- Photo-Auslösung als Entfernungsintervalle |
- Jeti + |
- Kamera-Neitung als Integral |
- RC-Lost am Startpunkt macht kein Failsafe, wenn GAS auf Null für 1,5sek war |
- Auswahl:Speak-All nun in der KopterTool-Config |
0.90e H.Buss 04.03.2013 |
- Parameter_ServoRollComp jetzt auf Poti /Kompatibilität auf 93 erhöht) |
0.90f (26.04.2013) |
- disable Yawing when Gas-Stick is to Zero |
- calibration must be within 20° Tilt angle |
- Hold I-Parts of the attitude control to zero when the MK is still on the ground |
- ACC-Altitude sensor data fusion implemented to the altitude controller (HW-Update from FC2.1 to 2.2 needed) |
- MK must be within 20° tilt angle when calibrating sensors |
- Parameter Reset, if the HW-Version changes (FC2.1 to 2.2) |
0.90g (29.04.2013) |
- No ACC-Z error if the MK is tilted after switching on |
- ATMEGA644 (until FC2.0): Sensitive RC-Signal validation removed -> that was only nessecary for old 35MHz receivers |
0.90h (14.05.2013) |
- Auto Start and landing for Waypoints |
- back to old eeprom-compatiblity to remain compatible to other Tools |
- HoTT-Bugfix: no speech while vario tone |
- Bugfix: Wrong error speech in JetiEX ("Error calibration") |
0.90j (27.05.2013) |
- Changes for better EEPROM-Safety |
- variable ActiveParamSet instead of the direct EEPROM-Reading (faster) |
- Checking the ACC-Z value in flight and report ACC-Z if out of range |
- disable Altitude hold in case of ACC-Z error |
2.00a (after public Beta test 0.91) |
- show SW-Version in Hot Display |
- GPS-Parameter changed (P = 90->100; I = 90->90; D = 90->120; A = 40) |
- Move NICK/Roll Sticks for switching on / off |
- Move the Stick > 100 instead > 75 for switch on / off |
- Failsafe active if ACC-Upgarde |
- AltitudeMode, GPS_Mode & Carefree_Mode are now direct channels instead of Poti-Values (NaviGpsModeChannel,CareFreeChannel,HoeheChannel) |
- NC-SPI communication from 25Hz to 41Hz |
- MotorTemperature and GPS-Mode-Switch more often to NC |
- Auto-Start/Landing |
- JetiEX: Name set to 'MK' |
- if(CareFree) Parameter_AchsKopplung1 += 30; removed |
- StickNeutral setting per default 127 |
- UART-Buffer increased from 175 to 220 Bytes |
- show name of active parameter set in the HoTT/Jeti display |
- fixed in 0.91L: if "ServoRelative" is used, it coud happen that the servo moves a wide range in the first second after the first calibration |
- Servo3-5 Limit to 24-255 |
- no. of channels increased from 12 to 16 |
// 0 -> frei bzw. ACT rssi (or zero if unsigned) |
// 1 - 16 -> 1-16 |
// 17 - 28 -> 12 Serial channels |
// 29 -> WP-Event kanal |
// 30 Fix -> -127 |
// 31 Fix -> 0 |
// 32 Fix -> 128 |
2.00b |
- default Camera-Position after calibration changed if Inverted |
- some changes in ACC-Altitude hold to reduce climbing in fast foreward fly |
- UserParameter1 > 100 disables camera nick control (for BL-Gimbals with self-alignments) |
- Beep at motor off (1sek) |
2.00d |
- Do not start if MK is moving |
- Full Range of altitude measure expansion (3000m flight instead of 950m) |
- compensation of the atmospheric altitude error |
- Measure the exact influence of the barometric range extender |
- Reduce Nick/Roll if Gas is Zero -> avoids MK to turn over during switch-off sequence |
- Tell NC to wait at the Waypoint until Out1 Pattern is over |
- virtual menu: single BL-Currents (FC2.1) |
- per default active: NO_GPSFIX_NO_START and CFG_NO_RCOFF_BEEPING |
- Servo-Nick-Refres reduced from 4 to 3 in default setting -> makes the camera servos faster |
- No undervoltage Beeping if the FC is only supplied by MKUSB (the Voltage measurement is zero) |
- Reset I2C-Error counter when calibrating the Sensors |
- HOTT & Jeti bugfix: The temperatures were sometimes wrong |
- HoTT: |
- GPS coordiante now in Degree + Minutes.Decimalminutes (like in original Graupner-Receivers) |
- added the MK Status in Transmitter Logfile -> General->Fuel |
- added the MK Speach in Transmitter Logfile -> General->Alt3Sek |
2.02a |
- code too big for MEGA644 -> only ATMEGA1284 supported |
- Jeti:GPS-Koordinate |
- Don't accept Reset-Command if Motor running |
- 'Idle' Bit in Output-Mask |
- Option: DisableServoNick |
- Bugfix Maximum Altitude -> New: SpeakHoTT Errormessage = "MaximumAltitude" and VarioCharacter goes to '=' |
- New Error code 32 "ERR:BL Selftest" |
- prepared for current measurements up to 75A per ESC |
- reduced speed of capacity-calculation() from 10ms to 50ms - that should be fast enough |
- Timing correction for NC-Data (41Hz) |
- Autolanding if undervoltage |
- Compass offset angle |
- 0.2V hysteresis in undervoltage warning |
- Fixed: Bug in LED-Output |
- Autolanding per default at 3,1V |
2.02b |
- Bugfix: Data reading for Dodecas (12 motors) |
/tags/V2.02b |
---|
Property changes: |
Added: tsvn:logminsize |
+8 |
\ No newline at end of property |