Cultural Diffusion of Programming Languages
Model was written in NetLogo 5.0.5
•
Viewed 636 times
•
Downloaded 44 times
•
Run 0 times
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
; A Model of Cultural Diffusion of Programming Languages ; Sergi Valverde and Ricard Solé ; May, 15th (2015) ; The array extension requires Netlogo 5.0 extensions [array] globals [ num-iter max-capacity census ] patches-own [ ; the programming culture of a developer is described by a list holding up to 'max-capacity' languages langj ] to setup set num-iter 0 set max-capacity 3 set census array:from-list n-values ( 1 + MaxLang ) [5] ; set empty lists ask patches [ ; set langj (list (1 + random MaxLang ) (1 + random MaxLang ) ( 1 + random MaxLang )) set langj (list) ] transfer_colormap end to plot-census clear-plot ; foreach n-values array:length census [?] let llista sort-by > array:to-list census foreach llista [ plot log ? 10 ] end to transfer_colormap ask patches [ let langs sort-by > langj let r 0 let g 0 let b 0 let len length langs if len > 0 [ set r (item 0 langs) / (1 + MaxLang) ] if len > 1 [ set g (item 1 langs) / (1 + MaxLang) ] if len > 2 [ set b (item 2 langs) / (1 + MaxLang) ] set pcolor rgb (255.0 * r) (255.0 * g) (255.0 * b) ] end ; Weighted random draw from a list, options: ; 1) Use the NetLogo/Rnd-Extension ; 2) http://stackoverflow.com/questions/22615519/netlogo-weighted-random-draw-from-a-list-how-to-use-rnd-extension to-report weighted-rand-index2 [ values probs ] let i -1 let found false let nc length probs while [(not found) ] [ set i random nc let p item i probs if ( random-float 1.0 < p ) or ( p >= 0.9999999999 ) [ set found true ] ] report i end ; this is executed in patch context to-report least-frequent-known [lan C ] ; langj census if C = 0 [ ; Is this a "Memento" world? report -1 ] if length lan = 0 [ ; An ignorant programmer? report -1 ] if length lan = 1 [ report 0 ] let prob map [ 1.0 - ((array:item census ?) / C) ] lan report weighted-rand-index2 lan prob end ; this is executed in patch context to-report most-frequent-known [ lan C ] ; langj census if C = 0 [ ; Is this a "Memento" world? report -1 ] if length lan = 0 [ ; An ignorant programmer? report -1 ] if length lan = 1 [ report 0 ] let prob map [ ((array:item census ?) / C) ] lan report weighted-rand-index2 lan prob end to adoption let check true ; Rule #1: Innovation if (random-float 1.0 < ProbInnov) [ ; check if this developer has some free memory slots if length langj < max-capacity [ ; discover one random language let l (1 + random MaxLang) ; is this new ? if not member? l langj [ set langj lput l langj ; update census[l] ++; array:set census l (array:item census l + 1) ] ] set check false ] ; Rule #2: Adoption if (random-float 1.0 < ProbAdoption) and check [ ; pick one random neighbor let n one-of neighbors ; source(n) knows at least one language let langv [langj] of n if length langv > 0 [ ; compute normalization constant let C (sum array:to-list census) ; learn the most frequent language let lv item (most-frequent-known langv C) langv ; check whether lv is a new language for the target j if not member? lv langj [ let lenj length langj if lenj >= max-capacity [ ; random replacement let i random lenj let f item i langj set langj remove-item i langj array:set census f (array:item census f - 1) ] set langj lput lv langj array:set census lv (array:item census lv + 1) ] ] set check false ] ; Rule #3: Language Forgetting if (random-float 1.0 < ProbForget) and check [ ; at least knows 2 different languages (one will be forgotten) if length langj > 1 [ ; compute normalization constant let C (sum array:to-list census) ; remove the least frequent language let i (least-frequent-known langj C) let f item i langj ; update census[l] --; array:set census f (array:item census f - 1) ; forget set langj remove-item i langj ] ] end to go ; pick a random developer ; let p one-of patches ; ask p ask patches [ adoption ] transfer_colormap plot-census set num-iter num-iter + 1 end
There are 2 versions of this model.
Attached files
File | Type | Description | Last updated | |
---|---|---|---|---|
A cultural diffusion model of programming languages.pdf | This is the paper were the model was first described: Valverde, S., Solé, R. V. (2015) "A Cultural Diffusion Model for the Rise and Fall of Programming Languages" Human Biology 87(3), 224-234. | over 8 years ago, by Sergi Valverde | Download | |
Cultural Diffusion of Programming Languages.png | preview | Preview for 'Cultural Diffusion of Programming Languages' | over 8 years ago, by Sergi Valverde | Download |
This model does not have any ancestors.
This model does not have any descendants.