Weighted Million Operations Per Second was nominated for deletion. The discussion was closed on 02 March 2012 with a consensus to merge. Its contents were merged into Instructions per second. The original page is now a redirect to this page. For the contribution history and old versions of the redirected article, please see its history; for its talk page, see here. |
This article is rated Start-class on Wikipedia's content assessment scale. It is of interest to the following WikiProjects: | |||||||||||
|
Reference for the Timeline Table
editI found a possible reference for the still unreferenced entries in the timeline table. It is from a book from Kai Qian,David den Haring,Li Cao named Embedded Software Development with C. It can be found under google books: http://books.google.com/books?id=aB1EgF0jB-MC&pg=PA8&lpg=PA8&dq=AMD+Athlon+%223,561+MIPS%22+-wiki&source=bl&ots=pG_B87T73t&sig=P4YYT12GS7tH9quVl9jiGUo5084&hl=de&ei=MQQbTYLmIYvwsgb91OH5DA&sa=X&oi=book_result&ct=result&resnum=1&ved=0CBUQ6AEwAA#v=onepage&q=AMD%20Athlon%20%223%2C561%20MIPS%22%20-wiki&f=false —Preceding unsigned comment added by 80.238.172.215 (talk) 09:58, 29 December 2010 (UTC)
Errata in Timeline
editHello. I'm sorry that I don't know how to edit Wikipaedia correctly, but the most of the M- prefixes for the recent processors are incorrect. They should all be GIPS, not MIPS. This can easily be confirmed by visiting the link cited in this table. I would appreciate it if somebody more savvy than I am could correct this. Thank you. — Preceding unsigned comment added by 96.255.78.233 (talk) 01:47, 25 November 2011 (UTC)
I'm glad you didn't edit it, because as a meaningful apples-to-apples comparison, all figures from the earliest computers to those at present are calculated on this same scale. NEVERTHELESS, it seems a little odd to me that the Intel Celeron and the i3 are both missing from this list. grubbmeister (talk) 21:57, 23 June 2018 (UTC)
Critics on MIPS
editThe article has a lengthy description of the acronyms critics of MIPs use, but does not state why they are critical of the metric. I suggest explaining why they are, for those people who read the article and have not taken computer architecture.
—Preceding unsigned comment added by 65.6.47.129 (talk) 19:25, 2 September 2007 (UTC)
- Those critics are personal opinions that are not appropriate for Wikipedia. I think the critics are mainly caused by ignorance of what MIPS means. Quite many people seem to mix MIPS with MNOPS (Million NOP instructions per second). That is, they assume that you can take the fastest possible execution time of the fastest instruction (such as NOP), calculate how many such instructions could be executed in second, and then call that MIPS. That would, of course, not be an useful method for comparing processor speeds. But that is not MIPS. MIPS is the average execution time of insturctions in real world applications.
- -- PauliKL (talk) 13:34, 14 March 2008 (UTC)
- Unfortunately this is not true. MIPS is highly dependent on the application that is used to calculate it. If a clever compiler reduces the use of time-eating instructions, this can possibly result in a lower MIPS value, although the processor is as fast as before. A simple example would be this: consider our processor contains only two instructions, add and multiply. In a sample program, compiled with a dumb compiler, all multiplications are displaced by multiple additions. Another compiler might use the builtin multiplication. Therefore, as one addition is faster than one multiplication, the first application results in a lower CPI (cycles per instructions) value, and the second one in a higher CPI. As a result (MIPS depends on CPI), the second application results in a lower MIPS value, although we are using the same processor. ( http://devel-rok.informatik.hu-berlin.de/svn/TI2/2006/folien/pdf/eng_ca03.pdf ) Is there more to add?
--141.20.192.251 (talk) 16:59, 15 July 2008 (UTC)
The acronym MIPS is inherently wrong due to the fact the unit of measure of time "second" has to be specified accordingly to the international standards spec. as a lowercase "s".
Following the correct example in the first sentence by the user "65.6.47.129" above, MIPs is the formally correct horthografy.
- No. The correct acronym is MIPS, since that is the acronym that has been commonly aggreed. If international standard specs (SI) was to be used, the acronym would be MI/s. But that is not the point. The main thing is what MIPS actually means and what does it measure. --PauliKL (talk) 18:54, 15 May 2008 (UTC)
Changes
editRemoved Pentium 4 data for error. Pentium 4s typically have MIPS between 3,000 and 20,000, depending on year of release.
Also removed data based on erroneous formula.
Added Year 2004 data for budget 32 bit and 64 bit PCs.
Several instructions per clock cycle
edit- Is that right about 20,000 MIPS for the Pentium and 10,000 for the Celeron? Can they really do several instructions per clock tick? Bubba73 19:15, 12 Jun 2005 (UTC)
- Theoretically yes. Starting from the 486 which is a 386CPU and 387FPU on the same die, most processors can theoretically do more than 1 instruction per cycle. Note that cycle does not equal clock.
- That is not true. 486 can definitely not execute more than 1 instruction per clock cycle. And many instructions take more than 1 clock cycle, so the average is significantly less than 1 instruction/cycle. Adding FPU on same die does not change that. It is insignificant whether the FPU is on the same die or on different die. It does not change the way the processor works, and it does not have effect on the MIPS value. Since the days of the first FPU's, everybody has known the fact that adding FPU does not change MIPS value. MIPS is about integer performance of the CPU itself. It does not take account floating point calculations. And adding external units such as graphics processors does not have effect on MIPS value either. - PauliKL (talk) 21:27, 24 February 2008 (UTC)
- P.S. Added the missing headings on talk page - PauliKL (talk) 22:22, 24 February 2008 (UTC)
- I'm pretty sure that multiple instructions per clock didn't come in until at least the Pentium MMX ... that was kind of it's selling point wasn't it? Or at least the P5 had some superscalar stuff just so it could claim "first!", at the expense of some instructions actually being SLOWER per-clock, and then the MMX actually did it properly with SIMD and other improvements.
- The 486 was more notable for having several one-clock instructions, and an actually-usable L1 cache that meant said 1CLKs were also effectively zero-wait-state if they were also cache hits (or 1WS for L2, which most 486 boards also had, and in greater quantities than the token 8kb-or-so of 386 boards). It is NOT a 386 + 387... it builds upon them in a similar but milder way to how the 386 built on the 286, but it's as much an integrated 386+FPU as the 386 was "a 286 with 32-bit registers and bus". It has a number of added instructions, revisions to the pipeline etc that allow the 1CLK routines (and many other instructions to execute quicker, arguably a more important advance), the cache, improved fpu, clock doubling/tripling in later versions, etc, all of which allowed a 486 to operate much quicker than a 386 at the same clock speed (I think a common comparison was that a 25mhz 486 SX, ie one with an inactive fpu, was equivalent to a 40mhz 386 DX?). You may be thinking of some of the "low power" LC/SL/SLC chips which were basically 386 cores with some fakery to allow common "486-only" code to run on them (at low speed)? BTW, not all 486s had an operable FPU anyway (same as there were enough 386s sold with a 16 bit bus), so that comparison immediately goes out of the window.193.63.174.211 (talk) 12:46, 15 February 2012 (UTC)
- Ever since the first Pentium processor they have been superscalar, which means they can perform more than one instruction per clock. Now for some modern MIPS calculations: the K7 and K8 (Athlon and Althon 64 from AMD) have 3 integer units each and can issue 3 insructions per clock, and can complete most non-memory integer operations in a single clock. The fastest single-core Athlon 64 is 2.8GHz, which gives a theoretical limit of 2.8e9 * 3 / 1e6 = 8400 MIPS. The Intel Pentium 4 has 2 simple integer units and one complex unit. It can perform a select subset of simple integer operations (add,subtract, and shifts on the Prescott) at a rate of 4 instructions per clock, or a single less simple operation. The fastest single-core Pentium 4 is 3.8GHz, which gives a peak of 15200 MIPS if you are doing the 4 instructions per clock, or down to 3800 MIPS for less-simple instructions. None of this includes things you can do with the SIMD instructions. Given the ambiguity in the Pentium calculations I'll just start by adding the Athlon 64 to give an idea of current speed of modern processors.
- According to SySoft SANDRA Dhrystone ALU benchmark, an Athlon FX-57 clocked at 2.8GHz yield 12000 MIPS, an Athlon 64 X2 3800+ with two cores at 2GHz yield 17200 MIPS, using the same benchmark, I reached 25150 MIPS by overclocking my Athlon 64 X2 3800+ to 2.8GHz. I took the liberty to edit the Athlon 64 MIPS accordingly, if you don't beleive me, 'bench 'em yourself.
- MIPS is now largely replaced by MTOPS which manufacturers are required to disclose by law. (United States Department of Commerce Export Administration Regulations 15 CFR 774 (Advisory Note 4 for Category 4). )
- Links to MTOP calculations : [[1]]
[[2]]
- Note that the above post is several years old and CTP is no longer required by the US government for export purposes. The Adjusted Peak Performance replaced CTP back in April 2006 but was itself replaced less than two years later. As seen in this Intel press release in November 5, 2007 the US government published amendments to the Export Administration Regulations 15 CFR which requires exporters to use the metric of Gigaflops (GFLOPS) to measure processor performance. --GrandDrake (talk) 05:57, 19 June 2010 (UTC)
Timeline
edit- Aren't timelines usually in chronological order? Shogun 01:07, 21 March 2006 (UTC)
- yep, they are. I corrected the table. jidan 15:56, 15 May 2006 (UTC)
New proposed timeline
editHi, instead modifying the table inside the article, I write here the new proposed timeline based on http://www.frc.ri.cmu.edu/users/hpm/book97/ch3/processor.list.txt. However the last entries with the processor name only (from Intel pentium pro) should be removed/changed, because I think that is more realistic to calculate the IPS for the enteire system (CPU/bus/memory) and not only the processor. I also found very useful the cost of the system compared to the value of USD in the 1997, to understand the customer target. The sources are various (specint, speedmark, winsscore..) compared to the MIPS. May be not perfect, but I think it is a good point to start. Please to leave some comment. --Trek00 02:54, 5 February 2007 (UTC)
Processor | IPS | Year | Cost (USD 1997) |
---|---|---|---|
Pencil and Paper | 0.0119 IPS | 1892 | |
ENIAC | 2.89 kIPS | 1946 | 600'000 |
UNIVAC I | 5.75 kIPS | 1951 | 930'000 |
Whirlwind | 69.4 kIPS | 1955 | 200'000 |
Atlas | 1.4 MIPS | 1961 | 5'000'000 |
CDC 6600 | 8.76 MIPS | 1964 | 5'000'000 |
CDC 7600 | 25.7 MIPS | 1969 | 10'000'000 |
IBM System/370-195 | 17.3 MIPS | 1972 | 8'000'000 |
Altair 8800 (Intel 8080 at 2 MHz) | 10 kIPS | 1974 | 500 |
Cray 1 | 150 MIPS | 1976 | 10'000'000 |
VAX 11/780 | 1 MIPS | 1977 | 200'000 |
Apple II | 20 kIPS | 1977 | 1'300 |
Commodore 64 | 200 kIPS | 1982 | 500 |
Macintosh 128K (Motorola 68000 at 8 MHz) | 520 kIPS | 1984 | 2'500 |
Cray 2 | 824 MIPS | 1985 | 10'000'000 |
Macintosh II (Motorola 68020) | 2.5 MIPS | 1987 | 3'000 |
PC Brand 386/25 (Intel 386DX at 25 MHz) | 4.3 MIPS | 1988 | 2'450 |
Amiga 3000 (Motorola 68030) | 12.5 MIPS | 1990 | 3'300 |
Gateway 486DX2/66 (Intel 486DX at 66 MHz) | 30.9 MIPS | 1991 | 3'900 |
Power Macintosh 7100/66 (PowerPC 601 at 66 MHz) | 100 MIPS | 1994 | 2'899 |
ARM 7500FE | 35.9 MIPS at 40 MHz | 1996 | |
Gateway G6-200 (Intel Pentium Pro at 200 MHz) | 350 MIPS | 1997 | 2'949 |
Power Macintosh G3 (PowerPC G3 at 266 MHz) | 500 MIPS | 1997 | 2'000 |
Zilog eZ80 | 80 MIPS at 50 MHz | 1999 | |
Intel Pentium III at 500 MHz | 820 MIPS | 1999 | 2'500 |
Power Macintosh G4 (PowerPC G4 at 450 MHz) | 856 MIPS | 1999 | 2'500 |
ASCI White | 10000000 MIPS | 2000 | 110'000'000 |
AMD Athlon | 3561 MIPS at 1.2 GHz | 2000 | |
AMD Athlon XP 2400+ | 5935 MIPS at 2.0 GHz | 2002 | |
Pentium 4 Extreme Edition | 9726 MIPS at 3.2 GHz | 2003 | |
System X | 20000000 MIPS | 2004 | 6'000'000 |
ARM Cortex A8 | 2000 MIPS at 1.0 GHz | 2005 | |
Xbox360 IBM "Xenon" Triple Core | 6400 MIPS at 3.2 GHz | 2005 | |
IBM Cell All SPEs | 12096 MIPS at 3.2 GHz | 2006 | |
AMD Athlon FX-57 | 12000 MIPS at 2.8 GHz | 2005 | |
AMD Athlon 64 3800+ X2 (Dual Core) | 14564 MIPS at 2.0 GHz | 2005 | |
AMD Athlon FX-60 (Dual Core) | 18938 MIPS at 2.6 GHz | 2006 | |
Intel Core 2 X6800 | 27079 MIPS at 2.93 GHz | 2006 | |
IBM Cell BE (All the SPEs) | 25600 MIPS (FLOPS) at 3.2 GHz | 2006 | |
Intel Core 2 Extreme QX6700 | 57063 MIPS at 3.33 GHz | 2006 |
- "Pencil and paper" is 1892 ? ... erm. OK. How about "indeterminate point several thousand years in the past"? You've got to fit abacuses, pascal's bones, slide rules and comptometers in-between that and ENIAC after all, without even getting into the differences between various paper-based methods and user experience and ability...
- Also this shows a quite different result for the speed of the M68k - in the main article it's 1.0 MIPS, here it's 0.52, both at 8Mhz ... which is correct? Also, the main article claims the i8080 - aka the 8-bit variant of the i8086 that the Z80 was cloned from - manages 0.5MIPS at 2Mhz, or twice the per-clock efficiency (or 4x, if we believe the figures here). I'm pretty certain that's a hundred million miles from the truth... (I'm not convinced by the 80286 having such a per-clock gain vs the 68000, either; it simply doesn't seem to keep up all that well IRL. Though perhaps the raw figures are correct and one of them is just a whole lot harder to program effectively?) 193.63.174.211 (talk) 12:57, 15 February 2012 (UTC)
Cell Data is blatantly incorrect
editGuys -- The data you posted about the Cell processor is just plain incorrect. Please update the page. For the record:
Cell runs at 3.2 GHz. Cell has one dual-threaded fully 64-bit Power Architecture core. This core, not including its AltiVec vector processor, does 6400 MIPS... although these are 64-bit instructions so the comparison to 32-bit processors is really not too valid. (Should we claim that it's 12800 "32-bit MIP equivalents"?) In ADDITION to the above, the Cell has 8 single-threaded 128-bit processor cores. That adds 25600 MIPS or 102400 32-bit MIP equivalents... for a total of 38400 (115200).
FLOPS have nothing to do with the above. In FLOPS, the Cell does over 200 single-precision GFLOPS and in the high teens in double precision. As of today (30 Mar 2007), information on the next-generation processor has been released... although I am not at liberty to disclose its performance until someone cites it.
The figure you cited was not a peak value (as cited for other processors). Instead, you took the performance on a given benchmark (Linpack) in FLOPS... which are not comparable to MIPS.
The Cell Team at IBM
- No, you can not multiply the MIPS value by 2 using the excuse that processor has some 64 bit instructions. One 64 bit instruction is still just one instruction. And, let's face it, 64 bit instructions are rarely used in real world applications. After all, 64 bit data is quite rare. Most common data is 8 bit (character data, 8 bit/channel RGB data etc.). In addition, most applications use only 32 bit instruction set in order to be compatible with older processors, so 64 bit processor is no faster than 32 bit one. But even if the program is compiled to use 64 bit insturctions, it will only be around 2% to 5% faster than the 32 bit version.
- Indeed, FLOPS measurement should not be mixed with MIPS. MIPS is only about integer performance. No matter how powerful FPU is included with the CPU, it does not have effect on the MIPS value of the CPU.
- There is no such thing as "peak value" in MIPS measurement. MIPS is the average number of instructions executed by the processor when running a real world application. (Well, the term "peak MIPS" is sometimes used to say that it is the speed of the CPU when the application fully fits in L1 cache so that the memory access is not slowing down the operation. Which is the case with Dhrystone benchmark, for example.)
- -- PauliKL (talk) 22:09, 24 February 2008 (UTC)
- Yes, but MIPS started in the days when processors did about the same amount per instruction. Before hardware multiply, when you had an MQ register and did shift and add, or shift and subtract, and each instruction operated on one processor word. As hardware changed, and the amount of processing that an instruction, or even a clock cycle, could do change, MIPS became less and less useful. That is why some call it Meaningless Indicator of Processor Speed. Gah4 (talk) 22:08, 23 April 2015 (UTC)
Given MIPS ratings not correct
editThe MIPS ratings given in the table seem to be incorrect. For example, 8080 at 2 MHz has been given value 640 kIPS (0.64 MIPS), which is impossible. The fastest instructions on 8080 take 4 clock cycles. Thus, 2 MHz 8080 can execute maximum of 0.5 million instructions per second.
However, max number of instructions per second is not MIPS. MIPS is calculated from weighted average of instruction execution times.
I recall Intel has given 8080 rating of 0.08 MIPS, which sounds more correct, considering the fact that a 8 bit processor needs multiple instructions to perform a single 32 bit operation.
Another example: Zilog eZ80 has been given rating of 80 MIPS at 50 MHz. As far as I know, eZ80 is not a superscalar processor, so it can not execute more than 1 instruction / clock cycle. Since it is a 8 bit processor, the MIPS rating must be significantly less than 50 MIPS.
PauliKL (talk) 18:08, 23 January 2008 (UTC)
- And youl English wliting not colect, eithel. Soly about that. --AVM (talk) 22:17, 14 February 2009 (UTC)
- PauliKL does not seem to understand what MIPS means. That may be partly because it is not a well defined term in general, but here I thought it was defined in terms of the speed of executing native instructions. That means no compensation is made for what the instructions are doing.
- I remember (although it has been a long time) that the 8080 can execute instructions as fast a 3 clock cycles. The basic instruction operation has three steps labeled T1, T2 and T3 which derive from the original 8008 which used three clock cycles to access memory over a single 8 bit port; output upper address, output lower address, input or output data. The 8080 retained the three clocks per machine cycle concept even though it could output the entire address and data in parallel.
- The whole table seems to be fed with wrong data. For example, the cited 23.8 IPS for a Core i7 Extreme 965 cannot be correct. Any Nehalem-based CPU is a 4-way superscalar CPU, i.e. it can execute at most four instructions per clock cycle (peak throughput). Having four cores (i7 Extreme 965) yields a theoretical maximum of 4*4 = 16 instructions per clock cycle. Thus, the 23.8 IPS number is clearly too high. --85.216.120.3 (talk) —Preceding undated comment added 16:49, 1 December 2010 (UTC).
- edit: I think the whole confusion is caused by the numbers from Sisoft Sandra (or the inability to think and interpret those numbers by whoever used it as a source for its high IPS claim): Sisoft Sandra probably uses SIMD instructions to maximize throughput (SSE2/3 etc.) but counts every sub-instruction in a large SIMD-word as one executed instruction. For instance, if computing several 32 bit numbers, it uses the 128 bit SSE1/2/3 format to do four 32bit calculations in parallel. Although the throughput is equivalent to four single 32 bit operations, this is actually _one_ instruction executed, not four! If for example the processor is executing two of those SIMD instructions in parallel, those yield only an IPS of two. The instruction pipeline of the processor is incapable of processing eight (i.e. two times four) instructions per clock cycle. The hardware is simple not capable of doing that! So, in this example (Core i7 Extreme 965), it is simply wrong claiming a higher value of four IPS per core (or sixteen IPS in total). --85.216.120.3 (talk) 17:04, 1 December 2010 (UTC)
- Sisoft Sandra does not count instructions. (In fact, I don't think it is even possible to count instructions without using dedicated debug hardware.) It uses Dhrystone test and then displays the results as MIPS. So, the unit used is actually Dhrystone-MIPS. However, the test used is not exactly the original Dhrystone test, but a multi-threaded, 32/64-bit variant, so the results are not 100% comparable with the original. (See the FAQ).
- Maybe there should be separate columns for "IPS" (which usually means execution speed of NOP instructions) and Dhrystone-MIPS. --PauliKL (talk) 11:29, 5 December 2010 (UTC)
Seems the Freescale page for the 68060 gives different values. But maybe it's due to newer fabrication process ? Mmu man (talk) 19:20, 18 December 2010 (UTC)
MIPS = MHz?
editIf a microprocessor can execute a singular instruction million times per second (MHz), then why can't it execute a million unique instructions within the same timeframe (MIPS)? What is the game-changing constraint here? This article does not explain this rather bizarre behaviour.Anwar (talk) 10:44, 15 May 2008 (UTC)
- Huh? What do you mean? MHz is unit of frequency, not unit of instructions per second. In context of processors, MHz is usually used to measure the clock frequency. Traditional CISC processor may require multiple clock cycles to execute one instruction, so they deliver less than 1 MIPS/MHz. RISC processors typically execute every instruction in one clock cycle. In that case, they would execute about as many instructions per second as the MHz value would indicate. Number of instructions executed per second is not same as MIPS, but with 32-bit processors, it is quite close. However, there are processors that can execute multiple instructions in parallel (superscalar). Further, there are processors with multiple cores. These deliver more than 1 MIPS/MHz. --PauliKL (talk) 19:10, 15 May 2008 (UTC)
- A RISC processor doesn't execute 1 instruction per clock cycle.
- One instruction needs as many clock cycles as the pipeline depth is (at least 1 cycle to fetch the instruction, 1 to execute, 1 to write result back).
- In the best case scenario 1 instruction is completed at each clock cycle, even is 1 instruction needs many cycles. Poil (talk) 01:21, 4 August 2024 (UTC)
IBM 704 & IBM 7030
editCould someone add the Mips of the IBM 704 (1954) and the IBM 7030 (1961) to this table? I'm too dumb to do so. tnx in advance. See also new proposed timeline above. Aleichem (talk) 20:37, 8 June 2008 (UTC)
IBM Mainframe cpus removed?
editWhy were the IBM Mainframe cpus removed? The newest z196 Mainframe have 24 cpus and gives 50.000 MIPS. This means each 196 give 2.000 MIPS each. Please add it.
The z10 Mainframe with 64 cpus, gives 28.000 MIPS, this means each z10 cpu gives 450 MIPS. Please add that. — Preceding unsigned comment added by 217.73.15.6 (talk) 11:06, 23 January 2012 (UTC)
IPS/Hz
editThere's something wrong with the IPS/Hz metric. In SI base units a hertz is "1/second". Thus,
Just plain instructions. It does not make sense to me. Also, since IPS and CPU clock frequency are both unreliable performance metrics([3], page 13), their ratio is pretty much worthless anyway. —ZeroOne (talk / @) 11:40, 3 April 2010 (UTC)
- It seems to be the number of instructions per clock cycle.--Patrick (talk) 15:29, 3 April 2010 (UTC)
- That's kind of what I figured too. It just does not make sense to me that a desktop computer could execute thousands of instructions per clock cycle, as has been marked to be the case for several systems in the article. A clock cycle is what makes the CPU 'tick', nothing can happen faster than in one clock cycle. A quad-core processor could, of course, execute four instructions per second, etc. It seems to me that in this article MIPS refers to something else than the obvious. Weicker[4] lists five possible interpretations of the concept of MIPS that manufacturers give for their products. One of the interpretations, a common one according to the author, is "VAX MIPS". This is a factor relative to the VAX-11/780. This could be the one that is being used here. Anyway, I'm in favor of dumping the entire table because collecting statistics of a meaningless indicator of processor speed is, well, meaningless. At least the newer than 1970s computers could be dropped, because that's about when the original concept of MIPS started to fall apart anyway. —ZeroOne (talk / @) 23:39, 3 April 2010 (UTC)
- The largest value in the table is 45, not thousands.--Patrick (talk) 06:11, 4 April 2010 (UTC)
- Oops, my bad. The numbers were presented in different precision and I got confused. I have now rounded them all to just one decimal place. Anyway, I think the article needs to explain why is it possible to have, say, 45 instructions per clock cycle. I suppose it's got to do with superscalarity, branch prediction, etc, but in any case the 45 must be a peak number that is impossible for the system to sustain. Right? —ZeroOne (talk / @) 10:43, 5 April 2010 (UTC)
- Rounding all values to 1 decimal was not a good idea. It would be OK to round 1234.56 to 1234.6, but when you round 0.25 to 0.3, you are creating a big error. For example, Intel 8080 now has value of 0.3 instructions/clock cycle, which means that average instruction execution time would be 3.33 cycles. However, on 8080 even the fastest instruction takes 4 clock cycles, and some instructions up to 18 cycles. --PauliKL (talk) 15:12, 8 April 2010 (UTC)
- It is usual to round based on the uncertainty in the value. In the case of MIPS, there is a lot of uncertainty, even though each person making a measurement will claim that theirs is correct. One digit is probably about right. If you don't like 0.3, then round to 0.2 instead. (According to "round to even" that would be more correct.) Gah4 (talk) 22:37, 23 April 2015 (UTC)
- MIPS is actually a good measure for CPU performance, definitely not "worthless". The expression "meaningless indicator of processor speed" is used by ignorant people who do not know what MIPS means. Of course you should realize that MIPS only measures CPU performance. There are many other factors that affect the computer performance, such as the speed of memory bus, display controller and hard disk.
- On the other hand, MIPS by itself does not measure the performance, it is just an unit used to display the performance value whichever method is used to measure it. There are good and not so good methods to do the measurement, just like there are many methods to measure temperature. Originally, the measurement was done by calculating a weighted average of specific instruction set (e.g. VAX instruction set for VAX MIPS). That was a good method, but laborious, so later many of the MIPS values were measured by running some benchmark and then comparing the results to known computers (e.g. Dhrystone MIPS).
- But, as I have said before, the values in the table are wrong. For example, the correct value (according to Intel) for 8080 is 0.04 MIPS, not 0.5 MIPS. For newer processors, the values seem to be just pulled out of a hat. --PauliKL (talk) 16:03, 8 April 2010 (UTC)
- One of the problems with MIPS as the unit of CPU performance is that different CPU architectures get different amounts of work done per instruction. Thus a 10 MIPS CPU can well be faster than a 20 MIPS CPU. —ZeroOne (talk / @) 12:24, 10 April 2010 (UTC)
- No. The problem with MIPS is that ignorant people do not understand what MIPS means, and therefore they have all kind of false beliefs. In reality, 10 MIPS CPU can never be faster than 20 MIPS CPU (in integer calculations), since, by definition, 20 MIPS is twice as much power as 10 MIPS.
- Back in the 70'ies and 80'ies, when actual calculated MIPS values were still used, the standard unit was VAX MIPS. It is based on VAX 11/780 instruction set (not the target machine's instruction set). The amount of work done depends on what VAX can do with the instructions, now what the target machine instructions do. If the target machine requires multiple instructions to perform one VAX instruction, the calculated instruction execution time is the sum of those instructions. That is why 8-bit processors have such a low MIPS ratings. For example, 8085 processor running at 4 MHz can execute up to 1 million instructions per second, but it's processing power (according to Intel) is only 0.08 MIPS.
- Later, MIPS values where usually derived from benchmarks. If CPU A (rated at 10 MIPS) executes a benchmark in 20 seconds, and CPU B executes the same benchmark in 10 seconds, CPU B will have rating of 20 MIPS. How could CPU A still be more powerful than CPU B? --PauliKL (talk) 19:49, 11 April 2010 (UTC)
- By definition MIPS = n / (t * 10^6) where n is the number of instructions executed and t is the time it took to execute those instructions, in seconds. It does not follow that a 20 MIPS CPU is always faster than a 10 MIPS CPU. An instruction of a CISC CPU could equal, say, 4 instructions of a RISC CPU. If the CISC CPU then performs at 10 MIPS, it would be equal to a 40 MIPS RISC CPU. Clearly the 10 MIPS CISC CPU would then be faster than a 20 MIPS RISC CPU. —ZeroOne (talk / @) 22:02, 11 April 2010 (UTC)
- No. That is not the definition of MIPS. And what do you mean by "instructions executed"? What instructions? Executed when? As I already explained, the actual MIPS rating is the weighted average of the execution times of all instructions in some specific instruction set (e.g. VAX instruction set). The weighting factor depends on how common the instruction is in real world applications. If a RISC processor requires multiple instructions to perform one VAX instruction, the sum of the execution times of those instructions is counted as one instruction in MIPS calculations. Dhrystone MIPS, on the other hand, is the result of Drystone test normalized into MIPS scale. It does not count the instructions at all.
- One CISC processor instruction definitely does not equal 4 RISC instructions. The studies show that a RISC processor typically needs 10% more instructions to execute a task than CISC processor. So, if executing an application requires 10 million instructions in CISC, it would require approximately 11 million instructions in RISC. If CISC processor needs 1 second to execute the task and RISC processor needs 0.5 seconds, then clearly RISC processor is more powerful. --PauliKL (talk) 16:46, 12 April 2010 (UTC)
- By "instructions" I mean the individual instructions the processor executes: loads, stores, register manipulations, etc. They are executed when the application is being executed, obviously, because applications are made out of those instructions. The definition of MIPS I gave you is from Measuring Computer Performance : A Practitioner's Guide by David Lilja, ISBN 9780521641050. What makes you think Lilja, a published author, is "ignorant"? Can you give me an equally credible source for your interpretation of the MIPS figure?
- I did not ask what you mean by "instructions". The question is, which instructions? Which application? What is that legendary "The Application" that is used to define which instructions are counted? The reason why ignorant people think MIPS is bad is because they assume they can just use any application they like, even one that contains nothing but NOP instructions. In reality, the weight factors used in VAX MIPS calculations were based on statistics from huge amount of real world applications run in VAX. The reliable source for this information are the many computer magazines (Byte, Dr. Dobb's Journal etc.) that were published in those times when MIPS calculations were actually used for benchmarking. The problem is that I don't have those magazines any more, that is why I have not fixed the article. --PauliKL (talk) 16:18, 13 April 2010 (UTC)
- Well, pardon me if I wrongly interpreted "what do you mean by "instructions executed"? What instructions?" as a question on what I mean by instructions. It seems to me that you are confusing the metric with some benchmark. "MIPS" does not care what instructions are being executed. It's just a metric. It's like I was telling you that a kilometer equals 1000 meters and you insisted that no, you must define whether you are going to travel the kilometer on foot or by car. —ZeroOne (talk / @) 21:51, 13 April 2010 (UTC)
- No, you are the one that is confusing things. Yes, MIPS is a metric, as I already told you. It is a metric of CPU speed. Not a metric of how many unspecified instructions are executed in whatever unspecified program. After all, such a "metric" would be pretty much useless (even if you find a way to count the instructions). Even the concept of "instruction" is vague. For example Pentium and Core 2 processors, even if called CISC processors, are actually RISC processors internally. The legacy CISC instructions are translated into RISC instructions before executing. Which instructions should you count, the CISC instructions in the code or the RISC instructions actually executed? And what about speculative execution?
- In reality, MIPS definitely does care what instructions are being executed. This is because (in CISC processors) instruction execution times vary very much, for example from 1 to 50 clock cycles. That is exactly why MIPS calculation is done as weighted average. --PauliKL (talk) 16:10, 16 April 2010 (UTC)
- Well, pardon me if I wrongly interpreted "what do you mean by "instructions executed"? What instructions?" as a question on what I mean by instructions. It seems to me that you are confusing the metric with some benchmark. "MIPS" does not care what instructions are being executed. It's just a metric. It's like I was telling you that a kilometer equals 1000 meters and you insisted that no, you must define whether you are going to travel the kilometer on foot or by car. —ZeroOne (talk / @) 21:51, 13 April 2010 (UTC)
- I did not ask what you mean by "instructions". The question is, which instructions? Which application? What is that legendary "The Application" that is used to define which instructions are counted? The reason why ignorant people think MIPS is bad is because they assume they can just use any application they like, even one that contains nothing but NOP instructions. In reality, the weight factors used in VAX MIPS calculations were based on statistics from huge amount of real world applications run in VAX. The reliable source for this information are the many computer magazines (Byte, Dr. Dobb's Journal etc.) that were published in those times when MIPS calculations were actually used for benchmarking. The problem is that I don't have those magazines any more, that is why I have not fixed the article. --PauliKL (talk) 16:18, 13 April 2010 (UTC)
- By "instructions" I mean the individual instructions the processor executes: loads, stores, register manipulations, etc. They are executed when the application is being executed, obviously, because applications are made out of those instructions. The definition of MIPS I gave you is from Measuring Computer Performance : A Practitioner's Guide by David Lilja, ISBN 9780521641050. What makes you think Lilja, a published author, is "ignorant"? Can you give me an equally credible source for your interpretation of the MIPS figure?
- Also my point holds even if RISC processors typically need 10 % more instructions than CISC processors. If an application requires 10 million instructions in CISC and 11 million in RISC and both execute the application in 1 second, then the CISC computer would have a MIPS value of 10 and the RISC computer a MIPS value of 11, even though they actually perform equally well.
- —ZeroOne (talk / @) 10:19, 13 April 2010 (UTC)
- No. If the application is a benchmark, and both processors get the same result (e.g. the same time), they both have the same result even when it is converted into MIPS value. For example, if it was Drystone test and both processors get the result 17570 dhrystones/sec, then both processors have Dhrystone MIPS rating of 10.0. The number of instructions they executed during the test has no effect on the results (and probably it is not even known). --PauliKL (talk) 16:18, 13 April 2010 (UTC)
- Well, I, for one, was talking about the concept of MIPS, not about the concept of various benchmarks. Why are you switching between Dhrystone MIPS and VAX MIPS anyway? Also if a MIPS figure does not represent millions of instructions per second, like you said it doesn't in the case of Dhrystone, then it's pretty obvious to me that the acronym is being used in some other meaning than its original one. —ZeroOne (talk / @) 21:51, 13 April 2010 (UTC)
- As I have explained, there are two possible ways to get MIPS rating:
- 1. Manually calculating a weighted average of instruction execution times for some specific reference instruction set (e.g. VAX instruction set, or older Gibson Mix or ADP Mix), or
- 2. Running a benchmark and then scaling the results into MIPS value (e.g. Dhrystone MIPS). In this case, MIPS is only used as a metric. Most of the values in the "Timeline of instructions per second" table (if not pulled out of hat) obviously come from benchmarks.
- I have shown that whichever method is used, your arguments are wrong. MIPS is measure of CPU performance, it is not an instruction counter. MIPS does not care about how many instructions are executed in the target processor. RISC and CISC processors that have equal performance will get (approximately) equal MIPS rating regardles of how many instructions they happen to execute for some task. --PauliKL (talk) 16:10, 16 April 2010 (UTC)
- I can't help but think that you are just dodging my questions or rephrasing what I (or you yourself) have been saying. How do you explain, for example, the definition of MIPS that Lilja gives in his book? Are you saying he is wrong? I gave you a claim with a source and you keep insisting on your own views, completely ignoring my points. —ZeroOne (talk / @) 10:16, 17 April 2010 (UTC)
"The nice thing about standards is that you have so many to choose from."[1]Gah4 (talk) 22:37, 23 April 2015 (UTC)
Corrections to DIPS/cycle/core
editI've made some corrections to the DIPS/cycle/core calculations for Intel Core i7 processors, they were half what they should have been because the math was done with the number of logical cores, not physical cores. Please remember to only count the number of PHYSICAL cores in CPUs with HyperThreading. Alereon (talk) 07:45, 11 October 2011 (UTC)
Atom N270
editN270 is single core right? The Atom entry lists 2.4 and 1.2 as if it is dual core. I think both values should be 2.4 but would like a second opinion before editing. thanks. — Preceding unsigned comment added by 194.46.201.216 (talk) 11:50, 12 October 2012 (UTC)
8080 Timing
editIntel 8080 MIPS numbers are incorrect and not plausible. The Intel 8080 and 8085 instructions ran in from 4 to 17 clock cycles each. There were a few 4 cycle, quite a few each of 5, 7, 10, 11, 13, 16, and 17. I wrote alot of 8080 code and optimized at the clock-cycle level. I used a rule of thumb of 10 cycles per instruction and found it a very good generalization. This would be 0.2MIPS, or 0.1 IPS/Cycle-per-second. Certainly anything claiming to be authoritative has to be in this ball park. The table lists 0.33 MIPS, or 6 instructions per clock cycle on average. This program would be primarily a long string of carefully selected arithmetic instructions with no memory accesses, branding, or stack operations - very unrealistic. What an average MIPS rate is in the absence of a standard benchmark is debatable, but in no case could one claim an 8080 to be above 0.5 MIPs. The paragraph just above the table states that a 2MHz 8080 executes 0.64 MIPS. With the shortest instruction being 4 clock cycles, this is not possible. Can the originator of the current numbers give any reference or anecdote on which they are based?
Until someone comes up with an authoritative reference of some sort I would use my numbers of 0.2 MIPS at 2MHz, 0.1 IPS/Cycles per second. At the very least, the 0.64 should be made consistent with the 0.33, and I would argue that the 0.33 is unrealistic. If nobody is happy with my number, put a range of 0.2-0.33 depending on instruction mix. I do not know how to edit and don't want to mess it up.
The new proposed table lists the Altair 8800. This seems redundant since the 8080 is already listed, but more important it lists it as 10 KIPS. Per my numbers above, this is 10x too slow. Even given the possibility of slow memory and wait states, there is no way it could possibly be this slow. This I believe should be 100KIPS, but not knowing how many wait states it ran to memory over the S100 bus, I cannot give an accurate number.
The proposed table also lists the 8085 and gives number that are inconsistent with the listed 8080 numbers. Except for the level of integration, both processors are identical, and execute all instructions in exactly the same number of clock cycles under all conditions. The mainline 8085 ran at 3MHz vs. the 8080's 2MHz, do the MIPS should be 1.5X listing 3MHz instead of 2, and the IPS/ClockCyclePerSecond should be the same. If you cranked up the power supply voltage they would run at 10MHz or so :-) ... But not for long :-( ...
— Preceding unsigned comment added by Rnsc5j (talk • contribs) 23:00, 25 January 2013 (UTC)
Summary table needs to be fixed
editLast few rows of the summary table were incorrectly added (wrong number of columns etc.), so they should to be fixed. It would be great if someone could handle that. Thank you. -- Dsimic (talk) 15:55, 7 October 2013 (UTC)
There are several new rows showing inconsistent values. (e.g. 486 and 486 same cpu but different values)--62.48.72.6 (talk) 08:08, 21 October 2015 (UTC)
Move discussion in progress
editThere is a move discussion in progress on Talk:Kilometres per hour which affects this page. Please participate on that page and not in this talk page section. Thank you. —RMCD bot 01:00, 10 December 2013 (UTC)
- I don't see that MIPS got much discussion there, but it doesn't seem appropriate, anyway. MIPS is not the plural of MIP, though I have seen MIP used as the singular. (VAX is a 1 MIP machine.) Reminds me of my old favorite, LASE and LASING are the verb forms of the acronym LASER. Gah4 (talk) 22:38, 11 November 2015 (UTC)
Meaningless Indicator of Processor Speed
editIn the 1950's and 1960's, computers weren't all that different. Scientific processors commonly had a 36 bit word, and instructions operated on that word size. You could probably make a fair comparison between a DEC PDP-10 and an IBM 7090 based on instruction execution rate. Even so, it is a rough indicator, but sometimes that isn't so bad. But as processors diverged, it became less useful. Comparing a 6502 with its 8 bit accumulator and an IBM 370/158 with 32 bit registers, based just on instruction execution rate is meaningless. When comparing members of a family, such as different models of VAX, or different models of IBM S/370, MIPS also tends to work. VAX MIPS, based on a certain VAX processor being 1 MIPS (even when it probably wasn't) and a reasonable set of benchmark programs also might be useful, though it removes the whole meaning behind the acronym. Might as well just compare in relative speed to a specific VAX processor, and not call them VAX MIPS. Gah4 (talk) 12:03, 28 October 2014 (UTC)
- There doesn't seem to be much interest in figuring out what to do with this. In the 1970's, people did use benchmarks to give MIPS values to machines for comparison purposes, but those benchmarks have to be reasonable for the machines of interest. Also, up through the early 1970's, it was usual to publish instruction timings for processors. But when processors started doing instruction overlap, those timings were meaningless, and they stopped being published. There are probably tables in Datamation that one could search for. About that time, it was realized that the benchmarks being used really weren't useful for comparing real problems. As the minicomputer market grew, new benchmarks were used for them, but not for comparing them to bigger mainframes and supercomputers. The VAX 11/780 was advertised as a 1MIPS machine, and others compared theirs to VAX. As the 8 bit microcomputer market grew, there were benchmarks, but not, as well as I know, measured in MIPS. Given that, this article should have tables based on actual tables from the 1950s to 1970s, one for mainframes, one for minicomputers. As the benchmarks used wouldn't run on the 4004, or many other small computers, those should not be in the table. Also, machines that do instruction overlap should not be, as the benchmarks don't apply. Newer benchmarks were created, but the times don't trace back to MIPS. Find actual tables, and don't make up numbers! Gah4 (talk) 04:55, 23 October 2015 (UTC)
A reference for benchmarks for the i860 includes tables for benchmarks of other contemporary processors. One is called "Stanford Integer MIPS", others are Whetstone, Dhrystone, and Linpack. The latter three are not calibrated in MIPS, but instead have their own unit.[1] Also, see reference [Serlin 86] in the PDF. Gah4 (talk) 05:18, 23 October 2015 (UTC)
References
- ^ intel. "i860 Processor Performance" (PDF). intel. Retrieved 23 October 2015.
Meaningless Indicator of Processor Speed
editThere seems to be disagreement on what MIPS means, but the numbers in the chart seem to be meaningless. Some suggest that the numbers should be based on a benchmark, and then scaled, but that isn't where the chart numbers come from. Trying to compare an 8080 and 370/158 based on instruction counts is meaningless. Before IBM System/360, machines for commercial use processed characters or decimal digits, and could be reasonably compared by instruction counts. Scientific machines, often with 36 bit words, could also be compared. Comparisons between the two are meaningless. Comparisons against 8 or 16 bit processors against 32 bit processors, on instruction counts, is meaningless. If based on a benchmark, for one, you have to specify the benchmark, and it has to run on all processors being compared. I don't know that there are any references that explain this, though. Gah4 (talk) 05:26, 21 July 2015 (UTC)
Changes
editIs there any interest in fixing this? As is noted a few times in the discussion, MIPS really isn't millions of instructions per second, but a speed calculated from a benchmark. Even more, different benchmarks will give different, not really comparable, values. Seems to me that the only fix is a separate table for each benchmark. That would allow for comparison between machines tested with that benchmark. Most obvious, given the Wikipedia rules, is tables based on published values for each benchmark. I believe that SPEC doesn't allow one to do their own tests. Some could probably be run on newer, or on existing older machines. Many of the posted numbers have no relation to any benchmark, some are based on instruction timing for a single instruction. Some are completely unrealistic. I have asked previously, with no hint of any interest. Gah4 (talk) 07:41, 6 May 2016 (UTC)
- The table should definitely either completely removed, or limited to the computers for which we have the equivalent VAX-MIPS value (with the 11/780 = 1).
- It make no sense to compare "MIPS" values of an UNIVAC with a VAX and VAX with a Connection Machine and a CM with a Ryzen 9. Poil (talk) 01:46, 4 August 2024 (UTC)
- It doesn't even make sense to compare two machines in the same product line without specifying the instruction Mix, e.g., when comparing an IBM 370/158 to a 4341, is the benchmark weighted to packed decimal arithmetic or to floating point. -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 18:14, 4 August 2024 (UTC)
Re. list of MIPS ratings
editThe big list of MIPS ratings appears to be cobbled together from sources that fail WP:RS. Some entries, such as the one for the K computer are highly suspect. It may be referenced, but the cited source is just a text file on what appears to be some professor's personal web page. The claim that the K computer has its MIPS measured is highly improbable, if not impossible. Supercomputers, let alone one like the K computer's scale, are not benchmarked by drystone. The cited source appears to have extrapolated the MIPS rating from something else. It need not be said that such an extrapolation would be invalid for obvious reasons. The rest of the entries have the same problem or others; for example, there are computers that could not have run drystone because drystone did not exist when those computers were in existence. There are some very small computers (such as the 4-bit Intel 4004) that weren't capable of running drystone. The drystone MIPS and MIPS column of the table conflates the two: one is a MIPS rating from a specific benchmark (that was also implemented in many ways, this is a problem in itself), the other is vague (MIPS could have been obtained from a variety of benchmarks, none comparable). The list has so many uncorrectable and fundamental flaws and is of such uselessness (because coalescing a bunch of MIPS ratings from random sources means the ratings cannot be compared to each other) it should be removed from the article. L9G45AT0 (talk) 22:53, 22 July 2016 (UTC)
All the tables are flawed. Over the years, the meaning of MIPS changed, but most of the time it was based on the speed of some (changed with time) benchmarks. Those benchmarks won't run on many smaller computers. Seems to me that the only fix is to make it historically accurate. That is, tables that correspond to the benchmarks when they were used. The problem is that the acronym comes from "Millions of Instructions Per Second". Given that, some desire to add new entries based on the instruction rate, sometimes executing No-Op instructions, of small processors. But it was originally on word addressed, often 36 bit, processors. Any numbers should be based on actual benchmarks from the appropriate time period. Gah4 (talk) 02:24, 10 August 2016 (UTC)
- To prevent invalid comparisons by restricting entries to tables that share the same benchmarking methodology is sensible, but what about systems where any sort of MIPS rating would be completely absurd? For instance, the K computer which was previous mentioned. AFAIK, there are no MIPS ratings from anything that could be considered a reliable source for the K computer. There are many similar entries in the table. I'm thinking of removing any entry for which the MIPS rating was estimated or derived by some form of magic from some other metric. It should be obvious that such practice is not founded on sound theory. L9G45AT0 (talk) 18:55, 11 August 2016 (UTC)
- Seems to me, especially following the encyclopedic nature of wikipedia, that the tables here should be based on published MIPS tables. That is, ones that are published as timing benchmarks, not based on individual instruction timing. In the 1960's and 1970's, there were many published processor comparisons denoted in MIPS. In the 1980's, as VAX became popular, and the VAX 11/780 was considered a 1 MIPS machine, tables were denoted in VAX-MIPS, with benchmarks normalized such that the 11/780 was 1.00. These timings don't necessarily (and likely not) compare directly to the MIPS published in the 1960's, but mostly that wasn't important. For purchase decisions, it is only necessary to compare against machines being sold at the time. It wasn't until SPEC that we had benchmarks that represented real problems that people wanted done. Gah4 (talk) 23:27, 11 August 2016 (UTC)
- I have to agree that the current table is highly suspect and not at all useful. Let me cite a few examples. i7-4770K is a 3.5-3.9GHz part, with four cores (plus SMT). Each core as a theoretical maximum can dispatch four micro-ops per cycle, which would be the best-case MIPS as far as I can tell. So 3,900 million cycles/sec * 4 instructions/cycle * 4 (cores) = 62,400 MIPS. The actual result seems to be based on the idea that the Haswell cores have eight potential instruction execution ports (Port 0 = ALU/Shift, Port 1 = ALU/LEA, Port 2 & 3 = Load/Store, Port 4 = Store data, Port 5 = ALU/Shift/256b vector, Port 6 = ALU/Shift/Branch, and Port 7 = Store address) -- see https://i.stack.imgur.com/zXXcA.png as an example block diagram. So if you assume eight ports per cycle, at 3.9GHz you have a theoretical maximum of 124,800 MIPS. But even that falls short of the reported 133,740 MIPS, which is derived by taking 3900 (MHz = cycles/sec) * 34.29 (D IPS/cycle), with no data on where D IPS/cycle even came from. The problem is, under absolutely no circumstance could the i7-4770K actually fill up every port, every cycle -- it decodes four instructions per clock, and dispatches four u-ops per clock. It's a 4-wide superscalar design, not "8-wide plus some extra".
- I wanted this page to have some useful numbers, so I could maybe look at how much relative performance has increased since the 286 or 386 of my youth, as an example. Instead, I find nonsensical and arbitrary numbers based on who knows what fuzzy math. As an example of how bad this gets, the i7-5960X is listed as having 3000 MHz and 79.4 D IPS/cycle, yielding 238,310 MIPS. As someone who has written about and reviewed processors for many years, I can say with certainty that the 3GHz i7-5960X will never be twice as fast as a 3.9GHz i7-4770K, and per core at equivalent clocks it's certainly not going to be 131.3 percent faster (79.4 / 34.29 = 131.3). Yes it has twice as any cores but each core is clocked lower.
- If we're going to go off theoretical numbers, fine, but then use the correct theoretical numbers. i7-5960X would be 8 (cores) * 3500 cycles/sec * 4 instructions / cycle = 112,000 MIPS, assuming it's running at max turbo and fully loading every dispatch each clock. Or 96,000 IPS if you want to use the base 3GHz clock. Alternatively, if you want to base the numbers off real-world values, then use proper real-world values. Here are some real numbers I published [1], and here are some more [2]. (Sadly, I don't have numbers going back to some of the older parts. We could go with AnandTech or some other site as well.) The point being, real-world results don't correlate with these MIPS numbers at all, and theoretical MIPS numbers don't agree either. Ergo, these reported MIPS values are basically fantasy land results. Which was sort of the problem with people trying to compare MIPS in the first place and why we got away from that, but it would still be nice to have some way of estimating relative performance for wildly different eras of computer. Jarredwalton (talk) 02:36, 14 December 2016 (UTC)
Intel 8035/8039/8048 entry is wrong
editThese are 8-bit microcontrollers from the MCS-48 family introduced in 1976. They are not six times faster than the VAX 11/780. The idea they do 6 MIPS is absurd and false. They're clocked at 6Mhz, which is not the same thing. The "source" for this claim is just an advertisement that cites clock rate. 107.141.160.161 (talk) 16:53, 9 August 2016 (UTC)
Dhrystone
editThe table seems to indicate that the Dhrystone benchmark was run on machines from the Univac I through the newest Intel multicore processor. Is this really true? Gah4 (talk) 09:13, 13 August 2016 (UTC)
- Absolutely not. The first version of the Dhrystone was released in 1984 (IIRC). Many of the machines listed predate 1984, and were decommissioned by the time Dhrystone was released, so it's impossible to have run Dhrystone on them (and hobbyists running Dhrystone on a poorly written simulator of questionable accuracy isn't credible). I also suspect the MIPS ratings for those early machines may have been raw MIPS ratings, so they're not comparable to Dhrystone. Additionally, some of the early computers, microcomputers, and microcontrollers are so lacking in capability, it would have been impossible to run Dhrystone on them in the first place. The table isn't useful because it confuses what IPS is. Is it raw IPS? Or relative IPS? How can raw IPS be made comparable to relative MIPS? How can relative IPS, made by half a dozen different benchmarks or implementations of the same benchmark be comparable? The table ignores all of these questions and is merely a collection of arbitrary MIPS ratings. L9G45AT0 (talk) 08:10, 14 August 2016 (UTC)
- Probably Dhrystone was released for some of the CPUs that where already out at that time, but probably not for anything older than the Intel 8080. For the 8080: it probably wasn't much in use anymore in 1984, but many silblings of it where, e.g. the Zilog Z80 which was backwards compatible to the Intel 8080 and sold much longer for Desktops as the 8080 (the 8080 was produced until 1990 according to Wikipedia, but at that time probably only for embedded systems). --MrBurns (talk) 14:40, 6 February 2019 (UTC)
Multiprocessor MIPS
editThe MIPS ratings for systems with multiple processors appear to be either measured by running multiple instances of a benchmark on each processor/core, or by multiplying the MIPS rating of one processor/core by the number of processors/cores in the system. Other entries appear to add together the MIPS ratings of several processors. Only the first method, running multiple instances of a benchmark on each processor/core is valid; and when this is done, it needs to stated that what is measured is throughput. Given that other entries in the table are not about throughput, having some entries listing throughput and others not, is wrong, confusing, and useless. Should the throughput ratings be removed? L9G45AT0 (talk) 08:31, 14 August 2016 (UTC)
External links modified
editHello fellow Wikipedians,
I have just modified 2 external links on Instructions per second. Please take a moment to review my edit. If you have any questions, or need the bot to ignore the links, or the page altogether, please visit this simple FaQ for additional information. I made the following changes:
- Added
{{dead link}}
tag to http://www.datasheetarchive.com/dlmain/Datasheets-112/DSAP0049295.pdf - Added
{{dead link}}
tag to http://www.datasheetarchive.com/dlmain/Datasheets-13/DSA-246134.pdf - Added archive https://web.archive.org/web/20160125154636/http://cgfm2.emuviews.com/txt/p16tech.txt to http://cgfm2.emuviews.com/txt/p16tech.txt
- Added
{{dead link}}
tag to http://www.datasheetarchive.com/dlmain/Datasheets-13/DSA-246134.pdf - Added
{{dead link}}
tag to http://www.segatech.com/technical/saturnspecs/ - Added archive https://web.archive.org/web/20160305063757/http://www.segatech.com/archives/january1998.html to http://www.segatech.com/archives/january1998.html
- Added
{{dead link}}
tag to http://findarticles.com/p/articles/mi_m0CGN/is_3751/ai_55817127 - Added
{{dead link}}
tag to http://www.segatech.com/technical/saturnspecs/
When you have finished reviewing my changes, you may follow the instructions on the template below to fix any issues with the URLs.
This message was posted before February 2018. After February 2018, "External links modified" talk page sections are no longer generated or monitored by InternetArchiveBot. No special action is required regarding these talk page notices, other than regular verification using the archive tool instructions below. Editors have permission to delete these "External links modified" talk page sections if they want to de-clutter talk pages, but see the RfC before doing mass systematic removals. This message is updated dynamically through the template {{source check}}
(last update: 5 June 2024).
- If you have discovered URLs which were erroneously considered dead by the bot, you can report them with this tool.
- If you found an error with any archives or the URLs themselves, you can fix them with this tool.
Cheers.—InternetArchiveBot (Report bug) 04:04, 24 May 2017 (UTC)
External links modified
editHello fellow Wikipedians,
I have just modified one external link on Instructions per second. Please take a moment to review my edit. If you have any questions, or need the bot to ignore the links, or the page altogether, please visit this simple FaQ for additional information. I made the following changes:
- Added archive https://web.archive.org/web/20141009144357/http://www.jcmit.com/cpu-performance.htm to http://www.jcmit.com/cpu-performance.htm
- Added
{{dead link}}
tag to ftp://137.208.3.70/pub/lib/info/dec/alpha-infosheet.ps.Z
When you have finished reviewing my changes, you may follow the instructions on the template below to fix any issues with the URLs.
This message was posted before February 2018. After February 2018, "External links modified" talk page sections are no longer generated or monitored by InternetArchiveBot. No special action is required regarding these talk page notices, other than regular verification using the archive tool instructions below. Editors have permission to delete these "External links modified" talk page sections if they want to de-clutter talk pages, but see the RfC before doing mass systematic removals. This message is updated dynamically through the template {{source check}}
(last update: 5 June 2024).
- If you have discovered URLs which were erroneously considered dead by the bot, you can report them with this tool.
- If you found an error with any archives or the URLs themselves, you can fix them with this tool.
Cheers.—InternetArchiveBot (Report bug) 14:22, 26 July 2017 (UTC)
External links modified
editHello fellow Wikipedians,
I have just modified 8 external links on Instructions per second. Please take a moment to review my edit. If you have any questions, or need the bot to ignore the links, or the page altogether, please visit this simple FaQ for additional information. I made the following changes:
- Added archive https://web.archive.org/web/20150609205112/http://maben.homeip.net/static/S100/zilog/z8000/Zilog%20Z8000%20reference%20manual.pdf to http://maben.homeip.net/static/s100/zilog/z8000/Zilog%20Z8000%20reference%20manual.pdf
- Added archive https://web.archive.org/web/20150609205112/http://maben.homeip.net/static/S100/zilog/z8000/Zilog%20Z8000%20reference%20manual.pdf to http://maben.homeip.net/static/s100/zilog/z8000/Zilog%20Z8000%20reference%20manual.pdf
- Added archive https://web.archive.org/web/20141006111247/http://www.ti.com/lit/ds/symlink/tms320ss16.pdf to http://www.ti.com/lit/ds/symlink/tms320ss16.pdf
- Added
{{dead link}}
tag to https://github.com/mamedev/mame/tree/master/src/mame/drivers/namcos21.c - Added
{{dead link}}
tag to https://github.com/mamedev/mame/tree/master/src/mame/drivers/namcos21.c - Added archive https://archive.is/20130625223553/http://alacron.com/index.php?src=gendocs&ref=Inteli860_basedBusBoardsFT_200_VME&category=news to http://alacron.com/index.php?src=gendocs&ref=Inteli860_basedBusBoardsFT_200_VME&category=news
- Added archive https://web.archive.org/web/20141006111247/http://www.ti.com/lit/ds/symlink/tms320ss16.pdf to http://www.ti.com/lit/ds/symlink/tms320ss16.pdf
- Added
{{dead link}}
tag to https://github.com/mamedev/mame/tree/master/src/mame/drivers/gal3.c - Added archive https://archive.is/20130625223553/http://alacron.com/index.php?src=gendocs&ref=Inteli860_basedBusBoardsFT_200_VME&category=news to http://alacron.com/index.php?src=gendocs&ref=Inteli860_basedBusBoardsFT_200_VME&category=news
- Added archive https://web.archive.org/web/20141006121958/http://www.microchip.com/stellent/idcplg?IdcService=SS_GET_PAGE&nodeId=2018&mcparam=en020144 to http://www.microchip.com/stellent/idcplg?IdcService=SS_GET_PAGE&nodeId=2018&mcparam=en020144
- Added archive https://web.archive.org/web/20110719103301/http://www.eeejournal.com/2009/12/arm11-vs-cortex-a8-vs-cortex-a9.html to http://www.eeejournal.com/2009/12/arm11-vs-cortex-a8-vs-cortex-a9.html
When you have finished reviewing my changes, you may follow the instructions on the template below to fix any issues with the URLs.
This message was posted before February 2018. After February 2018, "External links modified" talk page sections are no longer generated or monitored by InternetArchiveBot. No special action is required regarding these talk page notices, other than regular verification using the archive tool instructions below. Editors have permission to delete these "External links modified" talk page sections if they want to de-clutter talk pages, but see the RfC before doing mass systematic removals. This message is updated dynamically through the template {{source check}}
(last update: 5 June 2024).
- If you have discovered URLs which were erroneously considered dead by the bot, you can report them with this tool.
- If you found an error with any archives or the URLs themselves, you can fix them with this tool.
Cheers.—InternetArchiveBot (Report bug) 12:37, 14 November 2017 (UTC)
Operations per Second / Instructions per Second
editMOPS (Million Operations Per Second) refers to this article, however, the acronym is not mentioned here. According to bores.com one instruction in a certain processor can do several operations: "two arithmetic operations (an add and a multiply), three memory accesses (two reads and a write), one floating point register update, three address pointer increments". Google also find the meaning "Mega Operations Per Second" for MOPS.
Since IPS, KIPS and GIPS are mentioned in this article, I further wonder whether there are also OPS, KOPS and GOPS? The book "Programming Multicore and Many-core Computing Systems" by Sabri Pllana, Fatos Xhafa, 2017, mentions KOPS (Kilo Operations Per Second). GOPS (Giga Operations Per Second) is found, e.g., in "Handbook of Multimedia Computing" by Borko Furht, 1999. OPS (Operations Per Second) without quantifier prefix seems to be less common. I have found it at least in "Advanced algorithms and architectures for signal processing III" - a proceedings from 1988.
Once all acronyms are explained here, the pages OPS, KOPS and GOPS might get a link to this article, too.--2001:638:A0A:1192:ED2E:FABF:906C:61B7 (talk) 08:50, 14 February 2019 (UTC)
- Well, it is worse than that. MIPS, despite the meaning of the acronym, is generally considered a benchmark index. That is, one compares the speed of a processor on a specific benchmark program (or set of programs) and scales the MIPS value accordingly. That is also reasonably often done for FLOPS, (MegaFLOPS, GigaFLOPS, etc.). In the floating point case, since many algorithms have about the same ratio of add/subtract:multiply:divide, it works pretty well. MIPS not quite a well, but sometimes close enough. It is less obvious how to count memory access operation, or index register updates that are part of an instruction. I would think the OPS values would also be benchmark values, but I don't remember seeing them used. Gah4 (talk) 20:16, 14 February 2019 (UTC)
The Gibson Mix
editMacrakis: I've re added the Gibson Mix weights as a collapsed table. This was a widely use metric in the early years of scientific computing and is referenced from several other articles. In collapsed form it doesn't add significant clutter.--agr (talk) 18:32, 21 March 2021 (UTC)
- Collapsed is better than not, but I still think it's unnecessary detail in this article. I'm all for documenting the history of computing (and you can see my contributions to multiple articles on that), but this seems like trivial arcana relevant to very few readers. --Macrakis (talk) 18:56, 21 March 2021 (UTC)
- Our articles on the IBM 700/7000 series and IBM System/360, which cover three generations of computing, use the Gibson Mix to describe the floating point performance of some 18 machines. Knowing how it was computed allows one to better understand how those numbers compare to more modern measurements. The Timeline of instructions per second section contains plenty of entries that might be considered "trivial arcana relevant to very few readers." Indeed much of the articles on computer history contain material that could be categorized so. Yet on the whole, Wikipedia is an excellent resource on computer history largely because we do include so much.--agr (talk) 20:57, 21 March 2021 (UTC)
- I'm not saying that it's unimportant historically, just that it doesn't seem to make sense here: "unnecessary detail in this article". Probably the best solution is to have a separate article on the Gibson Mix as a benchmarking tool. After all, Whetstone, which is still used, isn't documented in detail in this article. Heck, even in its own article, there isn't enough detail given to reproduce it. --Macrakis (talk) 23:43, 21 March 2021 (UTC)
- A separate article is not an unreasonable suggestion, however the notability bar is higher for a separate article. The references I've found so far are brief. Instruction mix might be a better topic, incorporating Gibson and some others. Right now there seem to be a surfeit of overlapping articles, including Instructions per cycle and Cycles per instruction, and I do not want to add unnecessarily. I'll look into it further.--agr (talk) 15:58, 22 March 2021 (UTC)
- The Doduc benchmark was also used, and included in the SPEC benchmark suite.
- IMHO, both should not be part of this article. Poil (talk) 01:37, 4 August 2024 (UTC)
- A separate article is not an unreasonable suggestion, however the notability bar is higher for a separate article. The references I've found so far are brief. Instruction mix might be a better topic, incorporating Gibson and some others. Right now there seem to be a surfeit of overlapping articles, including Instructions per cycle and Cycles per instruction, and I do not want to add unnecessarily. I'll look into it further.--agr (talk) 15:58, 22 March 2021 (UTC)
- I'm not saying that it's unimportant historically, just that it doesn't seem to make sense here: "unnecessary detail in this article". Probably the best solution is to have a separate article on the Gibson Mix as a benchmarking tool. After all, Whetstone, which is still used, isn't documented in detail in this article. Heck, even in its own article, there isn't enough detail given to reproduce it. --Macrakis (talk) 23:43, 21 March 2021 (UTC)
Please make the table sort-able by CPU architecture
editIf i only want to see the development of x86 CPUs and their MIPS computation power, then this is at the moment not possible, because the table is not sortable by CPU architecture. The table could be improved by separating the CPU model from the architecture and putting the architecture in its own columns. 84.158.123.253 (talk) 18:36, 18 September 2023 (UTC)