Giới thiệu công cụ AI hỗ trợ lập trình - Continue.dev

Giới thiệu công cụ AI hỗ trợ lập trình - Continue.dev

Tin ngắn hàng ngày dành cho bạn
  • Mấy hôm trước OpenAI giới thiệu Deep Research - một công cụ duyệt web để nghiên cứu và cho ra một bản tổng hợp chỉ trong vài chục phút - so với nhiều giờ làm việc đối với con người, theo như họ công bố.

    Tính năng này hiện chỉ có sẵn cho người dùng Pro. Mặc dù chưa được dùng thử, nhưng qua nhiều bài viết đều nhấn mạnh vào sự ấn tượng trước khả năng của công cụ mới này. Nếu vẫn chưa biết Deep Research làm được gì thì bạn cứ hình dung như thế này: Nói với nó "Tôi cần thông tin nghiên cứu về lượng tiêu thụ cà phê của thế giới trong năm ngoái". Thế thôi! Ngồi chờ một lúc để nó tìm kiếm và tổng hợp lại kết quả và gửi lại cho bạn một bài báo cáo chi tiết. Chà, ghê thật chứ!

    Ngay lập tức huggingface đã lên một bài viết cố gắng tái tạo lại công cụ này theo cách của họ. Chi tiết tại Open-source DeepResearch – Freeing our search agents. Và không có gì ngạc nhiên khi cả 2 đều mang hơi hướng của AI Agents.

    » Xem thêm
  • Sống đủ lâu trong thế giới Internet, bạn có thể thấy rằng mọi người ở đây khá háo hức chạy theo xu hướng và chúng lan truyền với tốc độ chóng mặt.

    Chỉ vài tháng trước, chúng ta vẫn còn kinh ngạc về trí thông minh của các mô hình ngôn ngữ lớn (LLM) có thể trả lời giống như con người, và ngay sau đó, chúng đã được cập nhật với khả năng suy nghĩ và lý luận đáng kinh ngạc. Chúng được ứng dụng rộng rãi không chỉ trong lĩnh vực lập trình. Gần đây, thuật ngữ AI Agents đã tạo nên một sự khuấy động.

    Vậy, AI Agents là gì? Trong bài viết ngắn này, tất nhiên là không thể đưa ra một định nghĩa ngắn gọn nhưng toàn diện. Bạn đọc có thể tham khảo bài viết rất chi tiết này tại đây Agents | Chip Huyền. Để dễ hình dung hơn, AI Agents có thể được coi là một người hoặc một thực thể nào đó. Bản thân các Agents được trang bị tất cả các công cụ cần thiết. Từ đó, các Agents có thể kết hợp chúng để hoàn thành một nhiệm vụ mà chúng ta giao.

    Vẫn còn hơi mơ hồ phải không? Một ví dụ thực tế là khi bạn ra lệnh cho các Agents truy cập Facebook vào lúc 8 giờ tối mỗi ngày, kiểm tra bất kỳ tin tức nổi bật nào từ bạn bè, sau đó gửi tóm tắt đến Telegram. Vậy là xong!

    » Xem thêm
  • Hôm qua đến nay, lượt truy cập tới từ Facebook tăng đột biến. Thường như thế là do ai đó chia sẻ bài viết của blog vào một nhóm nào đó.

    Cơ mà lần này là liên kết trực tiếp đến trang chủ luôn. Tò mò ghê, không biết ai chia sẻ, chia sẻ ở đâu nữa. Muốn biết để tìm hiểu "insight" ghê 🥹

    » Xem thêm

Vấn đề

Xin chào các độc giả của 2coffee.dev! Như trong các bài viết trước đó, tôi đã "khoe" mình dùng rất nhiều công cụ trợ giúp viết mã, hay còn gọi là Generative AI. So sánh chúng với nhau và đi đến kết luận rằng Cursor đang đứng đầu trong số đó. Vậy nhưng với cái giá 20$ mỗi tháng tương đối chua chát có thể khiến nhiều người phải "rơi vào suy tư". Trong những cuộc trò chuyện với đồng nghiệp, tất cả chúng tôi đều đi đến một kết luận rằng: nếu như họ định giá ở mức rẻ hơn, cỡ 10-15$ thì nhiều người sẽ chịu chi hơn, dĩ nhiên là trong đó có cả chúng tôi.

Biết được sự việc đó. Sau khi hết hạn dùng thử Cursor, tôi đã dành thời gian để trải nghiệm "nghiêm túc" hơn với Continue.dev nhằm đưa ra nhận định khách quan hơn về công cụ này. Kết quả là nội dung của bài viết này. Trong bài viết, tôi sẽ điểm lại một số tính năng nổi bật, cách sử dụng, đồng thời nêu ra một số quan điểm cá nhân của riêng mình.

