<div dir="auto">What do you mean by good random properties? It should be uniformly distributed. Do you see any problem in Collection>>#atRandom: or Bag>>#atRandom:?</div><div dir="auto"><br></div><div dir="auto">Thanks!</div><div dir="auto">Luciano</div><div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sat, 14 May 2022 at 4:57 AM Juan Vuletich <<a href="mailto:JuanVuletich@zoho.com">JuanVuletich@zoho.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;padding-left:1ex;border-left-color:rgb(204,204,204)"><u></u>
<div bgcolor="#ffffff" text="#000000">
Anyone using #atRandom: on a non-sequenceable collection should be
aware that no good random properties can be guaranteed, right?<br>
<br>
Anyway, just pushed to GitHub.<br>
<br>
Thanks,</div><div bgcolor="#ffffff" text="#000000"><br>
<br>
On 5/9/2022 7:56 AM, Luciano Notarfrancesco via Cuis-dev wrote:
<blockquote type="cite">
<div>Juan, please don't forget to look at the changeset in my
previous mail when you have time.
<div><br>
</div>
<div>Here are some additional tweaks. I reimplemented
Collection>>#identityIncludes: using #allSatisfy:
instead of #do:, in this way it is fast for Bags too, and it
mirrors the implementation of Collection>>#includes:.</div>
<div><br>
</div>
<div>I also implemented a fast Bag>>#atRandom:, and
implemented a general Collection>>#atRandom:. Originally
#atRandom: was not implemented in Collection, so I implemented
a generic version that only assumes the collection
understands #size and #do:.</div>
<div><br>
</div>
<div>Thanks,</div>
<div>Luciano</div>
</div>
<br>
<div>
<div>On Tue, May 3, 2022 at 7:54 AM Luciano Notarfrancesco <<a href="mailto:luchiano@gmail.com" target="_blank">luchiano@gmail.com</a>>
wrote:<br>
</div>
<blockquote>
<div>Here are some more methods that take advantage of the
structure of a Bag (#allSatisfy:, #anySatisfy:, #max:,
#min:, #sum:, etc).
<div><br>
</div>
<div>Also made some tweaks to some methods in Collection to
call existing methods instead of reimplementing, in order
to simplify the changes in Bag (otherwise. for example,
I'd have to implement #sum, #sum: and #sum:ifEmpty: in Bag
instead of only implementing #sum:ifEmpty). And I changed
Collection>>#product to produce an error when the
collection is empty instead of returning 1 (to be
consistent with Collection>>#sum:).</div>
<div><br>
</div>
<div>All base image tests pass, but please review.
<div><br>
</div>
<div>Also, while running tests I got a walkback on
BitBltCanvasEngine, see the attached log.</div>
</div>
</div>
</blockquote>
</div>
</blockquote>
<br>
<br>
<pre cols="72" style="font-family:monospace">--
Juan Vuletich
<a href="http://www.cuis-smalltalk.org" target="_blank" style="font-family:monospace">www.cuis-smalltalk.org</a>
<a href="https://github.com/Cuis-Smalltalk/Cuis-Smalltalk-Dev" target="_blank" style="font-family:monospace">https://github.com/Cuis-Smalltalk/Cuis-Smalltalk-Dev</a>
<a href="https://github.com/jvuletich" target="_blank" style="font-family:monospace">https://github.com/jvuletich</a>
<a href="https://www.linkedin.com/in/juan-vuletich-75611b3" target="_blank" style="font-family:monospace">https://www.linkedin.com/in/juan-vuletich-75611b3</a>
<a href="https://independent.academia.edu/JuanVuletich" target="_blank" style="font-family:monospace">https://independent.academia.edu/JuanVuletich</a>
<a href="https://www.researchgate.net/profile/Juan-Vuletich" target="_blank" style="font-family:monospace">https://www.researchgate.net/profile/Juan-Vuletich</a>
<a href="https://patents.justia.com/inventor/juan-manuel-vuletich" target="_blank" style="font-family:monospace">https://patents.justia.com/inventor/juan-manuel-vuletich</a>
<a href="https://twitter.com/JuanVuletich" target="_blank" style="font-family:monospace">https://twitter.com/JuanVuletich</a></pre>
</div>
</blockquote></div></div>