12 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Release 0.2.17 (2023-10-07)
Contributors: @robamu
Release 0.2.16 (2023-07-20)
- Upgrade to 2018 edition, MSRV 1.31
 - The new 
ToBytesandFromBytestraits convert to and from byte representations of a value, with little, big, and native-endian options. - The new 
Float::is_subnormalmethod checks for subnormal values, with a non-zero magnitude that is less than the normal minimum positive value. - Several other improvements to documentation and testing.
 
Contributors: @ctrlcctrlv, @cuviper, @flier, @GuillaumeGomez, @kaidokert, @rs017991, @vicsn
Release 0.2.15 (2022-05-02)
- The new 
Euclidtrait calculates Euclidean division, where the remainder is always positive or zero. - The new 
LowerBoundedandUpperBoundedtraits separately describe types with lower and upper bounds. These traits are automatically implemented for all fully-Boundedtypes. - The new 
Float::copysignmethod copies the sign of the argument to to the magnitude ofself. - The new 
PrimInt::leading_onesandtrailing_onesmethods are the complement of the existing methods that count zero bits. - The new 
PrimInt::reverse_bitsmethod reverses the order of all bits of a primitive integer. - Improved 
Num::from_str_radixfor floats, also ignoring case. FloatandFloatCoreuse more fromlibmwhen that is enabled.
Contributors: @alion02, @clarfonthey, @cuviper, @ElectronicRU, @ibraheemdev, @SparrowLii, @sshilovsky, @tspiteri, @XAMPPRocky, @Xiretza
Release 0.2.14 (2020-10-29)
- Clarify the license specification as "MIT OR Apache-2.0".
 
Contributors: @cuviper
Release 0.2.13 (2020-10-29)
- The new 
OverflowingAdd,OverflowingSub, andOverflowingMultraits return a tuple with the operation result and aboolindicating overflow. - The "i128" feature now overrides compiler probes for that support.
This may fix scenarios where 
autocfgprobing doesn't work properly. - Casts from large 
f64values tof32now saturate to infinity. They previously returnedNonebecause that was once thought to be undefined behavior, but rust#15536 resolved that such casts are fine. Num::from_str_radixdocuments requirements for radix support, which are now more relaxed than previously implied. It is suggested to accept at least2..=36without panicking, butErrmay be returned otherwise.
Contributors: @cuviper, @Enet4, @KaczuH, @martin-t, @newpavlov
Release 0.2.12 (2020-06-11)
- The new 
WrappingNegtrait will wrap the result if it exceeds the boundary of the type, e.g.i32::MIN.wrapping_neg() == i32::MIN. - The new 
SaturatingAdd,SaturatingSub, andSaturatingMultraits will saturate at the numeric bounds if the operation would overflow. These soft-deprecate the existingSaturatingtrait that only has addition and subtraction methods. - Added new constants for logarithms, 
FloatConst::{LOG10_2, LOG2_10}. 
Contributors: @cuviper, @ocstl, @trepetti, @vallentin
Release 0.2.11 (2020-01-09)
Contributors: @cuviper, @m-ou-se
Release 0.2.10 (2019-11-22)
Contributors: @CryZe
Release 0.2.9 (2019-11-12)
- A new optional 
libmdependency enables theFloatandRealtraits inno_stdbuilds. - The new 
clamp_minandclamp_maxlimit minimum and maximum values while preserving inputNANs. - Fixed a panic in floating point 
from_str_radixon invalid signs. - Miscellaneous documentation updates.
 
