Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
情報科学特別演習 最終発表「動画編集ソフトウェアフレームワーク: mock up」
Search
Mutsuha Asada
January 17, 2023
Programming
52
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
情報科学特別演習 最終発表「動画編集ソフトウェアフレームワーク: mock up」
優秀賞をもらった
Mutsuha Asada
January 17, 2023
More Decks by Mutsuha Asada
See All by Mutsuha Asada
Reproducible Containers (ASPLOS'20)
momeemt
0
550
❄️ NixCon2025に参加した
momeemt
0
540
🔨 小さなビルドシステムを作る
momeemt
4
1.4k
情報科学類で学べる専門科目38選
momeemt
0
1.1k
❄️ tmux-nixの実装を通して学ぶNixOSモジュール
momeemt
1
1k
Wasmで拡張できる軽量マークアップ言語 Brack
momeemt
0
680
❄️ NixOS/nixpkgsにSATySFiサポートを実装する
momeemt
2
890
Intel系FPGA上へのRISC-Vプロセッサの実装
momeemt
0
570
情報科学若手の会 2024 LT「WebAssemblyで拡張可能な軽量マークアップ言語の開発」
momeemt
0
73
Other Decks in Programming
See All in Programming
AIとASP.NET Coreで雑Webアプリを作った話
mayuki
0
660
そのテスト、説明できますか?~LWテスト戦略FW~のご紹介
nakahara
0
150
Performance Engineering for Everyone
elenatanasoiu
0
180
Go1.27で導入されるジェネリクスメソッドでできること
mackee
0
140
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
160
C# and C++ Interoperability - cho-dotnetnew
harukasao
0
260
Observability in Practice:Grafana 與 Edge Device SRE 的那些事
blueswen
0
170
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
250
dRuby over BLE
makicamel
2
380
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
550
Skillsは効率化、Agentsは"自分の拡張"——Builder時代のエージェント編成(CC Night 2026)
wemra
1
140
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
200
Featured
See All Featured
Believing is Seeing
oripsolob
1
150
Git: the NoSQL Database
bkeepers
PRO
432
67k
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
2
220
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.4k
Code Reviewing Like a Champion
maltzj
528
40k
New Earth Scene 8
popppiees
3
2.3k
So, you think you're a good person
axbom
PRO
2
2.1k
Jamie Indigo - Trashchat’s Guide to Black Boxes: Technical SEO Tactics for LLMs
techseoconnect
PRO
0
170
Embracing the Ebb and Flow
colly
88
5.1k
How to Think Like a Performance Engineer
csswizardry
28
2.7k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.5k
The Limits of Empathy - UXLibs8
cassininazir
1
360
Transcript
プラグインの仕組みを実装 1. HLSを導入しWebから編集可能に 2. コミュニティの形成 3. 動画編集ソフトウェアフレームワーク 1 やったこと
浅田睦葉 筑波大学情報科学類1年 2 自己紹介 :bow:
3 開発の背景 モチベーション 動画編集は難しい ブロックを用いて編集する 動画編集ソフトウェアを開発 簡単に動画編集ソフトを作りたい 動画編集ソフトを作るのは難しい 文化祭での動画作成
4 開発の背景 モチベーション 動画編集ソフトウェア開発の工程を 共通化してフレームワークにしたい! 動画のデコード/エンコード、図形描画、テキスト描画、座標系の定義、拡大縮小、様々なメディア フォーマットへの対応、トリミング、ネガポジ反転、ゆがみ、ぼかし、アニメーション、部分適用、 3Dオブジェクト、その他フィルター、新しい動画編集ソフトウェアとしての革新的/独自の機能、レン ダリング高速化、プレビュー、スクリプト、プラグイン拡張、音声処理、ソフトウェアとしての設計、 ユーザーインターフェース、ユーザー体験の改善、ユーザーテスト、それらの分析...
etc.
Web技術ベースでこれらの機能を手軽に利用したい 様々な環境で利用ができる Webサービスの動画編集バックエンド 高性能とも限らないモバイルでの動画編集バックエンド Electron等で動かせばローカルでも利用可能 → UI等はアプリに適したものを開発してもらい、 様々な環境から利用できる拡張可能な動画編集フレームワーク 5 Webベースで動作する動画編集フレームワーク
モチベーション
① 大量のAPIを管理したくない ② 差分の関心を後回しにできる 20種類のフィルターをかけるなら 20個のエンドポイントを叩かなければいけないので辛い 差分更新の実装を後回しにできる 6 Webベースで動作する動画編集フレームワーク シンプルなRESTful
APIではなく中間言語muml
input output 7 簡単に動画編集を実現 色反転フィルターをかける例
Web開発者 ・UI/UXの改善に取り組む ・mumlを投げるだけ 動画編集機能開発者 ・レンダラを拡張する ・Web APIを意識しないでok 8 mumlによってクライアントとバックエンドを繋ぐ シームレス!
アプリケーション層 iOS App Android App WebApp Desktop App 開発者 APIサーバー
mumlのパース JSON Scheme で定義 タイムライン オブジェクトの 生成 必要なシェーダ ファイルの準備 メディア変換 ... FFmpeg 動画像のエンコード レンダリング レンダリング フレームを GLテクスチャ に変換 GLテクスチャを フレームに変換 永続化 データベース タイムライン オブジェクトを正規化 コンテナ化 ストリーミングサーバー HLSストリーミング の初期化 HTTP Live Streaming 何が動いているのか 気になる! 9 独自の動画編集ソフトの クライアントを開発 メディア変換 ... FFmpeg 動画像のエンコード メディアのアップロード
10 ユーザーがmock-upを拡張するためのプラグインを実装した プラグインシステムの実装 mumlを拡張する ユーザーが定義したElement型 型からJSONパーサ(parse_型名)を生成
11 パーザを統合してdeserializerを生成 独自のタグ・構造を解釈可能に ユーザーがmock-upを拡張するためのプラグインを実装した プラグインシステムの実装 mumlを拡張する
12 ユーザーがmock-upを拡張するためのプラグインを実装した プラグインシステムの実装 mumlを拡張する
13 Webアプリからmock-upのプレビューを読み込める RTMP配信 ... HLS配信 ブラウザで閲覧可能 HTTP Live Streamingに対応 mumlを拡張する
14 ・APIを整理し、ドキュメントを執筆した ・GLSLを書いている学生にフィルター実装を依頼している ・"動画編集ソフトウェアフレームワーク"に必要な全ての 機能を自分一人で実装することは難しい ・少しずつ、プログラマブルな動画編集や 動画編集ソフトウェア開発に関心のある若いプログラマと 機能を充実させていく必要がある
・そこで、外部で獲得した研究費から謝金を出して フィルター実装を外部に依頼した フィルター実装を外部に依頼 目標: コミュニティ形成
15 カスタムエレメント・カスタムフィルターの実装方法 作ってみる ① CLIでプラグインの雛形を作成する ② GLSLでフィルターを実装する(各種変数はmock upから与えられる) ③ エレメントの構造の型を定義する(パーサが自動生成される)
④ フックとなる関数を定義する ↑ フレームの処理についてのみ注力すればよく、 動画編集全体のフローについて理解する必要はない!
16 全体が均一にぼかされている 境界だけぼけている 実装例 ブラー / 境界ぼかし
17 モザイク 実装例 モザイク
18 グロー(発光) 実装例 グロー
19 元画像 フィルター適用後 実装例 クロマキー
まとめ 20 ▲ GitHub ・RESTful APIではなく中間言語で編集することで大量のAPIを管理する必要がなく、 差分更新について後回しにすることができる。出力やストリーミング、アップロード など編集以外の作業と編集そのものを分離できる ・フィルターや図形の描画、アニメーションについて表現でき、これらを組み合わせ ることで複雑な動画を作ることができる
・プラグインシステムによって柔軟な拡張を可能にした ・HLSによる配信によってWebからの動画編集を可能にした ・今後はコミュニティの形成や、mock upを利用した動画編集ソフトウェアの 開発(来年のジョットクなど...?)に取り組んでいく ・mock upやプログラマブルな動画編集に興味があれば
[email protected]
に連絡をください!(GLSL/Nimによる開発です)