Skip to content
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

fix: provider the latest duckduckgo_search API #5184

Closed
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
356 commits
Select commit Hold shift + click to select a range
3808689
Fixed docstring in faiss.py for load_local (#5440)
luckyduck May 30, 2023
3659475
Removes duplicated call from langchain/client/langchain.py (#5449)
patrickkeane May 30, 2023
c140214
`encoding_kwargs` for InstructEmbeddings (#5450)
Xmaster6y May 30, 2023
184244a
MRKL output parser no longer breaks well formed queries (#5432)
May 30, 2023
c793a64
docs: cleaning (#5413)
leo-gan May 30, 2023
f702d0a
Added async _acall to FakeListLLM (#5439)
camille-vanhoffelen May 30, 2023
53e9a99
Feat: Add batching to Qdrant (#5443)
kacperlukawski May 30, 2023
f30b403
Update psychicapi version (#5471)
Ayan-Bandyopadhyay May 30, 2023
61ce1d4
Add maximal relevance search to SKLearnVectorStore (#5430)
mrtj May 30, 2023
05771cb
add simple test for imports (#5461)
hwchase17 May 30, 2023
57f4f2c
Ability to specify credentials wihen using Google BigQuery as a data …
nsheils May 30, 2023
af6d7b0
convert the parameter 'text' to uppercase in the function 'parse' of …
ARSblithe212 May 30, 2023
efca78b
added n_threads functionality for gpt4all (#5427)
Vokturz May 30, 2023
7f85bf6
Allow for async use of SelfAskWithSearchChain (#5394)
pors May 31, 2023
6775dac
Allow ElasticsearchEmbeddings to create a connection with ES Client o…
jeffvestal May 31, 2023
b08a832
SQLite-backed Entity Memory (#5129)
JoseHervas May 31, 2023
3599b2e
py tracer fixes (#5377)
agola11 May 31, 2023
42b3024
Harrison/html splitter (#5468)
hwchase17 May 31, 2023
cc86975
Feature: Qdrant filters supports (#5446)
kacperlukawski May 31, 2023
fb3919e
Add matching engine vectorstore (#3350)
hwchase17 May 31, 2023
e188bac
code splitter docs (#5480)
hwchase17 May 31, 2023
92dc497
Bedrock llm and embeddings (#5464)
3coins May 31, 2023
73b6182
add more vars to text splitter (#5503)
hwchase17 May 31, 2023
248d57c
bump 187 (#5504)
dev2049 May 31, 2023
bf2a65d
Add Feedback Methods + Evaluation examples (#5166)
vowelparrot May 31, 2023
964c90d
Add allow_download as attribute for GPT4All (#5512)
Vokturz May 31, 2023
5a4c2d7
added DeepLearing.AI course link (#5518)
leo-gan May 31, 2023
d227c5d
Skips creating boto client for Bedrock if passed in constructor (#5523)
3coins May 31, 2023
c853ac3
Add Managed Motorhead (#5507)
softboyjimbo May 31, 2023
171b82f
Replace enumerate with zip. (#5527)
ttsugriy May 31, 2023
39d74f8
Add minor fixes for PySpark Document Loader Docs (#5525)
rithwik-db May 31, 2023
b80bbc9
docs: unstructured no longer requires installing detectron2 from sour…
MthwRobinson May 31, 2023
7231f99
Replace list comprehension with generator. (#5526)
ttsugriy May 31, 2023
0ed6ee4
Add param requests_kwargs for WebBaseLoader (#5485)
sevendark May 31, 2023
19bed37
Replace loop appends with list comprehension. (#5528)
ttsugriy May 31, 2023
3a7b2b3
[retrievers][knn] Replace loop appends with list comprehension. (#5529)
ttsugriy May 31, 2023
2c38ed4
Fix wrong class instantiation in docs MMR example (#5501)
tobiasvanderwerff Jun 1, 2023
12670d9
Add texts with embeddings to PGVector wrapper (#5500)
shenghann Jun 1, 2023
1701ae7
make BaseEntityStore inherit from BaseModel (#5478)
aditivin Jun 1, 2023
53adb8a
docs `ecosystem/integrations` update 3 (#5470)
leo-gan Jun 1, 2023
a900859
feat(integrations): Add WandbTracer (#4521)
parambharat Jun 1, 2023
3d567ca
add maxcompute (#5533)
dev2049 Jun 1, 2023
4268b84
add brave search util (#5538)
hwchase17 Jun 1, 2023
30f4a91
Corrects inconsistently misspelled variable name. (#5559)
patrickkeane Jun 1, 2023
6b174bb
Qdrant self query (#5567)
dev2049 Jun 1, 2023
58aabd6
bump 188 (#5568)
dev2049 Jun 1, 2023
4d8555b
make the elasticsearch api support version which below 8.x (#5495)
ARSblithe212 Jun 1, 2023
a8f58b2
Fix typo in docugami.ipynb (#5571)
eltociear Jun 1, 2023
927db98
Add missing comma in conv chat agent prompt json (#5573)
andrewlei Jun 1, 2023
4828a0b
Fix bedrock auth validation (#5574)
Jun 1, 2023
51290c4
Documentation fixes (linting and broken links) (#5563)
sseide Jun 1, 2023
2e0c4ab
nit (#5578)
dev2049 Jun 1, 2023
73f6953
Fix SQLAlchemy truncating text when it is too big (#5206)
wsantos Jun 2, 2023
a5a54e5
docs(integration): update colab and external links in WandbTracing do…
parambharat Jun 2, 2023
79328fc
Rm Template Title (#5616)
vowelparrot Jun 2, 2023
40ba2ea
human approval callback (#5581)
dev2049 Jun 2, 2023
be63db9
Es knn index search 5346 (#5569)
jeffvestal Jun 2, 2023
f074e30
Fix: Qdrant ids (#5515)
kacperlukawski Jun 2, 2023
a60f31e
Dev2049/add argilla callback (#5621)
dev2049 Jun 2, 2023
201fb7a
bump 189 (#5620)
dev2049 Jun 2, 2023
6a21bcd
fix chroma update_document to embed entire documents, fixes a charace…
cnellington Jun 2, 2023
7f729e5
Fix bedrock llm boto3 client instantiation (#5629)
Jun 2, 2023
6ac510e
Update Tracer Auth / Reduce Num Calls (#5517)
vowelparrot Jun 2, 2023
e6b30e9
fix import issue (#5636)
leo-gan Jun 2, 2023
3156234
feat: add `UnstructuredExcelLoader` for `.xlsx` and `.xls` files (#5617)
MthwRobinson Jun 3, 2023
76eebad
Fixed multi input prompt for MapReduceChain (#4979)
imeckr Jun 3, 2023
5a09e10
docs: `modules` pages simplified (#5116)
leo-gan Jun 3, 2023
6bd75b6
minor refactor GenerativeAgentMemory (#5315)
mbchang Jun 3, 2023
a3a8497
pref: reduce DB query error rate (#5339)
Undertone0809 Jun 3, 2023
5ca0644
Update confluence.py to return spaces between elements (#5383)
gardner Jun 3, 2023
6003ea2
Implements support for Personal Access Token Authentication in the Co…
felipeff Jun 3, 2023
978580d
Adds the option to pass the original prompt into the AgentExecutor fo…
nathan-az Jun 3, 2023
9d93b36
QuickFix for FinalStreamingStdOutCallbackHandler: Ignore new lines & …
UmerHA Jun 3, 2023
1796969
Add parameters to send_message() call for vertexai chat models (PaLM2…
khallbobo Jun 3, 2023
e4ce4cb
handle single arg to and/or (#5637)
dev2049 Jun 3, 2023
cb4fa68
docs `ecosystem/integrations` update 4 (#5590)
leo-gan Jun 3, 2023
31c3b73
nit: pgvector python example notebook, fix variable reference (#5595)
cjcjameson Jun 3, 2023
3a1c5eb
Harrison/update azure nb (#5665)
hwchase17 Jun 3, 2023
7a8e25c
Harrison/pubmed integration (#5664)
hwchase17 Jun 3, 2023
5a3f33a
removing client+namespace in favor of collection (#5610)
P-E-B Jun 3, 2023
a673535
fix: correct momento chat history notebook typo and title (#5646)
malandis Jun 3, 2023
3ef1e89
Created fix for 5475 (#5659)
rajib76 Jun 3, 2023
ee655f3
FileCallbackHandler (#5589)
mbchang Jun 3, 2023
ad53eae
refactor: BaseStringMessagePromptTemplate from_template method (#5332)
Sukitly Jun 3, 2023
3551344
Update youtube.py - Fix metadata validation error in YoutubeLoader (#…
ricardoreis Jun 3, 2023
a1f7141
Improve Error Messaging for APOC Procedure Failure in Neo4jGraph (#5547)
guangchen811 Jun 3, 2023
69af5f1
Support similarity_score_threshold retrieval with Chroma (#5655)
jiayao Jun 3, 2023
6243c32
This fixes issue #5651 - GPT4All wrapper loading issue (#5657)
bwv988 Jun 4, 2023
8ab249b
Add args_schema to google_places tool (#5680)
georgelroberts Jun 4, 2023
13e0435
Harrison/pipeline prompt (#5540)
hwchase17 Jun 4, 2023
74b48b8
Added Dependencies Status, Open issues and releases badges in Readme.…
nuhmanpk Jun 4, 2023
91514d6
SQL agent : Improved prompt engineering prevents agent guessing datab…
willsmithorg Jun 4, 2023
69e7b9b
Retitles Bedrock doc to appear in correct alphabetical order in site …
JasonWeill Jun 4, 2023
0c2a949
Update MongoDBChatMessageHistory to create an index on SessionId (#5632)
ldesousa-stf Jun 4, 2023
823cb98
Raise an exception in MKRL and Chat Output Parsers if parsing text wh…
nathan-az Jun 4, 2023
07fa1e5
refactor: extract token text splitter function (#5179)
JensMadsen Jun 4, 2023
7d503c3
sqlalchemy MovedIn20Warning declarative_base DEPRICATION fix (#5676)
kaahila Jun 4, 2023
41bbd0c
top_k and top_p transposed in vertexai (#5673)
mheguy-stingray Jun 4, 2023
a5a6f3b
bump version to 190 (#5704)
hwchase17 Jun 5, 2023
905998b
Addresses GPT4All wrapper model_type attribute issues #5720. (#5743)
bwv988 Jun 5, 2023
2b88921
docs: Added Deploying LLMs into production + a new ecosystem (#4047)
kouroshHakha Jun 5, 2023
15bb550
Adding support to save multiple memories at a time. Cuts save time by…
abhimalamkar Jun 5, 2023
0a16e7b
Cypher search: Check if generated Cypher is provided in backticks (#5…
tomasonjo Jun 5, 2023
3d08610
Zep Hybrid Search (#5742)
danielchalef Jun 5, 2023
ea99f92
Removes unnecessary backslash escaping for backticks in python (#5751)
spazm Jun 5, 2023
e35b394
Fix a typo in the documentation for the Slack document loader (#5745)
georgegeddes Jun 5, 2023
26c597d
Error in documentation: Chroma constructor (#5731)
gbrian Jun 5, 2023
108875c
Integrate Clickhouse as Vector Store (#5650)
haoch Jun 5, 2023
5db9973
Create OpenAIWhisperParser for generating Documents from audio files …
rlancemartin Jun 5, 2023
815512b
docs: `ecosystem/integrations` update 5 (#5752)
leo-gan Jun 5, 2023
51dcfaf
docs: updated `ecosystem/dependents` (#5753)
leo-gan Jun 5, 2023
e6a7e26
Add class attribute "return_generated_question" to class "BaseConvers…
felpigeon Jun 5, 2023
7789c37
Add aviary support (#5661)
waleedkadous Jun 5, 2023
7ee65e4
cohere retries (#5757)
hwchase17 Jun 5, 2023
3b631c4
Strips whitespace and \n from loc before filtering urls from sitemap …
ShelbyJenkins Jun 5, 2023
27ab3a0
Harrison/youtube multi language (#5758)
hwchase17 Jun 5, 2023
2163f62
fix markdown text splitter horizontal lines (#5625)
IlyaMichlin Jun 5, 2023
125bad3
Tracing Group (#5326)
agola11 Jun 6, 2023
304241a
Update tutorials.md (#5761)
edrickdch Jun 6, 2023
72584a3
feat: Support for `Tigris` Vector Database for vector search (#5703)
adilansari Jun 6, 2023
4848ade
Scores are explained in vectorestore docs (#5613)
berkedilekoglu Jun 6, 2023
77a03d4
bump ver 191 (#5766)
hwchase17 Jun 6, 2023
ac726e5
Use client from LCP-SDK (#5695)
vowelparrot Jun 6, 2023
a9199c1
fix ver 191 (#5784)
hwchase17 Jun 6, 2023
15c0a4f
Set Falsey (#5783)
vowelparrot Jun 6, 2023
2f9a4c6
Attribute support for html tags (#5782)
Xmaster6y Jun 6, 2023
5c374e9
support returning run info for llms, chat models and chains (#5666)
agola11 Jun 6, 2023
5f47075
fixing from_documents method of the MongoDB Atlas vector store (#5794)
P-E-B Jun 6, 2023
c78f949
Revise DATABRICKS_API_TOKEN as DATABRICKS_TOKEN (#5796)
gengliangwang Jun 6, 2023
9688727
YoutubeAudioLoader and updates to OpenAIWhisperParser (#5772)
rlancemartin Jun 6, 2023
10332e3
Base RunEvaluator Chain (#5750)
vowelparrot Jun 6, 2023
7960eb7
[Docs][Hotfix] Fix broken links (#5800)
kouroshHakha Jun 7, 2023
a09314e
Add UTF-8 json ouput support while langchain.debug is set to True. (#…
boxcounter Jun 7, 2023
d975d0c
WIP: openai settings (#5792)
hwchase17 Jun 7, 2023
a809a4a
added support for different types in ResponseSchema class (#5789)
MassimilianoBiancucci Jun 7, 2023
e110f96
fixed faiss integ tests (#5808)
bnassivet Jun 7, 2023
6e17a67
add doc about reusing MongoDBAtlasVectorSearch (#5805)
Pliman Jun 7, 2023
1c57a9b
Update adding_memory.ipynb (#5806)
ASwitlyk Jun 7, 2023
e9aad60
rm docs mongo (#5811)
hwchase17 Jun 7, 2023
aec1414
bump ver to 192 (#5812)
hwchase17 Jun 7, 2023
4028f77
fix: fullfill openai params when embedding (#5821)
warjiang Jun 7, 2023
609deed
bump version to 193 (#5838)
hwchase17 Jun 7, 2023
1d8226b
Add in the async methods and link the run id (#5810)
vowelparrot Jun 7, 2023
ac94e19
feat: issue-5712 add sleep tool (#5715)
whysage Jun 7, 2023
1c63876
Rm extraneous args to the trace group helper (#5801)
vowelparrot Jun 7, 2023
2d7b89b
FIX: backslash escaped (#5815)
ugfly1210 Jun 7, 2023
97f6e63
Add DeepInfra embeddings integration with tests and examples, better …
yessenzhar Jun 8, 2023
ed29496
Add how to use a custom scraping function with the sitemap loader. (#…
soos3d Jun 8, 2023
12196e1
feat: Add `UnstructuredCSVLoader` for CSV files (#5844)
MthwRobinson Jun 8, 2023
323d99c
Add logging in PBI tool (#5841)
eavanvalkenburg Jun 8, 2023
bd8c23c
Add additional VertexAI Params (#5837)
thehappydinoa Jun 8, 2023
401efcc
Update microsoft loader example with docx2txt dependency (#5832)
duarteocarmo Jun 8, 2023
04e0ebc
docs: add Shale Protocol integration guide (#5814)
renning22 Jun 8, 2023
25f9a06
qdrant vector store - search with relevancy scores (#5781)
bnassivet Jun 8, 2023
2a8c066
Update to Getting Started docs page for Memory (#5855)
daveaingram Jun 8, 2023
ff2cd56
Fix exporting GCP Vertex Matching Engine from vectorstores (#5793)
mjmammoth Jun 8, 2023
71562f6
Add knn and query search field options to ElasticKnnSearch (#5641)
jeffvestal Jun 8, 2023
81dbdf6
propagate callbacks to ConversationalRetrievalChain (#5572)
alecf Jun 8, 2023
33f8be0
Fix serialization issue with W&B (#5693)
jjzhuo Jun 8, 2023
4158155
Added SingleStoreDB Vector Store (#5619)
volodymyr-memsql Jun 8, 2023
942d3f4
Refactor and update databricks integration page (#5575)
liangz1 Jun 8, 2023
ef11125
Implement saving and loading of RetrievalQA chain (#5818)
liangz1 Jun 8, 2023
b3dc57d
Harrison/fauna loader (#5864)
hwchase17 Jun 8, 2023
4cc7808
Harrison/nebula graph (#5865)
hwchase17 Jun 8, 2023
5d6cdde
bump version to 194 (#5866)
hwchase17 Jun 8, 2023
8cd7385
fix: update qa_chain doc for "chai_type" (#5877)
warjiang Jun 8, 2023
df5c683
Update run eval imports in init (#5858)
vowelparrot Jun 8, 2023
ea460b2
Fix the shortcut conflict for document page search (#5874)
xming521 Jun 8, 2023
175e0ad
Fixes model arguments for amazon models (#5896)
3coins Jun 8, 2023
d8a3c38
Feature/add AWS Kendra Index Retriever (#5856)
hupe1980 Jun 8, 2023
217b009
Use LCP Client in Tracer (#5908)
vowelparrot Jun 9, 2023
8a6b3f8
Create snowflake Loader (#5825)
sergiolrinditex Jun 9, 2023
e8976a7
arxiv: Correct name of search client attribute to 'arxiv_search' from…
spazm Jun 9, 2023
5199a99
Fix typo (#5894)
TLazarevic Jun 9, 2023
2e36bb8
Baseten integration (#5862)
philipkiely-baseten Jun 9, 2023
5874596
Add start index to metadata in TextSplitter (#5912)
felpigeon Jun 9, 2023
860f217
Fix openai proxy error (#5914)
Fei-Wang Jun 9, 2023
5df76bf
Fix the issue where the parameters passed to VertexAI ignored #5889 (…
BigicecreamTaken Jun 9, 2023
0753c72
Add support for the endpoint URL in DynamoDBChatMesasgeHistory (#5836)
rubms Jun 9, 2023
74382c8
Expose full params in Qdrant (#5947)
kacperlukawski Jun 9, 2023
8456ae3
fixes to docs (#5919)
hwchase17 Jun 9, 2023
982572d
bump ver to 195 (#5949)
hwchase17 Jun 9, 2023
35dcbf6
Add load() to snowflake loader (#5956)
rlancemartin Jun 9, 2023
559c073
LOTR: Lord of the Retrievers. A retriever that merge several retrieve…
GMartin-dev Jun 10, 2023
c73bf87
bump version to 196 (#5988)
hwchase17 Jun 10, 2023
743f90a
Fix: SnowflakeLoader returning empty documents (#5967)
kaarthik108 Jun 10, 2023
a881f39
Fixed typo missing "use" (#5991)
constDave Jun 10, 2023
402e193
add test for structured tools (#5989)
hwchase17 Jun 10, 2023
31918d9
Fix handling of missing action & input for async MRKL agent (#5985)
danielgrittner Jun 10, 2023
b38d314
Add additional parameters to Graph Cypher Chain (#5979)
tomasonjo Jun 10, 2023
95a37bd
Add a new vector store - AwaDB (#5971) (#5992)
hwchase17 Jun 10, 2023
b23fd02
Create Airtable loader (#5958)
rlancemartin Jun 10, 2023
958e8da
feat: Add `UnstructuredXMLLoader` for `.xml` files (#5955)
qued Jun 10, 2023
0a0c034
Update to Vectara integration (#5950)
ofermend Jun 10, 2023
00f5003
fix: use model token limit not tokenizer ditto (#5939)
JensMadsen Jun 10, 2023
4dfd257
Fix: Grammer fix in documentation (#5925)
sateesh2020 Jun 10, 2023
ee69322
Fix IndexError in RecursiveCharacterTextSplitter (#5902)
TomTom101 Jun 10, 2023
3049931
add ocr_languages param for ConfluenceLoader.load() (#5823)
blankbro Jun 10, 2023
25f30d5
Harrison/arxiv fix (#5993)
hwchase17 Jun 11, 2023
7f7cb72
Obey handler.raise_error in _ahandle_event_for_handler (#6001)
pors Jun 11, 2023
9cbb492
support kwargs (#5990)
hwchase17 Jun 11, 2023
670ea1a
bump version to 197 (#6007)
hwchase17 Jun 11, 2023
f6ec845
Update databricks.md (#6006)
eltociear Jun 11, 2023
260cfa5
[APIChain] enhance the robustness or url (#6008)
jpzhangvincent Jun 11, 2023
35f3968
feat: :sparkles: Added filtering option to FAISS vectorstore (#5966)
vempaliakhil96 Jun 11, 2023
bb1ca71
fix: TypeError when loading confluence pages by cql (#5878)
haoqixu Jun 11, 2023
1568144
Harrison/embaas (#6010)
hwchase17 Jun 11, 2023
bf04b74
I before E (#6015)
vowelparrot Jun 11, 2023
fc3d07d
nc/load (#5733)
nfcampos Jun 11, 2023
1198156
Update check (#6020)
vowelparrot Jun 12, 2023
2bf7525
Langchain decorators (#6017)
ju-bezdek Jun 12, 2023
b79917f
Remove from PR template (#6018)
vowelparrot Jun 12, 2023
fce6f9a
add from_documents interface in awadb vector store (#6023)
ljeagle Jun 12, 2023
d40446b
Harrison/hologres (#6012)
hwchase17 Jun 12, 2023
6e35fe8
Update MongoDB Atlas support docs (#6022)
bafMdb Jun 12, 2023
b959e39
add dashscope text embedding (#5929)
wenmengzhou Jun 12, 2023
4c5264d
Harrison/cognitive search (#6011)
hwchase17 Jun 12, 2023
da251c4
bump ver to 198 (#6026)
hwchase17 Jun 12, 2023
8b52d43
Mongo db doc fix (#6042)
bafMdb Jun 12, 2023
0681a4c
embaas title
hwchase17 Jun 12, 2023
12bc0e2
comment out
hwchase17 Jun 12, 2023
38e5e25
chore: spedd up integration test by using smaller model (#6044)
JensMadsen Jun 12, 2023
d7de7b8
Text splitter for Markdown files by header (#5860)
rlancemartin Jun 12, 2023
5c37aac
Log tracer errors (#6066)
vowelparrot Jun 13, 2023
883a891
Add embaas document extraction api endpoints (#6048)
juliuslipp Jun 13, 2023
7f04c96
improve tools (#6062)
hwchase17 Jun 13, 2023
cfbc2c0
propogate kwargs fully (#6076)
hwchase17 Jun 13, 2023
fe37360
Enable serialization for anthropic (#6049)
nfcampos Jun 13, 2023
f4cdbc5
turn off repr (#6078)
hwchase17 Jun 13, 2023
bf7e800
Use Run object from SDK (#6067)
vowelparrot Jun 13, 2023
b115877
Fix for ModuleNotFoundError while running langchain-server. Issue #58…
solidate Jun 13, 2023
88102fc
Add tests and update notebook for MarkdownHeaderTextSplitter (#6069)
rlancemartin Jun 13, 2023
d56ebda
support functions (#6099)
hwchase17 Jun 13, 2023
af9fa13
convert tools to openai (#6100)
hwchase17 Jun 13, 2023
b7c9931
Implement `max_marginal_relevance_search` in `VectorStore` of Pinecon…
neo Jun 13, 2023
1d627fe
bump version to 199 (#6102)
hwchase17 Jun 13, 2023
843343a
Harrison/notebook functions (#6103)
hwchase17 Jun 13, 2023
4bebdbd
Add support for tags (#5898)
nfcampos Jun 13, 2023
63962cc
support streaming for functions (#6115)
hwchase17 Jun 13, 2023
e01f475
Return session name in runner response (#6112)
vowelparrot Jun 13, 2023
4b3e194
add functions agent (#6113)
hwchase17 Jun 14, 2023
0ea2cb1
bump ver to 200 (#6130)
hwchase17 Jun 14, 2023
d36d478
Add Run Collector Callback (#6133)
vowelparrot Jun 14, 2023
9946f75
Update Name (#6136)
vowelparrot Jun 14, 2023
f3e3394
Update readthedocs_documentation.ipynb (#6148)
maver1ck Jun 14, 2023
f10cdfb
typo: 'following following' to 'following' (#6163)
thiswillbeyourgithub Jun 14, 2023
2050204
Add docs for tags (#6155)
nfcampos Jun 14, 2023
71b35c4
feat: Add support for the Solidity language (#6054)
0xJord4n Jun 14, 2023
571ac6d
feat: add content_format param to ConfluenceLoader.load() (#5922)
haoqixu Jun 14, 2023
e2920a1
feat: use latest duckduckgo_search API to call
Undertone0809 Jun 19, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Raise an exception in MKRL and Chat Output Parsers if parsing text wh…
…ich contains both an action and a final answer (#5609)

Raises exception if OutputParsers receive a response with both a valid
action and a final answer

Currently, if an OutputParser receives a response which includes both an
action and a final answer, they return a FinalAnswer object. This allows
the parser to accept responses which propose an action and hallucinate
an answer without the action being parsed or taken by the agent.

This PR changes the logic to:
1. store a variable checking whether a response contains the
`FINAL_ANSWER_ACTION` (this is the easier condition to check).
2. store a variable checking whether the response contains a valid
action
3. if both are present, raise a new exception stating that both are
present
4. if an action is present, return an AgentAction
5. if an answer is present, return an AgentAnswer
6. if neither is present, raise the relevant exception based around the
action format (these have been kept consistent with the prior exception
messages)

Disclaimer:
* Existing mock data included strings which did include an action and an
answer. This might indicate that prioritising returning AgentAnswer was
always correct, and I am patching out desired behaviour? @hwchase17 to
advice. Curious if there are allowed cases where this is not
hallucinating, and we do want the LLM to output an action which isn't
taken.
* I have not passed `send_to_llm` through this new exception

Fixes #5601 

## Who can review?

Community members can review the PR once tests pass. Tag
maintainers/contributors who might be interested:

@hwchase17 - project lead
@vowelparrot
  • Loading branch information
nathan-az authored and Undertone0809 committed Jun 19, 2023
commit 823cb9884c0e44f03e369b2ad12b599cce7b3a66
17 changes: 12 additions & 5 deletions langchain/agents/chat/output_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 +13,24 @@ def get_format_instructions(self) -> str:
return FORMAT_INSTRUCTIONS

def parse(self, text: str) -> Union[AgentAction, AgentFinish]:
if FINAL_ANSWER_ACTION in text:
return AgentFinish(
{"output": text.split(FINAL_ANSWER_ACTION)[-1].strip()}, text
)
includes_answer = FINAL_ANSWER_ACTION in text
try:
action = text.split("```")[1]
response = json.loads(action.strip())
includes_action = "action" in response and "action_input" in response
if includes_answer and includes_action:
raise OutputParserException(
"Parsing LLM output produced a final answer "
f"and a parse-able action: {text}"
)
return AgentAction(response["action"], response["action_input"], text)

except Exception:
raise OutputParserException(f"Could not parse LLM output: {text}")
if not includes_answer:
raise OutputParserException(f"Could not parse LLM output: {text}")
return AgentFinish(
{"output": text.split(FINAL_ANSWER_ACTION)[-1].strip()}, text
)

@property
def _type(self) -> str:
Expand Down
68 changes: 37 additions & 31 deletions langchain/agents/mrkl/output_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,44 +13,50 @@ def get_format_instructions(self) -> str:
return FORMAT_INSTRUCTIONS

def parse(self, text: str) -> Union[AgentAction, AgentFinish]:
if FINAL_ANSWER_ACTION in text:
return AgentFinish(
{"output": text.split(FINAL_ANSWER_ACTION)[-1].strip()}, text
)
# \s matches against tab/newline/whitespace
includes_answer = FINAL_ANSWER_ACTION in text
regex = (
r"Action\s*\d*\s*:[\s]*(.*?)[\s]*Action\s*\d*\s*Input\s*\d*\s*:[\s]*(.*)"
)
match = re.search(regex, text, re.DOTALL)
if not match:
if not re.search(r"Action\s*\d*\s*:[\s]*(.*?)", text, re.DOTALL):
action_match = re.search(regex, text, re.DOTALL)
if action_match:
if includes_answer:
raise OutputParserException(
f"Could not parse LLM output: `{text}`",
observation="Invalid Format: Missing 'Action:' after 'Thought:'",
llm_output=text,
send_to_llm=True,
"Parsing LLM output produced both a final answer "
f"and a parse-able action: {text}"
)
elif not re.search(
r"[\s]*Action\s*\d*\s*Input\s*\d*\s*:[\s]*(.*)", text, re.DOTALL
):
raise OutputParserException(
f"Could not parse LLM output: `{text}`",
observation="Invalid Format:"
" Missing 'Action Input:' after 'Action:'",
llm_output=text,
send_to_llm=True,
)
else:
raise OutputParserException(f"Could not parse LLM output: `{text}`")
action = match.group(1).strip()
action_input = match.group(2)
action = action_match.group(1).strip()
action_input = action_match.group(2)
tool_input = action_input.strip(" ")
# ensure if its a well formed SQL query we don't remove any trailing " chars
if tool_input.startswith("SELECT ") is False:
tool_input = tool_input.strip('"')

tool_input = action_input.strip(" ")
# ensure if its a well formed SQL query we don't remove any trailing " chars
if tool_input.startswith("SELECT ") is False:
tool_input = tool_input.strip('"')
return AgentAction(action, tool_input, text)

return AgentAction(action, tool_input, text)
elif includes_answer:
return AgentFinish(
{"output": text.split(FINAL_ANSWER_ACTION)[-1].strip()}, text
)

if not re.search(r"Action\s*\d*\s*:[\s]*(.*?)", text, re.DOTALL):
raise OutputParserException(
f"Could not parse LLM output: `{text}`",
observation="Invalid Format: Missing 'Action:' after 'Thought:'",
llm_output=text,
send_to_llm=True,
)
elif not re.search(
r"[\s]*Action\s*\d*\s*Input\s*\d*\s*:[\s]*(.*)", text, re.DOTALL
):
raise OutputParserException(
f"Could not parse LLM output: `{text}`",
observation="Invalid Format:"
" Missing 'Action Input:' after 'Action:'",
llm_output=text,
send_to_llm=True,
)
else:
raise OutputParserException(f"Could not parse LLM output: `{text}`")

@property
def _type(self) -> str:
Expand Down
41 changes: 17 additions & 24 deletions tests/unit_tests/agents/test_mrkl.py
Original file line number Diff line number Diff line change
Expand Up @@ -90,44 +90,23 @@ def test_get_action_and_input_sql_query() -> None:

def test_get_final_answer() -> None:
"""Test getting final answer."""
llm_output = (
"Thought: I need to search for NBA\n"
"Action: Search\n"
"Action Input: NBA\n"
"Observation: founded in 1994\n"
"Thought: I can now answer the question\n"
"Final Answer: 1994"
)
llm_output = "Thought: I can now answer the question\n" "Final Answer: 1994"
action, action_input = get_action_and_input(llm_output)
assert action == "Final Answer"
assert action_input == "1994"


def test_get_final_answer_new_line() -> None:
"""Test getting final answer."""
llm_output = (
"Thought: I need to search for NBA\n"
"Action: Search\n"
"Action Input: NBA\n"
"Observation: founded in 1994\n"
"Thought: I can now answer the question\n"
"Final Answer:\n1994"
)
llm_output = "Thought: I can now answer the question\n" "Final Answer:\n1994"
action, action_input = get_action_and_input(llm_output)
assert action == "Final Answer"
assert action_input == "1994"


def test_get_final_answer_multiline() -> None:
"""Test getting final answer that is multiline."""
llm_output = (
"Thought: I need to search for NBA\n"
"Action: Search\n"
"Action Input: NBA\n"
"Observation: founded in 1994 and 1993\n"
"Thought: I can now answer the question\n"
"Final Answer: 1994\n1993"
)
llm_output = "Thought: I can now answer the question\n" "Final Answer: 1994\n1993"
action, action_input = get_action_and_input(llm_output)
assert action == "Final Answer"
assert action_input == "1994\n1993"
Expand All @@ -151,6 +130,20 @@ def test_bad_action_line() -> None:
assert e_info.value.observation is not None


def test_valid_action_and_answer_raises_exception() -> None:
"""Test handling when both an action and answer are found."""
llm_output = (
"Thought: I need to search for NBA\n"
"Action: Search\n"
"Action Input: NBA\n"
"Observation: founded in 1994\n"
"Thought: I can now answer the question\n"
"Final Answer: 1994"
)
with pytest.raises(OutputParserException):
get_action_and_input(llm_output)


def test_from_chains() -> None:
"""Test initializing from chains."""
chain_configs = [
Expand Down