q-voter model (expressed & private opinions)

q-voter model (expressed & private opinions) preview image

1 collaborator

Tags

(This model has yet to be categorized with any tags)
Visible to everyone | Changeable by the author
Model was written in NetLogo 6.3.0 • Viewed 104 times • Downloaded 3 times • Run 0 times
Download the 'q-voter model (expressed & private opinions)' modelDownload this modelEmbed this model

Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)


Info tab cannot be displayed because of an encoding error

Comments and Questions

Please start the discussion about this model! (You'll first need to log in.)

Click to Run Model

;; Copyright Barbara Kamińska 2024;;
;; implementation of Watts-Strogatz network taken from https://github.com/fsancho/Complex-Networks-Toolbox/blob/master/Complex%20Networks%20Model%206.nlogo


globals [diss diss_1000 priv_p_1000 pub_p_1000 avg_priv avg_pub avg_diss target q-voters size_normal size_highlight]
turtles-own [priv pub]

to setup
  clear-all
  set size_normal 2
  set size_highlight 3
  ask patches [set pcolor white]
  create-turtles N [
    set size size_normal
    ifelse (random 100) < density_of_ones
    [
      set shape "pp"
      set priv 1
      set pub 1
    ]
    [
      set shape "mm"
      set priv -1
      set pub -1
    ]
  ]
  layout-circle sort turtles 14
  ;; initial wiring
  let neigh (n-values (k / 2) [ [i] -> i + 1 ])
  ifelse k < N [
  ask turtles [
    let tar who
    foreach neigh [ [i] -> create-link-with (turtle ((tar + i) mod N)) ]
  ]
  ;; rewiring
  ask links [
    let if_rewired false
    if (random-float 1) < beta[
      let node1 end1
      if [ count link-neighbors ] of node1 < (N - 1) [
        let node2 one-of turtles with [ (self != node1) and (not link-neighbor? node1)]
        ask node1 [ create-link-with node2 [ set if_rewired true ] ]
      ]
    ]
    if (if_rewired)[
      die
    ]
  ]
  ][
    display
    user-message (word "Select k < N")

  ]
  ask turtles [ set label-color black ]
  set q-voters nobody
  set priv_p_1000 []
  set pub_p_1000 []
  set diss_1000 []
  set avg_priv 0
  set avg_pub 0
  set avg_diss 0
  reset-ticks
end 

to setup-algorithm
  clear-all
  set size_normal 3
  set size_highlight 5
  ask patches [set pcolor white]
  create-turtles N [
    set size size_normal
    ifelse (random 100) < density_of_ones
    [
      set pub 1
      ifelse (random-float 1) < 0.5 [set priv 1][set priv -1]
    ]
    [
      set pub -1
      ifelse (random-float 1) < 0.5 [set priv 1][set priv -1]
    ]
  ]
  layout-circle sort turtles 12
  ;; initial wiring
  let neigh (n-values (k / 2) [ [i] -> i + 1 ])
  ifelse k < N [
  ask turtles [
    let tar who
    foreach neigh [ [i] -> create-link-with (turtle ((tar + i) mod N)) ]
  ]
  ;; rewiring
  ask links [
    let if_rewired false
    if (random-float 1) < beta[
      let node1 end1
      if [ count link-neighbors ] of node1 < (N - 1) [
        let node2 one-of turtles with [ (self != node1) and (not link-neighbor? node1)]
        ask node1 [ create-link-with node2 [ set if_rewired true ] ]
      ]
    ]
    if (if_rewired)[
      die
    ]
  ]
  ][
    display
    user-message (word "Select k < N")

  ]
  ask turtles [ set label-color black ]
  set q-voters nobody
  set-shape-visible
end 

to set-target
  set-shape-visible
  ask links [set color gray set thickness 0.1]
  set target random N
  ask turtle target
  [
    set size size_highlight
    ifelse pub = 1 [
      ifelse priv = 1
      [set shape "pp"]
      [set shape "pm"]
    ][
      ifelse priv = 1
      [set shape "mp"]
      [ set shape "mm"]
    ]
    ask my-links [set color black set thickness 0.2]
  ]
  set q-voters nobody
end 

to q-panel
  if q-voters != nobody [
    ask q-voters[
      set size size_normal
    ]
  ]
    ask turtle target [
      set size size_highlight
      if (count link-neighbors) >= q
      [
        set q-voters n-of q link-neighbors
        ask q-voters [set size size_highlight]
      ]
    ]
end 

to act
  clear-output
  ;ask q-voters [set size size_highlight]
  ifelse random-float 1 < p
  [ ;; independence
    output-print "Independence"
    ask turtle target [set pub priv]
  ]
  [ ;; conformity
    ifelse q-voters = nobody [
      display
      user-message (word "Select q-panel")
    ]
    [
      output-print "Conformity"
      ask turtle target [
      ifelse priv = pub
      [
        output-print "Compliance"
        if (all? q-voters [pub = 1]) [ask turtle target [set pub 1]]
        if (all? q-voters [pub = -1]) [ask turtle target [set pub -1]]
      ]
      [
        output-print "Disinhibitory contagion"
        ifelse priv = 1
        [if (any? q-voters with [pub = 1]) [ask turtle target [set pub 1]]]
        [if (any? q-voters with [pub = -1]) [ask turtle target [set pub -1]]]
      ]
      ]
    ]
  ]
  ask turtle target [
     ifelse pub = 1 [
       ifelse priv = 1 [set shape "pp"][set shape "pm"]
     ][
       ifelse priv = 1 [set shape "mp"][set shape "mm"]
    ]
  ]
end 

to think
  clear-output
  ifelse random-float 1 < p
  [ ;; independence
    output-print "Independence"
    ask turtle target [
      ifelse random-float 1.0 < 0.5 [set priv 1][set priv -1]
    ]
  ]
  [ ;; conformity
    ifelse q-voters = nobody [
      display
      user-message (word "Select q-panel")
    ]
    [
      output-print "Conformity"
      ask turtle target [
      ifelse pub = 1
      [
        if (all? q-voters [pub = 1]) [ask turtle target [set priv 1]]
      ]
      [
        if (all? q-voters [pub = -1]) [ask turtle target [set priv -1]]
      ]
      ]
    ]
  ]
  ask turtle target [
     ifelse pub = 1 [
       ifelse priv = 1 [set shape "pp"][set shape "pm"]
     ][
       ifelse priv = 1 [set shape "mp"][set shape "mm"]
    ]
  ]
end 

to set-shape-visible
  ask turtles [set size size_normal]
  ask turtles [
  ifelse pub = 1 [
      set shape "p"
    ][
      set shape "m"
    ]
  ]
end 

to set-shape
  ask turtles [set size size_normal]
  ask turtles [
  ifelse pub = 1 [
      ifelse priv = 1
      [set shape "pp"]
      [set shape "pm"]
    ][
      ifelse priv = 1
      [set shape "mp"]
      [ set shape "mm"]
    ]
  ]
end 

to go-AT
  ask links [set color gray set thickness 0.1]
  set-shape
  set target random N
  ask turtle target
  [
    ;; ACT
    ask my-links [set color black set thickness 0.2]
    ifelse random-float 1.0 < p
    [ ;; independence
      ask turtle target [set pub priv]
    ]
    [ ;; conformity
      ifelse (count link-neighbors) >= q [set q-voters n-of q link-neighbors][set q-voters nobody]
      if q-voters != nobody
      [
        ifelse priv = pub
        [
          if (all? q-voters [pub = 1]) [ask turtle target [set pub 1]]
          if (all? q-voters [pub = -1]) [ask turtle target [set pub -1]]
        ]
        [
          ifelse priv = 1
          [if (any? q-voters with [pub = 1]) [ask turtle target [set pub 1]]]
          [if (any? q-voters with [pub = -1]) [ask turtle target [set pub -1]]]
        ]
      ]
    ]
    ;; THINK
    ifelse random-float 1 < p
    [ ;; independence
      ask turtle target [
        ifelse random-float 1.0 < 0.5 [set priv 1][set priv -1]
      ]
    ]
    [ ;; conformity
      ifelse (count link-neighbors) >= q [set q-voters n-of q link-neighbors] [set q-voters nobody]
      if q-voters != nobody
      [
        ifelse pub = 1
        [if (all? q-voters [pub = 1]) [ask turtle target [set priv 1]]]
        [if (all? q-voters [pub = -1]) [ask turtle target [set priv -1]]]
      ]
    ]
  ]

  set diss ((count turtles with [priv = 1 and pub = -1] + count turtles with [priv = -1 and pub = 1]) / N)

  if(ticks > 1000) [
    ifelse (length diss_1000 >= 1000) [
      set pub_p_1000 lput (count turtles with [pub = 1] / N) pub_p_1000
      set pub_p_1000 (but-first pub_p_1000)
      set avg_pub ((sum pub_p_1000) / 1000)

      set priv_p_1000 lput (count turtles with [priv = 1] / N) priv_p_1000
      set priv_p_1000 (but-first priv_p_1000)
      set avg_priv ((sum priv_p_1000) / 1000)

      set diss_1000 lput diss diss_1000
      set diss_1000 (but-first diss_1000)
      set avg_diss ((sum diss_1000) / 1000)
    ] [
      set pub_p_1000 lput (count turtles with [pub = 1] / N) pub_p_1000
      set priv_p_1000 lput (count turtles with [priv = 1] / N) priv_p_1000
      set diss_1000 lput diss diss_1000
    ]
  ]
  tick
end 

to go-TA
  ask links [set color gray set thickness 0.1]
  set-shape
  set target random N
  ask turtle target
  [
    ;; THINK
    ifelse random-float 1 < p
    [ ;; independence
      ask turtle target [
        ifelse random-float 1.0 < 0.5 [set priv 1][set priv -1]
      ]
    ]
    [ ;; conformity
      ifelse (count link-neighbors) >= q [set q-voters n-of q link-neighbors] [set q-voters nobody]
      if q-voters != nobody
      [
        ifelse pub = 1
        [if (all? q-voters [pub = 1]) [ask turtle target [set priv 1]]]
        [if (all? q-voters [pub = -1]) [ask turtle target [set priv -1]]]
      ]
    ]
    ;; ACT
    ask my-links [set color black set thickness 0.2]
    ifelse random-float 1.0 < p
    [ ;; independence
      ask turtle target [set pub priv]
    ]
    [ ;; conformity
      ifelse (count link-neighbors) >= q [set q-voters n-of q link-neighbors][set q-voters nobody]
      if q-voters != nobody
      [
        ifelse priv = pub
        [
          if (all? q-voters [pub = 1]) [ask turtle target [set pub 1]]
          if (all? q-voters [pub = -1]) [ask turtle target [set pub -1]]
        ]
        [
          ifelse priv = 1
          [if (any? q-voters with [pub = 1]) [ask turtle target [set pub 1]]]
          [if (any? q-voters with [pub = -1]) [ask turtle target [set pub -1]]]
        ]
      ]
    ]

  ]

  set diss ((count turtles with [priv = 1 and pub = -1] + count turtles with [priv = -1 and pub = 1]) / N)

  if(ticks > 1000) [
    ifelse (length diss_1000 >= 1000) [
      set pub_p_1000 lput (count turtles with [pub = 1] / N) pub_p_1000
      set pub_p_1000 (but-first pub_p_1000)
      set avg_pub ((sum pub_p_1000) / 1000)

      set priv_p_1000 lput (count turtles with [priv = 1] / N) priv_p_1000
      set priv_p_1000 (but-first priv_p_1000)
      set avg_priv ((sum priv_p_1000) / 1000)

      set diss_1000 lput diss diss_1000
      set diss_1000 (but-first diss_1000)
      set avg_diss ((sum diss_1000) / 1000)
    ] [
      set pub_p_1000 lput (count turtles with [pub = 1] / N) pub_p_1000
      set priv_p_1000 lput (count turtles with [priv = 1] / N) priv_p_1000
      set diss_1000 lput diss diss_1000
    ]
  ]
  tick
end 

There is only one version of this model, created 8 months ago by Barbara Kamińska.

Attached files

File Type Description Last updated
q-voter model (expressed & private opinions).png preview Preview for 'q-voter model (expressed & private opinions)' 8 months ago, by Barbara Kamińska Download

This model does not have any ancestors.

This model does not have any descendants.