Skip to content

Commit

Permalink
Fix final answer with extra meaningless symbol (#2676)
Browse files Browse the repository at this point in the history
* Fix final answer with extra meaningless symbol

Signed-off-by: Heng Qian <[email protected]>

* Add a new unit test to verify the case of final answer with quotes

Signed-off-by: Heng Qian <[email protected]>

---------

Signed-off-by: Heng Qian <[email protected]>
  • Loading branch information
qianheng-aws authored Jul 25, 2024
1 parent f8d6c7b commit 5ad26df
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -295,7 +295,7 @@ public static void parseThoughtResponse(Map<String, String> modelOutput, String
public static String extractFinalAnswer(String text) {
String result = null;
if (text.contains("\"final_answer\"")) {
String pattern = "\"final_answer\"\\s*:\\s*\"(.*?)$";
String pattern = "\"final_answer\"\\s*:\\s*\"(.*)\"";
Pattern jsonBlockPattern = Pattern.compile(pattern, Pattern.DOTALL);
Matcher jsonBlockMatcher = jsonBlockPattern.matcher(text);
if (jsonBlockMatcher.find()) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,14 @@ public class AgentUtilsTest {
+ "\"thought\": \"Now I know the final answer\",\n "
+ "\"final_answer\": \"PPLTool generates such query ```json source=iris_data | fields petal_length_in_cm,petal_width_in_cm | kmeans centroids=3 ```.\"\n}\n```";

private String responseForFinalAnswerWithMultilines = "---------------------```json\n{\n "
+ "\"thought\": \"Now I know the final answer\",\n "
+ "\"final_answer\": \"PPLTool generates such query \n```json source=iris_data | fields petal_length_in_cm,petal_width_in_cm | kmeans centroids=3 ```.\"\n}\n```";

private String responseForFinalAnswerWithQuotes = "---------------------```json\n{\n "
+ "\"thought\": \"Now I know the final answer\",\n "
+ "\"final_answer\": \"PPLTool generates such query \n```json source=iris_data | fields petal_length_in_cm,petal_width_in_cm | kmeans name=\"Jack\" ```.\"\n}\n```";

private String wrongResponseForAction = "---------------------```json\n{\n "
+ "\"thought\": \"Let's try VectorDBTool\",\n "
+ "\"action\": \"After checking online weather forecasts, it looks like tomorrow will be sunny with a high of 25 degrees Celsius.\"\n}\n```";
Expand Down Expand Up @@ -120,7 +128,7 @@ public void setup() {
THOUGHT,
"Unfortunately the tools did not provide the weather forecast directly. Let me check online sources:",
FINAL_ANSWER,
"After checking online weather forecasts, it looks like tomorrow will be sunny with a high of 25 degrees Celsius.\"\n}\n```"
"After checking online weather forecasts, it looks like tomorrow will be sunny with a high of 25 degrees Celsius."
);
llmResponseExpectedParseResults.put(responseForFinalAnswerInvalidJson, responseForFinalAnswerExpectedResultExpectedResult);
Map responseForFinalAnswerWithJsonExpectedResultExpectedResult = Map
Expand All @@ -144,6 +152,24 @@ public void setup() {
);
llmResponseExpectedParseResults.put(wrongResponseForAction, wrongResponseForActionExpectedResultExpectedResult);

Map responseForFinalAnswerWithMultilinesExpectedResult = Map
.of(
THOUGHT,
"Now I know the final answer",
FINAL_ANSWER,
"PPLTool generates such query \n```json source=iris_data | fields petal_length_in_cm,petal_width_in_cm | kmeans centroids=3 ```."
);
llmResponseExpectedParseResults.put(responseForFinalAnswerWithMultilines, responseForFinalAnswerWithMultilinesExpectedResult);

Map responseForFinalAnswerWithQuotesExpectedResult = Map
.of(
THOUGHT,
"Now I know the final answer",
FINAL_ANSWER,
"PPLTool generates such query \n```json source=iris_data | fields petal_length_in_cm,petal_width_in_cm | kmeans name=\"Jack\" ```."
);
llmResponseExpectedParseResults.put(responseForFinalAnswerWithQuotes, responseForFinalAnswerWithQuotesExpectedResult);

}

@Test
Expand Down Expand Up @@ -442,7 +468,7 @@ public void testExtractMethods_FinalAnswer() {
Assert.assertNull(actionInput);
Assert
.assertEquals(
"After checking online weather forecasts, it looks like tomorrow will be sunny with a high of 25 degrees Celsius.\"\n}\n```",
"After checking online weather forecasts, it looks like tomorrow will be sunny with a high of 25 degrees Celsius.",
finalAnswer
);
}
Expand Down

0 comments on commit 5ad26df

Please sign in to comment.