


Membina Penjana Artikel dengan LangChain dan LlamaAn AI Developers Journey
Membina Penjana Artikel dengan LangChain dan Llama3: Perjalanan Pembangun AI
Sebagai pembangun AI, saya sering mencari cara untuk menjadikan interaksi Model Bahasa Besar (LLM) yang kompleks lebih mudah diurus. LangChain menarik perhatian saya bukan sahaja kerana popularitinya yang semakin meningkat dalam komuniti pembangunan AI, tetapi juga kerana pendekatan praktikalnya untuk menyelesaikan cabaran penyepaduan LLM yang biasa. Reputasi rangka kerja untuk mengubah operasi LLM yang kompleks kepada aliran kerja yang diperkemas cukup menarik minat saya untuk mengujinya. Saya memutuskan untuk membina sistem penjanaan artikel yang akan menggabungkan keupayaan LangChain dengan model Llama3 untuk mencipta alat dengan aplikasi dunia sebenar.
Mengapa LangChain Masuk akal
LangChain mengubah cara kami berinteraksi dengan LLM dengan menyediakan pendekatan berstruktur dan intuitif untuk mengendalikan operasi yang kompleks. Anggap ia sebagai kit pembangunan yang direka dengan baik, dengan setiap komponen mempunyai tujuan tertentu. Daripada menyesuaikan panggilan API mentah dan mengurus gesaan secara manual, rangka kerja itu menyediakan antara muka bersih yang dirasakan semula jadi dari perspektif pembangun. Ia bukan sahaja tentang memudahkan proses, ia juga tentang menjadikan aplikasi LLM lebih dipercayai dan boleh diselenggara.
Komponen Utama LangChain
Pada terasnya, LangChain menggunakan rantaian, urutan operasi yang menghubungkan bersama untuk mencipta gelagat yang lebih kompleks. Rantaian ini melakukan segala-galanya daripada memformat gesaan kepada memproses respons model. Walaupun rangka kerja termasuk sistem canggih untuk mengurus gesaan dan mengekalkan konteks merentas interaksi, saya akan menumpukan terutamanya pada rantaian dan aspek gesaan untuk penjana artikel kami.
Penjana Artikel
Untuk projek ini, saya ingin membina sesuatu yang praktikal, sistem yang boleh menjana artikel tersuai berdasarkan parameter tertentu seperti topik, panjang, nada dan khalayak sasaran. Model Llama3, diakses melalui Ollama, memberikan keseimbangan prestasi dan fleksibiliti yang betul untuk tugasan ini.
Bermula
Persediaan adalah mudah:
- Mula-mula, saya memasang pakej yang diperlukan:
pip install langchain langchain-ollama requests
- Kemudian, saya menyediakan Ollama:
- Saya memuat turun dan memasang Ollama daripada https://ollama.com/blog/llama3
- Di terminal baharu, saya memulakan pelayan Ollama:
ollama serve
- Saya menarik model Llama3:
ollama pull llama3
Pelayan Ollama mesti berjalan di terminalnya semasa menggunakan penjana artikel. Jika ia ditutup, penjana tidak akan dapat menyambung kepada model.
Membina Komponen Teras
Mari kita pecahkan cara setiap bahagian sistem berfungsi:
Pengurusan Sambungan
Semakan ringkas ini membantu mengelakkan ralat masa jalan dengan mengetahui masalah sambungan lebih awal. Ia adalah cara yang boleh dipercayai untuk menyemak sambungan ke pelayan Ollama:
pip install langchain langchain-ollama requests
Konfigurasi Model
Persediaan model adalah penting untuk mendapatkan keseimbangan yang betul dalam kandungan terjana kami:
ollama serve
Parameter ini mewakili titik manis yang saya temui selepas menguji pelbagai kombinasi untuk penjanaan artikel.
Suhu (0.7): Mengawal rawak keluaran. Nilai yang lebih rendah (seperti 0.3) akan menjadikan teks lebih mudah diramal, manakala nilai yang lebih tinggi (seperti 0.9) akan menjadikannya lebih kreatif. 0.7 ialah keseimbangan yang baik.
Top_p (0.9): Parameter ini, juga dikenali sebagai pensampelan nukleus, memberitahu model berapa banyak pilihan perkataan yang perlu dipertimbangkan. Pada 0.9, ia melihat pilihan yang mencukupi untuk memastikan teks tetap menarik sambil kekal fokus pada topik.
num_ctx(4096): Saiz tetingkap konteks atau jumlah teks yang boleh digunakan oleh model sekali gus. Ini memberikan ruang yang cukup untuk kedua-dua input dan output artikel yang besar, kerana ia boleh mengendalikan kira-kira 3000-3500 perkataan.
Kejuruteraan Segera
Templat segera ialah tempat kami mentakrifkan perkara yang kami inginkan daripada model:
ollama pull llama3
Saluran Paip Generasi
Salah satu ciri LangChain yang paling elegan ialah komposisi rantainya yang ringkas:
def check_ollama_connection(): """ Check if Ollama server is running """ try: requests.get('http://localhost:11434/api/tags') return True except requests.exceptions.ConnectionError: return False
Barisan tunggal ini mencipta saluran paip generasi lengkap yang mengendalikan pemformatan segera, interaksi model dan pemprosesan tindak balas.
Antara Muka Baris Perintah
Untuk menjadikan alat ini mesra pengguna, saya melaksanakan antara muka baris arahan:
llm = OllamaLLM( model="llama3", temperature=0.7, # Balances creativity and consistency top_p=0.9, # Helps with text diversity num_ctx=4096 # Sets the context window )
Penggunaan Praktikal
Penggunaan penjana adalah sangat mudah: anda menjalankan kod dan lulus parameter.
Contoh #1
article_template = """ You are a professional content writer tasked with creating a comprehensive article. Topic: {topic} Writing Requirements: 1. Length: Approximately {word_count} words 2. Style: {tone} tone 3. Target Audience: {audience} 4. Format: Plain text without any markdown notation 5. Additional Details/Requirements: {extra_details} Content Structure Guidelines: - Start with an engaging introduction that hooks the reader - Organize content into clear sections with descriptive headings (not numbered) - Include relevant examples, statistics, or case studies when appropriate - Provide practical insights and actionable takeaways - End with a compelling conclusion that summarizes key points - Ensure smooth transitions between paragraphs and sections Writing Style Guidelines: - Use clear, concise language appropriate for the target audience - Avoid jargon unless necessary for the target audience - Incorporate relevant examples and real-world applications - Maintain an engaging and natural flow throughout the article - Use active voice predominantly - Include specific details and evidence to support main points - Ensure proper paragraph breaks for readability Additional Notes: - Do not use any markdown formatting - Keep paragraphs concise and focused - Use proper spacing between sections - If technical terms are used, provide brief explanations - Include a brief overview of what will be covered at the start Please write the article now: """
Artikel yang dihasilkan:
chain = prompt | llm
Contoh #2
def parse_arguments(): """ Parse command line arguments """ parser = argparse.ArgumentParser(description='Generate an article using AI') parser.add_argument('--topic', type=str, required=True, help='The topic of the article') parser.add_argument('--word-count', type=int, default=800, help='Target word count (default: 800)') parser.add_argument('--tone', type=str, default='professional', choices=['professional', 'casual', 'academic', 'informative', 'technical'], help='Writing tone (default: professional)') parser.add_argument('--audience', type=str, default='general', help='Target audience (default: general)') parser.add_argument('--extra-details', type=str, default='', help='Additional requirements or details for the article') return parser.parse_args()
Artikel yang dihasilkan:
python main.py \ --topic "Benefits of playing board games with friends" \ --word-count 200 \ --tone casual \ --audience "Board games lovers" \ --extra-details "Avoid markdown notation"
Pembelajaran Utama
Sepanjang projek ini, saya menemui beberapa pandangan penting tentang bekerja dengan LangChain:
- Corak Prestasi: Generasi pertama mengambil masa yang lebih lama disebabkan pemuatan model, tetapi larian berikutnya jauh lebih pantas.
- Pengurusan Konteks: Tetingkap konteks 4096 token menyediakan ruang yang cukup untuk kebanyakan artikel sambil mengekalkan prestasi yang baik.
- Parameter Penjanaan: Tetapan suhu (0.7) dan top_p (0.9) memberikan keseimbangan optimum antara kreativiti dan koheren.
Fikiran Akhir
Membina penjana artikel ini menunjukkan nilai praktikal LangChain dalam pembangunan AI. Ia mengendalikan kerumitan interaksi LLM sambil memberi kebebasan kepada pembangun untuk menumpukan pada membina ciri berguna. Rangka kerja mencapai keseimbangan antara pengabstrakan dan kawalan, menjadikannya lebih mudah untuk mencipta aplikasi berkuasa AI yang boleh dipercayai.
Untuk rakan sekerja yang dihormati di kawasan atau peminat tunggal, saya yakin LangChain memberikan semua makna yang diperlukan untuk pembangunan, dan bahagian yang terbaik ialah: ia bukan pertukaran dengan fleksibiliti. Memikirkan bahawa bidang alat AI berkembang pesat, rangka kerja seperti LangChain akan menjadi lebih berharga untuk membina aplikasi praktikal dan sedia pengeluaran.
Logo LangChain burung nuri dan rantai mempunyai maksud yang bijak di belakangnya. Burung nuri merujuk kepada cara LLM kadangkala dipanggil "burung nuri stokastik" kerana mereka mengulangi dan mengolah semula bahasa manusia. Bahagian rantai ialah rujukan yang menyeronokkan tentang cara rangka kerja membantu "merangkai" model bahasa "burung kakak tua" ke dalam aplikasi yang berguna.
Atas ialah kandungan terperinci Membina Penjana Artikel dengan LangChain dan LlamaAn AI Developers Journey. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Python sesuai untuk sains data, pembangunan web dan tugas automasi, manakala C sesuai untuk pengaturcaraan sistem, pembangunan permainan dan sistem tertanam. Python terkenal dengan kesederhanaan dan ekosistem yang kuat, manakala C dikenali dengan keupayaan kawalan dan keupayaan kawalan yang mendasari.

Anda boleh mempelajari asas -asas Python dalam masa dua jam. 1. Belajar pembolehubah dan jenis data, 2. Struktur kawalan induk seperti jika pernyataan dan gelung, 3 memahami definisi dan penggunaan fungsi. Ini akan membantu anda mula menulis program python mudah.

Python cemerlang dalam permainan dan pembangunan GUI. 1) Pembangunan permainan menggunakan pygame, menyediakan lukisan, audio dan fungsi lain, yang sesuai untuk membuat permainan 2D. 2) Pembangunan GUI boleh memilih tkinter atau pyqt. TKInter adalah mudah dan mudah digunakan, PYQT mempunyai fungsi yang kaya dan sesuai untuk pembangunan profesional.

