fbpx
Wikipedia

Floating-point unit

A floating-point unit (FPU, colloquially a math coprocessor) is a part of a computer system specially designed to carry out operations on floating-point numbers.[1] Typical operations are addition, subtraction, multiplication, division, and square root. Some FPUs can also perform various transcendental functions such as exponential or trigonometric calculations, but the accuracy can be low,[2][3] so some systems prefer to compute these functions in software.

Collection of the x87 family of math coprocessors by Intel

In general-purpose computer architectures, one or more FPUs may be integrated as execution units within the central processing unit; however, many embedded processors do not have hardware support for floating-point operations (while they increasingly have them as standard).

When a CPU is executing a program that calls for a floating-point operation, there are three ways to carry it out:

  • A floating-point unit emulator (a floating-point library in software)
  • Add-on FPU hardware
  • Integrated FPU (in hardware)

History Edit

In 1954, the IBM 704 had floating-point arithmetic as a standard feature, one of its major improvements over its predecessor the IBM 701. This was carried forward to its successors the 709, 7090, and 7094.

In 1963, Digital announced the PDP-6, which had floating point as a standard feature.[4]

In 1963, the GE-235 featured an "Auxiliary Arithmetic Unit" for floating point and double-precision calculations.[5]

Historically, some systems implemented floating point with a coprocessor rather than as an integrated unit (but now in addition to the CPU, e.g. GPUs – that are coprocessors not always built into the CPU – have FPUs as a rule, while first generations of GPUs did not). This could be a single integrated circuit, an entire circuit board or a cabinet. Where floating-point calculation hardware has not been provided, floating-point calculations are done in software, which takes more processor time, but avoids the cost of the extra hardware. For a particular computer architecture, the floating-point unit instructions may be emulated by a library of software functions; this may permit the same object code to run on systems with or without floating-point hardware. Emulation can be implemented on any of several levels: in the CPU as microcode (not a common practice), as an operating system function, or in user-space code. When only integer functionality is available, the CORDIC floating-point emulation methods are most commonly used.

In most modern computer architectures, there is some division of floating-point operations from integer operations. This division varies significantly by architecture; some have dedicated floating-point registers, while some, like Intel x86, go as far as independent clocking schemes.[6]

CORDIC routines have been implemented in Intel x87 coprocessors (8087,[7][8][9][10][11] 80287,[11][12] 80387[11][12]) up to the 80486[7] microprocessor series, as well as in the Motorola 68881[7][8] and 68882 for some kinds of floating-point instructions, mainly as a way to reduce the gate counts (and complexity) of the FPU subsystem.

Floating-point operations are often pipelined. In earlier superscalar architectures without general out-of-order execution, floating-point operations were sometimes pipelined separately from integer operations.

The modular architecture of Bulldozer microarchitecture uses a special FPU named FlexFPU, which uses simultaneous multithreading. Each physical integer core, two per module, is single-threaded, in contrast with Intel's Hyperthreading, where two virtual simultaneous threads share the resources of a single physical core.[13][14]

Floating-point library Edit

Some floating-point hardware only supports the simplest operations: addition, subtraction, and multiplication. But even the most complex floating-point hardware has a finite number of operations it can support – for example, no FPUs directly support arbitrary-precision arithmetic.

When a CPU is executing a program that calls for a floating-point operation that is not directly supported by the hardware, the CPU uses a series of simpler floating-point operations. In systems without any floating-point hardware, the CPU emulates it using a series of simpler fixed-point arithmetic operations that run on the integer arithmetic logic unit.

The software that lists the necessary series of operations to emulate floating-point operations is often packaged in a floating-point library.

Integrated FPUs Edit

In some cases, FPUs may be specialized, and divided between simpler floating-point operations (mainly addition and multiplication) and more complicated operations, like division. In some cases, only the simple operations may be implemented in hardware or microcode, while the more complex operations are implemented as software.

In some current architectures, the FPU functionality is combined with SIMD units to perform SIMD computation; an example of this is the augmentation of the x87 instructions set with SSE instruction set in the x86-64 architecture used in newer Intel and AMD processors.

Add-on FPUs Edit

Several models of the PDP-11, such as the PDP-11/45,[15] PDP-11/34a,[16]: 184–185  PDP-11/44,[16]: 195, 211  and PDP-11/70,[16]: 277, 286–287  supported an add-on floating-point unit to support floating-point instructions. The PDP-11/60,[16]: 261  MicroPDP-11/23[17] and several VAX models[18][19] could execute floating-point instructions without an add-on FPU (the MicroPDP-11/23 required an add-on microcode option),[17] and offered add-on accelerators to further speed the execution of those instructions.

