Note 1: Instructor supports context caching for Anthropic API and OpenAI API.
Note 2: Context caching is automatic for all OpenAI API calls. Read more in the OpenAI API documentation.
<?php
require 'examples/boot.php';
use Cognesy\Polyglot\Inference\Inference;
use Cognesy\Utils\Str;
$data = file_get_contents(__DIR__ . '/../../../README.md');
$inference = (new Inference)
//->wiretap(fn($e) => $e->print()) // wiretap to print all events
//->withDebugPreset('on') // debug HTTP traffic
->using('anthropic')
->withCachedContext(
messages: [
['role' => 'user', 'content' => 'Here is content of README.md file'],
['role' => 'user', 'content' => $data],
['role' => 'user', 'content' => 'Generate a short, very domain specific pitch of the project described in README.md. List relevant, domain specific problems that this project could solve. Use domain specific concepts and terminology to make the description resonate with the target audience.'],
['role' => 'assistant', 'content' => 'For whom do you want to generate the pitch?'],
],
);
$response = $inference
->with(
messages: [['role' => 'user', 'content' => 'founder of lead gen SaaS startup']],
options: ['max_tokens' => 512],
)
->response();
print("----------------------------------------\n");
print("\n# Summary for CTO of lead gen vendor\n");
print(" ({$response->usage()->cacheReadTokens} tokens read from cache)\n\n");
print("----------------------------------------\n");
print($response->content() . "\n");
assert(!empty($response->content()));
assert(Str::contains($response->content(), 'Instructor'));
assert(Str::contains($response->content(), 'lead', false));
assert($response->usage()->cacheReadTokens > 0 || $response->usage()->cacheWriteTokens > 0);
$response2 = $inference
->with(
messages: [['role' => 'user', 'content' => 'CIO of insurance company']],
options: ['max_tokens' => 512],
)
->response();
print("----------------------------------------\n");
print("\n# Summary for CIO of insurance company\n");
print(" ({$response2->usage()->cacheReadTokens} tokens read from cache)\n\n");
print("----------------------------------------\n");
print($response2->content() . "\n");
assert(!empty($response2->content()));
assert(Str::contains($response2->content(), 'Instructor'));
assert(Str::contains($response2->content(), 'insurance', false));
assert($response2->usage()->cacheReadTokens > 0);
?>