-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Combinations avoiding patterns #6
Comments
Well, I don't know of a fast method, but combinations right now supports indexing. That is, you can ask it for the i-th combination, so if you simply shuffle the integers {0,1,...,binomial(n,k)-1} and then do auto X = combinations(n,k);
for (size_t i = 0; i < X.size(); ++i)
{
auto combination = X[S[i]];
} where S = shuffled indices. It won't be fast (only about a million combinations per second) but maybe it doesn't matter. |
Thanks. I just realized what I meant was "non-decreasing sequences"/"combinations with repetition" but I don't think it makes much difference in this context. If there were a way to access these sequences/combinations in random order (or pseudo-random, or at least avoiding patterns) without the shuffled indexes, this could be useful in many environments. Whenever the number of sequences grows exponentially on the number of items (factorial hypothesis tests and generate-and-test algorithms), it's not viable to keep a list of random indexes and, because of that, people usually recur to algorithms that resample, which is very inefficient and it's impossible to know if the algorithm been through all sequences/combinations. If you know of any algorithm we can put in a container interface to do that, please let me know. Maybe I can help implement this container. |
Hello @alandefreitas, As mentioned in the README, combinations with repetitions isn't currently available. Until then, your problem can easily be attacked by doing the following:
You can alter the method below for the case with repetition: discreture/include/Discreture/Combinations.hpp Lines 684 to 707 in c90e939
@mraggi, please correct me if I am wrong. Hope that helps! |
Thank you for the great library.
Given your experiment, is there (or is it possible to implement) any algorithm or container interface that enumerates all combinations in a pseudo-random order (or at least avoiding patterns) without resampling?
Of course, apart from the impracticable alternative of keeping all possible combinations in memory and shuffling them.
This can be very useful for hypothesis testing and generate-and-test algorithms.
For instance, if we had these combinations:
I'm wondering if there would be a container interface that would return these combinations in random order (or at least an order that avoids patterns) but still being a container interface (without keeping all combinations in memory and shuffling a list of indexes).
In statistics, we could use that for randomized experiment control. In generate-and-test heuristics, this would be a systematic way of enumerating the search space without getting stuck in a region of the objective function.
Thank you.
The text was updated successfully, but these errors were encountered: