Skip to main content

Project PIRI Initial Proposal

Potential Project of USC CSCI 576 Multimedia Systems Design

Proof of Concept for a High-Performance, Fully-Fledged, and Universal Web Player using WebAssembly

Backgroundโ€‹

In an era where the web continues to dominate technological and software advancements, Atwood's Law has never been more relevant. Google Workspace has exemplified this shift, replacing traditional desktop applications like MS Word, PowerPoint, and Excel with web-based alternatives such as Google Docs, Slides, and Sheets. Figma took this step even further, replacing graphically intense design applications like Adobe XD and Sketch. These web applications offer performance comparable to their desktop counterparts without the hassle of manual installation or updates; users visit a URL to access up-to-date, full-featured applications.

Despite these advancements, video players and editors have remained mainly an exception to the web transition, primarily due to the complexity of video codecs and encodings. WebAssembly (WASM) emerged as a potential solution, offering near-native performance on the web and enabling the execution of lower-level executables online. Notably, in 2019, FFMpeg, a comprehensive, cross-platform solution for recording, converting, and streaming audio and video, was ported to the web. However, the WASM ecosystem experienced a temporary setback following the Spectre vulnerability, leading to the disabling of shared memory and high-resolution timers at the beginning of 2018. By 2020, a new secure approach had been standardized, re-enabling shared memory and revitalizing the potential for high-performance web-based video applications.

In light of this, we propose PIRI: a "Google Docs" of Video Players โ€” High-Performance, Fully-Fledged, and Universal Web Player.

PIRI consists of three parts:

  • A WASM-based Video Player (Consumer-facing product)
  • A WASM-based Video Editor (Prosumer-facing product)
  • A WASM-based Video Streaming SDK solution for companies (Business-facing product)

While we have plans to expand PIRI into these three realms, we want to start with a simple proof-of-concept web player.

Connections to CSCI 576: Multimedia Systems Designโ€‹

PIRI handles and represents various media types (images, video, audio, graphics, etc.) to create multimedia content. This directly correlates with the course's focus on media capture and assembly methods to produce multimedia content, emphasizing the practical application of these concepts in a modern, web-based environment.

Compression and Storageโ€‹

PIRI's development will require an understanding of generic and specific algorithms for media compression, including well-known ITU/ISO standards such as JPEG, MPEG1/2/4, H.261/263/264, HEVC, mp3, AAC, and Dolby Atmos. This aligns with the course's exploration of compression and storage techniques, offering a hands-on opportunity to apply these standards in optimizing video content for efficient web playback and storage.

Distributionโ€‹

PIRI is centered around the distribution of multimedia content via networked systems to a variety of end clients, incorporating aspects of wired and wireless network distribution, Quality of Service (QoS), priority queuing, and streaming protocols such as MPEG-DASH, Apple's HLS, and Adobe HDS. This directly relates to the course's examination of distribution mechanisms and the challenges of delivering high-quality multimedia content over diverse network conditions.

Digital Rights Managementโ€‹

Incorporating WebAssembly's secure execution environment, PIRI addresses the need for digital rights management (DRM) through watermarking and encryption. This component is relevant to the course's discussion on protecting and managing distributed multimedia content, emphasizing the importance of security in modern multimedia systems.

End-to-End Multimedia Systems Designโ€‹

PIRI exemplifies the design of distributed end-to-end multimedia systems, integrating content creation, compression, storage, and distribution components. This holistic approach to system design mirrors the course's goal to explain the architecture of modern multimedia applications, offering a practical case study that encompasses the theoretical and technical aspects covered in the curriculum.

Recent Protocols and Technologiesโ€‹

By leveraging recent protocols like MPEG-DASH, Apple's HLS, and Adobe HDS and exploring cutting-edge technologies such as stereoscopic and holographic displays, PIRI provides a platform for students to engage with the latest advancements in multimedia systems design. This aligns with the course's emphasis on showcasing recent industry progress and innovations through examples and guest lectures.

Multimodal Media Analysisโ€‹

PIRI's potential for enabling direct video editing and analysis in web browsers touches on aspects of multimodal media analysis, a topic of interest in the course, offering a practical application for theories and techniques related to multimedia data classification and natural language queries for multimedia analysis.

Commercial Valuesโ€‹

Universal Video Playback Solutionโ€‹

PIRI seeks to overcome the limitations of existing video players, such as VLC Media Player's requirement for installation and IINA's macOS-only support. Developing a universal web player will provide a consistent, accessible, and versatile solution for video playback across various platforms and codecs, eliminating the need for multiple platform-specific solutions and enhancing user experience by supporting a wide range of file formats, including MKV.

Enhanced Accessibility and User Engagementโ€‹

By enabling seamless video viewing and editing directly in web browsers, PIRI aims to improve accessibility and user engagement significantly. Removing the need for specialized installations makes digital content universally accessible, potentially increasing platform engagement and user satisfaction, especially for video-centric social media and content distribution platforms.

Video Streaming Infrastructureโ€‹

PIRI proposes a new approach to video streaming infrastructure by offering a comprehensive software development kit (SDK) that simplifies the process of encoding and streaming video files. This eliminates the need for video codec preprocessing that can degrade the video quality, a significant challenge that primary video services face. The direct streaming and playback of video content without initial preprocessing opens up new possibilities for smaller teams to compete with major players, avoiding the path dependency and vendor lock-ins associated with products like AWS Elemental MediaLive. Thus, introducing an SDK for video encoding and streaming presents significant cost savings for organizations. Moreover, integrating the technology with Content Delivery Networks (CDNs) promises to revolutionize video streaming efficiency, reducing latency and enhancing the quality of service for live streams and high-definition content.

Security and Sustainabilityโ€‹

Leveraging WebAssembly's secure execution environment, PIRI offers robust protection against security threats, safeguarding sensitive and copyrighted content. It also contributes to environmental sustainability by optimizing server-side video processing, potentially reducing energy consumption and carbon footprint.

Delivery Plansโ€‹

By the end of the semester, we aim to deliver:

A Proof of Concept WASM Video Playerโ€‹

This will demonstrate FFMpeg's capabilities in video playback on the web, showcasing the potential for a high-performance, fully-fledged web player.

A Proof of Concept WASM Video Trimmerโ€‹

This will highlight FFMpeg's editing capabilities, illustrating the feasibility of web-based video editing tools that leverage WASM for near-native performance.

Conclusionโ€‹

PIRI aims to bridge a significant gap in the current digital landscape by developing a universal web player and editor that leverages WebAssembly and FFMpeg. By addressing the limitations of existing video playback and editing solutions, PIRI has the potential to revolutionize how video content is accessed, viewed, and edited across various platforms, eliminating the need for separate installations and providing a seamless, high-quality user experience.