<div class="gmail_quote">On 6 January 2012 21:21, Walter Bright <span dir="ltr"><<a href="mailto:newshound2@digitalmars.com">newshound2@digitalmars.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">1. the language does typechecking, for example, trying to add a vector of 4 floats to 16 bytes would be (and should be) an error.</div>
</blockquote></div><br><div>I want to sell you on the 'primitive SIMD regs are truly typeless' point. (which I thought you had already agreed with) :)</div><div><br></div><div>Here are some examples of tight interacting between int/float, and interacting ON floats with int operations...</div>
<div>Naturally the examples I present will be wrapped as useful functions in libraries, but the primitive type shouldn't try and make this more annoying by trying to enforce pointless type safety errors like you seem to be suggesting.</div>
<div><br></div><div>In computer graphics it's common to work with float16's, a type not supported by simd units. Pack/Unpack code involved detailed float/int interaction.</div><div>You might take a register of floats, then mask the exponent and then perform integer arithmetic on the exponent to shift it into the float16 exponent range... then you will mask the bottom of the mantissa and shift them into place.</div>
<div>Unpacking is same process in reverse.</div><div><br></div><div>Other tricks with the float sign bits, making everything negative, by or-ing in 1's into the top bits. or you can gather the signs using various techniques.. useful for identifying the cell in a quad-tree for instance.</div>
<div>Integer manipulation of floats is surprisingly common.</div>