Continue.dev là gì?

Continue.dev là một "trợ lý" AI mã nguồn mở hàng đầu cho lập trình viên. Bạn có thể kết nối và sử dụng bất kỳ mô hình LLMs nào để cung cấp ngữ cảnh về mã nguồn, cũng như sử dụng tính năng tự động hoàn thành mã. Nói một cách nôm na thì Continue như một cái khung có thể cài cắm LLMs nào tuỳ thích. Ngoài ra còn có thể tuỳ chỉnh được bối cảnh và nhu cầu sử dụng.

Có 4 tính năng nổi bật mà Continue cung cấp: Chat, Autocomplete, EditAction.

Trong đó, Chat là tính năng cơ bản nhất, nơi bạn có thể trò chuyện với LLMs về bất kỳ nội dung gì mà không cần phải thoát ra khỏi trình soạn thảo mã. Ví dụ như hỏi về một tính năng, yêu cầu giải thích điều gì đó hoặc nhờ tạo một đoạn mã nào đó theo nhu cầu...

Autocomplete là một tính năng rất hữu ích. Continue dựa vào ngữ cảnh của dự án để gợi ý đoạn mã tiếp theo mà bạn sắp viết. Nhiệm vụ của bạn lúc này chỉ là Tab, Tab và Tab để điền vào đoạn mã mà AI tạo ra cho bạn.

Edit tham gia trực tiếp vào đoạn mã mà bạn ra lệnh. Ví dụ bôi đen đoạn mã rồi ra một lệnh gì đó như "refactor it" thì ngay lập tức nó sẽ sửa lại đoạn mã của bạn. Lúc này bạn có hai sự lựa chọn là đồng ý hoặc từ chối đoạn mã vừa hoàn thành.

Actions gần giống như Chat, nó có một số "splash command" để ra lệnh yêu cầu rất cụ thể.

Để làm được tất cả những điều trên, Continue buộc phải được kết nối với các mô hình LLMs. Ví dụ như Chat, bạn có thể sử dụng OpenAI, Claude, LLama... Trong khi với Autocomplete thì nên sử dụng các mô hình đặc thù hoặc "rẻ" hơn như Codestral của Mistral.

Sở dĩ phải lựa chọn mô hình phù hợp vì mỗi tính năng có cách tiêu tốn tokens khác nhau. Trong khi Chat chỉ đơn giản là dựa vào prompt nhập vào thì Autocomplete cần phải nhập vào cả nội dung của file để đưa ra gợi ý. Hành vi này tốn rất nhiều tokens, nếu sử dụng không cẩn thận, kết nối với các mô hình đắt đỏ thì chi phí sẽ bị độn lên rất nhiều.

Vấn đề về ngữ cảnh được Continue giải quyết bằng các mô hình embedding và re-ranking. Các mô hình nhúng được dùng để lập chỉ mục và tìm kiếm sự tương đồng cho gợi ý mã. Trong khi đó, các mô hình re-ranking tìm ra mức độ liên quan giữa câu hỏi và mã để đưa ra câu trả lời chính xác nhất cho người dùng. Để tìm hiểu sâu hơn về hai cơ chế này, bạn đọc đọc thêm tài liệu về Embeddings model & Reranking model.

Cấu hình

Continue hỗ trợ VSCodeJetBrains. Chúng ta cần cài đặt tiện ích mở rộng vào trình soạn thảo trước khi sử dụng.

Tiếp theo chúng ta cần cấu hình models để cho nó hoạt động. Continue đã có hướng dẫn rất chi tiết về cách cấu hình, kèm theo loại models khuyến nghị, từ miễn phí cho đến trả phí. Về cơ bản, chúng ta cần quan tâm đến 4 loại models chính dùng cho Chat, Autocompletion, Embeddings và Reranking.

Để vào màn cài đặt, với VSCode, bấm vào biểu tượng Continue ở thanh Status Bar nằm dưới cùng bên tay phải > chọn "Configure autocomple options".

Tại đây bạn nhập thông tin models vào từng mục theo hướng dẫn cấu hình. Ví dụ đây là file config.json của tôi:

{
  "models": [
    {
      "title": "Codestral",
      "provider": "mistral",
      "model": "codestral-latest",
      "apiKey": "xxx"
    }
  ],
  "tabAutocompleteModel": {
    "title": "Codestral",
    "provider": "mistral",
    "model": "codestral-latest",
    "apiKey": "xxx",
    "contextLength": 32000
  },
  "embeddingsProvider": {
    "provider": "openai",
    "model": "voyage-code-2",
    "apiBase": "https://api.voyageai.com/v1/",
    "apiKey": "xxx"
  },
  "reranker": {
    "name": "voyage",
    "params": {
      "model": "rerank-1",
      "apiKey": "xxx"
    }
  },
  "customCommands": [],
  "allowAnonymousTelemetry": false,
  "docs": []
}

