mirror of
https://github.com/paparazzi/paparazzi.git
synced 2026-05-25 14:35:51 +08:00
[v4.2-import] Recent additions to V4.2
This commit is contained in:
+93
-2
@@ -1,4 +1,4 @@
|
||||
Paparazzi 4.1 - development branch
|
||||
Paparazzi 4.9 - development branch
|
||||
==================================
|
||||
|
||||
- STM libs completely replaced by libopencm3
|
||||
@@ -8,6 +8,98 @@ Paparazzi 4.1 - development branch
|
||||
[#194] (https://github.com/paparazzi/paparazzi/pull/194)
|
||||
|
||||
|
||||
Paparazzi 4.2.0_stable
|
||||
======================
|
||||
|
||||
Stable version release
|
||||
|
||||
Since last stable v4.0:
|
||||
- Total energy control
|
||||
- Improve Google map tiles download
|
||||
- Several updates on the Digital Cam and photogrammetry modules
|
||||
- WMM210 model
|
||||
- Rate limiter in airframes control laws
|
||||
- Uart flow control (stm32)
|
||||
- Bug fix for INS and AHRS filters
|
||||
- AP/FBW separation using spi or uart
|
||||
- Sensors fix and addition (GPS, current, baro)
|
||||
|
||||
Paparazzi 4.1.1_testing
|
||||
=======================
|
||||
|
||||
Second release candidate for next stable release.
|
||||
|
||||
- Run AP and FBW on separate boards
|
||||
[#297] (https://github.com/paparazzi/paparazzi/pull/297)
|
||||
- Separate Board Files for yapa_v2.0
|
||||
[#303] (https://github.com/paparazzi/paparazzi/pull/303)
|
||||
- Add UART hardware flow control (for STM32 only)
|
||||
[#289] (https://github.com/paparazzi/paparazzi/pull/289)
|
||||
- Add ezosd current sensor module
|
||||
[#292] (https://github.com/paparazzi/paparazzi/pull/292)
|
||||
- Paparazzi Center: fix coloration by passing input buffer line by line, set language to english
|
||||
- Rate limiter bugfix
|
||||
- DC_SHOT message photo numbers shown in GCS
|
||||
- home mode height can be set different from security height
|
||||
- Ahrs float_dcm uses magnetic heading while not inflight for better initial guess
|
||||
[#299] (https://github.com/paparazzi/paparazzi/pull/299)
|
||||
- Outback Challenge "Safety" Rules 1 and 2
|
||||
- Added WMM2010 Geo model used in ahrs int_cmpl_quat for rotorcrafts
|
||||
[#288] (https://github.com/paparazzi/paparazzi/pull/288)
|
||||
- Fix missing gain definitions from airframe file in total energy control
|
||||
- Added stm32loader to sw/tools
|
||||
- Change vsupply to be a uint16 to enable reporting of voltages higher than 25.5V
|
||||
[#294] (https://github.com/paparazzi/paparazzi/issues/294)
|
||||
- Digital cam module: release camera button on init
|
||||
- Fix second order term in propagation of x-position in HFF
|
||||
|
||||
Paparazzi 4.1.0_testing
|
||||
=======================
|
||||
|
||||
First release candidate for next stable release.
|
||||
|
||||
- Total energy control
|
||||
[#251] (https://github.com/paparazzi/paparazzi/pull/251)
|
||||
- PPM input on UART1 RX for Lisa/M autopilots
|
||||
- Rate Limiter for Flaps, Gears and servo hatches
|
||||
[#252] (https://github.com/paparazzi/paparazzi/pull/252)
|
||||
- GPS acceleration compensation in ahrs_float_dcm
|
||||
[#255] (https://github.com/paparazzi/paparazzi/pull/255)
|
||||
- Improved gravity heuristic for int_cmpl_quat
|
||||
- Some updates on digital_cam and photogrammetry modules
|
||||
[#250] (https://github.com/paparazzi/paparazzi/pull/250)
|
||||
- Replace wget by OCaml Http_client from netclient lib to download files
|
||||
[#276] (https://github.com/paparazzi/paparazzi/pull/276)
|
||||
|
||||
|
||||
Paparazzi 4.0.3
|
||||
===============
|
||||
|
||||
Maintenance release
|
||||
|
||||
- fix google map version download
|
||||
- fix BMP scripts for stm32
|
||||
- fix lisa/m 2.0 default voltage
|
||||
- fix gpsd2ivy for libgps3.5
|
||||
- improve some makefiles
|
||||
|
||||
|
||||
Paparazzi 4.0.2
|
||||
===============
|
||||
|
||||
Maintenance release
|
||||
|
||||
- fix some illegal xml chars in xml description for xtend_rssi and pwm_meas modules
|
||||
- fix ins_arduimu_basic by adding an empty ahrs_update_gps function
|
||||
- fix some ivy includes on OSX for weird installation cases
|
||||
- fix ACTUATORS_PWM_NB for fixedwings with USE_SERVOS_7AND8
|
||||
- updated kestrel weather meter agent
|
||||
- fix uart_tunnel if leds are not available on some boards
|
||||
- fix GPS_LLA message
|
||||
- fix make failure when trying to get google maps version, but no internet connection
|
||||
[#187] (https://github.com/paparazzi/paparazzi/issues/187)
|
||||
|
||||
|
||||
Paparazzi 4.0.1
|
||||
===============
|
||||
|
||||
@@ -22,7 +114,6 @@ Maintenance release
|
||||
- Tool added: mergelogs
|
||||
|
||||
|
||||
|
||||
Paparazzi 4.0
|
||||
=============
|
||||
|
||||
|
||||
@@ -52,6 +52,7 @@
|
||||
|
||||
<firmware name="setup">
|
||||
<target name="setup_actuators" board="umarim_1.0"/>
|
||||
<target name="tunnel" board="umarim_1.0"/>
|
||||
</firmware>
|
||||
|
||||
<!-- commands section -->
|
||||
|
||||
@@ -0,0 +1,297 @@
|
||||
<!DOCTYPE airframe SYSTEM "../airframe.dtd">
|
||||
<!--
|
||||
Tobias Muench 2012
|
||||
|
||||
example airframe for energyadaptive ctl
|
||||
aircraft:
|
||||
Twinstar II
|
||||
hardware:
|
||||
twog_1.0 + aspirin + ETS baro + ETS speed
|
||||
-->
|
||||
|
||||
<airframe name="Tob_energyadaptive">
|
||||
|
||||
<firmware name="fixedwing">
|
||||
<target name="sim" board="pc"/>
|
||||
<target name="ap" board="twog_1.0">
|
||||
|
||||
<configure name="PERIODIC_FREQUENCY" value="120"/>
|
||||
<configure name="AHRS_PROPAGATE_FREQUENCY" value="100"/>
|
||||
<configure name="AHRS_CORRECT_FREQUENCY" value="100"/>
|
||||
<define name="AHRS_TRIGGERED_ATTITUDE_LOOP" />
|
||||
|
||||
<define name="USE_I2C0"/>
|
||||
<define name="USE_BARO_ETS"/>
|
||||
</target>
|
||||
|
||||
<define name="USE_AIRSPEED"/>
|
||||
<define name="AGR_CLIMB"/>
|
||||
<define name="STRONG_WIND"/>
|
||||
<define name="WIND_INFO"/>
|
||||
<define name="WIND_INFO_RET"/>
|
||||
|
||||
|
||||
<subsystem name="radio_control" type="ppm"/> <!-- Radio -->
|
||||
<subsystem name="gps" type="ublox"/> <!-- GPS -->
|
||||
<subsystem name="telemetry" type="transparent"/> <!-- Communication -->
|
||||
<subsystem name="imu" type="aspirin_i2c"/> <!-- IMU -->
|
||||
<subsystem name="ahrs" type="int_cmpl_quat"/>
|
||||
<subsystem name="ins" type="float_alt"/>
|
||||
<subsystem name="control" type="energyadaptive"/>
|
||||
<subsystem name="navigation" type="extra"/>
|
||||
</firmware>
|
||||
|
||||
<modules>
|
||||
<load name="airspeed_ets.xml">
|
||||
<define name="SENSOR_SYNC_SEND"/>
|
||||
<define name="AIRSPEED_ETS_SCALE" value="1.44"/> <!-- default 1.8-->
|
||||
<!-- <define name="AIRSPEED_ETS_OFFSET" value="50"/> --> <!-- default 0 -->
|
||||
<!-- <define name="AIRSPEED_ETS_I2C_DEV" value="i2c1"/> -->
|
||||
</load>
|
||||
<load name="baro_ets.xml">
|
||||
<define name="BARO_ETS_SCALE" value="0.3"/>
|
||||
<define name="BARO_ETS_TELEMETRY"/>
|
||||
</load>
|
||||
<load name="digital_cam.xml">
|
||||
<define name="DC_SHUTTER_LED" value="5"/><!-- led4:aux led5:camsw-->
|
||||
</load>
|
||||
</modules>
|
||||
|
||||
<!-- ################################################## -->
|
||||
<servos> <!-- Actuators -->
|
||||
<servo name="MOTOR_LEFT" no="0" min="1000" neutral="1000" max="2000"/>
|
||||
<!-- <servo name="MOTOR_RIGHT" no="1" min="1000" neutral="1000" max="2000"/> -->
|
||||
<servo name="AILERON_LEFT" no="7" min="900" neutral="1300" max="1700"/>
|
||||
<servo name="AILERON_RIGHT" no="3" min="1140" neutral="1540" max="1940"/>
|
||||
<servo name="ELEVATOR" no="2" min="1700" neutral="1400" max="1000"/>
|
||||
<servo name="RUDDER" no="6" min="1810" neutral="1410" max="1010"/>
|
||||
<servo name="HATCH" no="4" min="1300" neutral="1300" max="800"/>
|
||||
</servos>
|
||||
|
||||
<commands>
|
||||
<axis name="THROTTLE" failsafe_value="0"/>
|
||||
<axis name="ROLL" failsafe_value="0"/>
|
||||
<axis name="PITCH" failsafe_value="0"/>
|
||||
<axis name="YAW" failsafe_value="0"/>
|
||||
<axis name="HATCH" failsafe_value="0"/>
|
||||
</commands>
|
||||
|
||||
<rc_commands> <!-- commands section -->
|
||||
<set command="THROTTLE" value="@THROTTLE"/>
|
||||
<set command="ROLL" value="@ROLL"/>
|
||||
<set command="PITCH" value="@PITCH"/>
|
||||
<set command="YAW" value="@YAW"/>
|
||||
<set command="HATCH" value="@GAIN2"/>
|
||||
</rc_commands>
|
||||
|
||||
<section name="MIXER">
|
||||
<define name="AILERON_DIFF" value="0.66"/>
|
||||
<define name="COMBI_SWITCH" value="1.0"/>
|
||||
</section>
|
||||
|
||||
<command_laws>
|
||||
<set servo="MOTOR_LEFT" value="@THROTTLE"/>
|
||||
<!-- <set servo="MOTOR_RIGHT" value="@THROTTLE"/> -->
|
||||
<set servo="RUDDER" value="@YAW + @ROLL*COMBI_SWITCH"/>
|
||||
<let var="roll" value="@ROLL"/>
|
||||
<set servo="AILERON_LEFT" value="($roll > 0 ? AILERON_DIFF : 1) * $roll"/>
|
||||
<set servo="AILERON_RIGHT" value="($roll > 0 ? 1 : AILERON_DIFF) * $roll"/>
|
||||
<set servo="ELEVATOR" value="@PITCH"/>
|
||||
<set servo="HATCH" value="@HATCH"/>
|
||||
</command_laws>
|
||||
|
||||
<section name="AUTO1" prefix="AUTO1_">
|
||||
<define name="MAX_ROLL" value="RadOfDeg(60)"/>
|
||||
<define name="MAX_PITCH" value="RadOfDeg(40)"/>
|
||||
</section>
|
||||
|
||||
<section name="TRIM" prefix="COMMAND_">
|
||||
<define name="ROLL_TRIM" value="0"/>
|
||||
<define name="PITCH_TRIM" value="0."/> <!--788 -->
|
||||
</section>
|
||||
|
||||
<!--
|
||||
######################################################################################
|
||||
-->
|
||||
<section name="AHRS" prefix="AHRS_">
|
||||
<define name="H_X" value=" 0.376689168"/> <!-- magnatic field -->
|
||||
<define name="H_Y" value="0.008242371595"/>
|
||||
<define name="H_Z" value=" 0.92630171"/>
|
||||
</section>
|
||||
|
||||
<section name="INS" prefix="INS_">
|
||||
<define name="ROLL_NEUTRAL_DEFAULT" value="0" unit="deg"/>
|
||||
<define name="PITCH_NEUTRAL_DEFAULT" value="0" unit="deg"/>
|
||||
</section>
|
||||
|
||||
<!-- <include href="conf/airframes/Tobias_imu_aspirin_36.xml"/> --> <!-- IMU -->
|
||||
<section name="IMU" prefix="IMU_">
|
||||
<define name="GYRO_P_NEUTRAL" value="-110"/> <!--"-10"--> <!--changeme!!!-->
|
||||
<define name="GYRO_Q_NEUTRAL" value="90" /> <!--"-48"--> <!--changeme!!!-->
|
||||
<define name="GYRO_R_NEUTRAL" value="-35" /> <!--"-109"--> <!--changeme!!!-->
|
||||
<define name="GYRO_P_SENS" value="4.412" integer="16"/>
|
||||
<define name="GYRO_Q_SENS" value="4.412" integer="16"/>
|
||||
<define name="GYRO_R_SENS" value="4.412" integer="16"/>
|
||||
<define name="GYRO_PQ_SENS" value="0.0" integer="16"/>
|
||||
<define name="GYRO_PR_SENS" value="0.0" integer="16"/>
|
||||
<define name="GYRO_QR_SENS" value="0.0" integer="16"/>
|
||||
|
||||
<define name="ACCEL_X_NEUTRAL" value="-1"/>
|
||||
<define name="ACCEL_Y_NEUTRAL" value="1"/>
|
||||
<define name="ACCEL_Z_NEUTRAL" value="29"/>
|
||||
<define name="ACCEL_X_SENS" value="38.4772001528" integer="16"/>
|
||||
<define name="ACCEL_Y_SENS" value="38.4353174937" integer="16"/>
|
||||
<define name="ACCEL_Z_SENS" value="39.0784871813" integer="16"/>
|
||||
<define name="ACCEL_XY_SENS" value="0.0" integer="16"/>
|
||||
<define name="ACCEL_XZ_SENS" value="0.0" integer="16"/>
|
||||
<define name="ACCEL_YZ_SENS" value="0.0" integer="16"/>
|
||||
|
||||
<define name="MAG_X_NEUTRAL" value="0"/>
|
||||
<define name="MAG_Y_NEUTRAL" value="0"/>
|
||||
<define name="MAG_Z_NEUTRAL" value="0"/>
|
||||
<define name="MAG_X_SENS" value="1." integer="16"/>
|
||||
<define name="MAG_Y_SENS" value="1." integer="16"/>
|
||||
<define name="MAG_Z_SENS" value="1." integer="16"/>
|
||||
<define name="MAG_XY_SENS" value="0.0" integer="16"/>
|
||||
<define name="MAG_XZ_SENS" value="0.0" integer="16"/>
|
||||
<define name="MAG_YZ_SENS" value="0.0" integer="16"/>
|
||||
|
||||
<define name="GYRO_P_SIGN" value="1"/>
|
||||
<define name="GYRO_Q_SIGN" value="1"/>
|
||||
<define name="GYRO_R_SIGN" value="1"/>
|
||||
<define name="ACCEL_X_SIGN" value="1"/>
|
||||
<define name="ACCEL_Y_SIGN" value="1"/>
|
||||
<define name="ACCEL_Z_SIGN" value="1"/>
|
||||
<define name="MAG_X_SIGN" value="1"/>
|
||||
<define name="MAG_Y_SIGN" value="1"/>
|
||||
<define name="MAG_Z_SIGN" value="1"/>
|
||||
|
||||
<define name="BODY_TO_IMU_PHI" value="RadOfDeg(-2)"/>
|
||||
<define name="BODY_TO_IMU_THETA" value="RadOfDeg(2)"/>
|
||||
<define name="BODY_TO_IMU_PSI" value="0"/>
|
||||
</section>
|
||||
|
||||
<section name="BAT">
|
||||
<define name="MILLIAMP_AT_FULL_THROTTLE" value="34000" unit="mA"/>
|
||||
<define name="CATASTROPHIC_BAT_LEVEL" value="9.3" unit="V"/> <!--10.5-->
|
||||
<define name="CRITIC_BAT_LEVEL" value="9.6" unit="V"/><!--11.-->
|
||||
<define name="LOW_BAT_LEVEL" value="9.7" unit="V"/><!--11.5-->
|
||||
<define name="MAX_BAT_LEVEL" value="12.5" unit="V"/>
|
||||
</section>
|
||||
|
||||
<section name="MISC">
|
||||
<define name="CLIMB_AIRSPEED" value="12." unit="m/s"/>
|
||||
<define name="NOMINAL_AIRSPEED" value="14." unit="m/s"/>
|
||||
<define name="GLIDE_AIRSPEED" value="12." unit="m/s"/>
|
||||
<define name="RACE_AIRSPEED" value="25." unit="m/s"/>
|
||||
<define name="STALL_AIRSPEED" value="8." unit="m/s"/>
|
||||
<define name="AIRSPEED_SETPOINT_SLEW" value="1" unit="s"/> <!--default is 1-->
|
||||
|
||||
<define name="CARROT" value="4." unit="s"/>
|
||||
<define name="KILL_MODE_DISTANCE" value="(1.5*MAX_DIST_FROM_HOME)"/>
|
||||
<define name="CONTROL_FREQUENCY" value="60" unit="Hz"/> <!-- default is 60Hz -->
|
||||
<define name="NO_XBEE_API_INIT" value="TRUE"/>
|
||||
<define name="ALT_KALMAN_ENABLED" value="TRUE"/>
|
||||
<define name="TRIGGER_DELAY" value="1."/>
|
||||
<define name="DEFAULT_CIRCLE_RADIUS" value="70."/>
|
||||
<define name="MIN_CIRCLE_RADIUS" value="35.0"/>
|
||||
</section>
|
||||
|
||||
<section name="GLS_APPROACH" prefix="APP_">
|
||||
<define name="ANGLE" value="10" unit="deg"/>
|
||||
<define name="INTERCEPT_AF_TOD" value="100"/>
|
||||
<define name="TARGET_SPEED" value="13"/>
|
||||
</section>
|
||||
|
||||
<!-- ########################################################################################### -->
|
||||
<section name="VERTICAL CONTROL" prefix="V_CTL_">
|
||||
<define name="POWER_CTL_BAT_NOMINAL" value="11.1" unit="volt"/>
|
||||
<!-- outer loop proportional gain -->
|
||||
<define name="ALTITUDE_PGAIN" value="0.1049"/>
|
||||
<!-- outer loop saturation -->
|
||||
<define name="ALTITUDE_MAX_CLIMB" value="5."/> <!--default 2-->
|
||||
<!-- auto throttle inner loop -->
|
||||
<define name="AUTO_THROTTLE_NOMINAL_CRUISE_THROTTLE" value="0.3"/>
|
||||
<define name="AUTO_THROTTLE_CLIMB_THROTTLE_INCREMENT" value="0.1" unit="%/(m/s)"/>
|
||||
<define name="AUTO_THROTTLE_PITCH_OF_VZ_PGAIN" value="0.15"/>
|
||||
|
||||
<define name="AIRSPEED_PGAIN" value="0."/>
|
||||
|
||||
<define name="AUTO_THROTTLE_OF_AIRSPEED_PGAIN" value="0.069"/>
|
||||
<define name="AUTO_THROTTLE_OF_AIRSPEED_IGAIN" value="0.01"/>
|
||||
|
||||
<define name="AUTO_PITCH_OF_AIRSPEED_PGAIN" value="0.01"/>
|
||||
<define name="AUTO_PITCH_OF_AIRSPEED_IGAIN" value="0.003"/>
|
||||
<define name="AUTO_PITCH_OF_AIRSPEED_DGAIN" value="0.03"/>
|
||||
|
||||
<define name="ENERGY_TOT_PGAIN" value="0."/>
|
||||
<define name="ENERGY_TOT_IGAIN" value="0."/>
|
||||
<define name="ENERGY_DIFF_PGAIN" value="0."/>
|
||||
<define name="ENERGY_DIFF_IGAIN" value="0."/>
|
||||
|
||||
<define name="AUTO_GROUNDSPEED_SETPOINT" value="6.0" unit="m/s"/>
|
||||
<define name="AUTO_GROUNDSPEED_PGAIN" value="0.75"/>
|
||||
<define name="AUTO_GROUNDSPEED_IGAIN" value="0.25"/>
|
||||
|
||||
<define name="THROTTLE_SLEW_LIMITER" value="1" unit="s"/>
|
||||
</section>
|
||||
|
||||
<section name="HORIZONTAL CONTROL" prefix="H_CTL_">
|
||||
<define name="COURSE_PGAIN" value="0.8"/>
|
||||
<define name="COURSE_DGAIN" value="0.3"/>
|
||||
|
||||
<define name="ROLL_MAX_SETPOINT" value="50" unit="deg"/>
|
||||
<define name="ROLL_ATTITUDE_GAIN" value="7400."/>
|
||||
<define name="ROLL_RATE_GAIN" value="200."/>
|
||||
<define name="ROLL_IGAIN" value="100."/>
|
||||
<define name="ROLL_KFFA" value="0"/>
|
||||
<define name="ROLL_KFFD" value="0"/>
|
||||
|
||||
<define name="PITCH_MAX_SETPOINT" value="25" unit="deg"/>
|
||||
<define name="PITCH_MIN_SETPOINT" value="-25" unit="deg"/>
|
||||
<define name="PITCH_PGAIN" value="7200."/>
|
||||
<define name="PITCH_DGAIN" value="6."/>
|
||||
<define name="PITCH_IGAIN" value="100."/>
|
||||
<define name="PITCH_KFFA" value="0."/>
|
||||
<define name="PITCH_KFFD" value="0."/>
|
||||
|
||||
<define name="PITCH_OF_ROLL" value="RadOfDeg(1.0)"/>
|
||||
<define name="AILERON_OF_THROTTLE" value="0.0"/>
|
||||
</section>
|
||||
|
||||
<section name="AGGRESSIVE" prefix="AGR_">
|
||||
<define name="BLEND_START" value="20"/><!-- Altitude Error to Initiate Aggressive Climb CANNOT BE ZERO!!-->
|
||||
<define name="BLEND_END" value="10"/><!-- Altitude Error to Blend Aggressive to Regular Climb Modes CANNOT BE ZERO!!-->
|
||||
<define name="CLIMB_THROTTLE" value="0.60"/><!-- Gaz for Aggressive Climb -->
|
||||
<define name="CLIMB_PITCH" value="RadOfDeg(12)"/><!-- Pitch for Aggressive Climb -->
|
||||
<define name="DESCENT_THROTTLE" value="0.1"/><!-- Gaz for Aggressive Decent -->
|
||||
<define name="DESCENT_PITCH" value="RadOfDeg(-20)"/><!-- Pitch for Aggressive Decent -->
|
||||
<define name="CLIMB_NAV_RATIO" value="0.8"/><!-- Percent Navigation for Altitude Error Equal to Start Altitude -->
|
||||
<define name="DESCENT_NAV_RATIO" value="1.0"/> <!-- -->
|
||||
</section>
|
||||
|
||||
<section name="NAV">
|
||||
<define name="NAV_PITCH" value="0."/>
|
||||
<define name="NAV_GLIDE_PITCH_TRIM" value="0"/>
|
||||
</section>
|
||||
|
||||
<section name="DIGITAL_CAMERA" prefix="DC_">
|
||||
<define name="AUTOSHOOT_QUARTERSEC_PERIOD" value="12" unit="quarter_second"/>
|
||||
<define name="AUTOSHOOT_METER_GRID" value="50" unit="meter"/>
|
||||
</section>
|
||||
|
||||
<section name="FAILSAFE" prefix="FAILSAFE_">
|
||||
<define name="DELAY_WITHOUT_GPS" value="3" unit="s"/>
|
||||
<define name="DEFAULT_THROTTLE" value="0.3" unit="%"/>
|
||||
<define name="DEFAULT_ROLL" value="RadOfDeg(15)" unit="rad"/>
|
||||
<define name="DEFAULT_PITCH" value="RadOfDeg(0)" unit="rad"/>
|
||||
<define name="HOME_RADIUS" value="DEFAULT_CIRCLE_RADIUS" unit="m"/>
|
||||
</section>
|
||||
|
||||
<section name="SIMU">
|
||||
<define name="WEIGHT" value ="1."/>
|
||||
<define name="YAW_RESPONSE_FACTOR" value =".9"/> <!--default 1.-->
|
||||
<define name="PITCH_RESPONSE_FACTOR" value ="1."/> <!--default 1.-->
|
||||
<define name="ROLL_RESPONSE_FACTOR" value ="15."/> <!--default 15-->
|
||||
</section>
|
||||
</airframe>
|
||||
@@ -21,6 +21,7 @@
|
||||
<configure name="AHRS_PROPAGATE_FREQUENCY" value="100"/>
|
||||
<configure name="AHRS_CORRECT_FREQUENCY" value="100"/>
|
||||
<define name="AHRS_TRIGGERED_ATTITUDE_LOOP" />
|
||||
<define name="USE_AHRS_GPS_ACCELERATIONS" />
|
||||
</target>
|
||||
|
||||
<target name="sim" board="pc">
|
||||
@@ -59,7 +60,7 @@
|
||||
<servo name="AILERON_LEFT" no="2" min="1100" neutral="1545" max="1900"/>
|
||||
<servo name="AILERON_RIGHT" no="6" min="1100" neutral="1545" max="1900"/>
|
||||
<servo name="ELEVATOR" no="7" min="1900" neutral="1504" max="1100"/>
|
||||
<servo name="RUDDER" no="3" min="1900" neutral="1419" max="1100"/>
|
||||
<servo name="RUDDER" no="3" min="1100" neutral="1419" max="1900"/>
|
||||
</servos>
|
||||
|
||||
<commands>
|
||||
@@ -145,8 +146,8 @@
|
||||
</section>
|
||||
|
||||
<section name="INS" prefix="INS_">
|
||||
<define name="ROLL_NEUTRAL_DEFAULT" value="0" unit="deg"/>
|
||||
<define name="PITCH_NEUTRAL_DEFAULT" value="4" unit="deg"/>
|
||||
<define name="ROLL_NEUTRAL_DEFAULT" value="3" unit="deg"/>
|
||||
<define name="PITCH_NEUTRAL_DEFAULT" value="2" unit="deg"/>
|
||||
</section>
|
||||
|
||||
<section name="AUTO1" prefix="AUTO1_">
|
||||
@@ -156,8 +157,6 @@
|
||||
|
||||
<section name="BAT">
|
||||
<!--define name="MILLIAMP_AT_FULL_THROTTLE" value="10000."/-->
|
||||
<define name="ADC_CHANNEL_CURRENT" value="ADC_4"/>
|
||||
<define name="MilliAmpereOfAdc(adc)" value="(88*adc)"/>
|
||||
<define name="CATASTROPHIC_BAT_LEVEL" value="9.3" unit="V"/>
|
||||
<!-- 0.0247311828 -->
|
||||
<!-- 0.02432905 -->
|
||||
@@ -175,19 +174,22 @@
|
||||
|
||||
<define name="TRIGGER_DELAY" value="1."/>
|
||||
<define name="DEFAULT_CIRCLE_RADIUS" value="120."/>
|
||||
|
||||
<define name="COMMAND_ROLL_TRIM" value="0"/>
|
||||
<define name="COMMAND_PITCH_TRIM" value="0"/>
|
||||
</section>
|
||||
|
||||
<section name="VERTICAL CONTROL" prefix="V_CTL_">
|
||||
|
||||
<define name="POWER_CTL_BAT_NOMINAL" value="11.1" unit="volt"/>
|
||||
<!-- outer loop proportional gain -->
|
||||
<define name="ALTITUDE_PGAIN" value="0.06"/> <!-- -0.024 -->
|
||||
<define name="ALTITUDE_PGAIN" value="0.1"/> <!-- -0.06 -->
|
||||
<!-- outer loop saturation -->
|
||||
<define name="ALTITUDE_MAX_CLIMB" value="2."/>
|
||||
|
||||
<!-- auto throttle inner loop -->
|
||||
<define name="AUTO_THROTTLE_NOMINAL_CRUISE_THROTTLE" value="0.45"/>
|
||||
<define name="AUTO_THROTTLE_MIN_CRUISE_THROTTLE" value="0.25"/>
|
||||
<define name="AUTO_THROTTLE_NOMINAL_CRUISE_THROTTLE" value="0.66"/>
|
||||
<define name="AUTO_THROTTLE_MIN_CRUISE_THROTTLE" value="0.55"/>
|
||||
<define name="AUTO_THROTTLE_MAX_CRUISE_THROTTLE" value="0.85"/>
|
||||
<define name="AUTO_THROTTLE_LOITER_TRIM" value="1000"/>
|
||||
<define name="AUTO_THROTTLE_DASH_TRIM" value="-600"/>
|
||||
|
||||
@@ -125,4 +125,14 @@
|
||||
settings=" settings/test_fixedwing_actuators.xml"
|
||||
gui_color="blue"
|
||||
/>
|
||||
<aircraft
|
||||
name="Twinstar_energyadaptive"
|
||||
ac_id="13"
|
||||
airframe="airframes/examples/Twinstar_energyadaptive.xml"
|
||||
radio="radios/Corona_24_DIY.xml"
|
||||
telemetry="telemetry/default_fixedwing_imu.xml"
|
||||
flight_plan="flight_plans/basic.xml"
|
||||
settings=" settings/fixedwing_basic.xml settings/control/ctl_energyadaptive.xml"
|
||||
gui_color="blue"
|
||||
/>
|
||||
</conf>
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
#
|
||||
# Makefile for shared radio_control ppm susbsytem
|
||||
# Makefile for shared radio_control ppm subsystem
|
||||
#
|
||||
|
||||
NORADIO = False
|
||||
@@ -14,6 +14,7 @@ ifeq ($(NORADIO), False)
|
||||
$(TARGET).CFLAGS += -DRADIO_CONTROL
|
||||
ifneq ($(RADIO_CONTROL_LED),none)
|
||||
ap.CFLAGS += -DRADIO_CONTROL_LED=$(RADIO_CONTROL_LED)
|
||||
fbw.CFLAGS += -DRADIO_CONTROL_LED=$(RADIO_CONTROL_LED)
|
||||
endif
|
||||
$(TARGET).CFLAGS += -DRADIO_CONTROL_TYPE_H=\"subsystems/radio_control/ppm.h\"
|
||||
$(TARGET).CFLAGS += -DRADIO_CONTROL_TYPE_PPM
|
||||
@@ -37,3 +38,4 @@ ifeq ($(NORADIO), False)
|
||||
endif
|
||||
endif
|
||||
endif
|
||||
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
<!DOCTYPE flight_plan SYSTEM "flight_plan.dtd">
|
||||
|
||||
<flight_plan alt="75" ground_alt="0" lat0="43.46223" lon0="1.27289" max_dist_from_home="1500" name="Basic" security_height="25">
|
||||
<flight_plan alt="260" ground_alt="185" lat0="43.46223" lon0="1.27289" max_dist_from_home="1500" name="Basic" security_height="25">
|
||||
<header>
|
||||
#include "subsystems/navigation/nav_line.h"
|
||||
#include "subsystems/datalink/datalink.h"
|
||||
@@ -13,8 +13,8 @@
|
||||
<waypoint name="MOB" x="137.0" y="-11.6"/>
|
||||
<waypoint name="S1" x="-119.2" y="69.6"/>
|
||||
<waypoint name="S2" x="274.4" y="209.5"/>
|
||||
<waypoint alt="30.0" name="AF" x="177.4" y="45.1"/>
|
||||
<waypoint alt="0.0" name="TD" x="28.8" y="57.0"/>
|
||||
<waypoint alt="215.0" name="AF" x="177.4" y="45.1"/>
|
||||
<waypoint alt="185.0" name="TD" x="28.8" y="57.0"/>
|
||||
<waypoint name="_BASELEG" x="168.8" y="-13.8"/>
|
||||
<waypoint name="CLIMB" x="-114.5" y="162.3"/>
|
||||
</waypoints>
|
||||
|
||||
@@ -0,0 +1,77 @@
|
||||
<!DOCTYPE flight_plan SYSTEM "flight_plan.dtd">
|
||||
|
||||
<flight_plan alt="400" ground_alt="387" lat0="37.0380740" lon0="-122.1428470" max_dist_from_home="4000" name="Rotorcraft TRI Field" security_height="2">
|
||||
<header>
|
||||
#include "autopilot.h"
|
||||
</header>
|
||||
<waypoints>
|
||||
<waypoint name="HOME" x="0.0" y="0.0"/>
|
||||
<waypoint name="CLIMB" x="0.0" y="5.0"/>
|
||||
<waypoint name="STDBY" x="-21.7" y="-4.4"/>
|
||||
<waypoint name="p1" x="-43.9" y="-0.0"/>
|
||||
<waypoint name="p2" x="-52.3" y="23.2"/>
|
||||
<waypoint name="p3" x="-63.9" y="1.4"/>
|
||||
<waypoint name="p4" x="-55.4" y="-7.1"/>
|
||||
<waypoint name="CAM" x="-53.7" y="8.8"/>
|
||||
<waypoint name="TD" x="-7.3" y="-5.2"/>
|
||||
</waypoints>
|
||||
<blocks>
|
||||
<block name="Wait GPS">
|
||||
<call fun="NavKillThrottle()"/>
|
||||
<while cond="!GpsFixValid()"/>
|
||||
</block>
|
||||
<block name="Geo init">
|
||||
<while cond="LessThan(NavBlockTime(), 10)"/>
|
||||
<call fun="NavSetGroundReferenceHere()"/>
|
||||
</block>
|
||||
<block name="Holding point">
|
||||
<call fun="NavKillThrottle()"/>
|
||||
<attitude pitch="0" roll="0" throttle="0" until="FALSE" vmode="throttle"/>
|
||||
</block>
|
||||
<block name="Start Engine">
|
||||
<call fun="NavResurrect()"/>
|
||||
<attitude pitch="0" roll="0" throttle="0" until="FALSE" vmode="throttle"/>
|
||||
</block>
|
||||
<block name="Takeoff" strip_button="Takeoff" strip_icon="takeoff.png">
|
||||
<exception cond="ins_enu_pos.z > POS_BFP_OF_REAL(2.)" deroute="Standby"/>
|
||||
<call fun="NavSetWaypointHere(WP_CLIMB)"/>
|
||||
<stay climb="0.5" vmode="climb" wp="CLIMB"/>
|
||||
</block>
|
||||
<block name="Standby" strip_button="Standby" strip_icon="home.png">
|
||||
<stay wp="STDBY"/>
|
||||
</block>
|
||||
<block name="stay_p1">
|
||||
<stay wp="p1"/>
|
||||
</block>
|
||||
<block name="go_p2">
|
||||
<go wp="p2"/>
|
||||
<deroute block="stay_p1"/>
|
||||
</block>
|
||||
<block name="line_p1_p2">
|
||||
<go from="p1" hmode="route" wp="p2"/>
|
||||
<stay until="stage_time>10" wp="p2"/>
|
||||
<go from="p2" hmode="route" wp="p1"/>
|
||||
<deroute block="stay_p1"/>
|
||||
</block>
|
||||
<block name="route">
|
||||
<go from="p1" hmode="route" wp="p3"/>
|
||||
<go from="p3" hmode="route" wp="p4"/>
|
||||
<go from="p4" hmode="route" wp="p1"/>
|
||||
<deroute block="stay_p1"/>
|
||||
</block>
|
||||
<block name="circle">
|
||||
<circle radius="nav_radius" wp="p1"/>
|
||||
</block>
|
||||
<block name="land here" strip_button="Land Here" strip_icon="land-right.png">
|
||||
<call fun="NavSetWaypointHere(WP_TD)"/>
|
||||
</block>
|
||||
<block name="land">
|
||||
<go wp="TD"/>
|
||||
</block>
|
||||
<block name="flare">
|
||||
<exception cond="NavDetectGround()" deroute="Holding point"/>
|
||||
<call fun="NavStartDetectGround()"/>
|
||||
<stay climb="-0.8" vmode="climb" wp="TD"/>
|
||||
</block>
|
||||
</blocks>
|
||||
</flight_plan>
|
||||
@@ -0,0 +1,59 @@
|
||||
|
||||
<!--
|
||||
-- (c) 2006 Pascal Brisset, Antoine Drouin
|
||||
--
|
||||
-- This file is part of paparazzi.
|
||||
--
|
||||
-- paparazzi 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.
|
||||
--
|
||||
-- paparazzi 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 paparazzi; see the file COPYING. If not, write to
|
||||
-- the Free Software Foundation, 59 Temple Place - Suite 330,
|
||||
-- Boston, MA 02111-1307, USA.
|
||||
-->
|
||||
|
||||
<!--
|
||||
-- Attributes of root (Radio) tag :
|
||||
-- name: name of RC
|
||||
-- data_min: min width of a pulse to be considered as a data pulse
|
||||
-- data_max: max width of a pulse to be considered as a data pulse
|
||||
-- sync_min: min width of a pulse to be considered as a synchro pulse
|
||||
-- sync_max: max width of a pulse to be considered as a synchro pulse
|
||||
-- min, max and sync are expressed in micro-seconds
|
||||
-->
|
||||
|
||||
<!--
|
||||
-- Attributes of channel tag :
|
||||
-- ctl: name of the command on the transmitter - only for displaying
|
||||
-- no: order in the PPM frame
|
||||
-- function: logical command
|
||||
-- averaged: channel filtered through several frames (for discrete commands)
|
||||
-- min: minimum pulse length (micro-seconds)
|
||||
-- max: maximum pulse length (micro-seconds)
|
||||
-- neutral: neutral pulse length (micro-seconds)
|
||||
-- Note: a command may be reversed by exchanging min and max values
|
||||
-->
|
||||
|
||||
<!DOCTYPE radio SYSTEM "radio.dtd">
|
||||
<radio name="Corona 2.4GHz DIY" data_min="800" data_max="2200" sync_min ="5000" sync_max ="15000"
|
||||
pulse_type="POSITIVE">
|
||||
<channel ctl="G" function="UNUSED" min="1100" neutral="1500" max="1900" average="0"/>
|
||||
<channel ctl="F" function="GAIN2" min="1100" neutral="1500" max="1900" average="0"/>
|
||||
<channel ctl="E" function="GAIN1" min="1100" neutral="1500" max="1900" average="0"/>
|
||||
<channel ctl="switch" function="MODE" min="1100" neutral="1500" max="1900" average="1"/>
|
||||
<channel ctl="B" function="YAW" min="1900" neutral="1500" max="1100" average="0"/>
|
||||
<channel ctl="C" function="PITCH" min="1900" neutral="1500" max="1100" average="0"/>
|
||||
<channel ctl="D" function="ROLL" max="1100" neutral="1500" min="1900" average="0"/>
|
||||
<channel ctl="A" function="THROTTLE" min="1100" neutral="1100" max="1900" average="0"/>
|
||||
|
||||
|
||||
</radio>
|
||||
|
||||
Reference in New Issue
Block a user