Files
fil/docs/snippets/elixir/advanced/embedding_with_chunking.md
Henrik Jess Nielsen b4c07d3693
All checks were successful
Deploy fil (kreuzberg) / deploy (push) Successful in 49s
Nomad changes
2026-06-01 23:40:55 +02:00

798 B

config_json = Jason.encode!(%{
  "chunking" => %{
    "enabled" => true,
    "max_characters" => 512
  },
  "embeddings" => %{
    "enabled" => true
  }
})

{:ok, result} = Kreuzberg.extract_file_sync("document.pdf", "application/pdf", config_json)

# Process chunks with embeddings for semantic search
embedded_chunks = result.chunks
  |> Enum.with_index(1)
  |> Enum.map(fn {chunk, idx} ->
    %{
      "chunk_id" => idx,
      "content" => chunk["content"],
      "embedding" => chunk["embedding"],
      "page" => chunk["page"],
      "metadata" => %{
        "document" => "document.pdf",
        "chunk_index" => idx
      }
    }
  end)

IO.puts("Prepared #{length(embedded_chunks)} chunks with embeddings")
IO.inspect(embedded_chunks, label: "Embedded Chunks")