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

Add cached prompt costs feature with 50% discount #233

Open
wants to merge 123 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
123 commits
Select commit Hold shift + click to select a range
ac751a9
Revert "update deps"
svilupp Feb 26, 2024
423faef
remove GoogleGenAI (#83)
svilupp Feb 26, 2024
320b9b7
fix docs
svilupp Feb 27, 2024
18e1b71
Templating utilities (#84)
svilupp Feb 28, 2024
5200985
update docs + version (#85)
svilupp Feb 29, 2024
846aa37
Add image generation with DALL-E 3 (#86)
svilupp Mar 1, 2024
37fa1f4
update changelog (#87)
svilupp Mar 1, 2024
b8e888d
Update docs to Vitepress (#88)
svilupp Mar 1, 2024
4d26a4f
update docs/make.jl
svilupp Mar 1, 2024
a581d55
fix CI
svilupp Mar 1, 2024
83cefd9
Fix CI nr2
svilupp Mar 1, 2024
db91e60
Fix CI nr3
svilupp Mar 1, 2024
2d45b8e
Fix CI nr4
svilupp Mar 1, 2024
a84f230
Fix CI nr5
svilupp Mar 1, 2024
81198f5
Fix CI nr.6
svilupp Mar 1, 2024
0d6954e
Fix CI nr7
svilupp Mar 1, 2024
37603a4
Fix CI nr8
svilupp Mar 1, 2024
e97f571
Update README.md
svilupp Mar 2, 2024
cd681c8
Add support annotations (#90)
svilupp Mar 7, 2024
b3756b2
Update Documentation (#91)
svilupp Mar 9, 2024
94911cf
Add Prompt Templates to the Docs (#92)
svilupp Mar 9, 2024
846d069
fix typo on set_preferences! examples, fixes #93 (#94)
ceferisbarov Mar 17, 2024
3b30d66
RAG Interface Rewrite (#95)
svilupp Mar 20, 2024
2509e0b
Update Google AI tutorial (#103)
svilupp Mar 21, 2024
e347081
Allow HTMLStyler in node annotations (#105)
svilupp Mar 21, 2024
96357ce
update diagram in the docs (#108)
svilupp Mar 22, 2024
ce4a2ed
A little README.md correction (#107)
Muhammad-saad-2000 Mar 24, 2024
7cab975
Add support for Claude API (#109)
svilupp Mar 25, 2024
5146a95
Enable GoogleGenAI extension (#111)
svilupp Mar 26, 2024
4925b70
Update CHANGELOG.md (#104)
svilupp Mar 26, 2024
5d9d132
Add ShareGPT template (#113)
svilupp Mar 26, 2024
82d87db
Increase compat for GoogleGenAI v0.3
svilupp Mar 26, 2024
069b6f6
Update html printing (#115)
svilupp Mar 27, 2024
7eb32b1
Fix bug in `print_html` (#116)
svilupp Mar 27, 2024
ee3459d
Add Binary embeddings to RAGTools (#117)
svilupp Apr 3, 2024
024562d
Add data extraction for Anthropic models (#122)
svilupp Apr 5, 2024
fc0073e
Register mistral tiny (#123)
svilupp Apr 6, 2024
84f68cc
Add new GPT-4 Turbo (#124)
svilupp Apr 10, 2024
5054f4c
Update code fences in the hero cards in the docs
cpfiffer Apr 11, 2024
49f3f5b
Update Docs Hero page
svilupp Apr 11, 2024
eb94d1a
Add TraceMessage for observability (#133)
svilupp Apr 15, 2024
23e4f0b
Update binary RAG pipeline (#136)
svilupp Apr 17, 2024
a81bd76
Fix truncate_dimension (#137)
svilupp Apr 18, 2024
790b4e2
Add Llama 3 (#138)
svilupp Apr 19, 2024
02b7cf1
Add support for groq (#139)
svilupp Apr 20, 2024
3b18f02
Update Project.toml (#140)
svilupp Apr 20, 2024
ebaa2c5
Update new OpenAI pre-paid credit requirements (#135)
KronosTheLate Apr 20, 2024
4f28fb6
Add model providers and Supported functions (#134)
adarshpalaskar1 Apr 20, 2024
382638d
Add templates and minor improvements (#142)
svilupp Apr 27, 2024
4655422
Add DeepSeek models (#147)
svilupp May 7, 2024
36aa9cb
Update Changelog (#148)
svilupp May 7, 2024
64f51cb
Add GPT4-Omni
svilupp May 13, 2024
f29b99e
Improvements to aiclassify and aitemplates (#150)
svilupp May 18, 2024
2549722
Improve tracer schema / automated logging (#151)
svilupp May 19, 2024
d244680
Add BitPacked embeddings for RAG retrieval (#152)
svilupp May 19, 2024
39647b3
Add more tracer kwargs for logging
svilupp May 20, 2024
d8f3fca
Fix LCS utility
svilupp May 21, 2024
dee5263
Template file parsing fix
svilupp May 22, 2024
bf1eb85
Add BM25 Index (#157)
svilupp May 28, 2024
608bdf0
E2E Hybrid retrieval
svilupp May 28, 2024
6ec6456
Register Mistral Codestral
svilupp May 29, 2024
0f45fde
add FlashRank.jl package extension
svilupp Jun 11, 2024
f3e3994
Update deps
svilupp Jun 14, 2024
223107f
Update RAG performance
svilupp Jun 18, 2024
a4f191a
Improve unpack_bits (#165)
svilupp Jun 18, 2024
03029ee
Update FlashRank to use only unique documents (#166)
svilupp Jun 18, 2024
bbb1c38
fix formatting of changelog
svilupp Jun 18, 2024
f63935d
Add Anthropic Sonnet 3.5 (#167)
svilupp Jun 20, 2024
be91226
Rag Tools fix + relaxing `const` for API key loading
svilupp Jun 26, 2024
971e926
Update CHANGELOG.md
svilupp Jun 26, 2024
4f0cfd7
Add back API keys
svilupp Jun 26, 2024
af4f67f
Add RankGPT (#172)
svilupp Jul 1, 2024
44450c0
Reciprocal Rank Fusion
svilupp Jul 1, 2024
b5f089f
Update rankGPT
svilupp Jul 2, 2024
6e9f0ea
Compat-flashrank-v04
svilupp Jul 7, 2024
988f3d3
Fix CohereReranker bug
svilupp Jul 9, 2024
dd3fbbc
Drafter update
svilupp Jul 13, 2024
dfb88a1
Add AllTagFilter (#178)
svilupp Jul 16, 2024
53ac0b8
Add GPT-4o-mini + set as default (#180)
svilupp Jul 19, 2024
fcd7509
Add SubChunkIndex (view of index)
svilupp Jul 21, 2024
89d4c43
Add SubDocumentTermMatrix (#181)
svilupp Jul 22, 2024
0f1a334
Register Llama3.1 + minor retrieval improvements
svilupp Jul 23, 2024
c02bd43
Llama 3.1 Fireworks.ai
svilupp Jul 24, 2024
886bdd1
Add Mistral Large 2 and Nemo
svilupp Jul 24, 2024
f6cb37d
Fix wrap string
svilupp Jul 30, 2024
0916bd7
version fix
svilupp Jul 30, 2024
e2553b8
Updates embedding concatenation (#186)
svilupp Aug 4, 2024
1473799
Fix getindex
svilupp Aug 4, 2024
1f941f9
Update RAGTools docstrings
svilupp Aug 5, 2024
a53fbfe
Add GPT4o registry entry
svilupp Aug 7, 2024
7d6a8d8
Add DTM specialized method
svilupp Aug 8, 2024
8f697f6
Add OpenAI structured outputs
svilupp Aug 9, 2024
a2cde30
Add ChatGPT 4o (#195)
svilupp Aug 14, 2024
8e880f8
Add experimental prompt cache support for Anthropic
svilupp Aug 16, 2024
06aa438
Improved docs styling with DocumenterVitepress
lazarusA Aug 20, 2024
271ff08
Add assertion for empty docs in `get_embeddings` (#200)
iuliadmtru Aug 23, 2024
5fe770a
Fix documentation for building RAG (#201)
iuliadmtru Aug 23, 2024
1c8fb7d
Update Structured Extraction
svilupp Sep 3, 2024
e1a3d23
Add stream callbacks
svilupp Sep 7, 2024
1ef3ba3
Update Anthropic kwargs + docs
svilupp Sep 9, 2024
a125fcd
Updated DocumentTermMatrix implementation
svilupp Sep 10, 2024
7038175
OpenAI JSON mode extraction
svilupp Sep 15, 2024
9a75d2c
OpenRouter support, new OpenAI o1 models (#207)
svilupp Sep 15, 2024
fe23115
Update reserved keywords
svilupp Sep 15, 2024
51a46bc
Tidy up streaming
svilupp Sep 17, 2024
2a01bb5
Enable Streaming for OpenAI-compatible models
svilupp Sep 18, 2024
0745925
Fix logging
svilupp Sep 22, 2024
cd3f891
Support for Azure OpenAI API
pabvald Sep 24, 2024
ea8d51a
Version up
svilupp Sep 24, 2024
a66da99
Add Cerebras API + node validation for airetry!
svilupp Oct 9, 2024
f945ab9
Tool interface update
svilupp Oct 19, 2024
5280ee8
Add a new models, clean up tools (#219)
svilupp Oct 20, 2024
c57d209
Update VERSION
svilupp Oct 20, 2024
a8c1799
Multi-turn tool fix
svilupp Oct 20, 2024
e7b5f7f
Update anthropic models (#223)
svilupp Oct 22, 2024
80e232d
Add streaming for OllamaSchema (#224)
svilupp Oct 26, 2024
4c3516f
Fix call_cost (#225)
svilupp Nov 3, 2024
158f409
Anthropic computer use (#226)
svilupp Nov 3, 2024
8b6f951
Update Callbacks compat + ToolRef definition (#227)
svilupp Nov 3, 2024
b2bcb94
Update tool execution
svilupp Nov 3, 2024
bcc7c81
Add Haiku35 and Grok2Beta
svilupp Nov 5, 2024
31b1c27
Fix tool dict (#230)
svilupp Nov 6, 2024
e3eb4c1
Add cached prompt costs feature with 50% discount
devin-ai-integration[bot] Nov 7, 2024
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
Fix tool dict (#230)
svilupp authored Nov 6, 2024
commit 31b1c27964b054bfd1f3dd85c608226d35a782d9
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -10,6 +10,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

### Fixed

## [0.62.1]

### Fixed
- Fixed a bug in `tool_call_signature` where hidden fields were not hidden early enough and would fail if a Dict argument was provided. It used to do the processing after, but Dicts cannot be processed, so we're now masking the fields upfront.

## [0.62.0]

### Added
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
name = "PromptingTools"
uuid = "670122d1-24a8-4d70-bfce-740807c42192"
authors = ["J S @svilupp and contributors"]
version = "0.62.0"
version = "0.62.1"

[deps]
AbstractTrees = "1520ce14-60c1-5f80-bbc7-55ef81b5835c"
46 changes: 35 additions & 11 deletions src/extraction.jl
Original file line number Diff line number Diff line change
@@ -181,7 +181,17 @@ function extract_docstring(m::Method; max_description_length::Int = 100)
return extract_docstring(get_function(m); max_description_length)
end

function to_json_schema(orig_type; max_description_length::Int = 100)
@inline function is_hidden_field(field_name::AbstractString,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}})
any(x -> occursin(x, field_name), hidden_fields)
end
@inline function is_hidden_field(field_name::Symbol,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}})
is_hidden_field(string(field_name), hidden_fields)
end

function to_json_schema(orig_type; max_description_length::Int = 100,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}} = String[])
schema = Dict{String, Any}()
type = remove_null_types(orig_type)
if isstructtype(type)
@@ -190,9 +200,12 @@ function to_json_schema(orig_type; max_description_length::Int = 100)
## extract the field names and types
required_types = String[]
for (field_name, field_type) in zip(fieldnames(type), fieldtypes(type))
if is_hidden_field(field_name, hidden_fields)
continue
end
schema["properties"][string(field_name)] = to_json_schema(
remove_null_types(field_type);
max_description_length)
max_description_length, hidden_fields)
## Hack: no null type (Nothing, Missing) implies it it is a required field
is_required_field(field_type) && push!(required_types, string(field_name))
end
@@ -205,23 +218,29 @@ function to_json_schema(orig_type; max_description_length::Int = 100)
end
return schema
end
function to_json_schema(type::Type{<:AbstractString}; max_description_length::Int = 100)
function to_json_schema(type::Type{<:AbstractString}; max_description_length::Int = 100,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}} = String[])
Dict{String, Any}("type" => to_json_type(type))
end
function to_json_schema(type::Type{T};
max_description_length::Int = 100) where {T <:
Union{AbstractSet, Tuple, AbstractArray}}
max_description_length::Int = 100,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}} = String[]) where {T <:
Union{
AbstractSet, Tuple, AbstractArray}}
element_type = eltype(type)
return Dict{String, Any}("type" => "array",
"items" => to_json_schema(remove_null_types(element_type)))
"items" => to_json_schema(remove_null_types(element_type);
max_description_length, hidden_fields))
end
function to_json_schema(type::Type{<:Enum}; max_description_length::Int = 100)
function to_json_schema(type::Type{<:Enum}; max_description_length::Int = 100,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}} = String[])
enum_options = Base.Enums.namemap(type) |> values .|> string
return Dict{String, Any}("type" => "string",
"enum" => enum_options)
end
## Dispatch for method of a function -- grabs only arguments!! Not kwargs!!
function to_json_schema(m::Method; max_description_length::Int = 100)
function to_json_schema(m::Method; max_description_length::Int = 100,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}} = String[])
## Warning: We cannot extract keyword arguments from the method signature
kwargs = Base.kwarg_decl(m)
!isempty(kwargs) &&
@@ -233,9 +252,12 @@ function to_json_schema(m::Method; max_description_length::Int = 100)
## extract the field names and types
required_types = String[]
for (field_name, field_type) in zip(get_arg_names(m), get_arg_types(m))
if is_hidden_field(field_name, hidden_fields)
continue
end
schema["properties"][string(field_name)] = to_json_schema(
remove_null_types(field_type);
max_description_length)
max_description_length, hidden_fields)
## Hack: no null type (Nothing, Missing) implies it it is a required field
is_required_field(field_type) && push!(required_types, string(field_name))
end
@@ -245,7 +267,8 @@ function to_json_schema(m::Method; max_description_length::Int = 100)
!isempty(docs) && (schema["description"] = docs)
return schema
end
function to_json_schema(type::Type{<:AbstractDict}; max_description_length::Int = 100)
function to_json_schema(type::Type{<:AbstractDict}; max_description_length::Int = 100,
hidden_fields::AbstractVector{<:Union{AbstractString, Regex}} = String[])
throw(ArgumentError("Dicts are not supported yet as we cannot analyze their keys/values on a type-level. Use a nested Struct instead!"))
end

@@ -535,7 +558,8 @@ function tool_call_signature(
name
end
schema = Dict{String, Any}("name" => name,
"parameters" => to_json_schema(type_or_method; max_description_length))
"parameters" => to_json_schema(type_or_method; max_description_length,
hidden_fields))
## docstrings
docs = isnothing(docs) ? extract_docstring(type_or_method; max_description_length) :
docs
46 changes: 45 additions & 1 deletion test/extraction.jl
Original file line number Diff line number Diff line change
@@ -6,7 +6,7 @@ using PromptingTools: Tool, isabstracttool, execute_tool, parse_tool, get_arg_na
get_arg_types, get_method, get_function, remove_field!,
tool_call_signature, ToolRef
using PromptingTools: AbstractToolError, ToolNotFoundError, ToolExecutionError,
ToolGenericError
ToolGenericError, is_hidden_field

# TODO: check more edge cases like empty structs

@@ -358,6 +358,36 @@ end
@test schema_measurement["description"] ==
"Represents person's age, height, and weight\n"
end

@testset "is_hidden_field" begin
# Test basic string matching
@test is_hidden_field("context", ["context"]) == true
@test is_hidden_field("data", ["context"]) == false

# Test regex matching
@test is_hidden_field("my_context", [r"context$"]) == true
@test is_hidden_field("context_var", [r"^context"]) == true
@test is_hidden_field("mydata", [r"context"]) == false

# Test multiple patterns
@test is_hidden_field("context", ["data", "context", "temp"]) == true
@test is_hidden_field("context", [r"^data", r"temp$", r"context"]) == true

# Test mixed string and regex patterns
@test is_hidden_field(
"my_context", Union{AbstractString, Regex}["data", r"context$"]) == true
@test is_hidden_field(
"context_var", Union{AbstractString, Regex}[r"^context", "temp"]) == true

# Test empty patterns list
@test is_hidden_field("context", String[]) == false
@test is_hidden_field("context", Regex[]) == false

# Test with Symbol input
@test is_hidden_field(:context, ["context"]) == true
@test is_hidden_field(:my_context, [r"context$"]) == true
@test is_hidden_field(:data, ["context"]) == false
end
@testset "set_properties_strict!" begin
# Test 1: Basic functionality
params = Dict(
@@ -769,6 +799,20 @@ end
tool = ToolRef(; ref = :computer, callable = println)
tool_map = tool_call_signature(tool)
@test tool_map == Dict("computer" => tool)

## accepting dictionary when it's hidden // it would fail otherwise
tool_map = tool_call_signature(context_test_function2; hidden_fields = ["context"])
@test tool_map isa Dict

@test_throws ArgumentError tool_call_signature(context_test_function2)

# for struct
mutable struct MyStruct1234
context::Dict{String, Any}
end
@test_throws ArgumentError tool_call_signature(MyStruct1234)
tool_map = tool_call_signature(MyStruct1234; hidden_fields = ["context"])
@test tool_map isa Dict
end

@testset "parse_tool" begin