GoPro Studio gives you plenty of useful editing tools in a really gorgeous package. It can go shot for shot with Final Cut Pro, Windows Movie Maker, and all of.
GoPro Studio for Mac enables you to create professional video clips using advanced editing features and preset templates, making it a powerful tool for editing constant frame rate formats like GoPro, Canon, Nikon, H.264 MP4, and MOV. The app comes with a beautiful and easy-to-use interface, a cartload of features, and excellent performance, representing an excellent choice for amateur as well as professional video editors and GoPro fans.
GoPro Studio for Mac is a rather large download at 121MB, but well worth the wait. Once you install it, the application opens with an attractive, intuitive layout that lets you easily import one or multiple videos for editing. Selected clips appear in the main application interface and can be added to a conversion list that processes your video and saves the edited version to a location of your choice. Editing options are numerous, to say the least. You can adjust video speed for fast or slow motion, play with the frames, add music and audio tracks, and access GoPro Edit Templates in case you don't want to create your video project from scratch. Edits are easy to preview, making the process fast and accurate. The quality of the output video is impressive, too.
GoPro Studio for Mac offers outstanding functionality for a free app. As its name suggests, it's a powerful tool for targeting video editors who need professional features packed up in one complete offering. If you've been looking for a full-featured video editing app that works flawlessly, you've just found it.
GoPro CineForm® is a 12-bit, full-frame wavelet compression video codec. It is designed for speed and quality, at the expense of a very high compression size. Image compression is a balance of size, speed and quality, and you can only choose two. CineForm was the first of its type to focus on speed, while supporting higher bit depths for image quality. More recent examples would be Avid DNxHD® and Apple ProRes®, although both divide the image into blocks using DCT. The full frame wavelet as a subject quality advantage over DCTs, so you can compression more without classic ringing or block artifact issues.
Pixel formats supported:
Compression ratio: between 10:1 and 4:1 are typical, greater ranges are possible. CineForm is a constant quality design, bit-rates will vary as needed for the scene. Whereas most other intermediate video codecs are a constant bit-rate design, quality varies depending on the scene.
CineForm-SDK is licensed under either:
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Clone the project from Github (git clone https://github.com/gopro/cineform-sdk).You will need CMake version 3.5.1 or better for the full SDK.WaveletDemo is just three files: wavelets.c, utils.c, utils.h so it can be easy build without CMake.
After building it.
This tool uses the just build CineForm SDK to compress and decompress a generated image, testing the codec with a range of images and pixel formats. Open TestCFHD.cpp to learn of configuration options.
Within Example/TestCFHD.cpp, here are some key configuration controls:
The TestCFHD defaults to using the asynchronous encoder for the greatest performance on multi-core systems, which encodes ‘n’ frames simultaneously. For the highest performance, the number of frames to encode at once should match the number of CPU threads available, set by POOL_THREADS. To keep you CPU busy, have a POOL_QUEUE_LENGTH greater than the number of CPUs.
Asynchronous performance on a 4Ghz 8 core Broadwell E system:
As this is origin source it should decode all existing CineForm AVI or MOV files. Two sample files have been included showing YUV 4:2:2 and RGB 4:4:4 encoding.
After building it.
Files showing the decoded image, and differences and stored within .data
Within Example/WaveletDemo/wavelets.c: here are some key configuration controls:
Play with the BITDEPTH, to see the impact on quality. Change the number of LEVELS to see how wavelets work. Set the ERRORGAIN to amplify the difference between the source and the decoded image. Increase the GENERATIONS to see it makes very little difference on the quality.
The CineForm video codec was developed in between 2001 and 2002 as a light weight compressed alternative for DV or other consumer formats of the time. However its notoriety wouldn’t come unto around 2003 when CineForm HD when was developed, which moved the codec a from consumer 8-bit YUV, to offering 10-bit YUV and 12-bit RGB/RGBA for more professional digital intermediate work. The codec was ideal for the transition to HD, as its efficiency improved with the resolution increase, a bonus of it being a native Wavelet codec. Also as wavelet’s can be designed to do sub-resolution decoding at a very high rate, editing of HD would perform like SD (fast) whenever needed.
CineForm RAW was added in 2005, the first to offer substantial compression directly from CFA Bayer image sensor data. Once RAW was a compression profile, this is when CineForm stopped being like other codecs, which strive to encode (compress) and decode (decompress) to the same or as close as possible to the source image. Compressing RAW was straight forward, but decompressing back to RAW didn’t help the workflow, as most video editing tools (even today) do not handle native RAW well. To support RAW workflows the CineForm decoder would “develop” the image, applying demosaicing filters, color matrices, CDL color corrections and 3D LUTs before presenting the decoded image to the NLE, compositor or video editing tool. CineForm is still the only codec that does this, it was marketed as Active Metadata.
Active Metadata was used to enable stereoscopic 3D encoding and presentation, the third significant major feature addition to the codec core (first HD, second RAW.) The 3D support within the CineForm codec, was one of the reasons leading to the CineForm acquisition by GoPro in 2011.
Over the last six years at GoPro, the CineForm codec has been licensed to Adobe, FXHome and others and was tweaked and made into a standard through SMPTE as VC-5. VC-5 is a superset of the CineForm compression engine, it is better defined and can handle more pixel formats and resolutions than CineForm, although doesn’t include the Active Metadata engine, nor does it have a performance implementation for video yet. GoPro added VC-5 to their GoPro Hero5/6 Black edition cameras for compressing RAW photos – in camera a 24MByte DNG would be stored as a 4-7MByte GPR file using VC-5 compression.
There is a fourth wave for the original CineForm, as resolution goes beyond 4K, the benefits of wavelet compression are seen again. This demand for higher resolution is coming from 360° video production. GoPro’s Omni 360° rig would output 8Kp30 or 6Kp60 as CineForm files, as there is little else with the efficiency and performance to encode such demanding content. The upcoming GoPro Fusion, and small form-factor 360° camera shooting over 5K, will lead to a lot more CineForm content.
The wavelet used within CineForm is (mostly) a 2D three-level 2-6 Wavelet. As that will mean very little to most, the WaveletDemo has been included to help learn the principles. If you look up wavelets on Wikipedia, prepare to get confused fast. Wavelet compression of images is fairly simple if you don’t get distracted by the theory. The wavelet is a one dimensional filter that separates low frequency data from high frequency data, and the math is simple. For each two pixels in an image simply add them (low frequency):
For high frequency it can be as simple as the difference of the same two pixels:
For a 2-6 wavelet this math is for the high frequency:
The math doesn’t get much more complex than that.
To wavelet compress a monochrome frame (color can be compressed as separate monochrome channels), we start with a 2D array of pixels (a.k.a image.)
If you store data with low frequencies (low pass) on the left and the high frequencies (high pass) on the right you get the image below. A low pass image is basically the average, and high pass image is like an edge enhance.
You repeat the same operation vertically using the previous output as the input image.
Resulting in a 1 level 2D wavelet:
Pro 12 rugby fixtures. The program also includes PowerTools, such as the Topography Designer and Roofing Assistant, which function as plug-in modules, and can do more sophisticated and specialized work.
For a two level wavelet, you repeat the same horizontal and vertical wavelet operations of the top left quadrant to provide: Recording studio app for android.
Repeating again for the third level.
All that grey is easy to compress. The reason there is very little information seen in these high frequency regions of the image (generated from WaveletDemo) is the high frequency data has been quantized. The human eye is not very good at seeing subtle changes in high frequency regions, so this is exploited by scaling the high-frequency samples before they are stored:
After the wavelet and quantization stages, you have the same number of samples as the original source. The compression is achieved as the samples are no longer evenly distributed (after wavelet and quantization.) There are many many zeros and ones, than higher values, so we can store all these values more efficiently, often up to 10 times more so.
The output of the quantization stage has a lot of zeros, and many in a row. Additional compression is achieved by counting runs of zeros, and storing them like: a “z15” for 15 zeros, rather than “0,0,0,0,0,0,0,0,0,0,0,0,0,0,0”
After all previous steps the high frequency samples are stored with a variable length coding scheme. In CineForm classic Huffman coding is used. Again a lot of theory is turned into a table which maps sample values to codewords with differing bit lengths – not a lot of complexity.
The lack of complexity is what makes CineForm fast.
Reverse all the steps.
While I showed that the steps involved are fairly simple, and much can be modeled in only 800 lines of source code (WavetletDemo), the CineForm SDK is currently over 160k lines of code. There are many paths through the CineForm codec that where hand-optimized, each path for different source pixel format – back in 2003 realtime encoding of 1920x1080 was bleeding edge. There are also older bitstream formats supported by the SDK, even a 3D wavelet (volumetric, not stereoscopic) from 2003 which compressed two frames into one crazy wavelet. There are old tools for handling interlaced that are quite different than progressive image encoding. Finally there is all the Active Metadata code for color development, stereoscopic and 360 projection, which extends this codec to being a lightweight video editing engine – all the realtime effects within GoPro Studio use this engine.