Anda boleh mempelajari konsep pengaturcaraan asas dan kemahiran Python dalam masa 2 jam. 1. Belajar Pembolehubah dan Jenis Data, 2.

Python lebih mudah dipelajari dan digunakan, manakala C lebih kuat tetapi kompleks. 1. Sintaks Python adalah ringkas dan sesuai untuk pemula. Penaipan dinamik dan pengurusan memori automatik menjadikannya mudah digunakan, tetapi boleh menyebabkan kesilapan runtime. 2.C menyediakan kawalan peringkat rendah dan ciri-ciri canggih, sesuai untuk aplikasi berprestasi tinggi, tetapi mempunyai ambang pembelajaran yang tinggi dan memerlukan memori manual dan pengurusan keselamatan jenis.

Untuk memaksimumkan kecekapan pembelajaran Python dalam masa yang terhad, anda boleh menggunakan modul, masa, dan modul Python. 1. Modul DateTime digunakan untuk merakam dan merancang masa pembelajaran. 2. Modul Masa membantu menetapkan kajian dan masa rehat. 3. Modul Jadual secara automatik mengatur tugas pembelajaran mingguan.

Python digunakan secara meluas dalam bidang pembangunan web, sains data, pembelajaran mesin, automasi dan skrip. 1) Dalam pembangunan web, kerangka Django dan Flask memudahkan proses pembangunan. 2) Dalam bidang sains data dan pembelajaran mesin, numpy, panda, scikit-learn dan perpustakaan tensorflow memberikan sokongan yang kuat. 3) Dari segi automasi dan skrip, Python sesuai untuk tugas -tugas seperti ujian automatik dan pengurusan sistem.

Python cemerlang dalam automasi, skrip, dan pengurusan tugas. 1) Automasi: Sandaran fail direalisasikan melalui perpustakaan standard seperti OS dan Shutil. 2) Penulisan Skrip: Gunakan Perpustakaan Psutil untuk memantau sumber sistem. 3) Pengurusan Tugas: Gunakan perpustakaan jadual untuk menjadualkan tugas. Kemudahan penggunaan Python dan sokongan perpustakaan yang kaya menjadikannya alat pilihan di kawasan ini.
