using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespace grapher { public partial class RawAcceleration : Form { public RawAcceleration() { InitializeComponent(); var managedAccel = new ManagedAccel(6, 0, 1, 0.025, 0); var orderedPoints = new SortedDictionary(); for (int i = 0; i < 100; i++) { for (int j = 0; j <= i; j++) { var output = managedAccel.Accelerate(i, j, 1, 6); var inMagnitude = Magnitude(i,j); var outMagnitude = Magnitude(output.Item1, output.Item2); var ratio = inMagnitude > 0 ? outMagnitude / inMagnitude : 0; if (!orderedPoints.ContainsKey(inMagnitude)) { orderedPoints.Add(inMagnitude, ratio); } } } var series = this.AccelerationChart.Series.FirstOrDefault(); series.Points.Clear(); foreach (var point in orderedPoints) { series.Points.AddXY(point.Key, point.Value); } this.AccelerationChart.ChartAreas[0].AxisX.RoundAxisValues(); } public static double Magnitude(int x, int y) { return Math.Sqrt(x * x + y * y); } public static double Magnitude(double x, double y) { return Math.Sqrt(x * x + y * y); } private void Form1_Load(object sender, EventArgs e) { } } }