Pure Go untuk RWKV dan mendukung cross-platform.
rwkv.go adalah pembungkus di sekitar rwkv.cpp, yang merupakan adaptasi dari ggml.cpp.
go get github.com/seasonjs/rwkv Lihat Folder deps untuk Kompatibilitas Dylib, atau Anda dapat membangun perpustakaan sendiri, dan permintaan dorong dipersilakan.
NewRwkvAutoModel Baik GPU mendukung AMD dan NVIDIA di Windows.
NewRwkvModel membutuhkan Anda untuk memuat pustaka dinamis secara manual, dan perpustakaan dinamis bergantung pada platform.
Pengguna Windows AMD GPU mungkin perlu memeriksa arsitektur ROCM untuk mendapatkan informasi lebih lanjut.
Pengguna GPU Windows NVIDIA mungkin perlu memeriksa arsitektur CUDA untuk mendapatkan informasi lebih lanjut.
| platform | x32 | x64 | lengan | AMD/ROCM | Nvidia/cuda |
|---|---|---|---|---|---|
| windows | bukan dukungan | Dukungan AVX/AVX2/AVX512 | bukan dukungan | Dukungan ROCM5.5 | Dukungan CUDA12 |
| Linux | bukan dukungan | mendukung | bukan dukungan | bukan dukungan | bukan dukungan |
| Darwin | bukan dukungan | mendukung | mendukung | bukan dukungan | bukan dukungan |
Perpustakaan dinamis ini berasal dari rilis RWKV.cpp, versi perpustakaan dinamis dapat diperoleh dengan melihat file rwkv.version siapa pun dapat memeriksa konsistensi file dengan checksum MD5 file.
Yang bisa saya katakan adalah bahwa penciptaan perpustakaan dinamis bersifat publik dan tidak mengandung logika berbahaya subyektif. Jika Anda khawatir tentang keamanan perpustakaan dinamis selama proses penggunaan, Anda dapat membangunnya sendiri.
Saya dan penulis mana pun yang terkait dengan perpustakaan dinamis tidak memikul masalah, tanggung jawab, atau kewajiban hukum selama penggunaan.
Anda dapat menemukan contoh lengkap di folder contoh.
Berikut adalah contoh sederhana:
package main
import (
"fmt"
"github.com/seasonjs/rwkv"
)
func main () {
model , err := rwkv . NewRwkvAutoModel (rwkv. RwkvOptions {
MaxTokens : 500 ,
StopString : " n n " ,
Temperature : 0.8 ,
TopP : 0.5 ,
TokenizerType : rwkv . World , //or World
PrintError : true ,
CpuThreads : 10 ,
GpuEnable : false ,
})
if err != nil {
fmt . Print ( err . Error ())
return
}
defer model . Close ()
err = model . LoadFromFile ( "./models/RWKV-5-World-0.4B-v2-20231113-ctx4096-F16.bin" )
if err != nil {
fmt . Print ( err . Error ())
return
}
prompt := `The following is a coherent verbose detailed conversation between a Chinese girl named Alice and her friend Bob.
Alice is very intelligent, creative and friendly.
Alice likes to tell Bob a lot about herself and her opinions.
Alice usually gives Bob kind, helpful and informative advices.
Bob: lhc
Alice: LHC是指大型强子对撞机(Large Hadron Collider),是世界最大最强的粒子加速器,由欧洲核子中心(CERN)在瑞士日内瓦地下建造。
LHC的原理是加速质子(氢离子)并让它们相撞,让科学家研究基本粒子和它们之间的相互作用,并在2012年证实了希格斯玻色子的存在。
Bob: 企鹅会飞吗
Alice: 企鹅是不会飞的。企鹅的翅膀短而扁平,更像是游泳时的一对桨。企鹅的身体结构和羽毛密度也更适合在水中游泳,而不是飞行。
`
user := `Bob: 请介绍北京的旅游景点?
Alice: `
ctx , err := model . InitState ( prompt )
if err != nil {
print ( err . Error ())
return
}
out , err := ctx . Predict ( user )
if err != nil {
print ( err . Error ())
return
}
print ( out )
}Untuk mengirimkan program kerja yang mencakup AI ini, Anda harus memasukkan file -file berikut:
Paket ini juga menyediakan API tingkat rendah yang sama dengan RWKV-CPP. Lihat detail di RWKV-DOC.
Terima kasih khusus untuk dukungan JetBrains untuk mensponsori.
Hak Cipta (C) Musim. Semua hak dilindungi undang -undang. Berlisensi di bawah lisensi MIT. Lihat lisensi.txt di root proyek untuk informasi lisensi.