<div class="gmail_quote">On 15 March 2012 20:35, Robert Jacques <span dir="ltr"><<a href="mailto:sandford@jhu.edu">sandford@jhu.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="HOEnZb"><div class="h5">On Thu, 15 Mar 2012 12:09:58 -0500, Manu <<a href="mailto:turkeyman@gmail.com" target="_blank">turkeyman@gmail.com</a>> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hey chaps (and possibly lasses?)<br>
<br>
I've been slowly working a std.simd library, the aim of which is to provide<br>
a lowest-level hardware-independent SIMD interface. core.simd implements<br>
SSE currently for x86, other architectures are currently exposed via<br>
gcc.builtins.<br>
The purpose of std.simd, is to be the lowest level API that people make<br>
direct use of, while still having as-close-to-direct-as-possible mapping to<br>
the hardware opcodes, but still being portable. I would expect that custom,<br>
more-feature-rich SIMD/vector/matrix/linear algebra libraries should be<br>
built on top of std.simd in future, that way being portable to as many<br>
systems as possible.<br>
<br>
Now I've reached a question in the design of the library, I'd like to take<br>
a general consensus.<br>
<br>
lowest level vectors are defined by: __vector(type[width])<br>
But core.simd also defines a bunch of handy 'nice' aliases for common<br>
vector types, ie, float4, int4, short8, etc.<br>
<br>
I want to claim those names into std.simd. They should be the lowest level<br>
names that people use, and therefore associate with the std.simd<br>
functionality.<br>
I also want to enhance them a bit:<br>
I want to make them a struct that wraps the primitive rather than an<br>
alias. I understand this single-POD struct will be handled the same as the<br>
POD its self, is that right? If I pass the wrapper struct byval to a<br>
function, it will be passed in a register as it should yeah?<br>
I then intend to then add CTFE support, and maybe some properties and<br>
opDisplatch bits.<br>
<br>
Does this sound reasonable?<br>
</blockquote>
<br></div></div>
This sounds reasonable. However, please realize that if you wish to use the short vector names (i.e. float4, float3, float2, etc) you should support the full set with a decent range of operations and methods. Several people (myself included) have written similar short vector libraries; I think having having short vectors in phobos is important, but having one library provide float4 and another float2 is less than ideal, even if not all of the types could leverage the SMID backend. For myself, the killer feature for such a library would be have the CUDA compatible alignments for the types. (or an equivalent enum to the effect)<br>
</blockquote></div><div><br></div><div>I can see how you come to that conclusion, but I generally feel that that's a problem for a higher layer of library.</div><div>I really feel it's important to keep std.simd STRICTLY about the hardware simd operations, only implementing what the hardware can express efficiently, and not trying to emulate anything else. In some areas I feel I've already violated that premise, by adding some functions to make good use of something that NEON/VMX can express in a single opcode, but takes SSE 2-3. I don't want to push that bar, otherwise the user will lose confidence that the functions in std.simd will actually work efficiently on any given hardware.</div>
<div>It's not a do-everything library, it's a hardware SIMD abstraction, and most functions map to exactly one hardware opcode. I expect most people will want to implement their own higher level lib on top tbh; almost nobody will ever agree on what the perfect maths library should look like, and it's also context specific.</div>