From 787bdc379a7b3d8f053188acf104aec35d9fac2e Mon Sep 17 00:00:00 2001 From: Michael Oborne Date: Tue, 10 Jan 2012 08:16:10 +0800 Subject: [PATCH] APM Planner 1.1.19 fix log download misc --- .../ArdupilotMegaPlanner/ArdupilotMega.csproj | 3 - Tools/ArdupilotMegaPlanner/Camera.cs | 2 + Tools/ArdupilotMegaPlanner/Common.cs | 47 ++++++++++-- .../GCSViews/FlightData.cs | 23 +++--- .../GCSViews/FlightPlanner.cs | 18 ++++- .../GCSViews/Simulation.cs | 76 ++++++++++++------- Tools/ArdupilotMegaPlanner/HUD.cs | 4 +- Tools/ArdupilotMegaPlanner/Log.cs | 38 +++++----- Tools/ArdupilotMegaPlanner/MainV2.cs | 10 ++- Tools/ArdupilotMegaPlanner/Program.cs | 2 + .../Properties/AssemblyInfo.cs | 2 +- .../bin/Release/aircraft/Rascal/Rascal.xml | 41 +++++----- .../aircraft/Rascal/Rascal110-JSBSim-set.xml | 18 +++-- .../aircraft/Rascal/Rascal110-JSBSim.xml | 2 +- .../aircraft/Rascal/Systems/airdata.nas | 32 ++++++++ .../Release/aircraft/Rascal/Systems/main.nas | 1 + .../aircraft/arducopter/arducopter-set.xml | 19 ++--- .../bin/Release/mavcmd.xml | 12 +-- Tools/ArdupilotMegaPlanner/mavcmd.xml | 12 +-- 19 files changed, 235 insertions(+), 127 deletions(-) diff --git a/Tools/ArdupilotMegaPlanner/ArdupilotMega.csproj b/Tools/ArdupilotMegaPlanner/ArdupilotMega.csproj index 1ac4be927f..e945e0cff7 100644 --- a/Tools/ArdupilotMegaPlanner/ArdupilotMega.csproj +++ b/Tools/ArdupilotMegaPlanner/ArdupilotMega.csproj @@ -680,9 +680,6 @@ Always - - Always - Always diff --git a/Tools/ArdupilotMegaPlanner/Camera.cs b/Tools/ArdupilotMegaPlanner/Camera.cs index 12d9795a6d..6964565f1c 100644 --- a/Tools/ArdupilotMegaPlanner/Camera.cs +++ b/Tools/ArdupilotMegaPlanner/Camera.cs @@ -32,6 +32,8 @@ namespace ArdupilotMega public Camera() { InitializeComponent(); + + doCalc(); } void doCalc() diff --git a/Tools/ArdupilotMegaPlanner/Common.cs b/Tools/ArdupilotMegaPlanner/Common.cs index e18c1f7384..b15ebb94ad 100644 --- a/Tools/ArdupilotMegaPlanner/Common.cs +++ b/Tools/ArdupilotMegaPlanner/Common.cs @@ -48,7 +48,9 @@ namespace ArdupilotMega /// public class GMapMarkerRect : GMapMarker { - public Pen Pen; + public Pen Pen = new Pen(Brushes.White, 2); + + public Color Color { get { return Pen.Color; } set { Pen.Color = value; } } public GMapMarker InnerMarker; @@ -58,8 +60,6 @@ namespace ArdupilotMega public GMapMarkerRect(PointLatLng p) : base(p) { - Pen = new Pen(Brushes.White, 2); - Pen.DashStyle = DashStyle.Dash; // do not forget set Size of the marker @@ -75,9 +75,9 @@ namespace ArdupilotMega if (wprad == 0 || MainMap == null) return; + // undo autochange in mouse over if (Pen.Color == Color.Blue) Pen.Color = Color.White; - double width = (MainMap.Manager.GetDistance(MainMap.FromLocalToLatLng(0, 0), MainMap.FromLocalToLatLng(MainMap.Width, 0)) * 1000.0); double height = (MainMap.Manager.GetDistance(MainMap.FromLocalToLatLng(0, 0), MainMap.FromLocalToLatLng(MainMap.Height, 0)) * 1000.0); @@ -177,6 +177,7 @@ namespace ArdupilotMega public double Lng = 0; public double Alt = 0; public string Tag = ""; + public Color color = Color.White; public PointLatLngAlt(double lat, double lng, double alt, string tag) { @@ -263,7 +264,43 @@ namespace ArdupilotMega CIRCLE = 7, POSITION = 8 } - + + public static void linearRegression() + { + double[] values = { 4.8, 4.8, 4.5, 3.9, 4.4, 3.6, 3.6, 2.9, 3.5, 3.0, 2.5, 2.2, 2.6, 2.1, 2.2 }; + + double xAvg = 0; + double yAvg = 0; + + for (int x = 0; x < values.Length; x++) + { + xAvg += x; + yAvg += values[x]; + } + + xAvg = xAvg / values.Length; + yAvg = yAvg / values.Length; + + + double v1 = 0; + double v2 = 0; + + for (int x = 0; x < values.Length; x++) + { + v1 += (x - xAvg) * (values[x] - yAvg); + v2 += Math.Pow(x - xAvg, 2); + } + + double a = v1 / v2; + double b = yAvg - a * xAvg; + + Console.WriteLine("y = ax + b"); + Console.WriteLine("a = {0}, the slope of the trend line.", Math.Round(a, 2)); + Console.WriteLine("b = {0}, the intercept of the trend line.", Math.Round(b, 2)); + + Console.ReadLine(); + } + #if MAVLINK10 public static bool translateMode(string modein, ref MAVLink.__mavlink_set_mode_t mode) diff --git a/Tools/ArdupilotMegaPlanner/GCSViews/FlightData.cs b/Tools/ArdupilotMegaPlanner/GCSViews/FlightData.cs index e05f115624..a0a78e83df 100644 --- a/Tools/ArdupilotMegaPlanner/GCSViews/FlightData.cs +++ b/Tools/ArdupilotMegaPlanner/GCSViews/FlightData.cs @@ -432,7 +432,7 @@ namespace ArdupilotMega.GCSViews { if (plla == null || plla.Lng == 0 || plla.Lat == 0) break; - addpolygonmarker(plla.Tag, plla.Lng, plla.Lat, (int)plla.Alt); + addpolygonmarker(plla.Tag, plla.Lng, plla.Lat, (int)plla.Alt,plla.color); } RegeneratePolygon(); @@ -525,7 +525,7 @@ namespace ArdupilotMega.GCSViews }); } - private void addpolygonmarker(string tag, double lng, double lat, int alt) + private void addpolygonmarker(string tag, double lng, double lat, int alt, Color? color) { try { @@ -537,13 +537,18 @@ namespace ArdupilotMega.GCSViews GMapMarkerRect mBorders = new GMapMarkerRect(point); { - mBorders.InnerMarker = m; - mBorders.MainMap = gMapControl1; - try - { - mBorders.wprad = (int)float.Parse(ArdupilotMega.MainV2.config["TXT_WPRad"].ToString()); - } - catch { } + + mBorders.InnerMarker = m; + try + { + mBorders.wprad = (int)float.Parse(ArdupilotMega.MainV2.config["TXT_WPRad"].ToString()); + } + catch { } + mBorders.MainMap = gMapControl1; + if (color.HasValue) + { + mBorders.Color = color.Value; + } } polygons.Markers.Add(m); diff --git a/Tools/ArdupilotMegaPlanner/GCSViews/FlightPlanner.cs b/Tools/ArdupilotMegaPlanner/GCSViews/FlightPlanner.cs index d72d499bbd..cda5934cac 100644 --- a/Tools/ArdupilotMegaPlanner/GCSViews/FlightPlanner.cs +++ b/Tools/ArdupilotMegaPlanner/GCSViews/FlightPlanner.cs @@ -884,7 +884,7 @@ namespace ArdupilotMega.GCSViews /// /// /// - private void addpolygonmarker(string tag, double lng, double lat, int alt) + private void addpolygonmarker(string tag, double lng, double lat, int alt, Color? color) { try { @@ -900,6 +900,10 @@ namespace ArdupilotMega.GCSViews mBorders.InnerMarker = m; mBorders.wprad = (int)float.Parse(TXT_WPRad.Text); mBorders.MainMap = MainMap; + if (color.HasValue) + { + mBorders.Color = color.Value; + } } objects.Markers.Add(m); @@ -955,7 +959,7 @@ namespace ArdupilotMega.GCSViews if (objects != null) // during startup { pointlist.Add(new PointLatLngAlt(double.Parse(TXT_homelat.Text), double.Parse(TXT_homelng.Text), (int)double.Parse(TXT_homealt.Text), "Home")); - addpolygonmarker("Home", double.Parse(TXT_homelng.Text), double.Parse(TXT_homelat.Text), 0); + addpolygonmarker("Home", double.Parse(TXT_homelng.Text), double.Parse(TXT_homelat.Text), 0, null); } } else @@ -1029,8 +1033,14 @@ namespace ArdupilotMega.GCSViews if (cell4 == "?" || cell3 == "?") continue; - pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString())); - addpolygonmarker((a + 1).ToString(), double.Parse(cell4), double.Parse(cell3), (int)double.Parse(cell2)); + + if (command == (byte)MAVLink.MAV_CMD.LOITER_TIME || command == (byte)MAVLink.MAV_CMD.LOITER_TURNS || command == (byte)MAVLink.MAV_CMD.LOITER_UNLIM) { + pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString()){ color = Color.LightBlue }); + addpolygonmarker((a + 1).ToString(), double.Parse(cell4), double.Parse(cell3), (int)double.Parse(cell2) , Color.LightBlue); + } else { + pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString())); + addpolygonmarker((a + 1).ToString(), double.Parse(cell4), double.Parse(cell3), (int)double.Parse(cell2) ,null); + } avglong += double.Parse(Commands.Rows[a].Cells[Lon.Index].Value.ToString()); avglat += double.Parse(Commands.Rows[a].Cells[Lat.Index].Value.ToString()); diff --git a/Tools/ArdupilotMegaPlanner/GCSViews/Simulation.cs b/Tools/ArdupilotMegaPlanner/GCSViews/Simulation.cs index 7c22c69fa8..8843d16763 100644 --- a/Tools/ArdupilotMegaPlanner/GCSViews/Simulation.cs +++ b/Tools/ArdupilotMegaPlanner/GCSViews/Simulation.cs @@ -257,14 +257,18 @@ namespace ArdupilotMega.GCSViews { System.Diagnostics.ProcessStartInfo _procstartinfo = new System.Diagnostics.ProcessStartInfo(); _procstartinfo.WorkingDirectory = Path.GetDirectoryName(Application.ExecutablePath); - _procstartinfo.Arguments = "--realtime --suspend --nice --simulation-rate=50 --logdirectivefile=jsbsim/fgout.xml --script=jsbsim/rascal_test.xml"; + _procstartinfo.Arguments = "--realtime --suspend --nice --simulation-rate=1000 --logdirectivefile=jsbsim/fgout.xml --script=jsbsim/rascal_test.xml"; _procstartinfo.FileName = "JSBSim.exe"; // Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar + _procstartinfo.UseShellExecute = true; + //_procstartinfo.RedirectStandardOutput = true; + System.Diagnostics.Process.Start(_procstartinfo); + System.Threading.Thread.Sleep(2000); + SITLSEND = new UdpClient(simIP, 5501); } @@ -543,11 +547,15 @@ namespace ArdupilotMega.GCSViews udpdata = new byte[udpdata.Length]; try { - int recv = SimulatorRECV.ReceiveFrom(udpdata, ref Remote); + while (SimulatorRECV.Available > 0) + { + int recv = SimulatorRECV.ReceiveFrom(udpdata, ref Remote); - RECVprocess(udpdata, recv, comPort); + RECVprocess(udpdata, recv, comPort); + } + } + catch (Exception ex) { //OutputLog.AppendText("Xplanes Data Problem - You need DATA IN/OUT 3, 4, 17, 18, 19, 20\n" + ex.Message + "\n"); } - catch (Exception ex) { OutputLog.AppendText("Xplanes Data Problem - You need DATA IN/OUT 3, 4, 17, 18, 19, 20\n" + ex.Message + "\n"); } } if (MavLink != null && MavLink.Client != null && MavLink.Client.Connected && MavLink.Available > 0) { @@ -583,7 +591,7 @@ namespace ArdupilotMega.GCSViews if (hzcounttime.Second != DateTime.Now.Second) { - //Console.WriteLine("SIM hz {0}", hzcount); + Console.WriteLine("SIM hz {0}", hzcount); hzcount = 0; hzcounttime = DateTime.Now; } @@ -619,18 +627,23 @@ namespace ArdupilotMega.GCSViews { JSBSimSEND = new TcpClient(); JSBSimSEND.Client.NoDelay = true; - JSBSimSEND.Connect(simIP, simPort); + JSBSimSEND.Connect("127.0.0.1", simPort); OutputLog.AppendText("Sending to port TCP " + simPort + " (planner->sim)\n"); - System.Threading.Thread.Sleep(2000); + //JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set position/h-agl-ft 0\r\n")); - JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("info\n")); + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set position/lat-gc-deg " + MainV2.HomeLocation.Lat + "\r\n")); + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set position/long-gc-deg " + MainV2.HomeLocation.Lng + "\r\n")); - JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/phi-rad 0\n")); - JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/theta-rad 0\n")); - JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("resume\n")); + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/phi-rad 0\r\n")); + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/theta-rad 0\r\n")); + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("set attitude/psi-rad 0\r\n")); + + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("info\r\n")); + + JSBSimSEND.Client.Send(System.Text.Encoding.ASCII.GetBytes("resume\r\n")); } - catch { } + catch { Console.WriteLine("JSB console fail"); } } private void SetupUDPXplanes() @@ -1125,30 +1138,37 @@ namespace ArdupilotMega.GCSViews if (RAD_JSBSim.Checked && chkSensor.Checked) { + byte[] buffer = new byte[1500]; + while (JSBSimSEND.Client.Available > 5) + { + int read = JSBSimSEND.Client.Receive(buffer); + } byte[] sitlout = new byte[16 * 8 + 1 * 4]; // 16 * double + 1 * int int a = 0; - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.latitude), a, sitlout, a, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.longitude), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.latitude * rad2deg), a, sitlout, a, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.longitude * rad2deg), 0, sitlout, a += 8, 8); Array.Copy(BitConverter.GetBytes((double)lastfdmdata.altitude), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_north), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_east), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_X_pilot), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Y_pilot), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_north * ft2m), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.v_east * ft2m), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_X_pilot * ft2m), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Y_pilot * ft2m), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Z_pilot), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phidot), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.thetadot), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psidot), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phi), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.theta), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi), 0, sitlout, a += 8, 8); - Array.Copy(BitConverter.GetBytes((double)lastfdmdata.vcas), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.A_Z_pilot * ft2m), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phidot * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.thetadot * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psidot * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.phi * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.theta * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.psi * rad2deg), 0, sitlout, a += 8, 8); + Array.Copy(BitConverter.GetBytes((double)lastfdmdata.vcas * ft2m), 0, sitlout, a += 8, 8); + +// Console.WriteLine(lastfdmdata.theta); Array.Copy(BitConverter.GetBytes((int)0x4c56414e), 0, sitlout, a += 8, 4); - + SITLSEND.Send(sitlout, sitlout.Length); return; diff --git a/Tools/ArdupilotMegaPlanner/HUD.cs b/Tools/ArdupilotMegaPlanner/HUD.cs index f1b1267ef2..5039c8a4f9 100644 --- a/Tools/ArdupilotMegaPlanner/HUD.cs +++ b/Tools/ArdupilotMegaPlanner/HUD.cs @@ -277,8 +277,8 @@ namespace hud if (DateTime.Now.Second != countdate.Second) { countdate = DateTime.Now; - //Console.WriteLine("HUD " + count + " hz drawtime " + (huddrawtime / count) + " gl " + opengl); - if ((huddrawtime / count) > 500) + Console.WriteLine("HUD " + count + " hz drawtime " + (huddrawtime / count) + " gl " + opengl); + if ((huddrawtime / count) > 1000) opengl = false; count = 0; diff --git a/Tools/ArdupilotMegaPlanner/Log.cs b/Tools/ArdupilotMegaPlanner/Log.cs index 3934784983..1202274e75 100644 --- a/Tools/ArdupilotMegaPlanner/Log.cs +++ b/Tools/ArdupilotMegaPlanner/Log.cs @@ -121,10 +121,11 @@ namespace ArdupilotMega { MethodInvoker m = delegate() { - CHK_logs.Items.Clear(); - for (int a = 1; a <= logcount; a++) + //CHK_logs.Items.Clear(); + //for (int a = 1; a <= logcount; a++) + if (!CHK_logs.Items.Contains(logcount)) { - CHK_logs.Items.Add(a); + CHK_logs.Items.Add(logcount); } }; try @@ -189,23 +190,8 @@ namespace ArdupilotMega if (line.Contains("reset to FLY") || line.Contains("interactive setup") || line.Contains("CLI:") || line.Contains("Ardu")) { comPort.Write("logs\r"); - } - if (line.Contains("logs")) - { - Regex regex2 = new Regex(@"^([0-9]+)", RegexOptions.IgnoreCase); - if (regex2.IsMatch(line)) - { - MatchCollection matchs = regex2.Matches(line); - logcount = int.Parse(matchs[0].Groups[0].Value); - genchkcombo(logcount); - status = serialstatus.Done; - } - } - if (line.Contains("No logs")) - { status = serialstatus.Done; } - break; case serialstatus.Closefile: sw.Close(); @@ -252,6 +238,21 @@ namespace ArdupilotMega break; case serialstatus.Done: // + if (line.Contains("start") && line.Contains("end")) + { + Regex regex2 = new Regex(@"^Log ([0-9]+),", RegexOptions.IgnoreCase); + if (regex2.IsMatch(line)) + { + MatchCollection matchs = regex2.Matches(line); + logcount = int.Parse(matchs[0].Groups[1].Value); + genchkcombo(logcount); + //status = serialstatus.Done; + } + } + if (line.Contains("No logs")) + { + status = serialstatus.Done; + } break; case serialstatus.Reading: if (line.Contains("packets read") || line.Contains("Done") || line.Contains("logs enabled")) @@ -774,6 +775,7 @@ namespace ArdupilotMega System.Threading.Thread.Sleep(100); TXT_seriallog.AppendText("!!Allow 30 seconds for erase\n"); status = serialstatus.Done; + CHK_logs.Items.Clear(); } private void BUT_redokml_Click(object sender, EventArgs e) diff --git a/Tools/ArdupilotMegaPlanner/MainV2.cs b/Tools/ArdupilotMegaPlanner/MainV2.cs index eafaaa3c24..254148481a 100644 --- a/Tools/ArdupilotMegaPlanner/MainV2.cs +++ b/Tools/ArdupilotMegaPlanner/MainV2.cs @@ -1599,7 +1599,7 @@ namespace ArdupilotMega } } if (loadinglabel != null) - loadinglabel.Text = "Starting Updater"; + updatelabel(loadinglabel,"Starting Updater"); Console.WriteLine("Start " + P.StartInfo.FileName + " with " + P.StartInfo.Arguments); P.Start(); try @@ -1746,6 +1746,9 @@ namespace ArdupilotMega if (loadinglabel != null) updatelabel(loadinglabel, "Getting " + file); + // from head + long bytes = response.ContentLength; + // Create a request using a URL that can receive a post. request = WebRequest.Create(baseurl + file); // Set the Method property of the request to POST. @@ -1756,8 +1759,7 @@ namespace ArdupilotMega Console.WriteLine(((HttpWebResponse)response).StatusDescription); // Get the stream containing content returned by the server. dataStream = response.GetResponseStream(); - - long bytes = response.ContentLength; + long contlen = bytes; byte[] buf1 = new byte[1024]; @@ -1776,7 +1778,7 @@ namespace ArdupilotMega if (dt.Second != DateTime.Now.Second) { if (loadinglabel != null) - updatelabel(loadinglabel, "Getting " + file + ": " + Math.Abs(bytes) + " bytes");//(((double)(contlen - bytes) / (double)contlen) * 100).ToString("0.0") + "%"; + updatelabel(loadinglabel, "Getting " + file + ": " + (((double)(contlen - bytes) / (double)contlen) * 100).ToString("0.0") + "%"); //+ Math.Abs(bytes) + " bytes"); dt = DateTime.Now; } } diff --git a/Tools/ArdupilotMegaPlanner/Program.cs b/Tools/ArdupilotMegaPlanner/Program.cs index aab82e687e..e238cb58eb 100644 --- a/Tools/ArdupilotMegaPlanner/Program.cs +++ b/Tools/ArdupilotMegaPlanner/Program.cs @@ -26,6 +26,8 @@ namespace ArdupilotMega //MessageBox.Show("NOTE: This version may break advanced mission scripting"); + //Common.linearRegression(); + Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); try diff --git a/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs b/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs index 013c0d911d..8af3b41239 100644 --- a/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs +++ b/Tools/ArdupilotMegaPlanner/Properties/AssemblyInfo.cs @@ -34,5 +34,5 @@ using System.Resources; // by using the '*' as shown below: // [assembly: AssemblyVersion("1.0.*")] [assembly: AssemblyVersion("1.0.0.0")] -[assembly: AssemblyFileVersion("1.1.18")] +[assembly: AssemblyFileVersion("1.1.19")] [assembly: NeutralResourcesLanguageAttribute("")] diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal.xml b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal.xml index 7ec9446d08..2e2813a25b 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal.xml +++ b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal.xml @@ -55,14 +55,14 @@ 33.1 - -9.9 + -12.9 -13.1 - 1.0 - 0.8 - 0.02 - 12 - 1 + 0.8 + 0.5 + 0.1 + 480 + 100 0.0 NONE 0 @@ -70,14 +70,14 @@ 33.1 - 9.9 + 12.9 -13.1 - 1.0 - 0.8 - 0.02 - 12 - 1 + 0.8 + 0.5 + 0.1 + 480 + 100 0.0 NONE 0 @@ -86,18 +86,13 @@ 68.9 0 - - -7.8 + -3 - 1.0 - 0.8 - 0.02 - 12 - 1 + 8.0 + 5.0 + 0.1 + 480 + 100 360.0 NONE 0 diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim-set.xml b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim-set.xml index 9787a7f78a..12c2e019e8 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim-set.xml +++ b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim-set.xml @@ -123,16 +123,18 @@ dynamics model, and external 3D model. diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim.xml b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim.xml index 732420cf12..a8deb22bb2 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim.xml +++ b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Rascal110-JSBSim.xml @@ -86,7 +86,7 @@ 68.9 0 - -6.6 + -3 0.8 0.5 diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/airdata.nas b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/airdata.nas index 8322cbb169..f68112d12d 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/airdata.nas +++ b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/airdata.nas @@ -38,3 +38,35 @@ var update_airdata = func( dt ) { setprop("/accelerations/airspeed-ktps", accel_filt); } + +round10 = func(v) { + if (v == nil) return 0; + return 0.1*int(v*10); +} + +round100 = func(v) { + if (v == nil) return 0; + return 0.01*int(v*100); +} + +var update_vars = func( dt ) { + asl_ft = getprop("/position/altitude-ft"); + ground = getprop("/position/ground-elev-ft"); + agl_m = (asl_ft - ground) * 0.3048; + + setprop("/apm/altitude", round10(agl_m)); + + setprop("/apm/pitch", round10(getprop("/orientation/pitch-deg"))); + setprop("/apm/roll", round10(getprop("/orientation/roll-deg"))); + setprop("/apm/heading", round10(getprop("/orientation/heading-deg"))); + + setprop("/apm/aileron", round100(getprop("/surface-positions/right-aileron-pos-norm"))); + setprop("/apm/elevator", round100(getprop("/surface-positions/elevator-pos-norm"))); + setprop("/apm/rudder", round100(getprop("/surface-positions/rudder-pos-norm"))); + setprop("/apm/throttle", round10(getprop("/engines/engine/rpm"))); + + setprop("/apm/groundspeed", round10(0.514444444*getprop("/instrumentation/gps/indicated-ground-speed-kt"))); + + # airspeed-kt is actually in feet per second (FDM NET bug) + setprop("/apm/airspeed", round10(0.3048*getprop("/velocities/airspeed-kt"))); +} diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/main.nas b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/main.nas index 7aec75186f..765227701c 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/main.nas +++ b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/Rascal/Systems/main.nas @@ -10,6 +10,7 @@ var main_loop = func { last_time = time; update_airdata( dt ); + update_vars( dt ); update_ugear( dt ); settimer(main_loop, 0); diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/arducopter/arducopter-set.xml b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/arducopter/arducopter-set.xml index 4cd25150f5..fe8541b9ed 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/arducopter/arducopter-set.xml +++ b/Tools/ArdupilotMegaPlanner/bin/Release/aircraft/arducopter/arducopter-set.xml @@ -71,20 +71,21 @@ Arducotper UAV Model + Aircraft/arducopter/quad.nas diff --git a/Tools/ArdupilotMegaPlanner/bin/Release/mavcmd.xml b/Tools/ArdupilotMegaPlanner/bin/Release/mavcmd.xml index 8d18875db6..a1912a3368 100644 --- a/Tools/ArdupilotMegaPlanner/bin/Release/mavcmd.xml +++ b/Tools/ArdupilotMegaPlanner/bin/Release/mavcmd.xml @@ -193,9 +193,9 @@ Ser No - Repeat# - Delay (s) - PWM + PWM + Repeat# + Delay (s) @@ -431,9 +431,9 @@ Ser No - Repeat# - Delay (s) - PWM + PWM + Repeat# + Delay (s) diff --git a/Tools/ArdupilotMegaPlanner/mavcmd.xml b/Tools/ArdupilotMegaPlanner/mavcmd.xml index 8d18875db6..a1912a3368 100644 --- a/Tools/ArdupilotMegaPlanner/mavcmd.xml +++ b/Tools/ArdupilotMegaPlanner/mavcmd.xml @@ -193,9 +193,9 @@ Ser No - Repeat# - Delay (s) - PWM + PWM + Repeat# + Delay (s) @@ -431,9 +431,9 @@ Ser No - Repeat# - Delay (s) - PWM + PWM + Repeat# + Delay (s)