Skip to content

pgvector/pgvector-pascal

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pgvector-pascal

pgvector examples for Pascal

Supports SQLDB

Build Status

Getting Started

Follow the instructions for your database library:

SQLDB

Enable the extension

Query.SQL.Text := 'CREATE EXTENSION IF NOT EXISTS vector';
Query.ExecSQL;

Create a table

Query.SQL.Text := 'CREATE TABLE items (id bigserial PRIMARY KEY, embedding vector(3))';
Query.ExecSQL;

Insert vectors

Query.SQL.Text := 'INSERT INTO items (embedding) VALUES ((:embedding1)::vector), ((:embedding2)::vector)';
Query.Params.ParamByName('embedding1').AsString := '[1,2,3]';
Query.Params.ParamByName('embedding2').AsString := '[4,5,6]';
Query.ExecSQL;

Get the nearest neighbors

Query.SQL.Text := 'SELECT * FROM items ORDER BY embedding <-> (:embedding)::vector LIMIT 5';
Query.Params.ParamByName('embedding').AsString := '[3,1,2]';
Query.Open;
while not Query.EOF do
begin
  writeln(Query.FieldByName('id').AsString);
  Query.Next;
end;
Query.Close;

Add an approximate index

Query.SQL.Text := 'CREATE INDEX ON items USING hnsw (embedding vector_l2_ops)';
// or
Query.SQL.Text := 'CREATE INDEX ON items USING ivfflat (embedding vector_l2_ops) WITH (lists = 100)';
Query.ExecSQL;

Use vector_ip_ops for inner product and vector_cosine_ops for cosine distance

See a full example

Contributing

Everyone is encouraged to help improve this project. Here are a few ways you can help:

To get started with development:

git clone https://github.com/pgvector/pgvector-pascal.git
cd pgvector-pascal
createdb pgvector_pascal_test
fpc example.pp
./example

Specify the path to libpq if needed:

ln -s /opt/homebrew/opt/libpq/lib/libpq.dylib libpq.dylib

About

pgvector examples for Pascal

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages