If you have a problem or need to report a bug please email : support@dsprobotics.com
There are 3 sections to this support area:
DOWNLOADS: access to product manuals, support files and drivers
HELP & INFORMATION: tutorials and example files for learning or finding pre-made modules for your projects
USER FORUMS: meet with other users and exchange ideas, you can also get help and assistance here
NEW REGISTRATIONS - please contact us if you wish to register on the forum
Users are reminded of the forum rules they sign up to which prohibits any activity that violates any laws including posting material covered by copyright
Streamable knob prototype...
16 posts
• Page 1 of 2 • 1, 2
Streamable knob prototype...
'Concept'
- A file with a bitmap containing the knob is loaded, the bitmap is then streamed across the schematic into each individual module/knob.
- Why use this ratter than the regular ruby knob you wonder?
The problem with the ruby knob...is that Ruby tends to save inside its code assembler the memory of the png file...
for that reason, if you use a ruby animated knob lets say 100 times, it will load the same bitmap 100 times, that's an incredible ineficient way of making a plugin...You do NOT want that... because every time your plugin loads in a midi sequencer/DAW, you will be using 100 times more memory than the exact efficient way necessary to run
the plugin...
This is the correct way... this is logic
You load it only once...you use coding in ruby to rotate it (!)
in this case i made an hybrid between primitive modules and ruby, because the primitive draw
allow you to stream bitmaps.
I am not a ruby developer, so if you are and you know how to stream bitmaps in ruby...
please do tell, meanwhile this is a solution i was looking!
cheers
- A file with a bitmap containing the knob is loaded, the bitmap is then streamed across the schematic into each individual module/knob.
- Why use this ratter than the regular ruby knob you wonder?
The problem with the ruby knob...is that Ruby tends to save inside its code assembler the memory of the png file...
for that reason, if you use a ruby animated knob lets say 100 times, it will load the same bitmap 100 times, that's an incredible ineficient way of making a plugin...You do NOT want that... because every time your plugin loads in a midi sequencer/DAW, you will be using 100 times more memory than the exact efficient way necessary to run
the plugin...
This is the correct way... this is logic
You load it only once...you use coding in ruby to rotate it (!)
in this case i made an hybrid between primitive modules and ruby, because the primitive draw
allow you to stream bitmaps.
I am not a ruby developer, so if you are and you know how to stream bitmaps in ruby...
please do tell, meanwhile this is a solution i was looking!
cheers
- Attachments
-
- Streamable knob prot.fsm
- (88.66 KiB) Downloaded 1027 times
- Ricciardo
- Posts: 51
- Joined: Wed Sep 11, 2013 10:19 am
Re: Streamable knob prototype...
That has nothing to do with Ruby, but with the fact that the default knobs use a green bitmap loader purposely to store the image data.
"There lies the dog buried" (German saying translated literally)
- tulamide
- Posts: 2714
- Joined: Sat Jun 21, 2014 2:48 pm
- Location: Germany
Re: Streamable knob prototype...
tulamide wrote:That has nothing to do with Ruby, but with the fact that the default knobs use a green bitmap loader purposely to store the image data.
The default knob use a bitmap loader, that's correct...
But then what happens? when you give instructions in ruby to draw the image... the assembler will keep the image...
it will store it...
just try this, open a default knob... load an image, and then remove the loader...
you will notice, the image is still there in the knob... because its not dynamic, ruby is not reading the image from the green bitmap source, ruby uses it, to load it... but it keeps the image on the assembler in memory
in my prototype, if you remove the loader, the knob disapears... check it... if you remove the loader, they are gone
because the image is being streamed dynamically, unlike in ruby case...
This is why i had all this work, trying to figure out, a way to do this...
Right now, i am making some testing, im going to compare a plugin with more than 100 knobs using the regular default knob, and other with the method i am using...
- Ricciardo
- Posts: 51
- Joined: Wed Sep 11, 2013 10:19 am
Re: Streamable knob prototype...
interesting, following.
-
lalalandsynth - Posts: 600
- Joined: Sat Oct 01, 2016 12:48 pm
Re: Streamable knob prototype...
Inputs store their value (in this case an image), but again, that has nothing to do with Ruby. It's a standard Flowstone input.
Grab a default knob, remove the bitmap loader, drag an after load prim in to the schematic and connect it to the bitmap input. Bitmap gone.
For example, all of your knobs in your example still hold the original bitmap. Test it. Right under
paste this code
See, how it draws the original bitmap right under your new one? So if at all, your version will even be worse, as it saves a bitmap AND draws another one on top. Why you didn't notice it? Because the default knob you used doesn't have a strip. It is only one image of a knob without anything that isn't used as animation. So it's only like 1/40 or even less of the size of an animated strip. That's all.
Grab a default knob, remove the bitmap loader, drag an after load prim in to the schematic and connect it to the bitmap input. Bitmap gone.
For example, all of your knobs in your example still hold the original bitmap. Test it. Right under
- Code: Select all
# DRAWING (scroll down for interaction)
paste this code
- Code: Select all
def draw v
v.drawBitmap(@image, [0, 0])
end
See, how it draws the original bitmap right under your new one? So if at all, your version will even be worse, as it saves a bitmap AND draws another one on top. Why you didn't notice it? Because the default knob you used doesn't have a strip. It is only one image of a knob without anything that isn't used as animation. So it's only like 1/40 or even less of the size of an animated strip. That's all.
"There lies the dog buried" (German saying translated literally)
- tulamide
- Posts: 2714
- Joined: Sat Jun 21, 2014 2:48 pm
- Location: Germany
Re: Streamable knob prototype...
tulamide wrote:Inputs store their value (in this case an image), but again, that has nothing to do with Ruby. It's a standard Flowstone input.
Grab a default knob, remove the bitmap loader, drag an after load prim in to the schematic and connect it to the bitmap input. Bitmap gone.
For example, all of your knobs in your example still hold the original bitmap. Test it. Right under
- Code: Select all
# DRAWING (scroll down for interaction)
paste this code
- Code: Select all
def draw v
v.drawBitmap(@image, [0, 0])
end
See, how it draws the original bitmap right under your new one? So if at all, your version will even be worse, as it saves a bitmap AND draws another one on top. Why you didn't notice it? Because the default knob you used doesn't have a strip. It is only one image of a knob without anything that isn't used as animation. So it's only like 1/40 or even less of the size of an animated strip. That's all.
hmmm, Can you show me a an example how to do thast? j
My purpose here is to not let the plugin load unnecessary amounts of memory... so basically if i understood what you said correctly... your saying that if i use the after load trigger, it will reload the knob bitmap after the plugin is working... ok...
But how the hell i clean the plugin before export dll?
because i dont want the plugin to be exported with 100 knobs containing bitmaps data wasting memory...
- Ricciardo
- Posts: 51
- Joined: Wed Sep 11, 2013 10:19 am
Re: Streamable knob prototype...
have you made any tests with 100 knobs? which makes a bigger vst dll file? The ruby knobs or the old ones?
- adamszabo
- Posts: 667
- Joined: Sun Jul 11, 2010 7:21 am
Re: Streamable knob prototype...
adamszabo wrote:have you made any tests with 100 knobs? which makes a bigger vst dll file? The ruby knobs or the old ones?
Hello adam, yes i did...
using the exact same image, i made 2 vst dummy with 80 knobs each, both with the same image loaded.
to not make an unfair comparison, i used in both as well only one loader for the image...
and that means, the first i did was to create knob, take out the loading unit, and place outside connected via wirless...
then 79 knobs were coppied....
the ruby default animated knob, using only ruby code, consumes 40 mb per instance, notice this is only a dummy...
there is no dsp code inside the module, its only to compare the eficiency of the memory usage considering the bitmaps and knob quantity....
80 knobs in ruby use 4928 components
and, my "hybrid" 80's knobs dummy, uses 9787 components... the double
so, in theory, if the "hybrid dummy" uses the double of the components, it should waste the double of the memory per instance right??
quite contrary... in my testing, each hybrid 80 knob dummy consumes per instance 26 mb... almost half of the mb used by the ruby knob...
So imagine... if we find a way of streaming a bitmap across the schematic, using ruby, combining that with another simple ruby assembler inside each knob only to the rotation stuff and save the knob data etc etc
this will be extremely efficient.. i am talking about very complex plugins (like your Viper per example) matching the memory efficiency of plugins like Dune 2 or Zebra, wich are incredibly complex, but still they only use 10/15 mb per instance...
So i ask again, if anyone in the forum knows how to stream bitmaps in ruby, please do share.. because this is very important for everyone.
- Attachments
-
- testing memory knobs.zip
- (3.97 MiB) Downloaded 1287 times
- Ricciardo
- Posts: 51
- Joined: Wed Sep 11, 2013 10:19 am
Re: Streamable knob prototype...
The old synthmaker style can be somewhat lesser on memory if You share the one bitmap loader for many knobs. Just use the
module out links and link back from interaction and put the bitmap loader modules in the main schematic.
module out links and link back from interaction and put the bitmap loader modules in the main schematic.
-
wlangfor@uoguelph.ca - Posts: 912
- Joined: Tue Apr 03, 2018 5:50 pm
- Location: North Bay, Ontario, Canada
Re: Streamable knob prototype...
Did you even check his schematics? He loads one bitmap and sends them out wirelessly to all the knobs just like you said
- adamszabo
- Posts: 667
- Joined: Sun Jul 11, 2010 7:21 am
16 posts
• Page 1 of 2 • 1, 2
Who is online
Users browsing this forum: No registered users and 13 guests