Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Customizing "ads" #1

Open
etsea117 opened this issue Nov 28, 2022 · 9 comments
Open

Customizing "ads" #1

etsea117 opened this issue Nov 28, 2022 · 9 comments
Assignees
Labels
discussion Discussion on a possible enhancement enhancement New feature or request

Comments

@etsea117
Copy link

It would be wonderful to be able to customize the fictional ads. I could see this as being linked to a to-do list or reminders lists, allowing someone to advertise important things to themselves. Alternatively, it could be advertising recently learned facts for greater knowledge absorption.

@pncnmnp
Copy link
Owner

pncnmnp commented Nov 30, 2022

Hi @etsea117!
I love the idea of advertising recently learned facts. Also, imagine if this is being done in a short podcast like fashion - with 2 voices. I have a feeling that p335 from coqui-ai's vits model might be a great voice. Although, we should decrease her speed - similar to what we are currently doing with p267's voice.

There is a way to extract facts from a document using Textacy. We need to pass an (entity, cue, fragment) triple for this.

Two years back, I wrote some code to do this, but it is not in a good shape, lol.

Also about adding to-do lists or reminders, I have a question for everyone -
Do we want to take this project in a direction which is more like Google Assistant? Or should we keep it close to a radio-like behavior?

Honestly, I am a not sure what the right direction should be.

However, I have received some feedback about fictional ads - and it seems like putting them inside the schema.json would be a good idea. That way, anyone who does not want to listen to them can turn them off.

Would love to hear your opinions on this.

@pncnmnp pncnmnp added the enhancement New feature or request label Nov 30, 2022
@pncnmnp pncnmnp self-assigned this Nov 30, 2022
@bornagainpenguin
Copy link

A suggestion to consider also would be an ability to use scriptures between songs too for a religious themed broadcast. That could be something that people would like to have and take advantage of.

@pncnmnp
Copy link
Owner

pncnmnp commented Dec 13, 2022

@bornagainpenguin

With the recent commit (535a183), you can specify the music-genre to be something like religious or god to get a religious themed broadcast.

For instance, something like the following in your ./data/schema.json:

["music-genre", [["religious", 2], ["god", 1]]],

Tested it locally:

>>> import radio
>>> radio.Recommend().playlist_by_genre("religious")
[('Mahalia Jackson', 'City Called Heaven'), ('Hypatia Lake', 'Joseph and the Divine Intervention of the Recreational Center'), ('Collin Raye', 'When You Say Your Prayers')]
>>> radio.Recommend().playlist_by_genre("religious")
[('Collin Raye', 'When You Say Your Prayers'), ('Sister Rosetta Tharpe', 'The Devil Has Thrown Him Down'), ('Joy Askew', 'Little Darling')]
>>> radio.Recommend().playlist_by_genre("god")
[('The Bronx Casket Co.', 'Savior'), ('Pattern is Movement', 'Elephant'), ('Film School', 'Dear Me')]

Edit: Here is a list of genres this software supports.

pncnmnp added a commit that referenced this issue Dec 16, 2022
pncnmnp added a commit that referenced this issue Dec 16, 2022
@pncnmnp pncnmnp added the discussion Discussion on a possible enhancement label Apr 9, 2023
@ology
Copy link
Contributor

ology commented May 11, 2023

@bornagainpenguin I can imagine this and other related DJ-spoken subjects with an extra ["topic", "religion"], or ["topic", "science"], that you could (theoretically) add to data/schema.json. Then it would grab sentences from data/gpt/topics.json. 🤔

@pncnmnp
Copy link
Owner

pncnmnp commented May 11, 2023

@ology Aren't these topics currently supported by ./data/genres.csv?

For instance,

["music-genre", [["religion", 2], ["science", 1]]],

in schema.json should insert two songs with the tag religion and one song with the tag science. I am trying to understand the need for a topic action here.

@ology
Copy link
Contributor

ology commented May 11, 2023

Oops. I thought that "music-genre" meant "music only" - not talking. I will experiment before speculating this time!

@pncnmnp
Copy link
Owner

pncnmnp commented May 11, 2023

Oh, wait! My mistake. Are you saying that something like ["topic", "religion"] would recommend a relevant podcast clip (religious-themed) and not a religious song?

@ology
Copy link
Contributor

ology commented May 11, 2023

Yes! Spoken word, not music. Podcast would be cool.

@pncnmnp
Copy link
Owner

pncnmnp commented May 11, 2023

I see! Music part is currently supported.

To be honest, recommending podcasts based on genres seems like a research problem.

Here's how we could possibly achieve it:

  1. Start with something like Spotify Podcast Dataset (this is not public dataset, we need to request access)
  2. If access is granted, we can use the metadata information like show_name, show_description, episode_name, episode_description to predict the genres of that podcast episode.
    Probably the dumbest way to do this would be to use GPT-3.5-turbo. If we assume 750 words per execution, this can cost somewhere around $200 for 100k podcasts episodes.
    So, we might have to explore something else here.
  3. Then, we need to map the genres to the RSS feeds.
    We can then use this to recommend podcasts based on the genres.

Maybe we should look at some other datasets as well, like 13,000+ Podcasts. It even has genre and podcast description. However, we need to figure out how to get the RSS feed from this.

Let me think about this problem for a while. I'm sure there's an efficient way to do this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
discussion Discussion on a possible enhancement enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

4 participants