Skip to content

Commit

Permalink
4751 feat create intervention policy misc adjustments (#4902)
Browse files Browse the repository at this point in the history
Co-authored-by: dvince <dvince@uncharted.software>
  • Loading branch information
asylves1 and dvince2 authored Sep 25, 2024
1 parent d2e1ad4 commit d2e0de9
Show file tree
Hide file tree
Showing 13 changed files with 171 additions and 96 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,6 @@ export const isInterventionPoliciesValuesEqual = (
if (originalPolicy.interventions.length !== newPolicy.interventions.length) return false;

const notEqual = originalPolicy.interventions.some((intervention, index) => {
if (intervention.appliedTo !== newPolicy.interventions[index].appliedTo) return true;
if (intervention.type !== newPolicy.interventions[index].type) return true;
if (!isEqual(intervention.staticInterventions, newPolicy.interventions[index].staticInterventions)) return true;
if (!isEqual(intervention.dynamicInterventions, newPolicy.interventions[index].dynamicInterventions)) return true;
return false;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<template>
<div class="intervention-card">
<header class="flex align-items-center gap-2">
<header class="card-section">
<tera-toggleable-input :model-value="intervention.name" @update:model-value="onUpdateName($event)" tag="h6" />
<div class="flex align-items-center ml-auto">
<RadioButton
Expand All @@ -24,65 +24,101 @@
</div>
</header>
<section>
<div class="flex align-items-center flex-wrap gap-2">
Set
<section>
<Dropdown
class="type-menu"
:model-value="intervention.type"
@change="onSemanticChange"
:options="interventionSemanticOptions"
option-label="label"
option-value="value"
/>
<Dropdown
class="applied-to-menu"
:model-value="intervention.appliedTo"
@change="onAppliedToParameterChange"
:options="semanticOptions"
option-label="label"
option-value="value"
placeholder="Select"
/>
</section>
<div v-if="interventionType === 'static'" class="card-section pb-2">
Starting at day
<tera-input-number
auto-width
:model-value="intervention.staticInterventions[0].timestep"
@update:model-value="(val) => onUpdateThreshold(val, 0)"
placeholder="timestep"
/>
,
</div>
<div class="card-section">
<template v-if="interventionType === 'dynamic'">
Set
<section>
<Dropdown
class="type-menu"
:model-value="intervention.dynamicInterventions[0].type"
@change="onSemanticChange($event, 0)"
:options="interventionSemanticOptions"
option-label="label"
option-value="value"
/>
<Dropdown
class="applied-to-menu"
:model-value="intervention.dynamicInterventions[0].appliedTo"
@change="onAppliedToParameterChange($event, 0)"
:options="semanticOptions(intervention.dynamicInterventions[0].type)"
option-label="label"
option-value="value"
placeholder="Select"
/>
</section>
</template>
<!-- Static -->
<template v-if="interventionType === 'static'">
to
<template v-if="intervention.staticInterventions.length > 1">...</template>
<template v-else-if="intervention.staticInterventions.length === 1">
<template v-if="intervention.staticInterventions.length === 1">
Set
<section>
<Dropdown
class="type-menu"
:model-value="intervention.staticInterventions[0].type"
@change="onSemanticChange($event, 0)"
:options="interventionSemanticOptions"
option-label="label"
option-value="value"
/>
<Dropdown
class="applied-to-menu"
:model-value="intervention.staticInterventions[0].appliedTo"
@change="onAppliedToParameterChange($event, 0)"
:options="semanticOptions(intervention.staticInterventions[0].type)"
option-label="label"
option-value="value"
placeholder="Select"
/>
</section>
to
<tera-input-number
auto-width
:model-value="intervention.staticInterventions[0].value"
@update:model-value="(val) => onUpdateValue(val, 0)"
placeholder="value"
/>
starting at
<tera-input-number
auto-width
:model-value="intervention.staticInterventions[0].timestep"
@update:model-value="(val) => onUpdateThreshold(val, 0)"
placeholder="timestep"
/>
.
</template>

<ul v-if="intervention.staticInterventions.length > 1" class="w-full">
<li v-for="(i, index) in intervention.staticInterventions" class="flex-1" :key="index">
<div class="flex align-items-center pt-2 pb-2 gap-2">
Set
<section>
<Dropdown
class="type-menu"
:model-value="i.type"
@change="onSemanticChange($event, index)"
:options="interventionSemanticOptions"
option-label="label"
option-value="value"
/>
<Dropdown
class="applied-to-menu"
:model-value="i.appliedTo"
@change="onAppliedToParameterChange($event, index)"
:options="semanticOptions(i.type)"
option-label="label"
option-value="value"
placeholder="Select"
/>
</section>
to
<tera-input-number
auto-width
:model-value="i.value"
@update:model-value="(val) => onUpdateValue(val, index)"
placeholder="value"
/>
starting at
<tera-input-number
auto-width
:model-value="i.timestep"
@update:model-value="(val) => onUpdateThreshold(val, index)"
placeholder="timestep"
/>
.
<Button class="ml-auto" icon="pi pi-times" text @click="onRemoveStaticIntervention(index)" />
</div>
<Divider />
Expand Down Expand Up @@ -155,12 +191,12 @@ const interventionSemanticOptions = [
{ label: 'State', value: InterventionSemanticType.State }
];
const semanticOptions = computed(() => {
if (props.intervention.type === InterventionSemanticType.State) {
const semanticOptions = (type) => {
if (type === InterventionSemanticType.State) {
return props.stateOptions;
}
return props.parameterOptions;
});
};
const interventionType = computed(() => {
if (props.intervention.staticInterventions.length > 0) {
Expand All @@ -174,8 +210,8 @@ const interventionType = computed(() => {
const dynamicInterventionUnits = computed(() => {
let units = '';
const type = props.intervention.type;
const appliedTo = props.intervention.appliedTo;
const type = props.intervention.dynamicInterventions[0].type;
const appliedTo = props.intervention.dynamicInterventions[0].appliedTo;
if (type === InterventionSemanticType.Parameter) {
units = props.parameterOptions.find((parameter) => parameter.label === appliedTo)?.units ?? '';
Expand All @@ -191,16 +227,21 @@ const onUpdateName = (name: string) => {
debounceUpdateState(intervention);
};
const onAppliedToParameterChange = (event: DropdownChangeEvent) => {
const onAppliedToParameterChange = (event: DropdownChangeEvent, index: number) => {
const intervention = cloneDeep(props.intervention);
intervention.appliedTo = event.value;
const item =
interventionType.value === 'static' ? intervention.staticInterventions : intervention.dynamicInterventions;
item[index].appliedTo = event.value;
emit('update', intervention);
};
const onUpdateThreshold = (value: number, index: number) => {
const intervention = cloneDeep(props.intervention);
if (interventionType.value === 'static') {
intervention.staticInterventions[index].timestep = value;
// The timestep value is the same only for static interventions
intervention.staticInterventions.forEach((item) => {
item.timestep = value;
});
} else {
intervention.dynamicInterventions[index].threshold = value;
}
Expand All @@ -227,7 +268,9 @@ const onAddNewStaticIntervention = () => {
const intervention = cloneDeep(props.intervention);
intervention.staticInterventions.push({
timestep: Number.NaN,
value: Number.NaN
value: Number.NaN,
appliedTo: '',
type: InterventionSemanticType.Parameter
});
emit('update', intervention);
};
Expand All @@ -238,7 +281,9 @@ const onInterventionTypeChange = (value: string) => {
intervention.staticInterventions = [
{
timestep: Number.NaN,
value: Number.NaN
value: Number.NaN,
appliedTo: '',
type: InterventionSemanticType.Parameter
}
];
intervention.dynamicInterventions = [];
Expand All @@ -248,7 +293,9 @@ const onInterventionTypeChange = (value: string) => {
{
threshold: Number.NaN,
value: Number.NaN,
parameter: ''
parameter: '',
appliedTo: '',
type: InterventionSemanticType.Parameter
}
];
}
Expand All @@ -262,13 +309,15 @@ const onTargetParameterChange = (event: DropdownChangeEvent) => {
emit('update', intervention);
};
const onSemanticChange = (event: DropdownChangeEvent) => {
const onSemanticChange = (event: DropdownChangeEvent, index: number) => {
const intervention = cloneDeep(props.intervention);
intervention.type = event.value;
const item =
interventionType.value === 'static' ? intervention.staticInterventions : intervention.dynamicInterventions;
item[index].type = event.value;
if (event.value === InterventionSemanticType.State) {
intervention.appliedTo = '';
item[index].appliedTo = '';
} else {
intervention.appliedTo = '';
item[index].appliedTo = '';
}
emit('update', intervention);
};
Expand All @@ -287,6 +336,13 @@ const debounceUpdateState = debounce((intervention) => {
}
}
.card-section {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: var(--gap-2);
}
.type-menu {
border-radius: var(--border-radius) 0 0 var(--border-radius);
background: var(--surface-200);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -121,13 +121,13 @@
:key="staticIntervention.timestep"
>
<p>
Set {{ intervention.type }} {{ appliedTo }} to {{ staticIntervention.value }} at time step
{{ staticIntervention.timestep }}.
Set {{ staticIntervention.type }} {{ appliedTo }} to {{ staticIntervention.value }} at time
step {{ staticIntervention.timestep }}.
</p>
</li>
</ul>
<p v-else-if="!isEmpty(intervention.dynamicInterventions)">
Set {{ intervention.type }} {{ appliedTo }} to
Set {{ intervention.dynamicInterventions[0].type }} {{ appliedTo }} to
{{ intervention.dynamicInterventions[0].value }} when the
{{ intervention.dynamicInterventions[0].parameter }}
when it crosses the threshold value
Expand Down Expand Up @@ -279,7 +279,10 @@ const stateOptions = computed(() => {
});
const groupedOutputParameters = computed(() =>
groupBy(knobs.value.transientInterventionPolicy.interventions, 'appliedTo')
groupBy(
knobs.value.transientInterventionPolicy.interventions,
(item) => item.dynamicInterventions[0]?.appliedTo || item.staticInterventions[0]?.appliedTo
)
);
const preparedCharts = computed(() =>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -175,11 +175,9 @@ export async function getOptimizedInterventions(optimizeRunId: string) {
// From snake case -> camel case.
simulationStaticInterventions.forEach((inter) => {
const newIntervetion: Intervention = {
appliedTo: inter.applied_to,
dynamicInterventions: inter.dynamic_interventions,
name: inter.name,
staticInterventions: inter.static_interventions,
type: inter.type
staticInterventions: inter.static_interventions
};
allInterventions.push(newIntervetion);
});
Expand All @@ -199,10 +197,10 @@ export async function getOptimizedInterventions(optimizeRunId: string) {
for (let i = 0; i < paramNames.length; i++) {
allInterventions.push({
name: `Optimized ${paramNames[i]}`,
appliedTo: paramNames[i],
type: InterventionSemanticType.Parameter,
staticInterventions: [
{
appliedTo: paramNames[i],
type: InterventionSemanticType.Parameter,
timestep: policyResult[i],
value: paramValues[i]
}
Expand All @@ -215,12 +213,12 @@ export async function getOptimizedInterventions(optimizeRunId: string) {
for (let i = 0; i < paramNames.length; i++) {
allInterventions.push({
name: `Optimized ${paramNames[i]}`,
appliedTo: paramNames[i],
type: InterventionSemanticType.Parameter,
staticInterventions: [
{
timestep: startTimes[i],
value: policyResult[i]
value: policyResult[i],
appliedTo: paramNames[i],
type: InterventionSemanticType.Parameter
}
],
dynamicInterventions: []
Expand All @@ -232,12 +230,12 @@ export async function getOptimizedInterventions(optimizeRunId: string) {
for (let i = 0; i < paramNames.length; i++) {
allInterventions.push({
name: `Optimized ${paramNames[i]}`,
appliedTo: paramNames[i],
type: InterventionSemanticType.Parameter,
staticInterventions: [
{
timestep: policyResult[i * 2],
value: policyResult[i * 2 + 1]
value: policyResult[i * 2 + 1],
appliedTo: paramNames[i],
type: InterventionSemanticType.Parameter
}
],
dynamicInterventions: []
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
</aside>
</div>
<p>
Set the {{ config.intervention?.type }}&nbsp; <strong>{{ config.intervention?.appliedTo }}</strong> to
Set the {{ dynamicInterventions[0].type }}&nbsp; <strong>{{ dynamicInterventions[0].appliedTo }}</strong> to
<strong>{{ dynamicInterventions[0].threshold }}</strong> days when it crosses the threshold value
<strong>{{ dynamicInterventions[0].value }}</strong> person.
</p>
Expand Down
Loading

0 comments on commit d2e0de9

Please sign in to comment.