[Numpy-discussion] hstack(arr_Int32, arr_float32) fails because of casting rules

Travis Oliphant oliphant.travis at ieee.org
Fri Aug 25 00:03:10 EDT 2006


Sebastian Haase wrote:
> On Thursday 24 August 2006 17:28, Travis Oliphant wrote:
>   
>> Sebastian Haase wrote:
>>     
>>> Hi,
>>> I get
>>> TypeError: array cannot be safely cast to required type
>>>
>>> when calling hstack()  ( which calls  concatenate() )
>>> on two arrays being a int32 and a float32 respectively.
>>>
>>> I understand now that a int32 cannot be safely converted into a float32
>>> but why does  concatenate  not automatically
>>> up(?) cast to float64  ??
>>>       
>> Basically, NumPy is following Numeric's behavior of raising an error in
>> this case of unsafe casting in concatenate.  For functions that are not
>> universal-function objects, mixed-type behavior works basically just
>> like Numeric did (using the ordering of the types to determine which one
>> to choose as the output).
>>
>> It could be argued that the ufunc-rules should be followed instead.
>>
>> -Travis
>>
>>     
> Are you saying the  ufunc-rules  would convert "int32-float32" to float64  and 
> hence make my code "just work" !?
>   

This is now the behavior in SVN.   Note that this is different from both 
Numeric (which gave an error) and numarray (which coerced to float32). 

But, it is consistent with how mixed-types are handled in calculations 
and is thus an easier rule to explain.

Thanks for the testing.

-Travis





More information about the NumPy-Discussion mailing list