This Python package helps solving the Ecosystem Building game from the McKinsey Solve Game. In this game, you need to find a sustainable chain of 8 species among many species (39 in total).
This package provides a function called find_sustainable_food_chain
, which takes a list of species as input and returns a solution that optimizes the creation of sustainable food chains, maximizing the count of species involved.
A set of 39 species is given. From this set, you need to build a sustainable food chain. Species are divided into producers and animals. Producers do not need calories to survive and consume only natural resources. Animals consume other animals and producers and need calories to survive. Animals follow the following rules:
- The species with the highest calories provided eats first.
- It eats the species providing the highest calories provided as a food source. In case of a tie, it will eat half from each of the two species with the same calories.
- Eating consumes calories from the food source by the amount needed by the predator. You need calories provided greater than zero for a species to survive and all calories needed equal to zero after they eat.
If a species does not get enough calories or reaches zero with its own calories provided, the food chain is not sustainable.
To install mckinseysolvegame, simply use pip:
pip install mckinseysolvegame
You can solve the game using a DataFrame that you create from a csv file. Here's an example:
Csv file species.csv:
name,calories_provided,calories_needed,depth_range,temperature_range,food_sources
Red Moss,3000,0,0-10m,26.7-28.2,
Sea Fan,3500,0,0-10m,26.7-28.2,
Sea Lettuce,3000,0,0-10m,26.7-28.2,
Blue Jellyfish,4500,3000,0-10m,26.7-28.2,Sea Lettuce;Red Moss
Glass Squid,3850,3750,0-10m,26.7-28.2, Shrimp
Great White Shark,6000,4250,0-10m,26.7-28.2,Green Sea Turtle;Loggerhead Sea Turtle;Lanternfish
Green Sea Turtle,4400,3000,0-10m,26.7-28.2,Lanternfish;Sea Lettuce;Sea Urchin;Spadefish
Lanternfish,3300,2700,0-10m,26.7-28.2, Shrimp
Loggerhead Sea Turtle,4400,4350,0-10m,26.7-28.2,Blue Jellyfish;Lanternfish;Sea Lettuce;Spadefish;Sea Urchin
Sea Urchin,2100,3000,0-10m,26.7-28.2,Sea Fan;Sea Lettuce
Shrimp,2750,1450,0-10m,26.7-28.2,Red Moss;Sea Lettuce
Spadefish,2100,2400,0-10m,26.7-28.2,Sea Fan
Swordfish,5250,3750,0-10m,26.7-28.2,Glass Squid;Lanternfish;Shrimp
import pandas as pd
from mckinseysolvegame import Solver
# read the CSV file into a DataFrame
df = pd.read_csv('species.csv')
solver = Solver()
result = solver.solve_from_dataframe(df)
print(result)
You can also solve the game from a list of Species:
from mckinseysolvegame import Species
my_species = [
Species(name="Widgeon Grass",
calories_provided=4950,
calories_needed=0,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[]),
Species(name="Fire Coral",
calories_provided=5850,
calories_needed=0,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[]),
Species(name="Common Eel Grass",
calories_provided=4950,
calories_needed=0,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[]),
Species(name="Yellow Tube Sponge",
calories_provided=4600,
calories_needed=0,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[]),
Species(name="Green Zoanthid",
calories_provided=5050,
calories_needed=0,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[]),
Species(name="Peacock's Tail Algae",
calories_provided=4100,
calories_needed=0,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[]),
Species(name="Stalked Kelp",
calories_provided=4650,
calories_needed=0,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[]),
Species(name="Rock Weed",
calories_provided=4600,
calories_needed=0,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[]),
Species(name="Purple Hydrocoral",
calories_provided=5600,
calories_needed=0,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[]),
Species(name="Blue Striped Angelfish",
calories_provided=3750,
calories_needed=4550,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=["Common Eel Grass"]),
Species(name="Blue Shark",
calories_provided=4650,
calories_needed=2150,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Bicolour Angelfish",
"Majestic Angelfish",
"Northern Red Snapper",
"Coral Trout",
"Swordfish",
"Sailfin Tang",
"Powder Blue Tang",
"Flame Angelfish",
"Eyestripe Surgeonfish"
]),
Species(name="Bicolour Angelfish",
calories_provided=1900,
calories_needed=440,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Powder Blue Tang",
"Flame Angelfish",
"Eyestripe Surgeonfish",
"Stalked Kelp",
"Purple Hydrocoral"
]),
Species(name="Bicolour Parrotfish",
calories_provided=3400,
calories_needed=8800,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[
"Widgeon Grass",
"Common Eel Grass",
"Fire Coral"
]),
Species(name="Wahoo",
calories_provided=1700,
calories_needed=2500,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[
"Short-tail Stingray",
"Blue Striped Angelfish"
]),
Species(name="Swordfish",
calories_provided=2000,
calories_needed=500,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Bicolour Angelfish"
]),
Species(name="Short-tail Stingray",
calories_provided=1450,
calories_needed=2050,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[
"Common Dolphinfish",
"Foxface Rabbitfish"
]),
Species(name="Sailfin Tang",
calories_provided=2500,
calories_needed=4800,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Rock Weed"
]),
Species(name="Queen Parrotfish",
calories_provided=3800,
calories_needed=4700,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=["Fire Coral"]),
Species(name="Queen Angelfish",
calories_provided=2600,
calories_needed=3100,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[
"Blue Striped Angelfish",
"Queen Parrotfish",
"Common Eel Grass"
]),
Species(name="Powder Blue Tang",
calories_provided=3600,
calories_needed=4350,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Stalked Kelp",
"Purple Hydrocoral"
]),
Species(name="Porcupine Pufferfish",
calories_provided=2600,
calories_needed=3800,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Peacock's Tail Algae",
"Passer Angelfish"
]),
Species(name="Passer Angelfish",
calories_provided=2250,
calories_needed=4600,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Peacock's Tail Algae"
]),
Species(name="Pacific Tripletail",
calories_provided=2150,
calories_needed=2900,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Coral Beauty"
]),
Species(name="Olive Ridley Turtle",
calories_provided=3550,
calories_needed=4400,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Green Zoanthid",
"Pacific Tripletail"
]),
Species(name="Northern Red Snapper",
calories_provided=1200,
calories_needed=2150,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Majestic Angelfish",
"Sailfin Tang",
"Flame Angelfish",
"Eyestripe Surgeonfish"
]),
Species(name="Majestic Angelfish",
calories_provided=1150,
calories_needed=3200,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Sailfin Tang",
"Powder Blue Tang",
"Eyestripe Surgeonfish",
"Stalked Kelp"
]),
Species(name="Long Finned Pilot Whale",
calories_provided=3100,
calories_needed=950,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Pacific Tripletail"
]),
Species(name="Indo-Pacific Sailfish",
calories_provided=1600,
calories_needed=5600,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Pacific Tripletail",
"Coral Beauty",
"Flameback Angelfish"
]),
Species(name="Hawksbill Sea Turtle",
calories_provided=2800,
calories_needed=4950,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[
"Blue Striped Angelfish",
"Queen Parrotfish",
"Foxface Rabbitfish",
"Common Eel Grass",
"Fire Coral"
]),
Species(name="Gem Tang",
calories_provided=1250,
calories_needed=4900,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=["Widgeon Grass"]),
Species(name="Foxface Rabbitfish",
calories_provided=800,
calories_needed=4050,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=[
"Widgeon Grass",
"Fire Coral"
]),
Species(name="Flameback Angelfish",
calories_provided=2900,
calories_needed=4750,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Green Zoanthid"
]),
Species(name="Flame Angelfish",
calories_provided=2200,
calories_needed=4000,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Stalked Kelp",
"Rock Weed"
]),
Species(name="Eyestripe Surgeonfish",
calories_provided=1050,
calories_needed=3900,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Stalked Kelp",
"Rock Weed"
]),
Species(name="Cuvier Beaked Whale",
calories_provided=1400,
calories_needed=2250,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Coral Beauty",
"Flameback Angelfish"
]),
Species(name="Coral Trout",
calories_provided=1850,
calories_needed=3000,
depth_range="61-90m",
temperature_range="25-26.6",
food_sources=[
"Bicolour Angelfish",
"Powder Blue Tang",
"Flame Angelfish"
]),
Species(name="Coral Beauty",
calories_provided=2650,
calories_needed=4900,
depth_range="31-60m",
temperature_range="26.7-28.2",
food_sources=[
"Yellow Tube Sponge",
"Peacock's Tail Algae"
]),
Species(name="Common Dolphinfish",
calories_provided=2150,
calories_needed=2100,
depth_range="0-30m",
temperature_range="28.3-30",
food_sources=["Queen Parrotfish"])
]
Find the species that form a sustainable food chain:
from mckinseysolvegame import Solver
Solver().find_sustainable_food_chain(my_species)
The API will return a JSON object with the following format:
{
"Fire Coral": {
"calories_needed": 0,
"calories_provided": 1150
},
"Widgeon Grass": {
"calories_needed": 0,
"calories_provided": 50
},
"Common Eel Grass": {
"calories_needed": 0,
"calories_provided": 400
},
"Queen Parrotfish": {
"calories_needed": 0,
"calories_provided": 700,
"eats": ["Fire Coral"]
},
"Blue Striped Angelfish": {
"calories_needed": 0,
"calories_provided": 1250,
"eats": ["Common Eel Grass"]
},
"Queen Angelfish": {
"calories_needed": 0,
"calories_provided": 2600,
"eats": ["Queen Parrotfish"]
},
"Wahoo": {
"calories_needed": 0,
"calories_provided": 1700,
"eats": ["Blue Striped Angelfish"]
},
"Gem Tang": {
"calories_needed": 0,
"calories_provided": 1250,
"eats": ["Widgeon Grass"]
}
}
This dictionary contains the species name in order of eating, the food eaten as well as their final calories provided and needed.
We welcome contributions to mckinseysolvegame! If you find a bug or would like to request a new feature, please open an issue on the Github repository. If you would like to contribute code, please submit a pull request.
mckinseysolvegame is released under the MIT License.