Skip to main content

A pretty dumb PM.

Project description

dumbpm

GitHub version Build Status License

A pretty dumb PM.

At the moment it only does projects prioritization: it is pretty dumb, indeed.

The whole philosophy behind dumbpm is that PMs (project managers, product managers, people managers, pokemon masters, etc.) all do some tasks that could use some automation, but at the same time this automation should be as dumb as possible. There are so many changing factors that influence such tasks that you better hire a PM (or a team of researchers to do the automation) to do the clever stuff, not a random software on the internet. In addition, if we keep it dumb, people can just read the code and understand what is going on, if they really want.

If you have any suggestions for something (but nothing clever!) that you would like dumbpm to do for you, open an issue and let me know.

Prioritization

Giving a table of projetcs defined as below, it outputs a list of projects in order of priority within the optionally specified budget (prioritization as "data problem").

The prioritized list is modelled as the exact solution of a Knapsack Problem with the following value function: norm(value) / ((norm(cost) * norm(duration)) + norm(rigging). Pretty dumb, indeed.

$ dumbpm prioritize --help
usage: dumbpm prioritize [-h] [--budget [BUDGET]] filename

positional arguments:
  filename           CSV file with projects definition

optional arguments:
  -h, --help         show this help message and exit
  --budget [BUDGET]  Max budget allowed

Projects format

Project definition happens in a CSV file with the following structure:

  • Project: name of the project
  • Value: value of the project
  • Cost: cost of the project
  • Duration: duration of the project expressed in unit of times
  • Rigging: arbitrary value used to rig the result (yay, cheating!); the highest the more likely the project to be prioritized
  • Alternative: comma separated list of projects that are incompatible with this one (e.g.; make lunch vs buy lunch)

Any field which is not specified, will be filled with 0.

There is a bit of slack on the headers of the columns (e.g.; Project, Projects, project, etc. are all alright). Notable mentions: rig and rigging both work; same for alts and alternatives; PQ can be used instead of cost if that's your thing.

Project Value Cost Duration Rigging Alternatives
Buy a better espresso machine 5 4 2 9
Buy ambient parfume for the back 1 1 1
Find and remove source of bad smell 5 2 4 10
Find better coffee vendors 4 2 6 5
Buy smart component for roaster 3 5 2 Build in-house roasting notification system
Introduce a periodical suggestion survey for treats 3 2 6
Buy a more modern sign 3 3 1
Contact a designer to re-think the front 5 5 6
Buy beds for powernaps 1 3 1
Import treats from France 2 4 2
Build in-house roasting notification system 3 5 6 Buy smart component for roaster

Example

$ cat projects.csv
Project,Value,Cost,Duration,Rigging,Alternatives
Buy a better espresso machine,5,4,2,9,
Buy ambient parfume for the back,1,1,1,,
Find and remove source of bad smell,5,2,4,10,
Find better coffee vendors,4,2,6,5,
Buy smart component for roaster,3,5,2,,Build in-house roasting notification system
Introduce a periodical suggestion survey for treats,3,2,6,,
Buy a more modern sign,3,3,1,,
Contact a designer to re-think the front,5,5,6,,
Buy beds for powernaps,1,3,1,,
Import treats from France,2,4,2,,
Build in-house roasting notification system,3,5,6,,Buy smart component for roaster

$ dumbpm prioritize projects.csv
01 Buy ambient parfume for the back
02 Buy a more modern sign
03 Find and remove source of bad smell
04 Buy a better espresso machine
05 Find better coffee vendors
06 Buy beds for powernaps
07 Buy smart component for roaster
08 Import treats from France
09 Introduce a periodical suggestion survey for treats
10 Contact a designer to re-think the front

$ dumbpm prioritize projects.csv --budget 10
01 Buy ambient parfume for the back
02 Buy a more modern sign
03 Find and remove source of bad smell
04 Buy a better espresso machine

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dumbpm-0.1.3.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dumbpm-0.1.3-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file dumbpm-0.1.3.tar.gz.

File metadata

  • Download URL: dumbpm-0.1.3.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.7.1

File hashes

Hashes for dumbpm-0.1.3.tar.gz
Algorithm Hash digest
SHA256 b62b34d354ed8f62a86af0b7e1fcd0f167f90c9553eb2238703462a8fca0c359
MD5 d603fa576a00d69af8ae9cc69b9e0d74
BLAKE2b-256 5299a8b10d4bbd7dca8c43a2805c94a9d67fd4185024fffa473b1d7afefe8553

See more details on using hashes here.

File details

Details for the file dumbpm-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: dumbpm-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.7.1

File hashes

Hashes for dumbpm-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f01586df4e2b3a9a6a8d6dafcbb0fb5be2512070453199bc73f35f7be2e6a046
MD5 a9dd1704c5c8ca3ff63d5442619a7554
BLAKE2b-256 01afe732976da322ebdc33632e91f6b5e17aec8241ea69f24362ad4ad79fd78e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page