------------------------------------------------------------------------------ -- -- -- GNAT RUN-TIME COMPONENTS -- -- -- -- A D A . N U M E R I C S . A U X _ L O N G _ F L O A T -- -- -- -- S p e c -- -- (Intrinsic/SIMD Version, Long Float) -- -- -- -- Copyright (C) 1992-2024, Free Software Foundation, Inc. -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- -- ware Foundation; either version 3, or (at your option) any later ver- -- -- sion. GNAT is distributed in the hope that it will be useful, but WITH- -- -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY -- -- or FITNESS FOR A PARTICULAR PURPOSE. -- -- -- -- As a special exception under Section 7 of GPL version 3, you are granted -- -- additional permissions described in the GCC Runtime Library Exception, -- -- version 3.1, as published by the Free Software Foundation. -- -- -- -- You should have received a copy of the GNU General Public License and -- -- a copy of the GCC Runtime Library Exception along with this program; -- -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see -- -- . -- -- -- -- GNAT was originally developed by the GNAT team at New York University. -- -- Extensive contributions were provided by Ada Core Technologies Inc. -- -- -- ------------------------------------------------------------------------------ -- This package provides the basic computational interface for the -- generic elementary functions. With the intrinsic/SIMD version, the -- compiler can use its knowledge of the functions to select the most -- suitable implementation, including a vector implementation. These -- interfaces are suitable for cases in which Long Float and C's -- double share the same representation. with Ada.Numerics.Aux_Linker_Options; pragma Warnings (Off, Ada.Numerics.Aux_Linker_Options); package Ada.Numerics.Aux_Long_Float is pragma Pure; subtype T is Long_Float; -- We import these functions as intrinsics. Note that we label them -- all as pure functions, because indeed all of them are in fact pure. function Sin (X : T) return T with Import, Convention => Intrinsic, External_Name => "sin"; pragma Machine_Attribute (Sin, "simd", "notinbranch"); function Cos (X : T) return T with Import, Convention => Intrinsic, External_Name => "cos"; pragma Machine_Attribute (Cos, "simd", "notinbranch"); function Tan (X : T) return T with Import, Convention => Intrinsic, External_Name => "tan"; function Exp (X : T) return T with Import, Convention => Intrinsic, External_Name => "exp"; pragma Machine_Attribute (Exp, "simd", "notinbranch"); function Sqrt (X : T) return T with Import, Convention => Intrinsic, External_Name => "sqrt"; function Log (X : T) return T with Import, Convention => Intrinsic, External_Name => "log"; pragma Machine_Attribute (Log, "simd", "notinbranch"); function Acos (X : T) return T with Import, Convention => Intrinsic, External_Name => "acos"; function Asin (X : T) return T with Import, Convention => Intrinsic, External_Name => "asin"; function Atan (X : T) return T with Import, Convention => Intrinsic, External_Name => "atan"; function Sinh (X : T) return T with Import, Convention => Intrinsic, External_Name => "sinh"; function Cosh (X : T) return T with Import, Convention => Intrinsic, External_Name => "cosh"; function Tanh (X : T) return T with Import, Convention => Intrinsic, External_Name => "tanh"; function Pow (X, Y : T) return T with Import, Convention => Intrinsic, External_Name => "pow"; pragma Machine_Attribute (Pow, "simd", "notinbranch"); end Ada.Numerics.Aux_Long_Float;