In the 1980s, it was common in IBM PC/compatible microcomputers for the FPU to be entirely separate from the CPU, and typically sold as an optional add-on. It would only be purchased if needed to speed up or enable math-intensive programs.

The IBM PC, XT, and most compatibles based on the 8088 or 8086 had a socket for the optional 8087 coprocessor. The AT and 80286-based systems were generally socketed for the 80287, and 80386/80386SX-based machines – for the 80387 and 80387SX respectively, although early ones were socketed for the 80287, since the 80387 did not exist yet. Other companies manufactured co-processors for the Intel x86 series. These included Cyrix and Weitek. Acorn Computers opted for the WE32206 to offer single, double and extended precision[20] to its ARM powered Archimedes range.

Coprocessors were available for the Motorola 68000 family, the 68881 and 68882. These were common in Motorola 68020/68030-based workstations, like the Sun-3 series. They were also commonly added to higher-end models of Apple Macintosh and Commodore Amiga series, but unlike IBM PC-compatible systems, sockets for adding the coprocessor were not as common in lower-end systems.

There are also add-on FPU coprocessor units for microcontroller units (MCUs/μCs)/single-board computer (SBCs), which serve to provide floating-point arithmetic capability. These add-on FPUs are host-processor-independent, possess their own programming requirements (operations, instruction sets, etc.) and are often provided with their own integrated development environments (IDEs).

See also Edit

References Edit

  1. ^ Anderson, Stanley F.; Earle, John G.; Goldschmidt, Robert Elliott; Powers, Don M. (January 1967). "The IBM System/360 Model 91: Floating-Point Execution Unit". IBM Journal of Research and Development. 11 (1): 34–53. doi:10.1147/rd.111.0034. ISSN 0018-8646.
  2. ^ Dawson, Bruce (2014-10-09). "Intel Underestimates Error Bounds by 1.3 quintillion". randomascii.wordpress.com. Retrieved 2020-01-16.
  3. ^ . intel.com. 2014-10-09. Archived from the original on 2020-01-16. Retrieved 2020-01-16.
  4. ^ "PDP-6 Handbook" (PDF). www.bitsavers.org. Archived (PDF) from the original on 2022-10-09.
  5. ^ "GE-2xx documents". www.bitsavers.org. CPB-267_GE-235-SystemManual_1963.pdf, p. IV-4.
  6. ^ "Intel 80287 family". www.cpu-world.com. Retrieved 2019-01-15.
  7. ^ a b c Muller, Jean-Michel (2006). Elementary Functions: Algorithms and Implementation (2nd ed.). Boston, Massachusetts: Birkhäuser. p. 134. ISBN 978-0-8176-4372-0. LCCN 2005048094. Retrieved 2015-12-01.
  8. ^ a b Nave, Rafi (March 1983). "Implementation of Transcendental Functions on a Numerics Processor". Microprocessing and Microprogramming. 11 (3–4): 221–225. doi:10.1016/0165-6074(83)90151-5.
  9. ^ Palmer, John F.; Morse, Stephen Paul (1984). The 8087 Primer (1st ed.). John Wiley & Sons Australia, Limited. ISBN 0471875694. 9780471875697. Retrieved 2016-01-02.
  10. ^ Glass, L. Brent (January 1990). "Math Coprocessors: A look at what they do, and how they do it". Byte. 15 (1): 337–348. ISSN 0360-5280.
  11. ^ a b c Jarvis, Pitts (1990-10-01). "Implementing CORDIC algorithms – A single compact routine for computing transcendental functions". Dr. Dobb's Journal: 152–156. Retrieved 2016-01-02.
  12. ^ a b Yuen, A. K. (1988). "Intel's Floating-Point Processors". Electro/88 Conference Record: 48/5/1–7.
  13. ^ . cdn3.wccftech.com. Archived from the original on 9 May 2015. Retrieved 14 March 2022.{{cite web}}: CS1 maint: archived copy as title (link)
  14. ^ "AMD unveils Flex FP". bit-tech.net. Retrieved 29 March 2018.
  15. ^ PDP-11/45 Processor Handbook (PDF). Digital Equipment Corporation. 1973. Chapter 7 "Floating Point Processor".
  16. ^ a b c d PDP-11 Processor Handbook (PDF). Digital Equipment Corporation. 1979.
  17. ^ a b MICRO/PDP-11 Handbook (PDF). Digital Equipment Corporation. 1983. p. 33.
  18. ^ VAX – Hardware Handbook Volume I – 1986 (PDF). Digital Equipment Corporation. 1985.
  19. ^ VAX – Hardware Handbook Volume II – 1986 (PDF). Digital Equipment Corporation. 1986.
  20. ^ "Western Electric 32206 co-processor". www.cpu-world.com. Retrieved 2021-11-06.

