void thermoSingleLayer::evolveRegion() { if (debug) { tabAdd(); Info<<tab.c_str()<< "thermoSingleLayer::evolveRegion()" << endl; } //kvm, if updateSubmodels occurs after solveContinuity, then vaporization and separation don't get called until after deltaRho_ has been calculated, resulting in errors updateSubmodels(); // Solve continuity for deltaRho_ solveContinuity(); for (int oCorr=0; oCorr<nOuterCorr_; oCorr++) { // Explicit pressure source contribution tmp<volScalarField> tpu(this->pu()); // Implicit pressure source coefficient tmp<volScalarField> tpp(this->pp()); // Solve for momentum for U_ tmp<fvVectorMatrix> UEqn = solveMomentum(tpu(), tpp()); // Solve energy for hs_ - also updates thermo solveEnergy(); // Film thickness correction loop for (int corr=1; corr<=nCorr_; corr++) { // Solve thickness for delta_ solveThickness(tpu(), tpp(), UEqn()); } } T_ == T(hs_); #include "diagnostics.H" // Update deltaRho_ with new delta_ deltaRho_ == delta_*rho_; // Update film wall and surface velocities updateSurfaceVelocities(); // Update film wall and surface temperatures // only need to call once? // updateSurfaceTemperatures(); // Reset source terms for next time integration resetPrimaryRegionSourceTerms(); if (debug) { Info<<tab.c_str()<< "leaving thermoSingleLayer::evolveRegion()" << endl; tabSubtract(); } }
void kinematicSingleLayer::evolveRegion() { if (debug) { InfoInFunction << endl; } // Update film coverage indicator correctAlpha(); // Update film wall and surface velocities updateSurfaceVelocities(); // Update sub-models to provide updated source contributions updateSubmodels(); // Solve continuity for deltaRho_ solveContinuity(); // Implicit pressure source coefficient - constant tmp<volScalarField> tpp(this->pp()); for (int oCorr=1; oCorr<=nOuterCorr_; oCorr++) { // Explicit pressure source contribution - varies with delta_ tmp<volScalarField> tpu(this->pu()); // Solve for momentum for U_ tmp<fvVectorMatrix> UEqn = solveMomentum(tpu(), tpp()); // Film thickness correction loop for (int corr=1; corr<=nCorr_; corr++) { // Solve thickness for delta_ solveThickness(tpu(), tpp(), UEqn()); } } // Update deltaRho_ with new delta_ deltaRho_ == delta_*rho_; // Reset source terms for next time integration resetPrimaryRegionSourceTerms(); }
void ThreadPool::runMonitorTask() { // log stat float cpuLoad = rfc_sys_getcpuload( &cpuload ); logger.logInfo( String( "execute: currentCPULoad=" ) + lastCPULoad + ", didle=" + ( int )( cpuload.idle - cpuload.pidle ) + ", dkernel=" + ( int )( cpuload.kernel - cpuload.pkernel ) + ", duser="******", dclocks=" + ( int )( cpuload.clocks - cpuload.pclocks ) ); // calculate current metrics ThreadPoolPerformance tpp( logger , threads ); tpp.gather(); // recalculate operation time if dynamic tpp.updateSpeedIfRequired( cpuLoad , lastCPULoad , ( float )maxLoadPercents , cpuload ); lastCPULoad = cpuLoad; }
void TestTools::testProfiles() { TemporaryProfile tpp("parent", m_settings); Profile parentProfile = tpp.p; TemporaryProfile tpc("child", m_settings); Profile childProfile = tpc.p; parentProfile.removeBaseProfile(); parentProfile.remove("testKey"); QCOMPARE(parentProfile.value("testKey", "none").toString(), QLatin1String("none")); parentProfile.setValue("testKey", "testValue"); QCOMPARE(parentProfile.value("testKey").toString(), QLatin1String("testValue")); childProfile.remove("testKey"); childProfile.removeBaseProfile(); QCOMPARE(childProfile.value("testKey", "none").toString(), QLatin1String("none")); childProfile.setBaseProfile("parent"); QCOMPARE(childProfile.value("testKey").toString(), QLatin1String("testValue")); // Change base profile and check if the inherited value also changes. TemporaryProfile tpf("foo", m_settings); Profile fooProfile = tpf.p; fooProfile.setValue("testKey", "gnampf"); childProfile.setBaseProfile("foo"); QCOMPARE(childProfile.value("testKey", "none").toString(), QLatin1String("gnampf")); ErrorInfo errorInfo; childProfile.setBaseProfile("SmurfAlongWithMe"); childProfile.value("blubb", QString(), &errorInfo); QVERIFY(errorInfo.hasError()); errorInfo.clear(); childProfile.setBaseProfile("parent"); parentProfile.setBaseProfile("child"); QVERIFY(!childProfile.value("blubb", QString(), &errorInfo).isValid()); QVERIFY(errorInfo.hasError()); QVERIFY(!childProfile.allKeys(Profile::KeySelectionNonRecursive).isEmpty()); errorInfo.clear(); QVERIFY(childProfile.allKeys(Profile::KeySelectionRecursive, &errorInfo).isEmpty()); QVERIFY(errorInfo.hasError()); }