From c4f9522ef34849ed4cf52a6b65789cbb77ade79b Mon Sep 17 00:00:00 2001 From: Ralf Sieger Date: Mon, 18 Nov 2024 16:36:04 +0100 Subject: [PATCH] loop iterations are now deterministic --- .../DeltaIoTNetworkReconfiguration.qvto | 68 ++++++++++--------- 1 file changed, 36 insertions(+), 32 deletions(-) diff --git a/examples/org.palladiosimulator.envdyn.examples.deltaiot/src/main/resources/org/palladiosimulator/envdyn/examples/deltaiot/reconfigurations/DeltaIoTNetworkReconfiguration.qvto b/examples/org.palladiosimulator.envdyn.examples.deltaiot/src/main/resources/org/palladiosimulator/envdyn/examples/deltaiot/reconfigurations/DeltaIoTNetworkReconfiguration.qvto index 8961693..807c056 100644 --- a/examples/org.palladiosimulator.envdyn.examples.deltaiot/src/main/resources/org/palladiosimulator/envdyn/examples/deltaiot/reconfigurations/DeltaIoTNetworkReconfiguration.qvto +++ b/examples/org.palladiosimulator.envdyn.examples.deltaiot/src/main/resources/org/palladiosimulator/envdyn/examples/deltaiot/reconfigurations/DeltaIoTNetworkReconfiguration.qvto @@ -45,24 +45,26 @@ transformation adaptDeltaIoTNetwork(inout pcmRepository : PCM_REP, inout pcmSyst log('Start to adjust distribution factors'); - reconfParamRepo.rootObjects()[DeltaIoTReconfigurationParamRepository].allSubobjects()[DistributionFactor]->forEach(factor) { - pcmRepository.rootObjects()[Repository].allSubobjects()[BasicComponent]->forEach(component) { - if factor.appliedComponent.id = component.id then { - log('Found target component ' + component.entityName + ' for distribution factor adjustement.'); - - factor.factorValues->forEach(value) { - var branchToAdjust : ProbabilisticBranchTransition := component.serviceEffectSpecifications__BasicComponent - .allSubobjects()[ProbabilisticBranchTransition]->any(entityName = value.appliedBranch.entityName); + reconfParamRepo.rootObjects()[DeltaIoTReconfigurationParamRepository]->forEach(paramRepo) { + paramRepo.distributionFactors->forEach(factor) { + pcmRepository.rootObjects()[Repository].allSubobjects()[BasicComponent]->forEach(component) { + if factor.appliedComponent.id = component.id then { + log('Found target component ' + component.entityName + ' for distribution factor adjustement.'); - assert fatal(branchToAdjust != null) with log('The found component ' + component.entityName + ' does not include the branch to adjust; as specified in the reconfiguration params.'); - - branchToAdjust.branchProbability := branchToAdjust.branchProbability + value.value; - log('[adaptDeltaIoTNetwork distributionFactor: set branchProbability of ProbabilisticBranchTransition ' + branchToAdjust.entityName + ' to value:' + branchToAdjust.branchProbability.toString() + ']'); - }; - } - endif - }; - }; + factor.factorValues->forEach(value) { + var branchToAdjust : ProbabilisticBranchTransition := component.serviceEffectSpecifications__BasicComponent + .allSubobjects()[ProbabilisticBranchTransition]->any(entityName = value.appliedBranch.entityName); + + assert fatal(branchToAdjust != null) with log('The found component ' + component.entityName + ' does not include the branch to adjust; as specified in the reconfiguration params.'); + + branchToAdjust.branchProbability := branchToAdjust.branchProbability + value.value; + log('[adaptDeltaIoTNetwork distributionFactor: set branchProbability of ProbabilisticBranchTransition ' + branchToAdjust.entityName + ' to value:' + branchToAdjust.branchProbability.toString() + ']'); + }; + } + endif + }; + }; + }; } /** @@ -72,21 +74,23 @@ transformation adaptDeltaIoTNetwork(inout pcmRepository : PCM_REP, inout pcmSyst log('Start to adjust settings of transmission power.'); - reconfParamRepo.rootObjects()[DeltaIoTReconfigurationParamRepository].allSubobjects()[TransmissionPower]->forEach(powerSetting) { - pcmSystem.rootObjects()[System].allSubobjects()[AssemblyContext]->forEach(assembly) { - if powerSetting.appliedAssembly.id = assembly.id then { - log('Found target assembly ' + assembly.entityName + ' for transmission power adjustement.'); - powerSetting.transmissionPowerValues->forEach(value) { - var variableUsage : VariableUsage := assembly.configParameterUsages__AssemblyContext->any(namedReference__VariableUsage.referenceName = value.variableRef.referenceName); - var variableToAdjust : PCMRandomVariable := variableUsage.variableCharacterisation_VariableUsage->asSequence()->first().specification_VariableCharacterisation; - - assert fatal(variableToAdjust != null) with log('The found assembly ' + assembly.entityName + ' does not include the power settings to adjust; as specified in the reconfiguration params.'); - - variableToAdjust.specification := value.powerSetting.toString(); - log('[adaptDeltaIoTNetwork transmissionPower: set assembly ' + assembly.entityName + ' specification to ' + variableToAdjust.specification.toString()); - }; - } - endif + reconfParamRepo.rootObjects()[DeltaIoTReconfigurationParamRepository]->forEach(paramRepo) { + paramRepo.transmissionPower->forEach(powerSetting) { + pcmSystem.rootObjects()[System].allSubobjects()[AssemblyContext]->forEach(assembly) { + if powerSetting.appliedAssembly.id = assembly.id then { + log('Found target assembly ' + assembly.entityName + ' for transmission power adjustement.'); + powerSetting.transmissionPowerValues->forEach(value) { + var variableUsage : VariableUsage := assembly.configParameterUsages__AssemblyContext->any(namedReference__VariableUsage.referenceName = value.variableRef.referenceName); + var variableToAdjust : PCMRandomVariable := variableUsage.variableCharacterisation_VariableUsage->asSequence()->first().specification_VariableCharacterisation; + + assert fatal(variableToAdjust != null) with log('The found assembly ' + assembly.entityName + ' does not include the power settings to adjust; as specified in the reconfiguration params.'); + + variableToAdjust.specification := value.powerSetting.toString(); + log('[adaptDeltaIoTNetwork transmissionPower: set assembly ' + assembly.entityName + ' specification to ' + variableToAdjust.specification.toString()); + }; + } + endif + }; }; }; }