Automate areas management in MusicBrainz [GSoC '23 Proposal]

PrathameshG Metabrainz GSOC 2023 Proposal - Google Docs;

Name: Prathamesh S. Ghatole
Email: prathamesh.s.ghatole@gmail.com
Linkedin: https://www.linkedin.com/in/prathamesh-ghatole
GitHub: https://github.com/Prathamesh-Ghatole
IRC Nick: Pratha-Fish
Mentor: @reosarevok
Timezone: Indian Standard Time (GMT +5:30)
Languages: English, Hindi, Marathi

Abstract:

MusicBrainz is an open-source, community-maintained database of music metadata. It not only provides a comprehensive collection of information about various music artists, their releases, and related data such as recording and release dates, labels, and track listings - but also the locations (areas) related to these tracks!

MusicBrainz tracks area types like countries, cities, districts, etc. to indicate the location of recording studios, artist birthplaces, concert halls, events (concerts), etc. But considering the scope of the database, MusicBrainz refers to external databases like Wikidata & GeoNames to keep its area metadata up-to-date.

However, currently, areas are being added by manually submitting AREQ tickets on the MetaBrainz Jira issue tracker, where dr_saunders manually addresses them, and adds/updates areas on MusicBrainz. Given the manual nature of this process, it’s naturally cumbersome, causes delays, and lacks frequent updates on outdated areas.

With this GSoC project, we aim to tackle this issue by building a new Mechanize based “AreaBot” written in Python (similar to the old Perl Bot) to automatically maintain and update areas in MusicBrainz using Wikidata.

Problem Statement:

Currently, areas are mostly added manually as follows:

  1. Submit an AREQ ticket on the MetaBrainz Jira issue tracker.
    (e.g.[AREQ-3115] Prospect Heights, Brooklyn - MetaBrainz JIRA)
  2. Once submitted, dr_saunders manually address these tickets to create new areas on the MusicBrainz database.
    (e.g.: Prospect Heights - MusicBrainz)

The above method, however, is unideal due to the following reasons:

  • A tedious amount of manual editing is required.
  • Adding areas in bulk is not supported.
  • Areas are not being updated in real-time.
  • Delays in adding new areas can cause problems for users who need to link areas when adding new recordings to the MusicBrainz database. If an area is not available to link immediately, important area metadata could be missed.
  • Area data is not updated automatically and hence becomes outdated unless reported by an editor and fixed manually.
  • Existing area data doesn’t automatically update localized names that are later added to the references (Wikidata, Geonames, etc).

Solution Statement:

Initially, areas were added automatically from Wikidata using the old Perl bot that was discontinued due to concerns over vandalism using malicious Wikidata edits by certain editors who wanted to ensure specific areas were added by the bot. However, Wikidata nowadays has much stronger anti-vandalism tools, potentially enabling us to resume automatic area addition using Wikidata.

As the Perl bot is complex and mostly unused, a new Python-based “AreaBot” has to be built. We believe the existing MusicBrainz-Bot could be a great start for the bot.
Some references:

Given the existing Mechanize-based MusicBrainz-bot and Wikidata’s well maintained official Python libraries, we’re positive this solution is reasonable and could be finished well within the proposed 350-hour duration of this project.

Project Goals:

With this project, we propose some primary high-level goals as follows:

  1. Periodically fetch new areas from Wikidata/Geonames.

  2. Add new areas to the MusicBrainz database.

  3. Update missing, or updated metadata for all existing areas from their linked references.

  4. Write documentation for the existing MusicBrainz-Bot & the newly proposed “AreaBot”.

  5. Write tests for the existing MusicBrainz-Bot & the newly proposed “AreaBot”.

Deliverables:

  • An updated MusicBrainz-bot with complete support for adding areas.
    • Bot Service 1.1: Add new areas to MusicBrainz.
    • Bot Service 1.2: Update existing areas on MusicBrainz.
  • AreaBot (based on MusicBrainz-bot) to add areas to MusicBrainz.
    • Bot Service 2.1: Periodically Fetch areas from Wikidata.
    • Bot Service 2.2: Transform Wikidata and MusicBrainz area data into a similar structure.
    • Bot Service 2.3: Compare Wikidata and MusicBrainz areas. Return a list of “new areas”, and “existing areas”.
    • Bot Service 2.4: Wikidata Spam filter.
    • Bot Service 2.5: Parameter comparator - Compare parameter differences in existing area data. Create a list of areas with updated parameters.
    • Bot Service 2.6: Log Writer - write logs for added/updated areas and spam areas.
    • Bot Service 2.7: Data Feeder - Iteratively Feed Data to the MusicBrainz-Bot
  • Documentation & Tests for the AreaBot
  • Documentation & Tests for MusicBrainz-bot

Process Flowchart

Bot Structure

Progress So Far:

MusicBrainz-Bot (My Commits | My PRs)

So far I’ve worked on adding an “add_area” function to the MusicBrainz-Bot (Including parameters like references/external-links, ISO codes, etc.); the output for which is currently being tested on https://test.musicbrainz.org/.

e.g.: test_area_name_type_note_ISO_list_ext_link_list - MusicBrainz

Currently, the code for add_area() is up and running with some minor refactoring required.

AreaBot (My Commits)

I have also started working on the AreaBot, which uses the MusicBrainz-bot at its core (as a submodule, not as a fork). I am also using the mb2wikidatabot as a reference to structure this bot.

AreaBot is a standalone bot that includes various scripts to periodically fetch, compare, transform, and update area data using Wikidata. It also includes wrapper scripts to orchestrate the MusicBrainz-Bot to iteratively add the collected areas.

[Please Refer to the “Deliverables” section for more info]

So far I’ve made 14 commits to this project, writing driver code to call the MusicBrainz-Bot to post test data on test.musicbrainz.org, as well as running various analytics notebooks for comparing areas from Wikidata and the MusicBrainz database.

This bot would be potentially deployed and maintained using Docker.

Wikidata & MusicBrainz area coverage comparison & Spam Detection

The following Notebook in the MusicBrainz-AreaBot repository is a simple exploratory notebook that aims to fetch a subset of areas from Wikidata and compare them to existing areas in the MusicBrainz database.

On a small sample dataset with 44107 cities, So far, I’ve been able to identify 8905 cities from Wikidata that are NOT present in MusicBrainz. A pretty good start!

As observed above, we can see these missing areas include large cities as well as some malicious locations that weren’t added for a good reason.

However, we can filter out these areas based on their population metric. Cities with 0 population are most likely to be fake. But let’s take this a step further and filter out all cities with < 1000 population. This gives us 7268 cities that look pretty legit from the look of it!

To ensure we don’t include spam, we’d implement a spam filter for Wikidata areas with more parameters to filter out spam areas from the good ones. However, I propose we keep it as a stretch goal for now, keeping the time limitations of this project in mind.

Testing SPARQL queries for Wikidata:

As a learning exercise, I’ve been testing out relevant SPARQL queries for fetching areas from Wikidata in the following Jupyter Notebook: MusicBrainz-AreaBot/TEST_wikidata_queries.ipynb at master · Prathamesh-Ghatole/MusicBrainz-AreaBot · GitHub

(Please find the queries for the above Screenshots in the Notebook linked above.)

Project Timeline:

A detailed 12 Week timeline for the duration of Google Summer of Code.

Community Bonding Period (May 4 - May 28):

Phase 1 (May 29 - July 14):

  • Week 1 (May 29 - June 04)

    • Complete Bot Service 1.1
    • Implement Bot Service 1.2
    • Write tests and docs for the above services.
    • Write tests and docs for the MusicBrainz-bot
  • Week 2 (June 05 - June 11)

    • Explore SPARQL queries to give the best range of area data with a wide range of attributes to be added along with the area name.
    • Write queries for the following location types on priority:
      Countries, States (subdivisions), Cities, & Districts.
  • Week 3 (June 12 - July 18)

    • Implement Bot Service 2.1 - Write a script to fetch data from Wikidata and MusicBrainz based on previously decided queries.
    • Implement Bot Service 2.2 Write a script to transform the above datasets into a similar structure.
    • Write tests and docs for the above services.
  • Week 4 (June 19 - July 25)

    • Implement Bot Service 2.3 - Write a script to compare newly fetched areas with areas already in MusicBrainz, and return a list of “new areas”, and “existing areas”.
    • I believe the performance of this particular script could vary highly based on implementation, so I’d like to take a little more time with this one to make sure it works well.
  • Week 5 (June 26 - July 02)

    • Write tests and docs for the above service
    • Code Review and refactoring.
    • Getting ready for mid-term evaluations.
    • July 29 - MetaBrainz Perl bot’s 11-year anniversary :moyai::tada:

Phase 2 (July 03 - Aug 28):

  • Week 6 (Jul 03 - Jul 09)

    • Implement Bot Service 2.5 - Implement a script to compare parameter differences in existing area data. Create a list of areas with updated parameters.
    • Write tests and docs for the above service.
  • Week 7 (Jul 10 - Jul 16)

    • Implement Bot Service 2.5 - Implement a logging service for Bot Service 1.1, 1.2, and 2.4.
    • 15th - 16th Jul - Examinations
  • Week 8 (Jul 17 - Jul 23)

    • Write tests and docs for the above service (Bot Service 2.5).
    • Code Review and Refactoring.
  • Week 9 (Jul 24 - Jul 30)

    • Implement Bot Service 2.5 - Write driver code for the MusicBrainz-Bot to iteratively add new areas to the MusicBrainz database.
    • Write tests and docs for the above service.
  • Week 10 (Jul 31 - Aug 06)

    • 1st - 6th Aug- Examinations (ESTIMATED)
  • Week 11 (Aug 07 - Aug 13)

    • Continue implementing Bot Service 2.7 - Write driver code for the MusicBrainz-Bot to iteratively update areas with new metadata from Wikidata.
    • Write tests and docs for the above service.
    • Write tests and docs for the bot.
  • Week 12 (Aug 14 - Aug 20)

    • Orchestrate all the scripts together. Potentially using Apache Airflow and Kafka.
    • Use Docker for deployment.
    • Thoroughly test if all the components are working together properly.
    • Set up notifications to indicate bot failures.
    • Aug 20th - Leave for my birthday (maybe?)
  • FINAL WEEK (Aug 21 - Aug 28)

    • A final round of code reviews and quality checks.
    • Complete README for the MusicBrainz-AreaBot
    • Write and submit the final GSoC Blog.

Why would I like to work with MetaBrainz?

The opportunity to work with MetaBrainz last year has been one of the BEST work experiences of my life. With the GSoC ‘22 project “Cleaning the Music Listening Histories Dataset”, I’ve had the opportunity to contribute to a cause I care about, made a ton of new friends, got mentored by some of the best thinkers & executers in the field of Music Technology, and even earned my first pay cheque! After looking out for more relevant projects in this community for the past few months, I think I’ve finally run into a project that’s interesting, impactful, and resonates with my skills and learning goals.

Along with my whole teen life revolving around technology, I’ve spent quite some time trying to learn the ins and outs of making music and consuming music like a maniac.

Throughout this journey, MetaBrainz has been an omnipresent helping hand; be it with tagging & identifying downloaded music with Picard, or powering sites like last.fm even before I knew the name MetaBrainz!

Even since my music production days, I’ve been bugged by the lack of standardization in the music metadata space. Now, even more so since I’ve completely indulged myself in this domain. Thankfully, the MetaBrainz community has been infinitely helpful throughout this journey, and at this point, I’d be more than happy to give back something and learn a lot more about this very niche domain that interests me; especially when my goals & values seem to align really really well with the community. I plan on continuing my contribution to MetaBrainz well after my tenure with GSoC ends.

Some Questions as asked on the Official MetaBrainz GSoC template:

  1. Tell us about the computer(s) you have available for working on your SoC project!

  • I am currently rocking an Asus TUF Dash F15 laptop (i5 12450H + 16 GB RAM + RTX 3050) as my primary machine.
  • Thanks to the amazing MetaBrainz community, I also have access to the community server “Wolf”, and I’ve also previously worked with “Bono”.
  1. When did you first start Programming?

  • I started out in 6th grade by writing batch scripts on windows
  • Moved on to cybersecurity in 9th grade
  • Took a pleasant turn in 10th grade toward music production
  • Now for the past 3 years, I’ve been studying Data Science, Data Engineering, AI, and its applications in the world of Music, Metadata analysis, feature extraction, and related Social Networks.
  • Back in 2022 I finally set my first step into the Music Tech industry and worked as a GSoC contributor here at MetaBrainz on “Cleaning the Music Listening Histories Dataset” project :slight_smile:
  1. What type of music do you listen to?

  • You can find my music taste here: snaekboi - ListenBrainz
  • I have a weird obsession with Japanese rock, post-hardcore, Progressive-rock, Math-rock, Tech House, Progressive House, Hardstyle, Lo-Fi Hip-hop, Orchestral Music, Piano Solos, and a total hotchpotch of a lotta weird genres!
  • E.g. (recording MBIDs):
    cba64bc9-28cf-447e-9625-4f079c06ec23, 2259521d-11ab-4bde-95bb-0942b2f42e32, 256a6018-21d1-4de2-af70-3532206f5ee5, f45fb199-97eb-4732-8c55-79185e22b457, f2d5d66f-cf72-4e04-b913-9da2cfa1affb
  1. What aspects of the project you’re applying for?

  • I love working with Music Technology, Data Engineering, Analytics, and Machine Learning.
  • Therefore, I am most interested in MusicBrainz & ListenBrainz nowadays.
  1. Have you ever used MusicBrainz to tag your files?

  • Yes, I love MusicBrainz Picard, and I’ve used it to tag every single track in my 20 GB offline music library :slight_smile:
  1. If you have not contributed to open-source projects, do you have other code we can look at?

  • Yes, as discussed above, I have previously contributed to Google Summer of Code in 2022, and have been active in Open Source communities ever since!
  • I have also previously built personal projects like Last.fm Scraper which aims to scrape data from Last.fm/ListenBrainz, apply my own computations with the MusicBrainz/Spotify API, and provide the user with a rich set of world-class metadata features for personal use/analysis/archival.
  1. What sorts of programming projects have you done on your own time?

  • My interests mostly lie in the domain of Music Technology, Data Science, Data Engineering, Data Analysis, and Machine Learning, and I aim to build all my projects related to these domains.
  • Some of my favorite personal projects are: Last.fm scraper ; Document Topic Modelling ; Portfolio Site
  1. How much time do you have available, and how would you plan to use it?

  • I’d be able to find ~35-40 hours weekly for my GSoC activities with MetaBrainz.
  • Just like last time, I’d also be attending to my university commitments from 17th June onwards. However, I’d be ending my extra commitments from college clubs and teaching assistant activities to make space for this project.

However, given my peculiar dual degree scenario, I’d have to take some time off for my examinations around the following dates:
Jul 15th -16th, Aug 1st - 6th (Estimated)

About Me:

Hi, I am Prathamesh, an aspiring Data Engineer based in Pune with a sheer obsession for data, music, computers, cats, and open-source software.

Back in 4th grade, I started tinkering around with computers and developed a severe passion for technology, making it a highlight of most of my teen life. 6 years ago I developed a similar passion for making & consuming insane amounts of music. Given my 3+ years of experience in Music Production, playing Piano, & Audio Engineering under my artist alias “SNÆK” & a life-long love for computers, my passion for the world of music and technology has now convolved into a passion for Data and AI involving various audio Technologies!

I have previously worked with the MetaBrainz Foundation as a Google Summer of Code ‘22 contributor, and as a 3rd-year undergrad, I am currently pursuing a BS in Data Science and applications at IIT Madras and a BTech. in AI at GHRCEM Pune, where my friends know me for my enthusiasm & weird sense of humor, and my teachers know me for my perseverance and reliability.

Skills & Certifications:

5 Likes

Thank you for the proposal, Pratha-Fish!

Bot Service 1.2: Lookup status & MBID for the newly generated area on MusicBrainz

Can you give some more details on this aspect? Are we tracking this somewhere to make sure we don’t enter duplicate edits, or?

Bot Service 2.6 [Stretch Goal]: A Spam filter to filter out malicious areas from Wikidata.

I’m not familiar with how much of a problem this is on Wikidata, but filtering out bogus areas would seem important to me before we could deploy the bot for production use. Or is this a very rare concern?

Periodically sync updated metadata for all existing areas from their linked references (including aliases in other languages).

The proposal seems quite vague on how the bot will do this. (Perhaps it assumes knowledge of how the previous area bot worked.). Where does it store metadata fetched from Wikidata (and in what format, etc.), and how does it detect changes?

Orchestrate all the scripts together. Potentially using Apache Airflow and Kafka.

I’m not sure what this entails, but prefer to keep things simple and avoid using platforms that the rest of the team may not be familar with (unless there are good technical reasons).

1 Like

Bitmap, Thanks for the review!

Here’s the thought process behind some of my design decisions:

Can you give some more details on this aspect? Are we tracking this somewhere to make sure we don’t enter duplicate edits, or?

Once a request to post a new area is sent to the MusicBrainz-bot, it responds if the query is successfully posted (along with its newly generated area MBID) or informs if the request as failed. We’d need this info for debugging further.

I guess the “checking for duplicate edits” part could be best implemented in the MusicBrainz-Wikidata comparison service itself

I’m not familiar with how much of a problem this is on Wikidata, but filtering out bogus areas would seem important to me before we could deploy the bot for production use. Or is this a very rare concern?

I believe Wikidata still includes some spam areas every now and then. Here’s a Screenshot from an analysis I made on fetched Wikidata areas:

As you can observe, some areas with 0 population are definitely spam. However, the spammers could get a little smarter and add large random values in the population parameter to avoid this simple population > 1000 threshold, and cause issues later down the line. I believe should definitely look into a decent spam filter similar to GitHub - metabrainz/spambrainz: Spam detection for MusicBrainz for our area bot. But I am not sure how we’d be able to fit in such a complicated project within the scope of this 350-hour project.

The proposal seems quite vague on how the bot will do this. (Perhaps it assumes knowledge of how the previous area bot worked.). Where does it store metadata fetched from Wikidata (and in what format, etc.), and how does it detect changes?

This definitely calls for some more elaboration about the working of this service on my part… I’m on it.

I’m not sure what this entails, but prefer to keep things simple and avoid using platforms that the rest of the team may not be familar with (unless there are good technical reasons).

Although Apache airflow and kafka are industry-standard tools for scheduling and automating workflows in Python, I think we could totally do without them to avoid learning curves in the team. I don’t know a lot about it, but as an aspiring data engineer, I’d be super excited to learn these tools and take responsibility for implementing them in the project if required.

For what it’s worth, those Spanish areas with 0 people are not spam. They are legitimate small villages that used to exist, but have no inhabitants left (the Spanish countryside is becoming depopulated). That said, I agree with having a 1000 inhabitant filter for automatic adding - anything under that might make sense to review on a manual basis still :slight_smile:

2 Likes

I went through some of these areas again, and looks like some of them are indeed old areas, and even the oddly named “q12393950” areas are just untitled human settlements out somewhere in spain! (Q12393950 - Wikidata)

Looks like we might not have as much of a problem with spam areas as I made it out to be. :))
But yes, as you said we might be better off filtering some of these out and leaving them to manual addition.

Thanks for the review!

This makes me nervous. One place I know of is Red Rocks Auditorium No one lives there, so there is no population. The nearest town is Morrison, Colorado. The population is under 500. Maybe the software could just flag the under 1000s for investigation?

That doesn’t mean that they will be removed :slight_smile: It just means at least initially the bot will not add the areas automatically, but wait for a human to confirm we do want a specific one.

1 Like

Thanks for the review @dpr :))
As reosarevok said, these little areas would be filtered out initially - but only to be potentially reviewed later manually. I do plan on automating this process as much as possible though, so hopefully the manually approved places could be used to improve the spam filters for this process later down the line too :))

2 Likes