Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Schedule API #10848

Open
wants to merge 33 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
2d1b4c3
Initial commit, pre develop merge.
amirroth Dec 5, 2024
6a339a8
Merge develop, resolve conflicts
amirroth Dec 6, 2024
d0b7ff9
First round of fixes
amirroth Dec 7, 2024
1272641
Fix EMS issues and several others
amirroth Dec 8, 2024
0a5be5d
Fix a few more issues
amirroth Dec 9, 2024
ed1b393
Doh, forgot to update some unit test files
amirroth Dec 9, 2024
aa645ef
One more
amirroth Dec 9, 2024
b8b9473
Fix some audit, rdd, and eio diffs
amirroth Dec 9, 2024
72066d1
Fix accumulation/averaging issue
amirroth Dec 10, 2024
5f69976
Changing to std::vector for debugging purposes
amirroth Dec 11, 2024
60706a3
Spell out std::find, std::fill, and std::accumulate so that we can us…
amirroth Dec 11, 2024
1c1ead8
Moving a few more std::find's to loops
amirroth Dec 11, 2024
7b4e5a4
I'm officially starting to lose it
amirroth Dec 12, 2024
98978bd
Fix a few more memory issues and crashes
amirroth Dec 13, 2024
bc4d001
This one was a doozy, lAlphaFieldBlanks is true if the field was left…
amirroth Dec 13, 2024
e4974ba
Two more fixes, thanks rraustad
amirroth Dec 14, 2024
3e020e2
This pump fix was pervasive
amirroth Dec 14, 2024
aaac698
Dag nabbit
amirroth Dec 14, 2024
aa9851e
Plugging away
amirroth Dec 14, 2024
aa03507
Fix EMS issue
amirroth Dec 16, 2024
04e1872
VRF fix
amirroth Dec 16, 2024
4f8a09e
More fixes from RRaustad
amirroth Dec 18, 2024
0fe2ff0
ZoneContaminant and format fixes
amirroth Dec 18, 2024
33b94a9
More fixes, or maybe just changes
amirroth Dec 18, 2024
dfc8545
One step back
amirroth Dec 20, 2024
13c52af
Address nullptr-based failures
amirroth Dec 20, 2024
4243a37
Fix more crashes and diffs
amirroth Dec 20, 2024
278e872
Merge remote-tracking branch 'origin/develop' into ScheduleAPI
amirroth Dec 21, 2024
c6833bb
WalkIn freezer fix
amirroth Dec 21, 2024
d26c66d
A few cases that didn't pass visual code inspection
amirroth Dec 23, 2024
7d637f2
Got a little too exuberant
amirroth Dec 23, 2024
1d11ff5
Merge develop
Jan 8, 2025
fd772e2
Merge develop; resolve conflicts
Jan 10, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/EnergyPlus/AirflowNetwork/src/Solver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9880,7 +9880,7 @@ namespace AirflowNetwork {
// Note in the following that individual venting control for a window/door takes
// precedence over zone-level control
if (MultizoneSurfaceData(i).IndVentControl) {
VentTemp = MultizoneSurfaceData(i).ventTempControlSched->getCurrentVal();
VentTemp = MultizoneSurfaceData(i).ventTempControlSched ? MultizoneSurfaceData(i).ventTempControlSched->getCurrentVal() : 0.0;
VentCtrlNum = MultizoneSurfaceData(i).VentSurfCtrNum;
if (MultizoneSurfaceData(i).ventAvailSched != nullptr) {
VentingSchVal = MultizoneSurfaceData(i).ventAvailSched->getCurrentVal();
Expand Down
8 changes: 4 additions & 4 deletions src/EnergyPlus/InternalHeatGains.cc
Original file line number Diff line number Diff line change
Expand Up @@ -3222,18 +3222,18 @@ namespace InternalHeatGains {
} else {
print(state.files.eio, "N/A,");
}
print(state.files.eio, "{},", people.workEffSched->Name);
print(state.files.eio, "{},", people.workEffSched ? people.workEffSched->Name : "");

print(state.files.eio, clothingTypeEIOStrings[static_cast<int>(people.clothingType)]);
print(state.files.eio, clothingTypeEIOStrings[(int)people.clothingType]);

if (people.clothingType == ClothingType::CalculationSchedule) {
print(state.files.eio, "{},", people.clothingMethodSched->Name);
} else {
print(state.files.eio, "N/A,");
}

print(state.files.eio, "{},", people.clothingSched->Name);
print(state.files.eio, "{},", people.airVelocitySched->Name);
print(state.files.eio, "{},", people.clothingSched ? people.clothingSched->Name : "");
print(state.files.eio, "{},", people.airVelocitySched ? people.airVelocitySched->Name : "");

print(state.files.eio, "{},", yesNoNames[(int)people.Fanger]);
print(state.files.eio, "{},", yesNoNames[(int)people.Pierce]);
Expand Down
4 changes: 2 additions & 2 deletions src/EnergyPlus/PlantCentralGSHP.cc
Original file line number Diff line number Diff line change
Expand Up @@ -2883,7 +2883,7 @@ void WrapperSpecs::CalcWrapperModel(EnergyPlusData &state, Real64 &MyLoad, int c

HWOutletTemp = HWInletTemp;

if (this->ancillaryPowerSched->getCurrentVal() > 0) {
if (this->ancillaryPowerSched != nullptr) {
WrapperElecPowerCool += (this->AncillaryPower * this->ancillaryPowerSched->getCurrentVal());
}

Expand Down Expand Up @@ -3275,7 +3275,7 @@ void WrapperSpecs::CalcWrapperModel(EnergyPlusData &state, Real64 &MyLoad, int c
CHWOutletTemp = CHWInletTemp;

// Add ancilliary power if necessary
if (this->ancillaryPowerSched->getCurrentVal() > 0) {
if (this->ancillaryPowerSched != nullptr) {
WrapperElecPowerHeat += (this->AncillaryPower * this->ancillaryPowerSched->getCurrentVal());
}

Expand Down
4 changes: 2 additions & 2 deletions src/EnergyPlus/Pumps.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1816,8 +1816,8 @@ void CalcPumps(EnergyPlusData &state, int const PumpNum, Real64 const FlowReques
// Get RPM value for reporting as output
// RPM is calculated using pump affinity laws for rotation speed
if (thisPumpPlant.UsePressureForPumpCalcs && thisPump.HasVFD) {
RotSpeed_Min = thisPump.VFD.minRPMSched->getCurrentVal();
RotSpeed_Max = thisPump.VFD.maxRPMSched->getCurrentVal();
RotSpeed_Min = thisPump.VFD.minRPMSched ? thisPump.VFD.minRPMSched->getCurrentVal() : 0.0;
RotSpeed_Max = thisPump.VFD.maxRPMSched ? thisPump.VFD.maxRPMSched->getCurrentVal() : 0.0;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm surprised this would crash. If HasVFD = true then min/maxRPMSched must be valid schedules.

if (thisPump.PumpMassFlowRateMaxRPM < DataBranchAirLoopPlant::MassFlowTolerance ||
thisPump.PumpMassFlowRateMinRPM < DataBranchAirLoopPlant::MassFlowTolerance) {
thisPump.VFD.PumpActualRPM = 0.0;
Expand Down
10 changes: 5 additions & 5 deletions src/EnergyPlus/SQLiteProcedures.cc
Original file line number Diff line number Diff line change
Expand Up @@ -2314,13 +2314,13 @@ bool SQLite::NominalPeople::insertIntoSQLite(sqlite3_stmt *insertStmt)
sqliteBindText(insertStmt, 2, name);
sqliteBindForeignKey(insertStmt, 3, zonePtr);
sqliteBindDouble(insertStmt, 4, numberOfPeople);
sqliteBindForeignKey(insertStmt, 5, numberOfPeopleSched->Num);
sqliteBindForeignKey(insertStmt, 6, activityLevelSched->Num);
sqliteBindForeignKey(insertStmt, 5, numberOfPeopleSched ? numberOfPeopleSched->Num : -1);
sqliteBindForeignKey(insertStmt, 6, activityLevelSched ? activityLevelSched->Num : -1);
sqliteBindDouble(insertStmt, 7, fractionRadiant);
sqliteBindDouble(insertStmt, 8, fractionConvected);
sqliteBindForeignKey(insertStmt, 9, workEffSched->Num);
sqliteBindForeignKey(insertStmt, 10, clothingSched->Num);
sqliteBindForeignKey(insertStmt, 11, airVelocitySched->Num);
sqliteBindForeignKey(insertStmt, 9, workEffSched ? workEffSched->Num : -1);
sqliteBindForeignKey(insertStmt, 10, clothingSched ? clothingSched->Num : -1);
sqliteBindForeignKey(insertStmt, 11, airVelocitySched ? airVelocitySched->Num : -1);
sqliteBindLogical(insertStmt, 12, fanger);
sqliteBindLogical(insertStmt, 13, pierce);
sqliteBindLogical(insertStmt, 14, ksu);
Expand Down
18 changes: 16 additions & 2 deletions src/EnergyPlus/ScheduleManager.cc
Original file line number Diff line number Diff line change
Expand Up @@ -752,6 +752,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((daySched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -806,6 +808,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((daySched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -879,6 +883,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((daySched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -1072,6 +1078,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((sched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == 0) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -1199,7 +1207,6 @@ namespace Sched {
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");

} else if ((sched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -1779,10 +1786,11 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) { // No warning here for constant schedules
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((sched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");

}

sched->currentVal = Numbers(1);
Expand Down Expand Up @@ -1828,6 +1836,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((sched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -1894,6 +1904,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((sched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down Expand Up @@ -1960,6 +1972,8 @@ namespace Sched {

// Validate ScheduleType
if (lAlphaBlanks(2)) {
ShowWarningEmptyField(state, eoh, cAlphaFields(2));
ShowContinueError(state, "Schedule will not be validated.");
} else if ((sched->schedTypeNum = GetScheduleTypeNum(state, Alphas(2))) == SchedNum_Invalid) {
ShowWarningItemNotFound(state, eoh, cAlphaFields(2), Alphas(2));
ShowContinueError(state, "Schedule will not be validated.");
Expand Down
Loading