mirror of
https://github.com/metrostroi-repo/MetrostroiAddon.git
synced 2026-05-02 00:42:29 +00:00
Добавлены предохранители, исправления схем
Добавлены - Предохранители Обновление схем: - КРУ перенесено на 14-й провод - Контроль тормоза на 21-й провод - Запитка ВЗ-1 от АРС на 29-й провод - Небольшой фикс сопротивления резисторов Все схемы приведены к московской версии Еж3 от середины 80-ых до наших дней.
This commit is contained in:
@@ -42,7 +42,7 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
local RheostatController = Train.RheostatController
|
||||
local P = Train.PositionSwitch.SelectedPosition
|
||||
local RK = Train.RheostatController.SelectedPosition
|
||||
local B = (Train.Battery.Voltage > 55) and 1 or 0
|
||||
local B = Train.PR1.Value*((Train.Battery.Voltage > 55) and 1 or 0)
|
||||
local T = Train.SolverTemporaryVariables
|
||||
if not T then
|
||||
T = {}
|
||||
@@ -54,12 +54,13 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
local KV = Train.KV
|
||||
local KRU = Train.KRU
|
||||
local Panel = Train.Panel
|
||||
local BC = (Panel.MainLights1+Panel.MainLights2)
|
||||
|
||||
|
||||
Panel.V1 = BO
|
||||
Train:WriteTrainWire(10,B*Train.VB.Value)
|
||||
|
||||
S["10AK"] = BO*Train.VU.Value
|
||||
S["10AK"] = BO*Train.PRL24.Value*Train.VU.Value
|
||||
--10AK->AV --FIXME SAMM
|
||||
S["U2"] = S["10AK"]*KV["U2-10AK"]
|
||||
S["7G"] = BO*KV["7D-7G"]
|
||||
@@ -69,8 +70,9 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
Train:WriteTrainWire(4,S["10AK"]*KV["U2-4"])
|
||||
Train:WriteTrainWire(5,S["10AK"]*KV["U2-5"])
|
||||
Train:WriteTrainWire(6,S["10AK"]*Train.RVT.Value)
|
||||
Train:WriteTrainWire(7,BO*Train.Ring.Value)
|
||||
Train:WriteTrainWire(8,BO*KV["10-8"])
|
||||
Train:WriteTrainWire(14,BO*KV["10-14A"]*KV["14A-14B"])
|
||||
--Train:WriteTrainWire(14,BO*KV["10-14A"]*KV["14A-14B"])
|
||||
Train:WriteTrainWire(17,S["10AK"]*KV["10AK-17"]*Train.KU9.Value)
|
||||
Train:WriteTrainWire(20,S["U2"]*KV["U2-20"])
|
||||
Train:WriteTrainWire(24,S["U2"]*Train.KU8.Value)
|
||||
@@ -82,7 +84,7 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
Train.R1_5:TriggerInput("Set",S["10AK"]*Train.RV2.Value)
|
||||
Panel.AnnouncerPlaying = T[13]
|
||||
|
||||
Train:WriteTrainWire(34,Train.RKTT.Value+Train.DKPT.Value)
|
||||
Train:WriteTrainWire(21,Train.RKTT.Value+Train.DKPT.Value)
|
||||
Panel.RRP = S["U2"]*T[18]
|
||||
|
||||
local RCU = KV.RCU
|
||||
@@ -99,15 +101,13 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
Reverser:TriggerInput("VP",S["5A"]*Reverser.NZ)
|
||||
Train.LK4:TriggerInput("Set",(S["4A"]*Reverser.NZ+S["5A"]*Reverser.VP)*(1-Train.RPvozvrat.Value)*Train.LK3.Value*S["ZR"])
|
||||
|
||||
Train.PneumaticNo1:TriggerInput("Set",T[8]*C(17 <= RK and RK <= 18)+T[9])
|
||||
--Train.PneumaticNo2:TriggerInput("Set",T[8]*(1-Train.RV3.Value)*(1-Train.RT2.Value)*((1-Train.LK4.Value)+C(RK==1)))
|
||||
Train.PneumaticNo2:TriggerInput("Set",T[8]*(1-Train.RT2.Value)*((1-Train.LK4.Value)+C(RK==1)))
|
||||
Train.RV3:TriggerInput("Set",T[14])
|
||||
Train.PneumaticNo1:TriggerInput("Set",T[8]*Train.PRL23.Value*C(17 <= RK and RK <= 18)+T[29])
|
||||
Train.PneumaticNo2:TriggerInput("Set",T[8]*Train.PRL23.Value*(1-Train.RT2.Value)*((1-Train.LK4.Value)+C(RK==1)))
|
||||
|
||||
S["10A"] = BO*RCU
|
||||
self.ThyristorControllerPower = S["10A"]
|
||||
|
||||
S["10B"] = S["10A"]*(Train.RV1.Value+Train.TR1.Value)
|
||||
S["10B"] = Train.PRL16.Value*S["10A"]*(Train.RV1.Value+Train.TR1.Value)
|
||||
|
||||
--Train["RUTreg"] = T[9]
|
||||
S["10I"] = S["10A"]*RheostatController.RKM2
|
||||
@@ -126,14 +126,14 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
|
||||
--СДПП
|
||||
S["10AV"] = S["10A"]*(1-Train.LK3.Value)*C(2<=RK and RK<=18)*(1-Train.LK4.Value)
|
||||
S["10E"] = S["10A"]*((1-Train.LK3.Value)+Train.Rper.Value+Train.PositionSwitch.PMPos)
|
||||
S["10E"] = S["10A"]*Train.PRL28.Value*((1-Train.LK3.Value)+Train.Rper.Value+Train.PositionSwitch.PMPos)
|
||||
Train.SR2:TriggerInput("Set",S["10E"]*((C(P==3 or P==4)+Train.LK2.Value))*(1-Train.LK4.Value))
|
||||
|
||||
S["10AD"] = (1-Train.LK1.Value)*Train.SR2.Value
|
||||
S["10AYu"] = S["10AD"]*(1-Train.RPP.Value)
|
||||
S["10AZh"] = S["10AD"]* Train.TR1.Value*C(P==1 or P==2 or P==4)
|
||||
S["10AR"] = S["10AYu"]*(1-Train.TR1.Value)*C(2<=P and P<=4)
|
||||
S["10Ya"] = Train.LK3.Value*C(RK==18 and (P==1))
|
||||
S["10Ya"] = Train.PRL28.Value*Train.LK3.Value*C(RK==18 and (P==1))
|
||||
S["10AG"] = S["10E"]*(S["10AR"]+S["10AZh"]+S["10Ya"])
|
||||
Train.PositionSwitch:TriggerInput("MotorState",-1.0 + 2.0*math.max(0,S["10AG"]))
|
||||
|
||||
@@ -151,13 +151,14 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
Train.Rper:TriggerInput("Set",T[3]*RCU*C(17<=RK and RK<=18)*S["ZR"])
|
||||
Train.RU:TriggerInput("Set",S["2A"])
|
||||
|
||||
Train.RRU:TriggerInput("Set",T[29])
|
||||
Train.RRU:TriggerInput("Set",T[14])
|
||||
|
||||
S["6A"] = T[6]*RCU
|
||||
Train.TR1:TriggerInput("Set",S["6A"])
|
||||
Train.RPP:TriggerInput("Set",S["6A"])
|
||||
S["6G"] = S["6A"]*C(P==3 or P==4)
|
||||
S["6Yu"] = S["6G"]*C(1<=RK and RK<=2)
|
||||
--print(S["6Yu"])
|
||||
Train.KSB1:TriggerInput("Set",S["6Yu"])
|
||||
Train.KSB2:TriggerInput("Set",S["6Yu"])
|
||||
Train.RUP:TriggerInput("Set",S["6Yu"])
|
||||
@@ -168,7 +169,7 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
Train.KSH2:TriggerInput("Set",S["1R"]*S["ZR"]) --Идет обратная цепь от ЛК к 1 проводу, но мне лень
|
||||
Train.KSH1:TriggerInput("Set",S["1R"]*S["ZR"]) --Идет обратная цепь от ЛК к 1 проводу, но мне лень
|
||||
|
||||
S["1P"] = S["1A"]*C(P == 1 or P == 2)*Train.NR.Value+S["6A"]*C(P==3 or P==4)
|
||||
S["1P"] = S["1A"]*C(P == 1 or P == 2)*(Train.NR.Value+Train.RPU.Value)+S["6A"]*C(P==3 or P==4)
|
||||
Train["RUTavt"] = S["1P"]*(Train.KSB1.Value+Train.KSH2.Value)*S["ZR"] --Идет обратная цепь от ЛК к 1 проводу, но мне лень
|
||||
S["1G"] = S["1P"]*Train.AVT.Value*(1-Train.RPvozvrat.Value)
|
||||
S["1Zh"] = S["1G"]*(Train.LK3.Value+C(RK==1)*(Train.KSH2.Value+Train.KSB1.Value*Train.KSB2.Value)*C(P==1 or P==3)*Train.LK5.Value)
|
||||
@@ -183,46 +184,44 @@ function TRAIN_SYSTEM:SolveAllInternalCircuits(Train,dT,firstIter)
|
||||
Train.RKTTsh = T[30]
|
||||
|
||||
--Вспом цепи низкого напряжения
|
||||
Train:WriteTrainWire(11,BO*Train.VU2.Value)
|
||||
Train:WriteTrainWire(22,BO*Train.V1.Value*Train.AK.Value)
|
||||
Train:WriteTrainWire(11,BO*Train.VU2.Value*Train.PRL25.Value)
|
||||
Train:WriteTrainWire(22,BO*Train.PRL20.Value*Train.V1.Value*Train.AK.Value)
|
||||
Train:WriteTrainWire(23,BO*Train.KU15.Value)
|
||||
Train:WriteTrainWire(27,BO*Train.V4.Value)
|
||||
Train:WriteTrainWire(28,BO*Train.V5.Value)
|
||||
Panel.GRP = BO*Train.RPvozvrat.Value
|
||||
S["F7"] = BO*KV["F-F7"]
|
||||
Train:WriteTrainWire(27,BO*Train.PRL21.Value*Train.V4.Value)
|
||||
Train:WriteTrainWire(28,BO*Train.PRL21.Value*Train.V5.Value)
|
||||
Panel.GRP = BO*Train.PRL21.Value*Train.RPvozvrat.Value
|
||||
S["F7"] = BO*Train.PRL15.Value*KV["F-F7"]
|
||||
Panel.Headlights1 = S["F7"]
|
||||
Panel.Headlights2 = S["F7"]*Train.VU14.Value
|
||||
S["D1"] = BO*KV["D-D1"]
|
||||
Panel.RedLight1 = BO*Train.PRL26.Value*KV["B2-F1"]
|
||||
Panel.RedLight2 = BO*Train.PRL12.Value*KV["B2-F1"]
|
||||
S["D1"] = BO*Train.PRL22.Value*KV["D-D1"]
|
||||
Train:WriteTrainWire(31,S["D1"]*(Train.V6.Value+Train.KU12.Value))
|
||||
Train:WriteTrainWire(32,S["D1"]*Train.KU7.Value)
|
||||
Train:WriteTrainWire(12,S["D1"]*Train.V10.Value)
|
||||
Train:WriteTrainWire(16,S["D1"]*Train.V2.Value*Train.V3.Value)
|
||||
|
||||
Train.RPU:TriggerInput("Set",T[27])
|
||||
S["11A"] = T[11]*(1-Train.NR.Value)
|
||||
Panel.EmergencyLights1 = BO*Train.VU3.Value+S["11A"]*(1-Train.VU3.Value)
|
||||
Panel.EmergencyLights2 = S["11A"]
|
||||
Panel.MainLights1 = math.max(0,math.min(1,
|
||||
(
|
||||
self.Aux750V-100
|
||||
-self.Itotal*0.25*C(Train.PositionSwitch.SelectedPosition >= 3)
|
||||
-25*Train.KK.Value
|
||||
)/750*(0.5+0.5*B*Train.VB.Value*Train.KZ1.Value)
|
||||
))
|
||||
Panel.MainLights2 = Panel.MainLights1*Train.KO.Value
|
||||
Train.Battery:TriggerInput("Charge", Train.VB.Value*Panel.MainLights1)
|
||||
Train.KK:TriggerInput("Set",T[22]+T[23])
|
||||
Panel.EmergencyLights1 = (BO*Train.PRL21.Value*Train.VU3.Value)+(S["11A"]*(1-Train.VU3.Value))
|
||||
Panel.EmergencyLights2 = Train.PRL13.Value*S["11A"]
|
||||
Panel.Ring = (S["11A"]+T[7])*Train.PRL34.Value
|
||||
Panel.MainLights1 = math.max(0,math.min(1,(self.Aux750V*Train.PR4.Value*Train.PR9.Value-100-self.Itotal*0.25*C(Train.PositionSwitch.SelectedPosition >= 3)-25*Train.KK.Value)/750*(0.5+0.5*B*Train.VB.Value*Train.PR6.Value)))
|
||||
Panel.MainLights2 = math.max(0,math.min(1,(self.Aux750V*Train.PR4.Value*Train.KO.Value*Train.PR8.Value-100-self.Itotal*0.25*C(Train.PositionSwitch.SelectedPosition >= 3)-25*Train.KK.Value)/750*(0.5+0.5*B*Train.VB.Value*Train.PR6.Value)))
|
||||
Panel.LightPower = math.max(0,math.min(1,(self.Aux750V-100-self.Itotal*0.25*C(Train.PositionSwitch.SelectedPosition >= 3)-25*Train.KK.Value)/750*(0.5+0.5*B*Train.VB.Value*Train.PR6.Value)))
|
||||
Train.Battery:TriggerInput("Charge", Train.PR1.Value*BC*Train.PR6.Value)
|
||||
Train.KK:TriggerInput("Set",(T[22]*Train.PRL14.Value)+(T[23]*Train.PRL31.Value))
|
||||
Train.KO:TriggerInput("Close",T[27])
|
||||
Train.KO:TriggerInput("Open",T[28])
|
||||
|
||||
local BD = 1-Train.BD.Value
|
||||
Train:WriteTrainWire(15,BD*(1-Train.KU11.Value))--Заземление 15 провода
|
||||
Train.Panel.SD = (S["D1"]+BO*Train.KU11.Value)*(T[15]*(1-Train.KU11.Value)+BD)
|
||||
Train.Panel.SD = (S["D1"]+BO*Train.PRL22.Value*Train.KU11.Value)*(T[15]*(1-Train.KU11.Value)+BD)
|
||||
|
||||
Train.VDZ:TriggerInput("Set",T[16]*BD)
|
||||
Train.VDOL:TriggerInput("Set",T[31]+T[12])
|
||||
Train.VDOP:TriggerInput("Set",T[32]+T[12])
|
||||
Train.VDZ:TriggerInput("Set",T[16]*Train.PRL17.Value*BD)
|
||||
Train.VDOL:TriggerInput("Set",(T[31]*Train.PRL18.Value)+(T[12]*Train.PRL2A.Value))
|
||||
Train.VDOP:TriggerInput("Set",(T[32]*Train.PRL19.Value)+(T[12]*Train.PRL2A.Value))
|
||||
|
||||
Panel.CBKIPower = T[10]
|
||||
Panel.CBKIPower = T[10]*Train.PRL4A.Value
|
||||
end
|
||||
function TRAIN_SYSTEM:SolveRKInternalCircuits(Train,dT,firstIter)
|
||||
local RheostatController = Train.RheostatController
|
||||
@@ -282,7 +281,7 @@ function TRAIN_SYSTEM:SolveRKInternalCircuits(Train,dT,firstIter)
|
||||
return S
|
||||
end
|
||||
|
||||
local wires = {1,2,3,4,5,6,8,10,9,13,14,17,18,20,25,11,12,15,16,22,23,24,27,28,29,30,31,32}
|
||||
local wires = {1,2,3,4,5,6,7,8,10,9,13,14,17,18,20,25,11,12,15,16,21,-21,22,23,24,27,28,29,30,31,32}
|
||||
function TRAIN_SYSTEM:SolveInternalCircuits(Train,dT,firstIter)
|
||||
local T = Train.SolverTemporaryVariables
|
||||
if not T then
|
||||
|
||||
Reference in New Issue
Block a user