std.variant benchmark
Gor Gyolchanyan
gor.f.gyolchanyan at gmail.com
Fri Aug 3 00:41:28 PDT 2012
On Fri, Aug 3, 2012 at 8:28 AM, jerro <a at a.com> wrote:
> On Sunday, 29 July 2012 at 20:24:42 UTC, Dmitry Olshansky wrote:
>
>> On 30-Jul-12 00:11, Dmitry Olshansky wrote:
>>
>>> I've found something far more evil:
>>>
>>> @property bool convertsTo(T)() const
>>> {
>>> TypeInfo info = typeid(T);
>>> return fptr(OpID.testConversion, null, &info) == 0;
>>> }
>>>
>>> Okay... now let me pull off another piece of rag:
>>>
>>> private VariantN opArithmetic(T, string op)(T other)
>>> {
>>> VariantN result;
>>> static if (is(T == VariantN))
>>> {
>>> /*if (convertsTo!(uint) && other.convertsTo!(uint))
>>> result = mixin("get!(uint) " ~ op ~ " other.get!(uint)");
>>> else*/ if (convertsTo!(int) && other.convertsTo!(int))
>>> result = mixin("get!(int) " ~ op ~ " other.get!(int)");
>>>
>> ...
>> Apparently I'm spot on.
>> Just commenting one extra branch of this horror movie
>> gives interesting change:
>>
>> 2779us
>> 2667us
>> 3153762us
>>
>> After:
>>
>> 2319us
>> 2523us
>> 288581us
>>
>> Aye, 10x :o)
>>
>
> I profiled it and found out much of the time is spent inside
> TypeInfo.opEquals being called from tryPutting. So I tried replacing "!=
> typeid" in tryPutting with "!is typeid". That brought the time from 2.8 s
> down to 0.12 on my machine. I don't know if that is the proper solution,
> since I don't know if typeid can ever return two TypeInfo objects that
> aren't the same but are equal (I haven't used typeid and TypeInfo much
> before). The fib function here does return correct result after doing that,
> though.
>
Wow! Now that's an impressive improvement. If TypeInfo instances are unique
for every type, then we should be good to go!
--
Bye,
Gor Gyolchanyan.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.puremagic.com/pipermail/digitalmars-d/attachments/20120803/69e6a6ac/attachment.html>
More information about the Digitalmars-d
mailing list