音声や動画を圧縮するためにffmpegをインストールします。
ロイヤリティの関係上一部のコーデックがはいっていないので手動で追加します。
ffmpegのインストール
音声圧縮形式でメジャーなAACですが、デフォルトで入っているものは品質が悪いためlibfdk-aacを追加でインストールします。
ライブラリを用意する
ffmpegを入れる前に必要なライブラリを用意しておきます。
libfdk-aacはパッケージマネージャからいれることも自前でコンパイルすることも可能です。
# aptでいれる(ついでに使いそうな他のライブラリも入れる)
apt install libfdk-aac-dev libopus-dev nasm libmp3lame-dev
# コンパイルする(各々のライブラリごとにコンパイルする)
cd ~/ffmpeg_sources && \
git -C fdk-aac pull 2> /dev/null || git clone --depth 1 https://github.com/mstorsjo/fdk-aac && \
cd fdk-aac && \
autoreconf -fiv && \
./configure --prefix="$HOME/ffmpeg_build" --disable-shared && \
make && \
make install
ffmpegをコンパイルする
ffmpegをコンパイルするのに必要なライブラリをインストールする
### ubnutu 20.04
# apt update -qq && sudo apt-get -y install \
autoconf \
automake \
build-essential \
cmake \
git-core \
libass-dev \
libfreetype6-dev \
libgnutls28-dev \
libmp3lame-dev \
libsdl2-dev \
libtool \
libva-dev \
libvdpau-dev \
libvorbis-dev \
libxcb1-dev \
libxcb-shm0-dev \
libxcb-xfixes0-dev \
meson \
ninja-build \
pkg-config \
texinfo \
wget \
yasm \
zlib1g-dev \
libunistring-dev \
libaom-dev \
libdav1d-dev
# mkdir -p ~/ffmpeg_sources ~/bin
ffmpegをコンパイルする。エラーが出たら足りないライブラリをインストールする
cd ~/ffmpeg_sources && \
wget -O ffmpeg-snapshot.tar.bz2 https://ffmpeg.org/releases/ffmpeg-snapshot.tar.bz2 && \
tar xjvf ffmpeg-snapshot.tar.bz2 && \
cd ffmpeg && \
PATH="$HOME/bin:$PATH" PKG_CONFIG_PATH="$HOME/ffmpeg_build/lib/pkgconfig" ./configure \
--prefix="$HOME/ffmpeg_build" \
--pkg-config-flags="--static" \
--extra-cflags="-I$HOME/ffmpeg_build/include" \
--extra-ldflags="-L$HOME/ffmpeg_build/lib" \
--extra-libs="-lpthread -lm" \
--ld="g++" \
--bindir="$HOME/bin" \
--enable-gpl \
--enable-gnutls \
--enable-libfdk-aac \
--enable-libmp3lame \
--enable-libopus \
--enable-libvorbis \
--enable-libx264 \
--enable-libx265 \
--enable-nonfree && \
PATH="$HOME/bin:$PATH" make && \
make install && \
hash -r
##コンパイルがおわったら
export PATH=$PATH:/root/bin
ffmpegのコンパイルガイド https://trac.ffmpeg.org/wiki/CompilationGuide/Ubuntu
ffmpegでHE-AAC-v2に変換する
HE-AAC-v2は低ビットレート(48kbps以下)の音質が改善してます。
音質は24kbps・44100Hzくらいが丁度良い。サンプリングレートは下げると音質が下がる割にサイズ削減率は小さいのであまり下げるメリットはなさそうです。
16kbpsでも聞ける音質だが音割れや電話の通話のような音質になります。
ffmpeg -i audio.m4a -acodec libfdk_aac -profile:a aac_he_v2 -ab 16k -ar 44100 -ac 2 output.m4a
# -ab 16kbps
# -ar 44.1KHz
# -ac 2 (stereo)