Fixing CCcam 2.1.1 NewCS 1.66

It took me a long time to get the 2 plugins CCcam 2.1.1 and NewCS 1.66 to work correctly on my Dreambox running Gemini 4.2.

Basically the web interface was not working.

Hopefully I had a backup of the old scripts and after some research I found a difference between

CCcam_2.0.11_newcs_1.65_cam.sh and the new CCcam_2.1.1_newcs_1.66_cam.sh

At line 87 I changed from

/usr/bin/CCcam_2.1.1 -s &

to

/usr/bin/CCcam_2.1.1 &

The -s option prevent CCcam to become a server. So when you use it CCcam will not read your internal card and will not become a server. It may not be optimal because with the -s option you don’t have the web interface anymore. I guess they introduced the -s option because having both CCcam and NewCS reading your card may not always work.

After having edited the file I re uploaded it to /usr/script/CCcam_2.1.1_newcs_1.66_cam.sh

Restarted via blue panel and now everthing is fine!

Aes Dana (2009) – Leylines

Aes Dana aka Vincent Villuis, composer and sound designer, Dj and co-owner of Ultimae records.

I am a big fan of Ultimae records because the music on that label has it’s roots on the Berlin Music School of electronic music, I mean the original Tangerine Dream / Klaus Schulze of the 70’s.

Leylines is an ambient work, it’s very organic and I like a lot the complex evolutions. It’s rhythmic at some point but not to a point where it’s disturbing like a Trance track. Cool music to listen when you are coding anyway.

cover

You can listen to the album on the label web site : Aes Dana (2009) – Leylines

I bought my version on eMusic : Aes Dana (2009) – Leylines on eMusic

Creating a new video codec based on texture compression

At ArKaos we always fight to get the best out of current computer configuration regarding media playback.

When you are in the show industry and try to pick the best way to compress your content it’s still a little bit of black magic. While some codec do compress well video they are heavy to handle for the machines, even more, the codec that does the best job at compressing while keeping a good quality such as H264 are very bad when you need to scratch your media.

The best codec for artists that need to interact a lot with the content should allow to play forward and backward easily and should allow to jump into the content quickly.

Some have experimented with using a file format that is designed by the companies making the graphic chips of your computer. This file format is based on texture compression DXT1 DXT3 or DXT5.

I was wandering how hard it would be to add that file support to QuickTime inside a new codec. Being programing for the QuickTime API since it’s version 1.0 beta I was considering the challenge fun and interesting.

So I resuscitated an old sample code from 1999 on the apple web site and after a few hour I had a codec having my name and generating video files that could be played back by the QuickTime player.

I jumped then on the DXT texture compression problem and picked the squish library to handle texture compression. A few more hours and I had a working codec.

 

 

ArKaos codec in the QuickTime player

ArKaos codec in the QuickTime player

 

 

This codec when used by QuickTime is not efficient because the texture decompression is done on the CPU and so you don’t see the advantage of using the GPU to handle that texture format.

To demonstrate the speed up I used an experimental player I am working on and patched ffmpeg to handle that new codec I just created. Thanks to that I can leave the texture datas untouched and pass them to the GPU via the OpenGL extensions regarding texture compression.

When this was done I could enjoy the show and make some performance tests, file size is in MB and CPU load is taken from running top in the console:

name resolution data H264 Photo JPEG Dxt1 Dxt5 Dxt1 Compressed Dxt5 Compressed
Alternate Rotate DI 640*480 File Size 9,3 14,3 22 43,9 17,5 19,7
    CPU Load 31 30 7 9 15 18
                 
1920 HD 1920*1080 File Size 36,5 41,8 90 180 55,7 63,8
    CPU Load 99 95 13 22 42 56
                 
T25 Random Twirls 1280*720 File Size 35,9 73,2 65,9 131,8 51,5 58,4
    CPU Load 78 72 10 16 32 41
                 

If you are curious regarding frame quality here is a part of an original frame:

 

original frame Apple Intermediate

original frame Apple Intermediate

 

Here is the a part of the same frame using Dxt1

 

Part of an HD frame Dxt1 compressed

Part of an HD frame Dxt1 compressed

 

 

And here is a part of the same frame with Dxt5 compression:

 

Part of the same frame with Dxt5 compression

Part of the same frame with Dxt5 compression

 

 

The results of my test is that pure Dxt1 regarding CPU load is the best format, Dxt5 is better regarding quality but generate twice heavier files. Using Dxt1 I could play 7 HD loop at the same time with my laptop … if the data rate of my hard drive would allow it!

The problem with pure Dxt1 or Dxt5 files is that they are huge, 4 times bigger than photo jpeg or H264. To go around that I experimented with using data compression on the CPU because the CPU is now almost unused!

So using Dxt1 Compressed texture is the best solution regarding CPU usage and disk usage. The size is almost the same than photo jpeg and a little bit bigger than H 264. When using the CPU to decompress the texture data from disk the codec is still twice faster than any other codec I tested.

On my MacBook pro I can’t play a full HD loop and even at 1280*720 my machine is struggling. Using Dxt1 compressed I can play 2 HD layers and 3 720p layers.

I made available the test player I used and a set of video loops. This dmg file is for Mac OS X x86 only (no Power PC), so if you are curious here are the files:

CompressedTextureDemo.dmg (435 MB)

We will bundle that codec experiment in the next update of GrandVJ and MediaMaster, that’s for sure!

New synch experiments at WWDC

Using many computers to test my new experiment … it’s not always easy so I used the opportunity of having the compatibility lab at WWDC to check if my development is running under Snow Leopard and at least with 6 computers. There is one server and 5 clients. The clients are low end macs, Mac mini, iMacs, MacBook Pro. Here is the result:

There is a black frame when switching queues but hey, it’s a prototype 🙂

Everything is multithreaded so I move forward carefully. There are threads for the network synchronization, video decompression, OpenGL rendering and status update to the server…