DK3889768T3 - Systemer og fremgangsmåder til udførelse af instruktioner til konvertering til 16-bit-format med flydende komma - Google Patents

Systemer og fremgangsmåder til udførelse af instruktioner til konvertering til 16-bit-format med flydende komma Download PDF

Info

Publication number
DK3889768T3
DK3889768T3 DK21169540.8T DK21169540T DK3889768T3 DK 3889768 T3 DK3889768 T3 DK 3889768T3 DK 21169540 T DK21169540 T DK 21169540T DK 3889768 T3 DK3889768 T3 DK 3889768T3
Authority
DK
Denmark
Prior art keywords
converting
systems
methods
floating point
executing instructions
Prior art date
Application number
DK21169540.8T
Other languages
English (en)
Inventor
Alexander F Heinecke
Robert Valentine
Mark J Charney
Raanan Sade
Menachem Adelman
Zeev Sperber
Amit Gradstein
Simon Rubanovich
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Application granted granted Critical
Publication of DK3889768T3 publication Critical patent/DK3889768T3/da

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3885Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
    • G06F9/3887Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units controlled by a single instruction for multiple data lanes [SIMD]
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/3001Arithmetic instructions
    • G06F9/30014Arithmetic instructions with variable precision
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/30018Bit or string instructions
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/30025Format conversion instructions, e.g. Floating-Point to Integer, decimal conversion
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/30036Instructions to perform operations on packed data, e.g. vector, tile or matrix operations
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/30036Instructions to perform operations on packed data, e.g. vector, tile or matrix operations
    • G06F9/30038Instructions to perform operations on packed data, e.g. vector, tile or matrix operations using a mask
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30098Register arrangements
    • G06F9/30105Register structure
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3802Instruction prefetching
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3818Decoding for concurrent execution
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3836Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
    • G06F9/3838Dependency mechanisms, e.g. register scoreboarding
    • G06F9/384Register renaming
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3885Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
    • G06F9/3888Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units controlled by a single instruction for multiple threads [SIMT] in parallel

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Computational Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Complex Calculations (AREA)
  • Executing Machine-Instructions (AREA)
  • Advance Control (AREA)
DK21169540.8T 2018-11-09 2019-10-08 Systemer og fremgangsmåder til udførelse af instruktioner til konvertering til 16-bit-format med flydende komma DK3889768T3 (da)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US16/186,384 US11372643B2 (en) 2018-11-09 2018-11-09 Systems and methods for performing instructions to convert to 16-bit floating-point format
EP19201879.4A EP3651019B1 (en) 2018-11-09 2019-10-08 Systems and methods for performing instructions to convert to 16-bit floating-point format

Publications (1)

Publication Number Publication Date
DK3889768T3 true DK3889768T3 (da) 2024-04-02

Family

ID=65631109

Family Applications (2)

Application Number Title Priority Date Filing Date
DK20216494.3T DK3822774T3 (da) 2018-11-09 2019-10-08 Systemer og fremgangsmåder til at udføre instruktioner og konvertere til 16 bit-format med flydende komma
DK21169540.8T DK3889768T3 (da) 2018-11-09 2019-10-08 Systemer og fremgangsmåder til udførelse af instruktioner til konvertering til 16-bit-format med flydende komma

Family Applications Before (1)

Application Number Title Priority Date Filing Date
DK20216494.3T DK3822774T3 (da) 2018-11-09 2019-10-08 Systemer og fremgangsmåder til at udføre instruktioner og konvertere til 16 bit-format med flydende komma

Country Status (7)

Country Link
US (6) US11372643B2 (da)
EP (6) EP3889768B1 (da)
CN (5) CN112527396B (da)
DK (2) DK3822774T3 (da)
ES (3) ES2976107T3 (da)
FI (2) FI3822774T3 (da)
PL (2) PL3822774T3 (da)

