Skip to content
Merged
Show file tree
Hide file tree
Changes from 82 commits
Commits
Show all changes
89 commits
Select commit Hold shift + click to select a range
589afe0
Add api for BFloat16
huoyaoyuan Feb 18, 2024
312d051
Creating
huoyaoyuan Feb 18, 2024
5e1c981
Equals and GetHashCode
huoyaoyuan Feb 18, 2024
1fb4765
Comparison
huoyaoyuan Feb 18, 2024
fc05d3b
Constants and comment
huoyaoyuan Feb 18, 2024
152fe99
Xml doc
huoyaoyuan Feb 18, 2024
25a16e7
Using rounding for cast
huoyaoyuan Feb 18, 2024
50d90aa
Ref source
huoyaoyuan Feb 18, 2024
559f2e0
Simple tests
huoyaoyuan Feb 18, 2024
b24839c
Conversion tests
huoyaoyuan Feb 19, 2024
8284526
Stripping sign is redundant
huoyaoyuan Feb 19, 2024
8e32e71
Fix test copied from Half
huoyaoyuan Feb 19, 2024
4bd266e
Fix conversion test cases
huoyaoyuan Feb 19, 2024
6df00e6
Constants and well-known values
huoyaoyuan Feb 21, 2024
ff295fd
Categorizing methods
huoyaoyuan Feb 21, 2024
09af2b2
Reorder conversion members
huoyaoyuan Feb 21, 2024
1a8f0ad
Operators batch 1
huoyaoyuan Feb 21, 2024
c9fc867
Operators batch 2
huoyaoyuan Feb 21, 2024
e9fc0f8
TryConvert
huoyaoyuan Feb 21, 2024
c967aa5
Operators batch 3
huoyaoyuan Feb 21, 2024
17c13c0
Parsing and formatting
huoyaoyuan Feb 21, 2024
ad780a0
Add comments about how to determine parse and format info
huoyaoyuan Feb 21, 2024
c01949f
Add missing interface implementations
huoyaoyuan Feb 21, 2024
b63c1df
NumberBufferLength
huoyaoyuan Feb 21, 2024
754a3c8
Add more comment
huoyaoyuan Feb 22, 2024
bcc260f
Correct MinFastFloatDecimalExponent
huoyaoyuan Feb 24, 2024
5a3d200
Add explicit conversion to
huoyaoyuan Feb 24, 2024
c420dd3
Explicit convert from
huoyaoyuan Feb 24, 2024
13e65d1
Fullfill casting operators
huoyaoyuan Feb 24, 2024
8c5f546
Fullfill some formatting
huoyaoyuan Feb 24, 2024
0cb3932
Apply suggestions from code review
huoyaoyuan Apr 6, 2024
b615e68
Merge branch 'main' into BFloat16
huoyaoyuan Apr 6, 2024
8f70d91
Generic DiyFp
huoyaoyuan Feb 24, 2024
2458dd8
Generic Grisu3
huoyaoyuan Feb 24, 2024
a8bb94b
Generic Dragon4
huoyaoyuan Feb 24, 2024
9644914
Add MaxRoundTripDigits to MaxPrecisionCustomFormat to FormatInfo
huoyaoyuan Feb 25, 2024
a29db5c
Generic FormatFloat
huoyaoyuan Feb 25, 2024
a8a8a49
Adapt with existing FP types
huoyaoyuan Feb 25, 2024
2fd392f
Merge branch 'fp-formatting-generic' into BFloat16
huoyaoyuan Apr 6, 2024
f1582e7
Adapt formatting traits
huoyaoyuan Apr 6, 2024
eace3a6
Use generic format and delete Number.BFloat16
huoyaoyuan Apr 6, 2024
abd1e80
Update ref source
huoyaoyuan Apr 6, 2024
62156c9
Merge branch 'main'
huoyaoyuan May 3, 2024
e8012c9
Enable constant value tests
huoyaoyuan May 3, 2024
f711f8d
IsFinite/IsNaN
huoyaoyuan May 3, 2024
08168ff
IsPositive/IsNegative/IsSubnormal
huoyaoyuan May 3, 2024
d59a8c5
ToDouble
huoyaoyuan May 3, 2024
eb6dc47
Merge branch 'main' into BFloat16
huoyaoyuan May 23, 2024
25b7684
Merge branch 'main'
huoyaoyuan Jun 4, 2024
832651e
Merge branch 'main' into BFloat16
huoyaoyuan Jun 9, 2024
a07fe96
Fix test case
huoyaoyuan Jun 9, 2024
f9c35d3
Add double conversion test
huoyaoyuan Jun 9, 2024
4059b66
Parse tests
huoyaoyuan Jun 9, 2024
4b4d1a5
Formatting tests
huoyaoyuan Jun 9, 2024
6ed52f5
RoundTripping tests
huoyaoyuan Jun 9, 2024
14b0d85
Port float->Half conversion algorithm to double->BFloat16 to handle U…
huoyaoyuan Jun 10, 2024
ea1dd5f
Port function tests from Half
huoyaoyuan Jun 10, 2024
dfd49c8
Convert the precesion of test cases.
huoyaoyuan Jun 10, 2024
f5461ac
Merge branch 'main' into BFloat16
danmoseley Dec 2, 2024
daaec69
Merge branch 'main' into BFloat16
huoyaoyuan Dec 29, 2024
9938e8b
Align with TryWriteBig/LittleEndian
huoyaoyuan Dec 29, 2024
b889417
Remove redundant 'partial'
huoyaoyuan Dec 31, 2024
1282c85
Merge branch 'main' into BFloat16
tannergooding Jan 27, 2025
e6dd118
Merge branch 'main' into BFloat16
huoyaoyuan Feb 6, 2025
922f411
Use DefaultParseStyle
huoyaoyuan Feb 6, 2025
86dce2d
Fill conversion in signed integer
huoyaoyuan Feb 6, 2025
9f729a3
Fill conversion in unsigned integer and floating point
huoyaoyuan Feb 6, 2025
6baf940
Add conversion for S.R.Numerics
huoyaoyuan Feb 6, 2025
fb88f8e
Use float member function instead of MathF
huoyaoyuan Feb 6, 2025
d697344
Fill conversion in decimal
huoyaoyuan Feb 7, 2025
4e83ad9
Add conversion for NFloat
huoyaoyuan Feb 7, 2025
d58c80a
Use soft rounding for uint->bf16
huoyaoyuan Feb 9, 2025
8639fa3
Generic math rounding from unsigned and signed integer
huoyaoyuan Feb 10, 2025
34b1d07
Cleanup helper methods
huoyaoyuan Feb 10, 2025
8adbeb2
Add integer rounding tests
huoyaoyuan Feb 10, 2025
1f2653f
Move helpers and fix comment
huoyaoyuan Feb 11, 2025
9046622
Update comment
huoyaoyuan Feb 11, 2025
c372590
Merge branch 'main'
huoyaoyuan Jun 25, 2025
5302790
Fix ILogB
huoyaoyuan Jun 25, 2025
317400d
Merge branch 'main' into BFloat16
jeffhandley Sep 1, 2025
4fabff9
Merge branch 'main' into BFloat16
huoyaoyuan Sep 2, 2025
5549afa
Merge branch 'main' into BFloat16
tannergooding Sep 18, 2025
a071699
Apply suggestions from code review
huoyaoyuan Sep 19, 2025
1a7e65a
Move conversion interface to BFloat16
huoyaoyuan Sep 19, 2025
3268b4a
Add missing conversion to Half
huoyaoyuan Sep 19, 2025
87fb85f
Remove NFloat conversion
huoyaoyuan Sep 19, 2025
a8111e4
Tune CreateSingle/CreateDouble
huoyaoyuan Sep 19, 2025
f1f7ca7
Adjust constant naming
huoyaoyuan Sep 20, 2025
2acf213
Use <summary> for math expression
huoyaoyuan Sep 20, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -4379,6 +4379,9 @@
<data name="NotSupported_EmitDebugInfo" xml:space="preserve">
<value>Emitting debug info is not supported for this member.</value>
</data>
<data name="Arg_MustBeBFloat16" xml:space="preserve">
<value>Object must be of type BFloat16.</value>
</data>
<data name="NotSupported_ReferenceEnumOrPrimitiveTypeRequired" xml:space="preserve">
<value>The specified type must be a reference type, a primitive type, or an enum type.</value>
</data>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -603,6 +603,7 @@
<Compile Include="$(MSBuildThisFileDirectory)System\Number.Grisu3.cs" />
<Compile Include="$(MSBuildThisFileDirectory)System\Number.NumberToFloatingPointBits.cs" />
<Compile Include="$(MSBuildThisFileDirectory)System\Number.Parsing.cs" />
<Compile Include="$(MSBuildThisFileDirectory)System\Numerics\BFloat16.cs" />
<Compile Include="$(MSBuildThisFileDirectory)System\Numerics\BitOperations.cs" />
<Compile Include="$(MSBuildThisFileDirectory)System\Numerics\Matrix3x2.cs" />
<Compile Include="$(MSBuildThisFileDirectory)System\Numerics\Matrix3x2.Impl.cs" />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
// The .NET Foundation licenses this file to you under the MIT license.

