Hi all,
Another feature request... Would it be possible to have "Random" added to the chaser as a direction? For scanners I generally make a bunch of positions then try and randomly scatter them in really long chases to keep the movement fresh, and having QLC+ randomly play back the positions would save much much time.
Thanks!
Random Chase Order?
Can you propose some definition for "random order"?
Let's say we have a deck (chaser) of 10 cards (steps), and you have to show a random card every one minute. How would you go about that? Would you (1) pick some card, show it and stick it back to deck? Or (2) shuffle the deck and then show the cards one by one, and when it's done, shuffle it again? Or some other way?
Note that (1) seems more random, but one card can appear several times in a row (this case can be handled as a special case), while in (2) the frequency of each card is more or less equal. What's more preferable? What properties should the random order have?
If you propose a way, I'll implement it (unless I'm really busy with other things).
--
I was thinking also of making random EFX path, but it requires similar thought... so that
e.g. the movement respects speed, is not too random, etc. I'm afraid "pick any position every x milliseconds" won't work (and neither will the motors/joints )
Let's say we have a deck (chaser) of 10 cards (steps), and you have to show a random card every one minute. How would you go about that? Would you (1) pick some card, show it and stick it back to deck? Or (2) shuffle the deck and then show the cards one by one, and when it's done, shuffle it again? Or some other way?
Note that (1) seems more random, but one card can appear several times in a row (this case can be handled as a special case), while in (2) the frequency of each card is more or less equal. What's more preferable? What properties should the random order have?
If you propose a way, I'll implement it (unless I'm really busy with other things).
--
I was thinking also of making random EFX path, but it requires similar thought... so that
e.g. the movement respects speed, is not too random, etc. I'm afraid "pick any position every x milliseconds" won't work (and neither will the motors/joints )
Hi, about this, I guess the most expected behaviour is that on 10 steps, they have to be reproduced randomly (with their own timings) with no repetitions until you reach 10. Then the random order is shuffled and played back again.
This is what happens on RGB matrix random effects at least.
This is what happens on RGB matrix random effects at least.
Effectively you want it to cycle through the cue deck, but every time it gets to the end and restarts it, it will shuffle the deck into a random order first, then play through each of them in that order. This would ensure fairness
I am in favor of a "shuffle" as well. How ever many steps are in the chaser, shuffle them.
A special case (if you want to get fancy) is when you hit the end of the 'deck' and then shuffle, there is still a chance you repeat the last one as the first in the next 'shuffle' (but never repeats more than twice).
This happens in our audio players, we have changed all "random" to "shuffle" as people expect a 'shuffle' even when they ask for 'random'.
Bob
A special case (if you want to get fancy) is when you hit the end of the 'deck' and then shuffle, there is still a chance you repeat the last one as the first in the next 'shuffle' (but never repeats more than twice).
This happens in our audio players, we have changed all "random" to "shuffle" as people expect a 'shuffle' even when they ask for 'random'.
Bob
The shuffle style thing sounds fine to me. Also Jano, a Random EFX path would be great too. Only question is would you have it draw a path (better for moving heads) or just have random points (better for snap movements on Scanners).
Ouch ! Right after I've done this so long awaited Chaser tutorial
Well done anyway
Well done anyway
-
- Posts: 21
- Joined: Thu Aug 10, 2023 1:37 pm
- Real Name: Dennis Suermann
Hey,
just a quick question: Is it intended that a random order chase connected to a button in the virtual console always starts with the first function in the chase?
As I understood it right, the order gets shuffled before playing the chase.
I am currently searching in the code if i can find the place where this is implemented.
I assume the "computeNextStep" in the ChaserRunner class is the function that is called when starting and stepping a chaser, right?
Can someone give me a hint where the start of a chaser from a virtual console is implemented?
Otherwise, i have to search the code.
Best regards,
Dennis
just a quick question: Is it intended that a random order chase connected to a button in the virtual console always starts with the first function in the chase?
As I understood it right, the order gets shuffled before playing the chase.
I am currently searching in the code if i can find the place where this is implemented.
I assume the "computeNextStep" in the ChaserRunner class is the function that is called when starting and stepping a chaser, right?
Can someone give me a hint where the start of a chaser from a virtual console is implemented?
Otherwise, i have to search the code.
Best regards,
Dennis
Last edited by Wazzledi on Thu Aug 10, 2023 1:52 pm, edited 1 time in total.
-
- Posts: 21
- Joined: Thu Aug 10, 2023 1:37 pm
- Real Name: Dennis Suermann
I actually found the line in the code that causes this "issue".
In "chaserrunner.cpp" in the write method when we execute the ChaserSetStepIndex action, which is attached and called by "vcbutton.cpp" in the pressFunction method, the index of the chase always gets set to 0.
The randomStepIndex method gets never used for this action.
Therefore, i changed the code to this:
The if statement is not necessarily needed here because the randomStepIndex method already checks the necessary condition.
Now the chase always starts with another chase function instead of always using the first one.
If that is intended behavior, i can submit a pull request, otherwise, i just use it for myself.
In "chaserrunner.cpp" in the write method when we execute the ChaserSetStepIndex action, which is attached and called by "vcbutton.cpp" in the pressFunction method, the index of the chase always gets set to 0.
The randomStepIndex method gets never used for this action.
Therefore, i changed the code to this:
Code: Select all
if(m_chaser->runOrder() == Function::Random)
{
m_lastRunStepIdx = randomStepIndex(m_pendingAction.m_stepIndex);
}
else
{
m_lastRunStepIdx = m_pendingAction.m_stepIndex;
}
Now the chase always starts with another chase function instead of always using the first one.
If that is intended behavior, i can submit a pull request, otherwise, i just use it for myself.
- mcallegari
- Posts: 4807
- Joined: Sun Apr 12, 2015 9:09 am
- Location: Italy
- Real Name: Massimo Callegari
- Contact:
Hi, please send a Pull Request and I'll check it when I have some time. Thanks