I’m capturing a camera stream and performing some fairly intensive computer vision on the frames (using a C++ DLL), and then sending the video to another program over Spout and the CV data over websockets.
The computer vision is bringing down my overall framerate to <30FPS, which also slows down the Spout framerate. TD has helpfully synced up everything, which would be awesome in a lot of cases, but I don’t actually need to synchronize; it’s ok if the video stream comes in at 60FPS and the websocket data at 30FPS. The receiving program doesn’t need them to be in perfect lockstep, and a little delay is totally ok.
So, I’m wondering if it’s possible to decouple the two. Can one part of my network run at 60FPS and another at 30FPS, or is that a fundamental impossibility?
Note - I ended up adding threading to my C++ DLL, and just dropping every other frame. Works like a charm, but I’m still curious if there’s a way to do this at the TD level, especially if I was using built-in OPs instead of a custom DLL.
One option might be to break this into multiple processes - something like the new Process COMP in the experimental branch might be something that address this need.
In a recent application I worked on video frames were sent via either spout or ‘shared memory’ to a fully independent c++ application. Once processing of the video frame is complete the results can be handled at the developer’s discretion. This nicely decouples touchdesigner and its draw loop from the work done in c++.
To have a sub-section of your file run at 30fps, you can add a Component Time to a COMP (under the right click menu for the network). This is a secondary timeline that can run at a lower FPS than your main file is. Ideally the FPS should evenly divide your main FPS. So 30 and 60 is fine