Sử dụng cơ bản

Đầu tiên hãy thử trải nghiệm tính năng Autocomplete. Rất đơn giản! Mỗi khi gõ vào thì tiện ích tự động hoàn thành.

Autocomplete

Thử sử dụng tính năng Chat nhé! Bôi đen một đoạn mã rồi bấm tổ hợp phím Cmd + L để đưa nó vào đoạn Chat, rồi nhờ "giải thích".

Chat

Hoặc cũng có thể hỏi những câu hỏi ngoài lề.

Chat

Điều này tiết kiệm thời gian tìm kiếm trên sự trợ giúp trên mạng.

Tiếp theo hãy thử tính năng Edit. Sửa trực tiếp mã theo yêu cầu. Bôi đen đoạn mã cần sửa, bấm tổ hợp phím Cmd + i, nhập prompt vào.

Edit

Cuối cùng là tính năng Actions cũng tương tự như Chat, nhưng thay vì ra lệnh bằng prompt thì Action có thêm prefix để hướng dẫn AI làm một công việc cụ thể. Ví dụ tạo commit message cho git.

Actions

Ngoài ra nếu bạn là người thích vọc vạch thì Continue có hẳn một mục "Customize" để can thiệp sâu hơn như cấu hình thêm LLMs, tạo lại ngữ cảnh, tạo Actions... Bạn đọc tham khảo thêm tại Overview | Customize Continue.

Một phần sức mạnh của các công cụ Generative AI nằm ở model mà sử dụng. Đối với lập trình, Claude 3.5 Sonnet đang thuộc tốp đầu. Nhưng giá tokens rất đắt vậy nên bạn chỉ nên dùng nó cho mục đích Chat, và các mục đích tiết kiệm tokens hơn so với Autocompletion.

So sánh với Cursor

Continue có những tính năng rất giống với Cursor vì thế trải nghiệm sử dụng là khá tương đồng. Tuy nhiên về mặt gợi ý mã thì Cursor làm tốt hơn rất nhiều, có thể họ đầu tư vào thiết kế ngữ cảnh hoặc sử dụng các mô hình LLMs tân tiến... Continue thì miễn phí so với cái giá 20$ hàng tháng của Cursor.

Hiện tại tôi đang sử dụng Continue kết hợp với các models của Mistral. Họ cung cấp 2 mô hình Chat và Completion hoàn toàn miễn phí. Bạn đọc có thể tham khảo tại Codestral: Hello, World!. Theo cảm nhận, Codestral hoạt động tốt nhưng chưa xuất sắc bằng Cursor.

Còn một số vấn đề nữa với Continue là tính năng tự động hoàn thành mã thi thoảng không hoạt động. Đây là vấn đề được biết từ lâu nhưng có vẻ như vẫn chưa được khắc phục triệt để. Những lúc như vậy hãy thử tắt đi bật lại hoặc khởi động lại máy. Hy vọng lỗi này sẽ được sửa trong tương lai.

Kết luận

Bài viết trên đây là một cái nhìn khách quan của tôi sau gần một tháng sử dụng Continue.dev. Nếu bạn đang sử dụng, hãy để lại cảm nhận của mình xuống dưới bài viết nhé. Hoặc bạn có đang sử dụng công cụ nào tương tự như Continue nữa hay không? Có điều gì tốt hơn không thì hãy cùng nhau thảo luận nhé. Xin cảm ơn!

Cao cấp
Hello

Tôi & khao khát "chơi chữ"

Bạn đã thử viết? Và rồi thất bại hoặc chưa ưng ý? Tại 2coffee.dev chúng tôi đã có quãng thời gian chật vật với công việc viết. Đừng nản chí, vì giờ đây chúng tôi đã có cách giúp bạn. Hãy bấm vào để trở thành hội viên ngay!

Bạn đã thử viết? Và rồi thất bại hoặc chưa ưng ý? Tại 2coffee.dev chúng tôi đã có quãng thời gian chật vật với công việc viết. Đừng nản chí, vì giờ đây chúng tôi đã có cách giúp bạn. Hãy bấm vào để trở thành hội viên ngay!

Xem tất cả

Đăng ký nhận thông báo bài viết mới

hoặc
* Bản tin tổng hợp được gửi mỗi 1-2 tuần, huỷ bất cứ lúc nào.

Bình luận (0)

Nội dung bình luận...
Bấm hoặc cuộn mạnh để sang bài mới