/cosmere-social-network

A social network analysis of Brandon Sanderson's Cosmere

Primary LanguagePython

Cosmere Social Network

inspired by this social network analysis of George R. R. Martin's A Song of Ice and Fire.

** THIS ANALYSIS IS CURRENTLY IN PROGRESS **

view project site (with interactive graphs) here

Installation

work in progress As the project currently stands, all of the analysis can be done on your local machine. To begin, clone this repository onto your local machine.

git clone https://github.com/zebernst/cosmere-social-network

This project manages its Python dependencies with Pipenv. To install dependencies needed to run scripts in this repository, follow the instructions on the Pipenv page to install Pipenv on your local machine, navigate to the directory that this repository has been cloned into, and run

pipenv install

Once the dependencies have been installed, there's only one more step. Because Pipenv incorporates a virtual environment, you need to prepend any commands that run scripts in this repository with pipenv run, or alternatively run the following command once:

pipenv shell

This will enter the virtual environment created by Pipenv. You'll have to run pipenv shell once each time you open a new terminal window, but the virtual environment will persist in the same work session.

Project Structure

code:

  • csn.py is the main script to manage data acquisition and network analysis, meant to be run via the command line.
  • core/characters.py gets character data from the wiki.
  • core/config.py is the file where parameters used for the analysis can be tweaked.
  • networks/family.py generates a network graph with links representing direct nuclear family relationships.
  • networks/interactions.py generates a network graph with weighted links representing interactions between characters in books.
  • utils/ contains utility functions used in other files.

analysis:

  • interactive graphs can be found on the project site. this is where most of the analysis efforts will be concentrated.
  • graphs/family/ contains network graphs showing family relationships in the Cosmere. Includes sub-graphs showing certain key families and relationships on a per-shardworld basis.

misc:

  • docs/ contains the code for the project site.
  • data/ is the directory in which all data relevant to the analysis is stored. To avoid potential copyright issues, only data generated with this analysis (e.g. GML network files) will be stored publicly on GitHub.
  • Gemfile and Gemfile.lock contain the Jekyll dependencies that support the project site. These aren't important unless locally hosting your own version of the project site.
  • Pipfile and Pipfile.lock contain the Python dependencies used in the analysis. These can be easily installed using pipenv.
  • readme.md you are here :)