Training assessment: Difference between revisions

From Opasnet
Jump to navigation Jump to search
(→‎Calculations: under construction, testing a few things)
Line 85: Line 85:
name="answer"  
name="answer"  
graphics="1"
graphics="1"
include="page:OpasnetUtils/Summary|name:summary"
>
>
library(OpasnetUtils)
library(OpasnetUtils)
library(xtable)
library(xtable)
library(ggplot2)
library(ggplot2)


net.cost <- new("ovariable",
net.cost <- new("ovariable",
Line 111: Line 113:
)
)


decisions <- opbase.data("Op_en5677.decisions")
decisions <- tidy(opbase.data("Op_en5677.decisions"))
 
# The next row should happen inside tidy but it doesn't. Why?
decisions <- decisions[ , colnames(decisions) != "Obs"]
 
# BAU options are added to each combination Decisionmaker - Decision - Variable. This should be included in the DecisionTableParser.
BAUs <- decisions[!duplicated(decisions[c("Decisionmaker", "Decision", "Variable")]), ]
BAUs$Change <- "Add"
BAUs$Result <- 0
BAUs$Option <- "BAU"
decisions <- rbind(decisions, BAUs)
 
DecisionTableParser(decisions)
DecisionTableParser(decisions)


Line 118: Line 131:
health.impact <- EvalOutput(health.impact)
health.impact <- EvalOutput(health.impact)
health.impact <- CheckDecisions(health.impact)
health.impact <- CheckDecisions(health.impact)
colnames(health.impact@output)


print(xtable(health.impact@output[1:20,]), type = "html")
#print(xtable(health.impact@output[1:20,]), type = "html")


probabilities <- new("ovariable",
probabilities <- new("ovariable",
Line 127: Line 139:
)
)


#summary(endpoints)
summary(health.impact)
#decisions
 
#summary(probabilities)
ggplot(health.impact@output, aes(x = Year, y = health.impactResult, colour = Health.promotion)) +
geom_point() +
theme_grey(base_size = 24)
 
#########################
 
#endp <- function(dectable)
dectable <- tidy(opbase.data("Op_en5677.endpoints"))
dectable
out <- health.impact@output
 
# Conditions: Constructing a list of logical vectors which correspond to those rows of our new data.frame that we want to apply
# effects on.
cond <- list()
# Build multiple condition vectors that correspond to a unique decision - option combination
for (j in 1:nrow(dectable)) {
# In the decision table format conditions are given in the "Cell"-column separated by ";".
sel1 <- strsplit(as.character(dectable[j, "Cell"]), split = ";")[[1]]
# ":" defines index - location matches as a condition.
sel2 <- strsplit(sel1, split = ":") # No need for lapply, since strsplit is a vectorized function and current list depth is 1.
# Create a list of conditions which the decision and option specific condition vector consists of.
print(sel1)
print(sel2)
selection <- list()
for (k in 1:length(sel1)) { # For each condition separated by ";"
if (length(sel2[[k]]) > 1) { # If ":" has been used for condition k
locs <- strsplit(sel2[[k]][2], split = ",")[[1]] # Split by "," for multiple locs per given index
selection[[k]] <- out[, sel2[[k]][1]] %in% locs # Match our data.frame to the condition
#print(selection)
}
}
# Match all conditions given for this decision - option combination.
selection <- as.data.frame(selection)
selection$optslice <- out[[as.character(dectable[["Decision"]][j])]] == dectable[["Option"]][j] # We only want rows where the relevant option is in use to be affected
selection <- as.matrix(selection)
cond[[j]] <- apply(
selection,
1,
all
)
}
} else { # Otherwise use given condition functions.
for (j in 1:length(dec@condition)) {
cond[[j]] <- dec@condition[[j]](variable@output)
}
}
# Effects
if (length(dec@effect) == 1 & dec@effect[[1]](variable@output) == 0) {
eff <- list()
for (j in 1:nrow(dectable)) {
eff[[j]] <- EffectPreset(dectable[["Change"]][j]) # Returns a standard function from presets defined below.
}
} else {
eff <- dec@effect
}
# Applying effects
 
