rawaccel/grapher/Models/Calculations/Data/AccelDataXYDirectional.cs
2021-09-07 05:08:25 -04:00

84 lines
2.7 KiB
C#

using grapher.Models.Charts;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace grapher.Models.Calculations.Data
{
public class AccelDataXYDirectional : IAccelData
{
public AccelDataXYDirectional(
EstimatedPoints xPoints,
EstimatedPoints yPoints,
AccelCalculator calculator)
{
XPoints = xPoints;
YPoints = yPoints;
Calculator = calculator;
AngleToData = new AccelChartData[Constants.AngleDivisions];
FillAngleData();
}
public AccelChartData X { get => AngleToData[0]; }
public AccelChartData Y { get => AngleToData[Constants.AngleDivisions-1]; }
public double SensitivityMax { get => X.MaxAccel; }
public double SensitivityMin { get => X.MinAccel; }
public double GainMax { get => X.MaxGain; }
public double GainMin { get => X.MinGain; }
private AccelChartData[] AngleToData { get; }
private EstimatedPoints XPoints { get; }
private EstimatedPoints YPoints { get; }
private AccelCalculator Calculator { get; }
public void CalculateDots(double x, double y, double timeInMs)
{
var outVelocity = AccelCalculator.Velocity(x, y, timeInMs);
var outAngle = Math.Atan2(Math.Abs(y),Math.Abs(x));
var nearestAngleDivision = AccelCalculator.NearestAngleDivision(outAngle);
var data = AngleToData[nearestAngleDivision];
var index = data.GetVelocityIndex(outVelocity);
var inVelocity = data.VelocityPoints.ElementAt(index).Key;
var xPoints = X.ValuesAtIndex(index);
var yPoints = Y.ValuesAtIndex(index);
XPoints.Sensitivity.Set(inVelocity, xPoints.Item1);
XPoints.Velocity.Set(inVelocity, xPoints.Item2);
XPoints.Gain.Set(inVelocity, xPoints.Item3);
YPoints.Sensitivity.Set(inVelocity, yPoints.Item1);
YPoints.Velocity.Set(inVelocity, yPoints.Item2);
YPoints.Gain.Set(inVelocity, yPoints.Item3);
}
public void Clear()
{
foreach (var data in AngleToData)
{
data.Clear();
}
}
public void CreateGraphData(ManagedAccel accel, Profile settings)
{
Clear();
Calculator.CalculateDirectional(AngleToData, accel, settings, Calculator.SimulatedDirectionalInput);
}
private void FillAngleData()
{
for(int i=0; i < Constants.AngleDivisions; i++)
{
AngleToData[i] = new AccelChartData();
}
}
}
}