-
Notifications
You must be signed in to change notification settings - Fork 10.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Random seed possible problems. #8593
Comments
the second time I ran llama.cpp with the same seed it told me the same story. so I don't understand why, when I did not specify the seed, the log shown the seed and when I entered it manually instead told me a different story, then run again with the same seed manually, it told the same story. I see 2 possibilities:
|
The CUDA version introduces some randomness even with the same seed. |
I am using CPU ONLY. |
Why the -ngl 999 then? |
This is weird because both of these possibilities don't seem to be what's happening, which means it might be hard to debug. llama.cpp/examples/main/main.cpp Lines 188 to 194 in 87e397d
This rules out non-determinism of the backend. EDIT: I can also reproduce this problem on my machine (with CPU-only inference). It's a very weird behavior. |
AHA! The sampling seed in This seems to fix it: diff --git a/examples/main/main.cpp b/examples/main/main.cpp
index a0d817b1..ceed4ce5 100644
--- a/examples/main/main.cpp
+++ b/examples/main/main.cpp
@@ -187,6 +187,7 @@ int main(int argc, char ** argv) {
if (params.seed == LLAMA_DEFAULT_SEED) {
params.seed = time(NULL);
+ sparams.seed = params.seed;
}
LOG_TEE("%s: seed = %u\n", __func__, params.seed);
It seems like BOTH of theses guesses were true after all. |
The CUDA backend is deterministic as in the results for the same input parameters will have the same output logits. However, if you use >1 slots or prompt caching on the server then the input parameters can vary and thus the outputs will vary too. |
That's good to learn! Thank you. |
|
When not specified, the sampling seed is random. Line 82 in 22f281a
|
@compilade so.. I don't understand: what was happening before? why the seed printed when it was random didn't work?
so why did it work the second time? luck? |
I tried to figure out why using >1 slot does not produce deterministic results when doing parallel requests. Do you know why it is not possible to get deterministic output when making parallel requests? |
Because floating point arithmetic is not commutative. You only get bit-for-bit identical results if you do the exact same operations in the exact same order. But the whole reason why >1 slots is faster is that you do not do that but instead change the kernels depending on how many slots are currently in use. Also the positions of individual sequences within the unified KV cache will be different. |
See also ggerganov/whisper.cpp#1941 (comment). But when the order is exactly the same, the output between runs can still be exactly the same, even with parallel sequences, as I've seen in #6122 (comment). |
I see. Thanks @compilade @JohannesGaessler So, running higher-precision models with a higher-precision KV cache would alleviate this effect, right? |
No, even with 16 bit precision you will still run into this issue because the condition numbers of the weight matrices can be arbitrarily large. |
I did some quick tests for the sake of curiosity with "Phi-3-mini-4k-instruct-fp16.gguf" vs "Phi-3-mini-4k-instruct-q4.gguf". Bottom Line: As you stated, JohannesGaessler, both are nondeterministic for the vast majority of cases. Even with cherry-picked settings attempting to minimize non-determinism (i.e., "-b 1 -ub 1 -nocb" with cache_prompt=false), I only managed to get a few prompts on the fp16 model to return deterministic output. I used "-np 10", i.e. 10 slots and 10 parallel requests. |
Hey Johannes, is there any test cases for CUDA bit-exact determinism for the project? |
There are multiple in the server tests. But they're commented out since they're failing on master. |
This issue was closed because it has been inactive for 14 days since being marked as stale. |
I ran llama.cpp (latest version) with these parameters:
llama-cli --seed 1721414715 -c 4096 -m /content/$m -t $(nproc) -ngl 999 -p "User: Hi\nBot:Hi\nUser: {prompt}\nBot:"
and in the log I read the seed was: 1721414715
so at the next run I used --seed 1721414715 but the story was a different one.
why?
The text was updated successfully, but these errors were encountered: