Complex Quality Improvement Network
Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)
THE COMPLEX QUALITY IMPROVEMENT NETWORK (CQIN) AGENT-BASED MODEL
This model explores the behaviour of quality improvement (QI) teams seeking improvement within a complex adaptive system. The starting point is the agent communication and cooperation underpinning the activity. Any improvement (or lack of improvement) is an emergent property of the system arising from this granular cooperative activity.
The CQIN agent-based model treats large-scale improvement activity as a network of adaptive agents cooperating to solve a problem. To cooperate effectively, agents require a shared understanding of the improvement goals, the current state of their actions, and how to progress towards the goal state. The working premise is that maintaining a shared representation of the problems, solution options, problem-solving effectiveness and progress towards goals are prerequisites to the necessary cooperation. These factors drive the probability of success and how quickly the goal state can be achieved within the unique constraints of the problem, the networked participants, and external constraints.
HOW THE CQIN MODEL WORKS
Model function is based on the idea of the spread of a virus through a computer network. In our case, it is information that is shared amongst linked neighbours. This information may then be accepted or rejected. At agent level, the behaviour is 'share', 'update' or 'reject' the information. At the system level, the spreading process, once triggered, cycles through five quality improvement phases analogous to a plan-do-study-act cycle, with the cycles proceeding through a planned number of iterations. Each completed iteration incrementally updates progress towards the 'target state'. 'Information' as used here is an abstract notion - it is whatever the relevant message is in relation to the quality improvement phase and may include acting on the information in a coordinated manner (e.g. "we need to cooperate to do this together"). Stop conditions can be set for reaching the target, maximum number of iterations, or falling below a minimum level of network cooperation.
The process commences with detection of an environmental signal of interest by a pre-determined number of the agents. Each agent with this new information then seeks to share the update with their network neighbours. Sharing follows a transmit and receive format, where the transmission must first succeed, and then also be received (or accepted). Each failed share has a chance of rejection and making the receiving agent uncooperative. For each agent interaction to be successful, a probability threshold must be exceeded. The thresholds are determined by the interaction between the variables that apply to each QI phase. A high value for the product of variable interactions results in a correspondingly high chance of sharing/cooperation; conversely, a low value for the product of the variable interaction increases the chances of rejection and reducing network cooperation.
HOW TO USE THIS MODEL
- Setup
- If generating a network, set the number of nodes, network connection type, and node degree
- If loading a network, use the "Load Network" button (refer code comments for more details)
- Generate or import the network
- Layout the network
- Set desired values for the CQIN composite factors (Initial detection, planned iterations, schema share effectiveness, problem solving capability, coevolution constraints, problem space complexity, learning gain, rejection threshold, rejection chance)
- Set the base improvement signal level, increments and target level
- Set maximum level of network dropout (non-cooperation)
- Trigger
- To complete one iteration, run Go, Go-1, Go-2, Go-3 Go-4, Go-5.Each phase will stop when all agents are updated or resistant, or a stop condition is reached.
- To run the next iteration, use 'Cycle', then repeat the 'Go' sequence
- Use behaviour space to run as an automated sequence
QUESTIONS AND ONGOING WORK
The threshold formulas are starting points based on the hypothesised relationships between the CQIN factors, quality improvement theory and literature (please refer to the research that accompanies this model). Whilst plausible and practical, they are almost certainly insufficiently defined and ongoing verification with real-world examples will refine them.
This version allows resistant actors to rejoin the network each new iteration. This is premised on each new iteration (if done well) being an opportunity to reset and try again, this time with the learning gain from the previous iteration. It is assumed there will be real-world examples where this reset may not be able to applicable.
HOW TO CITE
If you mention this model or the NetLogo software in a publication, please include the citations below.
- William Wilson (2020-2023) School of Food and Advanced Technology, Massey University, New Zealand
Related rersearch: William Wilson, Scott McLachlan, Kudakwashe Dube, Kathleen Potter & Nihal Jayamaha (2023) Uncertainty, emergence and adaptation: A complex adaptive systems approach to quality improvement, Quality Management Journal, 30:3, 168-186, DOI: 10.1080/10686967.2023.2211287
This model was inspired and adapted from:
- Stonedahl, F. and Wilensky, U. (2008). NetLogo Virus on a Network model. http://ccl.northwestern.edu/netlogo/models/VirusonaNetwork. Center for Connected Learning and Computer-Based Modeling, Northwestern University, Evanston, IL.
The original code for the two underlying ideas in the Stonedahl and Wilensky model:
;; to spread-virus ;; ask turtles with [infected?] ;; [ ask link-neighbors with [not resistant?] ;; [ if random-float 100 < virus-spread-chance ;; [ become-infected ] ] ] ;; end
;; to do-virus-checks ;; ask turtles with [infected? and virus-check-timer = 0] ;; [ ;; if random 100 < recovery-chance ;; [ ;; ifelse random 100 < gain-resistance-chance ;; [ become-resistant ] ;; [ become-susceptible ] ;; ] ;; ] ;; end
The major feature of the original retained is the idea of the schema-check function as the basis for the agents to determine their state. The CQIN model expands the number of agent states, the spreading activity via phases and iterations, input variables, creates new threshold formulas, stop conditions, output reporting and network measures.
Code for the centrality measures and the ability to import an external network graph is sourced from the Netlogo model library - 'Extensions NW General' Examples
Please cite the NetLogo software as:
- Wilensky, U. (1999). NetLogo. http://ccl.northwestern.edu/netlogo/. Center for Connected Learning and Computer-Based Modeling, Northwestern University, Evanston, IL.
COPYRIGHT AND LICENSE
Copyright 2008 Uri Wilensky.
This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. To view a copy of this license, visit https://creativecommons.org/licenses/by-nc-sa/3.0/ or send a letter to Creative Commons, 559 Nathan Abbott Way, Stanford, California 94305, USA.
Commercial licenses are also available. To inquire about commercial licenses, please contact Uri Wilensky at uri@northwestern.edu.
Comments and Questions
extensions [nw] ;; This is the netlogo network extension called from the code directed-link-breed [ directed-edges directed-edge ] ;; category of link. Only used for centrality measures undirected-link-breed [ undirected-edges undirected-edge ] ;; category of link. Only used for centrality measures Globals ;; global variables (these are the observer-level variables) [ Signal Iteration-count ] turtles-own ;; Potential agent states [ susceptible? ;; if true, the turtle will accept the new environmental signal and can be updated updated? ;; if true, the turtle has been updated with the new environmental signal agreed? ;; if true, the turtle has a shared problem-solving schema implemented? ;; if true, the turtle has implemented the agreed problem-solving action reviewed? ;; if true, the turtle has reviewed the problem solving action adjusted? ;; if true, the turtle has adjusted the problem solving action resistant? ;; if true, the turtle will resist/reject the new signal and can't be updated schema-check-timer ;; number of ticks since this turtle's last schema-check ] to setup clear-all if Network-source = "Generate" ;; This 'if' condition prevents accidently generating a network over the top of an imported network [create-network] set-current-plot "degree distribution" set signal (Signal-base + (0)) set-default-shape turtles "person" reset-ticks end to cycle ask turtles [ set color blue set adjusted? false ;;one of two end states from previous cycle set susceptible? true set resistant? false ;;one of two end states from previous cycle become-susceptible set schema-check-timer random schema-check-frequency ] set Iteration-count Iteration-count + 1 ;; tracking 1 iteration set-current-plot "Network Status" ask n-of Initial-detection-size turtles ;; this sets the initial update size [ become-updated ] ask links [ set color yellow ] end ;; Load network ;;Only used if importing a network - not used if generating the network to load-network nw:set-context turtles links nw:load-graphml "CQINTest1.graphml" ;;target graphml file must be in C:\Users\bill\OneDrive\Documents\NetLogo ;; (i.e. must be the same folder as the model) [ set size 3 set shape "person" ;; set color blue set updated? false set susceptible? true set resistant? false become-susceptible set schema-check-timer random schema-check-frequency ] reset-ticks end ;;Generate networks rather than use imported network to create-network ;; create the agent network - random or preferential attachment if network-type = "random" [setup-nodes setup-spatially-clustered-network ] if network-type = "preferential-attachment" [create-preferential-attachment ] end to setup-nodes set-default-shape turtles "person" create-turtles number-of-nodes [ ; for visual reasons, we don't put any nodes *too* close to the edges setxy (random-xcor * 0.9) (random-ycor * 0.9) set size 1.5 become-susceptible set schema-check-timer random schema-check-frequency ] end to create-preferential-attachment ;; this is the Barabasi-Albert method of creating a preferential attachment graph nw:generate-preferential-attachment turtles links (number-of-nodes) (node-degree) ;; N.B for this preferential attachment code in Netlogo the node degree represents the MINIMUM degree [ set size 2 set shape "person" set color blue set updated? false set susceptible? true set resistant? false become-susceptible set schema-check-timer random schema-check-frequency ] end to create-random-network ;; generate an Erdos-Renyi random graph nw:generate-random turtles links (number-of-nodes) (number-of-nodes * node-degree / 2 * 0.5) [ set size 1.5 set shape "person" set color blue set updated? false set susceptible? true set resistant? false ] end to layout ;; visually set out network repeat 20 [ ;; layout-spring turtles links 1 22 4 layout-spring turtles links 0.7 20 3 ;; layout-radial turtles links (turtle 0) ;; layout-circle turtles 18 ;; update-plots display ] end to setup-spatially-clustered-network let num-links (node-degree * number-of-nodes) / 2 ;; for random network node degree is average while [count links < num-links ] [ ask one-of turtles [ let choice (min-one-of (other turtles with [not link-neighbor? myself]) [distance myself]) if choice != nobody [ create-link-with choice ] ] ] ; make the network look a little prettier repeat 10 [ layout-spring turtles links 0.3 (world-width / (sqrt number-of-nodes)) 1 ] end ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; set initial signal detection;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; to trigger ;; Note that this can be repeated if desired set Iteration-count Iteration-count + 1 ;; tracking 1 iteration set-current-plot "Network Status" ask n-of Initial-detection-size turtles ;; this sets the initial update size [ become-updated ] ask links [ set color yellow ] reset-ticks end ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Underlying process sequence (The Improvement cycle phases);; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; to go ;; this is the first phase of the learning classifier cycle, detecting and assigning credit to a new environmental signal if count turtles with [resistant?] >= count turtles * max-non-co-operating [stop] if all? turtles [updated? or resistant?] [stop] if Iteration-count = Planned-iterations + 1 [stop] if Signal = Signal-target [stop ] ask turtles [ set schema-check-timer schema-check-timer + 1 if schema-check-timer >= schema-check-frequency [ set schema-check-timer 0 ] ] spread-signal do-schema-checks tick ;; nw:save-graphml "example.graphml" ;; option saves generated network to graphml format for analysis outside netlogo end to go-2 ;; this is the second phase of the learning classifier cycle, determining and agreeing available problem-solving elements and actions if count turtles with [resistant?] >= count turtles * max-non-co-operating [stop] if all? turtles [agreed? or resistant?] [ stop ] if Iteration-count = Planned-iterations + 1 [ stop ] if Signal = Signal-target [stop ] ask turtles [ set schema-check-timer schema-check-timer + 2 if schema-check-timer >= schema-check-frequency [ set schema-check-timer 0 ] ] problem-solve do-schema-checks-2 tick end to go-3 ;; this is the third phase of the learning classifier cycle, implementing problem-solving actions if count turtles with [resistant?] >= count turtles * max-non-co-operating [stop] if all? turtles [implemented? or resistant?] [ stop ] if Iteration-count = Planned-iterations + 1 [stop] if Signal = Signal-target [stop ] ask turtles [ set schema-check-timer schema-check-timer + 3 if schema-check-timer >= schema-check-frequency [ set schema-check-timer 0 ] ] implement do-schema-checks-3 tick end to go-4 ;; fourth phase of the learning classifier cycle, check/assess effectiveness, progress, unintended consequences if count turtles with [resistant?] >= count turtles * max-non-co-operating [stop] if all? turtles [reviewed? or resistant?] [ stop ] if Iteration-count = Planned-iterations + 1 [stop] if Signal = Signal-target [stop ] ask turtles [ set schema-check-timer schema-check-timer + 4 if schema-check-timer >= schema-check-frequency [ set schema-check-timer 0 ] ] review do-schema-checks-4 tick end to go-5 ;; fifth phase of the learning classifier cycle, adjusting (within intended parameters) if count turtles with [resistant?] >= count turtles * max-non-co-operating [stop] if all? turtles [adjusted? or resistant?] [ stop ] if Iteration-count = Planned-iterations + 1 [stop] if Signal = Signal-target [stop ] if Signal = Signal-target [stop ] ask turtles [ set schema-check-timer schema-check-timer + 5 if schema-check-timer >= schema-check-frequency [ set schema-check-timer 0 ] ] adjust do-schema-checks-5 tick end ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; turtle procedures (behaviour and actions);; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; to become-susceptible ;; turtle procedure set susceptible? true set updated? false set agreed? false set implemented? false set reviewed? false set adjusted? false set resistant? false set color blue end to become-updated ;; turtle procedure set updated? true set susceptible? false set agreed? false set implemented? false set reviewed? false set adjusted? false set resistant? false set color red end to become-agreed ;; turtle procedure set agreed? true set susceptible? false set updated? false set implemented? false set reviewed? false set adjusted? false set resistant? false set color green end to become-implemented ;; turtle procedure set implemented? true set susceptible? false set updated? false set agreed? false set reviewed? false set adjusted? false set resistant? false set color brown end to become-reviewed ;; turtle procedure set reviewed? true set susceptible? false set updated? false set agreed? false set implemented? false set adjusted? false set resistant? false set color pink end to become-adjusted ;; turtle procedure set adjusted? true set susceptible? false set updated? false set agreed? false set implemented? false set reviewed? false set resistant? false set color orange end to become-resistant ;; turtle procedure set susceptible? false set updated? false set agreed? false set implemented? false set reviewed? false set adjusted? false set resistant? true set color gray ask my-links [ set color gray - 2 ] end to spread-signal ask turtles with [updated?] ; n=initial detection size [ask link-neighbors with [susceptible? and not resistant?] [ if random-float 100 < (schema-share-effectiveness) * (Learning-gain ^ Iteration-count) [ become-updated ] ] ] end to problem-solve ask turtles with [updated?] ;;ask turtles with [updated? or agreed?] ;; [ask link-neighbors with [updated? and not resistant?] [ if random-float 100 < (schema-share-effectiveness) * (learning-gain ^ Iteration-count) * (problem-solving-effectiveness * (Learning-gain ^ Iteration-count)) / problem-space-complexity ;; Option 1: Rationale tbc [ become-agreed ] ] ] end to implement ask turtles with [agreed?] ;; ask turtles with [agreed? or implemented?] [ask link-neighbors with [agreed? and not resistant?] [ if random-float 100 < (schema-share-effectiveness * (learning-gain ^ Iteration-count)) * ((problem-solving-effectiveness * (Learning-gain ^ Iteration-count)) / problem-space-complexity) * ((100 - coevolution-constraints) / 100) ;; Option 1: Rationale tbc [ become-implemented ] ] ] end to review ask turtles with [implemented?] ;; ask turtles with [implemented? or reviewed?] [ask link-neighbors with [implemented? and not resistant?] [ if random-float 100 < (schema-share-effectiveness) * (Learning-gain ^ Iteration-count) [ become-reviewed ] ] ] end to adjust ask turtles with [reviewed?] ;; ask turtles with [reviewed? or adjusted?] [ask link-neighbors with [reviewed? and not resistant?] [ if random-float 100 < (schema-share-effectiveness) * (learning-gain ^ Iteration-count) * (problem-solving-effectiveness * (Learning-gain ^ Iteration-count)) / problem-space-complexity * (100 - coevolution-constraints) / 100 ;; [ become-adjusted ] ] ] end to do-schema-checks ask turtles with [updated? and schema-check-timer = 0] [ if random 100 < (rejection-threshold *(0.8 + (problem-space-complexity / 100 ))) ;; Rejection threshold hypothesised as lightly coupled to problem space complexity in this version [ ifelse random 100 < (rejection-chance *(0.8 + (problem-space-complexity / 100 ))) [become-resistant ] [become-updated] ] ] end to do-schema-checks-2 ask turtles with [updated? and schema-check-timer = 0] ;; ask turtles with [agreed? or updated? and schema-check-timer = 0] ;; ask turtles with [not resistant? and schema-check-timer = 0] [ if random 100 < (rejection-threshold *(0.8 + (problem-space-complexity / 100 ))) [ ifelse random 100 < (rejection-chance *(0.8 + (problem-space-complexity / 100 ))) [become-resistant] [become-agreed] ] ] end to do-schema-checks-3 ask turtles with [agreed? and schema-check-timer = 0] ;; ask turtles with [implemented? or agreed? and schema-check-timer = 0] ;; ask turtles with [not resistant? and schema-check-timer = 0] [ if random 100 < (rejection-threshold *(0.8 + (problem-space-complexity / 100 ))) [ ifelse random 100 < (rejection-chance *(0.8 + (problem-space-complexity / 100 ))) [become-resistant] [become-implemented] ] ] end to do-schema-checks-4 ask turtles with [implemented? and schema-check-timer = 0] ;; ask turtles with [reviewed? or implemented? and schema-check-timer = 0] ;; ask turtles with [not resistant? and schema-check-timer = 0] [ if random 100 < (rejection-threshold *(0.8 + (problem-space-complexity / 100 ))) [ ifelse random 100 < (rejection-chance *(0.8 + (problem-space-complexity / 100 ))) [become-resistant] [become-reviewed] ] ] end to do-schema-checks-5 ask turtles with [reviewed? and schema-check-timer = 0] ;; ask turtles with [adjusted? or reviewed? and schema-check-timer = 0] ;; ask turtles with [not resistant? and schema-check-timer = 0] [ if random 100 < (rejection-threshold *(0.8 + (problem-space-complexity / 100 ))) [ ifelse random 100 < (rejection-chance *(0.8 + (problem-space-complexity / 100 ))) [become-resistant] [become-adjusted] ] ] if count turtles with [resistant?] < count turtles * max-non-co-operating [set signal (Signal-base + (Signal-increment * Iteration-count))] show-signal end to show-signal output-show Signal end ;;;;;;;;;;;;;;;;;;;;;;;; ;; Centrality measures;; ;;;;;;;;;;;;;;;;;;;;;;;; ;; This section of code is from the Netlogo model library - 'Extensions NW General' Examples to-report get-links-to-use ;; Reports the link set corresponding to the value of the links-to-use combo box report ifelse-value links-to-use = "directed" [ directed-edges ] [ undirected-edges ] end to betweenness centrality [ -> nw:betweenness-centrality ] end to eigenvector centrality [ -> nw:eigenvector-centrality ] end to closeness centrality [ -> nw:closeness-centrality ] end ; Takes a centrality measure as a reporter task, runs it for all nodes ; and set labels, sizes and colors of turtles to illustrate result to centrality [ measure ] nw:set-context turtles links ask turtles [ let res (runresult measure) ; run the task for the turtle ifelse is-number? res [ set label precision res 2 set size res ; this will be normalized later ] [ ; if the result is not a number, it is because eigenvector returned false (in the case of disconnected graphs set label res set size 1 ] ] normalize-sizes-and-colors end ; We want the size of the turtles to reflect their centrality, but different measures ; give different ranges of size, so we normalize the sizes according to the formula ; below. We then use the normalized sizes to pick an appropriate color. to normalize-sizes-and-colors if count turtles > 0 [ let sizes sort [ size ] of turtles ; initial sizes in increasing order let delta last sizes - first sizes ; difference between biggest and smallest ifelse delta = 0 [ ; if they are all the same size ask turtles [ set size 1 ] ] [ ; remap the size to a range between 0.5 and 2.5 ask turtles [ set size ((size - first sizes) / delta) * 2 + 0.5 ] ] ask turtles [ set color scale-color red size 0 5 ] ; using a higher range max not to get too white... ] end ;;;;;;;;;;;;; ;; Clusters;; ;;;;;;;;;;;;; ;; This section of code from the Netlogo model library - Extensions NW General Examples ; Colorizes each node according to the community it is part of to community-detection nw:set-context turtles get-links-to-use color-clusters nw:louvain-communities end ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Highlighting and coloring of clusters ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; This section of code from the Netlogo model library - Extensions NW General Examples to color-clusters [ clusters ] ; reset all colors ask turtles [ set color gray ] ask links [ set color gray - 2 ] let n length clusters ; Generate a unique hue for each cluster let hues n-values n [ i -> (360 * i / n) ] ; loop through the clusters and colors zipped together (foreach clusters hues [ [cluster hue] -> ask cluster [ ; for each node in the cluster ; give the node the color of its cluster set color hsb hue 100 100 ; Color links contained in the cluster slightly darker than the cluster color ask my-links with [ member? other-end cluster ] [ set color hsb hue 100 75 ] ] ]) end ;; Bill Wilson Complex Quality Improvement Network (CQIN) Massey University Research Project 2020-2023 ; Reference Model: 'Virus on a network' ; Copyright 2008 Uri Wilensky. ; See Info tab for full copyright and license.
There is only one version of this model, created about 1 year ago by Bill Wilson.
Attached files
File | Type | Description | Last updated | |
---|---|---|---|---|
Complex Quality Improvement Network.png | preview | Preview for 'Complex Quality Improvement Network' | about 1 year ago, by Bill Wilson | Download |
This model does not have any ancestors.
This model does not have any descendants.