Further reading Edit

  • Filiatreault, Raymond (2003). "SIMPLY FPU".

floating, point, unit, floating, point, unit, colloquially, math, coprocessor, part, computer, system, specially, designed, carry, operations, floating, point, numbers, typical, operations, addition, subtraction, multiplication, division, square, root, some, f. A floating point unit FPU colloquially a math coprocessor is a part of a computer system specially designed to carry out operations on floating point numbers 1 Typical operations are addition subtraction multiplication division and square root Some FPUs can also perform various transcendental functions such as exponential or trigonometric calculations but the accuracy can be low 2 3 so some systems prefer to compute these functions in software Collection of the x87 family of math coprocessors by IntelIn general purpose computer architectures one or more FPUs may be integrated as execution units within the central processing unit however many embedded processors do not have hardware support for floating point operations while they increasingly have them as standard When a CPU is executing a program that calls for a floating point operation there are three ways to carry it out A floating point unit emulator a floating point library in software Add on FPU hardware Integrated FPU in hardware Contents 1 History 2 Floating point library 3 Integrated FPUs 4 Add on FPUs 5 See also 6 References 7 Further readingHistory EditIn 1954 the IBM 704 had floating point arithmetic as a standard feature one of its major improvements over its predecessor the IBM 701 This was carried forward to its successors the 709 7090 and 7094 In 1963 Digital announced the PDP 6 which had floating point as a standard feature 4 In 1963 the GE 235 featured an Auxiliary Arithmetic Unit for floating point and double precision calculations 5 Historically some systems implemented floating point with a coprocessor rather than as an integrated unit but now in addition to the CPU e g GPUs that are coprocessors not always built into the CPU have FPUs as a rule while first generations of GPUs did not This could be a single integrated circuit an entire circuit board or a cabinet Where floating point calculation hardware has not been provided floating point calculations are done in software which takes more processor time but avoids the cost of the extra hardware For a particular computer architecture the floating point unit instructions may be emulated by a library of software functions this may permit the same object code to run on systems with or without floating point hardware Emulation can be implemented on any of several levels in the CPU as microcode not a common practice as an operating system function or in user space code When only integer functionality is available the CORDIC floating point emulation methods are most commonly used In most modern computer architectures there is some division of floating point operations from integer operations This division varies significantly by architecture some have dedicated floating point registers while some like Intel x86 go as far as independent clocking schemes 6 CORDIC routines have been implemented in Intel x87 coprocessors 8087 7 8 9 10 11 80287 11 12 80387 11 12 up to the 80486 7 microprocessor series as well as in the Motorola 68881 7 8 and 68882 for some kinds of floating point instructions mainly as a way to reduce the gate counts and complexity of the FPU subsystem Floating point operations are often pipelined In earlier superscalar architectures without general out of order execution floating point operations were sometimes pipelined separately from integer operations The modular architecture of Bulldozer microarchitecture uses a special FPU named FlexFPU which uses simultaneous multithreading Each physical integer core two per module is single threaded in contrast with Intel s Hyperthreading where two virtual simultaneous threads share the resources of a single physical core 13 14 Floating point library Edit nbsp Wikibooks has a book on the topic of Floating Point Soft Implementations nbsp Wikibooks has a book on the topic of Embedded Systems Floating Point Unit Some floating point hardware only supports the simplest operations addition subtraction and multiplication But even the most complex floating point hardware has a finite number of operations it can support for example no FPUs directly support arbitrary precision arithmetic When a CPU is executing a program that calls for a floating point operation that is not directly supported by the hardware the CPU uses a series of simpler floating point operations In systems without any floating point hardware the CPU emulates it using a series of simpler fixed point arithmetic operations that run on the integer arithmetic logic unit The software that lists the necessary series of operations to emulate floating point operations is often packaged in a floating point library Integrated FPUs EditIn some cases FPUs may be specialized and divided between simpler floating point operations mainly addition and multiplication and more complicated operations like division In some cases only the simple operations may be implemented in hardware or microcode while the more complex operations are implemented as software In some current architectures the FPU functionality is combined with SIMD units to perform SIMD computation an example of this is the augmentation of the x87 instructions set with SSE instruction set in the x86 64 architecture used in newer Intel and AMD processors Add on FPUs EditMain article Coprocessor Several models of the PDP 11 such as the PDP 11 45 15 PDP 11 34a 16 184 185 PDP 11 44 16 195 211 and PDP 11 70 16 277 286 287 supported an add on floating point unit to support floating point instructions The PDP 11 60 16 261 MicroPDP 11 23 17 and several VAX models 18 19 could execute floating point instructions without an add on FPU the MicroPDP 11 23 required an add on microcode option 17 and offered add on accelerators to further speed the execution of those instructions In the 1980s it was common in IBM PC compatible microcomputers for the FPU to be entirely separate from the CPU and typically sold as an optional add on It would only be purchased if needed to speed up or enable math intensive programs The IBM PC XT and most compatibles based on the 8088 or 8086 had a socket for the optional 8087 coprocessor The AT and 80286 based systems were generally socketed for the 80287 and 80386 80386SX based machines for the 80387 and 80387SX respectively although early ones were socketed for the 80287 since the 80387 did not exist yet Other companies manufactured co processors for the Intel x86 series These included Cyrix and Weitek Acorn Computers opted for the WE32206 to offer single double and extended precision 20 to its ARM powered Archimedes range Coprocessors were available for the Motorola 68000 family the 68881 and 68882 These were common in Motorola 68020 68030 based workstations like the Sun 3 series They were also commonly added to higher end models of Apple Macintosh and Commodore Amiga series but unlike IBM PC compatible systems sockets for adding the coprocessor were not as common in lower end systems There are also add on FPU coprocessor units for microcontroller units MCUs mCs single board computer SBCs which serve to provide floating point arithmetic capability These add on FPUs are host processor independent possess their own programming requirements operations instruction sets etc and are often provided with their own integrated development environments IDEs See also EditArithmetic logic unit ALU Address generation unit AGU Load store unit CORDIC routines are used in many FPUs to implement functions but not greatly increase gate count Execution unit IEEE 754 floating point standard IBM hexadecimal floating point Graphics processing unit Multiply accumulate operationReferences Edit Anderson Stanley F Earle John G Goldschmidt Robert Elliott Powers Don M January 1967 The IBM System 360 Model 91 Floating Point Execution Unit IBM Journal of Research and Development 11 1 34 53 doi 10 1147 rd 111 0034 ISSN 0018 8646 Dawson Bruce 2014 10 09 Intel Underestimates Error Bounds by 1 3 quintillion randomascii wordpress com Retrieved 2020 01 16 FSIN Documentation Improvements in the Intel 64 and IA 32 Architectures Software Developer s Manual intel com 2014 10 09 Archived from the original on 2020 01 16 Retrieved 2020 01 16 PDP 6 Handbook PDF www bitsavers org Archived PDF from the original on 2022 10 09 GE 2xx documents www bitsavers org CPB 267 GE 235 SystemManual 1963 pdf p IV 4 Intel 80287 family www cpu world com Retrieved 2019 01 15 a b c Muller Jean Michel 2006 Elementary Functions Algorithms and Implementation 2nd ed Boston Massachusetts Birkhauser p 134 ISBN 978 0 8176 4372 0 LCCN 2005048094 Retrieved 2015 12 01 a b Nave Rafi March 1983 Implementation of Transcendental Functions on a Numerics Processor Microprocessing and Microprogramming 11 3 4 221 225 doi 10 1016 0165 6074 83 90151 5 Palmer John F Morse Stephen Paul 1984 The 8087 Primer 1st ed John Wiley amp Sons Australia Limited ISBN 0471875694 9780471875697 Retrieved 2016 01 02 Glass L Brent January 1990 Math Coprocessors A look at what they do and how they do it Byte 15 1 337 348 ISSN 0360 5280 a b c Jarvis Pitts 1990 10 01 Implementing CORDIC algorithms A single compact routine for computing transcendental functions Dr Dobb s Journal 152 156 Retrieved 2016 01 02 a b Yuen A K 1988 Intel s Floating Point Processors Electro 88 Conference Record 48 5 1 7 Archived copy cdn3 wccftech com Archived from the original on 9 May 2015 Retrieved 14 March 2022 a href Template Cite web html title Template Cite web cite web a CS1 maint archived copy as title link AMD unveils Flex FP bit tech net Retrieved 29 March 2018 PDP 11 45 Processor Handbook PDF Digital Equipment Corporation 1973 Chapter 7 Floating Point Processor a b c d PDP 11 Processor Handbook PDF Digital Equipment Corporation 1979 a b MICRO PDP 11 Handbook PDF Digital Equipment Corporation 1983 p 33 VAX Hardware Handbook Volume I 1986 PDF Digital Equipment Corporation 1985 VAX Hardware Handbook Volume II 1986 PDF Digital Equipment Corporation 1986 Western Electric 32206 co processor www cpu world com Retrieved 2021 11 06 Further reading EditFiliatreault Raymond 2003 SIMPLY FPU Retrieved from https en wikipedia org w index php title Floating point unit amp oldid 1180964846 Floating point emulation, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.