{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# Schelling Segregation Model\n", "\n", "## Background\n", "\n", "The Schelling (1971) segregation model is a classic of agent-based modeling, demonstrating how agents following simple rules lead to the emergence of qualitatively different macro-level outcomes. Agents are randomly placed on a grid. There are two types of agents, one constituting the majority and the other the minority. All agents want a certain number (generally, 3) of their 8 surrounding neighbors to be of the same type in order for them to be happy. Unhappy agents will move to a random available grid space. While individual agents do not have a preference for a segregated outcome (e.g. they would be happy with 3 similar neighbors and 5 different ones), the aggregate outcome is nevertheless heavily segregated.\n", "\n", "## Implementation\n", "\n", "This is a demonstration of running a Mesa model in an IPython Notebook. The actual model and agent code are implemented in Schelling.py, in the same directory as this notebook. Below, we will import the model class, instantiate it, run it, and plot the time series of the number of happy agents." ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [], "source": [ "import matplotlib.pyplot as plt\n", "%matplotlib inline\n", "\n", "from model import Schelling" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Now we instantiate a model instance: a 10x10 grid, with an 80% change of an agent being placed in each cell, approximately 20% of agents set as minorities, and agents wanting at least 3 similar neighbors." ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "collapsed": true }, "outputs": [], "source": [ "model = Schelling(10, 10, 0.8, 0.2, 3)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "We want to run the model until all the agents are happy with where they are. However, there's no guarentee that a given model instantiation will *ever* settle down. So let's run it for either 100 steps or until it stops on its own, whichever comes first:" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "100\n" ] } ], "source": [ "while model.running and model.schedule.steps < 100:\n", " model.step()\n", "print(model.schedule.steps) # Show how many steps have actually run" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The model has a DataCollector object, which checks and stores how many agents are happy at the end of each step. It can also generate a pandas DataFrame of the data it has collected:" ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "collapsed": true }, "outputs": [], "source": [ "model_out = model.datacollector.get_model_vars_dataframe()" ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
happy
061
167
269
371
471
\n", "
" ], "text/plain": [ " happy\n", "0 61\n", "1 67\n", "2 69\n", "3 71\n", "4 71" ] }, "execution_count": 5, "metadata": {}, "output_type": "execute_result" } ], "source": [ "model_out.head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Finally, we can plot the 'happy' series:" ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "" ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAD8CAYAAABn919SAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAGGRJREFUeJzt3X2MXfV95/H3Zx49YxvP2B7z4BnX2ATTlBADA8V0QxJc\nqtBSk91NW1BTuaQra6MVG6ImKVmkqJW2u2na3SzStrQWBPEHok1c00SVQoOyfZSNyWCcEDBOMgZ7\nBowZz4MNvvM83/3jnrHH47Hn3pl777m+9/OSLPuc+/D7+ej4Mz9/f79zjiICMzO79NWk3QEzMysM\nB7qZWYVwoJuZVQgHuplZhXCgm5lVCAe6mVmFcKCbmVUIB7qZWYVwoJuZVYi6Uja2evXqWL9+fSmb\nNDO75L300ksnIqJtvveVNNDXr19PV1dXKZs0M7vkSTqSy/tccjEzqxAOdDOzCuFANzOrEA50M7MK\n4UA3M6sQ8wa6pE2SDsz4dUrSQ8lrD0o6JOlVSV8rfnfNzOxC5l22GBGHgM0AkmqBt4BnJX0cuBe4\nISJGJa0pak/NzOyi8l2HvhXojogjkv4U+GpEjAJExLsF753xra4eegYyZ7Y3r2vhzusuT7FHZlau\n8g30+4Bnkj9fC3xE0h8DI8AXIuIHsz8gaQewA2DdunWL6Gr1eXtomC/u+hEAEkTAmuWNvPiIA93M\nzpfzpKikBmAb8K1kVx3QCtwGfBH4piTN/lxE7IyIzojobGub98pVm2Fvdz8A3/3cR3jjf/4av3/X\ntbz73igj45Mp98zMylE+q1zuBvZHxPFkuxfYHVkvAlPA6kJ3sJrt6e6ntbmeTZcvB6BjZTMAvYOZ\ni33MzKpUPoF+P2fLLQB/B9wJIOlaoAE4UbiuVbeIYG/3CbZsXEVNTfY/Pu2tTQD0DAyn2TUzK1M5\nBbqkZuAuYPeM3d8ANkj6MfDXwPaIiMJ3sTodHcjw9skRtmxYdWbf9Ai9xyN0M5tDTpOiEZEBVs3a\nNwZ8uhidsmy5BWDLxrNVrLZljTTU1Zyz6sXMbJqvFC1Te7r7WbO8kY1tS8/sq6kR7a1N9A665GJm\n53Ogl6Fs/byfLRtXMXvhUEdrs0suZjYnB3oZ+tm773Pi/VFu37jqvNc6VjZ5UtTM5uRAL0PT9fPb\nN56/CrS9tZmTw+OcGhkvdbfMrMw50MvQ3u5+1rY0nVnVMlNHa7LSxROjZjaLA73MTE0Few/3z1lu\ngWzJBbwW3czOV9KHRNv8Xjt2ipPD42y5UKC3+mpRs0vFwWOneOPE6TPbHa3NfKh9RdHac6CXmRcO\nT68/nzvQW5rrWdZY56WLZmVuYnKK3/qrvZwamTizr7Guhpe/chfNDcWJXpdcysye7n6uXr2UK1c0\nzfm6lF2L7hq6WXl75a2TnBqZ4Cv3fJB/eOgOvvYfb2B0YoquNweL1qYDvYxMTE7x4hsDF6yfT2v3\nWnSzsrc3+d/2ts1XsemK5dzz4Supq9GZVWzF4EAvI6+8dZL3RycuWG6ZNr0W3bfOMStfe7v72XT5\nclYvawSguaGOzR0tZ4K+GBzoZWT6J/dtG+YJ9NZmhscn6T89VopumVmeRicm+cGbA+cNzm7fuIpX\neoeKdh2JA72M7O3u57orzv5Ev5Azd110Hd2sLP2w5yQj41PnBfqWjauZCnjx8EBR2nWgl4nRiUm6\njgzMOzqHs2vRvdLFrDzt6T6BBLddfe6/5xvXtdBYV1O0sosDvUwcODrEyPjUvBOikJ0UBd8X3axc\n7e3u5/qrVrCiuf6c/Uvqa7n551qLNjHqQC8Te7r7qRH8Yg4j9GWNdbQ21/tqUbMyNDw2yctHhy64\nuOH2jas4eOwUA0WYA3Ogl4m9h/u5fu0KVjTVz/9msnV0Xy1qVn5eOjLI2OT59fNp0w+t2VeEssu8\ngS5pk6QDM36dkvTQjNe/ICkk+QHRC5T9iT54zuPm5tPR2uxJUbMytPfwCepqxC3rV875+g3tK2hu\nqC1K2WXeQI+IQxGxOSI2AzcDGeBZAEkdZJ81erTgPasiXUcGGJ+Medefz9S+som3hoaZnPJadLNy\nsqe7nxvaV7Csce7L++tra7j16pXs6T5R8LbzvaHAVqA7Io4k218HvgR8u6C9KqKTmXH6T4+m3Y1z\nfO/V4xf9iT6XjtZmxieDl44MsnpZQxF7Z2a5Gp2Y4ke9J/nsRzde9H23b1zF/zjUx/6jg7TkWGbN\nRb6Bfh/wDICkbcBbEfHD2Y9JK1dTU8HH/9c/FWUyYrFuWd/K0gv8RJ/LhtXZZ43+5l/tLVaXzGyB\nbr/m4v/b/qVrshXq//AXewrabs4JIqkB2AZ8WVIz8AjwKzl8bgewA2DdunUL7GZhHH9vhIHTY9x3\nS0de5Y1SuGlda17vv23DKnb+zs0Mj08WqUdmthDLGuvmnQ/7hatW8NRnbmUok9vg8pN/klvb+YzQ\n7wb2R8RxSR8CrgamR+ftwH5Jt0bEOzM/FBE7gZ0AnZ2dqRZ8py/E+cT1V/CxTWvS7Mqi1dSIX/mF\nK9Luhpkt0EevbSv4d+YT6PeTlFsi4hXgTCJKehPojIjCV/kLaHpVyFyPdjMzu9TltA49KbHcBewu\nbneKa/pCnLUtc99r3MzsUpbTCD0iMsAFi0IRsb5QHSqmnsEMa5Y3sqS+Nu2umJkVXFVdKdozkHG5\nxcwqVlUFeu/gMB2tLreYWWWqmkAfn5zi2Mlhj9DNrGJVTaAfGxphKrJXWJqZVaKqCfTpe4e3r3TJ\nxcwqU/UE+vQadI/QzaxCVU+gD2aorRFXrliSdlfMzIqiegJ9YJirWpZQV1s1f2UzqzJVk249gxna\nW1xuMbPKVTWB3js4TIcnRM2sglVFoI+MT9L33qgnRM2solVFoE8/TNkXFZlZJauKQJ++y6JLLmZW\nyaoj0Ae9Bt3MKl91BPpAhsa6GtqWN6bdFTOzoqmKQO8dHKa9tYlL5WHWZmYLURWB3jOYod3lFjOr\ncPM+sUjSJuBvZuzaAHwFWAv8OjAGdAMPRMRQMTq5WD0Dw2zuaEm7G2ZmRTXvCD0iDkXE5ojYDNwM\nZIBngeeB6yPiBuAnwJeL2tMFOjUyzsnhcU+ImlnFy7fkshXojogjEfG9iJhI9r8AtBe2a4Vx5i6L\nXoNuZhUup4dEz3Af8Mwc+z/DuWWZovjD77zK/qODeX3m/ZHszxyP0M2s0uUc6JIagG3MKq1IegSY\nAJ6+wOd2ADsA1q1bt+CODmXGeGrvm3xgzTLWtuR+gdCqpQ1sXtfCpiuWL7htM7NLQT4j9LuB/RFx\nfHqHpO3APcDWiIi5PhQRO4GdAJ2dnXO+Jxf73hggAv77Jz/ErVevXOjXmJlVrHwC/X5mlFskfQL4\nA+CjEZEpdMdm29vdz5L6Gq9WMTO7gJwmRSU1A3cBu2fs/r/AcuB5SQck/WUR+nfGnu4T3LJ+JQ11\nVbF03swsbzmN0JMR+KpZ+64pSo/m0PfeKD85/j7//sayXEhjZlYWLonh7guH+wHYsnHVPO80M6te\nl0Sg7+nuZ3ljHddfdVnaXTEzK1uXRKDv7T7BL25Y6Qc8m5ldRNkn5NtDw7zZn2HLxtVpd8XMrKyV\nfaDv7U7q5xtcPzczu5iyD/Q93f20Ntdzna/0NDO7qLIO9Ihgb/cJtmxcRU2NH05hZnYx+d6cq+j2\ndJ/g2f1vATA+OcXbJ0f4rMstZmbzKrtA3/kvh9nzs35WL2sA4Jo1y9j685en3Cszs/JXdoHeM5Dh\nzuvW8Je/c3PaXTEzu6SUVQ09IugdHKZjZe63xzUzs6yyCvS+90YZnZjy04XMzBagrAK9ZzB5XJyf\nLmRmlreyCvTewWEAl1zMzBagrAJ9+oHO7R6hm5nlrcwCfZjVyxpZUl+bdlfMzC455RXogxmXW8zM\nFqj8At3lFjOzBZk30CVtSp4ZOv3rlKSHJK2U9Lyknya/ty6mIxOTU7w9NOIRupnZAs0b6BFxKCI2\nR8Rm4GYgAzwLPAx8PyI+AHw/2V6wYydHmJwKj9DNzBYo35LLVqA7Io4A9wJPJfufAj65mI6cXbLo\nQDczW4h8A/0+4Jnkz5dHxDGA5Pc1c31A0g5JXZK6+vr6LvjF0xcVtbe65GJmthA5B7qkBmAb8K18\nGoiInRHRGRGdbW1tF3xf70CGGsFVLQ50M7OFyGeEfjewPyKOJ9vHJV0JkPz+7mI60jM4zJUrmqj3\ng6DNzBYkn/S8n7PlFoDvANuTP28Hvr2YjvQMZFxuMTNbhJwCXVIzcBewe8burwJ3Sfpp8tpXF9OR\n7EVFnhA1M1uonB5wEREZYNWsff1kV70s2sj4JMdPjXrJopnZIpRFwfrtoeySRZdczMwWriwCvcdr\n0M3MFq08Aj25ba4v+zczW7jyCPTBDA21NVy+fEnaXTEzu2SVRaD3DgyztrWJmhql3RUzs0tWWQR6\nz6DXoJuZLVZ5BPpAxo+dMzNbpNQD/fToBIOZcU+ImpktUuqBPn2XRV9UZGa2OOkH+oDXoJuZFUIZ\nBPr0CN0lFzOzxUg/0AczNDfUsnJpQ9pdMTO7pKUf6APDdLQ2I3kNupnZYqQe6L1eg25mVhCpBnpE\n0Ds47AlRM7MCSDXQhzLjvD864RG6mVkBpBroZ9age4RuZrZouT6CrkXSLkmvSzooaYukzZJekHRA\nUpekW/Nt/MwadF9UZGa2aDk9gg54FHguIj4lqQFoBr4J/FFEfFfSrwJfAz6WT+NnR+guuZiZLda8\ngS7pMuAO4HcBImIMGJMUwGXJ21YAb+fbeM9AhpbmepYvqc/3o2ZmNksuI/QNQB/wpKQPAy8BnwMe\nAv5B0p+RLd3cnm/jvYPDnhA1MyuQXGrodcBNwGMRcSNwGngY+Czw+YjoAD4PPDHXhyXtSGrsXX19\nfee81jOYcf3czKxAcgn0XqA3IvYl27vIBvx2YHey71vAnJOiEbEzIjojorOtre3M/qkpr0E3Myuk\neQM9It4BeiRtSnZtBV4jWzP/aLLvTuCn+TTc9/4oYxNTvimXmVmB5LrK5UHg6WSFy2HgAeDbwKOS\n6oARYEc+DU/fZbHdI3Qzs4LIKdAj4gDQOWv3vwE3L7RhP9jCzKywUrtSdPqiIq9yMTMrjNQCvXcw\nQ9vyRpbU16bVBTOzipLqCN0TomZmhZNeoA9mvGTRzKyAUgn0ickpjp0c8YSomVkBpRLox06OMDkV\nvimXmVkBpRLo02vQPUI3MyucVAK9d3B6yaID3cysUFIJ9KHhMQBal/q2uWZmhZJKoGfGJgFobsj1\nzgNmZjafVAJ9eGyShroaamuURvNmZhUptRF6c4OvEDUzK6T0At2X/JuZFVQ6JZfxCZo8QjczK6jU\nauieEDUzK6zUSi4eoZuZFVZKJRdPipqZFVpOgS6pRdIuSa9LOihpS7L/QUmHJL0q6Wu5NupVLmZm\nhZdrIftR4LmI+FTyXNFmSR8H7gVuiIhRSWtybXR4bJKmetfQzcwKad5UlXQZcAfwuwARMQaMSfos\n8NWIGE32v5tro5mxCY/QzcwKLJeSywagD3hS0suSHpe0FLgW+IikfZL+WdItuTbqkouZWeHlEuh1\nwE3AYxFxI3AaeDjZ3wrcBnwR+Kak867ll7RDUpekrr6+PiangtGJKa9yMTMrsFwCvRfojYh9yfYu\nsgHfC+yOrBeBKWD17A9HxM6I6IyIzra2NobHp2/M5UA3MyukeQM9It4BeiRtSnZtBV4D/g64E0DS\ntUADcGK+78uMTQDQ5AuLzMwKKtdUfRB4Olnhchh4gGzp5RuSfgyMAdsjIub7ouHpW+f6Xi5mZgWV\nU6BHxAGgc46XPp1vg9P3QncN3cyssEp+pagD3cysOEoe6C65mJkVRwoj9OykqO+2aGZWWKUfoY+7\n5GJmVgyp1dC9Dt3MrLDSq6E70M3MCsolFzOzCpHKpGhtjWioTeXZGmZmFSuVGnpzfS1z3MfLzMwW\nIZUausstZmaFl84I3YFuZlZwqQS677RoZlZ4Kaxy8ePnzMyKwSUXM7MKkc6kqG/MZWZWcB6hm5lV\niJQmRR3oZmaFlkLJZYKmeq9yMTMrtJwCXVKLpF2SXpd0UNKWGa99QVJIWp3Ld2XGXXIxMyuGXIfK\njwLPRcSnkgdFNwNI6gDuAo7m8iUR2V8uuZiZFd68I3RJlwF3AE8ARMRYRAwlL38d+BIQuTQ2Gdm3\neYRuZlZ4uZRcNgB9wJOSXpb0uKSlkrYBb0XEDy/2YUk7JHVJ6jpxoh9woJuZFUMugV4H3AQ8FhE3\nAqeBPwQeAb4y34cjYmdEdEZEZ+vKlQC+9N/MrAhyCfReoDci9iXbu8gG/NXADyW9CbQD+yVdcbEv\nmppKSi6+sMjMrODmDfSIeAfokbQp2bUV2B8RayJifUSsJxv6NyXvvaAp19DNzIom19rHg8DTyQqX\nw8ADC2ksGaB7lYuZWRHkFOgRcQDovMjr63P5nrMjdNfQzcwKraRXirrkYmZWPCUO9OzvLrmYmRVe\naQN9yiN0M7NiSaXksqTOgW5mVmglL7k01ddSU6NSNmtmVhVKPkJ3ucXMrDhKHuhLfJWomVlRlHhS\n1BOiZmbF4pKLmVmFKGmgR4TXoJuZFUlJA30yfNm/mVmxeIRuZlYhSr4O3fdCNzMrjpJf+u9JUTOz\n4ij5Khc/fs7MrDhKW0PH69DNzIqlpIEODnQzs2LJKdAltUjaJel1SQclbZH0p8n2jyQ9K6kll+/y\nKhczs+LIdYT+KPBcRFwHfBg4CDwPXB8RNwA/Ab6cyxd5hG5mVhzzBrqky4A7gCcAImIsIoYi4nsR\nMZG87QWgPZcGm+o9KWpmVgy5jNA3AH3Ak5JelvS4pKWz3vMZ4Lu5NOgRuplZceQS6HXATcBjEXEj\ncBp4ePpFSY8AE8DTc31Y0g5JXZK6wIFuZlYsuQR6L9AbEfuS7V1kAx5J24F7gN+OSJ4vN0tE7IyI\nzojoBE+KmpkVy7yBHhHvAD2SNiW7tgKvSfoE8AfAtojI5Npgky/9NzMrilxnKB8EnpbUABwGHgB+\nADQCz0sCeCEi/vN8X+S7LZqZFUdO6RoRB4DOWbuvWUiDLrmYmRWHrxQ1M6sQJQ10AfW1Jf8ZYmZW\nFUqarjXZWruZmRWBA93MrEKUNtBdbTEzK5rS1tA9QjczK5qSBnqt89zMrGg8QjczqxAlDfRljb5K\n1MysWEoa6G3LG0vZnJlZVfG6EzOzCuFANzOrEA50M7MK4UA3M6sQDnQzswrhQDczqxAOdDOzCuFA\nNzOrEIqI0jUmvQccKlmD5W81cCLtTpQJH4tz+Xic5WMBPxcRbfO9qdTX4h+KiNnPJq1akrp8PLJ8\nLM7l43GWj0XuXHIxM6sQDnQzswpR6kDfWeL2yp2Px1k+Fufy8TjLxyJHJZ0UNTOz4nHJxcysQpQk\n0CV9QtIhST+T9HAp2iwnkjok/aOkg5JelfS5ZP9KSc9L+mnye2vafS0VSbWSXpb098n21ZL2Jcfi\nbyQ1pN3HUpHUImmXpNeTc2RLlZ8bn0/+nfxY0jOSllTz+ZGPoge6pFrgz4G7gQ8C90v6YLHbLTMT\nwO9HxM8DtwH/JTkGDwPfj4gPAN9PtqvF54CDM7b/BPh6ciwGgd9LpVfpeBR4LiKuAz5M9rhU5bkh\naS3wX4HOiLgeqAXuo7rPj5yVYoR+K/CziDgcEWPAXwP3lqDdshERxyJif/Ln98j+g11L9jg8lbzt\nKeCT6fSwtCS1A78GPJ5sC7gT2JW8pZqOxWXAHcATABExFhFDVOm5kagDmiTVAc3AMar0/MhXKQJ9\nLdAzY7s32VeVJK0HbgT2AZdHxDHIhj6wJr2eldT/Ab4ETCXbq4ChiJhItqvpHNkA9AFPJiWoxyUt\npUrPjYh4C/gz4CjZID8JvET1nh95KUWga459Vbm0RtIy4G+BhyLiVNr9SYOke4B3I+KlmbvneGu1\nnCN1wE3AYxFxI3CaKimvzCWZK7gXuBq4ClhKtlw7W7WcH3kpRaD3Ah0zttuBt0vQblmRVE82zJ+O\niN3J7uOSrkxevxJ4N63+ldAvAdskvUm2/HYn2RF7S/JfbKiuc6QX6I2Ifcn2LrIBX43nBsAvA29E\nRF9EjAO7gdup3vMjL6UI9B8AH0hmqRvITnB8pwTtlo2kRvwEcDAi/veMl74DbE/+vB34dqn7VmoR\n8eWIaI+I9WTPhf8XEb8N/CPwqeRtVXEsACLiHaBH0qZk11bgNarw3EgcBW6T1Jz8u5k+HlV5fuSr\nJBcWSfpVsqOwWuAbEfHHRW+0jEj6d8C/Aq9wtm7838jW0b8JrCN7Iv9GRAyk0skUSPoY8IWIuEfS\nBrIj9pXAy8CnI2I0zf6ViqTNZCeIG4DDwANkB1tVeW5I+iPgt8iuDnsZ+E9ka+ZVeX7kw1eKmplV\nCF8pamZWIRzoZmYVwoFuZlYhHOhmZhXCgW5mViEc6GZmFcKBbmZWIRzoZmYV4v8Dy+yBMELBv9QA\nAAAASUVORK5CYII=\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "model_out.happy.plot()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "For testing purposes, here is a table giving each agent's x and y values at each step." ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "collapsed": true }, "outputs": [], "source": [ "x_positions = model.datacollector.get_agent_vars_dataframe()" ] }, { "cell_type": "code", "execution_count": 8, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
xy
StepAgentID
0(0, 0)25
(0, 2)84
(0, 3)54
(0, 4)49
(0, 5)10
\n", "
" ], "text/plain": [ " x y\n", "Step AgentID \n", "0 (0, 0) 2 5\n", " (0, 2) 8 4\n", " (0, 3) 5 4\n", " (0, 4) 4 9\n", " (0, 5) 1 0" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "x_positions.head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# Effect of Homophily on segregation\n", "\n", "Now, we can do a parameter sweep to see how segregation changes with homophily.\n", "\n", "First, we create a function which takes a model instance and returns what fraction of agents are segregated -- that is, have no neighbors of the opposite type." ] }, { "cell_type": "code", "execution_count": 9, "metadata": {}, "outputs": [], "source": [ "from mesa.batchrunner import BatchRunner" ] }, { "cell_type": "code", "execution_count": 10, "metadata": { "collapsed": true }, "outputs": [], "source": [ "def get_segregation(model):\n", " '''\n", " Find the % of agents that only have neighbors of their same type.\n", " '''\n", " segregated_agents = 0\n", " for agent in model.schedule.agents:\n", " segregated = True\n", " for neighbor in model.grid.neighbor_iter(agent.pos):\n", " if neighbor.type != agent.type:\n", " segregated = False\n", " break\n", " if segregated:\n", " segregated_agents += 1\n", " return segregated_agents / model.schedule.get_agent_count()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Now, we set up the batch run, with a dictionary of fixed and changing parameters. Let's hold everything fixed except for Homophily." ] }, { "cell_type": "code", "execution_count": 11, "metadata": { "collapsed": true }, "outputs": [], "source": [ "fixed_params = {\"height\": 10, \"width\": 10, \"density\": 0.8, \"minority_pc\": 0.2} \n", "variable_parms = {\"homophily\": range(1,9)}" ] }, { "cell_type": "code", "execution_count": 12, "metadata": { "collapsed": true }, "outputs": [], "source": [ "model_reporters = {\"Segregated_Agents\": get_segregation}" ] }, { "cell_type": "code", "execution_count": 13, "metadata": { "collapsed": true }, "outputs": [], "source": [ "param_sweep = BatchRunner(Schelling, \n", " variable_parameters=variable_parms, fixed_parameters=fixed_params,\n", " iterations=10, \n", " max_steps=200,\n", " model_reporters=model_reporters)" ] }, { "cell_type": "code", "execution_count": 14, "metadata": {}, "outputs": [ { "name": "stderr", "output_type": "stream", "text": [ "80it [00:02, 27.26it/s] \n" ] } ], "source": [ "param_sweep.run_all()" ] }, { "cell_type": "code", "execution_count": 15, "metadata": { "collapsed": true }, "outputs": [], "source": [ "df = param_sweep.get_model_vars_dataframe()" ] }, { "cell_type": "code", "execution_count": 16, "metadata": {}, "outputs": [ { "data": { "image/png": "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\nl6QG/RdKeUiSHYeeDwAAAABJRU5ErkJggg==\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "plt.scatter(df.homophily, df.Segregated_Agents)\n", "plt.grid(True)" ] } ], "metadata": { "kernelspec": { "display_name": "Python [mesa_dev]", "language": "python", "name": "Python [mesa_dev]" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.5.3" }, "widgets": { "state": {}, "version": "1.1.2" } }, "nbformat": 4, "nbformat_minor": 1 }