this post was submitted on 02 Dec 2023
5 points (100.0% liked)

Advent Of Code

766 readers
1 users here now

An unofficial home for the advent of code community on programming.dev!

Advent of Code is an annual Advent calendar of small programming puzzles for a variety of skill sets and skill levels that can be solved in any programming language you like.

AoC 2023

Solution Threads

M T W T F S S
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25

Rules/Guidelines

Relevant Communities

Relevant Links

Credits

Icon base by Lorc under CC BY 3.0 with modifications to add a gradient

console.log('Hello World')

founded 1 year ago
MODERATORS
 

Is there a way to measure performance without depending on the hardware, i.e. two entirely different computers get the same score for the same code?

I could probably run the program on a server or something, but something local feels more reliable.

top 12 comments
sorted by: hot top controversial new old
[–] FuzzChef@feddit.de 8 points 11 months ago (1 children)

Yes, you can consider the algorithmic complexity of your code, which is independent of any hardware.

[–] Sekoia@lemmy.blahaj.zone 2 points 11 months ago (1 children)

Sure, but that makes a lot of optimizations nonexistent (e.g. cloning the input on an O(n) algorithm is "free")

[–] damium@programming.dev 4 points 11 months ago

You don't need to use big-O. You can calculate the full complexity in algebraic notation. It's just a lot more work as you don't get to discard terms.

[–] stifle867@programming.dev 4 points 11 months ago (2 children)

Im theory you could try counting CPU cycles or something analogous, or algorithmic complexity as the other commenter mentioned. You could also try to measure it in comparison to different code.

Outside of that, and in any practical sense, no you can't. Performance measurements are dependent on the machine as much as the software.

If a car is hardware, and the driver is software, how would you measure the performance of the driver in the different cars? The only way I can think of is if you had 2 different drivers and could compare their times in both cars. If driver 1 is 2x as fast in car 1, and 2x as fast in car 2, you could say driver 1 has a score 2x higher than driver 2.

[–] FuzzChef@feddit.de 2 points 11 months ago

CPU cycles depend on the instruction set of the hardware. This would also require compilation without any optimization to avoid even software dependency.

[–] Sekoia@lemmy.blahaj.zone 1 points 11 months ago (1 children)

One option could be to emulate a full CPU and run it on that, and count the cycles on that. One issue is linking/syscalls. Maybe compiling to smth like WASM could work?

[–] stifle867@programming.dev 1 points 11 months ago (1 children)

I would be interested to hear if you get far down that road. It sounds infinitely more difficult than running code and timing it.

Are you able to expand what problem lead you to this question (out of curiosity)?

[–] Sekoia@lemmy.blahaj.zone 1 points 11 months ago (1 children)

Friend and I are comparing times, but since he uses Jai, I can't compile his.

[–] stifle867@programming.dev 1 points 11 months ago

As an alternative could he compile your program?

[–] vole@lemmy.world 2 points 11 months ago* (last edited 11 months ago) (1 children)

perf and valgrind might be good places to start. Although, some programs aren't going to have the exact same executed instruction count between runs, and it's possible that executed instruction count can depend on the exact CPU that's running. You can probably mitigate the latter by running valgrind and the program inside of QEMU.

[–] Sekoia@lemmy.blahaj.zone 1 points 11 months ago

Thank you! That's exactly the kinda thing I was looking for!

[–] dns@aussie.zone 1 points 11 months ago

I believe everyone gets different input and needs to produce a different result. There can be multiple solutions. Do you process as you are going, or do you parse and build a data structure to process later so you loop through the results multiple times.