using System.Diagnostics;
using System.Numerics;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using System.Runtime.Intrinsics;
Expand Down Expand Up @@ -947,6 +948,10 @@ public static bool ToBoolean(ReadOnlySpan<byte> value)
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static Half Int16BitsToHalf(short value) => new Half((ushort)(value));

internal static short BFloat16BitsToInt16(BFloat16 value) => (short)value._value;

internal static BFloat16 Int16BitsToBFloat16(short value) => new BFloat16((ushort)(value));

/// <summary>
/// Converts the specified double-precision floating point number to a 64-bit unsigned integer.
/// </summary>
Expand Down Expand Up @@ -1000,5 +1005,9 @@ public static bool ToBoolean(ReadOnlySpan<byte> value)
[CLSCompliant(false)]
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static Half UInt16BitsToHalf(ushort value) => new Half(value);

internal static ushort BFloat16BitsToUInt16(BFloat16 value) => value._value;

internal static BFloat16 UInt16BitsToBFloat16(ushort value) => new BFloat16(value);
}
}
18 changes: 18 additions & 0 deletions src/libraries/System.Private.CoreLib/src/System/Byte.cs
Original file line number Diff line number Diff line change
Expand Up @@ -906,6 +906,12 @@ static bool INumberBase<byte>.TryConvertToChecked<TOther>(byte value, [MaybeNull
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualResult = value;
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualResult = value;
Expand Down Expand Up @@ -980,6 +986,12 @@ static bool INumberBase<byte>.TryConvertToSaturating<TOther>(byte value, [MaybeN
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualResult = value;
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualResult = value;
Expand Down Expand Up @@ -1054,6 +1066,12 @@ static bool INumberBase<byte>.TryConvertToTruncating<TOther>(byte value, [MaybeN
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualResult = value;
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualResult = value;
Expand Down
12 changes: 12 additions & 0 deletions src/libraries/System.Private.CoreLib/src/System/Decimal.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1661,6 +1661,12 @@ static bool INumberBase<decimal>.TryConvertToChecked<TOther>(decimal value, [May
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualResult = checked((BFloat16)value);
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualResult = checked((short)value);
Expand Down Expand Up @@ -1749,6 +1755,12 @@ private static bool TryConvertTo<TOther>(decimal value, [MaybeNullWhen(false)] o
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualResult = (BFloat16)value;
result = (TOther)(object)actualResult;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualResult = (value >= short.MaxValue) ? short.MaxValue :
Expand Down
8 changes: 8 additions & 0 deletions src/libraries/System.Private.CoreLib/src/System/Double.cs
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,8 @@ internal static ulong ExtractTrailingSignificandFromBits(ulong bits)
return bits & TrailingSignificandMask;
}

internal static double CreateDouble(bool sign, ushort exp, ulong sig) => BitConverter.UInt64BitsToDouble(((sign ? 1UL : 0UL) << double.SignShift) + ((ulong)exp << double.BiasedExponentShift) + sig);

/// <summary>Determines whether the specified value is finite (zero, subnormal, or normal).</summary>
/// <remarks>This effectively checks the value is not NaN and not infinite.</remarks>
[NonVersionable]
Expand Down Expand Up @@ -1245,6 +1247,12 @@ private static bool TryConvertFrom<TOther>(TOther value, out double result)
result = (double)actualValue;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (double)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down
22 changes: 9 additions & 13 deletions src/libraries/System.Private.CoreLib/src/System/Half.cs
Original file line number Diff line number Diff line change
Expand Up @@ -738,8 +738,8 @@ public static explicit operator Half(float value)
const uint SingleBiasedExponentMask = float.BiasedExponentMask;
// Exponent displacement #2
const uint Exponent13 = 0x0680_0000u;
// Maximum value that is not Infinity in Half
const float MaxHalfValueBelowInfinity = 65520.0f;
// The maximum infinitely precise value that will round down to MaxValue
const float HalfAboveMaxValue = 65520.0f;
// Mask for exponent bits in Half
const uint ExponentMask = BiasedExponentMask;
uint bitValue = BitConverter.SingleToUInt32Bits(value);
Expand All @@ -750,7 +750,7 @@ public static explicit operator Half(float value)
// Clear sign bit
value = float.Abs(value);
// Rectify values that are Infinity in Half. (float.Min now emits vminps instruction if one of two arguments is a constant)
value = float.Min(MaxHalfValueBelowInfinity, value);
value = float.Min(HalfAboveMaxValue, value);
// Rectify lower exponent
uint exponentOffset0 = BitConverter.SingleToUInt32Bits(float.Max(value, BitConverter.UInt32BitsToSingle(MinExp)));
// Extract exponent
Expand Down Expand Up @@ -1015,7 +1015,7 @@ public static explicit operator double(Half value)
exp -= 1;
}

return CreateDouble(sign, (ushort)(exp + 0x3F0), (ulong)sig << 42);
return double.CreateDouble(sign, (ushort)(exp + 0x3F0), (ulong)sig << 42);
}

/// <summary>Explicitly converts a half-precision floating-point value to its nearest representable <see cref="float" /> value.</summary>
Expand Down Expand Up @@ -1177,10 +1177,6 @@ private static double CreateDoubleNaN(bool sign, ulong significand)
return BitConverter.UInt64BitsToDouble(signInt | NaNBits | sigInt);
}

private static float CreateSingle(bool sign, byte exp, uint sig) => BitConverter.UInt32BitsToSingle(((sign ? 1U : 0U) << float.SignShift) + ((uint)exp << float.BiasedExponentShift) + sig);

private static double CreateDouble(bool sign, ushort exp, ulong sig) => BitConverter.UInt64BitsToDouble(((sign ? 1UL : 0UL) << double.SignShift) + ((ulong)exp << double.BiasedExponentShift) + sig);

#endregion

//
Expand Down Expand Up @@ -1360,7 +1356,7 @@ int IFloatingPoint<Half>.GetExponentShortestBitLength()
int IFloatingPoint<Half>.GetSignificandByteCount() => sizeof(ushort);

/// <inheritdoc cref="IFloatingPoint{TSelf}.GetSignificandBitLength()" />
int IFloatingPoint<Half>.GetSignificandBitLength() => 11;
int IFloatingPoint<Half>.GetSignificandBitLength() => SignificandLength;

/// <inheritdoc cref="IFloatingPoint{TSelf}.TryWriteExponentBigEndian(Span{byte}, out int)" />
bool IFloatingPoint<Half>.TryWriteExponentBigEndian(Span<byte> destination, out int bytesWritten)
Expand Down Expand Up @@ -2339,7 +2335,7 @@ public static bool TryParse(ReadOnlySpan<byte> utf8Text, NumberStyles style, IFo
static int IBinaryFloatParseAndFormatInfo<Half>.NumberBufferLength => Number.HalfNumberBufferLength;

static ulong IBinaryFloatParseAndFormatInfo<Half>.ZeroBits => 0;
static ulong IBinaryFloatParseAndFormatInfo<Half>.InfinityBits => 0x7C00;
static ulong IBinaryFloatParseAndFormatInfo<Half>.InfinityBits => PositiveInfinityBits;

static ulong IBinaryFloatParseAndFormatInfo<Half>.NormalMantissaMask => (1UL << SignificandLength) - 1;
static ulong IBinaryFloatParseAndFormatInfo<Half>.DenormalMantissaMask => TrailingSignificandMask;
Expand All @@ -2351,15 +2347,15 @@ public static bool TryParse(ReadOnlySpan<byte> utf8Text, NumberStyles style, IFo
static int IBinaryFloatParseAndFormatInfo<Half>.MaxDecimalExponent => 5;

static int IBinaryFloatParseAndFormatInfo<Half>.ExponentBias => ExponentBias;
static ushort IBinaryFloatParseAndFormatInfo<Half>.ExponentBits => 5;
static ushort IBinaryFloatParseAndFormatInfo<Half>.ExponentBits => BiasedExponentLength;

static int IBinaryFloatParseAndFormatInfo<Half>.OverflowDecimalExponent => (MaxExponent + (2 * SignificandLength)) / 3;
static int IBinaryFloatParseAndFormatInfo<Half>.InfinityExponent => 0x1F;
static int IBinaryFloatParseAndFormatInfo<Half>.InfinityExponent => MaxBiasedExponent;

static ushort IBinaryFloatParseAndFormatInfo<Half>.NormalMantissaBits => SignificandLength;
static ushort IBinaryFloatParseAndFormatInfo<Half>.DenormalMantissaBits => TrailingSignificandLength;

static int IBinaryFloatParseAndFormatInfo<Half>.MinFastFloatDecimalExponent => -8;
static int IBinaryFloatParseAndFormatInfo<Half>.MinFastFloatDecimalExponent => -26;
static int IBinaryFloatParseAndFormatInfo<Half>.MaxFastFloatDecimalExponent => 4;

static int IBinaryFloatParseAndFormatInfo<Half>.MinExponentRoundToEven => -21;
Expand Down
20 changes: 20 additions & 0 deletions src/libraries/System.Private.CoreLib/src/System/Int128.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1522,6 +1522,12 @@ private static bool TryConvertFromChecked<TOther>(TOther value, out Int128 resul
result = checked((Int128)actualValue);
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = checked((Int128)actualValue);
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down Expand Up @@ -1594,6 +1600,13 @@ private static bool TryConvertFromSaturating<TOther>(TOther value, out Int128 re
result = (Int128)actualValue;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x7F00)) /* (BFloat16)MaxValue */ ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xFF00)) /* (BFloat16)MinValue */ ? MinValue : (Int128)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down Expand Up @@ -1666,6 +1679,13 @@ private static bool TryConvertFromTruncating<TOther>(TOther value, out Int128 re
result = (Int128)actualValue;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x7F00)) ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xFF00)) ? MinValue : (Int128)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down
24 changes: 22 additions & 2 deletions src/libraries/System.Private.CoreLib/src/System/Int16.cs
Original file line number Diff line number Diff line change
Expand Up @@ -898,6 +898,12 @@ private static bool TryConvertFromChecked<TOther>(TOther value, out short result
result = checked((short)actualValue);
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = checked((short)actualValue);
return true;
}
else if (typeof(TOther) == typeof(int))
{
int actualValue = (int)(object)value;
Expand Down Expand Up @@ -968,8 +974,15 @@ private static bool TryConvertFromSaturating<TOther>(TOther value, out short res
else if (typeof(TOther) == typeof(Half))
{
Half actualValue = (Half)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToHalf(0x7800)) ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToHalf(0xF800)) ? MinValue : (short)actualValue;
result = (actualValue >= BitConverter.UInt16BitsToHalf(0x7800)) /* (Half)MaxValue */ ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToHalf(0xF800)) /* (Half)MinValue */ ? MinValue : (short)actualValue;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x4700)) /* (BFloat16)MaxValue */ ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xB700)) /* (BFloat16)MinValue */ ? MinValue : (short)actualValue;
return true;
}
else if (typeof(TOther) == typeof(int))
Expand Down Expand Up @@ -1051,6 +1064,13 @@ private static bool TryConvertFromTruncating<TOther>(TOther value, out short res
(actualValue <= BitConverter.UInt16BitsToHalf(0xF800)) ? MinValue : (short)actualValue;
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x4700)) ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xB700)) ? MinValue : (short)actualValue;
return true;
}
else if (typeof(TOther) == typeof(int))
{
int actualValue = (int)(object)value;
Expand Down
20 changes: 20 additions & 0 deletions src/libraries/System.Private.CoreLib/src/System/Int32.cs
Original file line number Diff line number Diff line change
Expand Up @@ -939,6 +939,12 @@ private static bool TryConvertFromChecked<TOther>(TOther value, out int result)
result = checked((int)actualValue);
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = checked((int)actualValue);
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down Expand Up @@ -1021,6 +1027,13 @@ private static bool TryConvertFromSaturating<TOther>(TOther value, out int resul
#endif
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x4F00)) /* (BFloat16)MaxValue */ ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xBF00)) /* (BFloat16)MinValue */ ? MinValue : (int)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down Expand Up @@ -1111,6 +1124,13 @@ private static bool TryConvertFromTruncating<TOther>(TOther value, out int resul
#endif
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x4F00)) ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xBF00)) ? MinValue : (int)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down
20 changes: 20 additions & 0 deletions src/libraries/System.Private.CoreLib/src/System/Int64.cs
Original file line number Diff line number Diff line change
Expand Up @@ -936,6 +936,12 @@ private static bool TryConvertFromChecked<TOther>(TOther value, out long result)
result = checked((long)actualValue);
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = checked((long)actualValue);
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down Expand Up @@ -1018,6 +1024,13 @@ private static bool TryConvertFromSaturating<TOther>(TOther value, out long resu
#endif
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x5F00)) /* (BFloat16)MaxValue */ ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xCF00)) /* (BFloat16)MinValue */ ? MinValue : (long)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down Expand Up @@ -1106,6 +1119,13 @@ private static bool TryConvertFromTruncating<TOther>(TOther value, out long resu
#endif
return true;
}
else if (typeof(TOther) == typeof(BFloat16))
{
BFloat16 actualValue = (BFloat16)(object)value;
result = (actualValue >= BitConverter.UInt16BitsToBFloat16(0x5F00)) ? MaxValue :
(actualValue <= BitConverter.UInt16BitsToBFloat16(0xCF00)) ? MinValue : (long)actualValue;
return true;
}
else if (typeof(TOther) == typeof(short))
{
short actualValue = (short)(object)value;
Expand Down
Loading
Loading