this post was submitted on 09 Jul 2023
6 points (80.0% liked)

Piracy: ꜱᴀɪʟ ᴛʜᴇ ʜɪɢʜ ꜱᴇᴀꜱ

54577 readers
265 users here now

⚓ Dedicated to the discussion of digital piracy, including ethical problems and legal advancements.

Rules • Full Version

1. Posts must be related to the discussion of digital piracy

2. Don't request invites, trade, sell, or self-promote

3. Don't request or link to specific pirated titles, including DMs

4. Don't submit low-quality posts, be entitled, or harass others



Loot, Pillage, & Plunder

📜 c/Piracy Wiki (Community Edition):


💰 Please help cover server costs.

Ko-Fi Liberapay
Ko-fi Liberapay

founded 1 year ago
MODERATORS
 

I've been using Clipgrab (macOS) to download music (mp3s) from YouTube. I've seen some mentions that the quality (real bitrate as opposed to what the file states) is bad to begin with on YouTube and that downloaders might make it worse. How bad is the quality of what I'm downloading? Any better downloaders or does the quality suck to begin with?

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 5 points 1 year ago* (last edited 1 year ago) (7 children)

Please somebody correct me if I'm wrong:

Separate audio is rarely available on streaming sites like YouTube, so if you're ripping a song from it, you essentially are transcoding the files three times:

  • Encoding by the content creator
  • Extracting the audio from the the content
  • Encoding in the format of choice

So no matter how great the quality is at either of these transcoding ends, you are still transcoding in lossy format at least two times

[–] [email protected] 3 points 1 year ago (5 children)

yt-dlp can just download the audio. It usually comes down in m4a at quality that I would describe as "very listenable". So only the first of those three steps are mandatory if you do it that way.

yt-dlp -x <url>

[–] [email protected] 2 points 1 year ago* (last edited 1 year ago) (3 children)

From my use of this, it downloads a video and extracts the audio stream from it. In fact, you can see this as it leaves the video file on disk while it's extracting the audio, and the audio-extraction process uses a decent amount of cpu (takes a few minutes for long concert sets on my raspberry pi). AFAICT, there's no way to only download the audio without incurring the unnecessary bandwidth and CPU usage.

Edit: I just checked and the CPU usage seems to be coming from the fact that I am asking yt-dlp to convert the audio format. Now I'm questioning whether it is actually the video that I've seen temporarily on disk or just the audio file in the youtube-native format.

[–] [email protected] 3 points 1 year ago* (last edited 1 year ago) (2 children)

It varies based on the age of the video, newer ones do indeed have separate audio downloads. You can force audio only with

yt-dlp -f bestaudio

This will cause the script to only consider audio-only formats, if bandwidth is a concern. However, how it decides which one is "best" is beyond me. For example, I tried one video and got a webm that contains only an audio track:

~ $ yt-dlp -f bestaudio https://www.youtube.com/watch?v=dQw4w9WgXcQ
[youtube] Extracting URL: https://www.youtube.com/watch?v=dQw4w9WgXcQ
[youtube] dQw4w9WgXcQ: Downloading webpage
[youtube] dQw4w9WgXcQ: Downloading ios player API JSON
[youtube] dQw4w9WgXcQ: Downloading android player API JSON
[youtube] dQw4w9WgXcQ: Downloading m3u8 information
[info] dQw4w9WgXcQ: Downloading 1 format(s): 251
[download] Destination: /data/data/com.termux/files/home/storage/movies/ytdl/20091025__Rick_Astley_-_Never_Gonna_Give_You_Up_Official_Music_Video.webm
[download] 100% of    3.28MiB in 00:00:00 at 6.91MiB/s
[–] [email protected] 1 points 1 year ago

Here is an alternative Piped link(s): https://piped.video/watch?v=dQw4w9WgXcQ

https://piped.video/watch?v=dQw4w9WgXcQ

Piped is a privacy-respecting open-source alternative frontend to YouTube.

I'm open-source, check me out at GitHub.

[–] [email protected] 1 points 1 year ago

Yes, I deleted my comment after I checked the command line I was using and testing it out. The CPU usage was because I was using the --audio-format flag with something other than m4a/opus or whatever it is that youtube uses natively. And the file I saw on disk was not the video, it was the audio file in youtube's native format.

For reference, I'm using $ytdl -f "bestaudio/best" -ciw -o "$audioroot/%(title)s (%(upload_date>%Y-%m-%d)s).%(ext)s" --extract-audio --audio-quality 0 --audio-format mp3 "$vidurl".

load more comments (1 replies)
load more comments (2 replies)