for (j in 1:nrow(dectable)) {
out[
cond[[j]],
paste(variable@name, "Result", sep = "")
] <- eff[[j]](
out[
cond[[j]],
paste(variable@name, "Result", sep = "")
],
dectable[["Result"]][j]
)
}
variable@marginal <- colnames(out) %in% c(colnames(variable@output)[variable@marginal], colnames(temp2))
variable@output <- out
}
# return(variable)
#}
 
########################


</rcode>
</rcode>

Revision as of 15:24, 1 January 2013



This is a training assessment about an imaginary, simple case. The purpose is to illustrate assessment functionalities.

Scope

Question

What decisions are worth implementing in the training assessment?

Boundaries

  • Time: Year 2012 - 2020

Scenarios

  • Factory can reduce emissions, or continue business as usual.
  • School can increase health education, decrease it to save money, or continue business as usual.

Intended users

  • Anyone who wants to learn to make open assessments.

Participants

  • Main participants:
    • YMAL,
    • Summer workers of YMAL in 2012,
    • Participants of [[Decision analysis and risk management 2013}}

Answer

Conclusions

Results

Not yet available.

Rationale

The causal diagram for the training assessment.

Assessment-specific data

Decisions
Decisions(-)
ObsDecisionmakerDecisionOptionVariableCellChangeUnitAmountDescription
1FactoryCleaning.policyReduce emissionsexposureYear:2020Multiply-0.5
2SchoolHealth.promotionIncrease health educationhealth.impactYear:2020Multiply-0.9
3SchoolHealth.promotionPromotion budget reducedhealth.impactYear:2020Multiply-1.1
Probabilities
Probabilities(P)
ObsStakeholderVariableCellProbabilityDescription
1City of KuopioexposureCleaning.policy: Reduce emissions0.8
2City of KuopioexposureCleaning.policy: BAU0.2
3Factoyhealth.impactHealth.promotion: Increase health education0.1
4Factoyhealth.impactHealth.promotion: Promotion budget reduced0.4
5Factoyhealth.impactHealth.promotion: BAU0.5
Endpoints
Endpoints(-)
ObsStakeholderVariableCellModelResultDescription
1City of Kuopiohealth.impactYear:2012Weighted sum1000
2City of Kuopiohealth.impactYear:2020Weighted sum1000
3Citizenshealth.impactYear:2012Weighted sum1000
4Citizenshealth.impactYear:2020Weighted sum2000Future years are twice as important.
Variables
Analyses
  • Decision analysis on each policy: Which option minimises the health risks?
  • Value of information (VOI) analysis for each policy about the major variables in the model and the total VOI.

Calculations

+ Show code

See also

Materials and examples for training in Opasnet and open assessment
Help pages Wiki editingHow to edit wikipagesQuick reference for wiki editingDrawing graphsOpasnet policiesWatching pagesWriting formulaeWord to WikiWiki editing Advanced skills
Training assessment (examples of different objects) Training assessmentTraining exposureTraining health impactTraining costsClimate change policies and health in KuopioClimate change policies in Kuopio
Methods and concepts AssessmentVariableMethodQuestionAnswerRationaleAttributeDecisionResultObject-oriented programming in OpasnetUniversal objectStudyFormulaOpasnetBaseUtilsOpen assessmentPSSP
Terms with changed use ScopeDefinitionResultTool


  • Descriptions of a previous structure
  • ----#: . Päätöksenteon sokea piste: se mitä ihmiset eivät näe mutta eivät myöskään huomaa etteivät näe. Kuitenkin tutkimalla sitä mitä mitä ihmiset eivät näe saadaan selville asioita sokeasta pisteesta. Ymmärtämällä sokeaa pistettä voidaan keksiä asioita jotka järjestelmällisesti jäävät huomaamatta ja asioita, joilla voidaan korjata järjestelmällisiä puutteita. Avoin arviointi on tämmöinen päätöksenteon järjestelmällisten puutteiden korjausmekanismi. --Jouni 08:55, 1 May 2012 (EEST) (type: truth; paradigms: science: comment)

References


Related files

<mfanonymousfilelist></mfanonymousfilelist>