From 2ba23f89e40d36400503fc6024b374ce85a82d29 Mon Sep 17 00:00:00 2001 From: Chris Bieneman Date: Fri, 19 Apr 2024 11:03:45 -0500 Subject: [PATCH 1/3] Update conversion ranks for minimum precision types This just updates the conversion rank for minimum precision types which are now represented in the Basic.types section. TL;DR: min10int < min12int < min16int < int16_t < int32_t < int64_t min10uint < min12uint < min16uint < uint16_t < uint32_t < uint64_t min10float < min12float < min16float < half < float < double --- specs/language/basic.tex | 14 +++++++++----- specs/language/conversions.tex | 10 ++++++++++ 2 files changed, 19 insertions(+), 5 deletions(-) diff --git a/specs/language/basic.tex b/specs/language/basic.tex index 565243c0..f898f0f5 100644 --- a/specs/language/basic.tex +++ b/specs/language/basic.tex @@ -75,11 +75,15 @@ minimum precision unsigned integer types are collectively called \textit{unsigned integer types}. -\p The signed integer types and unsigned integer types are collectively called -\textit{integer types}. Integer types inherit the object representation of -integers defined in \glsdesc{isoC23}\footnote{C23 adopts two's compliment as the -object representation for integer types.}. Integer types shall satisfy the -constraints defined in \glsdesc{isoCPP}, section \textbf{basic.fundamental}. +\p The minimum precision signed integer types and minimum precision unsigned +integer types are collectively called \textit{minimum precision integer types}. +The standard signed integer types and standard unsigned integer types are +collectively called \textit{standard integer types}. The signed integer types +and unsigned integer types are collectively called \textit{integer types}. +Integer types inherit the object representation of integers defined in +\glsdesc{isoC23}\footnote{C23 adopts two's compliment as the object +representation for integer types.}. Integer types shall satisfy the constraints +defined in \glsdesc{isoCPP}, section \textbf{basic.fundamental}. \p There are three \textit{standard floating point types}: \texttt{half}, \texttt{float}, and \texttt{double}. The \texttt{float} type is a 32-bit diff --git a/specs/language/conversions.tex b/specs/language/conversions.tex index 0ab1d895..85468479 100644 --- a/specs/language/conversions.tex +++ b/specs/language/conversions.tex @@ -159,6 +159,11 @@ corresponding signed integer type. \item The rank of \texttt{bool} shall be less than the rank of all other standard integer types. + \item The rank of a minimum precision integer type shall be less than the rank + of any other minimum precision integer type with a larger minimum value + representation size. + \item The rank of a minimum precision integer type shall be less than the rank + of all standard integer types. \item For all integer types \texttt{T1}, \texttt{T2}, and \texttt{T3}: if \texttt{T1} has greater rank than \texttt{T2} and \texttt{T2} has greater rank than \texttt{T3}, then \texttt{T1} shall have greater rank than \texttt{T3}. @@ -172,6 +177,11 @@ \item The rank of a floating point type shall be greater than the rank of any floating point type with a smaller size. \item The rank \texttt{float} shall be greater than the rank of \texttt{half}. + \item The rank of a minimum precision floating point type shall be less than + the rank of any other minimum precision floating point type with a larger + minimum value representation size. + \item The rank of a minimum precision floating point type shall be less than + the rank of all standard floating point types. \item For all floating point types \texttt{T1}, \texttt{T2}, and \texttt{T3}: if \texttt{T1} has greater rank than \texttt{T2} and \texttt{T2} has greater rank than \texttt{T3}, then \texttt{T1} shall have greater rank than From d93bab700965f742549e26fa89739ebf78798677 Mon Sep 17 00:00:00 2001 From: Chris Bieneman Date: Tue, 23 Apr 2024 18:57:51 -0500 Subject: [PATCH 2/3] Fix the minimum precision type list There is not a 10, 12, and 16 for each type. Float has 10 and 16, int has 12 and 16, and uint has only 16. --- specs/language/basic.tex | 41 ++++++++++++++++++++-------------------- 1 file changed, 20 insertions(+), 21 deletions(-) diff --git a/specs/language/basic.tex b/specs/language/basic.tex index f898f0f5..8739ea53 100644 --- a/specs/language/basic.tex +++ b/specs/language/basic.tex @@ -56,24 +56,23 @@ \texttt{int32\_t}, and \texttt{int64\_t}. Each of the signed integer types is explicitly named for the size in bits of the type's object representation. There is also the type alias \texttt{int} which is an alias of \texttt{int32\_t}. -There are three \textit{minimum precision signed integer types}: -\texttt{min10int}, \texttt{min12int}, and \texttt{min16int}. Each of the minimum -precision signed integer types are named for the required minimum value -representation size in bits. The object representation of all minimum precision -types is \texttt{int}. The standard signed integer types and minimum precision -signed integer types are collectively called \textit{signed integer types}. +There are two \textit{minimum precision signed integer types}: +\texttt{min12int}, and \texttt{min16int}. Each of the minimum precision signed +integer types are named for the required minimum value representation size in +bits. The object representation of all minimum precision types is \texttt{int}. +The standard signed integer types and minimum precision signed integer types are +collectively called \textit{signed integer types}. \p There are three \textit{standard unsigned integer types}: \texttt{uint16\_t}, \texttt{uint32\_t}, and \texttt{uint64\_t}. Each of the unsigned integer types is explicitly named for the size in bits of the type's object representation. There is also the type alias \texttt{uint} which is an alias of -\texttt{uint32\_t}. There are three \textit{minimum precision unsigned integer -types}: \texttt{min10uint}, \texttt{min12uint}, and \texttt{min16uint}. Each of -the minimum precision unsigned integer types are named for the required minimum -value representation size in bits. The object representation of all minimum -precision types is \texttt{uint}. The standard unsigned integer types and -minimum precision unsigned integer types are collectively called -\textit{unsigned integer types}. +\texttt{uint32\_t}. There is one \textit{minimum precision unsigned integer +type}: \texttt{min16uint}. The minimum precision unsigned integer type is named +for the required minimum value representation size in bits. The object +representation of \texttt{min16uint} is \texttt{uint}. The standard unsigned +integer types and minimum precision unsigned integer type are collectively +called \textit{unsigned integer types}. \p The minimum precision signed integer types and minimum precision unsigned integer types are collectively called \textit{minimum precision integer types}. @@ -95,14 +94,14 @@ otherwise it will have an object representation matching the \textbf{binary16} format defined in \gls{IEEE754}\footnote{IEEE-754 only defines a binary encoding for 16-bit floating point values, it does not fully specify the behavior of such -types.}. There are three \textit{minimum precision floating point types}: -\texttt{min10float}, \texttt{min12float}, and \texttt{min16float}. Each of the -minimum precision floating point types are named for the required minimum value -representation size in bits. The object representation of all minimum precision -types is \texttt{float}\footnote{This means when stored to memory minimum -precision types are stored as \textbf{binary32} as defined in \gls{IEEE754}.}. -The standard floating point types and minimum precision floating point types are -collectively called \textit{floating point types}. +types.}. There are two \textit{minimum precision floating point types}: +\texttt{min10float}, and \texttt{min16float}. Each of the minimum precision +floating point types are named for the required minimum value representation +size in bits. The object representation of all minimum precision types is +\texttt{float}\footnote{This means when stored to memory minimum precision types +are stored as \textbf{binary32} as defined in \gls{IEEE754}.}. The standard +floating point types and minimum precision floating point types are collectively +called \textit{floating point types}. \p Integer and floating point types are collectively called \textit{arithmetic types}. From c079e5b46fc9c9b14e3d6aeee4b08b82169ee9ff Mon Sep 17 00:00:00 2001 From: Chris Bieneman Date: Thu, 25 Apr 2024 18:17:22 -0500 Subject: [PATCH 3/3] Restricting to just min16{int|uint|float} --- specs/language/basic.tex | 27 +++++++++++++-------------- specs/language/conversions.tex | 11 ++--------- 2 files changed, 15 insertions(+), 23 deletions(-) diff --git a/specs/language/basic.tex b/specs/language/basic.tex index 8739ea53..bccef946 100644 --- a/specs/language/basic.tex +++ b/specs/language/basic.tex @@ -56,12 +56,12 @@ \texttt{int32\_t}, and \texttt{int64\_t}. Each of the signed integer types is explicitly named for the size in bits of the type's object representation. There is also the type alias \texttt{int} which is an alias of \texttt{int32\_t}. -There are two \textit{minimum precision signed integer types}: -\texttt{min12int}, and \texttt{min16int}. Each of the minimum precision signed -integer types are named for the required minimum value representation size in -bits. The object representation of all minimum precision types is \texttt{int}. -The standard signed integer types and minimum precision signed integer types are -collectively called \textit{signed integer types}. +There is one \textit{minimum precision signed integer type}: \texttt{min16int}. +The minimum precision signed integer type is named for the required minimum +value representation size in bits. The object representation of +\texttt{min16int} is \texttt{int}. The standard signed integer types and minimum +precision signed integer type are collectively called \textit{signed integer +types}. \p There are three \textit{standard unsigned integer types}: \texttt{uint16\_t}, \texttt{uint32\_t}, and \texttt{uint64\_t}. Each of the unsigned integer types @@ -94,14 +94,13 @@ otherwise it will have an object representation matching the \textbf{binary16} format defined in \gls{IEEE754}\footnote{IEEE-754 only defines a binary encoding for 16-bit floating point values, it does not fully specify the behavior of such -types.}. There are two \textit{minimum precision floating point types}: -\texttt{min10float}, and \texttt{min16float}. Each of the minimum precision -floating point types are named for the required minimum value representation -size in bits. The object representation of all minimum precision types is -\texttt{float}\footnote{This means when stored to memory minimum precision types -are stored as \textbf{binary32} as defined in \gls{IEEE754}.}. The standard -floating point types and minimum precision floating point types are collectively -called \textit{floating point types}. +types.}. There is one \textit{minimum precision floating point type}: +\texttt{min16float}. The minimum precision floating point type is named for the +required minimum value representation size in bits. The object representation of +\texttt{min16float} is \texttt{float}\footnote{This means when stored to memory +objects of type \texttt{min16float} are stored as \textbf{binary32} as defined +in \gls{IEEE754}.}. The standard floating point types and minimum precision +floating point type are collectively called \textit{floating point types}. \p Integer and floating point types are collectively called \textit{arithmetic types}. diff --git a/specs/language/conversions.tex b/specs/language/conversions.tex index 85468479..04b136a8 100644 --- a/specs/language/conversions.tex +++ b/specs/language/conversions.tex @@ -172,16 +172,9 @@ \Sub{Floating Point Conversion Rank}{Conv.rank.float} \begin{itemize} - \item No two floating point types shall have the same conversion rank even if - they have the same representation. - \item The rank of a floating point type shall be greater than the rank of any - floating point type with a smaller size. + \item The rank \texttt{half} shall be greater than the rank of \texttt{min16float}. \item The rank \texttt{float} shall be greater than the rank of \texttt{half}. - \item The rank of a minimum precision floating point type shall be less than - the rank of any other minimum precision floating point type with a larger - minimum value representation size. - \item The rank of a minimum precision floating point type shall be less than - the rank of all standard floating point types. + \item The rank \texttt{double} shall be greater than the rank of \texttt{float}. \item For all floating point types \texttt{T1}, \texttt{T2}, and \texttt{T3}: if \texttt{T1} has greater rank than \texttt{T2} and \texttt{T2} has greater rank than \texttt{T3}, then \texttt{T1} shall have greater rank than