หากคุณต้องการข้อมูลเพิ่มเติม ความช่วยเหลือ หรือต้องการให้ข้อเสนอแนะทั่วไปเกี่ยวกับ Orama เข้าร่วมช่อง Orama Slack
คุณสามารถติดตั้ง Orama โดยใช้ npm
, yarn
, pnpm
, bun
:
npm i @orama/orama
หรือนำเข้าโดยตรงในโมดูลเบราว์เซอร์:
< html >
< body >
< script type =" module " >
import { create , insert , search } from 'https://cdn.jsdelivr.net/npm/@orama/orama@latest/+esm'
</ script >
</ body >
</ html >
ด้วย Deno คุณสามารถใช้ CDN URL เดียวกันหรือใช้ตัวระบุ npm:
import { create , search , insert } from 'npm:@orama/orama'
อ่านเอกสารฉบับเต็มได้ที่ https://docs.orama.com
Orama ค่อนข้างใช้งานง่าย สิ่งแรกที่ต้องทำคือสร้างอินสแตนซ์ฐานข้อมูลใหม่และตั้งค่าสคีมาการจัดทำดัชนี:
import { create , insert , remove , search , searchVector } from '@orama/orama'
const db = create ( {
schema : {
name : 'string' ,
description : 'string' ,
price : 'number' ,
embedding : 'vector[1536]' , // Vector size must be expressed during schema initialization
meta : {
rating : 'number' ,
} ,
} ,
} )
insert ( db , {
name : 'Noise cancelling headphones' ,
description : 'Best noise cancelling headphones on the market' ,
price : 99.99 ,
embedding : [ 0.2432 , 0.9431 , 0.5322 , 0.4234 , ... ] ,
meta : {
rating : 4.5
}
} )
const results = search ( db , {
term : 'Best headphones'
} )
// {
// elapsed: {
// raw: 21492,
// formatted: '21μs',
// },
// hits: [
// {
// id: '41013877-56',
// score: 0.925085832971998432,
// document: {
// name: 'Noise cancelling headphones',
// description: 'Best noise cancelling headphones on the market',
// price: 99.99,
// embedding: [0.2432, 0.9431, 0.5322, 0.4234, ...],
// meta: {
// rating: 4.5
// }
// }
// }
// ],
// count: 1
// }
ปัจจุบัน Orama รองรับข้อมูล 10 ประเภทที่แตกต่างกัน:
พิมพ์ | คำอธิบาย | ตัวอย่าง |
---|---|---|
string | สตริงของอักขระ | 'Hello world' |
number | ค่าตัวเลข ไม่ว่าจะเป็นจำนวนทศนิยมหรือจำนวนเต็ม | 42 |
boolean | ค่าบูลีน | true |
enum | ค่าแจงนับ | 'drama' |
geopoint | ค่าตำแหน่งทางภูมิศาสตร์ | { lat: 40.7128, lon: 74.0060 } |
string[] | อาร์เรย์ของสตริง | ['red', 'green', 'blue'] |
number[] | อาร์เรย์ของตัวเลข | [42, 91, 28.5] |
boolean[] | อาร์เรย์ของบูลีน | [true, false, false] |
enum[] | อาร์เรย์ของ enum | ['comedy', 'action', 'romance'] |
vector[<size>] | เวกเตอร์ของตัวเลขเพื่อทำการค้นหาเวกเตอร์ | [0.403, 0.192, 0.830] |
Orama รองรับการค้นหาทั้งแบบเวกเตอร์และแบบผสมโดยเพียงแค่ตั้งค่า mode: 'vector'
เมื่อทำการค้นหา
หากต้องการดำเนินการค้นหาประเภทนี้ คุณจะต้องระบุการฝังข้อความ ณ เวลาที่ค้นหา:
import { create , insertMultiple , search } from '@orama/orama'
const db = create ( {
schema : {
title : 'string' ,
embedding : 'vector[5]' ' , // we are using a 5-dimensional vector.
} ,
} ) ;
insertMultiple ( db , [
{ title : 'The Prestige' , embedding : [ 0.938293 , 0.284951 , 0.348264 , 0.948276 , 0.56472 ] } ,
{ title : 'Barbie' , embedding : [ 0.192839 , 0.028471 , 0.284738 , 0.937463 , 0.092827 ] } ,
{ title : 'Oppenheimer' , embedding : [ 0.827391 , 0.927381 , 0.001982 , 0.983821 , 0.294841 ] } ,
] )
const results = search ( db , {
// Search mode. Can be 'vector', 'hybrid', or 'fulltext'
mode : 'vector' ,
vector : {
// The vector (text embedding) to use for search
value : [ 0.938292 , 0.284961 , 0.248264 , 0.748276 , 0.26472 ] ,
// The schema property where Orama should compare embeddings
property : 'embedding' ,
} ,
// Minimum similarity to determine a match. Defaults to `0.8`
similarity : 0.85 ,
// Defaults to `false`. Setting to 'true' will return the embeddings in the response (which can be very large).
includeVectors : true ,
} )
มีปัญหาในการสร้างการฝังสำหรับการค้นหาเวกเตอร์และไฮบริดใช่ไหม ลองใช้ปลั๊กอิน @orama/plugin-embeddings
ของเรา!
import { create } from '@orama/orama'
import { pluginEmbeddings } from '@orama/plugin-embeddings'
import '@tensorflow/tfjs-node' // Or any other appropriate TensorflowJS backend, like @tensorflow/tfjs-backend-webgl
const plugin = await pluginEmbeddings ( {
embeddings : {
// Schema property used to store generated embeddings
defaultProperty : 'embeddings' ,
onInsert : {
// Generate embeddings at insert-time
generate : true ,
// properties to use for generating embeddings at insert time.
// Will be concatenated to generate a unique embedding.
properties : [ 'description' ] ,
verbose : true ,
}
}
} )
const db = create ( {
schema : {
description : 'string' ,
// Orama generates 512-dimensions vectors.
// When using @orama/plugin-embeddings, set the property where you want to store embeddings as `vector[512]`.
embeddings : 'vector[512]'
} ,
plugins : [ plugin ]
} )
// Orama will generate and store embeddings at insert-time!
await insert ( db , { description : 'Classroom Headphones Bulk 5 Pack, Student On Ear Color Varieties' } )
await insert ( db , { description : 'Kids Wired Headphones for School Students K-12' } )
await insert ( db , { description : 'Kids Headphones Bulk 5-Pack for K-12 School' } )
await insert ( db , { description : 'Bose QuietComfort Bluetooth Headphones' } )
// Orama will also generate and use embeddings at search time when search mode is set to "vector" or "hybrid"!
const searchResults = await search ( db , {
term : 'Headphones for 12th grade students' ,
mode : 'vector'
} )
ต้องการใช้โมเดลการฝัง OpenAI หรือไม่ ใช้ปลั๊กอิน Secure Proxy ของเราเพื่อเรียก OpenAI จากฝั่งไคลเอ็นต์อย่างปลอดภัย
ตั้งแต่ v3.0.0
Orama ให้คุณสร้างประสบการณ์ ChatGPT/Perplexity/SearchGPT ของคุณเองได้ คุณจะต้องเรียกใช้ OpenAI API ดังนั้นเราขอแนะนำอย่างยิ่งให้ใช้ Secure Proxy Plugin เพื่อดำเนินการดังกล่าวอย่างปลอดภัยจากฝั่งไคลเอ็นต์ของคุณ ฟรี!
import { create , insert } from '@orama/orama'
import { pluginSecureProxy } from '@orama/plugin-secure-proxy'
const secureProxy = await pluginSecureProxy ( {
apiKey : 'my-api-key' ,
defaultProperty : 'embeddings' ,
models : {
// The chat model to use to generate the chat answer
chat : 'openai/gpt-4o-mini'
}
} )
const db = create ( {
schema : {
name : 'string'
} ,
plugins : [ secureProxy ]
} )
insert ( db , { name : 'John Doe' } )
insert ( db , { name : 'Jane Doe' } )
const session = new AnswerSession ( db , {
// Customize the prompt for the system
systemPrompt : 'You will get a name as context, please provide a greeting message' ,
events : {
// Log all state changes. Useful to reactively update a UI on a new message chunk, sources, etc.
onStateChange : console . log ,
}
} )
const response = await session . ask ( {
term : 'john'
} )
console . log ( response ) // Hello, John Doe! How are you doing?
อ่านเอกสารฉบับเต็มได้ที่นี่
อ่านเอกสารฉบับเต็มได้ที่ https://docs.orama.com/open-source
เขียนปลั๊กอินของคุณเอง: https://docs.orama.com/open-source/plugins/writing-your-own-plugins
Orama ได้รับอนุญาตภายใต้ใบอนุญาต Apache 2.0