Families Citing this family (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20190220278A1 (en) * 2019-03-27 2019-07-18 Menachem Adelman Apparatus and method for down-converting and interleaving multiple floating point values
US10824428B2 (en) * 2019-03-29 2020-11-03 Intel Corporation Apparatuses, methods, and systems for hashing instructions
CN112394903A (zh) * 2019-08-13 2021-02-23 上海寒武纪信息科技有限公司 短整形转半精度浮点指令处理装置、方法及相关产品
US11216275B1 (en) 2019-08-05 2022-01-04 Xilinx, Inc. Converting floating point data into integer data using a dynamically adjusted scale factor
CN112394991A (zh) * 2019-08-13 2021-02-23 上海寒武纪信息科技有限公司 浮点转半精度浮点指令处理装置、方法及相关产品
US10970914B1 (en) * 2019-11-15 2021-04-06 Imagination Technologies Limited Multiple precision level intersection testing in a ray tracing system
KR102868993B1 (ko) * 2020-09-02 2025-10-10 삼성전자주식회사 저장 장치, 저장 장치의 동작 방법 및 이를 포함한 전자 장치
US12277419B2 (en) * 2020-09-26 2025-04-15 Intel Corporation Apparatuses, methods, and systems for instructions to convert 16-bit floating-point formats
US12423102B2 (en) * 2020-12-26 2025-09-23 Intel Corporation Instructions to convert from FP16 to BF8
US12135968B2 (en) * 2020-12-26 2024-11-05 Intel Corporation Instructions to convert from FP16 to BF8
US11663004B2 (en) * 2021-02-26 2023-05-30 International Business Machines Corporation Vector convert hexadecimal floating point to scaled decimal instruction
US11531546B2 (en) 2021-03-08 2022-12-20 International Business Machines Corporation Hexadecimal floating point multiply and add instruction
US12086595B2 (en) * 2021-03-27 2024-09-10 Intel Corporation Apparatuses, methods, and systems for instructions for downconverting a tile row and interleaving with a register
US12079658B2 (en) * 2021-06-17 2024-09-03 International Business Machines Corporation Detection of invalid machine-specific data types during data conversion
US11269632B1 (en) * 2021-06-17 2022-03-08 International Business Machines Corporation Data conversion to/from selected data type with implied rounding mode
US12608175B2 (en) 2021-08-31 2026-04-21 Intel Corporation BFLOAT16 square root and/or reciprocal square root instructions
US12379927B2 (en) * 2021-08-31 2025-08-05 Intel Corporation BFLOAT16 scale and/or reduce instructions
US12443409B2 (en) * 2021-09-16 2025-10-14 Intel Corporation Conditional modular subtraction instruction
US12572355B2 (en) 2021-10-29 2026-03-10 Intel Corporation Modular addition instruction
CN116301720A (zh) * 2021-12-08 2023-06-23 达发科技(苏州)有限公司 在Linux系统上实现ARM64位浮点模拟器的方法
US20230205527A1 (en) * 2021-12-23 2023-06-29 Intel Corporation Conversion instructions
US12585430B2 (en) 2022-03-16 2026-03-24 International Business Machines Corporation Floating-point conversion with denormalization
CN115237992B (zh) * 2022-08-08 2025-10-31 昆仑芯(北京)科技有限公司 数据格式转换的方法、装置及矩阵处理的方法、装置
US20250110733A1 (en) * 2023-09-29 2025-04-03 Intel Corporation Conversion operations and special value use cases supporting 8-bit floating point format in a graphics architecture
TWI847921B (zh) * 2023-11-22 2024-07-01 立鴻半導體股份有限公司 記憶體內二進位浮點乘法裝置及其操作方法
CN120950126B (zh) * 2025-10-15 2025-12-09 上海兆芯集成电路股份有限公司 指令执行方法及装置和处理器

Family Cites Families (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6282554B1 (en) 1998-04-30 2001-08-28 Intel Corporation Method and apparatus for floating point operations and format conversion operations
US5995122A (en) 1998-04-30 1999-11-30 Intel Corporation Method and apparatus for parallel conversion of color values from a single precision floating point format to an integer format
US7330864B2 (en) * 2001-03-01 2008-02-12 Microsoft Corporation System and method for using native floating point microprocessor instructions to manipulate 16-bit floating point data representations
US9223751B2 (en) 2006-09-22 2015-12-29 Intel Corporation Performing rounding operations responsive to an instruction
US8667250B2 (en) * 2007-12-26 2014-03-04 Intel Corporation Methods, apparatus, and instructions for converting vector data
JP5309636B2 (ja) * 2008-03-21 2013-10-09 富士通株式会社 演算処理装置及び演算処理装置の制御方法
US9600281B2 (en) * 2010-07-12 2017-03-21 International Business Machines Corporation Matrix multiplication operations using pair-wise load and splat operations
EP2695054B1 (en) * 2011-04-01 2018-08-15 Intel Corporation Vector friendly instruction format and execution thereof
US9411585B2 (en) * 2011-09-16 2016-08-09 International Business Machines Corporation Multi-addressable register files and format conversions associated therewith
CN104011647B (zh) * 2011-12-22 2018-06-15 英特尔公司 浮点舍入处理器、方法、系统和指令
US10474463B2 (en) * 2011-12-23 2019-11-12 Intel Corporation Apparatus and method for down conversion of data types
US9448765B2 (en) * 2011-12-28 2016-09-20 Intel Corporation Floating point scaling processors, methods, systems, and instructions
US9513871B2 (en) * 2011-12-30 2016-12-06 Intel Corporation Floating point round-off amount determination processors, methods, systems, and instructions
US9483265B2 (en) * 2013-08-01 2016-11-01 Nuance Communications, Inc. Vectorized lookup of floating point values
KR101893814B1 (ko) 2014-03-26 2018-10-04 인텔 코포레이션 3 소스 피연산자 부동 소수점 가산 프로세서, 방법, 시스템, 및 명령어
US20170061279A1 (en) 2015-01-14 2017-03-02 Intel Corporation Updating an artificial neural network using flexible fixed point representation
GB2543554B (en) 2015-10-22 2019-01-23 Advanced Risc Mach Ltd Handling exceptional conditions for vector arithmetic instruction
US20170177350A1 (en) 2015-12-18 2017-06-22 Intel Corporation Instructions and Logic for Set-Multiple-Vector-Elements Operations
US11204764B2 (en) * 2016-03-31 2021-12-21 Intel Corporation Processors, methods, systems, and instructions to Partition a source packed data into lanes
US10891131B2 (en) 2016-09-22 2021-01-12 Intel Corporation Processors, methods, systems, and instructions to consolidate data elements and generate index updates
US20180121199A1 (en) * 2016-10-27 2018-05-03 Apple Inc. Fused Multiply-Add that Accepts Sources at a First Precision and Generates Results at a Second Precision
US10216479B2 (en) * 2016-12-06 2019-02-26 Arm Limited Apparatus and method for performing arithmetic operations to accumulate floating-point numbers
US10228938B2 (en) * 2016-12-30 2019-03-12 Intel Corporation Apparatus and method for instruction-based flop accounting
US10698685B2 (en) * 2017-05-03 2020-06-30 Intel Corporation Instructions for dual destination type conversion, mixed precision accumulation, and mixed precision atomic memory operations
US10705839B2 (en) 2017-12-21 2020-07-07 Intel Corporation Apparatus and method for multiplying, summing, and accumulating sets of packed bytes
US10546044B2 (en) * 2018-05-15 2020-01-28 Apple Inc. Low precision convolution operations
US11093579B2 (en) * 2018-09-05 2021-08-17 Intel Corporation FP16-S7E8 mixed precision for deep learning and other algorithms

Also Published As

Publication number Publication date
CN120540718A (zh) 2025-08-26
US11068263B2 (en) 2021-07-20
EP3651019A3 (en) 2020-07-22
PL3822774T3 (pl) 2025-04-07
CN112527396A (zh) 2021-03-19
US20210124581A1 (en) 2021-04-29
EP3889768B1 (en) 2024-01-10
ES3013609T3 (en) 2025-04-14
EP3822774A1 (en) 2021-05-19
EP4560463A2 (en) 2025-05-28
US20250117217A1 (en) 2025-04-10
PL3889768T3 (pl) 2024-05-13
CN111176730A (zh) 2020-05-19
US12131154B2 (en) 2024-10-29
US12541365B2 (en) 2026-02-03
US20260072683A1 (en) 2026-03-12
US20220326948A1 (en) 2022-10-13
EP3889768A1 (en) 2021-10-06
EP3651019A2 (en) 2020-05-13
EP4560463A3 (en) 2025-08-20
US11372643B2 (en) 2022-06-28
ES3064521T3 (en) 2026-04-27
US20210124580A1 (en) 2021-04-29
CN113076139A (zh) 2021-07-06
EP4700570A2 (en) 2026-02-25
US20190079762A1 (en) 2019-03-14
CN121879849A (zh) 2026-04-17
FI3889768T3 (fi) 2024-03-26
ES2976107T3 (es) 2024-07-23
DK3822774T3 (da) 2025-02-24
EP3798827A1 (en) 2021-03-31
EP3798827B1 (en) 2026-03-04
EP3822774B1 (en) 2024-12-04
EP3651019B1 (en) 2026-01-21
CN113076139B (zh) 2024-09-06
CN112527396B (zh) 2024-05-10
FI3822774T3 (fi) 2025-02-27
US11068262B2 (en) 2021-07-20

Similar Documents

Publication Publication Date Title
DK3889768T3 (da) Systemer og fremgangsmåder til udførelse af instruktioner til konvertering til 16-bit-format med flydende komma
DK3855308T3 (da) Systemer og fremgangsmåder til udførelse af 16-bit-vektorprikproduktinstruktioner med flydende komma
DK4002105T3 (da) Systemer og fremgangsmåder til udførelse af instruktioner for et prikprodukt med 16-bit-matrix med flydende komma
DK3276164T3 (da) System og fremgangsmåde til styring af en vindmølle
DK3353779T3 (da) Fremgangsmåde og system til kodning af et stereolydssignal ved at anvende kodningsparametre for en primær kanal til at kode en sekundær kanal
DK3279757T3 (da) System og fremgangsmåde til detektering af fejl og/eller til tilvejebringelse af optimeringsmål til forbedring af performance af en eller flere bygninger
DK3672919T3 (da) Anlæg og fremgangsmåde til fremstilling af cementklinker
DK3406896T3 (da) System til montering og demontering af vindmøller
DK3065251T3 (da) System og fremgangsmåde til stabilisering af en subsynkron interaktion af en vindmølle
DK3743624T3 (da) System og fremgangsmåde til stabilisering af en vindmølle
DK3777181T3 (da) Fremgangsmåde og indretning til kodning af geometrien af en punktysky
DK3048295T4 (da) Fremgangsmåde til opførelse af en vindmølle og vindmølle
DK3591222T3 (da) Vindmølle og fremgangsmåde til drift af en vindmølle
DK3067556T3 (da) System og fremgangsmåde til variabel styring af en vindmølles spidshastighedforhold
DK3303890T3 (da) Fremgangsmåde til drift af en membranventil og system og udlæsningsindretning
DK3212927T3 (da) System og fremgangsmåde til styring af driften af en vindmølle
DK4049290T3 (da) Systemer og fremgangsmåder til design af vacciner
DK2918825T3 (da) System og fremgangsmåde til initialisering af en opstartsekvens af en vindmølle
DK3394778T3 (da) Fremgangsmåde og system til at forbedre sikkerheden af en transaktion
DK3643915T3 (da) System og fremgangsmåde til anvendelse af en bremse til en vindmølle
DK3513061T3 (da) Fremgangsmåde og system til fastgørelse af en spidsforlængelse til en vindmøllevinge
DK3631200T3 (da) System og fremgangsmåde til optimering af en vindmølles udgangseffekt under en driftsbegrænsning
DK3665133T3 (da) Fremgangsmåde og anlæg til fremstilling af cement
DK3499021T3 (da) Kitesystem og fremgangsmåde til drift af et kitesystem
DK3249218T3 (da) System og metode til micrositing af en vindmøllepark for belastningsoptimering