ПРИМЕЧАНИЕ. Этот вопрос относится к PrescribedSpeedPump.mo, расположенному в ThermoPower.Examples.RankineCycle.Models.PrescribedSpeedPump
Я пытаюсь простая модель насоса, так как все модели, которые я собираю, включают этот насосвсегда выдает одно и то же сообщение об ошибке:
[1] 16:02:01 Ошибка перевода [ThermoPower.PowerPlants: 2071: 95-2071: 108]: переменная q_nom не найдена в области действия ThermoPower.PowerPlants.HRSG.Components.
[2] 16:02:01 Ошибка перевода [ThermoPower.PowerPlants: 2076: 84-2076: 132]: циклически зависимые константы или параметры, найденные в области видимости: {q_nom}, {head_nom} (игнорировать с помощью-d = ignoreCycles).
После проверки этого PrescribedSpeedPump он состоит из двух классов: «FluidMedium» и «flowCharacteristic».Именно функция - FlowCharacteristic приводит к ошибке.
Почему я запутался: ошибка говорит о том, что она не может найти переменную q_nom в пути ThermoPower.PowerPlants.HRSG.Components.Ну, как упоминалось ранее, я сказал, что это находится в пакете примеров библиотеки ThermoPower.
Еще одна причина, по которой меня смущает эта ситуация, заключается в том, что я могу вручную вводить значения параметров для q_nom и head_nom.Им дали фиктивные значения {1,2,3} для них обоих.Тем не менее, переменная «не может быть найдена».
Наконец, я попытался вручную отредактировать функцию «flowCharacteristic», а затем попытался проверить мою модель.По-прежнему та же ошибка появляется.Я действительно не знаю, как устранить эту ошибку на данный момент, и попробовал то, что мне удалось придумать.
Если у вас есть какие-либо идеи или предложения, пожалуйста, не стесняйтесь оставлять комментарии ниже!Спасибо, что прочитали это далеко, я ценю ваше время и усилия в попытках помочь другим в этом сообществе.Ниже я скопировал код для моей модели насоса.
КОД ОБНОВЛЕН:
model Pump_Verified
function flowCharacteristic =
ThermoPower.Functions.PumpCharacteristics.quadraticFlow (
q_nom = q_nom, head_nom = head_nom);
ThermoPower.PowerPlants.HRSG.Components.PrescribedSpeedPump
prescribedSpeedPump1(
redeclare package WaterMedium = ThermoPower.Water.StandardWater,
Np0 = 1,
V = 20,
head_nom = {1, 2, 3},
hstart = 451024,
n0 = 1200,
nominalFlow = 142.512,
nominalInletPressure=132000,
nominalOutletPressure=8581000,
q_nom = {1, 2, 3},
rho0=1000)
annotation (
Placement(visible = true, transformation(origin = {2, 0}, extent = {{-10,
-10}, {10, 10}}, rotation = 0)));
ThermoPower.Examples.RankineCycle.Models.PrescribedPressureCondenser
Condenser(
Vtot = 50,
p = 132000) annotation (
Placement(visible = true, transformation(origin = {-50, 40}, extent =
{{-10,
-10}, {10, 10}}, rotation = 0)));
ThermoPower.PowerPlants.SteamTurbineGroup.Components.StateReader_water
stateReader_water1 annotation (
Placement(visible = true, transformation(origin = {-50, 70}, extent =
{{-10,
-10}, {10, 10}}, rotation = -90)));
ThermoPower.PowerPlants.SteamTurbineGroup.Components.StateReader_water
stateReader_water2 annotation (
Placement(visible = true, transformation(origin = {-50, 10}, extent =
{{-10,
-10}, {10, 10}}, rotation = -90)));
ThermoPower.Water.SourceMassFlow SourceSteamFlow(
T = 380.561 - 273,
h = 931235,
p0 = 1.32e5,
w0 = 142.512) annotation (
Placement(visible = true, transformation(origin = {-72, 84}, extent =
{{-10,
-10}, {10, 10}}, rotation = 0)));
ThermoPower.Water.SinkMassFlow SinkWaterFlow annotation (
Placement(visible = true, transformation(origin = {52, 0}, extent = {{-10,
-10}, {10, 10}}, rotation = 0)));
inner ThermoPower.System system annotation (
Placement(visible = true, transformation(origin = {90, 88}, extent =
{{-10,
-10}, {10, 10}}, rotation = 0)));
ThermoPower.Water.SensP sensP_Inlet annotation(
Placement(visible = true, transformation(origin = {-32, 4}, extent =
{{-10, -10}, {10, 10}}, rotation = 0)));
ThermoPower.Water.SensP sensP_Outlet annotation(
Placement(visible = true, transformation(origin = {26, 4}, extent = {{-10,
-10}, {10, 10}}, rotation = 0)));
Modelica.Blocks.Sources.Constant const(k = 1200) annotation(
Placement(visible = true, transformation(origin = {-10, 66}, extent =
{{-10, -10}, {10, 10}}, rotation = 0)));
equation
connect(const.y, prescribedSpeedPump1.pumpSpeed_rpm) annotation(
Line(points = {{2, 66}, {10, 66}, {10, 30}, {-18, 30}, {-18, 6}, {-6, 6},
{-6, 6}}, color = {0, 0, 127}));
connect(sensP_Outlet.flange, SinkWaterFlow.flange) annotation(
Line(points = {{26, 0}, {42, 0}, {42, 0}, {42, 0}}, color = {0, 0, 255}));
connect(prescribedSpeedPump1.outlet, sensP_Outlet.flange) annotation(
Line(points = {{12, 0}, {26, 0}, {26, 0}, {26, 0}}, color = {0, 0, 255}));
connect(sensP_Inlet.flange, prescribedSpeedPump1.inlet) annotation(
Line(points = {{-32, 0}, {-8, 0}, {-8, 0}, {-8, 0}}, color = {0, 0,
255}));
connect(stateReader_water2.outlet, sensP_Inlet.flange) annotation(
Line(points = {{-50, 4}, {-50, 4}, {-50, 0}, {-32, 0}, {-32, 0}}, color =
{0, 0, 255}));
connect(Condenser.waterOut, stateReader_water2.inlet) annotation(
Line(points = {{-50, 30}, {-50, 16}}, color = {0, 0, 255}));
connect(stateReader_water1.outlet, Condenser.steamIn) annotation(
Line(points = {{-50, 64}, {-50, 50}}, color = {0, 0, 255}));
connect(SourceSteamFlow.flange, stateReader_water1.inlet) annotation(
Line(points = {{-62, 84}, {-50, 84}, {-50, 76}, {-50, 76}, {-50, 76}},
color = {0, 0, 255}));
annotation (
uses(ThermoPower(version = "3.1"), Modelica(version="3.2.2")));
end Pump_Verified;