8 -GINI系数计算与 如何使用行为空间做实验
 
 
首先,我们加入保底机制。
对于每一个agent,都有一个随机的保底比例 s(每个agent的 s 不都一样,且s初始化之后不会改变)
进行交易时,双方会保留一部分的财富作为保底财富,只拿一部分出来交易。
 
 
 
GINI系数的计算
它是以下图中 S 面积的两倍。
用积分的思想,底乘高
( i/num_ag ents)* (wealth_so_far/total_wealth)
 
 
经过修改后的模型代码:
turtles-own [
money
save_rate ;; 新增了一个保底比例
] to setup clear-all
create-turtles agent_num[
setxy random-xcor random-ycor
set money (total_money / agent_num)
set save_rate random-float ;;对于每一个人来说,这个保底比例不一样 ]
reset-ticks
end to go
ask turtles[
let agsets other turtles-here
if count agsets >= [
transaction (one-of agsets)
]
forward
]
tick
end to transaction [trader]
let deltam
let money1 ([money] of trader)
let epsilon (random-float )
set deltam (epsilon - ) * money + epsilon * money1
if money + deltam >= and money1 - deltam >=
[
set money money + deltam
ask trader[
set money money1 - deltam
] ]
end to go2
ask turtles[
let agsets other turtles-here
if count agsets >= [
transaction2 (one-of agsets)
]
forward
]
tick
end to transaction2 [trader] ;; go2 按钮调用的函数
let deltam
let money0 ( ( - save_rate) * money) ;; 自己拿出来交易的财富
let money1 ( ( - ([save_rate] of trader)) * ( [money] of trader)) ;; 另外一个人拿出来交易的财富
let epsilon (random-float ) ;; 随机分割财富的系数
set deltam (epsilon - ) * money0 + epsilon * money1
if money + deltam >= and ([money] of trader) - deltam >=
[
set money money + deltam
ask trader[
set money money - deltam
] ]
end to to-update-plot
 let lst [money] of turtles
 set-histogram-num-bars
 if not empty? lst [
set-plot-x-range max lst
histogram lst
] end to save-file
file-open "ag.txt"
let wealths""
ask turtles[
set wealths (word wealths money "\r\n")
]
file-print wealths
file-close
end to lorenz-plot
clear-plot
set-current-plot-pen "equal"
plot
plot set-current-plot-pen "dominant"
plot-pen-down
plotxy
plotxy
plotxy
plot-pen-up set-current-plot-pen "lorenz"
set-plot-pen-interval / agent_num
plot let sorted-wealths sort [money] of turtles
let total-weath sum sorted-wealths
let weath-sum-so-far
let index
let gini-s ;;
repeat agent_num [
set weath-sum-so-far (weath-sum-so-far + item index sorted-wealths)
plot (weath-sum-so-far / total-weath)
set index (index + ) set gini-s gini-s + ((index / agent_num) - (weath-sum-so-far / total-weath)) / agent_num
;; ]
set-current-plot "吉尼系数"
 plot gini-s *
end to-report compute-gini ;;行为空间调用的重复函数
let sorted-wealths sort [money] of turtles
let total-weath sum sorted-wealths
let weath-sum-so-far
let index
let gini-s
repeat agent_num [
set weath-sum-so-far (weath-sum-so-far + item index sorted-wealths)
plot (weath-sum-so-far / total-weath)
set index (index + ) set gini-s gini-s + ((index / agent_num) - (weath-sum-so-far / total-weath)) / agent_num ]
set-current-plot "吉尼系数"
 report gini-s *
end
 
 
 
行为空间
用处:
  • 为了找出哪组参数控制下的 某个参数最高,我们需要重复实验,但是手动太麻烦了,我们可以用netlogo 自带的 “行为空间” 工具
新建一个行为空间
 
  • 实验名称
  • 组合起来不同的参数。
有两种方法:
1. 列出参数的取值;
示例: [ "para" 1, 3 ,8 ,9 ]
2. 指定参数的 初值、增量、终值(需要额外的中括号)。
示例: ["agent_num" [10 10 100]]
  • 对于每一组参数的实验,需要 重复多次
  • 调用报告函数 ,这个函数负责绘制每一组参数下的 gini 系数
  • 设置每一次实验的 终止时间步数
 
  • 实时更新 视图
  • 实时更新 绘图 和 监视器
  • 最大并行运算数
  • 然后会让你选择需要存放 csv 数据表格的目录
  • 取消 这两项实时更新的话,数据会跑的比之前快很多
 
 