Contributors: @cuviper, @dingelish, @HeroicKatora, @jturner314, @ocstl, @Shnatsel, @termoshtt, @waywardmonkeys, @yoanlcq
Release 0.2.8 (2019-05-21)
Contributors: @cuviper
Release 0.2.7 (2019-05-20)
- Documented when 
CheckedShlandCheckedShrreturnNone. - The new 
Zero::set_zeroandOne::set_onewill set values to their identities in place, possibly optimized better than direct assignment. - Documented general features and intentions of 
PrimInt. 
Contributors: @cuviper, @dvdhrm, @ignatenkobrain, @lcnr, @samueltardieu
Release 0.2.6 (2018-09-13)
- Documented that 
pow(0, 0)returns1. Mathematically, this is not strictly defined, but the current behavior is a pragmatic choice that has precedent in Rustcorefor the primitives and in many other languages. - The new 
WrappingShlandWrappingShrtraits will wrap the shift count if it exceeds the bit size of the type. 
Contributors: @cuviper, @edmccard, @meltinglava
Release 0.2.5 (2018-06-20)
- Documentation for 
mul_addnow clarifies that it's not always faster. - The default methods in 
FromPrimitiveandToPrimitiveare more robust. 
Contributors: @cuviper, @frewsxcv
Release 0.2.4 (2018-05-11)
- Support for 128-bit integers is now automatically detected and enabled.
Setting the 
i128crate feature now causes the build script to panic if such support is not detected. 
Contributors: @cuviper
Release 0.2.3 (2018-05-10)
- The new 
CheckedNegandCheckedRemtraits perform checkedNegandRem, returningSome(output)orNoneon overflow. - The 
no_stdimplementation ofFloatCore::to_degreesforf32now uses a constant for greater accuracy, mirroring rust#47919. (Withstdit just calls the inherentf32::to_degreesin the standard library.) - The new 
MulAddandMulAddAssigntraits perform a fused multiply- add. For integer types this is just a convenience, but for floating point types this produces a more accurate result than the separate operations. - All applicable traits are now implemented for 128-bit integers starting
with Rust 1.26, enabled by the new 
i128crate feature. TheFromPrimitiveandToPrimitivetraits now also have corresponding 128-bit methods, which default to converting via 64-bit integers for compatibility. 
Contributors: @cuviper, @LEXUGE, @regexident, @vks
Release 0.2.2 (2018-03-18)
- Casting from floating point to integers now returns 
Noneon overflow, avoiding rustc's undefined behavior. This applies to thecastfunction and the traitsNumCast,FromPrimitive, andToPrimitive. 
Contributors: @apopiak, @cuviper, @dbarella
Release 0.2.1 (2018-03-01)
- The new 
FloatCoretrait offers a subset ofFloatfor#![no_std]use. This includes everything except the transcendental functions and FMA. - The new 
Invtrait returns the multiplicative inverse, or reciprocal. - The new 
Powtrait performs exponentiation, much like the existingpowfunction, but with generic exponent types. - The new 
One::is_onemethod tests if a value equals 1. Implementers should override this method if there's a more efficient way to check for 1, rather than comparing with a temporaryone(). 
Contributors: @clarcharr, @cuviper, @vks
Release 0.2.0 (2018-02-06)
- breaking change: There is now a 
stdfeature, enabled by default, along with the implication that building without this feature makes this a#![no_std]crate.- The 
FloatandRealtraits are only available whenstdis enabled. - Otherwise, the API is unchanged, and num-traits 0.1.43 now re-exports its items from num-traits 0.2 for compatibility (the semver-trick).
 
 - The 
 
Contributors: @cuviper, @termoshtt, @vks
Release 0.1.43 (2018-02-06)
- All items are now re-exported from num-traits 0.2 for compatibility.
 
Release 0.1.42 (2018-01-22)
- num-traits now has its own source repository at rust-num/num-traits.
 ParseFloatErrornow implementsDisplay.- The new 
AsPrimitivetrait implements generic casting with theasoperator. - The new 
CheckedShlandCheckedShrtraits implement generic support for thechecked_shlandchecked_shrmethods on primitive integers. - The new 
Realtrait offers a subset ofFloatfunctionality that may be applicable to more types, with a blanket implementation for all existingT: Floattypes. 
Thanks to @cuviper, @Enet4, @fabianschuiki, @svartalf, and @yoanlcq for their contributions!
Prior releases
No prior release notes were kept. Thanks all the same to the many contributors that have made this crate what it is!