diff --git a/VectoCore/VectoCore/Models/Simulation/Impl/PowertrainBuilder.cs b/VectoCore/VectoCore/Models/Simulation/Impl/PowertrainBuilder.cs index 99e3d9c798d299a95666d92386d47ab003ae6329..10424e0d97f57969b41df75c12fe57609782c032 100644 --- a/VectoCore/VectoCore/Models/Simulation/Impl/PowertrainBuilder.cs +++ b/VectoCore/VectoCore/Models/Simulation/Impl/PowertrainBuilder.cs @@ -841,7 +841,7 @@ namespace TUGraz.VectoCore.Models.Simulation.Impl .AddComponent(new AxleGear(container, data.AxleGearData)) .AddComponent(data.AngledriveData != null ? new Angledrive(container, data.AngledriveData) : null) .AddComponent(GetRetarder(RetarderType.TransmissionOutputRetarder, data.Retarder, container)) - .AddComponent(new CycleGearbox(container, data)) + .AddComponent(new BEVCycleGearbox(container, data)) .AddComponent(GetRetarder(RetarderType.TransmissionInputRetarder, data.Retarder, container)) .AddComponent(em); @@ -1095,7 +1095,7 @@ namespace TUGraz.VectoCore.Models.Simulation.Impl .AddComponent(new Brakes(container)) .AddComponent(new AxleGear(container, data.AxleGearData)) .AddComponent(data.AngledriveData != null ? new Angledrive(container, data.AngledriveData) : null) - .AddComponent(new CycleGearbox(container, data)) + .AddComponent(new BEVCycleGearbox(container, data)) .AddComponent(em); new ATClutchInfo(container); diff --git a/VectoCore/VectoCore/Models/SimulationComponent/Impl/BEVCycleGearbox.cs b/VectoCore/VectoCore/Models/SimulationComponent/Impl/BEVCycleGearbox.cs new file mode 100644 index 0000000000000000000000000000000000000000..9a3a28d684014d5431f7a99fd19dd1fbfe9509f2 --- /dev/null +++ b/VectoCore/VectoCore/Models/SimulationComponent/Impl/BEVCycleGearbox.cs @@ -0,0 +1,20 @@ +using TUGraz.VectoCommon.Models; +using TUGraz.VectoCommon.Utils; +using TUGraz.VectoCore.Models.Simulation; +using TUGraz.VectoCore.Models.Simulation.Data; + +namespace TUGraz.VectoCore.Models.SimulationComponent.Impl +{ + public class BEVCycleGearbox : CycleGearbox + { + public BEVCycleGearbox(IVehicleContainer container, VectoRunData runData) : base(container, runData) + {} + + protected override IResponse GetDisengagedResponse(Second absTime, Second dt, PerSecond outAngularVelocity) + { + var outVelocity = outAngularVelocity * ((NextGear.Gear > 0) ? ModelData.Gears[NextGear.Gear].Ratio : 1); + + return NextComponent.Request(absTime, dt, 0.SI<NewtonMeter>(), outVelocity, false); + } + } +} diff --git a/VectoCore/VectoCore/Models/SimulationComponent/Impl/CycleGearbox.cs b/VectoCore/VectoCore/Models/SimulationComponent/Impl/CycleGearbox.cs index 657aa963d1ed8d29587ff9c2a6d968b11a75c854..e9fdb78034386c9ae586841b1ab34f5985e86bad 100644 --- a/VectoCore/VectoCore/Models/SimulationComponent/Impl/CycleGearbox.cs +++ b/VectoCore/VectoCore/Models/SimulationComponent/Impl/CycleGearbox.cs @@ -346,16 +346,8 @@ namespace TUGraz.VectoCore.Models.SimulationComponent.Impl }; } - IResponse disengagedResponse; - if (GearboxType.AutomaticTransmission()) { - disengagedResponse = EngineIdleRequest(absTime, dt); - } else { - disengagedResponse = NextGear.Gear > 0 - ? NextComponent.Request( - absTime, dt, 0.SI<NewtonMeter>(), - outAngularVelocity * ModelData.Gears[NextGear.Gear].Ratio, false) - : EngineIdleRequest(absTime, dt); - } + IResponse disengagedResponse = GetDisengagedResponse(absTime, dt, outAngularVelocity); + if (TorqueConverter != null) { if (DataBus.VehicleInfo.VehicleStopped) { TorqueConverter.Locked( @@ -376,6 +368,23 @@ namespace TUGraz.VectoCore.Models.SimulationComponent.Impl return disengagedResponse; } + protected virtual IResponse GetDisengagedResponse(Second absTime, Second dt, PerSecond outAngularVelocity) + { + IResponse disengagedResponse; + + if (GearboxType.AutomaticTransmission()) { + disengagedResponse = EngineIdleRequest(absTime, dt); + } else { + disengagedResponse = (NextGear.Gear > 0) + ? NextComponent.Request( + absTime, dt, 0.SI<NewtonMeter>(), + outAngularVelocity * ((NextGear.Gear > 0) ? ModelData.Gears[NextGear.Gear].Ratio : 1), false) + : EngineIdleRequest(absTime, dt); + } + + return disengagedResponse; + } + private IResponse EngineIdleRequest(Second absTime, Second dt) { var disengagedResponse = NextComponent.Request(absTime, dt, 0.SI<NewtonMeter>(), DataBus.EngineInfo.EngineIdleSpeed, false); diff --git a/VectoCore/VectoCoreTest/Integration/BatteryElectric/BEVTimeRunTest.cs b/VectoCore/VectoCoreTest/Integration/BatteryElectric/BEVTimeRunTest.cs index 06c6d2a7576998a660a6d63bad79830454696427..36134240f504aa457848b3b65922a8f3cee632c8 100644 --- a/VectoCore/VectoCoreTest/Integration/BatteryElectric/BEVTimeRunTest.cs +++ b/VectoCore/VectoCoreTest/Integration/BatteryElectric/BEVTimeRunTest.cs @@ -32,13 +32,13 @@ namespace TUGraz.VectoCore.Tests.Integration.BatteryElectric TestCase(E2_JOB, 1, 1, 3.9969, 120.1189, TestName = "E2 BEV TimeRun MeasuredSpeed RegionalDelivery"), TestCase(E2_JOB, 2, 2, 26.2759, 143.7661, TestName = "E2 BEV TimeRun MeasuredSpeed UrbanDelivery"), - TestCase(E2_JOB, 6, 0, 1.128, 120.0374, TestName = "E2 BEV TimeRun MeasuredSpeedGear LongHaul"), - TestCase(E2_JOB, 7, 1, 4.3124, 117.0889, TestName = "E2 BEV TimeRun MeasuredSpeedGear RegionalDelivery"), - TestCase(E2_JOB, 8, 2, 28.8197, 125.4709, TestName = "E2 BEV TimeRun MeasuredSpeedGear UrbanDelivery"), + TestCase(E2_JOB, 6, 0, 1.128, 120.0309, TestName = "E2 BEV TimeRun MeasuredSpeedGear LongHaul"), + TestCase(E2_JOB, 7, 1, 4.3124, 117.0313, TestName = "E2 BEV TimeRun MeasuredSpeedGear RegionalDelivery"), + TestCase(E2_JOB, 8, 2, 28.8197, 125.1797, TestName = "E2 BEV TimeRun MeasuredSpeedGear UrbanDelivery"), - TestCase(E2_JOB, 9, 0, 1.155, 119.989, TestName = "E2 BEV TimeRun PWheel LongHaul"), - TestCase(E2_JOB, 10, 1, 4.4643, 116.9733, TestName = "E2 BEV TimeRun PWheel RegionalDelivery"), - TestCase(E2_JOB, 11, 2, 30.4811, 125.033, TestName = "E2 BEV TimeRun PWheel UrbanDelivery"), + TestCase(E2_JOB, 9, 0, 1.155, 119.9847, TestName = "E2 BEV TimeRun PWheel LongHaul"), + TestCase(E2_JOB, 10, 1, 4.4643, 116.9218, TestName = "E2 BEV TimeRun PWheel RegionalDelivery"), + TestCase(E2_JOB, 11, 2, 30.4811, 124.8204, TestName = "E2 BEV TimeRun PWheel UrbanDelivery"), TestCase(E3_JOB, 0, 0, 0.7916, 101.6194, TestName = "E3 BEV TimeRun MeasuredSpeed LongHaul"), TestCase(E3_JOB, 1, 1, 3.3777, 104.792, TestName = "E3 BEV TimeRun MeasuredSpeed RegionalDelivery"),