行为空间的函数:
to-report compute-gini ;; 这个函数是需要输出的
let sorted-wealths sort [money] of turtles
let total-weath sum sorted-wealths
let weath-sum-so-far
let index
let gini-s
repeat agent_num [
set weath-sum-so-far (weath-sum-so-far + item index sorted-wealths)
plot (weath-sum-so-far / total-weath)
set index (index + ) set gini-s gini-s + ((index / agent_num) - (weath-sum-so-far / total-weath)) / agent_num ]
set-current-plot "吉尼系数"
 report gini-s *
end
 
 

《Netlogo多主体建模入门》笔记8的更多相关文章

  1. 《Netlogo多主体建模入门》笔记 2

    从自带的模型库开始     财富分配模型 黄色代表稻谷,有的人消化快,有的慢,稻谷的积累代表财富的积累,不涉及交易行为.   点击setup后 ,点击 go   红线--穷人: 绿线-- 中产 : 蓝 ...

  2. 《Netlogo多主体建模入门》笔记4

    4- 从Langton的蚂蚁看Turtle与Patch的交互   这只蚂蚁从10000步开始,就会自发地 “建桥”     Turtle与Patch就好比是,一个方块和一个格子的关系. 一个格子上可以 ...

  3. 《Netlogo多主体建模入门》笔记3

    3- 用“生命游戏”认识Patch     代码:   patches-own[living] to setup clear-all ask patches [ < 0.3[ set pcolo ...

  4. 每天成长一点---WEB前端学习入门笔记

    WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...

  5. ES6入门笔记

    ES6入门笔记 02 Let&Const.md 增加了块级作用域. 常量 避免了变量提升 03 变量的解构赋值.md var [a, b, c] = [1, 2, 3]; var [[a,d] ...

  6. [Java入门笔记] 面向对象编程基础(二):方法详解

    什么是方法? 简介 在上一篇的blog中,我们知道了方法是类中的一个组成部分,是类或对象的行为特征的抽象. 无论是从语法和功能上来看,方法都有点类似与函数.但是,方法与传统的函数还是有着不同之处: 在 ...

  7. React.js入门笔记

    # React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...

  8. redis入门笔记(2)

    redis入门笔记(2) 上篇文章介绍了redis的基本情况和支持的数据类型,本篇文章将介绍redis持久化.主从复制.简单的事务支持及发布订阅功能. 持久化 •redis是一个支持持久化的内存数据库 ...

  9. redis入门笔记(1)

    redis入门笔记(1) 1. Redis 简介 •Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure serv ...

随机推荐

  1. 吴裕雄--天生自然PythonDjangoWeb企业开发:框架基础和技术选型

    简单的Web Server import socket eol1 = b'\n\n' eol2 = b'\n\r\n' body = '''Hello,world!<h1>tszrwyx& ...

  2. C++ 类型、类型转换

    C++ 数据类型 基本内置类型 字面值常量和字面值类型 类类型 隐式的类类型转换 聚合类 字面值常量类 constexpr 构造函数 类的静态成员 使用编程语言进行编程时,需要用到各种变量来存储各种信 ...

  3. Spring boot 2.x 中使用redis

    一.添加Maven  依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifac ...

  4. matlab学习 — 实现简单的爬虫

    这里复杂的情况暂时不考虑..测试网址为pixiv的每日排行榜 = = url = 'https://www.pixiv.net/ranking.php?mode=daily' text = webre ...

  5. CR LF CR/LF

    CR:Carriage Return,对应ASCII中转义字符 '\r' (0x0D),表示回车LF:Line Feed,对应ASCII中转义字符 '\n' (0x0A),表示换行CRLF:Carri ...

  6. JavaScript动画实例:李萨如曲线

    在“JavaScript图形实例:阿基米德螺线”和“JavaScript图形实例:曲线方程”中,我们学习了利用曲线的方程绘制曲线的方法.如果想看看曲线是怎样绘制出来的,怎么办呢?编写简单的动画,就可以 ...

  7. [Linux] day05——命令行

    --------------------linux命令 实现某一功能指令或程序 命令行执行依赖于解释器linux命令的分类 内部命令 属于shell解释器一部分 /bin/bash 外部命令 独立与s ...

  8. 吴裕雄--天生自然PYTHON爬虫:安装配置MongoDBy和爬取天气数据并清洗保存到MongoDB中

    1.下载MongoDB 官网下载:https://www.mongodb.com/download-center#community 上面这张图选择第二个按钮 上面这张图直接Next 把bin路径添加 ...

  9. (二)Buildroot介绍

    详情请参考: http://www.buildroot.org/downloads/manual/manual.html 参考博客: https://www.cnblogs.com/arnoldlu/ ...

  10. SAP BO WebI 如何连接webi server folder下面的EXCEL文件作为数据源

    昨天做Webi Report,需要连接一个在Webi Server Folder下面的EXCEL文件作为数据源,然后再去生成相应的报表,找了半天才找到可以连接Webi Server Folder的EX ...