- Single core and thread performance
- Multithreaded CPU performance (Multiple threads on one core)
- Multicore CPU performance (1 thread per core)
- GPU performance
- Operating system
- RAM quantity
- CPU brand and name
- GPU brand and name
- System name (hostname)
This bench is more accurate on lower-end systems running Core. High end systems may achieve very fluctuating results.
- Your data (only listed above) may be stored on an external server.
- Your data uploaded to the external server (only listed above) belongs to TriTech for any fair use such as:
- Making tables, graphs, or charts featuring your data.
- Readjusting the program according to your data.
- Publishing your data publicly unassociated with your system name.
- Storage on any device owned by TriTech.
- Any other use considered fair.
- If you do not wish for your data to be used any of the cases above, you may not use CoreBench.
- If your data (in the list above) is collected by CoreBench you may not request its deletion, as by using CoreBench you agree to the terms above.
- Any information not listed above will not be recorded. If it is, you have all right to request its deletion.
- You have all right to request the data related to your system from our servers at [email protected], and if it is stored you will receive it as soon as possible, if you format the email in the following fashion:
-
- To: [email protected]
- Subject: CoreBench Server Data Request
- Content: This is a request for the data for [INSERT HOSTNAME HERE].
- No sensitive data is collected by this program.
- Download version
3.10.14
+ of Python. - Download files
main.py
,colours.py
, andrequirements.txt
- Put them all in the same directory.
- Enter this directory and run
pip install -r requirements.txt
- run
sudo apt install neofetch
- Then run
python3 main.py
- Linux portable image coming soon™
- dmg will never exist
- WINDOWS IS CURRENTLY UNSUPPORTED
- Coming soon™
Users running on Windows through Python interpreters may run into issues such as absurdly low scores, much longer loading times, and inefficient hardware utilization. The multicore method used in this program is NOT compatible with Windows. Higher end systems on Windows may achieve low scores compared to Linux users, as the benchmark was designed for Linux. If you desperately want to run this and get accurate results, I guess you could make a tiny partition for dual booting a Linux distro.
- As of CoreBench version 1.0.0, there is no storage of data. There may be in future updates when a simple cloud solution is found
- This program lacks the ability to run GPU tests, it is currently limited to CPU single core, multi core, and multi thread benchmarks
- This program lacks testing data, so what can be considered "good" and "bad" has not been determined yet, so scores are currently arbitrary. Feel free after executing this program to send me your info and scores at [email protected]
- During multicore and multithread tests, multiple lines of text will show for the progress of the different operations
- Changed RAM to calculate more accurately by showing two decimal places
- Fixed misnaming of "totalTime" variable in the single core test
- Optimised to run faster and obtain more accurate scores representative of the system
- Fixed stage 3 single core test percentage going up in multiples of 2 instead of 1
- Fixed stage 2 multicore/multithread test progress showing one decimal place instead of only one significant figure
- Balanced single core scores to be higher and more representative of the system's power
- Added full CPU performance test
- Improved readability of test select menu
- Renamed "info.txt" to "corebenchinfo.txt" as the name was too generic, and removal of this file could cause issues if the file is for other applications
- Added all test results to full CPU performance test results screen
- Added checks for administrator/root permissions on startup
- Aimed to fix a few small issues with text formatting and RAM calculations
- Added specific Linux distro identification to make recording results easier
- Full CPU test no longer flashes results from each individual test
- Full CPU test results are now stored to file
corebenchinfo.txt
- Added a timer cooldown between successive tests on the full CPU test
- Fixed multithread test results being bottlenecked by I/O operations and percentage calculations
- Fixed multithread epilepsy effect
- Fixed a very intellectual bug that meant that the script wouldn't correctly check for admin privileges on Linux/MacOS (totally didn't use os.geteuid() instead of os.getuid())
- Did the same fix to the multiprocessing test as the multithread test.
- Added compatibility with CPU temperature monitoring. This project may require lm_sensors in the future.
- Removed the 4 decimal place CPU clock speed response and rounded it to 2 decimal places as is standard.
- Updated core count to count physical CPU cores, and added a seperate info tab for threads - ruining my colour scheme >:(
- Neofetch is now a dependency of CoreBench. It is utilised to get the colour of your distro.
- Added support for the Windows-coloured name in the "OS Name" tab (despite there being no Windows support)
- Added more loading messages.
- Added an activation screen when grabbing "essential" variable data.
- The multithread test now utilises 12 threads.
- The multicore test now utilises 6 cores.
-
Dynamic mode - adjusts the performance tests based on your hardware. Multicore and multithread tests will match the number of cores and threads your CPU has. It's a test aimed at CPU efficiency (not power efficiency, core and thread utilisation efficiency), so comparing dynamic mode scores between 2 CPUs with different core/thread counts is not advised. (The default test runs on 6 cores and 12 threads.) Your scores will not be submitted when recorded in dynamic mode. Press [CTRL] + [C] when CoreBench is starting up (before it shows
Activating...
) to enter dynamic mode. -
CoreBench 104 and 105 beta only ran on 4 cores and 4 threads. This has been adjusted for realistic performance monitoring, now running on 6 cores and 12 threads.
-
Various stability fixes.
-
Various score re-balancing (comparing scores between 104 and 105 is no longer valid, and these changes explain why I haven't made the database yet)
-
Scores in dynamic mode are based on the ratio of cores/threads to 6 and 12.
-
Dynamic mode was finished on 05/02/2025.
- Changed method of grabbing name to getpass.getuser() instead of pwd.
- Single core test was not guaranteed to be isolated to a single core. The single core test ignores hyperthreading, and runs on one core on one thread. This was hastily added after its discovery just after 105.
- As you can see, all the CPU cores activate at the same time, indicating that Python is using more than 1 core, as this is a 1 core per thread processor.
- In the new 1.0.6 patch, only CPU 0 is fully utilised. The rest are supposed to be idling, but this is a Chromebook processor. (Thank you avale for being smarter than me!!!)
Yes, this example is running on Windows. This does not mean Windows support is coming. I think. Maybe I should add a multiplier for Windows machines, or make a seperate database for Windows machines or... no.
- Single core test doesn't take as long anymore.
- The percentage shows to one significant figure rather than the nearest integer to prevent I/O bottleneck.
- Moved the benchmark process code for multicore test into a main check.
- The reason why it isn't compatible with Windows is now known. Windows cannot "pickle" (initiate for use in multicore) local functions (functions defined inside of functions). I don't want to change this especially since I am so far into development, and it will mess up the few consistencies that exist in my spaghetti code. Once again, my totally nonexistent dreams for CoreBench on Windows are destroyed. Maybe I'll make one for Windows. I hate Windows so much man. Why can't it just work?
- Added one additional point to all test scores. Or did I?
- Another reason that CoreBench runs badly on Windows has been discovered (other than overhead). Due to Windows' Multilevel Feedback Queue process scheduling method, CoreBench is treated like a background process, and punished for being demanding. Linux uses the Completely Fair scheduling method, which is why scores are so much higher and more definitive.
It takes an extra 8 seconds without high priority. This was WITH background processes running in both tests. (Brave browser idling)
Despite the tab saying "CoreBench105.py", it is actually CoreBench 1.0.7.
- Just realised it still says (c) TriTech 2024, meaning the copyright is outdated. That ain't good. Updated to (c) TriTech 2025 as of 7th February 2025.
- Added version no. and dynamic mode info to the corebenchinfo.txt file. A new set of results will be written to corebench.txt when you run a full CPU test.
- Added a set of data in .csv format called "corebenchdata.csv", created when not present and written to with each non-dynamic mode test result.
- Full CPU test now produces a visual bar chart showing performance vs your system's overall average, called "corebenchdata.png"
- Added "test commands" due to the growing number of tests.
"sc"/"st" - Single core test
"mc" - Multicore test
"mt" - Multithread test
"nic"/"n" - Internet speed test
"fullc"/"fc" - Full CPU test
Add "-d" to the end of your command to run the test in dynamic mode. The [CTRL] + [C] shortcut has been removed.
- Completely reworks the single core algorithms.
- Stage 1 is now a gravity and collision detection simulator.
- Stage 2 simulates simple trigonometric calculations in quick succession and vector maths.
- Stage 3 calculates floating point performance for the single core through lots of demanding vector calculations.
- Prettified single core text layout and colours.
- Sorted out code order issues.
- Added credits to readme.
- Fixed title header layout on readme.
- Fixed a bug when the algorithms in multicore and multithread would not be evenly spread out, the first algorithm would run once, and the second for the remaining number of cores/threads.
- Changed the multicore and multithread algorithms to be nerfed versions of the single core algorithm. The algorithms used in versions 1.1.1 and below are no longer present.
- Issues with this version: scores are not balanced. Version 2.0.0 will be released once scores are fully balanced.
- Thread algorithms have half the intensity of multicore algorithms, and multicore algorithms have a tenth of the intensity of single core algorithms.
- Fixed I/O bottlenecks by using a buffer and printing a list instead of multiple strings in single core.
- Removed a little bit of boilerplate code.
- On average after these optimisations CPUs will score 5% higher.
- GFLOP performance of your CPU is now calculated differently, using the standard deviation of each datapoint from the mean and calculation of Z-score to deliver a more precise value.
- GFLOP performance is now delivered to 2 decimal places.
- Fixed RAM calculation to not show 2 decimal places, and show quantity of physicall RAM installed in your system as advertised.
- Fixed RAM showing incorrectly.
- Fixed clock speeds showing incredibly high numbers.
- Allowed CTRL+C to be used to cancel an ongoing test
- Added new commands "quit", "exit", "clear"
- You can now add "*x" before your command (e.g.
*2 sc
) to run your testx
number of times. - Various stability fixes and improvements.
- Shows the graph in default image viewer once the full CPU test is complete.
- Removed AVX-512 estimation.
- Added a runner file that creates the CoreBench environment for ideal circumstances on startup.
- To use, just
chmod +x corebench.sh
and./corebench.sh
. - Readjusted multicore score calculation to be more balanced. The score is almost at a point that I can call it balanced.