From 488ddaa8369436a369ddec456c87c5387935ecf0 Mon Sep 17 00:00:00 2001 From: Titan Yuan Date: Thu, 12 Sep 2024 22:57:16 -0700 Subject: [PATCH] Update the sensor at its sensing frequency --- Assets/Scripts/Interceptors/Micromissile.cs | 12 +++++------- Assets/Scripts/Missile.cs | 2 +- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/Assets/Scripts/Interceptors/Micromissile.cs b/Assets/Scripts/Interceptors/Micromissile.cs index b69acf8..4377dd4 100644 --- a/Assets/Scripts/Interceptors/Micromissile.cs +++ b/Assets/Scripts/Interceptors/Micromissile.cs @@ -6,9 +6,8 @@ public class Micromissile : Missile { [SerializeField] private float _navigationGain = 3f; // Typically 3-5 - private Vector3 _previousLOS; + private SensorOutput _sensorOutput; private Vector3 _accelerationCommand; - private float _lastUpdateTime; private double _elapsedTime = 0; protected override void UpdateMidCourse(double deltaTime) { @@ -21,16 +20,15 @@ public class Micromissile : Missile // Correct the state of the target model at the sensor frequency float sensorUpdatePeriod = 1f / _agentConfig.dynamic_config.sensor_config.frequency; - if (_elapsedTime - _lastUpdateTime >= sensorUpdatePeriod) + if (_elapsedTime >= sensorUpdatePeriod) { // TODO: Implement guidance filter to estimate state from sensor output // For now, we'll use the target's actual state - // targetModel.SetState(_target.GetState()); - _lastUpdateTime = (float)_elapsedTime; + _sensorOutput = GetComponent().Sense(_target); _elapsedTime = 0; } - // Sense the target + // Check whether the target should be considered a miss SensorOutput sensorOutput = GetComponent().Sense(_target); if(sensorOutput.velocity.range > 1000f) { this.MarkAsMiss(); @@ -38,7 +36,7 @@ public class Micromissile : Missile } // Calculate the acceleration input - accelerationInput = CalculateAccelerationCommand(sensorOutput); + accelerationInput = CalculateAccelerationCommand(_sensorOutput); } // Calculate and set the total acceleration diff --git a/Assets/Scripts/Missile.cs b/Assets/Scripts/Missile.cs index efb66ea..053a3e0 100644 --- a/Assets/Scripts/Missile.cs +++ b/Assets/Scripts/Missile.cs @@ -45,7 +45,7 @@ public class Missile : Agent Vector3 rollAxis = transform.forward; // Calculate boost acceleration - float boostAcceleration = StaticConfig.boostConfig.boostAcceleration * Physics.gravity.magnitude; + float boostAcceleration = (float)(StaticConfig.boostConfig.boostAcceleration * Constants.kGravity); Vector3 accelerationInput = boostAcceleration * rollAxis; // Calculate the total acceleration