/writing-progress-2024-25

Track words written and time spent on writing projects in 2024 and 2025.

Primary LanguagePythonMIT LicenseMIT

Version License: MIT

Track progress on writing projects with bar plots and heatmaps

Format

Google Sheets workbook exported to Excel or ODT workbook files. Either can be imported back into Google Sheets. I recommend using Google Sheets for faster access to enter daily progress. Store the link to the workbook in a bookmark, or better yet, in a local index.html file for fast access from your browser. You can also store the link in a voice command; see the quick start section below.

The problem addressed

Managing multiple writing projects is a significant unsolved problem in academic writing and time management. Most academics have to make progress on two or more writing projects per day. The overhead for doing so consumes mental bandwidth. Most books on academic writing skip over this problem because they do not have a good solution for this problem. I designed the above spreadsheets to address this problem.

Most writing guides suggest tracking the total effort expended on writing per day in terms of minutes spent, word count, or both. Word count tends to plateau early when writing academic papers and grant applications, so tracking time is more important. The spreadsheets support tracking both. The workbook tracks at the project level so that you can monitor the distribution of your effort. You can use it well or poorly, like any tool. Good luck!

Synopsis

The above Open Office Document (writing-progress-2024-25.ods) can be imported into Google Sheets, where it was created. You can also open this document in Libre Office or Open Office for offline use. The Excel version writing-progress-2024-25.xlsx can be run in Microsoft Excel. Either document can be imported into your Google Drive account for faster access as a Google Sheets document. I store a link to the Google Sheet document in my web browser for instant access.

After spending 10-30 minutes customizing the workbook for your current and planned writing projects, you should be set to track your writing progress by project for 2024 and 2025. It should take no more than a minute a day to make the entries and to check on your monthly progress displayed as bar plots in the right margin, as shown below. The sums in the bar plot are taken across all projects. To check your effort on a particular project, open its project sheet and sum over columns F for minutes and G for words.

Version 0.5 contains a column on the left side of the min_day and word_day sheets with the difference between the cumulative monthly total and the cumulative monthly goal. A negative value means that you are behind.

Python scripts are included for remotely accessing the min_day and word_day sheets and displaying a summary as a horizontal bar plot or a heatmap with matplotlib. I mapped this to three-letter aliases for rapid access.

Quick start: add today's progress for Project 18

  1. Open the file.
  2. Select Project sheet 18.
  3. Enter minutes spent on project 18 in column F and the current day's row.
  4. Enter the number of words written on Project 18 in column G and the current day's row.

You are finished!! It is that fast and easy!!!

Note:

If you use Voice In Plus, you can map the voice command open sheet 18 to the code<open: <insert sheet's url> > to use your voice to open Project 18's Google Sheet for updating. You can create multiple aliases for the same web page that do not include the project number so that you can still open up the appropriate sheet without remembering the project number.

I use the command open project 18 to open the project's website on Overleaf.

You can do something similar with Serenade, Talon Voice, or the built-in Voice Control software on the Mac.

Checking progress

  1. Open sheet min_day. Scroll to the right margin. Inspect the bar graph for the current month. The gray bars are the cumulative goals; the orange bars are the cumulative progress.
  2. Repeat with sheet word_day.

Customization

  1. Edit the sheet tabs to change the project names. This will break the formula in the corresponding column of the min_day and word_day sheets. Edit the formulas as needed.
  2. Edit the column names in sheets min_day and word_day to refer to the changed project name.
  3. [Optional] The goals can be reset to align with your objectives.

Adding an eleventh project

  1. Create a new project sheet by duplicating an old one and edit to customize it.
  2. Insert a new project column in the min_day and word_day sheets and edit the column name to refer to the new project name.
  3. Add the formula summation formula in row 733 of the new column else the Python scripts below will not work.
  4. [Optional. Read to the end.] Edit the formula in the Daily Total column (column E) min_day and word_day to include the new column in the range of columns so that the progress on this project gets counted. Note that this formula will be automatically updated if you insert the new column at an interior site among the project columns.

Observations

  1. Limit the tracking to the projects you are committed to finishing in the next two years. The purpose of this tool is to sustain your commitment to finishing these projects, not necessarily to document your effort. You can use a writing log for that purpose (see Writing Log templates).
  2. To save space, name the sheets using integers. Map the project number to the project name in the project sheet.
  3. The optimal column width for the project columns on the min_day and word_day' sheets is 45 points when using four-digit project numbers.
  4. Up to 30 projects can be viewed simultaneously without scrolling horizontally. You could always move some of the rightmost project columns on min_day and word_day sheet to the right of the bar plots to keep the bar plots in view without needing to scroll to the right or you can zoom out further.

You are now ready for the next two years!!!! :)

Upgrades

Version 0.5.1

  • Minor edits of the readme.
  • Added funding.

Version 0.5

  • Column inserted in the min_day and word_day sheets to record the difference between the cumulative monthly total and the monthly cumulative goal. A positive value means you are ahead of your goal, and a negative value means you are behind your goal. Glancing at this column might be faster and more informative than scrolling to the right to see the bar plots.

Version 0.4

  • Sum formula added to row 733 at the bottom of the columns for the projects in sheets min_day and words_day. The minutes were converted to hours in these sums.

  • Scripts provided to plot cumulative words and time spent by the project as bar plots (gs2hbarm.py and gs2hbarw.py) or by day as heatmaps (gs2hmw.py and gs2hmm.py) by extracting the data from the workbook on Google Sheets. You must provide authorization for access to your Google Drive and your Google Sheets. See the Read-the-docs for gspread. Take care to update the script file if rename the workbook.

  • I map these scripts to the following three-letter bash aliases (hbh, hbw, hmm, and hmw) so that I can generate these plots on the fly from the prompt in the terminal. mp312 is a bash alias to Python3.12 from MacPorts: /opt/local/bin/python3.12.
# barplots
alias hbh='mp312 ~/gs2hbarm.py && echo "Horizontal bar plot of hours spent per project since January 1, 2024."'
alias hbw='mp312 ~/gs2hbarw.py && echo "Horizontal bar plot of words written per project since January 1, 2024."' 

# heatmaps.
alias hmm='mp312 ~/gs2hmm.py && echo "Heat map of minutes spent per day since January 1, 2024."'
alias hmw='mp312 ~/gs2hmw.py && echo "Heat map of words spent per day since January 1, 2024."' 

Here is the heatmap on September 7, 2024. It was made with alias hmj to show effort on journal articles only. It is reading data from a sqlite time tracking database that I started in May 2022. This display shows repeating temporal variation due to teaching and NIH grant reviewer service.

Long form version of the README.md

More details are found here

Related links

Related projects of possible interest

Sources of funding

  • NIH: R01 CA242845
  • NIH: R01 AI088011
  • NIH: P30 CA225520 (PI: R. Mannel)
  • NIH: P20 GM103640 and P30 GM145423 (PI: A. West)