-
Notifications
You must be signed in to change notification settings - Fork 2.9k
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
[Bug]: Input text is included in both System and User context #1203
Comments
Can you share my_test pattern, please? |
oh, I can replicate. @scross01 {{input}} is appended if it's not in the pattern, and then replaced with the actual user input. The previous behaviour was to simply append the pattern with the user input. |
For reference this is the prompt file You are highly skilled document summarization AI.
# OUTPUT:
Summarize the content in a single paragraph with no more than 100 words.
# INPUT: |
ah, I think I have found it. I will get a patch in later today. |
@scross01 can you try the latest build and report back? |
@mattjoyce I'm still getting the input content in both the system and user prompt. Installed the latest from source $ go install github.com/danielmiessler/fabric@latest
$ fabric --version
v1.4.123 $ echo "This is a another test" | fabric -p my_summarize --dry-run
Dry run: Would send the following request:
System:
You are highly skilled document summarization AI.
# OUTPUT:
Summarize the content in a single paragraph with no more than 100 words.
# INPUT:
This is a another test
User:
This is a another test
Options:
Model: llama3.2:3b
Temperature: 0.700000
TopP: 0.900000
PresencePenalty: 0.000000
FrequencyPenalty: 0.000000
empty response |
@scross01
|
Nope, sorry to say it's still not working for me. I've tried using two methods of installing just to double check, and get the same result with both $ go install github.com/danielmiessler/fabric@latest
go: downloading github.com/danielmiessler/fabric v1.4.124
$ fabric --version
v1.4.124 $ git clone https://github.com/danielmiessler/fabric.git
$ cd fabric
$ go build .
$ ./fabric --version At the time of testing git log
commit 6d00405eb66e7c232e8c558407587d190fa4ed13 (HEAD -> main, tag: v1.4.124, origin/main, origin/HEAD)
Author: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Date: Sat Dec 21 14:01:47 2024 +0000
Update version to v1.4.124 and commit Result from both installs:
|
@scross01 sorry, you were sort of right to begin with, it is cause by the implementation of the template system. What we have now is system(context, pattern (vars, input (vars)))) |
So my proposal is to structure the initial messages like this. @eugeis this is a departure from the original fabric message structure, but I think it will not have any detrimental effect. My testing works fine. |
Hi @mattjoyce, thank you for the great visualization! I believe the system role plays a much more significant part in certain models. While it might work fine for a single message and response, in the context of session-based conversations, we risk losing the clarity and impact of the initial prompt. What are your thoughts? |
@eugeis , I can do this tomorrow, and then I will be away for a bit. |
What happened?
With the default settings I'm getting the original content that is piped to fabric included in both the system prompt and the user prompt, this can be seen when using the
--dry-run
option:echo "This is a test" | fabric -p my_test --dry-run
Expected output should only include the input
this is a test
in the User content, and not repeated in the System prompt.I've found that the duplication of the user content in the system prompt leads to very poor prompt adherence, and also has the side effect of doubling required model context window size.
Cause of the issue seems to be here in the pattern
applyVariables
which is forcing the{{input}}
to be included. Commenting out this block fixes the problem, but breaks the--raw
option which does need the pattern and input combined.Version check
Relevant log output
No response
Relevant screenshots (optional)
No response
The text was updated successfully, but these errors were encountered: