diff --git a/404.html b/404.html index 53edcebb..17452a2c 100644 --- a/404.html +++ b/404.html @@ -18,8 +18,8 @@ - - + + diff --git a/about/2035/index.html b/about/2035/index.html index cf75ca2e..e70a65e8 100644 --- a/about/2035/index.html +++ b/about/2035/index.html @@ -18,8 +18,8 @@ - - + + @@ -31,6 +31,6 @@
  • 10 year vision
  • 2 week sprint
  • -

    And we measure our success on Quarterly OKRs

    +

    And we measure our success on Quarterly OKRs

    \ No newline at end of file diff --git a/about/faq/index.html b/about/faq/index.html index f8a845fe..29bcbcb5 100644 --- a/about/faq/index.html +++ b/about/faq/index.html @@ -18,8 +18,8 @@ - - + + @@ -60,6 +60,6 @@

    Can I self-host?

    Yes! We love the self-hosted movement. Jan is available as a Helm chart/ Docker composes which can be run across home servers or even production-level environments.

    Are you hiring?

    -

    We often hire directly from our community. If you are interested in applying, please see our careers page here.

    +

    We often hire directly from our community. If you are interested in applying, please see our careers page here.

    \ No newline at end of file diff --git a/about/index.html b/about/index.html index b1f4defb..8eb7bede 100644 --- a/about/index.html +++ b/about/index.html @@ -18,8 +18,8 @@ - - + + @@ -92,6 +92,6 @@

    FootnotesLlama.cpp, TensorRT-LLM, vLLM, LMDeploy and more.

    -
    +
    \ No newline at end of file diff --git a/about/roadmap/index.html b/about/roadmap/index.html index 669a9e92..135c9ced 100644 --- a/about/roadmap/index.html +++ b/about/roadmap/index.html @@ -18,8 +18,8 @@ - - + + @@ -28,6 +28,6 @@
    Skip to main content
    + \ No newline at end of file diff --git a/acknowledgements/index.html b/acknowledgements/index.html index f5983a38..fb750133 100644 --- a/acknowledgements/index.html +++ b/acknowledgements/index.html @@ -18,8 +18,8 @@ - - + + @@ -38,6 +38,6 @@

    Dev ToolsScalar
  • Continue
  • -
    +
    \ No newline at end of file diff --git a/api-reference-1.0/index.html b/api-reference-1.0/index.html index c6f21394..ed81190b 100644 --- a/api-reference-1.0/index.html +++ b/api-reference-1.0/index.html @@ -22,8 +22,8 @@ - - + + diff --git a/api-reference/index.html b/api-reference/index.html index 2e3bc483..5c81623a 100644 --- a/api-reference/index.html +++ b/api-reference/index.html @@ -18,8 +18,8 @@ - - + + diff --git a/assets/js/008541a4.7719ba24.js b/assets/js/008541a4.7719ba24.js new file mode 100644 index 00000000..7ad8840a --- /dev/null +++ b/assets/js/008541a4.7719ba24.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3152],{77200:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>o,default:()=>d,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var s=i(74848),t=i(28453);const a={sidebar_position:14,slug:"/changelog/changelog-v0.3.0"},o="v0.3.0",l={id:"releases/changelog/changelog-v0.3.0",title:"v0.3.0",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.0.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.0",permalink:"/changelog/changelog-v0.3.0",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.0.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:14,frontMatter:{sidebar_position:14,slug:"/changelog/changelog-v0.3.0"},sidebar:"releasesSidebar",previous:{title:"v0.3.1",permalink:"/changelog/changelog-v0.3.1"},next:{title:"v0.2.3",permalink:"/changelog/changelog-v0.2.3"}},r={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function h(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"v030",children:"v0.3.0"}),"\n",(0,s.jsxs)(n.p,{children:["For more details, ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.0",children:"GitHub Issues"})]}),"\n",(0,s.jsxs)(n.p,{children:["Highlighted Issue: ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/482",children:"Issue #482: fix: hide preferences section if empty"})]}),"\n",(0,s.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"fix: hide preferences section if empty @louis-jan (#482)"}),"\n",(0,s.jsx)(n.li,{children:"chore: fix conversation summary @louis-jan (#480)"}),"\n",(0,s.jsx)(n.li,{children:"chore: missing create conversation button when there is no conversation is selected @louis-jan (#478)"}),"\n",(0,s.jsx)(n.li,{children:"fix: download now change state immediately @namchuai (#475)"}),"\n",(0,s.jsx)(n.li,{children:"chore: add required app version to edge release plugin @louis-jan (#471)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"add rebuild for mac x64 @hiento09 (#473)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Add build deps for data-plugin in CI @hiento09 (#472)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,s.jsx)(n.p,{children:"@hiento09, @hientominh, @jan-service-account, @louis-jan and @namchuai"})]})}function d(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>l});var s=i(96540);const t={},a=s.createContext(t);function o(e){const n=s.useContext(a);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),s.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/008541a4.fa71dc5e.js b/assets/js/008541a4.fa71dc5e.js deleted file mode 100644 index 5da21b12..00000000 --- a/assets/js/008541a4.fa71dc5e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3152],{77200:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>o,default:()=>d,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var s=i(74848),t=i(28453);const a={sidebar_position:14,slug:"/changelog/changelog-v0.3.0"},o="v0.3.0",l={id:"releases/changelog/changelog-v0.3.0",title:"v0.3.0",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.0.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.0",permalink:"/changelog/changelog-v0.3.0",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.0.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:14,frontMatter:{sidebar_position:14,slug:"/changelog/changelog-v0.3.0"},sidebar:"releasesSidebar",previous:{title:"v0.3.1",permalink:"/changelog/changelog-v0.3.1"},next:{title:"v0.2.3",permalink:"/changelog/changelog-v0.2.3"}},r={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function h(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"v030",children:"v0.3.0"}),"\n",(0,s.jsxs)(n.p,{children:["For more details, ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.0",children:"GitHub Issues"})]}),"\n",(0,s.jsxs)(n.p,{children:["Highlighted Issue: ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/482",children:"Issue #482: fix: hide preferences section if empty"})]}),"\n",(0,s.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"fix: hide preferences section if empty @louis-jan (#482)"}),"\n",(0,s.jsx)(n.li,{children:"chore: fix conversation summary @louis-jan (#480)"}),"\n",(0,s.jsx)(n.li,{children:"chore: missing create conversation button when there is no conversation is selected @louis-jan (#478)"}),"\n",(0,s.jsx)(n.li,{children:"fix: download now change state immediately @namchuai (#475)"}),"\n",(0,s.jsx)(n.li,{children:"chore: add required app version to edge release plugin @louis-jan (#471)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"add rebuild for mac x64 @hiento09 (#473)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Add build deps for data-plugin in CI @hiento09 (#472)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,s.jsx)(n.p,{children:"@hiento09, @hientominh, @jan-service-account, @louis-jan and @namchuai"})]})}function d(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>l});var s=i(96540);const t={},a=s.createContext(t);function o(e){const n=s.useContext(a);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),s.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/00863b7a.0417af2a.js b/assets/js/00863b7a.0417af2a.js deleted file mode 100644 index aa786c2a..00000000 --- a/assets/js/00863b7a.0417af2a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8282],{71254:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>d,frontMatter:()=>r,metadata:()=>s,toc:()=>l});var o=n(74848),i=n(28453);const r={title:"Overview",slug:"/integrationss",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,s={id:"guides/integrations/overview-integration",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/integrations/overview-integration.mdx",sourceDirName:"guides/integrations",slug:"/integrationss",permalink:"/integrationss",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/overview-integration.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Overview",slug:"/integrationss",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},c={},l=[];function u(e){const t={p:"p",...(0,i.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function d(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(u,{...e})}):u(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>s});var o=n(96540);const i={},r=o.createContext(i);function a(e){const t=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function s(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),o.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/00863b7a.c2d39e72.js b/assets/js/00863b7a.c2d39e72.js new file mode 100644 index 00000000..81edc6ea --- /dev/null +++ b/assets/js/00863b7a.c2d39e72.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8282],{71254:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>l});var o=n(74848),i=n(28453);const r={title:"Overview",slug:"/integrationss",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,a={id:"guides/integrations/overview-integration",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/integrations/overview-integration.mdx",sourceDirName:"guides/integrations",slug:"/integrationss",permalink:"/integrationss",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/overview-integration.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Overview",slug:"/integrationss",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},c={},l=[];function u(e){const t={p:"p",...(0,i.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function d(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(u,{...e})}):u(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>a});var o=n(96540);const i={},r=o.createContext(i);function s(e){const t=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),o.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/024311fd.754e23fa.js b/assets/js/024311fd.754e23fa.js deleted file mode 100644 index b97cefab..00000000 --- a/assets/js/024311fd.754e23fa.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9666],{28952:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>p,frontMatter:()=>l,metadata:()=>d,toc:()=>h});var i=s(74848),r=s(28453),t=s(11470),o=s(19365);const l={title:"Troubleshooting",slug:"/troubleshooting",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:21,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","troubleshooting","error codes","broken build","something amiss","unexpected token","undefined issue","permission denied"]},a=void 0,d={id:"guides/troubleshooting",title:"Troubleshooting",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/troubleshooting.mdx",sourceDirName:"guides",slug:"/troubleshooting",permalink:"/troubleshooting",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/troubleshooting.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:21,frontMatter:{title:"Troubleshooting",slug:"/troubleshooting",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:21,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","troubleshooting","error codes","broken build","something amiss","unexpected token","undefined issue","permission denied"]},sidebar:"guidesSidebar",previous:{title:"Continue Integration",permalink:"/integrations/continue"}},c={},h=[{value:"Broken Build",id:"broken-build",level:2},{value:"1. Uninstall Jan",id:"1-uninstall-jan",level:4},{value:"2. Delete Application Data, Cache, and User Data",id:"2-delete-application-data-cache-and-user-data",level:4},{value:"3. Additional Step for Versions Before 0.4.2",id:"3-additional-step-for-versions-before-042",level:4},{value:"4. Download the Latest Version",id:"4-download-the-latest-version",level:4},{value:"1. Uninstall Jan",id:"1-uninstall-jan-1",level:4},{value:"2. Delete Application Data, Cache, and User Data",id:"2-delete-application-data-cache-and-user-data-1",level:4},{value:"3. Additional Step for Versions Before 0.4.2",id:"3-additional-step-for-versions-before-042-1",level:4},{value:"4. Download the Latest Version",id:"4-download-the-latest-version-1",level:4},{value:"1. Uninstall Jan",id:"1-uninstall-jan-2",level:4},{value:"2. Delete Application Data, Cache, and User Data",id:"2-delete-application-data-cache-and-user-data-2",level:4},{value:"3. Additional Step for Versions Before 0.4.2",id:"3-additional-step-for-versions-before-042-2",level:4},{value:"4. Download the Latest Version",id:"4-download-the-latest-version-2",level:4},{value:"Troubleshooting NVIDIA GPU",id:"troubleshooting-nvidia-gpu",level:2},{value:"1. Ensure GPU Mode Requirements",id:"1-ensure-gpu-mode-requirements",level:4},{value:"NVIDIA Driver",id:"nvidia-driver",level:5},{value:"CUDA Toolkit",id:"cuda-toolkit",level:5},{value:"NVIDIA Driver",id:"nvidia-driver-1",level:5},{value:"CUDA Toolkit",id:"cuda-toolkit-1",level:5},{value:"Linux Specifics",id:"linux-specifics",level:5},{value:"2. Switch to GPU Mode",id:"2-switch-to-gpu-mode",level:4},{value:"Troubleshooting Tips",id:"troubleshooting-tips",level:5},{value:"3. Check GPU Settings",id:"3-check-gpu-settings",level:4},{value:"4. Restart Jan",id:"4-restart-jan",level:4},{value:"Troubleshooting Tips",id:"troubleshooting-tips-1",level:5},{value:"Tested Configurations",id:"tested-configurations",level:4},{value:"Common Issues and Solutions",id:"common-issues-and-solutions",level:4},{value:"How to Get Error Logs",id:"how-to-get-error-logs",level:2},{value:"Jan Application",id:"jan-application",level:4},{value:"Jan UI",id:"jan-ui",level:4},{value:"Jan API Server",id:"jan-api-server",level:4},{value:"Permission Denied",id:"permission-denied",level:2},{value:"Something's Amiss",id:"somethings-amiss",level:2},{value:"Undefined Issue",id:"undefined-issue",level:2},{value:"Unexpected Token",id:"unexpected-token",level:2}];function u(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h4:"h4",h5:"h5",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"broken-build",children:"Broken Build"}),"\n",(0,i.jsx)(n.p,{children:"To resolve the issue where your Jan is stuck in a broken build after installation."}),"\n",(0,i.jsxs)(t.A,{children:[(0,i.jsxs)(o.A,{value:"mac",label:"Mac",default:!0,children:[(0,i.jsx)(n.h4,{id:"1-uninstall-jan",children:"1. Uninstall Jan"}),(0,i.jsxs)(n.p,{children:["Delete Jan from your ",(0,i.jsx)(n.code,{children:"/Applications"})," folder."]}),(0,i.jsx)(n.h4,{id:"2-delete-application-data-cache-and-user-data",children:"2. Delete Application Data, Cache, and User Data"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-zsh",children:"# Step 1: Delete the application data\n## Newer versions\nrm -rf ~/Library/Application\\ Support/jan\n## Versions 0.2.0 and older\nrm -rf ~/Library/Application\\ Support/jan-electron\n\n# Step 2: Clear application cache\nrm -rf ~/Library/Caches/jan*\n\n# Step 3: Remove all user data\nrm -rf ~/jan\n"})}),(0,i.jsx)(n.h4,{id:"3-additional-step-for-versions-before-042",children:"3. Additional Step for Versions Before 0.4.2"}),(0,i.jsxs)(n.p,{children:["If you are using a version before ",(0,i.jsx)(n.code,{children:"0.4.2"}),", you need to run the following commands:"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-zsh",children:"ps aux | grep nitro\n# Looks for processes like `nitro` and `nitro_arm_64`, and kill them one by one by process ID\nkill -9 \n"})}),(0,i.jsx)(n.h4,{id:"4-download-the-latest-version",children:"4. Download the Latest Version"}),(0,i.jsxs)(n.p,{children:["Download the latest version of Jan from our ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"homepage"}),"."]})]}),(0,i.jsxs)(o.A,{value:"windows",label:"Windows",children:[(0,i.jsx)(n.h4,{id:"1-uninstall-jan-1",children:"1. Uninstall Jan"}),(0,i.jsxs)(n.p,{children:["To uninstall Jan on Windows, use the ",(0,i.jsx)(n.a,{href:"https://support.microsoft.com/en-us/windows/uninstall-or-remove-apps-and-programs-in-windows-4b55f974-2cc6-2d2b-d092-5905080eaf98",children:"Windows Control Panel"}),"."]}),(0,i.jsx)(n.h4,{id:"2-delete-application-data-cache-and-user-data-1",children:"2. Delete Application Data, Cache, and User Data"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Delete the `/Jan` directory in Windows's AppData\nrm -r C:\\Users\\%USERNAME%\\AppData\\Roaming\\Jan\n\n# Delete the `/Jan` directory in Windows's AppData\nrm -r C:\\Users\\%USERNAME%\\jan\n"})}),(0,i.jsx)(n.h4,{id:"3-additional-step-for-versions-before-042-1",children:"3. Additional Step for Versions Before 0.4.2"}),(0,i.jsxs)(n.p,{children:["If you are using a version before ",(0,i.jsx)(n.code,{children:"0.4.2"}),", you need to run the following commands:"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:'# Find the process ID (PID) of the nitro process by filtering the list by process name\ntasklist | findstr "nitro"\n# Once you have the PID of the process you want to terminate, run the `taskkill`\ntaskkill /F /PID \n'})}),(0,i.jsx)(n.h4,{id:"4-download-the-latest-version-1",children:"4. Download the Latest Version"}),(0,i.jsxs)(n.p,{children:["Download the latest version of Jan from our ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"homepage"}),"."]})]}),(0,i.jsxs)(o.A,{value:"linux",label:"Linux",children:[(0,i.jsx)(n.h4,{id:"1-uninstall-jan-2",children:"1. Uninstall Jan"}),(0,i.jsxs)(t.A,{groupId:"linux_type",children:[(0,i.jsxs)(o.A,{value:"linux_main",label:"Linux",children:[(0,i.jsx)(n.p,{children:"To uninstall Jan, you should use your package manager's uninstall or remove option."}),(0,i.jsx)(n.p,{children:"This will return your system to its state before the installation of Jan."}),(0,i.jsx)(n.p,{children:"This method can also reset all settings if you are experiencing any issues with Jan."})]}),(0,i.jsxs)(o.A,{value:"deb_ub",label:"Debian / Ubuntu",children:[(0,i.jsx)(n.p,{children:"To uninstall Jan, run the following command.MDXContent"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"sudo apt-get remove jan\n# where jan is the name of Jan package\n"})}),(0,i.jsx)(n.p,{children:"This will return your system to its state before the installation of Jan."}),(0,i.jsx)(n.p,{children:"This method can also be used to reset all settings if you are experiencing any issues with Jan."})]}),(0,i.jsxs)(o.A,{value:"other",label:"Others",children:[(0,i.jsxs)(n.p,{children:["To uninstall Jan, you can uninstall Jan by deleting the ",(0,i.jsx)(n.code,{children:".AppImage"})," file."]}),(0,i.jsxs)(n.p,{children:["If you wish to completely remove all user data associated with Jan after uninstallation, you can delete the user data at ",(0,i.jsx)(n.code,{children:"~/jan"}),"."]}),(0,i.jsx)(n.p,{children:"This method can also reset all settings if you are experiencing any issues with Jan."})]})]}),(0,i.jsx)(n.h4,{id:"2-delete-application-data-cache-and-user-data-2",children:"2. Delete Application Data, Cache, and User Data"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# You can delete the user data folders located at the following `~/jan`\nrm -rf ~/jan\n"})}),(0,i.jsx)(n.h4,{id:"3-additional-step-for-versions-before-042-2",children:"3. Additional Step for Versions Before 0.4.2"}),(0,i.jsxs)(n.p,{children:["If you are using a version before ",(0,i.jsx)(n.code,{children:"0.4.2"}),", you need to run the following commands:"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-zsh",children:"ps aux | grep nitro\n# Looks for processes like `nitro` and `nitro_arm_64`, and kill them one by one by process ID\nkill -9 \n"})}),(0,i.jsx)(n.h4,{id:"4-download-the-latest-version-2",children:"4. Download the Latest Version"}),(0,i.jsxs)(n.p,{children:["Download the latest version of Jan from our ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"homepage"}),"."]})]})]}),"\n",(0,i.jsx)(n.p,{children:"By following these steps, you can cleanly uninstall and reinstall Jan, ensuring a smooth and error-free experience with the latest version."}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"Before reinstalling Jan, ensure it's completely removed from all shared spaces if it's installed on multiple user accounts on your device."})}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting-nvidia-gpu",children:"Troubleshooting NVIDIA GPU"}),"\n",(0,i.jsx)(n.p,{children:"To resolve issues when the Jan app does not utilize the NVIDIA GPU on Windows and Linux systems."}),"\n",(0,i.jsx)(n.h4,{id:"1-ensure-gpu-mode-requirements",children:"1. Ensure GPU Mode Requirements"}),"\n",(0,i.jsxs)(t.A,{children:[(0,i.jsxs)(o.A,{value:"windows",label:"Windows",children:[(0,i.jsx)(n.h5,{id:"nvidia-driver",children:"NVIDIA Driver"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install an ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/Download/index.aspx",children:"NVIDIA Driver"})," supporting CUDA 11.7 or higher.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvidia-smi\n"})}),(0,i.jsx)(n.h5,{id:"cuda-toolkit",children:"CUDA Toolkit"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install a ",(0,i.jsx)(n.a,{href:"https://developer.nvidia.com/cuda-downloads",children:"CUDA toolkit"})," compatible with your NVIDIA driver.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvcc --version\n"})})]}),(0,i.jsxs)(o.A,{value:"linux",label:"Linux",children:[(0,i.jsx)(n.h5,{id:"nvidia-driver-1",children:"NVIDIA Driver"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install an ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/Download/index.aspx",children:"NVIDIA Driver"})," supporting CUDA 11.7 or higher.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvidia-smi\n"})}),(0,i.jsx)(n.h5,{id:"cuda-toolkit-1",children:"CUDA Toolkit"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install a ",(0,i.jsx)(n.a,{href:"https://developer.nvidia.com/cuda-downloads",children:"CUDA toolkit"})," compatible with your NVIDIA driver.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvcc --version\n"})}),(0,i.jsx)(n.h5,{id:"linux-specifics",children:"Linux Specifics"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Ensure that ",(0,i.jsx)(n.code,{children:"gcc-11"}),", ",(0,i.jsx)(n.code,{children:"g++-11"}),", ",(0,i.jsx)(n.code,{children:"cpp-11"}),", or higher is installed."]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["See ",(0,i.jsx)(n.a,{href:"https://gcc.gnu.org/projects/cxx-status.html#cxx17",children:"instructions"})," for Ubuntu installation."]}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.strong,{children:"Post-Installation Actions"}),": Add CUDA libraries to ",(0,i.jsx)(n.code,{children:"LD_LIBRARY_PATH"}),"."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Follow the ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html#post-installation-actions",children:"Post-installation Actions"})," instructions."]}),"\n"]}),"\n"]})]})]}),"\n",(0,i.jsx)(n.h4,{id:"2-switch-to-gpu-mode",children:"2. Switch to GPU Mode"}),"\n",(0,i.jsxs)(n.p,{children:["Jan defaults to CPU mode but automatically switches to GPU mode if your system supports it, selecting the GPU with the highest VRAM. Check this setting in ",(0,i.jsx)(n.code,{children:"Settings"})," > ",(0,i.jsx)(n.code,{children:"Advanced Settings"}),"."]}),"\n",(0,i.jsx)(n.h5,{id:"troubleshooting-tips",children:"Troubleshooting Tips"}),"\n",(0,i.jsx)(n.p,{children:"If GPU mode isn't enabled by default:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Confirm that you have installed an NVIDIA driver supporting CUDA 11.7 or higher. Refer to ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/deploy/cuda-compatibility/index.html#binary-compatibility__table-toolkit-driver",children:"CUDA compatibility"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Ensure compatibility of the CUDA toolkit with your NVIDIA driver. Refer to ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/deploy/cuda-compatibility/index.html#binary-compatibility__table-toolkit-driver",children:"CUDA compatibility"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["For Linux, add CUDA's ",(0,i.jsx)(n.code,{children:".so"})," libraries to the ",(0,i.jsx)(n.code,{children:"LD_LIBRARY_PATH"}),". For Windows, ensure that CUDA's ",(0,i.jsx)(n.code,{children:".dll"})," libraries are in the PATH. Refer to ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/cuda/cuda-installation-guide-microsoft-windows/index.html#environment-setup",children:"Windows setup"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"3-check-gpu-settings",children:"3. Check GPU Settings"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"Settings"})," > ",(0,i.jsx)(n.code,{children:"Advanced Settings"})," > ",(0,i.jsx)(n.code,{children:"Jan Data Folder"})," to access GPU settings."]}),"\n",(0,i.jsxs)(n.li,{children:["Open the ",(0,i.jsx)(n.code,{children:"settings.json"})," file in the ",(0,i.jsx)(n.code,{children:"settings"})," folder. Here's an example:"]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/settings/settings.json"',children:'{\n "notify": true,\n "run_mode": "gpu",\n "nvidia_driver": {\n "exist": true,\n "version": "531.18"\n },\n "cuda": {\n "exist": true,\n "version": "12"\n },\n "gpus": [\n {\n "id": "0",\n "vram": "12282"\n },\n {\n "id": "1",\n "vram": "6144"\n },\n {\n "id": "2",\n "vram": "6144"\n }\n ],\n "gpu_highest_vram": "0"\n}\n'})}),"\n",(0,i.jsx)(n.h4,{id:"4-restart-jan",children:"4. Restart Jan"}),"\n",(0,i.jsx)(n.p,{children:"Restart Jan application to make sure it works."}),"\n",(0,i.jsx)(n.h5,{id:"troubleshooting-tips-1",children:"Troubleshooting Tips"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Ensure ",(0,i.jsx)(n.code,{children:"nvidia_driver"})," and ",(0,i.jsx)(n.code,{children:"cuda"})," fields indicate installed software."]}),"\n",(0,i.jsxs)(n.li,{children:["If ",(0,i.jsx)(n.code,{children:"gpus"})," field is empty or lacks your GPU, check NVIDIA driver and CUDA toolkit installations."]}),"\n",(0,i.jsxs)(n.li,{children:["For further assistance, share the ",(0,i.jsx)(n.code,{children:"settings.json"})," file."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"tested-configurations",children:"Tested Configurations"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Windows 11 Pro 64-bit:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce RTX 4070ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.2"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 531.18 (Bare metal)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Ubuntu 22.04 LTS:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce RTX 4070ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.2"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 545 (Bare metal)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Ubuntu 20.04 LTS:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce GTX 1660ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.1"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 535 (Proxmox VM passthrough GPU)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Ubuntu 18.04 LTS:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce GTX 1660ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.1"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 535 (Proxmox VM passthrough GPU)"}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"common-issues-and-solutions",children:"Common Issues and Solutions"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["If the issue persists, try installing the ",(0,i.jsx)(n.a,{href:"/guides/quickstart/#nightly-releases",children:"Nightly version"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Ensure your (V)RAM is accessible; some users with virtual RAM may require additional configuration."}),"\n",(0,i.jsxs)(n.li,{children:["Seek assistance in ",(0,i.jsx)(n.a,{href:"https://discord.gg/mY69SZaMaC",children:"Jan Discord"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"how-to-get-error-logs",children:"How to Get Error Logs"}),"\n",(0,i.jsx)(n.p,{children:"To get the error logs of your Jan application, follow the steps below:"}),"\n",(0,i.jsx)(n.h4,{id:"jan-application",children:"Jan Application"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,i.jsxs)(n.li,{children:["Click the ",(0,i.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,i.jsxs)(n.li,{children:["Under the ",(0,i.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,i.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["On the ",(0,i.jsx)(n.strong,{children:"Jan Data Folder"})," click the ",(0,i.jsx)(n.strong,{children:"folder icon (\ud83d\udcc2)"})," to access the data."]}),"\n",(0,i.jsxs)(n.li,{children:["Click the ",(0,i.jsx)(n.strong,{children:"logs"})," folder."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"jan-ui",children:"Jan UI"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Open your Unix or Linux terminal."}),"\n",(0,i.jsx)(n.li,{children:"Use the following commands to get the recent 50 lines of log files:"}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"tail -n 50 ~/jan/logs/app.log\n\n"})}),"\n",(0,i.jsx)(n.h4,{id:"jan-api-server",children:"Jan API Server"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Open your Unix or Linux terminal."}),"\n",(0,i.jsx)(n.li,{children:"Use the following commands to get the recent 50 lines of log files:"}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"tail -n 50 ~/jan/logs/server.log\n\n"})}),"\n",(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsx)(n.p,{children:"Ensure to redact any private or sensitive information when sharing logs or error details."})}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"permission-denied",children:"Permission Denied"}),"\n",(0,i.jsx)(n.p,{children:"When running Jan, you might encounter the following error message:"}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{children:"Uncaught (in promise) Error: Error invoking layout-480796bff433a3a3.js:538 remote method 'installExtension':\nError Package /Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-assistant-extension-1.0.0.tgz does not contain a valid manifest:\nError EACCES: permission denied, mkdtemp '/Users/username/.npm/_cacache/tmp/ueCMn4'\n"})}),"\n",(0,i.jsx)(n.p,{children:"This error mainly caused by permission problem during installation. To resolve this issue, follow these steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:"Open your terminal."}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Execute the following command to change ownership of the ",(0,i.jsx)(n.code,{children:"~/.npm"})," directory to the current user:"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"sudo chown -R $(whoami) ~/.npm\n"})}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"This command ensures that the necessary permissions are granted for Jan installation, resolving the encountered error."}),"\n",(0,i.jsxs)(n.li,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]}),"\n"]})}),"\n",(0,i.jsx)(n.h2,{id:"somethings-amiss",children:"Something's Amiss"}),"\n",(0,i.jsx)(n.p,{children:"When you start a chat with a model and encounter with a Something's Amiss error, here's how to resolve it:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Ensure your OS is up to date."}),"\n",(0,i.jsx)(n.li,{children:"Choose a model smaller than 80% of your hardware's V/RAM. For example, on an 8GB machine, opt for models smaller than 6GB."}),"\n",(0,i.jsxs)(n.li,{children:["Install the latest ",(0,i.jsx)(n.a,{href:"/guides/quickstart/#nightly-releases",children:"Nightly release"})," or ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"clear the application cache"})," when reinstalling Jan."]}),"\n",(0,i.jsx)(n.li,{children:"Confirm your V/RAM accessibility, particularly if using virtual RAM."}),"\n",(0,i.jsxs)(n.li,{children:["Nvidia GPU users should download ",(0,i.jsx)(n.a,{href:"https://developer.nvidia.com/cuda-downloads",children:"CUDA"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Linux users, ensure your system meets the requirements of gcc 11, g++ 11, cpp 11, or higher. Refer to this ",(0,i.jsx)(n.a,{href:"/troubleshooting/#troubleshooting-nvidia-gpu",children:"link"})," for details."]}),"\n",(0,i.jsxs)(n.li,{children:["You might use the wrong port when you ",(0,i.jsx)(n.a,{href:"/troubleshooting/#how-to-get-error-logs",children:"check the app logs"})," and encounter the Bind address failed at 127.0.0.1:3928 error. To check the port status, try use the ",(0,i.jsx)(n.code,{children:"netstat"})," command, like the following:"]}),"\n"]}),"\n",(0,i.jsxs)(t.A,{children:[(0,i.jsx)(o.A,{value:"mac",label:"MacOS",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"netstat -an | grep 3928\n"})})}),(0,i.jsx)(o.A,{value:"windows",label:"Windows",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:'netstat -ano | find "3928" \ntasklist /fi "PID eq 3928"\n'})})}),(0,i.jsx)(o.A,{value:"linux",label:"Linux",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:'netstat -anpe | grep "3928" \n'})})})]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.code,{children:"Netstat"})," displays the contents of various network-related data structures for active connections"]})}),"\n",(0,i.jsxs)(n.admonition,{type:"tip",children:[(0,i.jsx)(n.p,{children:"Jan uses the following ports:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Nitro: ",(0,i.jsx)(n.code,{children:"3928"})]}),"\n",(0,i.jsxs)(n.li,{children:["Jan API Server: ",(0,i.jsx)(n.code,{children:"1337"})]}),"\n",(0,i.jsxs)(n.li,{children:["Jan Documentation: ",(0,i.jsx)(n.code,{children:"3001"})]}),"\n"]})]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"undefined-issue",children:"Undefined Issue"}),"\n",(0,i.jsxs)(n.p,{children:["Encountering an ",(0,i.jsx)(n.code,{children:"undefined issue"})," in Jan is caused by errors related to the Nitro tool or other internal processes. It can be resolved through the following steps:"]}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Clearing the Jan folder and then reopen the application to determine if the problem persists"}),"\n",(0,i.jsxs)(n.li,{children:["Manually run the nitro tool located at ",(0,i.jsx)(n.code,{children:"~/jan/extensions/@janhq/inference-nitro-extensions/dist/bin/(your-os)/nitro"})," to check for error messages."]}),"\n",(0,i.jsx)(n.li,{children:"Address any nitro error messages that are identified and reassess the persistence of the issue."}),"\n",(0,i.jsx)(n.li,{children:"Reopen Jan to determine if the problem has been resolved after addressing any identified errors."}),"\n",(0,i.jsxs)(n.li,{children:["If the issue persists, please share the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#how-to-get-error-logs",children:"app logs"})," via ",(0,i.jsx)(n.a,{href:"https://discord.gg/mY69SZaMaC",children:"Jan Discord"})," for further assistance and troubleshooting."]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"unexpected-token",children:"Unexpected Token"}),"\n",(0,i.jsxs)(n.p,{children:["Encountering the ",(0,i.jsx)(n.code,{children:"Unexpected token"})," error when initiating a chat with OpenAI models mainly caused by either your OpenAI key or where you access your OpenAI from. This issue can be solved through the following steps:"]}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Obtain an OpenAI API key from ",(0,i.jsx)(n.a,{href:"https://platform.openai.com/",children:"OpenAI's developer platform"})," and integrate it into your application."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:"Trying a VPN could potentially solve the issue, especially if it's related to region locking for accessing OpenAI services. By connecting through a VPN, you may bypass such restrictions and successfully initiate chats with OpenAI models."}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})})]})}function p(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(u,{...e})}):u(e)}},19365:(e,n,s)=>{s.d(n,{A:()=>o});s(96540);var i=s(18215);const r={tabItem:"tabItem_Ymn6"};var t=s(74848);function o(e){let{children:n,hidden:s,className:o}=e;return(0,t.jsx)("div",{role:"tabpanel",className:(0,i.A)(r.tabItem,o),hidden:s,children:n})}},11470:(e,n,s)=>{s.d(n,{A:()=>w});var i=s(96540),r=s(18215),t=s(23104),o=s(56347),l=s(205),a=s(57485),d=s(31682),c=s(89466);function h(e){return i.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,i.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function u(e){const{values:n,children:s}=e;return(0,i.useMemo)((()=>{const e=n??function(e){return h(e).map((e=>{let{props:{value:n,label:s,attributes:i,default:r}}=e;return{value:n,label:s,attributes:i,default:r}}))}(s);return function(e){const n=(0,d.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,s])}function p(e){let{value:n,tabValues:s}=e;return s.some((e=>e.value===n))}function x(e){let{queryString:n=!1,groupId:s}=e;const r=(0,o.W6)(),t=function(e){let{queryString:n=!1,groupId:s}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!s)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return s??null}({queryString:n,groupId:s});return[(0,a.aZ)(t),(0,i.useCallback)((e=>{if(!t)return;const n=new URLSearchParams(r.location.search);n.set(t,e),r.replace({...r.location,search:n.toString()})}),[t,r])]}function j(e){const{defaultValue:n,queryString:s=!1,groupId:r}=e,t=u(e),[o,a]=(0,i.useState)((()=>function(e){let{defaultValue:n,tabValues:s}=e;if(0===s.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:s}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${s.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const i=s.find((e=>e.default))??s[0];if(!i)throw new Error("Unexpected error: 0 tabValues");return i.value}({defaultValue:n,tabValues:t}))),[d,h]=x({queryString:s,groupId:r}),[j,g]=function(e){let{groupId:n}=e;const s=function(e){return e?`docusaurus.tab.${e}`:null}(n),[r,t]=(0,c.Dv)(s);return[r,(0,i.useCallback)((e=>{s&&t.set(e)}),[s,t])]}({groupId:r}),m=(()=>{const e=d??j;return p({value:e,tabValues:t})?e:null})();(0,l.A)((()=>{m&&a(m)}),[m]);return{selectedValue:o,selectValue:(0,i.useCallback)((e=>{if(!p({value:e,tabValues:t}))throw new Error(`Can't select invalid tab value=${e}`);a(e),h(e),g(e)}),[h,g,t]),tabValues:t}}var g=s(92303);const m={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var f=s(74848);function v(e){let{className:n,block:s,selectedValue:i,selectValue:o,tabValues:l}=e;const a=[],{blockElementScrollPositionUntilNextRender:d}=(0,t.a_)(),c=e=>{const n=e.currentTarget,s=a.indexOf(n),r=l[s].value;r!==i&&(d(n),o(r))},h=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const s=a.indexOf(e.currentTarget)+1;n=a[s]??a[0];break}case"ArrowLeft":{const s=a.indexOf(e.currentTarget)-1;n=a[s]??a[a.length-1];break}}n?.focus()};return(0,f.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,r.A)("tabs",{"tabs--block":s},n),children:l.map((e=>{let{value:n,label:s,attributes:t}=e;return(0,f.jsx)("li",{role:"tab",tabIndex:i===n?0:-1,"aria-selected":i===n,ref:e=>a.push(e),onKeyDown:h,onClick:c,...t,className:(0,r.A)("tabs__item",m.tabItem,t?.className,{"tabs__item--active":i===n}),children:s??n},n)}))})}function b(e){let{lazy:n,children:s,selectedValue:r}=e;const t=(Array.isArray(s)?s:[s]).filter(Boolean);if(n){const e=t.find((e=>e.props.value===r));return e?(0,i.cloneElement)(e,{className:"margin-top--md"}):null}return(0,f.jsx)("div",{className:"margin-top--md",children:t.map(((e,n)=>(0,i.cloneElement)(e,{key:n,hidden:e.props.value!==r})))})}function y(e){const n=j(e);return(0,f.jsxs)("div",{className:(0,r.A)("tabs-container",m.tabList),children:[(0,f.jsx)(v,{...e,...n}),(0,f.jsx)(b,{...e,...n})]})}function w(e){const n=(0,g.A)();return(0,f.jsx)(y,{...e,children:h(e.children)},String(n))}},28453:(e,n,s)=>{s.d(n,{R:()=>o,x:()=>l});var i=s(96540);const r={},t=i.createContext(r);function o(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/024311fd.9e3819f5.js b/assets/js/024311fd.9e3819f5.js new file mode 100644 index 00000000..1d8e43a8 --- /dev/null +++ b/assets/js/024311fd.9e3819f5.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9666],{28952:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>p,frontMatter:()=>l,metadata:()=>d,toc:()=>h});var i=s(74848),r=s(28453),t=s(11470),o=s(19365);const l={title:"Troubleshooting",slug:"/troubleshooting",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:21,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","troubleshooting","error codes","broken build","something amiss","unexpected token","undefined issue","permission denied"]},a=void 0,d={id:"guides/troubleshooting",title:"Troubleshooting",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/troubleshooting.mdx",sourceDirName:"guides",slug:"/troubleshooting",permalink:"/troubleshooting",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/troubleshooting.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:21,frontMatter:{title:"Troubleshooting",slug:"/troubleshooting",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:21,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","troubleshooting","error codes","broken build","something amiss","unexpected token","undefined issue","permission denied"]},sidebar:"guidesSidebar",previous:{title:"Continue Integration",permalink:"/integrations/continue"}},c={},h=[{value:"Broken Build",id:"broken-build",level:2},{value:"1. Uninstall Jan",id:"1-uninstall-jan",level:4},{value:"2. Delete Application Data, Cache, and User Data",id:"2-delete-application-data-cache-and-user-data",level:4},{value:"3. Additional Step for Versions Before 0.4.2",id:"3-additional-step-for-versions-before-042",level:4},{value:"4. Download the Latest Version",id:"4-download-the-latest-version",level:4},{value:"1. Uninstall Jan",id:"1-uninstall-jan-1",level:4},{value:"2. Delete Application Data, Cache, and User Data",id:"2-delete-application-data-cache-and-user-data-1",level:4},{value:"3. Additional Step for Versions Before 0.4.2",id:"3-additional-step-for-versions-before-042-1",level:4},{value:"4. Download the Latest Version",id:"4-download-the-latest-version-1",level:4},{value:"1. Uninstall Jan",id:"1-uninstall-jan-2",level:4},{value:"2. Delete Application Data, Cache, and User Data",id:"2-delete-application-data-cache-and-user-data-2",level:4},{value:"3. Additional Step for Versions Before 0.4.2",id:"3-additional-step-for-versions-before-042-2",level:4},{value:"4. Download the Latest Version",id:"4-download-the-latest-version-2",level:4},{value:"Troubleshooting NVIDIA GPU",id:"troubleshooting-nvidia-gpu",level:2},{value:"1. Ensure GPU Mode Requirements",id:"1-ensure-gpu-mode-requirements",level:4},{value:"NVIDIA Driver",id:"nvidia-driver",level:5},{value:"CUDA Toolkit",id:"cuda-toolkit",level:5},{value:"NVIDIA Driver",id:"nvidia-driver-1",level:5},{value:"CUDA Toolkit",id:"cuda-toolkit-1",level:5},{value:"Linux Specifics",id:"linux-specifics",level:5},{value:"2. Switch to GPU Mode",id:"2-switch-to-gpu-mode",level:4},{value:"Troubleshooting Tips",id:"troubleshooting-tips",level:5},{value:"3. Check GPU Settings",id:"3-check-gpu-settings",level:4},{value:"4. Restart Jan",id:"4-restart-jan",level:4},{value:"Troubleshooting Tips",id:"troubleshooting-tips-1",level:5},{value:"Tested Configurations",id:"tested-configurations",level:4},{value:"Common Issues and Solutions",id:"common-issues-and-solutions",level:4},{value:"How to Get Error Logs",id:"how-to-get-error-logs",level:2},{value:"Jan Application",id:"jan-application",level:4},{value:"Jan UI",id:"jan-ui",level:4},{value:"Jan API Server",id:"jan-api-server",level:4},{value:"Permission Denied",id:"permission-denied",level:2},{value:"Something's Amiss",id:"somethings-amiss",level:2},{value:"Undefined Issue",id:"undefined-issue",level:2},{value:"Unexpected Token",id:"unexpected-token",level:2}];function u(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h4:"h4",h5:"h5",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"broken-build",children:"Broken Build"}),"\n",(0,i.jsx)(n.p,{children:"To resolve the issue where your Jan is stuck in a broken build after installation."}),"\n",(0,i.jsxs)(t.A,{children:[(0,i.jsxs)(o.A,{value:"mac",label:"Mac",default:!0,children:[(0,i.jsx)(n.h4,{id:"1-uninstall-jan",children:"1. Uninstall Jan"}),(0,i.jsxs)(n.p,{children:["Delete Jan from your ",(0,i.jsx)(n.code,{children:"/Applications"})," folder."]}),(0,i.jsx)(n.h4,{id:"2-delete-application-data-cache-and-user-data",children:"2. Delete Application Data, Cache, and User Data"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-zsh",children:"# Step 1: Delete the application data\n## Newer versions\nrm -rf ~/Library/Application\\ Support/jan\n## Versions 0.2.0 and older\nrm -rf ~/Library/Application\\ Support/jan-electron\n\n# Step 2: Clear application cache\nrm -rf ~/Library/Caches/jan*\n\n# Step 3: Remove all user data\nrm -rf ~/jan\n"})}),(0,i.jsx)(n.h4,{id:"3-additional-step-for-versions-before-042",children:"3. Additional Step for Versions Before 0.4.2"}),(0,i.jsxs)(n.p,{children:["If you are using a version before ",(0,i.jsx)(n.code,{children:"0.4.2"}),", you need to run the following commands:"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-zsh",children:"ps aux | grep nitro\n# Looks for processes like `nitro` and `nitro_arm_64`, and kill them one by one by process ID\nkill -9 \n"})}),(0,i.jsx)(n.h4,{id:"4-download-the-latest-version",children:"4. Download the Latest Version"}),(0,i.jsxs)(n.p,{children:["Download the latest version of Jan from our ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"homepage"}),"."]})]}),(0,i.jsxs)(o.A,{value:"windows",label:"Windows",children:[(0,i.jsx)(n.h4,{id:"1-uninstall-jan-1",children:"1. Uninstall Jan"}),(0,i.jsxs)(n.p,{children:["To uninstall Jan on Windows, use the ",(0,i.jsx)(n.a,{href:"https://support.microsoft.com/en-us/windows/uninstall-or-remove-apps-and-programs-in-windows-4b55f974-2cc6-2d2b-d092-5905080eaf98",children:"Windows Control Panel"}),"."]}),(0,i.jsx)(n.h4,{id:"2-delete-application-data-cache-and-user-data-1",children:"2. Delete Application Data, Cache, and User Data"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Delete the `/Jan` directory in Windows's AppData\nrm -r C:\\Users\\%USERNAME%\\AppData\\Roaming\\Jan\n\n# Delete the `/Jan` directory in Windows's AppData\nrm -r C:\\Users\\%USERNAME%\\jan\n"})}),(0,i.jsx)(n.h4,{id:"3-additional-step-for-versions-before-042-1",children:"3. Additional Step for Versions Before 0.4.2"}),(0,i.jsxs)(n.p,{children:["If you are using a version before ",(0,i.jsx)(n.code,{children:"0.4.2"}),", you need to run the following commands:"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:'# Find the process ID (PID) of the nitro process by filtering the list by process name\ntasklist | findstr "nitro"\n# Once you have the PID of the process you want to terminate, run the `taskkill`\ntaskkill /F /PID \n'})}),(0,i.jsx)(n.h4,{id:"4-download-the-latest-version-1",children:"4. Download the Latest Version"}),(0,i.jsxs)(n.p,{children:["Download the latest version of Jan from our ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"homepage"}),"."]})]}),(0,i.jsxs)(o.A,{value:"linux",label:"Linux",children:[(0,i.jsx)(n.h4,{id:"1-uninstall-jan-2",children:"1. Uninstall Jan"}),(0,i.jsxs)(t.A,{groupId:"linux_type",children:[(0,i.jsxs)(o.A,{value:"linux_main",label:"Linux",children:[(0,i.jsx)(n.p,{children:"To uninstall Jan, you should use your package manager's uninstall or remove option."}),(0,i.jsx)(n.p,{children:"This will return your system to its state before the installation of Jan."}),(0,i.jsx)(n.p,{children:"This method can also reset all settings if you are experiencing any issues with Jan."})]}),(0,i.jsxs)(o.A,{value:"deb_ub",label:"Debian / Ubuntu",children:[(0,i.jsx)(n.p,{children:"To uninstall Jan, run the following command.MDXContent"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"sudo apt-get remove jan\n# where jan is the name of Jan package\n"})}),(0,i.jsx)(n.p,{children:"This will return your system to its state before the installation of Jan."}),(0,i.jsx)(n.p,{children:"This method can also be used to reset all settings if you are experiencing any issues with Jan."})]}),(0,i.jsxs)(o.A,{value:"other",label:"Others",children:[(0,i.jsxs)(n.p,{children:["To uninstall Jan, you can uninstall Jan by deleting the ",(0,i.jsx)(n.code,{children:".AppImage"})," file."]}),(0,i.jsxs)(n.p,{children:["If you wish to completely remove all user data associated with Jan after uninstallation, you can delete the user data at ",(0,i.jsx)(n.code,{children:"~/jan"}),"."]}),(0,i.jsx)(n.p,{children:"This method can also reset all settings if you are experiencing any issues with Jan."})]})]}),(0,i.jsx)(n.h4,{id:"2-delete-application-data-cache-and-user-data-2",children:"2. Delete Application Data, Cache, and User Data"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# You can delete the user data folders located at the following `~/jan`\nrm -rf ~/jan\n"})}),(0,i.jsx)(n.h4,{id:"3-additional-step-for-versions-before-042-2",children:"3. Additional Step for Versions Before 0.4.2"}),(0,i.jsxs)(n.p,{children:["If you are using a version before ",(0,i.jsx)(n.code,{children:"0.4.2"}),", you need to run the following commands:"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-zsh",children:"ps aux | grep nitro\n# Looks for processes like `nitro` and `nitro_arm_64`, and kill them one by one by process ID\nkill -9 \n"})}),(0,i.jsx)(n.h4,{id:"4-download-the-latest-version-2",children:"4. Download the Latest Version"}),(0,i.jsxs)(n.p,{children:["Download the latest version of Jan from our ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"homepage"}),"."]})]})]}),"\n",(0,i.jsx)(n.p,{children:"By following these steps, you can cleanly uninstall and reinstall Jan, ensuring a smooth and error-free experience with the latest version."}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"Before reinstalling Jan, ensure it's completely removed from all shared spaces if it's installed on multiple user accounts on your device."})}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting-nvidia-gpu",children:"Troubleshooting NVIDIA GPU"}),"\n",(0,i.jsx)(n.p,{children:"To resolve issues when the Jan app does not utilize the NVIDIA GPU on Windows and Linux systems."}),"\n",(0,i.jsx)(n.h4,{id:"1-ensure-gpu-mode-requirements",children:"1. Ensure GPU Mode Requirements"}),"\n",(0,i.jsxs)(t.A,{children:[(0,i.jsxs)(o.A,{value:"windows",label:"Windows",children:[(0,i.jsx)(n.h5,{id:"nvidia-driver",children:"NVIDIA Driver"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install an ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/Download/index.aspx",children:"NVIDIA Driver"})," supporting CUDA 11.7 or higher.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvidia-smi\n"})}),(0,i.jsx)(n.h5,{id:"cuda-toolkit",children:"CUDA Toolkit"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install a ",(0,i.jsx)(n.a,{href:"https://developer.nvidia.com/cuda-downloads",children:"CUDA toolkit"})," compatible with your NVIDIA driver.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvcc --version\n"})})]}),(0,i.jsxs)(o.A,{value:"linux",label:"Linux",children:[(0,i.jsx)(n.h5,{id:"nvidia-driver-1",children:"NVIDIA Driver"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install an ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/Download/index.aspx",children:"NVIDIA Driver"})," supporting CUDA 11.7 or higher.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvidia-smi\n"})}),(0,i.jsx)(n.h5,{id:"cuda-toolkit-1",children:"CUDA Toolkit"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Install a ",(0,i.jsx)(n.a,{href:"https://developer.nvidia.com/cuda-downloads",children:"CUDA toolkit"})," compatible with your NVIDIA driver.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Use the following command to verify the installation:"}),"\n"]}),"\n"]}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"nvcc --version\n"})}),(0,i.jsx)(n.h5,{id:"linux-specifics",children:"Linux Specifics"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Ensure that ",(0,i.jsx)(n.code,{children:"gcc-11"}),", ",(0,i.jsx)(n.code,{children:"g++-11"}),", ",(0,i.jsx)(n.code,{children:"cpp-11"}),", or higher is installed."]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["See ",(0,i.jsx)(n.a,{href:"https://gcc.gnu.org/projects/cxx-status.html#cxx17",children:"instructions"})," for Ubuntu installation."]}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.strong,{children:"Post-Installation Actions"}),": Add CUDA libraries to ",(0,i.jsx)(n.code,{children:"LD_LIBRARY_PATH"}),"."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Follow the ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html#post-installation-actions",children:"Post-installation Actions"})," instructions."]}),"\n"]}),"\n"]})]})]}),"\n",(0,i.jsx)(n.h4,{id:"2-switch-to-gpu-mode",children:"2. Switch to GPU Mode"}),"\n",(0,i.jsxs)(n.p,{children:["Jan defaults to CPU mode but automatically switches to GPU mode if your system supports it, selecting the GPU with the highest VRAM. Check this setting in ",(0,i.jsx)(n.code,{children:"Settings"})," > ",(0,i.jsx)(n.code,{children:"Advanced Settings"}),"."]}),"\n",(0,i.jsx)(n.h5,{id:"troubleshooting-tips",children:"Troubleshooting Tips"}),"\n",(0,i.jsx)(n.p,{children:"If GPU mode isn't enabled by default:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Confirm that you have installed an NVIDIA driver supporting CUDA 11.7 or higher. Refer to ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/deploy/cuda-compatibility/index.html#binary-compatibility__table-toolkit-driver",children:"CUDA compatibility"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Ensure compatibility of the CUDA toolkit with your NVIDIA driver. Refer to ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/deploy/cuda-compatibility/index.html#binary-compatibility__table-toolkit-driver",children:"CUDA compatibility"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["For Linux, add CUDA's ",(0,i.jsx)(n.code,{children:".so"})," libraries to the ",(0,i.jsx)(n.code,{children:"LD_LIBRARY_PATH"}),". For Windows, ensure that CUDA's ",(0,i.jsx)(n.code,{children:".dll"})," libraries are in the PATH. Refer to ",(0,i.jsx)(n.a,{href:"https://docs.nvidia.com/cuda/cuda-installation-guide-microsoft-windows/index.html#environment-setup",children:"Windows setup"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"3-check-gpu-settings",children:"3. Check GPU Settings"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"Settings"})," > ",(0,i.jsx)(n.code,{children:"Advanced Settings"})," > ",(0,i.jsx)(n.code,{children:"Jan Data Folder"})," to access GPU settings."]}),"\n",(0,i.jsxs)(n.li,{children:["Open the ",(0,i.jsx)(n.code,{children:"settings.json"})," file in the ",(0,i.jsx)(n.code,{children:"settings"})," folder. Here's an example:"]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/settings/settings.json"',children:'{\n "notify": true,\n "run_mode": "gpu",\n "nvidia_driver": {\n "exist": true,\n "version": "531.18"\n },\n "cuda": {\n "exist": true,\n "version": "12"\n },\n "gpus": [\n {\n "id": "0",\n "vram": "12282"\n },\n {\n "id": "1",\n "vram": "6144"\n },\n {\n "id": "2",\n "vram": "6144"\n }\n ],\n "gpu_highest_vram": "0"\n}\n'})}),"\n",(0,i.jsx)(n.h4,{id:"4-restart-jan",children:"4. Restart Jan"}),"\n",(0,i.jsx)(n.p,{children:"Restart Jan application to make sure it works."}),"\n",(0,i.jsx)(n.h5,{id:"troubleshooting-tips-1",children:"Troubleshooting Tips"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Ensure ",(0,i.jsx)(n.code,{children:"nvidia_driver"})," and ",(0,i.jsx)(n.code,{children:"cuda"})," fields indicate installed software."]}),"\n",(0,i.jsxs)(n.li,{children:["If ",(0,i.jsx)(n.code,{children:"gpus"})," field is empty or lacks your GPU, check NVIDIA driver and CUDA toolkit installations."]}),"\n",(0,i.jsxs)(n.li,{children:["For further assistance, share the ",(0,i.jsx)(n.code,{children:"settings.json"})," file."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"tested-configurations",children:"Tested Configurations"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Windows 11 Pro 64-bit:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce RTX 4070ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.2"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 531.18 (Bare metal)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Ubuntu 22.04 LTS:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce RTX 4070ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.2"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 545 (Bare metal)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Ubuntu 20.04 LTS:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce GTX 1660ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.1"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 535 (Proxmox VM passthrough GPU)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Ubuntu 18.04 LTS:"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"GPU: NVIDIA GeForce GTX 1660ti"}),"\n",(0,i.jsx)(n.li,{children:"CUDA: 12.1"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver: 535 (Proxmox VM passthrough GPU)"}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"common-issues-and-solutions",children:"Common Issues and Solutions"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["If the issue persists, try installing the ",(0,i.jsx)(n.a,{href:"/guides/quickstart/#nightly-releases",children:"Nightly version"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Ensure your (V)RAM is accessible; some users with virtual RAM may require additional configuration."}),"\n",(0,i.jsxs)(n.li,{children:["Seek assistance in ",(0,i.jsx)(n.a,{href:"https://discord.gg/mY69SZaMaC",children:"Jan Discord"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"how-to-get-error-logs",children:"How to Get Error Logs"}),"\n",(0,i.jsx)(n.p,{children:"To get the error logs of your Jan application, follow the steps below:"}),"\n",(0,i.jsx)(n.h4,{id:"jan-application",children:"Jan Application"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,i.jsxs)(n.li,{children:["Click the ",(0,i.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,i.jsxs)(n.li,{children:["Under the ",(0,i.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,i.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["On the ",(0,i.jsx)(n.strong,{children:"Jan Data Folder"})," click the ",(0,i.jsx)(n.strong,{children:"folder icon (\ud83d\udcc2)"})," to access the data."]}),"\n",(0,i.jsxs)(n.li,{children:["Click the ",(0,i.jsx)(n.strong,{children:"logs"})," folder."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"jan-ui",children:"Jan UI"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Open your Unix or Linux terminal."}),"\n",(0,i.jsx)(n.li,{children:"Use the following commands to get the recent 50 lines of log files:"}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"tail -n 50 ~/jan/logs/app.log\n\n"})}),"\n",(0,i.jsx)(n.h4,{id:"jan-api-server",children:"Jan API Server"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Open your Unix or Linux terminal."}),"\n",(0,i.jsx)(n.li,{children:"Use the following commands to get the recent 50 lines of log files:"}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"tail -n 50 ~/jan/logs/server.log\n\n"})}),"\n",(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsx)(n.p,{children:"Ensure to redact any private or sensitive information when sharing logs or error details."})}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"permission-denied",children:"Permission Denied"}),"\n",(0,i.jsx)(n.p,{children:"When running Jan, you might encounter the following error message:"}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{children:"Uncaught (in promise) Error: Error invoking layout-480796bff433a3a3.js:538 remote method 'installExtension':\nError Package /Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-assistant-extension-1.0.0.tgz does not contain a valid manifest:\nError EACCES: permission denied, mkdtemp '/Users/username/.npm/_cacache/tmp/ueCMn4'\n"})}),"\n",(0,i.jsx)(n.p,{children:"This error mainly caused by permission problem during installation. To resolve this issue, follow these steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:"Open your terminal."}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Execute the following command to change ownership of the ",(0,i.jsx)(n.code,{children:"~/.npm"})," directory to the current user:"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"sudo chown -R $(whoami) ~/.npm\n"})}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"This command ensures that the necessary permissions are granted for Jan installation, resolving the encountered error."}),"\n",(0,i.jsxs)(n.li,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]}),"\n"]})}),"\n",(0,i.jsx)(n.h2,{id:"somethings-amiss",children:"Something's Amiss"}),"\n",(0,i.jsx)(n.p,{children:"When you start a chat with a model and encounter with a Something's Amiss error, here's how to resolve it:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Ensure your OS is up to date."}),"\n",(0,i.jsx)(n.li,{children:"Choose a model smaller than 80% of your hardware's V/RAM. For example, on an 8GB machine, opt for models smaller than 6GB."}),"\n",(0,i.jsxs)(n.li,{children:["Install the latest ",(0,i.jsx)(n.a,{href:"/guides/quickstart/#nightly-releases",children:"Nightly release"})," or ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"clear the application cache"})," when reinstalling Jan."]}),"\n",(0,i.jsx)(n.li,{children:"Confirm your V/RAM accessibility, particularly if using virtual RAM."}),"\n",(0,i.jsxs)(n.li,{children:["Nvidia GPU users should download ",(0,i.jsx)(n.a,{href:"https://developer.nvidia.com/cuda-downloads",children:"CUDA"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Linux users, ensure your system meets the requirements of gcc 11, g++ 11, cpp 11, or higher. Refer to this ",(0,i.jsx)(n.a,{href:"/troubleshooting/#troubleshooting-nvidia-gpu",children:"link"})," for details."]}),"\n",(0,i.jsxs)(n.li,{children:["You might use the wrong port when you ",(0,i.jsx)(n.a,{href:"/troubleshooting/#how-to-get-error-logs",children:"check the app logs"})," and encounter the Bind address failed at 127.0.0.1:3928 error. To check the port status, try use the ",(0,i.jsx)(n.code,{children:"netstat"})," command, like the following:"]}),"\n"]}),"\n",(0,i.jsxs)(t.A,{children:[(0,i.jsx)(o.A,{value:"mac",label:"MacOS",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"netstat -an | grep 3928\n"})})}),(0,i.jsx)(o.A,{value:"windows",label:"Windows",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:'netstat -ano | find "3928" \ntasklist /fi "PID eq 3928"\n'})})}),(0,i.jsx)(o.A,{value:"linux",label:"Linux",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:'netstat -anpe | grep "3928" \n'})})})]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.code,{children:"Netstat"})," displays the contents of various network-related data structures for active connections"]})}),"\n",(0,i.jsxs)(n.admonition,{type:"tip",children:[(0,i.jsx)(n.p,{children:"Jan uses the following ports:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Nitro: ",(0,i.jsx)(n.code,{children:"3928"})]}),"\n",(0,i.jsxs)(n.li,{children:["Jan API Server: ",(0,i.jsx)(n.code,{children:"1337"})]}),"\n",(0,i.jsxs)(n.li,{children:["Jan Documentation: ",(0,i.jsx)(n.code,{children:"3001"})]}),"\n"]})]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"undefined-issue",children:"Undefined Issue"}),"\n",(0,i.jsxs)(n.p,{children:["Encountering an ",(0,i.jsx)(n.code,{children:"undefined issue"})," in Jan is caused by errors related to the Nitro tool or other internal processes. It can be resolved through the following steps:"]}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Clearing the Jan folder and then reopen the application to determine if the problem persists"}),"\n",(0,i.jsxs)(n.li,{children:["Manually run the nitro tool located at ",(0,i.jsx)(n.code,{children:"~/jan/extensions/@janhq/inference-nitro-extensions/dist/bin/(your-os)/nitro"})," to check for error messages."]}),"\n",(0,i.jsx)(n.li,{children:"Address any nitro error messages that are identified and reassess the persistence of the issue."}),"\n",(0,i.jsx)(n.li,{children:"Reopen Jan to determine if the problem has been resolved after addressing any identified errors."}),"\n",(0,i.jsxs)(n.li,{children:["If the issue persists, please share the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#how-to-get-error-logs",children:"app logs"})," via ",(0,i.jsx)(n.a,{href:"https://discord.gg/mY69SZaMaC",children:"Jan Discord"})," for further assistance and troubleshooting."]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"unexpected-token",children:"Unexpected Token"}),"\n",(0,i.jsxs)(n.p,{children:["Encountering the ",(0,i.jsx)(n.code,{children:"Unexpected token"})," error when initiating a chat with OpenAI models mainly caused by either your OpenAI key or where you access your OpenAI from. This issue can be solved through the following steps:"]}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Obtain an OpenAI API key from ",(0,i.jsx)(n.a,{href:"https://platform.openai.com/",children:"OpenAI's developer platform"})," and integrate it into your application."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:"Trying a VPN could potentially solve the issue, especially if it's related to region locking for accessing OpenAI services. By connecting through a VPN, you may bypass such restrictions and successfully initiate chats with OpenAI models."}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["If you have any questions or are looking for support, please don't hesitate to contact us via our ",(0,i.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," or create a new issue in our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/new/choose",children:"GitHub repository"}),"."]})})]})}function p(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(u,{...e})}):u(e)}},19365:(e,n,s)=>{s.d(n,{A:()=>o});s(96540);var i=s(18215);const r={tabItem:"tabItem_Ymn6"};var t=s(74848);function o(e){let{children:n,hidden:s,className:o}=e;return(0,t.jsx)("div",{role:"tabpanel",className:(0,i.A)(r.tabItem,o),hidden:s,children:n})}},11470:(e,n,s)=>{s.d(n,{A:()=>w});var i=s(96540),r=s(18215),t=s(23104),o=s(56347),l=s(205),a=s(57485),d=s(31682),c=s(89466);function h(e){return i.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,i.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function u(e){const{values:n,children:s}=e;return(0,i.useMemo)((()=>{const e=n??function(e){return h(e).map((e=>{let{props:{value:n,label:s,attributes:i,default:r}}=e;return{value:n,label:s,attributes:i,default:r}}))}(s);return function(e){const n=(0,d.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,s])}function p(e){let{value:n,tabValues:s}=e;return s.some((e=>e.value===n))}function x(e){let{queryString:n=!1,groupId:s}=e;const r=(0,o.W6)(),t=function(e){let{queryString:n=!1,groupId:s}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!s)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return s??null}({queryString:n,groupId:s});return[(0,a.aZ)(t),(0,i.useCallback)((e=>{if(!t)return;const n=new URLSearchParams(r.location.search);n.set(t,e),r.replace({...r.location,search:n.toString()})}),[t,r])]}function j(e){const{defaultValue:n,queryString:s=!1,groupId:r}=e,t=u(e),[o,a]=(0,i.useState)((()=>function(e){let{defaultValue:n,tabValues:s}=e;if(0===s.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:s}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${s.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const i=s.find((e=>e.default))??s[0];if(!i)throw new Error("Unexpected error: 0 tabValues");return i.value}({defaultValue:n,tabValues:t}))),[d,h]=x({queryString:s,groupId:r}),[j,g]=function(e){let{groupId:n}=e;const s=function(e){return e?`docusaurus.tab.${e}`:null}(n),[r,t]=(0,c.Dv)(s);return[r,(0,i.useCallback)((e=>{s&&t.set(e)}),[s,t])]}({groupId:r}),m=(()=>{const e=d??j;return p({value:e,tabValues:t})?e:null})();(0,l.A)((()=>{m&&a(m)}),[m]);return{selectedValue:o,selectValue:(0,i.useCallback)((e=>{if(!p({value:e,tabValues:t}))throw new Error(`Can't select invalid tab value=${e}`);a(e),h(e),g(e)}),[h,g,t]),tabValues:t}}var g=s(92303);const m={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var f=s(74848);function v(e){let{className:n,block:s,selectedValue:i,selectValue:o,tabValues:l}=e;const a=[],{blockElementScrollPositionUntilNextRender:d}=(0,t.a_)(),c=e=>{const n=e.currentTarget,s=a.indexOf(n),r=l[s].value;r!==i&&(d(n),o(r))},h=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const s=a.indexOf(e.currentTarget)+1;n=a[s]??a[0];break}case"ArrowLeft":{const s=a.indexOf(e.currentTarget)-1;n=a[s]??a[a.length-1];break}}n?.focus()};return(0,f.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,r.A)("tabs",{"tabs--block":s},n),children:l.map((e=>{let{value:n,label:s,attributes:t}=e;return(0,f.jsx)("li",{role:"tab",tabIndex:i===n?0:-1,"aria-selected":i===n,ref:e=>a.push(e),onKeyDown:h,onClick:c,...t,className:(0,r.A)("tabs__item",m.tabItem,t?.className,{"tabs__item--active":i===n}),children:s??n},n)}))})}function b(e){let{lazy:n,children:s,selectedValue:r}=e;const t=(Array.isArray(s)?s:[s]).filter(Boolean);if(n){const e=t.find((e=>e.props.value===r));return e?(0,i.cloneElement)(e,{className:"margin-top--md"}):null}return(0,f.jsx)("div",{className:"margin-top--md",children:t.map(((e,n)=>(0,i.cloneElement)(e,{key:n,hidden:e.props.value!==r})))})}function y(e){const n=j(e);return(0,f.jsxs)("div",{className:(0,r.A)("tabs-container",m.tabList),children:[(0,f.jsx)(v,{...e,...n}),(0,f.jsx)(b,{...e,...n})]})}function w(e){const n=(0,g.A)();return(0,f.jsx)(y,{...e,children:h(e.children)},String(n))}},28453:(e,n,s)=>{s.d(n,{R:()=>o,x:()=>l});var i=s(96540);const r={},t=i.createContext(r);function o(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/05bed8b8.34e33dfa.js b/assets/js/05bed8b8.34e33dfa.js new file mode 100644 index 00000000..864b5c6a --- /dev/null +++ b/assets/js/05bed8b8.34e33dfa.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[127],{1886:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>a,toc:()=>c});var l=i(74848),r=i(28453);const s={sidebar_position:5,slug:"/changelog/changelog-v0.4.5"},o="v0.4.5",a={id:"releases/changelog/changelog-v0.4.5",title:"v0.4.5",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.5.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.5",permalink:"/changelog/changelog-v0.4.5",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.5.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:5,frontMatter:{sidebar_position:5,slug:"/changelog/changelog-v0.4.5"},sidebar:"releasesSidebar",previous:{title:"v0.4.6",permalink:"/changelog/changelog-v0.4.6"},next:{title:"v0.4.4",permalink:"/changelog/changelog-v0.4.4"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",code:"code",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v045",children:"v0.4.5"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.5",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/1758",children:"Issue #1758: bug: Correct text for Windows"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix(Wording): #1758 correct text for windows @namchuai (#1768)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Log): server log is not display in windows @namchuai (#1764)"}),"\n",(0,l.jsx)(n.li,{children:"Release Cut v0.4.5 @louis-jan (#1752)"}),"\n",(0,l.jsx)(n.li,{children:"chore(nitro): 0.2.11 -> 0.2.12 @hiro-v (#1754)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Nitro CPU threads with correct physical/ performance CPU count @hiro-v (#1726)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Model): #1662 imported model does not use gpu @namchuai (#1723)"}),"\n",(0,l.jsx)(n.li,{children:"fix(API): #1720 host/port provided in the local API server does not fully applied @namchuai (#1721)"}),"\n",(0,l.jsx)(n.li,{children:"fix: server API reference @hiro-v (#1670)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Model): refactor model label @namchuai (#1596)"}),"\n",(0,l.jsx)(n.li,{children:"docs/postmortem v 0.4.4 @hieu-jan (#1617)"}),"\n",(0,l.jsx)(n.li,{children:"chore(ShortcutModal): clean up shortcut modal @namchuai (#1614)"}),"\n",(0,l.jsx)(n.li,{children:"chore(Dependencies): upgrade node-fetch to fix vulnerable issue @namchuai (#1598)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: update UI allow user change folder @urmauur (#1738)"}),"\n",(0,l.jsx)(n.li,{children:"feat: error message when not enough RAM @urmauur (#1706)"}),"\n",(0,l.jsx)(n.li,{children:"feat: improvement ux for local api server @urmauur (#1704)"}),"\n",(0,l.jsx)(n.li,{children:"feat: allow user to move jan folder @namchuai (#1649)"}),"\n",(0,l.jsx)(n.li,{children:"feat: HTTP proxy support @markmehere (#1562)"}),"\n",(0,l.jsx)(n.li,{children:"Feature add schedule clean cloudflare page and r2 @hiento09 (#1653)"}),"\n",(0,l.jsx)(n.li,{children:"feat: relayout left panel setting page @urmauur (#1648)"}),"\n",(0,l.jsx)(n.li,{children:"Update CI follow git flow @hiento09 (#1625)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Implement UI page API server dashboard @urmauur (#1636)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1545 long thread title @lucido-simon (#1605)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: model selection does not show in API settings page @louis-jan (#1828)"}),"\n",(0,l.jsx)(n.li,{children:"fix: user can't view model setting in local api server @namchuai (#1807)"}),"\n",(0,l.jsx)(n.li,{children:"fix: cannot change jan data folder @namchuai (#1805)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model selection does not show in API settings page @louis-jan (#1802)"}),"\n",(0,l.jsx)(n.li,{children:"fix: user can't use a model in model hub @namchuai (#1801)"}),"\n",(0,l.jsx)(n.li,{children:"fix: stop openai inference raises something amiss @louis-jan (#1799)"}),"\n",(0,l.jsx)(n.li,{children:"regression fix: input disabled darkmode @urmauur (#1800)"}),"\n",(0,l.jsx)(n.li,{children:"fix: clean last message when user clean thread message @namchuai (#1793)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app log not being printed @namchuai (#1790)"}),"\n",(0,l.jsx)(n.li,{children:"fix: api settings are not applied on changes @louis-jan (#1789)"}),"\n",(0,l.jsx)(n.li,{children:"fix: could not delete model @louis-jan (#1779)"}),"\n",(0,l.jsx)(n.li,{children:"fix: can not start model when server is not enabled from model settings page @louis-jan (#1774)"}),"\n",(0,l.jsx)(n.li,{children:"regression fix: input port not accept alphabets @urmauur (#1772)"}),"\n",(0,l.jsx)(n.li,{children:"Correct bash script syntax in ci @hiento09 (#1769)"}),"\n",(0,l.jsx)(n.li,{children:"Hotfix CI pre-release not trigger @hiento09 (#1757)"}),"\n",(0,l.jsx)(n.li,{children:"fix: bring back open app directory @louis-jan (#1756)"}),"\n",(0,l.jsx)(n.li,{children:"fix: input port have range validation @urmauur (#1741)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error nightly build schedule run failed @hiento09 (#1736)"}),"\n",(0,l.jsx)(n.li,{children:"fix: active model when start server @urmauur (#1719)"}),"\n",(0,l.jsxs)(n.li,{children:["fix: Change to fixed ",(0,l.jsx)(n.code,{children:"localhost"})," instead of using host variable @hiro-v (#1729)"]}),"\n",(0,l.jsx)(n.li,{children:"Fix autoupdater nightly build error @hiento09 (#1727)"}),"\n",(0,l.jsx)(n.li,{children:"Correct download url readme @hiento09 (#1724)"}),"\n",(0,l.jsx)(n.li,{children:"fix: API chat/completion is blocked by CORS @louis-jan (#1705)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Jan server - v1/chat/completions is throwing ERR_REQUIRE_ESM @louis-jan (#1703)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Jan server is showing blank page @louis-jan (#1702)"}),"\n",(0,l.jsx)(n.li,{children:"fix: switching loader from remote to local model from thread right panel @urmauur (#1692)"}),"\n",(0,l.jsx)(n.li,{children:"fix: hot-fix algolia search @hieu-jan (#1700)"}),"\n",(0,l.jsx)(n.li,{children:"fix: disable api key field while server is running @urmauur (#1694)"}),"\n",(0,l.jsx)(n.li,{children:"fix: stoping model show starting model @urmauur (#1693)"}),"\n",(0,l.jsx)(n.li,{children:"fix bug #1650 hogging resources @hiento09 (#1663)"}),"\n",(0,l.jsx)(n.li,{children:"fix: auto select text when collapse panel @urmauur (#1645)"}),"\n",(0,l.jsx)(n.li,{children:"fix: wrong selected model ref @louis-jan (#1638)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable check for update on all supported platforms @louis-jan (#1626)"}),"\n",(0,l.jsx)(n.li,{children:"fix: correct footer @hieu-jan (#1628)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Docs publish to github page trigger on push to docs branch @hiento09 (#1783)"}),"\n",(0,l.jsx)(n.li,{children:"Correct bash script syntax in ci @hiento09 (#1769)"}),"\n",(0,l.jsx)(n.li,{children:"Combine 2 ci pipeline pre-release and nightly into one @hiento09 (#1767)"}),"\n",(0,l.jsx)(n.li,{children:"Hotfix CI pre-release not trigger @hiento09 (#1757)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error nightly build schedule run failed @hiento09 (#1736)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add troubleshoot unexpected token @hieu-jan (#1711)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix about pages @0xSage (#1699)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: deprecate extension type implementation @louis-jan (#1677)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: file prefix replace utils & add unit test @louis-jan (#1676)"}),"\n",(0,l.jsx)(n.li,{children:"Correct ref branch for update url on README.md file @hiento09 (#1672)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update 02-somethings-amiss @hieu-jan (#1668)"}),"\n",(0,l.jsx)(n.li,{children:"Cherrypick cicd to main branch to apply new gitflow @hiento09 (#1665)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add user and developer guides for extensions @hieu-jan (#1657)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add QA Script @hieu-jan (#1660)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump nitro to 0.2.11 @hiro-v (#1655)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump version nitro to 0.2.10 @hiro-v (#1644)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add antivirus compatibility testing @hieu-jan (#1641)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: introduce node module in nitro extension @louis-jan (#1630)"}),"\n",(0,l.jsx)(n.li,{children:"Update 02-somethings-amiss.mdx @Ssstars (#1634)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add integration AzureOpenAI @hieu-jan (#1632)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add troubleshooting permission denied @hieu-jan (#1631)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @Ssstars, @hiento09, @hientominh, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @lucido-simon, @markmehere, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>a});var l=i(96540);const r={},s=l.createContext(r);function o(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/05bed8b8.c39ac60f.js b/assets/js/05bed8b8.c39ac60f.js deleted file mode 100644 index a3ce058d..00000000 --- a/assets/js/05bed8b8.c39ac60f.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[127],{1886:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>a,toc:()=>c});var l=i(74848),r=i(28453);const s={sidebar_position:5,slug:"/changelog/changelog-v0.4.5"},o="v0.4.5",a={id:"releases/changelog/changelog-v0.4.5",title:"v0.4.5",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.5.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.5",permalink:"/changelog/changelog-v0.4.5",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.5.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:5,frontMatter:{sidebar_position:5,slug:"/changelog/changelog-v0.4.5"},sidebar:"releasesSidebar",previous:{title:"v0.4.6",permalink:"/changelog/changelog-v0.4.6"},next:{title:"v0.4.4",permalink:"/changelog/changelog-v0.4.4"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",code:"code",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v045",children:"v0.4.5"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.5",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/issues/1758",children:"Issue #1758: bug: Correct text for Windows"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix(Wording): #1758 correct text for windows @namchuai (#1768)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Log): server log is not display in windows @namchuai (#1764)"}),"\n",(0,l.jsx)(n.li,{children:"Release Cut v0.4.5 @louis-jan (#1752)"}),"\n",(0,l.jsx)(n.li,{children:"chore(nitro): 0.2.11 -> 0.2.12 @hiro-v (#1754)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Nitro CPU threads with correct physical/ performance CPU count @hiro-v (#1726)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Model): #1662 imported model does not use gpu @namchuai (#1723)"}),"\n",(0,l.jsx)(n.li,{children:"fix(API): #1720 host/port provided in the local API server does not fully applied @namchuai (#1721)"}),"\n",(0,l.jsx)(n.li,{children:"fix: server API reference @hiro-v (#1670)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Model): refactor model label @namchuai (#1596)"}),"\n",(0,l.jsx)(n.li,{children:"docs/postmortem v 0.4.4 @hieu-jan (#1617)"}),"\n",(0,l.jsx)(n.li,{children:"chore(ShortcutModal): clean up shortcut modal @namchuai (#1614)"}),"\n",(0,l.jsx)(n.li,{children:"chore(Dependencies): upgrade node-fetch to fix vulnerable issue @namchuai (#1598)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: update UI allow user change folder @urmauur (#1738)"}),"\n",(0,l.jsx)(n.li,{children:"feat: error message when not enough RAM @urmauur (#1706)"}),"\n",(0,l.jsx)(n.li,{children:"feat: improvement ux for local api server @urmauur (#1704)"}),"\n",(0,l.jsx)(n.li,{children:"feat: allow user to move jan folder @namchuai (#1649)"}),"\n",(0,l.jsx)(n.li,{children:"feat: HTTP proxy support @markmehere (#1562)"}),"\n",(0,l.jsx)(n.li,{children:"Feature add schedule clean cloudflare page and r2 @hiento09 (#1653)"}),"\n",(0,l.jsx)(n.li,{children:"feat: relayout left panel setting page @urmauur (#1648)"}),"\n",(0,l.jsx)(n.li,{children:"Update CI follow git flow @hiento09 (#1625)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Implement UI page API server dashboard @urmauur (#1636)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1545 long thread title @lucido-simon (#1605)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: model selection does not show in API settings page @louis-jan (#1828)"}),"\n",(0,l.jsx)(n.li,{children:"fix: user can't view model setting in local api server @namchuai (#1807)"}),"\n",(0,l.jsx)(n.li,{children:"fix: cannot change jan data folder @namchuai (#1805)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model selection does not show in API settings page @louis-jan (#1802)"}),"\n",(0,l.jsx)(n.li,{children:"fix: user can't use a model in model hub @namchuai (#1801)"}),"\n",(0,l.jsx)(n.li,{children:"fix: stop openai inference raises something amiss @louis-jan (#1799)"}),"\n",(0,l.jsx)(n.li,{children:"regression fix: input disabled darkmode @urmauur (#1800)"}),"\n",(0,l.jsx)(n.li,{children:"fix: clean last message when user clean thread message @namchuai (#1793)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app log not being printed @namchuai (#1790)"}),"\n",(0,l.jsx)(n.li,{children:"fix: api settings are not applied on changes @louis-jan (#1789)"}),"\n",(0,l.jsx)(n.li,{children:"fix: could not delete model @louis-jan (#1779)"}),"\n",(0,l.jsx)(n.li,{children:"fix: can not start model when server is not enabled from model settings page @louis-jan (#1774)"}),"\n",(0,l.jsx)(n.li,{children:"regression fix: input port not accept alphabets @urmauur (#1772)"}),"\n",(0,l.jsx)(n.li,{children:"Correct bash script syntax in ci @hiento09 (#1769)"}),"\n",(0,l.jsx)(n.li,{children:"Hotfix CI pre-release not trigger @hiento09 (#1757)"}),"\n",(0,l.jsx)(n.li,{children:"fix: bring back open app directory @louis-jan (#1756)"}),"\n",(0,l.jsx)(n.li,{children:"fix: input port have range validation @urmauur (#1741)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error nightly build schedule run failed @hiento09 (#1736)"}),"\n",(0,l.jsx)(n.li,{children:"fix: active model when start server @urmauur (#1719)"}),"\n",(0,l.jsxs)(n.li,{children:["fix: Change to fixed ",(0,l.jsx)(n.code,{children:"localhost"})," instead of using host variable @hiro-v (#1729)"]}),"\n",(0,l.jsx)(n.li,{children:"Fix autoupdater nightly build error @hiento09 (#1727)"}),"\n",(0,l.jsx)(n.li,{children:"Correct download url readme @hiento09 (#1724)"}),"\n",(0,l.jsx)(n.li,{children:"fix: API chat/completion is blocked by CORS @louis-jan (#1705)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Jan server - v1/chat/completions is throwing ERR_REQUIRE_ESM @louis-jan (#1703)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Jan server is showing blank page @louis-jan (#1702)"}),"\n",(0,l.jsx)(n.li,{children:"fix: switching loader from remote to local model from thread right panel @urmauur (#1692)"}),"\n",(0,l.jsx)(n.li,{children:"fix: hot-fix algolia search @hieu-jan (#1700)"}),"\n",(0,l.jsx)(n.li,{children:"fix: disable api key field while server is running @urmauur (#1694)"}),"\n",(0,l.jsx)(n.li,{children:"fix: stoping model show starting model @urmauur (#1693)"}),"\n",(0,l.jsx)(n.li,{children:"fix bug #1650 hogging resources @hiento09 (#1663)"}),"\n",(0,l.jsx)(n.li,{children:"fix: auto select text when collapse panel @urmauur (#1645)"}),"\n",(0,l.jsx)(n.li,{children:"fix: wrong selected model ref @louis-jan (#1638)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable check for update on all supported platforms @louis-jan (#1626)"}),"\n",(0,l.jsx)(n.li,{children:"fix: correct footer @hieu-jan (#1628)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Docs publish to github page trigger on push to docs branch @hiento09 (#1783)"}),"\n",(0,l.jsx)(n.li,{children:"Correct bash script syntax in ci @hiento09 (#1769)"}),"\n",(0,l.jsx)(n.li,{children:"Combine 2 ci pipeline pre-release and nightly into one @hiento09 (#1767)"}),"\n",(0,l.jsx)(n.li,{children:"Hotfix CI pre-release not trigger @hiento09 (#1757)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error nightly build schedule run failed @hiento09 (#1736)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add troubleshoot unexpected token @hieu-jan (#1711)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix about pages @0xSage (#1699)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: deprecate extension type implementation @louis-jan (#1677)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: file prefix replace utils & add unit test @louis-jan (#1676)"}),"\n",(0,l.jsx)(n.li,{children:"Correct ref branch for update url on README.md file @hiento09 (#1672)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update 02-somethings-amiss @hieu-jan (#1668)"}),"\n",(0,l.jsx)(n.li,{children:"Cherrypick cicd to main branch to apply new gitflow @hiento09 (#1665)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add user and developer guides for extensions @hieu-jan (#1657)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add QA Script @hieu-jan (#1660)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump nitro to 0.2.11 @hiro-v (#1655)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump version nitro to 0.2.10 @hiro-v (#1644)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add antivirus compatibility testing @hieu-jan (#1641)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: introduce node module in nitro extension @louis-jan (#1630)"}),"\n",(0,l.jsx)(n.li,{children:"Update 02-somethings-amiss.mdx @Ssstars (#1634)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add integration AzureOpenAI @hieu-jan (#1632)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add troubleshooting permission denied @hieu-jan (#1631)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @Ssstars, @hiento09, @hientominh, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @lucido-simon, @markmehere, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>a});var l=i(96540);const r={},s=l.createContext(r);function o(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/05e26e91.0a0f9e15.js b/assets/js/05e26e91.0a0f9e15.js new file mode 100644 index 00000000..9a08c9a3 --- /dev/null +++ b/assets/js/05e26e91.0a0f9e15.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6770],{45549:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>c,contentTitle:()=>d,default:()=>f,frontMatter:()=>s,metadata:()=>u,toc:()=>a});var o=e(74848),r=e(28453);const s={},d=void 0,u={id:"foundry/foundry",title:"foundry",description:"",source:"@site/docs/foundry/foundry.md",sourceDirName:"foundry",slug:"/foundry/",permalink:"/foundry/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/foundry/foundry.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{}},c={},a=[];function i(t){return(0,o.jsx)(o.Fragment,{})}function f(t={}){const{wrapper:n}={...(0,r.R)(),...t.components};return n?(0,o.jsx)(n,{...t,children:(0,o.jsx)(i,{...t})}):i()}},28453:(t,n,e)=>{e.d(n,{R:()=>d,x:()=>u});var o=e(96540);const r={},s=o.createContext(r);function d(t){const n=o.useContext(s);return o.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function u(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:d(t.components),o.createElement(s.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/05e26e91.4348527a.js b/assets/js/05e26e91.4348527a.js deleted file mode 100644 index 4a6b5461..00000000 --- a/assets/js/05e26e91.4348527a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6770],{45549:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>c,contentTitle:()=>d,default:()=>f,frontMatter:()=>s,metadata:()=>u,toc:()=>a});var o=e(74848),r=e(28453);const s={},d=void 0,u={id:"foundry/foundry",title:"foundry",description:"",source:"@site/docs/foundry/foundry.md",sourceDirName:"foundry",slug:"/foundry/",permalink:"/foundry/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/foundry/foundry.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{}},c={},a=[];function i(t){return(0,o.jsx)(o.Fragment,{})}function f(t={}){const{wrapper:n}={...(0,r.R)(),...t.components};return n?(0,o.jsx)(n,{...t,children:(0,o.jsx)(i,{...t})}):i()}},28453:(t,n,e)=>{e.d(n,{R:()=>d,x:()=>u});var o=e(96540);const r={},s=o.createContext(r);function d(t){const n=o.useContext(s);return o.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function u(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:d(t.components),o.createElement(s.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/07d35b44.7b3e839e.js b/assets/js/07d35b44.7b3e839e.js new file mode 100644 index 00000000..a98d784a --- /dev/null +++ b/assets/js/07d35b44.7b3e839e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8946],{31609:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>u});var o=n(74848),r=n(28453);const a={title:"Join us"},s=void 0,i={id:"team/join-us",title:"Join us",description:"- [ ] Explain Core Team, Contributors and Open Source approach",source:"@site/docs/team/join-us.md",sourceDirName:"team",slug:"/team/join-us",permalink:"/team/join-us",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/team/join-us.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Join us"},sidebar:"aboutSidebar",previous:{title:"Who we are",permalink:"/team/"},next:{title:"Contributor Program",permalink:"/team/contributor-program"}},c={},u=[{value:"Careers",id:"careers",level:3}];function l(e){const t={a:"a",h3:"h3",input:"input",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsxs)(t.ul,{className:"contains-task-list",children:["\n",(0,o.jsxs)(t.li,{className:"task-list-item",children:[(0,o.jsx)(t.input,{type:"checkbox",disabled:!0})," ","Explain Core Team, Contributors and Open Source approach"]}),"\n"]}),"\n",(0,o.jsx)(t.p,{children:(0,o.jsx)(t.a,{href:"https://janai.bamboohr.com/careers",children:"Careers on Bamboo"})}),"\n",(0,o.jsx)(t.h3,{id:"careers",children:"Careers"}),"\n",(0,o.jsxs)(t.p,{children:["Jan has a culture of ownership, independent thought, and lightning fast execution. If you'd like to join us, we have open positions on our ",(0,o.jsx)(t.a,{href:"https://janai.bamboohr.com/careers",children:"careers page"}),"."]})]})}function d(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(l,{...e})}):l(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>i});var o=n(96540);const r={},a=o.createContext(r);function s(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:s(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/07d35b44.cf5f7291.js b/assets/js/07d35b44.cf5f7291.js deleted file mode 100644 index 529adf74..00000000 --- a/assets/js/07d35b44.cf5f7291.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8946],{31609:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>u});var o=n(74848),r=n(28453);const a={title:"Join us"},s=void 0,i={id:"team/join-us",title:"Join us",description:"- [ ] Explain Core Team, Contributors and Open Source approach",source:"@site/docs/team/join-us.md",sourceDirName:"team",slug:"/team/join-us",permalink:"/team/join-us",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/team/join-us.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Join us"},sidebar:"aboutSidebar",previous:{title:"Who we are",permalink:"/team/"},next:{title:"Contributor Program",permalink:"/team/contributor-program"}},c={},u=[{value:"Careers",id:"careers",level:3}];function l(e){const t={a:"a",h3:"h3",input:"input",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsxs)(t.ul,{className:"contains-task-list",children:["\n",(0,o.jsxs)(t.li,{className:"task-list-item",children:[(0,o.jsx)(t.input,{type:"checkbox",disabled:!0})," ","Explain Core Team, Contributors and Open Source approach"]}),"\n"]}),"\n",(0,o.jsx)(t.p,{children:(0,o.jsx)(t.a,{href:"https://janai.bamboohr.com/careers",children:"Careers on Bamboo"})}),"\n",(0,o.jsx)(t.h3,{id:"careers",children:"Careers"}),"\n",(0,o.jsxs)(t.p,{children:["Jan has a culture of ownership, independent thought, and lightning fast execution. If you'd like to join us, we have open positions on our ",(0,o.jsx)(t.a,{href:"https://janai.bamboohr.com/careers",children:"careers page"}),"."]})]})}function d(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(l,{...e})}):l(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>i});var o=n(96540);const r={},a=o.createContext(r);function s(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:s(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/08b75426.ddd153f8.js b/assets/js/08b75426.ddd153f8.js deleted file mode 100644 index 2e949c10..00000000 --- a/assets/js/08b75426.ddd153f8.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[257],{82010:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>r,toc:()=>u});var o=n(74848),i=n(28453);const s={title:"Claude",sidebar_position:6,slug:"/guides/engines/claude",description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Claude integration","claude"]},a=void 0,r={id:"guides/remote-providers/claude",title:"Claude",description:"A step-by-step guide on how to integrate Jan with LM Studio.",source:"@site/docs/guides/remote-providers/claude.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/claude",permalink:"/guides/engines/claude",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/claude.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:6,frontMatter:{title:"Claude",sidebar_position:6,slug:"/guides/engines/claude",description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Claude integration","claude"]}},d={},u=[];function c(e){const t={p:"p",...(0,i.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(c,{...e})}):c(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>r});var o=n(96540);const i={},s=o.createContext(i);function a(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/08b75426.fdec7da0.js b/assets/js/08b75426.fdec7da0.js new file mode 100644 index 00000000..eef3af68 --- /dev/null +++ b/assets/js/08b75426.fdec7da0.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[257],{82010:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>r,toc:()=>u});var o=n(74848),i=n(28453);const s={title:"Claude",sidebar_position:6,slug:"/guides/engines/claude",description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Claude integration","claude"]},a=void 0,r={id:"guides/remote-providers/claude",title:"Claude",description:"A step-by-step guide on how to integrate Jan with LM Studio.",source:"@site/docs/guides/remote-providers/claude.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/claude",permalink:"/guides/engines/claude",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/claude.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:6,frontMatter:{title:"Claude",sidebar_position:6,slug:"/guides/engines/claude",description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Claude integration","claude"]}},d={},u=[];function c(e){const t={p:"p",...(0,i.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(c,{...e})}):c(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>r});var o=n(96540);const i={},s=o.createContext(i);function a(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/09d23ef9.514d4ef7.js b/assets/js/09d23ef9.514d4ef7.js new file mode 100644 index 00000000..fa2dd282 --- /dev/null +++ b/assets/js/09d23ef9.514d4ef7.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9975],{14643:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>a,default:()=>d,frontMatter:()=>o,metadata:()=>s,toc:()=>c});var r=t(74848),i=t(28453);const o={title:"Engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,s={id:"how-we-work/engineering/engineering",title:"Engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/how-we-work/engineering/engineering.md",sourceDirName:"how-we-work/engineering",slug:"/engineering",permalink:"/engineering",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/engineering/engineering.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"aboutSidebar",previous:{title:"Project Management",permalink:"/how-we-work/project-management"},next:{title:"CI & CD",permalink:"/engineering/ci-cd"}},l={},c=[{value:"Prerequisites",id:"prerequisites",level:2}];function u(e){const n={a:"a",h2:"h2",li:"li",ul:"ul",...(0,i.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://github.com/janhq/jan?tab=readme-ov-file#requirements-for-running-jan",children:"Requirements"})}),"\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://github.com/janhq/jan?tab=readme-ov-file#contributing",children:"Setting up local env"})}),"\n"]})]})}function d(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>s});var r=t(96540);const i={},o=r.createContext(i);function a(e){const n=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),r.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/09d23ef9.f584f7a9.js b/assets/js/09d23ef9.f584f7a9.js deleted file mode 100644 index 9d4cd45f..00000000 --- a/assets/js/09d23ef9.f584f7a9.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9975],{14643:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>a,default:()=>d,frontMatter:()=>o,metadata:()=>s,toc:()=>c});var r=t(74848),i=t(28453);const o={title:"Engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,s={id:"how-we-work/engineering/engineering",title:"Engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/how-we-work/engineering/engineering.md",sourceDirName:"how-we-work/engineering",slug:"/engineering",permalink:"/engineering",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/engineering/engineering.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"aboutSidebar",previous:{title:"Project Management",permalink:"/how-we-work/project-management"},next:{title:"CI & CD",permalink:"/engineering/ci-cd"}},l={},c=[{value:"Prerequisites",id:"prerequisites",level:2}];function u(e){const n={a:"a",h2:"h2",li:"li",ul:"ul",...(0,i.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://github.com/janhq/jan?tab=readme-ov-file#requirements-for-running-jan",children:"Requirements"})}),"\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://github.com/janhq/jan?tab=readme-ov-file#contributing",children:"Setting up local env"})}),"\n"]})]})}function d(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>s});var r=t(96540);const i={},o=r.createContext(i);function a(e){const n=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),r.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/0a199304.94441f67.js b/assets/js/0a199304.94441f67.js deleted file mode 100644 index 44fcbca1..00000000 --- a/assets/js/0a199304.94441f67.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7028],{90282:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>i,contentTitle:()=>s,default:()=>u,frontMatter:()=>o,metadata:()=>c,toc:()=>p});var n=r(74848),a=r(28453);const o={title:"Become a Partner"},s=void 0,c={id:"partners/become-a-partner",title:"Become a Partner",description:"",source:"@site/docs/partners/become-a-partner.md",sourceDirName:"partners",slug:"/partners/become-a-partner",permalink:"/partners/become-a-partner",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/partners/become-a-partner.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Become a Partner"},sidebar:"ecosystemSidebar",previous:{title:"Partners",permalink:"/partners/"},next:{title:"Integrations",permalink:"/integrations"}},i={},p=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function u(e={}){const{wrapper:t}={...(0,a.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>s,x:()=>c});var n=r(96540);const a={},o=n.createContext(a);function s(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/0a199304.f7e477ae.js b/assets/js/0a199304.f7e477ae.js new file mode 100644 index 00000000..5d2bcabb --- /dev/null +++ b/assets/js/0a199304.f7e477ae.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7028],{90282:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>i,contentTitle:()=>s,default:()=>u,frontMatter:()=>o,metadata:()=>c,toc:()=>p});var n=r(74848),a=r(28453);const o={title:"Become a Partner"},s=void 0,c={id:"partners/become-a-partner",title:"Become a Partner",description:"",source:"@site/docs/partners/become-a-partner.md",sourceDirName:"partners",slug:"/partners/become-a-partner",permalink:"/partners/become-a-partner",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/partners/become-a-partner.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Become a Partner"},sidebar:"ecosystemSidebar",previous:{title:"Partners",permalink:"/partners/"},next:{title:"Integrations",permalink:"/integrations"}},i={},p=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function u(e={}){const{wrapper:t}={...(0,a.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>s,x:()=>c});var n=r(96540);const a={},o=n.createContext(a);function s(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/0b3bb891.8c8eb7eb.js b/assets/js/0b3bb891.8c8eb7eb.js new file mode 100644 index 00000000..34af27ca --- /dev/null +++ b/assets/js/0b3bb891.8c8eb7eb.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9754],{87062:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>a,contentTitle:()=>r,default:()=>h,frontMatter:()=>o,metadata:()=>l,toc:()=>d});var i=s(74848),t=s(28453);const o={title:"TensorRT-LLM Extension",slug:"/guides/engines/tensorrt-llm",sidebar_position:2,description:"A step-by-step guide on how to customize the TensorRT-LLM extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]},r=void 0,l={id:"guides/local-providers/tensorrt",title:"TensorRT-LLM Extension",description:"A step-by-step guide on how to customize the TensorRT-LLM extension.",source:"@site/docs/guides/local-providers/tensorrt.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/tensorrt-llm",permalink:"/guides/engines/tensorrt-llm",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/tensorrt.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"TensorRT-LLM Extension",slug:"/guides/engines/tensorrt-llm",sidebar_position:2,description:"A step-by-step guide on how to customize the TensorRT-LLM extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]},sidebar:"guidesSidebar",previous:{title:"Llama.cpp Extension",permalink:"/guides/engines/llamacpp"},next:{title:"LM Studio",permalink:"/guides/engines/lmstudio"}},a={},d=[{value:"Overview",id:"overview",level:2},{value:"TensortRT-LLM Extension",id:"tensortrt-llm-extension",level:2},{value:"Pre-requisites",id:"pre-requisites",level:3},{value:"Step 1: Install TensorRT-Extension",id:"step-1-install-tensorrt-extension",level:3},{value:"Step 2: Download a Compatible Model",id:"step-2-download-a-compatible-model",level:3},{value:"Step 3: Configure Settings",id:"step-3-configure-settings",level:3},{value:"Troubleshooting",id:"troubleshooting",level:2},{value:"Incompatible Extension vs Engine versions",id:"incompatible-extension-vs-engine-versions",level:3},{value:"Uninstall Extension",id:"uninstall-extension",level:3},{value:"Install Nitro-TensorRT-LLM manually",id:"install-nitro-tensorrt-llm-manually",level:3},{value:"Build your own TensorRT models",id:"build-your-own-tensorrt-models",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,i.jsxs)(n.p,{children:["Users with Nvidia GPUs can get ",(0,i.jsx)(n.strong,{children:"20-40% faster token speeds"})," compared to using LlamaCPP engine on their laptop or desktops by using ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"}),". The greater implication is that you are running FP16, which is also more accurate than quantized models."]}),"\n",(0,i.jsx)(n.h2,{id:"tensortrt-llm-extension",children:"TensortRT-LLM Extension"}),"\n",(0,i.jsxs)(n.p,{children:["This guide walks you through how to install Jan's official ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm",children:"TensorRT-LLM Extension"}),". This extension uses ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm",children:"Nitro-TensorRT-LLM"})," as the AI engine, instead of the default ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"Nitro-Llama-CPP"}),". It includes an efficient C++ server to natively execute the ",(0,i.jsx)(n.a,{href:"https://nvidia.github.io/TensorRT-LLM/gpt_runtime.html",children:"TRT-LLM C++ runtime"}),". It also comes with additional feature and performance improvements like OpenAI compatibility, tokenizer improvements, and queues."]}),"\n",(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:"This feature is only available for Windows users. Linux is coming soon."}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Additionally, we only prebuilt a few demo models. You can always build your desired models directly on your machine. For more information, please see ",(0,i.jsx)(n.a,{href:"#build-your-own-tensorrt-models",children:"here"}),"."]}),"\n"]}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"pre-requisites",children:"Pre-requisites"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"A Windows PC"}),"\n",(0,i.jsx)(n.li,{children:"Nvidia GPU(s): Ada or Ampere series (i.e. RTX 4000s & 3000s). More will be supported soon."}),"\n",(0,i.jsx)(n.li,{children:"3GB+ of disk space to download TRT-LLM artifacts and a Nitro binary"}),"\n",(0,i.jsx)(n.li,{children:"Jan v0.4.9+ or Jan v0.4.8-321+ (nightly)"}),"\n",(0,i.jsxs)(n.li,{children:["Nvidia Driver v535+ (For installation guide, please see ",(0,i.jsx)(n.a,{href:"/troubleshooting/#1-ensure-gpu-mode-requirements",children:"here"}),")"]}),"\n",(0,i.jsxs)(n.li,{children:["CUDA Toolkit v12.2+ (For installation guide, please see ",(0,i.jsx)(n.a,{href:"/troubleshooting/#1-ensure-gpu-mode-requirements",children:"here"}),")"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"step-1-install-tensorrt-extension",children:"Step 1: Install TensorRT-Extension"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Extensions"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Click ",(0,i.jsx)(n.strong,{children:"Install"})," next to the TensorRT-LLM Extension."]}),"\n",(0,i.jsx)(n.li,{children:"Check that files are correctly downloaded."}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"ls ~\\jan\\extensions\\@janhq\\tensorrt-llm-extension\\dist\\bin\n# Your Extension Folder should now include `nitro.exe`, among other artifacts needed to run TRT-LLM\n"})}),"\n",(0,i.jsx)(n.h3,{id:"step-2-download-a-compatible-model",children:"Step 2: Download a Compatible Model"}),"\n",(0,i.jsxs)(n.p,{children:["TensorRT-LLM can only run models in ",(0,i.jsx)(n.code,{children:"TensorRT"}),' format. These models, aka "TensorRT Engines", are prebuilt specifically for each target OS+GPU architecture.']}),"\n",(0,i.jsx)(n.p,{children:"We offer a handful of precompiled models for Ampere and Ada cards that you can immediately download and play with:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Restart the application and go to the Hub."}),"\n",(0,i.jsxs)(n.li,{children:["Look for models with the ",(0,i.jsx)(n.code,{children:"TensorRT-LLM"})," label in the recommended models list > Click ",(0,i.jsx)(n.strong,{children:"Download"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"This step might take some time. \ud83d\ude4f"})}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{src:"https://hackmd.io/_uploads/rJewrEgRp.png",alt:"image"})}),"\n",(0,i.jsxs)(n.ol,{start:"3",children:["\n",(0,i.jsx)(n.li,{children:"Click use and start chatting!"}),"\n",(0,i.jsx)(n.li,{children:"You may need to allow Nitro in your network"}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"alt text",src:s(61914).A+"",width:"679",height:"428"})}),"\n",(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsx)(n.p,{children:"If you are our nightly builds, you may have to reinstall the TensorRT-LLM extension each time you update the app. We're working on better extension lifecyles - stay tuned."})}),"\n",(0,i.jsx)(n.h3,{id:"step-3-configure-settings",children:"Step 3: Configure Settings"}),"\n",(0,i.jsx)(n.p,{children:"You can customize the default parameters for how Jan runs TensorRT-LLM."}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsx)(n.p,{children:"coming soon"})}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,i.jsx)(n.h3,{id:"incompatible-extension-vs-engine-versions",children:"Incompatible Extension vs Engine versions"}),"\n",(0,i.jsx)(n.p,{children:"For now, the model versions are pinned to the extension versions."}),"\n",(0,i.jsx)(n.h3,{id:"uninstall-extension",children:"Uninstall Extension"}),"\n",(0,i.jsx)(n.p,{children:"To uninstall the extension, follow the steps below:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Quit the app."}),"\n",(0,i.jsxs)(n.li,{children:["Go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Extensions"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Delete the entire Extensions folder."}),"\n",(0,i.jsx)(n.li,{children:"Reopen the app, only the default extensions should be restored."}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"install-nitro-tensorrt-llm-manually",children:"Install Nitro-TensorRT-LLM manually"}),"\n",(0,i.jsxs)(n.p,{children:["To manually build the artifacts needed to run the server and TensorRT-LLM, you can reference the source code. ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm?tab=readme-ov-file#quickstart",children:"Read here"}),"."]}),"\n",(0,i.jsx)(n.h3,{id:"build-your-own-tensorrt-models",children:"Build your own TensorRT models"}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsx)(n.p,{children:"coming soon"})})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},61914:(e,n,s)=>{s.d(n,{A:()=>i});const i=s.p+"assets/images/image-43682306e0e1318012556ba5111c1b38.png"},28453:(e,n,s)=>{s.d(n,{R:()=>r,x:()=>l});var i=s(96540);const t={},o=i.createContext(t);function r(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:r(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/0b3bb891.9a855800.js b/assets/js/0b3bb891.9a855800.js deleted file mode 100644 index 9ff69837..00000000 --- a/assets/js/0b3bb891.9a855800.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9754],{87062:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>a,contentTitle:()=>r,default:()=>h,frontMatter:()=>o,metadata:()=>l,toc:()=>d});var i=s(74848),t=s(28453);const o={title:"TensorRT-LLM Extension",slug:"/guides/engines/tensorrt-llm",sidebar_position:2,description:"A step-by-step guide on how to customize the TensorRT-LLM extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]},r=void 0,l={id:"guides/local-providers/tensorrt",title:"TensorRT-LLM Extension",description:"A step-by-step guide on how to customize the TensorRT-LLM extension.",source:"@site/docs/guides/local-providers/tensorrt.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/tensorrt-llm",permalink:"/guides/engines/tensorrt-llm",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/tensorrt.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"TensorRT-LLM Extension",slug:"/guides/engines/tensorrt-llm",sidebar_position:2,description:"A step-by-step guide on how to customize the TensorRT-LLM extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]},sidebar:"guidesSidebar",previous:{title:"Llama.cpp Extension",permalink:"/guides/engines/llamacpp"},next:{title:"LM Studio",permalink:"/guides/engines/lmstudio"}},a={},d=[{value:"Overview",id:"overview",level:2},{value:"TensortRT-LLM Extension",id:"tensortrt-llm-extension",level:2},{value:"Pre-requisites",id:"pre-requisites",level:3},{value:"Step 1: Install TensorRT-Extension",id:"step-1-install-tensorrt-extension",level:3},{value:"Step 2: Download a Compatible Model",id:"step-2-download-a-compatible-model",level:3},{value:"Step 3: Configure Settings",id:"step-3-configure-settings",level:3},{value:"Troubleshooting",id:"troubleshooting",level:2},{value:"Incompatible Extension vs Engine versions",id:"incompatible-extension-vs-engine-versions",level:3},{value:"Uninstall Extension",id:"uninstall-extension",level:3},{value:"Install Nitro-TensorRT-LLM manually",id:"install-nitro-tensorrt-llm-manually",level:3},{value:"Build your own TensorRT models",id:"build-your-own-tensorrt-models",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,i.jsxs)(n.p,{children:["Users with Nvidia GPUs can get ",(0,i.jsx)(n.strong,{children:"20-40% faster token speeds"})," compared to using LlamaCPP engine on their laptop or desktops by using ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"}),". The greater implication is that you are running FP16, which is also more accurate than quantized models."]}),"\n",(0,i.jsx)(n.h2,{id:"tensortrt-llm-extension",children:"TensortRT-LLM Extension"}),"\n",(0,i.jsxs)(n.p,{children:["This guide walks you through how to install Jan's official ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm",children:"TensorRT-LLM Extension"}),". This extension uses ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm",children:"Nitro-TensorRT-LLM"})," as the AI engine, instead of the default ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"Nitro-Llama-CPP"}),". It includes an efficient C++ server to natively execute the ",(0,i.jsx)(n.a,{href:"https://nvidia.github.io/TensorRT-LLM/gpt_runtime.html",children:"TRT-LLM C++ runtime"}),". It also comes with additional feature and performance improvements like OpenAI compatibility, tokenizer improvements, and queues."]}),"\n",(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsx)(n.p,{children:"This feature is only available for Windows users. Linux is coming soon."}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Additionally, we only prebuilt a few demo models. You can always build your desired models directly on your machine. For more information, please see ",(0,i.jsx)(n.a,{href:"#build-your-own-tensorrt-models",children:"here"}),"."]}),"\n"]}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"pre-requisites",children:"Pre-requisites"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"A Windows PC"}),"\n",(0,i.jsx)(n.li,{children:"Nvidia GPU(s): Ada or Ampere series (i.e. RTX 4000s & 3000s). More will be supported soon."}),"\n",(0,i.jsx)(n.li,{children:"3GB+ of disk space to download TRT-LLM artifacts and a Nitro binary"}),"\n",(0,i.jsx)(n.li,{children:"Jan v0.4.9+ or Jan v0.4.8-321+ (nightly)"}),"\n",(0,i.jsxs)(n.li,{children:["Nvidia Driver v535+ (For installation guide, please see ",(0,i.jsx)(n.a,{href:"/troubleshooting/#1-ensure-gpu-mode-requirements",children:"here"}),")"]}),"\n",(0,i.jsxs)(n.li,{children:["CUDA Toolkit v12.2+ (For installation guide, please see ",(0,i.jsx)(n.a,{href:"/troubleshooting/#1-ensure-gpu-mode-requirements",children:"here"}),")"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"step-1-install-tensorrt-extension",children:"Step 1: Install TensorRT-Extension"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Extensions"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Click ",(0,i.jsx)(n.strong,{children:"Install"})," next to the TensorRT-LLM Extension."]}),"\n",(0,i.jsx)(n.li,{children:"Check that files are correctly downloaded."}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"ls ~\\jan\\extensions\\@janhq\\tensorrt-llm-extension\\dist\\bin\n# Your Extension Folder should now include `nitro.exe`, among other artifacts needed to run TRT-LLM\n"})}),"\n",(0,i.jsx)(n.h3,{id:"step-2-download-a-compatible-model",children:"Step 2: Download a Compatible Model"}),"\n",(0,i.jsxs)(n.p,{children:["TensorRT-LLM can only run models in ",(0,i.jsx)(n.code,{children:"TensorRT"}),' format. These models, aka "TensorRT Engines", are prebuilt specifically for each target OS+GPU architecture.']}),"\n",(0,i.jsx)(n.p,{children:"We offer a handful of precompiled models for Ampere and Ada cards that you can immediately download and play with:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Restart the application and go to the Hub."}),"\n",(0,i.jsxs)(n.li,{children:["Look for models with the ",(0,i.jsx)(n.code,{children:"TensorRT-LLM"})," label in the recommended models list > Click ",(0,i.jsx)(n.strong,{children:"Download"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"This step might take some time. \ud83d\ude4f"})}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{src:"https://hackmd.io/_uploads/rJewrEgRp.png",alt:"image"})}),"\n",(0,i.jsxs)(n.ol,{start:"3",children:["\n",(0,i.jsx)(n.li,{children:"Click use and start chatting!"}),"\n",(0,i.jsx)(n.li,{children:"You may need to allow Nitro in your network"}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"alt text",src:s(61914).A+"",width:"679",height:"428"})}),"\n",(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsx)(n.p,{children:"If you are our nightly builds, you may have to reinstall the TensorRT-LLM extension each time you update the app. We're working on better extension lifecyles - stay tuned."})}),"\n",(0,i.jsx)(n.h3,{id:"step-3-configure-settings",children:"Step 3: Configure Settings"}),"\n",(0,i.jsx)(n.p,{children:"You can customize the default parameters for how Jan runs TensorRT-LLM."}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsx)(n.p,{children:"coming soon"})}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,i.jsx)(n.h3,{id:"incompatible-extension-vs-engine-versions",children:"Incompatible Extension vs Engine versions"}),"\n",(0,i.jsx)(n.p,{children:"For now, the model versions are pinned to the extension versions."}),"\n",(0,i.jsx)(n.h3,{id:"uninstall-extension",children:"Uninstall Extension"}),"\n",(0,i.jsx)(n.p,{children:"To uninstall the extension, follow the steps below:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Quit the app."}),"\n",(0,i.jsxs)(n.li,{children:["Go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Extensions"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Delete the entire Extensions folder."}),"\n",(0,i.jsx)(n.li,{children:"Reopen the app, only the default extensions should be restored."}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"install-nitro-tensorrt-llm-manually",children:"Install Nitro-TensorRT-LLM manually"}),"\n",(0,i.jsxs)(n.p,{children:["To manually build the artifacts needed to run the server and TensorRT-LLM, you can reference the source code. ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm?tab=readme-ov-file#quickstart",children:"Read here"}),"."]}),"\n",(0,i.jsx)(n.h3,{id:"build-your-own-tensorrt-models",children:"Build your own TensorRT models"}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsx)(n.p,{children:"coming soon"})})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},61914:(e,n,s)=>{s.d(n,{A:()=>i});const i=s.p+"assets/images/image-43682306e0e1318012556ba5111c1b38.png"},28453:(e,n,s)=>{s.d(n,{R:()=>r,x:()=>l});var i=s(96540);const t={},o=i.createContext(t);function r(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:r(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/106736fc.087a487c.js b/assets/js/106736fc.087a487c.js deleted file mode 100644 index 1aeba6fe..00000000 --- a/assets/js/106736fc.087a487c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8663],{92790:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var s=n(74848),o=n(28453);const r={title:"Developers",tags:["audiences"]},i=void 0,a={id:"solutions/developers",title:"Developers",description:"",source:"@site/docs/solutions/developers.md",sourceDirName:"solutions",slug:"/solutions/developers",permalink:"/solutions/developers",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/developers.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Developers",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Government",permalink:"/solutions/government"},next:{title:"Software Consultants",permalink:"/solutions/consultants"}},l={},u=[];function c(e){return(0,s.jsx)(s.Fragment,{})}function d(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(c,{...e})}):c()}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>a});var s=n(96540);const o={},r=s.createContext(o);function i(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:i(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/106736fc.c7df8512.js b/assets/js/106736fc.c7df8512.js new file mode 100644 index 00000000..4c2729c3 --- /dev/null +++ b/assets/js/106736fc.c7df8512.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8663],{92790:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var s=n(74848),o=n(28453);const r={title:"Developers",tags:["audiences"]},i=void 0,a={id:"solutions/developers",title:"Developers",description:"",source:"@site/docs/solutions/developers.md",sourceDirName:"solutions",slug:"/solutions/developers",permalink:"/solutions/developers",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/developers.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Developers",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Government",permalink:"/solutions/government"},next:{title:"Software Consultants",permalink:"/solutions/consultants"}},l={},u=[];function c(e){return(0,s.jsx)(s.Fragment,{})}function d(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(c,{...e})}):c()}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>a});var s=n(96540);const o={},r=s.createContext(o);function i(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:i(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/119e46ed.3e9d2eef.js b/assets/js/119e46ed.3e9d2eef.js new file mode 100644 index 00000000..1f4a9b84 --- /dev/null +++ b/assets/js/119e46ed.3e9d2eef.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7570],{92617:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>a,default:()=>p,frontMatter:()=>o,metadata:()=>c,toc:()=>u});var r=t(74848),s=t(28453),i=t(11470),l=t(19365);const o={title:"Install with Docker",sidebar_position:4,slug:"/guides/install/server",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan using Docker.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Docker","Docker","Helm"]},a=void 0,c={id:"guides/installation/docker",title:"Install with Docker",description:"A step-by-step guide to install Jan using Docker.",source:"@site/docs/guides/installation/docker.mdx",sourceDirName:"guides/installation",slug:"/guides/install/server",permalink:"/guides/install/server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/docker.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:4,frontMatter:{title:"Install with Docker",sidebar_position:4,slug:"/guides/install/server",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan using Docker.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Docker","Docker","Helm"]}},d={},u=[{value:"Pre-requisites",id:"pre-requisites",level:3},{value:"Run Jan in Docker",id:"run-jan-in-docker",level:3},{value:"Docker Compose Profile and Environment",id:"docker-compose-profile-and-environment",level:3},{value:"Docker Compose Profile",id:"docker-compose-profile",level:4},{value:"Environment Variables",id:"environment-variables",level:4}];function h(e){const n={a:"a",admonition:"admonition",code:"code",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h3,{id:"pre-requisites",children:"Pre-requisites"}),"\n",(0,r.jsx)(n.p,{children:"Ensure that your system meets the following requirements:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Linux or WSL2 Docker"}),"\n",(0,r.jsx)(n.li,{children:"Latest Docker Engine and Docker Compose"}),"\n"]}),"\n",(0,r.jsx)(n.p,{children:"To enable GPU support, you will need:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.code,{children:"nvidia-driver"})}),"\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.code,{children:"nvidia-docker2"})}),"\n"]}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["If you have not installed Docker, follow the instructions ",(0,r.jsx)(n.a,{href:"https://docs.docker.com/engine/install/ubuntu/",children:"here"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["If you have not installed the required file for GPU support, follow the instructions ",(0,r.jsx)(n.a,{href:"https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/install-guide.html",children:"here"}),"."]}),"\n"]})}),"\n",(0,r.jsx)(n.h3,{id:"run-jan-in-docker",children:"Run Jan in Docker"}),"\n",(0,r.jsx)(n.p,{children:"You can run Jan in Docker with two methods:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Run Jan in CPU mode"}),"\n",(0,r.jsx)(n.li,{children:"Run Jan in GPU mode"}),"\n"]}),"\n",(0,r.jsxs)(i.A,{groupId:"ldocker_type",children:[(0,r.jsxs)(l.A,{value:"docker_cpu",label:"CPU",children:[(0,r.jsx)(n.p,{children:"To run Jan in Docker CPU mode, by using the following code:"}),(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"# cpu mode with default file system\ndocker compose --profile cpu-fs up -d\n\n# cpu mode with S3 file system\ndocker compose --profile cpu-s3fs up -d\n"})})]}),(0,r.jsxs)(l.A,{value:"docker_gpu",label:"GPU",children:[(0,r.jsx)(n.p,{children:"To run Jan in Docker CPU mode, follow the steps below:"}),(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Check CUDA compatibility with your NVIDIA driver by running nvidia-smi and check the CUDA version in the output as shown below:"}),"\n"]}),(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"nvidia-smi\n\n# Output\n+---------------------------------------------------------------------------------------+\n| NVIDIA-SMI 531.18 Driver Version: 531.18 CUDA Version: 12.1 |\n|-----------------------------------------+----------------------+----------------------+\n| GPU Name TCC/WDDM | Bus-Id Disp.A | Volatile Uncorr. ECC |\n| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |\n| | | MIG M. |\n|=========================================+======================+======================|\n| 0 NVIDIA GeForce RTX 4070 Ti WDDM | 00000000:01:00.0 On | N/A |\n| 0% 44C P8 16W / 285W| 1481MiB / 12282MiB | 2% Default |\n| | | N/A |\n+-----------------------------------------+----------------------+----------------------+\n| 1 NVIDIA GeForce GTX 1660 Ti WDDM | 00000000:02:00.0 Off | N/A |\n| 0% 49C P8 14W / 120W| 0MiB / 6144MiB | 0% Default |\n| | | N/A |\n+-----------------------------------------+----------------------+----------------------+\n| 2 NVIDIA GeForce GTX 1660 Ti WDDM | 00000000:05:00.0 Off | N/A |\n| 29% 38C P8 11W / 120W| 0MiB / 6144MiB | 0% Default |\n| | | N/A |\n+-----------------------------------------+----------------------+----------------------+\n\n+---------------------------------------------------------------------------------------+\n| Processes: |\n| GPU GI CI PID Type Process name GPU Memory |\n| ID ID Usage |\n|=======================================================================================|\n"})}),(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsxs)(n.li,{children:["Visit ",(0,r.jsx)(n.a,{href:"https://catalog.ngc.nvidia.com/orgs/nvidia/containers/cuda/tags",children:"NVIDIA NGC Catalog"})," and find the smallest minor version of image tag that matches your CUDA version (e.g., 12.1 -> 12.1.0)"]}),"\n",(0,r.jsxs)(n.li,{children:["Update the ",(0,r.jsx)(n.code,{children:"Dockerfile.gpu"})," line number 5 with the latest minor version of the image tag from step 2 (e.g. change ",(0,r.jsx)(n.code,{children:"FROM nvidia/cuda:12.2.0-runtime-ubuntu22.04 AS base"})," to ",(0,r.jsx)(n.code,{children:"FROM nvidia/cuda:12.1.0-runtime-ubuntu22.04 AS base"}),")"]}),"\n",(0,r.jsx)(n.li,{children:"Run Jan in GPU mode by using the following command:"}),"\n"]}),(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"# GPU mode with default file system\ndocker compose --profile gpu-fs up -d\n\n# GPU mode with S3 file system\ndocker compose --profile gpu-s3fs up -d\n"})})]})]}),"\n",(0,r.jsx)(n.h3,{id:"docker-compose-profile-and-environment",children:"Docker Compose Profile and Environment"}),"\n",(0,r.jsx)(n.p,{children:"The available Docker Compose profile and the environment variables listed below:"}),"\n",(0,r.jsx)(n.h4,{id:"docker-compose-profile",children:"Docker Compose Profile"}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Profile"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"cpu-fs"}),(0,r.jsx)(n.td,{children:"Run Jan in CPU mode with default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"cpu-s3fs"}),(0,r.jsx)(n.td,{children:"Run Jan in CPU mode with S3 file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"gpu-fs"}),(0,r.jsx)(n.td,{children:"Run Jan in GPU mode with default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"gpu-s3fs"}),(0,r.jsx)(n.td,{children:"Run Jan in GPU mode with S3 file system"})]})]})]}),"\n",(0,r.jsx)(n.h4,{id:"environment-variables",children:"Environment Variables"}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Environment Variable"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"S3_BUCKET_NAME"}),(0,r.jsx)(n.td,{children:"S3 bucket name - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_ACCESS_KEY_ID"}),(0,r.jsx)(n.td,{children:"AWS access key ID - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_SECRET_ACCESS_KEY"}),(0,r.jsx)(n.td,{children:"AWS secret access key - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_ENDPOINT"}),(0,r.jsx)(n.td,{children:"AWS endpoint URL - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_REGION"}),(0,r.jsx)(n.td,{children:"AWS region - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"API_BASE_URL"}),(0,r.jsxs)(n.td,{children:["Jan Server URL, please modify it as your public ip address or domain name default ",(0,r.jsx)(n.a,{href:"http://localhost:1377",children:"http://localhost:1377"})]})]})]})]}),"\n",(0,r.jsx)(n.admonition,{type:"warning",children:(0,r.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,r.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]})}function p(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>l});t(96540);var r=t(18215);const s={tabItem:"tabItem_Ymn6"};var i=t(74848);function l(e){let{children:n,hidden:t,className:l}=e;return(0,i.jsx)("div",{role:"tabpanel",className:(0,r.A)(s.tabItem,l),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>y});var r=t(96540),s=t(18215),i=t(23104),l=t(56347),o=t(205),a=t(57485),c=t(31682),d=t(89466);function u(e){return r.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function h(e){const{values:n,children:t}=e;return(0,r.useMemo)((()=>{const e=n??function(e){return u(e).map((e=>{let{props:{value:n,label:t,attributes:r,default:s}}=e;return{value:n,label:t,attributes:r,default:s}}))}(t);return function(e){const n=(0,c.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function f(e){let{queryString:n=!1,groupId:t}=e;const s=(0,l.W6)(),i=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,a.aZ)(i),(0,r.useCallback)((e=>{if(!i)return;const n=new URLSearchParams(s.location.search);n.set(i,e),s.replace({...s.location,search:n.toString()})}),[i,s])]}function m(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,i=h(e),[l,a]=(0,r.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const r=t.find((e=>e.default))??t[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:n,tabValues:i}))),[c,u]=f({queryString:t,groupId:s}),[m,b]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,i]=(0,d.Dv)(t);return[s,(0,r.useCallback)((e=>{t&&i.set(e)}),[t,i])]}({groupId:s}),x=(()=>{const e=c??m;return p({value:e,tabValues:i})?e:null})();(0,o.A)((()=>{x&&a(x)}),[x]);return{selectedValue:l,selectValue:(0,r.useCallback)((e=>{if(!p({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);a(e),u(e),b(e)}),[u,b,i]),tabValues:i}}var b=t(92303);const x={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var j=t(74848);function v(e){let{className:n,block:t,selectedValue:r,selectValue:l,tabValues:o}=e;const a=[],{blockElementScrollPositionUntilNextRender:c}=(0,i.a_)(),d=e=>{const n=e.currentTarget,t=a.indexOf(n),s=o[t].value;s!==r&&(c(n),l(s))},u=e=>{let n=null;switch(e.key){case"Enter":d(e);break;case"ArrowRight":{const t=a.indexOf(e.currentTarget)+1;n=a[t]??a[0];break}case"ArrowLeft":{const t=a.indexOf(e.currentTarget)-1;n=a[t]??a[a.length-1];break}}n?.focus()};return(0,j.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:o.map((e=>{let{value:n,label:t,attributes:i}=e;return(0,j.jsx)("li",{role:"tab",tabIndex:r===n?0:-1,"aria-selected":r===n,ref:e=>a.push(e),onKeyDown:u,onClick:d,...i,className:(0,s.A)("tabs__item",x.tabItem,i?.className,{"tabs__item--active":r===n}),children:t??n},n)}))})}function g(e){let{lazy:n,children:t,selectedValue:s}=e;const i=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=i.find((e=>e.props.value===s));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return(0,j.jsx)("div",{className:"margin-top--md",children:i.map(((e,n)=>(0,r.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function k(e){const n=m(e);return(0,j.jsxs)("div",{className:(0,s.A)("tabs-container",x.tabList),children:[(0,j.jsx)(v,{...e,...n}),(0,j.jsx)(g,{...e,...n})]})}function y(e){const n=(0,b.A)();return(0,j.jsx)(k,{...e,children:u(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>l,x:()=>o});var r=t(96540);const s={},i=r.createContext(s);function l(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:l(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/119e46ed.9caf18e3.js b/assets/js/119e46ed.9caf18e3.js deleted file mode 100644 index e9f66147..00000000 --- a/assets/js/119e46ed.9caf18e3.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7570],{92617:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>a,default:()=>p,frontMatter:()=>o,metadata:()=>c,toc:()=>u});var r=t(74848),s=t(28453),i=t(11470),l=t(19365);const o={title:"Install with Docker",sidebar_position:4,slug:"/guides/install/server",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan using Docker.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Docker","Docker","Helm"]},a=void 0,c={id:"guides/installation/docker",title:"Install with Docker",description:"A step-by-step guide to install Jan using Docker.",source:"@site/docs/guides/installation/docker.mdx",sourceDirName:"guides/installation",slug:"/guides/install/server",permalink:"/guides/install/server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/docker.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:4,frontMatter:{title:"Install with Docker",sidebar_position:4,slug:"/guides/install/server",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan using Docker.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Docker","Docker","Helm"]}},d={},u=[{value:"Pre-requisites",id:"pre-requisites",level:3},{value:"Run Jan in Docker",id:"run-jan-in-docker",level:3},{value:"Docker Compose Profile and Environment",id:"docker-compose-profile-and-environment",level:3},{value:"Docker Compose Profile",id:"docker-compose-profile",level:4},{value:"Environment Variables",id:"environment-variables",level:4}];function h(e){const n={a:"a",admonition:"admonition",code:"code",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h3,{id:"pre-requisites",children:"Pre-requisites"}),"\n",(0,r.jsx)(n.p,{children:"Ensure that your system meets the following requirements:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Linux or WSL2 Docker"}),"\n",(0,r.jsx)(n.li,{children:"Latest Docker Engine and Docker Compose"}),"\n"]}),"\n",(0,r.jsx)(n.p,{children:"To enable GPU support, you will need:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.code,{children:"nvidia-driver"})}),"\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.code,{children:"nvidia-docker2"})}),"\n"]}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["If you have not installed Docker, follow the instructions ",(0,r.jsx)(n.a,{href:"https://docs.docker.com/engine/install/ubuntu/",children:"here"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["If you have not installed the required file for GPU support, follow the instructions ",(0,r.jsx)(n.a,{href:"https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/install-guide.html",children:"here"}),"."]}),"\n"]})}),"\n",(0,r.jsx)(n.h3,{id:"run-jan-in-docker",children:"Run Jan in Docker"}),"\n",(0,r.jsx)(n.p,{children:"You can run Jan in Docker with two methods:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Run Jan in CPU mode"}),"\n",(0,r.jsx)(n.li,{children:"Run Jan in GPU mode"}),"\n"]}),"\n",(0,r.jsxs)(i.A,{groupId:"ldocker_type",children:[(0,r.jsxs)(l.A,{value:"docker_cpu",label:"CPU",children:[(0,r.jsx)(n.p,{children:"To run Jan in Docker CPU mode, by using the following code:"}),(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"# cpu mode with default file system\ndocker compose --profile cpu-fs up -d\n\n# cpu mode with S3 file system\ndocker compose --profile cpu-s3fs up -d\n"})})]}),(0,r.jsxs)(l.A,{value:"docker_gpu",label:"GPU",children:[(0,r.jsx)(n.p,{children:"To run Jan in Docker CPU mode, follow the steps below:"}),(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Check CUDA compatibility with your NVIDIA driver by running nvidia-smi and check the CUDA version in the output as shown below:"}),"\n"]}),(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"nvidia-smi\n\n# Output\n+---------------------------------------------------------------------------------------+\n| NVIDIA-SMI 531.18 Driver Version: 531.18 CUDA Version: 12.1 |\n|-----------------------------------------+----------------------+----------------------+\n| GPU Name TCC/WDDM | Bus-Id Disp.A | Volatile Uncorr. ECC |\n| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |\n| | | MIG M. |\n|=========================================+======================+======================|\n| 0 NVIDIA GeForce RTX 4070 Ti WDDM | 00000000:01:00.0 On | N/A |\n| 0% 44C P8 16W / 285W| 1481MiB / 12282MiB | 2% Default |\n| | | N/A |\n+-----------------------------------------+----------------------+----------------------+\n| 1 NVIDIA GeForce GTX 1660 Ti WDDM | 00000000:02:00.0 Off | N/A |\n| 0% 49C P8 14W / 120W| 0MiB / 6144MiB | 0% Default |\n| | | N/A |\n+-----------------------------------------+----------------------+----------------------+\n| 2 NVIDIA GeForce GTX 1660 Ti WDDM | 00000000:05:00.0 Off | N/A |\n| 29% 38C P8 11W / 120W| 0MiB / 6144MiB | 0% Default |\n| | | N/A |\n+-----------------------------------------+----------------------+----------------------+\n\n+---------------------------------------------------------------------------------------+\n| Processes: |\n| GPU GI CI PID Type Process name GPU Memory |\n| ID ID Usage |\n|=======================================================================================|\n"})}),(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsxs)(n.li,{children:["Visit ",(0,r.jsx)(n.a,{href:"https://catalog.ngc.nvidia.com/orgs/nvidia/containers/cuda/tags",children:"NVIDIA NGC Catalog"})," and find the smallest minor version of image tag that matches your CUDA version (e.g., 12.1 -> 12.1.0)"]}),"\n",(0,r.jsxs)(n.li,{children:["Update the ",(0,r.jsx)(n.code,{children:"Dockerfile.gpu"})," line number 5 with the latest minor version of the image tag from step 2 (e.g. change ",(0,r.jsx)(n.code,{children:"FROM nvidia/cuda:12.2.0-runtime-ubuntu22.04 AS base"})," to ",(0,r.jsx)(n.code,{children:"FROM nvidia/cuda:12.1.0-runtime-ubuntu22.04 AS base"}),")"]}),"\n",(0,r.jsx)(n.li,{children:"Run Jan in GPU mode by using the following command:"}),"\n"]}),(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"# GPU mode with default file system\ndocker compose --profile gpu-fs up -d\n\n# GPU mode with S3 file system\ndocker compose --profile gpu-s3fs up -d\n"})})]})]}),"\n",(0,r.jsx)(n.h3,{id:"docker-compose-profile-and-environment",children:"Docker Compose Profile and Environment"}),"\n",(0,r.jsx)(n.p,{children:"The available Docker Compose profile and the environment variables listed below:"}),"\n",(0,r.jsx)(n.h4,{id:"docker-compose-profile",children:"Docker Compose Profile"}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Profile"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"cpu-fs"}),(0,r.jsx)(n.td,{children:"Run Jan in CPU mode with default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"cpu-s3fs"}),(0,r.jsx)(n.td,{children:"Run Jan in CPU mode with S3 file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"gpu-fs"}),(0,r.jsx)(n.td,{children:"Run Jan in GPU mode with default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"gpu-s3fs"}),(0,r.jsx)(n.td,{children:"Run Jan in GPU mode with S3 file system"})]})]})]}),"\n",(0,r.jsx)(n.h4,{id:"environment-variables",children:"Environment Variables"}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Environment Variable"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"S3_BUCKET_NAME"}),(0,r.jsx)(n.td,{children:"S3 bucket name - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_ACCESS_KEY_ID"}),(0,r.jsx)(n.td,{children:"AWS access key ID - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_SECRET_ACCESS_KEY"}),(0,r.jsx)(n.td,{children:"AWS secret access key - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_ENDPOINT"}),(0,r.jsx)(n.td,{children:"AWS endpoint URL - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"AWS_REGION"}),(0,r.jsx)(n.td,{children:"AWS region - leave blank for default file system"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"API_BASE_URL"}),(0,r.jsxs)(n.td,{children:["Jan Server URL, please modify it as your public ip address or domain name default ",(0,r.jsx)(n.a,{href:"http://localhost:1377",children:"http://localhost:1377"})]})]})]})]}),"\n",(0,r.jsx)(n.admonition,{type:"warning",children:(0,r.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,r.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]})}function p(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>l});t(96540);var r=t(18215);const s={tabItem:"tabItem_Ymn6"};var i=t(74848);function l(e){let{children:n,hidden:t,className:l}=e;return(0,i.jsx)("div",{role:"tabpanel",className:(0,r.A)(s.tabItem,l),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>y});var r=t(96540),s=t(18215),i=t(23104),l=t(56347),o=t(205),a=t(57485),c=t(31682),d=t(89466);function u(e){return r.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function h(e){const{values:n,children:t}=e;return(0,r.useMemo)((()=>{const e=n??function(e){return u(e).map((e=>{let{props:{value:n,label:t,attributes:r,default:s}}=e;return{value:n,label:t,attributes:r,default:s}}))}(t);return function(e){const n=(0,c.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function f(e){let{queryString:n=!1,groupId:t}=e;const s=(0,l.W6)(),i=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,a.aZ)(i),(0,r.useCallback)((e=>{if(!i)return;const n=new URLSearchParams(s.location.search);n.set(i,e),s.replace({...s.location,search:n.toString()})}),[i,s])]}function m(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,i=h(e),[l,a]=(0,r.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const r=t.find((e=>e.default))??t[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:n,tabValues:i}))),[c,u]=f({queryString:t,groupId:s}),[m,b]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,i]=(0,d.Dv)(t);return[s,(0,r.useCallback)((e=>{t&&i.set(e)}),[t,i])]}({groupId:s}),x=(()=>{const e=c??m;return p({value:e,tabValues:i})?e:null})();(0,o.A)((()=>{x&&a(x)}),[x]);return{selectedValue:l,selectValue:(0,r.useCallback)((e=>{if(!p({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);a(e),u(e),b(e)}),[u,b,i]),tabValues:i}}var b=t(92303);const x={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var j=t(74848);function v(e){let{className:n,block:t,selectedValue:r,selectValue:l,tabValues:o}=e;const a=[],{blockElementScrollPositionUntilNextRender:c}=(0,i.a_)(),d=e=>{const n=e.currentTarget,t=a.indexOf(n),s=o[t].value;s!==r&&(c(n),l(s))},u=e=>{let n=null;switch(e.key){case"Enter":d(e);break;case"ArrowRight":{const t=a.indexOf(e.currentTarget)+1;n=a[t]??a[0];break}case"ArrowLeft":{const t=a.indexOf(e.currentTarget)-1;n=a[t]??a[a.length-1];break}}n?.focus()};return(0,j.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:o.map((e=>{let{value:n,label:t,attributes:i}=e;return(0,j.jsx)("li",{role:"tab",tabIndex:r===n?0:-1,"aria-selected":r===n,ref:e=>a.push(e),onKeyDown:u,onClick:d,...i,className:(0,s.A)("tabs__item",x.tabItem,i?.className,{"tabs__item--active":r===n}),children:t??n},n)}))})}function g(e){let{lazy:n,children:t,selectedValue:s}=e;const i=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=i.find((e=>e.props.value===s));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return(0,j.jsx)("div",{className:"margin-top--md",children:i.map(((e,n)=>(0,r.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function k(e){const n=m(e);return(0,j.jsxs)("div",{className:(0,s.A)("tabs-container",x.tabList),children:[(0,j.jsx)(v,{...e,...n}),(0,j.jsx)(g,{...e,...n})]})}function y(e){const n=(0,b.A)();return(0,j.jsx)(k,{...e,children:u(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>l,x:()=>o});var r=t(96540);const s={},i=r.createContext(s);function l(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:l(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/11c8e996.3b9b91c6.js b/assets/js/11c8e996.3b9b91c6.js deleted file mode 100644 index 045ad8cc..00000000 --- a/assets/js/11c8e996.3b9b91c6.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2563],{11318:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>d,contentTitle:()=>l,default:()=>h,frontMatter:()=>t,metadata:()=>o,toc:()=>a});var i=s(74848),r=s(28453);const t={title:"TensorRT-LLM",slug:"/guides/providers/tensorrt-llm",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]},l=void 0,o={id:"guides/providers/tensorrt-llm",title:"TensorRT-LLM",description:"TensorRT-LLM support was launched in 0.4.9, and should be regarded as an Experimental feature.",source:"@site/docs/guides/providers/tensorrt-llm.md",sourceDirName:"guides/providers",slug:"/guides/providers/tensorrt-llm",permalink:"/guides/providers/tensorrt-llm",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/providers/tensorrt-llm.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"TensorRT-LLM",slug:"/guides/providers/tensorrt-llm",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]}},d={},a=[{value:"What is TensorRT-LLM?",id:"what-is-tensorrt-llm",level:2},{value:"Requirements",id:"requirements",level:2},{value:"Hardware",id:"hardware",level:3},{value:"Software",id:"software",level:3},{value:"Getting Started",id:"getting-started",level:2},{value:"Install TensorRT-Extension",id:"install-tensorrt-extension",level:3},{value:"Download a TensorRT-LLM Model",id:"download-a-tensorrt-llm-model",level:3},{value:"Importing Pre-built Models",id:"importing-pre-built-models",level:3},{value:"Using a TensorRT-LLM Model",id:"using-a-tensorrt-llm-model",level:3},{value:"Configure Settings",id:"configure-settings",level:3},{value:"Troubleshooting",id:"troubleshooting",level:2},{value:"Extension Details",id:"extension-details",level:2},{value:"Manual Build",id:"manual-build",level:3},{value:"Uninstall Extension",id:"uninstall-extension",level:3},{value:"Build your own TensorRT models",id:"build-your-own-tensorrt-models",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsxs)(n.admonition,{type:"info",children:[(0,i.jsx)(n.p,{children:"TensorRT-LLM support was launched in 0.4.9, and should be regarded as an Experimental feature."}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Only Windows is supported for now."}),"\n",(0,i.jsxs)(n.li,{children:["Please report bugs in our Discord's ",(0,i.jsx)(n.a,{href:"https://discord.com/channels/1107178041848909847/1201832734704795688",children:"#tensorrt-llm"})," channel."]}),"\n"]})]}),"\n",(0,i.jsxs)(n.p,{children:["Jan supports ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"})," as an alternate Inference Engine, for users who have Nvidia GPUs with large VRAM. TensorRT-LLM allows for blazing fast inference, but requires Nvidia GPUs with ",(0,i.jsx)(n.a,{href:"https://nvidia.github.io/TensorRT-LLM/memory.html",children:"larger VRAM"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"what-is-tensorrt-llm",children:"What is TensorRT-LLM?"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"})," is an hardware-optimized LLM inference engine for Nvidia GPUs, that compiles models to run extremely fast on Nvidia GPUs."]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Mainly used on Nvidia's Datacenter-grade GPUs like the H100s ",(0,i.jsx)(n.a,{href:"https://nvidia.github.io/TensorRT-LLM/blogs/H100vsA100.html",children:"to produce 10,000 tok/s"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Can be used on Nvidia's workstation (e.g. ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/en-us/design-visualization/rtx-6000/",children:"A6000"}),") and consumer-grade GPUs (e.g. ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/en-us/geforce/graphics-cards/40-series/rtx-4090/",children:"RTX 4090"}),")"]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{title:"Benefits",type:"tip",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Our performance testing shows 20-40% faster token/s speeds on consumer-grade GPUs"}),"\n",(0,i.jsx)(n.li,{children:"On datacenter-grade GPUs, TensorRT-LLM can go up to 10,000 tokens/s"}),"\n",(0,i.jsxs)(n.li,{children:["TensorRT-LLM is a relatively new library, that was ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM/graphs/contributors",children:"released in Sept 2023"}),". We anticipate performance and resource utilization improvements in the future."]}),"\n"]})}),"\n",(0,i.jsx)(n.admonition,{title:"Caveats",type:"warning",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:'TensorRT-LLM requires models to be compiled into GPU and OS-specific "Model Engines" (vs. GGUF\'s "convert once, run anywhere" approach)'}),"\n",(0,i.jsx)(n.li,{children:"TensorRT-LLM Model Engines tend to utilize larger amount of VRAM and RAM in exchange for performance"}),"\n",(0,i.jsx)(n.li,{children:"This usually means only people with top-of-the-line Nvidia GPUs can use TensorRT-LLM"}),"\n"]})}),"\n",(0,i.jsx)(n.h2,{id:"requirements",children:"Requirements"}),"\n",(0,i.jsx)(n.h3,{id:"hardware",children:"Hardware"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Windows PC"}),"\n",(0,i.jsx)(n.li,{children:"Nvidia GPU(s): Ada or Ampere series (i.e. RTX 4000s & 3000s). More will be supported soon."}),"\n",(0,i.jsx)(n.li,{children:"3GB+ of disk space to download TRT-LLM artifacts and a Nitro binary"}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Compatible GPUs"})}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{children:"Architecture"}),(0,i.jsx)(n.th,{children:"Supported?"}),(0,i.jsx)(n.th,{children:"Consumer-grade"}),(0,i.jsx)(n.th,{children:"Workstation-grade"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Ada"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"4050 and above"}),(0,i.jsx)(n.td,{children:"RTX A2000 Ada"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Ampere"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"3050 and above"}),(0,i.jsx)(n.td,{children:"A100"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Turing"}),(0,i.jsx)(n.td,{children:"\u274c"}),(0,i.jsx)(n.td,{children:"Not Supported"}),(0,i.jsx)(n.td,{children:"Not Supported"})]})]})]}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsxs)(n.p,{children:["Please ping us in Discord's ",(0,i.jsx)(n.a,{href:"https://discord.com/channels/1107178041848909847/1201832734704795688",children:"#tensorrt-llm"})," channel if you would like Turing support."]})}),"\n",(0,i.jsx)(n.h3,{id:"software",children:"Software"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Jan v0.4.9+ or Jan v0.4.8-321+ (nightly)"}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://jan.ai/guides/common-error/not-using-gpu/#1-ensure-gpu-mode-requirements",children:"Nvidia Driver v535+"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://jan.ai/guides/common-error/not-using-gpu/#1-ensure-gpu-mode-requirements",children:"CUDA Toolkit v12.2+"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"getting-started",children:"Getting Started"}),"\n",(0,i.jsx)(n.h3,{id:"install-tensorrt-extension",children:"Install TensorRT-Extension"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Go to Settings > Extensions"}),"\n",(0,i.jsx)(n.li,{children:"Install the TensorRT-LLM Extension"}),"\n"]}),"\n",(0,i.jsxs)(n.admonition,{type:"info",children:[(0,i.jsx)(n.p,{children:"You can check if files have been correctly downloaded:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"ls ~\\jan\\extensions\\@janhq\\tensorrt-llm-extension\\dist\\bin\n# Your Extension Folder should now include `nitro.exe`, among other `.dll` files needed to run TRT-LLM\n"})})]}),"\n",(0,i.jsx)(n.h3,{id:"download-a-tensorrt-llm-model",children:"Download a TensorRT-LLM Model"}),"\n",(0,i.jsxs)(n.p,{children:["Jan's Hub has a few pre-compiled TensorRT-LLM models that you can download, which have a ",(0,i.jsx)(n.code,{children:"TensorRT-LLM"})," label"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"We automatically download the TensorRT-LLM Model Engine for your GPU architecture"}),"\n",(0,i.jsx)(n.li,{children:"We have made a few 1.1b models available that can run even on Laptop GPUs with 8gb VRAM"}),"\n"]}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{children:"Model"}),(0,i.jsx)(n.th,{children:"OS"}),(0,i.jsx)(n.th,{children:"Ada (40XX)"}),(0,i.jsx)(n.th,{children:"Ampere (30XX)"}),(0,i.jsx)(n.th,{children:"Description"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Llamacorn 1.1b"}),(0,i.jsx)(n.td,{children:"Windows"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"TinyLlama-1.1b, fine-tuned for usability"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"TinyJensen 1.1b"}),(0,i.jsx)(n.td,{children:"Windows"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"TinyLlama-1.1b, fine-tuned on Jensen Huang speeches"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Mistral Instruct 7b"}),(0,i.jsx)(n.td,{children:"Windows"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"Mistral"})]})]})]}),"\n",(0,i.jsx)(n.h3,{id:"importing-pre-built-models",children:"Importing Pre-built Models"}),"\n",(0,i.jsxs)(n.p,{children:["You can import a pre-built model, by creating a new folder in Jan's ",(0,i.jsx)(n.code,{children:"/models"})," directory that includes:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["TensorRT-LLM Engine files (e.g. ",(0,i.jsx)(n.code,{children:"tokenizer"}),", ",(0,i.jsx)(n.code,{children:".engine"}),", etc)"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"model.json"})," that registers these files, and specifies ",(0,i.jsx)(n.code,{children:"engine"})," as ",(0,i.jsx)(n.code,{children:"nitro-tensorrt-llm"})]}),"\n"]}),"\n",(0,i.jsxs)(n.admonition,{title:"Sample model.json",type:"note",children:[(0,i.jsxs)(n.p,{children:["Note the ",(0,i.jsx)(n.code,{children:"engine"})," is ",(0,i.jsx)(n.code,{children:"nitro-tensorrt-llm"}),": this won't work without it!"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'{\n "sources": [\n {\n "filename": "config.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/config.json"\n },\n {\n "filename": "mistral_float16_tp1_rank0.engine",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/mistral_float16_tp1_rank0.engine"\n },\n {\n "filename": "tokenizer.model",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/tokenizer.model"\n },\n {\n "filename": "special_tokens_map.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/special_tokens_map.json"\n },\n {\n "filename": "tokenizer.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/tokenizer.json"\n },\n {\n "filename": "tokenizer_config.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/tokenizer_config.json"\n },\n {\n "filename": "model.cache",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/model.cache"\n }\n ],\n "id": "tinyjensen-1.1b-chat-fp16",\n "object": "model",\n "name": "TinyJensen 1.1B Chat FP16",\n "version": "1.0",\n "description": "Do you want to chat with Jensen Huan? Here you are",\n "format": "TensorRT-LLM",\n "settings": {\n "ctx_len": 2048,\n "text_model": false\n },\n "parameters": {\n "max_tokens": 4096\n },\n "metadata": {\n "author": "LLama",\n "tags": [\n "TensorRT-LLM",\n "1B",\n "Finetuned"\n ],\n "size": 2151000000\n },\n "engine": "nitro-tensorrt-llm"\n}\n'})})]}),"\n",(0,i.jsx)(n.h3,{id:"using-a-tensorrt-llm-model",children:"Using a TensorRT-LLM Model"}),"\n",(0,i.jsx)(n.p,{children:"You can just select and use a TensorRT-LLM model from Jan's Thread interface."}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Jan will automatically start the TensorRT-LLM model engine in the background"}),"\n",(0,i.jsx)(n.li,{children:"You may encounter a pop-up from Windows Security, asking for Nitro to allow public and private network access"}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{title:"Why does Nitro need network access?",type:"info",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["This is because Jan runs TensorRT-LLM using the ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm/",children:"Nitro Server"})]}),"\n",(0,i.jsx)(n.li,{children:"Jan makes network calls to the Nitro server running on your computer on a separate port"}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"configure-settings",children:"Configure Settings"}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"coming soon"})}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,i.jsx)(n.h2,{id:"extension-details",children:"Extension Details"}),"\n",(0,i.jsxs)(n.p,{children:["Jan's TensorRT-LLM Extension is built on top of the open source ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm",children:"Nitro TensorRT-LLM Server"}),", a C++ inference server on top of TensorRT-LLM that provides an OpenAI-compatible API."]}),"\n",(0,i.jsx)(n.h3,{id:"manual-build",children:"Manual Build"}),"\n",(0,i.jsxs)(n.p,{children:["To manually build the artifacts needed to run the server and TensorRT-LLM, you can reference the source code. ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm?tab=readme-ov-file#quickstart",children:"Read here"}),"."]}),"\n",(0,i.jsx)(n.h3,{id:"uninstall-extension",children:"Uninstall Extension"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Quit the app"}),"\n",(0,i.jsx)(n.li,{children:"Go to Settings > Extensions"}),"\n",(0,i.jsx)(n.li,{children:"Delete the entire Extensions folder."}),"\n",(0,i.jsx)(n.li,{children:"Reopen the app, only the default extensions should be restored."}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"build-your-own-tensorrt-models",children:"Build your own TensorRT models"}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsx)(n.p,{children:"coming soon"})})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>l,x:()=>o});var i=s(96540);const r={},t=i.createContext(r);function l(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:l(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/11c8e996.e477498f.js b/assets/js/11c8e996.e477498f.js new file mode 100644 index 00000000..8b04bdc0 --- /dev/null +++ b/assets/js/11c8e996.e477498f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2563],{11318:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>d,contentTitle:()=>l,default:()=>h,frontMatter:()=>t,metadata:()=>o,toc:()=>a});var i=s(74848),r=s(28453);const t={title:"TensorRT-LLM",slug:"/guides/providers/tensorrt-llm",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]},l=void 0,o={id:"guides/providers/tensorrt-llm",title:"TensorRT-LLM",description:"TensorRT-LLM support was launched in 0.4.9, and should be regarded as an Experimental feature.",source:"@site/docs/guides/providers/tensorrt-llm.md",sourceDirName:"guides/providers",slug:"/guides/providers/tensorrt-llm",permalink:"/guides/providers/tensorrt-llm",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/providers/tensorrt-llm.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"TensorRT-LLM",slug:"/guides/providers/tensorrt-llm",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","TensorRT-LLM Extension","TensorRT","tensorRT","extension"]}},d={},a=[{value:"What is TensorRT-LLM?",id:"what-is-tensorrt-llm",level:2},{value:"Requirements",id:"requirements",level:2},{value:"Hardware",id:"hardware",level:3},{value:"Software",id:"software",level:3},{value:"Getting Started",id:"getting-started",level:2},{value:"Install TensorRT-Extension",id:"install-tensorrt-extension",level:3},{value:"Download a TensorRT-LLM Model",id:"download-a-tensorrt-llm-model",level:3},{value:"Importing Pre-built Models",id:"importing-pre-built-models",level:3},{value:"Using a TensorRT-LLM Model",id:"using-a-tensorrt-llm-model",level:3},{value:"Configure Settings",id:"configure-settings",level:3},{value:"Troubleshooting",id:"troubleshooting",level:2},{value:"Extension Details",id:"extension-details",level:2},{value:"Manual Build",id:"manual-build",level:3},{value:"Uninstall Extension",id:"uninstall-extension",level:3},{value:"Build your own TensorRT models",id:"build-your-own-tensorrt-models",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsxs)(n.admonition,{type:"info",children:[(0,i.jsx)(n.p,{children:"TensorRT-LLM support was launched in 0.4.9, and should be regarded as an Experimental feature."}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Only Windows is supported for now."}),"\n",(0,i.jsxs)(n.li,{children:["Please report bugs in our Discord's ",(0,i.jsx)(n.a,{href:"https://discord.com/channels/1107178041848909847/1201832734704795688",children:"#tensorrt-llm"})," channel."]}),"\n"]})]}),"\n",(0,i.jsxs)(n.p,{children:["Jan supports ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"})," as an alternate Inference Engine, for users who have Nvidia GPUs with large VRAM. TensorRT-LLM allows for blazing fast inference, but requires Nvidia GPUs with ",(0,i.jsx)(n.a,{href:"https://nvidia.github.io/TensorRT-LLM/memory.html",children:"larger VRAM"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"what-is-tensorrt-llm",children:"What is TensorRT-LLM?"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"})," is an hardware-optimized LLM inference engine for Nvidia GPUs, that compiles models to run extremely fast on Nvidia GPUs."]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Mainly used on Nvidia's Datacenter-grade GPUs like the H100s ",(0,i.jsx)(n.a,{href:"https://nvidia.github.io/TensorRT-LLM/blogs/H100vsA100.html",children:"to produce 10,000 tok/s"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Can be used on Nvidia's workstation (e.g. ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/en-us/design-visualization/rtx-6000/",children:"A6000"}),") and consumer-grade GPUs (e.g. ",(0,i.jsx)(n.a,{href:"https://www.nvidia.com/en-us/geforce/graphics-cards/40-series/rtx-4090/",children:"RTX 4090"}),")"]}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{title:"Benefits",type:"tip",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Our performance testing shows 20-40% faster token/s speeds on consumer-grade GPUs"}),"\n",(0,i.jsx)(n.li,{children:"On datacenter-grade GPUs, TensorRT-LLM can go up to 10,000 tokens/s"}),"\n",(0,i.jsxs)(n.li,{children:["TensorRT-LLM is a relatively new library, that was ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM/graphs/contributors",children:"released in Sept 2023"}),". We anticipate performance and resource utilization improvements in the future."]}),"\n"]})}),"\n",(0,i.jsx)(n.admonition,{title:"Caveats",type:"warning",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:'TensorRT-LLM requires models to be compiled into GPU and OS-specific "Model Engines" (vs. GGUF\'s "convert once, run anywhere" approach)'}),"\n",(0,i.jsx)(n.li,{children:"TensorRT-LLM Model Engines tend to utilize larger amount of VRAM and RAM in exchange for performance"}),"\n",(0,i.jsx)(n.li,{children:"This usually means only people with top-of-the-line Nvidia GPUs can use TensorRT-LLM"}),"\n"]})}),"\n",(0,i.jsx)(n.h2,{id:"requirements",children:"Requirements"}),"\n",(0,i.jsx)(n.h3,{id:"hardware",children:"Hardware"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Windows PC"}),"\n",(0,i.jsx)(n.li,{children:"Nvidia GPU(s): Ada or Ampere series (i.e. RTX 4000s & 3000s). More will be supported soon."}),"\n",(0,i.jsx)(n.li,{children:"3GB+ of disk space to download TRT-LLM artifacts and a Nitro binary"}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Compatible GPUs"})}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{children:"Architecture"}),(0,i.jsx)(n.th,{children:"Supported?"}),(0,i.jsx)(n.th,{children:"Consumer-grade"}),(0,i.jsx)(n.th,{children:"Workstation-grade"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Ada"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"4050 and above"}),(0,i.jsx)(n.td,{children:"RTX A2000 Ada"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Ampere"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"3050 and above"}),(0,i.jsx)(n.td,{children:"A100"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Turing"}),(0,i.jsx)(n.td,{children:"\u274c"}),(0,i.jsx)(n.td,{children:"Not Supported"}),(0,i.jsx)(n.td,{children:"Not Supported"})]})]})]}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsxs)(n.p,{children:["Please ping us in Discord's ",(0,i.jsx)(n.a,{href:"https://discord.com/channels/1107178041848909847/1201832734704795688",children:"#tensorrt-llm"})," channel if you would like Turing support."]})}),"\n",(0,i.jsx)(n.h3,{id:"software",children:"Software"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Jan v0.4.9+ or Jan v0.4.8-321+ (nightly)"}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://jan.ai/guides/common-error/not-using-gpu/#1-ensure-gpu-mode-requirements",children:"Nvidia Driver v535+"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://jan.ai/guides/common-error/not-using-gpu/#1-ensure-gpu-mode-requirements",children:"CUDA Toolkit v12.2+"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"getting-started",children:"Getting Started"}),"\n",(0,i.jsx)(n.h3,{id:"install-tensorrt-extension",children:"Install TensorRT-Extension"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Go to Settings > Extensions"}),"\n",(0,i.jsx)(n.li,{children:"Install the TensorRT-LLM Extension"}),"\n"]}),"\n",(0,i.jsxs)(n.admonition,{type:"info",children:[(0,i.jsx)(n.p,{children:"You can check if files have been correctly downloaded:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"ls ~\\jan\\extensions\\@janhq\\tensorrt-llm-extension\\dist\\bin\n# Your Extension Folder should now include `nitro.exe`, among other `.dll` files needed to run TRT-LLM\n"})})]}),"\n",(0,i.jsx)(n.h3,{id:"download-a-tensorrt-llm-model",children:"Download a TensorRT-LLM Model"}),"\n",(0,i.jsxs)(n.p,{children:["Jan's Hub has a few pre-compiled TensorRT-LLM models that you can download, which have a ",(0,i.jsx)(n.code,{children:"TensorRT-LLM"})," label"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"We automatically download the TensorRT-LLM Model Engine for your GPU architecture"}),"\n",(0,i.jsx)(n.li,{children:"We have made a few 1.1b models available that can run even on Laptop GPUs with 8gb VRAM"}),"\n"]}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{children:"Model"}),(0,i.jsx)(n.th,{children:"OS"}),(0,i.jsx)(n.th,{children:"Ada (40XX)"}),(0,i.jsx)(n.th,{children:"Ampere (30XX)"}),(0,i.jsx)(n.th,{children:"Description"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Llamacorn 1.1b"}),(0,i.jsx)(n.td,{children:"Windows"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"TinyLlama-1.1b, fine-tuned for usability"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"TinyJensen 1.1b"}),(0,i.jsx)(n.td,{children:"Windows"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"TinyLlama-1.1b, fine-tuned on Jensen Huang speeches"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Mistral Instruct 7b"}),(0,i.jsx)(n.td,{children:"Windows"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"\u2705"}),(0,i.jsx)(n.td,{children:"Mistral"})]})]})]}),"\n",(0,i.jsx)(n.h3,{id:"importing-pre-built-models",children:"Importing Pre-built Models"}),"\n",(0,i.jsxs)(n.p,{children:["You can import a pre-built model, by creating a new folder in Jan's ",(0,i.jsx)(n.code,{children:"/models"})," directory that includes:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["TensorRT-LLM Engine files (e.g. ",(0,i.jsx)(n.code,{children:"tokenizer"}),", ",(0,i.jsx)(n.code,{children:".engine"}),", etc)"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"model.json"})," that registers these files, and specifies ",(0,i.jsx)(n.code,{children:"engine"})," as ",(0,i.jsx)(n.code,{children:"nitro-tensorrt-llm"})]}),"\n"]}),"\n",(0,i.jsxs)(n.admonition,{title:"Sample model.json",type:"note",children:[(0,i.jsxs)(n.p,{children:["Note the ",(0,i.jsx)(n.code,{children:"engine"})," is ",(0,i.jsx)(n.code,{children:"nitro-tensorrt-llm"}),": this won't work without it!"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'{\n "sources": [\n {\n "filename": "config.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/config.json"\n },\n {\n "filename": "mistral_float16_tp1_rank0.engine",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/mistral_float16_tp1_rank0.engine"\n },\n {\n "filename": "tokenizer.model",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/tokenizer.model"\n },\n {\n "filename": "special_tokens_map.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/special_tokens_map.json"\n },\n {\n "filename": "tokenizer.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/tokenizer.json"\n },\n {\n "filename": "tokenizer_config.json",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/tokenizer_config.json"\n },\n {\n "filename": "model.cache",\n "url": "https://delta.jan.ai/dist/models///tensorrt-llm-v0.7.1/TinyJensen-1.1B-Chat-fp16/model.cache"\n }\n ],\n "id": "tinyjensen-1.1b-chat-fp16",\n "object": "model",\n "name": "TinyJensen 1.1B Chat FP16",\n "version": "1.0",\n "description": "Do you want to chat with Jensen Huan? Here you are",\n "format": "TensorRT-LLM",\n "settings": {\n "ctx_len": 2048,\n "text_model": false\n },\n "parameters": {\n "max_tokens": 4096\n },\n "metadata": {\n "author": "LLama",\n "tags": [\n "TensorRT-LLM",\n "1B",\n "Finetuned"\n ],\n "size": 2151000000\n },\n "engine": "nitro-tensorrt-llm"\n}\n'})})]}),"\n",(0,i.jsx)(n.h3,{id:"using-a-tensorrt-llm-model",children:"Using a TensorRT-LLM Model"}),"\n",(0,i.jsx)(n.p,{children:"You can just select and use a TensorRT-LLM model from Jan's Thread interface."}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Jan will automatically start the TensorRT-LLM model engine in the background"}),"\n",(0,i.jsx)(n.li,{children:"You may encounter a pop-up from Windows Security, asking for Nitro to allow public and private network access"}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{title:"Why does Nitro need network access?",type:"info",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["This is because Jan runs TensorRT-LLM using the ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm/",children:"Nitro Server"})]}),"\n",(0,i.jsx)(n.li,{children:"Jan makes network calls to the Nitro server running on your computer on a separate port"}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"configure-settings",children:"Configure Settings"}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"coming soon"})}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,i.jsx)(n.h2,{id:"extension-details",children:"Extension Details"}),"\n",(0,i.jsxs)(n.p,{children:["Jan's TensorRT-LLM Extension is built on top of the open source ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm",children:"Nitro TensorRT-LLM Server"}),", a C++ inference server on top of TensorRT-LLM that provides an OpenAI-compatible API."]}),"\n",(0,i.jsx)(n.h3,{id:"manual-build",children:"Manual Build"}),"\n",(0,i.jsxs)(n.p,{children:["To manually build the artifacts needed to run the server and TensorRT-LLM, you can reference the source code. ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro-tensorrt-llm?tab=readme-ov-file#quickstart",children:"Read here"}),"."]}),"\n",(0,i.jsx)(n.h3,{id:"uninstall-extension",children:"Uninstall Extension"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Quit the app"}),"\n",(0,i.jsx)(n.li,{children:"Go to Settings > Extensions"}),"\n",(0,i.jsx)(n.li,{children:"Delete the entire Extensions folder."}),"\n",(0,i.jsx)(n.li,{children:"Reopen the app, only the default extensions should be restored."}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"build-your-own-tensorrt-models",children:"Build your own TensorRT models"}),"\n",(0,i.jsx)(n.admonition,{type:"info",children:(0,i.jsx)(n.p,{children:"coming soon"})})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>l,x:()=>o});var i=s(96540);const r={},t=i.createContext(r);function l(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:l(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/13238e48.426268fb.js b/assets/js/13238e48.426268fb.js deleted file mode 100644 index 4e6f9b69..00000000 --- a/assets/js/13238e48.426268fb.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2727],{28348:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>a,metadata:()=>c,toc:()=>i});var n=r(74848),o=r(28453);const a={title:"Storage"},s=void 0,c={id:"hardware/concepts/storage",title:"Storage",description:"",source:"@site/docs/hardware/concepts/storage.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/storage",permalink:"/hardware/concepts/storage",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/storage.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Storage"}},d={},i=[];function u(t){return(0,n.jsx)(n.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u()}},28453:(t,e,r)=>{r.d(e,{R:()=>s,x:()=>c});var n=r(96540);const o={},a=n.createContext(o);function s(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/13238e48.ed8f6865.js b/assets/js/13238e48.ed8f6865.js new file mode 100644 index 00000000..4c3c64bf --- /dev/null +++ b/assets/js/13238e48.ed8f6865.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2727],{28348:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>a,metadata:()=>c,toc:()=>i});var n=r(74848),o=r(28453);const a={title:"Storage"},s=void 0,c={id:"hardware/concepts/storage",title:"Storage",description:"",source:"@site/docs/hardware/concepts/storage.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/storage",permalink:"/hardware/concepts/storage",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/storage.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Storage"}},d={},i=[];function u(t){return(0,n.jsx)(n.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u()}},28453:(t,e,r)=>{r.d(e,{R:()=>s,x:()=>c});var n=r(96540);const o={},a=n.createContext(o);function s(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/1496a874.0781cdda.js b/assets/js/1496a874.0781cdda.js new file mode 100644 index 00000000..dcc2bfbe --- /dev/null +++ b/assets/js/1496a874.0781cdda.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1919],{65284:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>r,contentTitle:()=>a,default:()=>h,frontMatter:()=>o,metadata:()=>l,toc:()=>d});var i=t(74848),s=t(28453);const o={title:"QA",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering/qa",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,l={id:"how-we-work/engineering/qa",title:"QA",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/how-we-work/engineering/qa.mdx",sourceDirName:"how-we-work/engineering",slug:"/engineering/qa",permalink:"/engineering/qa",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/engineering/qa.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"QA",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering/qa",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"aboutSidebar",previous:{title:"CI & CD",permalink:"/engineering/ci-cd"},next:{title:"Product & Design",permalink:"/how-we-work/product-design"}},r={},d=[{value:"Phase 1: Planning",id:"phase-1-planning",level:3},{value:"Definition of Ready (DoR):",id:"definition-of-ready-dor",level:4},{value:"Definition of Done (DoD):",id:"definition-of-done-dod",level:4},{value:"Phase 2: Development",id:"phase-2-development",level:3},{value:"Definition of Ready (DoR):",id:"definition-of-ready-dor-1",level:4},{value:"Definition of Done (DoD):",id:"definition-of-done-dod-1",level:4},{value:"Phase 3: QA for feature",id:"phase-3-qa-for-feature",level:3},{value:"Definition of Ready (DoR):",id:"definition-of-ready-dor-2",level:4},{value:"Definition of Done (DoD):",id:"definition-of-done-dod-2",level:4},{value:"Phase 4: Release (DoR)",id:"phase-4-release-dor",level:3},{value:"Notes (WIP)",id:"notes-wip",level:3}];function c(e){const n={h3:"h3",h4:"h4",input:"input",li:"li",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h3,{id:"phase-1-planning",children:"Phase 1: Planning"}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-ready-dor",children:"Definition of Ready (DoR):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Scope Defined:"})," The features to be implemented are clearly defined and scoped out."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Requirements Gathered:"})," Gather and document all the necessary requirements for the feature."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Stakeholder Input:"})," Ensure relevant stakeholders have provided input on the document scope and content."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-done-dod",children:"Definition of Done (DoD):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Document Complete:"})," All sections of the document are filled out with relevant information."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Reviewed by Stakeholders:"})," The document has been reviewed and approved by stakeholders."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Ready for Development:"})," The document is in a state where developers can use it to begin implementation."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"phase-2-development",children:"Phase 2: Development"}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-ready-dor-1",children:"Definition of Ready (DoR):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Task Breakdown:"})," The development team has broken down tasks based on the document."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Communication Plan:"})," A plan is in place for communication between developers and writers if clarification is needed during implementation."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Developer Understanding:"})," Developers have a clear understanding of the document content."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-done-dod-1",children:"Definition of Done (DoD):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Code Implementation:"})," The feature is implemented according to the document specifications."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Developer Testing:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Unit tests and basic integration tests are completed"}),"\n",(0,i.jsx)(n.li,{children:"Developer also completed self-testing for the feature (please add this as a comment in the ticket, with the tested OS and as much info as possible to reduce overlaping effort)."}),"\n",(0,i.jsx)(n.li,{children:"(AC -> Code Changes -> Impacted scenarios)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Communication with Writers:"})," Developers have communicated any changes or challenges to the writers, and necessary adjustments are made in the document. (Can be through a note in the PR of the feature for writers to take care, or create a separate PR with the change you made for the docs, for writers to review)"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"phase-3-qa-for-feature",children:"Phase 3: QA for feature"}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-ready-dor-2",children:"Definition of Ready (DoR):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Note Defined:"})," The test note is prepared outlining the testing items."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Environment Ready:"})," PR merged to nightly build, Nightly build notes updated (automatically from pipeline after merged)."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Status:"})," Ticket moved to the column Testing and assigning to QA/writers to review."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Data Prepared:"})," Relevant test data is prepared for testing the scenarios."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-done-dod-2",children:"Definition of Done (DoD):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Executed:"})," All identified test items are executed on different OS, along with exploratory testing."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Defects Logged:"})," Any defects found during testing are resolved / appropriately logged (and approved for future fix)."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Sign-Off:"})," QA team provides sign-off indicating the completion of testing."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"phase-4-release-dor",children:"Phase 4: Release (DoR)"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Pre-release wait time:"})," Code change to pre-release version should be frozen for at least X (hrs/days) for Regression testing purpose.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Pre-release cut off on Thu morning for the team to regression test."}),"\n",(0,i.jsx)(n.li,{children:"Release to production (Stable) during working hour on Mon morning (if no blocker) or Tue morning."}),"\n",(0,i.jsx)(n.li,{children:"During the release cut off, the nightly build will be paused, to leave room for pre-release build. The build version used for regression test will be notified."}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Pre-release testing:"})," A review of the implemented feature has been conducted, a long with regression test (check-list) by the team.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Release checklist cloned from the templat for different OS (with hackMD link)"}),"\n",(0,i.jsx)(n.li,{children:"New key test items from new feature added to the checklist."}),"\n",(0,i.jsx)(n.li,{children:"Split 3 OS to different team members for testing."}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Document Updated:"})," The document is updated based on the review and feedback on any discrepancies or modification needed for this release."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Reviewed by Stakeholders:"})," New feature and the updated document is reviewed and approved by stakeholders. The document is in its final version, reflecting the implemented feature accurately."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"notes-wip",children:"Notes (WIP)"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"API collection run:"})," to run along with nightly build daily, for critical API validation"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Automation run:"})," for regression testing purpose, to reduce manual testing effort for the same items each release on multiple OS."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>l});var i=t(96540);const s={},o=i.createContext(s);function a(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/1496a874.957a0822.js b/assets/js/1496a874.957a0822.js deleted file mode 100644 index c565e12f..00000000 --- a/assets/js/1496a874.957a0822.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1919],{65284:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>r,contentTitle:()=>a,default:()=>h,frontMatter:()=>o,metadata:()=>l,toc:()=>d});var i=t(74848),s=t(28453);const o={title:"QA",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering/qa",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,l={id:"how-we-work/engineering/qa",title:"QA",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/how-we-work/engineering/qa.mdx",sourceDirName:"how-we-work/engineering",slug:"/engineering/qa",permalink:"/engineering/qa",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/engineering/qa.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"QA",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/engineering/qa",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"aboutSidebar",previous:{title:"CI & CD",permalink:"/engineering/ci-cd"},next:{title:"Product & Design",permalink:"/how-we-work/product-design"}},r={},d=[{value:"Phase 1: Planning",id:"phase-1-planning",level:3},{value:"Definition of Ready (DoR):",id:"definition-of-ready-dor",level:4},{value:"Definition of Done (DoD):",id:"definition-of-done-dod",level:4},{value:"Phase 2: Development",id:"phase-2-development",level:3},{value:"Definition of Ready (DoR):",id:"definition-of-ready-dor-1",level:4},{value:"Definition of Done (DoD):",id:"definition-of-done-dod-1",level:4},{value:"Phase 3: QA for feature",id:"phase-3-qa-for-feature",level:3},{value:"Definition of Ready (DoR):",id:"definition-of-ready-dor-2",level:4},{value:"Definition of Done (DoD):",id:"definition-of-done-dod-2",level:4},{value:"Phase 4: Release (DoR)",id:"phase-4-release-dor",level:3},{value:"Notes (WIP)",id:"notes-wip",level:3}];function c(e){const n={h3:"h3",h4:"h4",input:"input",li:"li",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h3,{id:"phase-1-planning",children:"Phase 1: Planning"}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-ready-dor",children:"Definition of Ready (DoR):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Scope Defined:"})," The features to be implemented are clearly defined and scoped out."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Requirements Gathered:"})," Gather and document all the necessary requirements for the feature."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Stakeholder Input:"})," Ensure relevant stakeholders have provided input on the document scope and content."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-done-dod",children:"Definition of Done (DoD):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Document Complete:"})," All sections of the document are filled out with relevant information."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Reviewed by Stakeholders:"})," The document has been reviewed and approved by stakeholders."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Ready for Development:"})," The document is in a state where developers can use it to begin implementation."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"phase-2-development",children:"Phase 2: Development"}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-ready-dor-1",children:"Definition of Ready (DoR):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Task Breakdown:"})," The development team has broken down tasks based on the document."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Communication Plan:"})," A plan is in place for communication between developers and writers if clarification is needed during implementation."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Developer Understanding:"})," Developers have a clear understanding of the document content."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-done-dod-1",children:"Definition of Done (DoD):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Code Implementation:"})," The feature is implemented according to the document specifications."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Developer Testing:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Unit tests and basic integration tests are completed"}),"\n",(0,i.jsx)(n.li,{children:"Developer also completed self-testing for the feature (please add this as a comment in the ticket, with the tested OS and as much info as possible to reduce overlaping effort)."}),"\n",(0,i.jsx)(n.li,{children:"(AC -> Code Changes -> Impacted scenarios)"}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Communication with Writers:"})," Developers have communicated any changes or challenges to the writers, and necessary adjustments are made in the document. (Can be through a note in the PR of the feature for writers to take care, or create a separate PR with the change you made for the docs, for writers to review)"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"phase-3-qa-for-feature",children:"Phase 3: QA for feature"}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-ready-dor-2",children:"Definition of Ready (DoR):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Note Defined:"})," The test note is prepared outlining the testing items."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Environment Ready:"})," PR merged to nightly build, Nightly build notes updated (automatically from pipeline after merged)."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Status:"})," Ticket moved to the column Testing and assigning to QA/writers to review."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Data Prepared:"})," Relevant test data is prepared for testing the scenarios."]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"definition-of-done-dod-2",children:"Definition of Done (DoD):"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Executed:"})," All identified test items are executed on different OS, along with exploratory testing."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Defects Logged:"})," Any defects found during testing are resolved / appropriately logged (and approved for future fix)."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Test Sign-Off:"})," QA team provides sign-off indicating the completion of testing."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"phase-4-release-dor",children:"Phase 4: Release (DoR)"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Pre-release wait time:"})," Code change to pre-release version should be frozen for at least X (hrs/days) for Regression testing purpose.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Pre-release cut off on Thu morning for the team to regression test."}),"\n",(0,i.jsx)(n.li,{children:"Release to production (Stable) during working hour on Mon morning (if no blocker) or Tue morning."}),"\n",(0,i.jsx)(n.li,{children:"During the release cut off, the nightly build will be paused, to leave room for pre-release build. The build version used for regression test will be notified."}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Pre-release testing:"})," A review of the implemented feature has been conducted, a long with regression test (check-list) by the team.","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Release checklist cloned from the templat for different OS (with hackMD link)"}),"\n",(0,i.jsx)(n.li,{children:"New key test items from new feature added to the checklist."}),"\n",(0,i.jsx)(n.li,{children:"Split 3 OS to different team members for testing."}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Document Updated:"})," The document is updated based on the review and feedback on any discrepancies or modification needed for this release."]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Reviewed by Stakeholders:"})," New feature and the updated document is reviewed and approved by stakeholders. The document is in its final version, reflecting the implemented feature accurately."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"notes-wip",children:"Notes (WIP)"}),"\n",(0,i.jsxs)(n.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"API collection run:"})," to run along with nightly build daily, for critical API validation"]}),"\n",(0,i.jsxs)(n.li,{className:"task-list-item",children:[(0,i.jsx)(n.input,{type:"checkbox",disabled:!0})," ",(0,i.jsx)(n.strong,{children:"Automation run:"})," for regression testing purpose, to reduce manual testing effort for the same items each release on multiple OS."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>l});var i=t(96540);const s={},o=i.createContext(s);function a(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/15d51a08.125bb6d8.js b/assets/js/15d51a08.125bb6d8.js deleted file mode 100644 index 3069b3b6..00000000 --- a/assets/js/15d51a08.125bb6d8.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6034],{15373:(n,e,s)=>{s.r(e),s.d(e,{assets:()=>l,contentTitle:()=>a,default:()=>x,frontMatter:()=>o,metadata:()=>r,toc:()=>d});var t=s(74848),i=s(28453);const o={title:"What are Jan Extensions?",slug:"/extensions",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Jan Extensions","Extensions"]},a=void 0,r={id:"guides/extensions/extensions",title:"What are Jan Extensions?",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/extensions/extensions.mdx",sourceDirName:"guides/extensions",slug:"/extensions",permalink:"/extensions",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/extensions/extensions.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"What are Jan Extensions?",slug:"/extensions",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Jan Extensions","Extensions"]},sidebar:"guidesSidebar",previous:{title:"Any OAI Compatible Server",permalink:"/guides/engines/remote-server"},next:{title:"Integrations",permalink:"/integrations/"}},l={},d=[{value:"Default Extensions",id:"default-extensions",level:2},{value:"List of Default Extensions",id:"list-of-default-extensions",level:2},{value:"Configure Extension Settings",id:"configure-extension-settings",level:2},{value:"Import Custom Extension",id:"import-custom-extension",level:2}];function c(n){const e={a:"a",admonition:"admonition",code:"code",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...n.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(e.p,{children:"The current Jan Desktop Client has some default extensions built on top of this framework to enhance the user experience. In this guide, we will show you the list of default extensions and how to configure extension settings."}),"\n",(0,t.jsx)(e.h2,{id:"default-extensions",children:"Default Extensions"}),"\n",(0,t.jsxs)(e.p,{children:["You can find the default extensions in the ",(0,t.jsx)(e.code,{children:"Settings"})," > ",(0,t.jsx)(e.code,{children:"Extensions"}),"."]}),"\n",(0,t.jsx)(e.h2,{id:"list-of-default-extensions",children:"List of Default Extensions"}),"\n",(0,t.jsxs)(e.table,{children:[(0,t.jsx)(e.thead,{children:(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.th,{children:"Extension Name"}),(0,t.jsx)(e.th,{children:"Version"}),(0,t.jsx)(e.th,{children:"Description"}),(0,t.jsx)(e.th,{children:"Source Code Link"})]})}),(0,t.jsxs)(e.tbody,{children:[(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Assistant Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables assistants, including Jan, a default assistant that can call all downloaded models."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/assistant-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Conversational Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables conversations and state persistence via your filesystem."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/conversational-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Inference Nitro Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension embeds Nitro, a lightweight (3 MB) inference engine in C++. See nitro.jan.ai."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/inference-nitro-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Inference Openai Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables OpenAI chat completion API calls."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/inference-openai-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Inference Triton Trt Llm Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables Nvidia's TensorRT-LLM as an inference engine option."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/inference-triton-trtllm-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Model Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.22"})}),(0,t.jsx)(e.td,{children:"Model Management Extension provides model exploration and seamless downloads."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/model-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Monitoring Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.9"})}),(0,t.jsx)(e.td,{children:"This extension offers system health and OS-level data."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/monitoring-extension",children:"Link to Source"})})]})]})]}),"\n",(0,t.jsx)(e.h2,{id:"configure-extension-settings",children:"Configure Extension Settings"}),"\n",(0,t.jsx)(e.p,{children:"To configure extension settings:"}),"\n",(0,t.jsxs)(e.ol,{children:["\n",(0,t.jsxs)(e.li,{children:["Navigate to the ",(0,t.jsx)(e.code,{children:"~/jan/extensions"}),"."]}),"\n",(0,t.jsxs)(e.li,{children:["Open the ",(0,t.jsx)(e.code,{children:"extensions.json"})," file"]}),"\n",(0,t.jsx)(e.li,{children:"Edit the file with options including:"}),"\n"]}),"\n",(0,t.jsxs)(e.table,{children:[(0,t.jsx)(e.thead,{children:(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.th,{children:"Option"}),(0,t.jsx)(e.th,{children:"Description"})]})}),(0,t.jsxs)(e.tbody,{children:[(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"_active"})}),(0,t.jsx)(e.td,{children:"Enable/disable the extension."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"listeners"})}),(0,t.jsx)(e.td,{children:"Default listener setting."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"origin"})}),(0,t.jsx)(e.td,{children:"Extension file path."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"installOptions"})}),(0,t.jsx)(e.td,{children:"Version and metadata configuration."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"name"})}),(0,t.jsx)(e.td,{children:"Extension name."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"version"})}),(0,t.jsx)(e.td,{children:"Extension version."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"main"})}),(0,t.jsx)(e.td,{children:"Main file path."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"description"})}),(0,t.jsx)(e.td,{children:"Extension description."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"url"})}),(0,t.jsx)(e.td,{children:"Extension URL."})]})]})]}),"\n",(0,t.jsx)(e.pre,{children:(0,t.jsx)(e.code,{className:"language-json",metastring:'title="~/jan/extensions/extensions.json"',children:'{\n "@janhq/assistant-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-assistant-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/assistant-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables assistants, including Jan, a default assistant that can call all downloaded models",\n "url": "extension://@janhq/assistant-extension/dist/index.js"\n },\n "@janhq/conversational-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-conversational-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/conversational-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables conversations and state persistence via your filesystem",\n "url": "extension://@janhq/conversational-extension/dist/index.js"\n },\n "@janhq/inference-nitro-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-inference-nitro-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/inference-nitro-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension embeds Nitro, a lightweight (3mb) inference engine written in C++. See nitro.jan.ai",\n "url": "extension://@janhq/inference-nitro-extension/dist/index.js"\n },\n "@janhq/inference-openai-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-inference-openai-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/inference-openai-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables OpenAI chat completion API calls",\n "url": "extension://@janhq/inference-openai-extension/dist/index.js"\n },\n "@janhq/inference-triton-trt-llm-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-inference-triton-trt-llm-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/inference-triton-trt-llm-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables Nvidia\'s TensorRT-LLM as an inference engine option",\n "url": "extension://@janhq/inference-triton-trt-llm-extension/dist/index.js"\n },\n "@janhq/model-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-model-extension-1.0.22.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/model-extension",\n "version": "1.0.22",\n "main": "dist/index.js",\n "description": "Model Management Extension provides model exploration and seamless downloads",\n "url": "extension://@janhq/model-extension/dist/index.js"\n },\n "@janhq/monitoring-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-monitoring-extension-1.0.9.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/monitoring-extension",\n "version": "1.0.9",\n "main": "dist/index.js",\n "description": "This extension provides system health and OS level data",\n "url": "extension://@janhq/monitoring-extension/dist/index.js"\n }\n}\n'})}),"\n",(0,t.jsx)(e.h2,{id:"import-custom-extension",children:"Import Custom Extension"}),"\n",(0,t.jsx)(e.admonition,{type:"note",children:(0,t.jsx)(e.p,{children:"Currently, Jan only supports official extensions, which can be directly downloaded in Extension Settings. We plan to support 3rd party Extensions in the future."})}),"\n",(0,t.jsx)(e.p,{children:"For now you can always import a third party extension at your own risk by following the steps below:"}),"\n",(0,t.jsxs)(e.ol,{children:["\n",(0,t.jsxs)(e.li,{children:["Navigate to ",(0,t.jsx)(e.strong,{children:"Settings"})," > ",(0,t.jsx)(e.strong,{children:"Extensions"})," > Click Select under ",(0,t.jsx)(e.strong,{children:"Manual Installation"}),"."]}),"\n",(0,t.jsx)(e.li,{children:"Then, the ~/jan/extensions/extensions.json file will be updated automatically."}),"\n"]}),"\n",(0,t.jsx)(e.admonition,{type:"caution",children:(0,t.jsxs)(e.p,{children:["You need to prepare the extension file in .tgz format to install the ",(0,t.jsx)(e.strong,{children:"non-default"})," extension."]})}),"\n",(0,t.jsx)(e.admonition,{title:"Assistance and Support",type:"info",children:(0,t.jsxs)(e.p,{children:["If you have questions, please join our ",(0,t.jsx)(e.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," for support, updates, and discussions."]})})]})}function x(n={}){const{wrapper:e}={...(0,i.R)(),...n.components};return e?(0,t.jsx)(e,{...n,children:(0,t.jsx)(c,{...n})}):c(n)}},28453:(n,e,s)=>{s.d(e,{R:()=>a,x:()=>r});var t=s(96540);const i={},o=t.createContext(i);function a(n){const e=t.useContext(o);return t.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function r(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(i):n.components||i:a(n.components),t.createElement(o.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/15d51a08.9f1a16e5.js b/assets/js/15d51a08.9f1a16e5.js new file mode 100644 index 00000000..69335769 --- /dev/null +++ b/assets/js/15d51a08.9f1a16e5.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6034],{15373:(n,e,s)=>{s.r(e),s.d(e,{assets:()=>l,contentTitle:()=>r,default:()=>x,frontMatter:()=>o,metadata:()=>a,toc:()=>d});var t=s(74848),i=s(28453);const o={title:"What are Jan Extensions?",slug:"/extensions",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Jan Extensions","Extensions"]},r=void 0,a={id:"guides/extensions/extensions",title:"What are Jan Extensions?",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/extensions/extensions.mdx",sourceDirName:"guides/extensions",slug:"/extensions",permalink:"/extensions",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/extensions/extensions.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"What are Jan Extensions?",slug:"/extensions",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Jan Extensions","Extensions"]},sidebar:"guidesSidebar",previous:{title:"Any OAI Compatible Server",permalink:"/guides/engines/remote-server"},next:{title:"Integrations",permalink:"/integrations/"}},l={},d=[{value:"Default Extensions",id:"default-extensions",level:2},{value:"List of Default Extensions",id:"list-of-default-extensions",level:2},{value:"Configure Extension Settings",id:"configure-extension-settings",level:2},{value:"Import Custom Extension",id:"import-custom-extension",level:2}];function c(n){const e={a:"a",admonition:"admonition",code:"code",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...n.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(e.p,{children:"The current Jan Desktop Client has some default extensions built on top of this framework to enhance the user experience. In this guide, we will show you the list of default extensions and how to configure extension settings."}),"\n",(0,t.jsx)(e.h2,{id:"default-extensions",children:"Default Extensions"}),"\n",(0,t.jsxs)(e.p,{children:["You can find the default extensions in the ",(0,t.jsx)(e.code,{children:"Settings"})," > ",(0,t.jsx)(e.code,{children:"Extensions"}),"."]}),"\n",(0,t.jsx)(e.h2,{id:"list-of-default-extensions",children:"List of Default Extensions"}),"\n",(0,t.jsxs)(e.table,{children:[(0,t.jsx)(e.thead,{children:(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.th,{children:"Extension Name"}),(0,t.jsx)(e.th,{children:"Version"}),(0,t.jsx)(e.th,{children:"Description"}),(0,t.jsx)(e.th,{children:"Source Code Link"})]})}),(0,t.jsxs)(e.tbody,{children:[(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Assistant Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables assistants, including Jan, a default assistant that can call all downloaded models."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/assistant-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Conversational Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables conversations and state persistence via your filesystem."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/conversational-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Inference Nitro Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension embeds Nitro, a lightweight (3 MB) inference engine in C++. See nitro.jan.ai."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/inference-nitro-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Inference Openai Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables OpenAI chat completion API calls."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/inference-openai-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Inference Triton Trt Llm Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.0"})}),(0,t.jsx)(e.td,{children:"This extension enables Nvidia's TensorRT-LLM as an inference engine option."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/inference-triton-trtllm-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Model Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.22"})}),(0,t.jsx)(e.td,{children:"Model Management Extension provides model exploration and seamless downloads."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/model-extension",children:"Link to Source"})})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:"Monitoring Extension"}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"v1.0.9"})}),(0,t.jsx)(e.td,{children:"This extension offers system health and OS-level data."}),(0,t.jsx)(e.td,{children:(0,t.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/dev/extensions/monitoring-extension",children:"Link to Source"})})]})]})]}),"\n",(0,t.jsx)(e.h2,{id:"configure-extension-settings",children:"Configure Extension Settings"}),"\n",(0,t.jsx)(e.p,{children:"To configure extension settings:"}),"\n",(0,t.jsxs)(e.ol,{children:["\n",(0,t.jsxs)(e.li,{children:["Navigate to the ",(0,t.jsx)(e.code,{children:"~/jan/extensions"}),"."]}),"\n",(0,t.jsxs)(e.li,{children:["Open the ",(0,t.jsx)(e.code,{children:"extensions.json"})," file"]}),"\n",(0,t.jsx)(e.li,{children:"Edit the file with options including:"}),"\n"]}),"\n",(0,t.jsxs)(e.table,{children:[(0,t.jsx)(e.thead,{children:(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.th,{children:"Option"}),(0,t.jsx)(e.th,{children:"Description"})]})}),(0,t.jsxs)(e.tbody,{children:[(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"_active"})}),(0,t.jsx)(e.td,{children:"Enable/disable the extension."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"listeners"})}),(0,t.jsx)(e.td,{children:"Default listener setting."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"origin"})}),(0,t.jsx)(e.td,{children:"Extension file path."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"installOptions"})}),(0,t.jsx)(e.td,{children:"Version and metadata configuration."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"name"})}),(0,t.jsx)(e.td,{children:"Extension name."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"version"})}),(0,t.jsx)(e.td,{children:"Extension version."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"main"})}),(0,t.jsx)(e.td,{children:"Main file path."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"description"})}),(0,t.jsx)(e.td,{children:"Extension description."})]}),(0,t.jsxs)(e.tr,{children:[(0,t.jsx)(e.td,{children:(0,t.jsx)(e.code,{children:"url"})}),(0,t.jsx)(e.td,{children:"Extension URL."})]})]})]}),"\n",(0,t.jsx)(e.pre,{children:(0,t.jsx)(e.code,{className:"language-json",metastring:'title="~/jan/extensions/extensions.json"',children:'{\n "@janhq/assistant-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-assistant-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/assistant-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables assistants, including Jan, a default assistant that can call all downloaded models",\n "url": "extension://@janhq/assistant-extension/dist/index.js"\n },\n "@janhq/conversational-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-conversational-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/conversational-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables conversations and state persistence via your filesystem",\n "url": "extension://@janhq/conversational-extension/dist/index.js"\n },\n "@janhq/inference-nitro-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-inference-nitro-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/inference-nitro-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension embeds Nitro, a lightweight (3mb) inference engine written in C++. See nitro.jan.ai",\n "url": "extension://@janhq/inference-nitro-extension/dist/index.js"\n },\n "@janhq/inference-openai-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-inference-openai-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/inference-openai-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables OpenAI chat completion API calls",\n "url": "extension://@janhq/inference-openai-extension/dist/index.js"\n },\n "@janhq/inference-triton-trt-llm-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-inference-triton-trt-llm-extension-1.0.0.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/inference-triton-trt-llm-extension",\n "version": "1.0.0",\n "main": "dist/index.js",\n "description": "This extension enables Nvidia\'s TensorRT-LLM as an inference engine option",\n "url": "extension://@janhq/inference-triton-trt-llm-extension/dist/index.js"\n },\n "@janhq/model-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-model-extension-1.0.22.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/model-extension",\n "version": "1.0.22",\n "main": "dist/index.js",\n "description": "Model Management Extension provides model exploration and seamless downloads",\n "url": "extension://@janhq/model-extension/dist/index.js"\n },\n "@janhq/monitoring-extension": {\n "_active": true,\n "listeners": {},\n "origin": "/Applications/Jan.app/Contents/Resources/app.asar.unpacked/pre-install/janhq-monitoring-extension-1.0.9.tgz",\n "installOptions": { "version": false, "fullMetadata": false },\n "name": "@janhq/monitoring-extension",\n "version": "1.0.9",\n "main": "dist/index.js",\n "description": "This extension provides system health and OS level data",\n "url": "extension://@janhq/monitoring-extension/dist/index.js"\n }\n}\n'})}),"\n",(0,t.jsx)(e.h2,{id:"import-custom-extension",children:"Import Custom Extension"}),"\n",(0,t.jsx)(e.admonition,{type:"note",children:(0,t.jsx)(e.p,{children:"Currently, Jan only supports official extensions, which can be directly downloaded in Extension Settings. We plan to support 3rd party Extensions in the future."})}),"\n",(0,t.jsx)(e.p,{children:"For now you can always import a third party extension at your own risk by following the steps below:"}),"\n",(0,t.jsxs)(e.ol,{children:["\n",(0,t.jsxs)(e.li,{children:["Navigate to ",(0,t.jsx)(e.strong,{children:"Settings"})," > ",(0,t.jsx)(e.strong,{children:"Extensions"})," > Click Select under ",(0,t.jsx)(e.strong,{children:"Manual Installation"}),"."]}),"\n",(0,t.jsx)(e.li,{children:"Then, the ~/jan/extensions/extensions.json file will be updated automatically."}),"\n"]}),"\n",(0,t.jsx)(e.admonition,{type:"caution",children:(0,t.jsxs)(e.p,{children:["You need to prepare the extension file in .tgz format to install the ",(0,t.jsx)(e.strong,{children:"non-default"})," extension."]})}),"\n",(0,t.jsx)(e.admonition,{title:"Assistance and Support",type:"info",children:(0,t.jsxs)(e.p,{children:["If you have questions, please join our ",(0,t.jsx)(e.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," for support, updates, and discussions."]})})]})}function x(n={}){const{wrapper:e}={...(0,i.R)(),...n.components};return e?(0,t.jsx)(e,{...n,children:(0,t.jsx)(c,{...n})}):c(n)}},28453:(n,e,s)=>{s.d(e,{R:()=>r,x:()=>a});var t=s(96540);const i={},o=t.createContext(i);function r(n){const e=t.useContext(o);return t.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function a(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(i):n.components||i:r(n.components),t.createElement(o.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/16993ecd.2a40c761.js b/assets/js/16993ecd.2a40c761.js new file mode 100644 index 00000000..ea5b6a44 --- /dev/null +++ b/assets/js/16993ecd.2a40c761.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4597],{46193:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>h,frontMatter:()=>i,metadata:()=>C,toc:()=>F});var s=e(74848),g=e(28453),t=e(64023);const i={title:"Local Engines",slug:"/guides/engines/local",sidebar_position:13,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},d=void 0,C={id:"guides/local-providers/README",title:"Local Engines",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/local-providers/README.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/local",permalink:"/guides/engines/local",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:13,frontMatter:{title:"Local Engines",slug:"/guides/engines/local",sidebar_position:13,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},sidebar:"guidesSidebar",previous:{title:"Advanced Settings",permalink:"/guides/advanced"},next:{title:"Llama.cpp Extension",permalink:"/guides/engines/llamacpp"}},l={},F=[];function r(A){return(0,s.jsx)(t.A,{})}function h(A={}){const{wrapper:a}={...(0,g.R)(),...A.components};return a?(0,s.jsx)(a,{...A,children:(0,s.jsx)(r,{...A})}):r()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var s=e(18215),g=e(84142),t=e(20053),i=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},F="",r="",h="",n="",u="",o="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",b="",N="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,t.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:s,description:g}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,t.A)("text--truncate",l.cardTitle),title:s,children:[e," ",s]}),g&&(0,L.jsx)("p",{className:(0,t.A)(l.cardDescription),title:g,children:g})]})}function q(A){let{item:a}=A;const e=(0,g.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",s=(0,g.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??s?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,g.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const t=(0,g.d1)(a);return(0,L.jsx)("section",{className:(0,s.A)("row",e),children:t.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var s=e(96540);const g={},t=s.createContext(g);function i(A){const a=s.useContext(t);return s.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(g):A.components||g:i(A.components),s.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/16993ecd.d0a0035e.js b/assets/js/16993ecd.d0a0035e.js deleted file mode 100644 index 9f52f7f6..00000000 --- a/assets/js/16993ecd.d0a0035e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4597],{46193:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>h,frontMatter:()=>i,metadata:()=>C,toc:()=>F});var s=e(74848),g=e(28453),t=e(64023);const i={title:"Local Engines",slug:"/guides/engines/local",sidebar_position:13,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},d=void 0,C={id:"guides/local-providers/README",title:"Local Engines",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/local-providers/README.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/local",permalink:"/guides/engines/local",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:13,frontMatter:{title:"Local Engines",slug:"/guides/engines/local",sidebar_position:13,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},sidebar:"guidesSidebar",previous:{title:"Advanced Settings",permalink:"/guides/advanced"},next:{title:"Llama.cpp Extension",permalink:"/guides/engines/llamacpp"}},l={},F=[];function r(A){return(0,s.jsx)(t.A,{})}function h(A={}){const{wrapper:a}={...(0,g.R)(),...A.components};return a?(0,s.jsx)(a,{...A,children:(0,s.jsx)(r,{...A})}):r()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var s=e(18215),g=e(84142),t=e(20053),i=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},F="",r="",h="",n="",u="",o="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",b="",N="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,t.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:s,description:g}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,t.A)("text--truncate",l.cardTitle),title:s,children:[e," ",s]}),g&&(0,L.jsx)("p",{className:(0,t.A)(l.cardDescription),title:g,children:g})]})}function q(A){let{item:a}=A;const e=(0,g.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",s=(0,g.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??s?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,g.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const t=(0,g.d1)(a);return(0,L.jsx)("section",{className:(0,s.A)("row",e),children:t.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var s=e(96540);const g={},t=s.createContext(g);function i(A){const a=s.useContext(t);return s.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(g):A.components||g:i(A.components),s.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/1736cbe2.86be4396.js b/assets/js/1736cbe2.86be4396.js deleted file mode 100644 index 5c1cdbef..00000000 --- a/assets/js/1736cbe2.86be4396.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4606],{45017:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>c,contentTitle:()=>r,default:()=>p,frontMatter:()=>o,metadata:()=>s,toc:()=>d});var i=e(74848),a=e(28453);const o={title:"Langchain"},r=void 0,s={id:"integrations/langchain",title:"Langchain",description:"WIP",source:"@site/docs/integrations/langchain.md",sourceDirName:"integrations",slug:"/integrations/langchain",permalink:"/integrations/langchain",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/langchain.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Langchain"},sidebar:"ecosystemSidebar",previous:{title:"Integrations",permalink:"/integrations"},next:{title:"llama.cpp",permalink:"/integrations/llamacpp"}},c={},d=[];function l(t){const n={admonition:"admonition",p:"p",...(0,a.R)(),...t.components};return(0,i.jsx)(n.admonition,{type:"caution",children:(0,i.jsx)(n.p,{children:"WIP"})})}function p(t={}){const{wrapper:n}={...(0,a.R)(),...t.components};return n?(0,i.jsx)(n,{...t,children:(0,i.jsx)(l,{...t})}):l(t)}},28453:(t,n,e)=>{e.d(n,{R:()=>r,x:()=>s});var i=e(96540);const a={},o=i.createContext(a);function r(t){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function s(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(a):t.components||a:r(t.components),i.createElement(o.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/1736cbe2.920b0095.js b/assets/js/1736cbe2.920b0095.js new file mode 100644 index 00000000..a3eddddf --- /dev/null +++ b/assets/js/1736cbe2.920b0095.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4606],{45017:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>c,contentTitle:()=>r,default:()=>p,frontMatter:()=>o,metadata:()=>s,toc:()=>d});var i=e(74848),a=e(28453);const o={title:"Langchain"},r=void 0,s={id:"integrations/langchain",title:"Langchain",description:"WIP",source:"@site/docs/integrations/langchain.md",sourceDirName:"integrations",slug:"/integrations/langchain",permalink:"/integrations/langchain",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/langchain.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Langchain"},sidebar:"ecosystemSidebar",previous:{title:"Integrations",permalink:"/integrations"},next:{title:"llama.cpp",permalink:"/integrations/llamacpp"}},c={},d=[];function l(t){const n={admonition:"admonition",p:"p",...(0,a.R)(),...t.components};return(0,i.jsx)(n.admonition,{type:"caution",children:(0,i.jsx)(n.p,{children:"WIP"})})}function p(t={}){const{wrapper:n}={...(0,a.R)(),...t.components};return n?(0,i.jsx)(n,{...t,children:(0,i.jsx)(l,{...t})}):l(t)}},28453:(t,n,e)=>{e.d(n,{R:()=>r,x:()=>s});var i=e(96540);const a={},o=i.createContext(a);function r(t){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function s(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(a):t.components||a:r(t.components),i.createElement(o.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/188f62ae.08008b2c.js b/assets/js/188f62ae.08008b2c.js new file mode 100644 index 00000000..1dbd1307 --- /dev/null +++ b/assets/js/188f62ae.08008b2c.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2616],{23124:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>r,contentTitle:()=>d,default:()=>F,frontMatter:()=>i,metadata:()=>C,toc:()=>l});var g=e(74848),s=e(28453),t=e(64023);const i={title:"Engineering Specs",slug:"/developer/engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","engineering"]},d=void 0,C={id:"developer/framework/engineering/README",title:"Engineering Specs",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/README.mdx",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/engineering",permalink:"/developer/engineering",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Engineering Specs",slug:"/developer/engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","engineering"]},sidebar:"developerSidebar",previous:{title:"Framework",permalink:"/developer/framework/"},next:{title:"Assistants",permalink:"/developer/framework/engineering/assistants"}},r={},l=[];function n(A){const a={p:"p",...(0,s.R)(),...A.components};return(0,g.jsxs)(g.Fragment,{children:[(0,g.jsx)(t.A,{className:"DocCardList--no-description"}),"\n",(0,g.jsx)(a.p,{children:"Talk about CoreSDK here"})]})}function F(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,g.jsx)(a,{...A,children:(0,g.jsx)(n,{...A})}):n(A)}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var g=e(18215),s=e(84142),t=e(20053),i=e(28774),d=e(21312),C=e(51107);const r={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},l="",n="",F="",h="",o="",u="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",N="",b="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,t.A)("card padding--lg",r.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:g,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,t.A)("text--truncate",r.cardTitle),title:g,children:[e," ",g]}),s&&(0,L.jsx)("p",{className:(0,t.A)(r.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:l,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",g=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??g?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const t=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,g.A)("row",e),children:t.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var g=e(96540);const s={},t=g.createContext(s);function i(A){const a=g.useContext(t);return g.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:i(A.components),g.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/188f62ae.5bc6ece2.js b/assets/js/188f62ae.5bc6ece2.js deleted file mode 100644 index 55f9b81c..00000000 --- a/assets/js/188f62ae.5bc6ece2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2616],{23124:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>r,contentTitle:()=>d,default:()=>F,frontMatter:()=>i,metadata:()=>C,toc:()=>l});var g=e(74848),s=e(28453),t=e(64023);const i={title:"Engineering Specs",slug:"/developer/engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","engineering"]},d=void 0,C={id:"developer/framework/engineering/README",title:"Engineering Specs",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/README.mdx",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/engineering",permalink:"/developer/engineering",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Engineering Specs",slug:"/developer/engineering",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","engineering"]},sidebar:"developerSidebar",previous:{title:"Framework",permalink:"/developer/framework/"},next:{title:"Assistants",permalink:"/developer/framework/engineering/assistants"}},r={},l=[];function n(A){const a={p:"p",...(0,s.R)(),...A.components};return(0,g.jsxs)(g.Fragment,{children:[(0,g.jsx)(t.A,{className:"DocCardList--no-description"}),"\n",(0,g.jsx)(a.p,{children:"Talk about CoreSDK here"})]})}function F(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,g.jsx)(a,{...A,children:(0,g.jsx)(n,{...A})}):n(A)}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var g=e(18215),s=e(84142),t=e(20053),i=e(28774),d=e(21312),C=e(51107);const r={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},l="",n="",F="",h="",o="",u="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",N="",b="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,t.A)("card padding--lg",r.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:g,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,t.A)("text--truncate",r.cardTitle),title:g,children:[e," ",g]}),s&&(0,L.jsx)("p",{className:(0,t.A)(r.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:l,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",g=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??g?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const t=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,g.A)("row",e),children:t.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var g=e(96540);const s={},t=g.createContext(s);function i(A){const a=g.useContext(t);return g.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:i(A.components),g.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/1ca75787.7f1a5870.js b/assets/js/1ca75787.7f1a5870.js deleted file mode 100644 index f0b8c9ed..00000000 --- a/assets/js/1ca75787.7f1a5870.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9876],{44074:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>i,default:()=>l,frontMatter:()=>r,metadata:()=>c,toc:()=>d});var o=n(74848),s=n(28453);const r={title:"Admin Console"},i=void 0,c={id:"server-suite/admin-console",title:"Admin Console",description:"",source:"@site/docs/server-suite/admin-console.md",sourceDirName:"server-suite",slug:"/server-suite/admin-console",permalink:"/server-suite/admin-console",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/admin-console.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Admin Console"}},a={},d=[];function u(e){return(0,o.jsx)(o.Fragment,{})}function l(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(u,{...e})}):u()}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>c});var o=n(96540);const s={},r=o.createContext(s);function i(e){const t=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),o.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/1ca75787.af1e63c9.js b/assets/js/1ca75787.af1e63c9.js new file mode 100644 index 00000000..61164c78 --- /dev/null +++ b/assets/js/1ca75787.af1e63c9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9876],{44074:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>i,default:()=>l,frontMatter:()=>r,metadata:()=>c,toc:()=>d});var o=n(74848),s=n(28453);const r={title:"Admin Console"},i=void 0,c={id:"server-suite/admin-console",title:"Admin Console",description:"",source:"@site/docs/server-suite/admin-console.md",sourceDirName:"server-suite",slug:"/server-suite/admin-console",permalink:"/server-suite/admin-console",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/admin-console.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Admin Console"}},a={},d=[];function u(e){return(0,o.jsx)(o.Fragment,{})}function l(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(u,{...e})}):u()}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>c});var o=n(96540);const s={},r=o.createContext(s);function i(e){const t=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),o.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/22f0f67d.4de223f9.js b/assets/js/22f0f67d.4de223f9.js new file mode 100644 index 00000000..09107d14 --- /dev/null +++ b/assets/js/22f0f67d.4de223f9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5032],{70116:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>n,frontMatter:()=>g,metadata:()=>C,toc:()=>r});var t=e(74848),s=e(28453),i=e(64023);const g={title:"Integrations",slug:"/integrations/",sidebar_position:1,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},d=void 0,C={id:"guides/integrations/README",title:"Integrations",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/integrations/README.mdx",sourceDirName:"guides/integrations",slug:"/integrations/",permalink:"/integrations/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Integrations",slug:"/integrations/",sidebar_position:1,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},sidebar:"guidesSidebar",previous:{title:"What are Jan Extensions?",permalink:"/extensions"},next:{title:"Discord",permalink:"/integrations/discord"}},l={},r=[];function F(A){return(0,t.jsx)(i.A,{})}function n(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,t.jsx)(a,{...A,children:(0,t.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var t=e(18215),s=e(84142),i=e(20053),g=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},r="",F="",n="",h="",o="",u="",E="",c="",B="",p="",Y="",w="",V="",R="",I="",U="",v="",W="",K="",b="",N="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(g.A,{href:a,className:(0,i.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:t,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,i.A)("text--truncate",l.cardTitle),title:t,children:[e," ",t]}),s&&(0,L.jsx)("p",{className:(0,i.A)(l.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",t=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??t?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const i=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,t.A)("row",e),children:i.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>g,x:()=>d});var t=e(96540);const s={},i=t.createContext(s);function g(A){const a=t.useContext(i);return t.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:g(A.components),t.createElement(i.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/22f0f67d.c82a1c3a.js b/assets/js/22f0f67d.c82a1c3a.js deleted file mode 100644 index 0bbe03ee..00000000 --- a/assets/js/22f0f67d.c82a1c3a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5032],{70116:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>n,frontMatter:()=>g,metadata:()=>C,toc:()=>r});var t=e(74848),s=e(28453),i=e(64023);const g={title:"Integrations",slug:"/integrations/",sidebar_position:1,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},d=void 0,C={id:"guides/integrations/README",title:"Integrations",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/integrations/README.mdx",sourceDirName:"guides/integrations",slug:"/integrations/",permalink:"/integrations/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Integrations",slug:"/integrations/",sidebar_position:1,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},sidebar:"guidesSidebar",previous:{title:"What are Jan Extensions?",permalink:"/extensions"},next:{title:"Discord",permalink:"/integrations/discord"}},l={},r=[];function F(A){return(0,t.jsx)(i.A,{})}function n(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,t.jsx)(a,{...A,children:(0,t.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var t=e(18215),s=e(84142),i=e(20053),g=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},r="",F="",n="",h="",o="",u="",E="",c="",B="",p="",Y="",w="",V="",R="",I="",U="",v="",W="",K="",b="",N="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(g.A,{href:a,className:(0,i.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:t,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,i.A)("text--truncate",l.cardTitle),title:t,children:[e," ",t]}),s&&(0,L.jsx)("p",{className:(0,i.A)(l.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",t=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??t?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const i=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,t.A)("row",e),children:i.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>g,x:()=>d});var t=e(96540);const s={},i=t.createContext(s);function g(A){const a=t.useContext(i);return t.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:g(A.components),t.createElement(i.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/2460799d.1e416fb9.js b/assets/js/2460799d.1e416fb9.js new file mode 100644 index 00000000..19962d18 --- /dev/null +++ b/assets/js/2460799d.1e416fb9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7152],{70117:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>i,contentTitle:()=>a,default:()=>p,frontMatter:()=>r,metadata:()=>o,toc:()=>d});var n=s(74848),c=s(28453);const r={title:"Chassis"},a=void 0,o={id:"hardware/concepts/chassis",title:"Chassis",description:"",source:"@site/docs/hardware/concepts/chassis.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/chassis",permalink:"/hardware/concepts/chassis",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/chassis.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Chassis"}},i={},d=[];function u(t){return(0,n.jsx)(n.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,c.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u()}},28453:(t,e,s)=>{s.d(e,{R:()=>a,x:()=>o});var n=s(96540);const c={},r=n.createContext(c);function a(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function o(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(c):t.components||c:a(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/2460799d.700fa647.js b/assets/js/2460799d.700fa647.js deleted file mode 100644 index 56c42dd1..00000000 --- a/assets/js/2460799d.700fa647.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7152],{70117:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>i,contentTitle:()=>a,default:()=>p,frontMatter:()=>r,metadata:()=>o,toc:()=>d});var n=s(74848),c=s(28453);const r={title:"Chassis"},a=void 0,o={id:"hardware/concepts/chassis",title:"Chassis",description:"",source:"@site/docs/hardware/concepts/chassis.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/chassis",permalink:"/hardware/concepts/chassis",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/chassis.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Chassis"}},i={},d=[];function u(t){return(0,n.jsx)(n.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,c.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u()}},28453:(t,e,s)=>{s.d(e,{R:()=>a,x:()=>o});var n=s(96540);const c={},r=n.createContext(c);function a(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function o(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(c):t.components||c:a(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/266350b9.8a6fe053.js b/assets/js/266350b9.8a6fe053.js deleted file mode 100644 index 9fe9f8fa..00000000 --- a/assets/js/266350b9.8a6fe053.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[166],{980:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>r,default:()=>h,frontMatter:()=>a,metadata:()=>t,toc:()=>d});var l=i(74848),s=i(28453);const a={sidebar_position:3,slug:"/changelog/changelog-v0.4.7"},r="v0.4.7",t={id:"releases/changelog/changelog-v0.4.7",title:"v0.4.7",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.7.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.7",permalink:"/changelog/changelog-v0.4.7",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.7.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:3,frontMatter:{sidebar_position:3,slug:"/changelog/changelog-v0.4.7"},sidebar:"releasesSidebar",previous:{title:"v0.4.8",permalink:"/changelog/changelog-v0.4.8"},next:{title:"v0.4.6",permalink:"/changelog/changelog-v0.4.6"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",code:"code",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v047",children:"v0.4.7"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.7",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/2121",children:"Issue #2121: Release cut v0.4.7"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Release cut v0.4.7 @louis-jan (#2121)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update models @hahuyhoang411 (#1829)"}),"\n",(0,l.jsx)(n.li,{children:"add docs for entire advanced settings @hieu-jan (#2063)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Fix #2040 : added /v1 path to apiBase @ldebs (#2041)"}),"\n",(0,l.jsx)(n.li,{children:"fix: ui for disabled state of gpu acceleration @namchuai (#2034)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Initialize POM structure with fixtures on Playwright @Van-QA (#2015)"}),"\n",(0,l.jsxs)(n.li,{children:["Alternative solution for ",(0,l.jsx)(n.code,{children:"Thread titles should auto-summarize Topic"})," @0xgokuz (#1976)"]}),"\n",(0,l.jsx)(n.li,{children:"Update authors.yml Rex @hahuyhoang411 (#1956)"}),"\n",(0,l.jsx)(n.li,{children:"Update authors.yml Louis @louis-jan (#1955)"}),"\n",(0,l.jsx)(n.li,{children:"Change env Dockerfile.gpu and update README @hiento09 (#1963)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update authors.yml for Van Pham @Van-QA (#1954)"}),"\n",(0,l.jsx)(n.li,{children:"Sync dev branch to docs branch @hieu-jan (#1948)"}),"\n",(0,l.jsx)(n.li,{children:"sync current docs branch to dev branch @hieu-jan (#1947)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Playwright capture screenshot of Electron desktop app (Jan) on failures @Van-QA (#1934)"}),"\n",(0,l.jsx)(n.li,{children:"Sync main to dev after release 0.4.6 @hiento09 (#1929)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: Add nitro vulkan to support AMD GPU/ APU and Intel Arc GPU @hiro-v (#2056)"}),"\n",(0,l.jsx)(n.li,{children:"fix: flow edit message @urmauur (#2113)"}),"\n",(0,l.jsx)(n.li,{children:"Feature helmchart and ci jan server @hiento09 (#2106)"}),"\n",(0,l.jsx)(n.li,{children:"feat: improvementUI GPU acceleration @urmauur (#1990)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add edit messages users @urmauur (#1974)"}),"\n",(0,l.jsx)(n.li,{children:"feat: revamp ui dropdown list model option @urmauur (#1977)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add modal troubleshooting guideline @urmauur (#1968)"}),"\n",(0,l.jsx)(n.li,{children:"feat: integrate umami script locally @hieu-jan (#1958)"}),"\n",(0,l.jsx)(n.li,{children:"feat: User Selectable GPUs and GPU-based Model Recommendations @hiento09 (#1730)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: correct vulkan settings @louis-jan (#2128)"}),"\n",(0,l.jsx)(n.li,{children:"fix: chore UI @louis-jan (#2125)"}),"\n",(0,l.jsx)(n.li,{children:"Regression: bump nitro to 0.3.13 @hiento09 (#2124)"}),"\n",(0,l.jsx)(n.li,{children:"Regression: Linux vulkan binary path @hiento09 (#2123)"}),"\n",(0,l.jsx)(n.li,{children:"fix: revert back menu actions @louis-jan (#2120)"}),"\n",(0,l.jsx)(n.li,{children:"fix: mismatching between nightly build and version - jan about @louis-jan (#2114)"}),"\n",(0,l.jsx)(n.li,{children:"fix: flow edit message @urmauur (#2113)"}),"\n",(0,l.jsx)(n.li,{children:"fix: tools section should be expanded by default @louis-jan (#2110)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to bind port - nitro error message copy @louis-jan (#2101)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove caret down icon when tab selected into remote model @urmauur (#2102)"}),"\n",(0,l.jsx)(n.li,{children:"fix: openai client sdk compatible @louis-jan (#2096)"}),"\n",(0,l.jsx)(n.li,{children:"Fix bug #2005 docker blank website @hiento09 (#2093)"}),"\n",(0,l.jsx)(n.li,{children:"fix: check if port is occupied before start local server @namchuai (#2098)"}),"\n",(0,l.jsx)(n.li,{children:"fix: broken model.json update @louis-jan (#2099)"}),"\n",(0,l.jsx)(n.li,{children:"fix: make text input scrollable @urmauur (#2083)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to send message blocks thread creation @louis-jan (#2091)"}),"\n",(0,l.jsx)(n.li,{children:"fix: server crashes on missing module @louis-jan (#2089)"}),"\n",(0,l.jsx)(n.li,{children:"fix: expand assistant and model settings by default @louis-jan (#2081)"}),"\n",(0,l.jsx)(n.li,{children:"fix: move jan data folder - error handling for no write permission granted @louis-jan (#2077)"}),"\n",(0,l.jsx)(n.li,{children:"fix: check for updates should show no update are available on the latest build @louis-jan (#2075)"}),"\n",(0,l.jsx)(n.li,{children:"fix: infinity showed when haven't get total size @namchuai (#2066)"}),"\n",(0,l.jsx)(n.li,{children:"fix: should stop running the model when GPU settings are changed @louis-jan (#2067)"}),"\n",(0,l.jsx)(n.li,{children:"fix: settings page state loop and dark theme @louis-jan (#2065)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Fix Nitro windows with error 3221225781 @hiro-v (#2057)"}),"\n",(0,l.jsx)(n.li,{children:"fix: message should only be interrupted when i start another thread @louis-jan (#2053)"}),"\n",(0,l.jsx)(n.li,{children:"fix: local server start error should not change to started state @louis-jan (#2052)"}),"\n",(0,l.jsx)(n.li,{children:"fix: update copy of message queue @louis-jan (#2051)"}),"\n",(0,l.jsx)(n.li,{children:"fix: download mutilple binaries @namchuai (#2043)"}),"\n",(0,l.jsx)(n.li,{children:"fix: disable gpu drop down box if there's no GPU ready @namchuai (#2046)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app should generate thread title with length restriction @louis-jan (#2037)"}),"\n",(0,l.jsx)(n.li,{children:"fix: factory reset not remove jan data folder @namchuai (#2027)"}),"\n",(0,l.jsx)(n.li,{children:"fix: content setting right panel default to collapse @urmauur (#2026)"}),"\n",(0,l.jsx)(n.li,{children:"fix: local server blank parameters if there is no thread selected @louis-jan (#2028)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model path backward compatible @louis-jan (#2018)"}),"\n",(0,l.jsx)(n.li,{children:"fix: resolve state update loop infinitive rerendering @louis-jan (#2017)"}),"\n",(0,l.jsx)(n.li,{children:"fix: lack of auto-cleaning mechanism for logs @louis-jan (#2003)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app stuck regenerating assistant response @louis-jan (#2001)"}),"\n",(0,l.jsx)(n.li,{children:"fix: decouple thread summary update @louis-jan (#1994)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app fails gracefully with clear error messages @louis-jan (#1993)"}),"\n",(0,l.jsx)(n.li,{children:"fix: retrieval stuck at generating response @louis-jan (#1988)"}),"\n",(0,l.jsx)(n.li,{children:"Fix macos auto update failed on nightly build @hiento09 (#1991)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model downloads broken on nightly @louis-jan (#1984)"}),"\n",(0,l.jsx)(n.li,{children:"fix: RAG enhancements @urmauur (#1965)"}),"\n",(0,l.jsx)(n.li,{children:"Update docs run Jan Server in Docker mode @hiento09 (#1960)"}),"\n",(0,l.jsx)(n.li,{children:"fix: update conditional check last status message @urmauur (#1951)"}),"\n",(0,l.jsx)(n.li,{children:"fix: markdown render for chat completion role user @urmauur (#1944)"}),"\n",(0,l.jsx)(n.li,{children:"fix: avoid users to create so many threads at the same time @urmauur (#1930)"}),"\n",(0,l.jsx)(n.li,{children:"fix: download model will close panel item hub @urmauur (#1923)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"docs: improve integrations guide & import model using absolute path @hieu-jan (#2076)"}),"\n",(0,l.jsx)(n.li,{children:"chore: add app version into log @namchuai (#2116)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add integration docs Mistral AI API @hieu-jan (#2070)"}),"\n",(0,l.jsxs)(n.li,{children:["docs",":add-advanced-settings-https-proxy"," @hieu-jan (#2054)"]}),"\n",(0,l.jsx)(n.li,{children:"chore: refactor watch system resource hook @louis-jan (#2048)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Updates Guide Using the Local Server @SamPatt (#1924)"}),"\n",(0,l.jsx)(n.li,{children:"server install core using link instead of file @hiento09 (#2025)"}),"\n",(0,l.jsx)(n.li,{children:"chore: prettier fix @louis-jan (#2019)"}),"\n",(0,l.jsx)(n.li,{children:"chore: bump nitro 0.3.9 @louis-jan (#2016)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: reduce IPC & API handlers - shared node logics @louis-jan (#2011)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update 03-gpu-not-used with RTX issues @hieu-jan (#1992)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add Jan installation using Docker @hieu-jan (#1981)"}),"\n",(0,l.jsx)(n.li,{children:"chore: reduce bundle size @louis-jan (#1970)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add author.yml @hieu-jan (#1973)"}),"\n",(0,l.jsx)(n.li,{children:"Update authors.yml hien @hiento09 (#1953)"}),"\n",(0,l.jsx)(n.li,{children:"chore: server download progress + S3 @louis-jan (#1925)"}),"\n",(0,l.jsx)(n.li,{children:"chore: add author james @namchuai (#1952)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Add author - Ashley @imtuyethan (#1950)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Add Author - Hiro @hiro-v (#1949)"}),"\n",(0,l.jsx)(n.li,{children:"docs: adding new feature for v0.4.6 to release checklist @Van-QA (#1927)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @0xgokuz, @SamPatt, @Van-QA, @hahuyhoang411, @hiento09, @hieu-jan, @hiro-v, @imtuyethan, @jan-service-account, @ldebs, @louis-jan, @namchuai, @urmauur and James"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>t});var l=i(96540);const s={},a=l.createContext(s);function r(e){const n=l.useContext(a);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),l.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/266350b9.afa25041.js b/assets/js/266350b9.afa25041.js new file mode 100644 index 00000000..07070fbd --- /dev/null +++ b/assets/js/266350b9.afa25041.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[166],{980:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>r,default:()=>h,frontMatter:()=>a,metadata:()=>t,toc:()=>d});var l=i(74848),s=i(28453);const a={sidebar_position:3,slug:"/changelog/changelog-v0.4.7"},r="v0.4.7",t={id:"releases/changelog/changelog-v0.4.7",title:"v0.4.7",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.7.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.7",permalink:"/changelog/changelog-v0.4.7",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.7.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:3,frontMatter:{sidebar_position:3,slug:"/changelog/changelog-v0.4.7"},sidebar:"releasesSidebar",previous:{title:"v0.4.8",permalink:"/changelog/changelog-v0.4.8"},next:{title:"v0.4.6",permalink:"/changelog/changelog-v0.4.6"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",code:"code",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v047",children:"v0.4.7"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.7",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/2121",children:"Issue #2121: Release cut v0.4.7"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Release cut v0.4.7 @louis-jan (#2121)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update models @hahuyhoang411 (#1829)"}),"\n",(0,l.jsx)(n.li,{children:"add docs for entire advanced settings @hieu-jan (#2063)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Fix #2040 : added /v1 path to apiBase @ldebs (#2041)"}),"\n",(0,l.jsx)(n.li,{children:"fix: ui for disabled state of gpu acceleration @namchuai (#2034)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Initialize POM structure with fixtures on Playwright @Van-QA (#2015)"}),"\n",(0,l.jsxs)(n.li,{children:["Alternative solution for ",(0,l.jsx)(n.code,{children:"Thread titles should auto-summarize Topic"})," @0xgokuz (#1976)"]}),"\n",(0,l.jsx)(n.li,{children:"Update authors.yml Rex @hahuyhoang411 (#1956)"}),"\n",(0,l.jsx)(n.li,{children:"Update authors.yml Louis @louis-jan (#1955)"}),"\n",(0,l.jsx)(n.li,{children:"Change env Dockerfile.gpu and update README @hiento09 (#1963)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update authors.yml for Van Pham @Van-QA (#1954)"}),"\n",(0,l.jsx)(n.li,{children:"Sync dev branch to docs branch @hieu-jan (#1948)"}),"\n",(0,l.jsx)(n.li,{children:"sync current docs branch to dev branch @hieu-jan (#1947)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Playwright capture screenshot of Electron desktop app (Jan) on failures @Van-QA (#1934)"}),"\n",(0,l.jsx)(n.li,{children:"Sync main to dev after release 0.4.6 @hiento09 (#1929)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: Add nitro vulkan to support AMD GPU/ APU and Intel Arc GPU @hiro-v (#2056)"}),"\n",(0,l.jsx)(n.li,{children:"fix: flow edit message @urmauur (#2113)"}),"\n",(0,l.jsx)(n.li,{children:"Feature helmchart and ci jan server @hiento09 (#2106)"}),"\n",(0,l.jsx)(n.li,{children:"feat: improvementUI GPU acceleration @urmauur (#1990)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add edit messages users @urmauur (#1974)"}),"\n",(0,l.jsx)(n.li,{children:"feat: revamp ui dropdown list model option @urmauur (#1977)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add modal troubleshooting guideline @urmauur (#1968)"}),"\n",(0,l.jsx)(n.li,{children:"feat: integrate umami script locally @hieu-jan (#1958)"}),"\n",(0,l.jsx)(n.li,{children:"feat: User Selectable GPUs and GPU-based Model Recommendations @hiento09 (#1730)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: correct vulkan settings @louis-jan (#2128)"}),"\n",(0,l.jsx)(n.li,{children:"fix: chore UI @louis-jan (#2125)"}),"\n",(0,l.jsx)(n.li,{children:"Regression: bump nitro to 0.3.13 @hiento09 (#2124)"}),"\n",(0,l.jsx)(n.li,{children:"Regression: Linux vulkan binary path @hiento09 (#2123)"}),"\n",(0,l.jsx)(n.li,{children:"fix: revert back menu actions @louis-jan (#2120)"}),"\n",(0,l.jsx)(n.li,{children:"fix: mismatching between nightly build and version - jan about @louis-jan (#2114)"}),"\n",(0,l.jsx)(n.li,{children:"fix: flow edit message @urmauur (#2113)"}),"\n",(0,l.jsx)(n.li,{children:"fix: tools section should be expanded by default @louis-jan (#2110)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to bind port - nitro error message copy @louis-jan (#2101)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove caret down icon when tab selected into remote model @urmauur (#2102)"}),"\n",(0,l.jsx)(n.li,{children:"fix: openai client sdk compatible @louis-jan (#2096)"}),"\n",(0,l.jsx)(n.li,{children:"Fix bug #2005 docker blank website @hiento09 (#2093)"}),"\n",(0,l.jsx)(n.li,{children:"fix: check if port is occupied before start local server @namchuai (#2098)"}),"\n",(0,l.jsx)(n.li,{children:"fix: broken model.json update @louis-jan (#2099)"}),"\n",(0,l.jsx)(n.li,{children:"fix: make text input scrollable @urmauur (#2083)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to send message blocks thread creation @louis-jan (#2091)"}),"\n",(0,l.jsx)(n.li,{children:"fix: server crashes on missing module @louis-jan (#2089)"}),"\n",(0,l.jsx)(n.li,{children:"fix: expand assistant and model settings by default @louis-jan (#2081)"}),"\n",(0,l.jsx)(n.li,{children:"fix: move jan data folder - error handling for no write permission granted @louis-jan (#2077)"}),"\n",(0,l.jsx)(n.li,{children:"fix: check for updates should show no update are available on the latest build @louis-jan (#2075)"}),"\n",(0,l.jsx)(n.li,{children:"fix: infinity showed when haven't get total size @namchuai (#2066)"}),"\n",(0,l.jsx)(n.li,{children:"fix: should stop running the model when GPU settings are changed @louis-jan (#2067)"}),"\n",(0,l.jsx)(n.li,{children:"fix: settings page state loop and dark theme @louis-jan (#2065)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Fix Nitro windows with error 3221225781 @hiro-v (#2057)"}),"\n",(0,l.jsx)(n.li,{children:"fix: message should only be interrupted when i start another thread @louis-jan (#2053)"}),"\n",(0,l.jsx)(n.li,{children:"fix: local server start error should not change to started state @louis-jan (#2052)"}),"\n",(0,l.jsx)(n.li,{children:"fix: update copy of message queue @louis-jan (#2051)"}),"\n",(0,l.jsx)(n.li,{children:"fix: download mutilple binaries @namchuai (#2043)"}),"\n",(0,l.jsx)(n.li,{children:"fix: disable gpu drop down box if there's no GPU ready @namchuai (#2046)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app should generate thread title with length restriction @louis-jan (#2037)"}),"\n",(0,l.jsx)(n.li,{children:"fix: factory reset not remove jan data folder @namchuai (#2027)"}),"\n",(0,l.jsx)(n.li,{children:"fix: content setting right panel default to collapse @urmauur (#2026)"}),"\n",(0,l.jsx)(n.li,{children:"fix: local server blank parameters if there is no thread selected @louis-jan (#2028)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model path backward compatible @louis-jan (#2018)"}),"\n",(0,l.jsx)(n.li,{children:"fix: resolve state update loop infinitive rerendering @louis-jan (#2017)"}),"\n",(0,l.jsx)(n.li,{children:"fix: lack of auto-cleaning mechanism for logs @louis-jan (#2003)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app stuck regenerating assistant response @louis-jan (#2001)"}),"\n",(0,l.jsx)(n.li,{children:"fix: decouple thread summary update @louis-jan (#1994)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app fails gracefully with clear error messages @louis-jan (#1993)"}),"\n",(0,l.jsx)(n.li,{children:"fix: retrieval stuck at generating response @louis-jan (#1988)"}),"\n",(0,l.jsx)(n.li,{children:"Fix macos auto update failed on nightly build @hiento09 (#1991)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model downloads broken on nightly @louis-jan (#1984)"}),"\n",(0,l.jsx)(n.li,{children:"fix: RAG enhancements @urmauur (#1965)"}),"\n",(0,l.jsx)(n.li,{children:"Update docs run Jan Server in Docker mode @hiento09 (#1960)"}),"\n",(0,l.jsx)(n.li,{children:"fix: update conditional check last status message @urmauur (#1951)"}),"\n",(0,l.jsx)(n.li,{children:"fix: markdown render for chat completion role user @urmauur (#1944)"}),"\n",(0,l.jsx)(n.li,{children:"fix: avoid users to create so many threads at the same time @urmauur (#1930)"}),"\n",(0,l.jsx)(n.li,{children:"fix: download model will close panel item hub @urmauur (#1923)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"docs: improve integrations guide & import model using absolute path @hieu-jan (#2076)"}),"\n",(0,l.jsx)(n.li,{children:"chore: add app version into log @namchuai (#2116)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add integration docs Mistral AI API @hieu-jan (#2070)"}),"\n",(0,l.jsxs)(n.li,{children:["docs",":add-advanced-settings-https-proxy"," @hieu-jan (#2054)"]}),"\n",(0,l.jsx)(n.li,{children:"chore: refactor watch system resource hook @louis-jan (#2048)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Updates Guide Using the Local Server @SamPatt (#1924)"}),"\n",(0,l.jsx)(n.li,{children:"server install core using link instead of file @hiento09 (#2025)"}),"\n",(0,l.jsx)(n.li,{children:"chore: prettier fix @louis-jan (#2019)"}),"\n",(0,l.jsx)(n.li,{children:"chore: bump nitro 0.3.9 @louis-jan (#2016)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: reduce IPC & API handlers - shared node logics @louis-jan (#2011)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update 03-gpu-not-used with RTX issues @hieu-jan (#1992)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add Jan installation using Docker @hieu-jan (#1981)"}),"\n",(0,l.jsx)(n.li,{children:"chore: reduce bundle size @louis-jan (#1970)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add author.yml @hieu-jan (#1973)"}),"\n",(0,l.jsx)(n.li,{children:"Update authors.yml hien @hiento09 (#1953)"}),"\n",(0,l.jsx)(n.li,{children:"chore: server download progress + S3 @louis-jan (#1925)"}),"\n",(0,l.jsx)(n.li,{children:"chore: add author james @namchuai (#1952)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Add author - Ashley @imtuyethan (#1950)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Add Author - Hiro @hiro-v (#1949)"}),"\n",(0,l.jsx)(n.li,{children:"docs: adding new feature for v0.4.6 to release checklist @Van-QA (#1927)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @0xgokuz, @SamPatt, @Van-QA, @hahuyhoang411, @hiento09, @hieu-jan, @hiro-v, @imtuyethan, @jan-service-account, @ldebs, @louis-jan, @namchuai, @urmauur and James"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>t});var l=i(96540);const s={},a=l.createContext(s);function r(e){const n=l.useContext(a);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),l.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/26c8ba65.9130bbf2.js b/assets/js/26c8ba65.9130bbf2.js new file mode 100644 index 00000000..e78be745 --- /dev/null +++ b/assets/js/26c8ba65.9130bbf2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1178],{20963:(n,t,e)=>{e.r(t),e.d(t,{assets:()=>u,contentTitle:()=>l,default:()=>d,frontMatter:()=>s,metadata:()=>a,toc:()=>r});var i=e(74848),o=e(28453);const s={title:"Install on Linux",sidebar_position:3,slug:"/guides/install/linux",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Linux.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Linux","Linux"]},l=void 0,a={id:"guides/installation/linux",title:"Install on Linux",description:"A step-by-step guide to install Jan on your Linux.",source:"@site/docs/guides/installation/linux.mdx",sourceDirName:"guides/installation",slug:"/guides/install/linux",permalink:"/guides/install/linux",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/linux.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:3,frontMatter:{title:"Install on Linux",sidebar_position:3,slug:"/guides/install/linux",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Linux.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Linux","Linux"]}},u={},r=[];function c(n){const t={p:"p",...(0,o.R)(),...n.components};return(0,i.jsx)(t.p,{children:"Coming soon"})}function d(n={}){const{wrapper:t}={...(0,o.R)(),...n.components};return t?(0,i.jsx)(t,{...n,children:(0,i.jsx)(c,{...n})}):c(n)}},28453:(n,t,e)=>{e.d(t,{R:()=>l,x:()=>a});var i=e(96540);const o={},s=i.createContext(o);function l(n){const t=i.useContext(s);return i.useMemo((function(){return"function"==typeof n?n(t):{...t,...n}}),[t,n])}function a(n){let t;return t=n.disableParentContext?"function"==typeof n.components?n.components(o):n.components||o:l(n.components),i.createElement(s.Provider,{value:t},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/26c8ba65.f2d34ba6.js b/assets/js/26c8ba65.f2d34ba6.js deleted file mode 100644 index d680bf22..00000000 --- a/assets/js/26c8ba65.f2d34ba6.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1178],{20963:(n,t,e)=>{e.r(t),e.d(t,{assets:()=>u,contentTitle:()=>l,default:()=>d,frontMatter:()=>s,metadata:()=>a,toc:()=>r});var i=e(74848),o=e(28453);const s={title:"Install on Linux",sidebar_position:3,slug:"/guides/install/linux",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Linux.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Linux","Linux"]},l=void 0,a={id:"guides/installation/linux",title:"Install on Linux",description:"A step-by-step guide to install Jan on your Linux.",source:"@site/docs/guides/installation/linux.mdx",sourceDirName:"guides/installation",slug:"/guides/install/linux",permalink:"/guides/install/linux",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/linux.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:3,frontMatter:{title:"Install on Linux",sidebar_position:3,slug:"/guides/install/linux",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Linux.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Install on Linux","Linux"]}},u={},r=[];function c(n){const t={p:"p",...(0,o.R)(),...n.components};return(0,i.jsx)(t.p,{children:"Coming soon"})}function d(n={}){const{wrapper:t}={...(0,o.R)(),...n.components};return t?(0,i.jsx)(t,{...n,children:(0,i.jsx)(c,{...n})}):c(n)}},28453:(n,t,e)=>{e.d(t,{R:()=>l,x:()=>a});var i=e(96540);const o={},s=i.createContext(o);function l(n){const t=i.useContext(s);return i.useMemo((function(){return"function"==typeof n?n(t):{...t,...n}}),[t,n])}function a(n){let t;return t=n.disableParentContext?"function"==typeof n.components?n.components(o):n.components||o:l(n.components),i.createElement(s.Provider,{value:t},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/286abf9a.662965b4.js b/assets/js/286abf9a.662965b4.js new file mode 100644 index 00000000..35e4708d --- /dev/null +++ b/assets/js/286abf9a.662965b4.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1860],{62935:(e,r,t)=>{t.r(r),t.d(r,{assets:()=>l,contentTitle:()=>a,default:()=>u,frontMatter:()=>s,metadata:()=>i,toc:()=>c});var o=t(74848),n=t(28453);const s={title:"Hub",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,i={id:"developer/framework/product/hub",title:"Hub",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/hub.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/hub",permalink:"/developer/framework/product/hub",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/hub.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Hub",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Chat",permalink:"/developer/framework/product/chat"},next:{title:"Jan (The Default Assistant)",permalink:"/developer/framework/product/jan"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2}];function d(e){const r={code:"code",h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,n.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(r.h2,{id:"overview",children:"Overview"}),"\n",(0,o.jsx)(r.p,{children:"The Hub is like a store for everything, where users can discover and download models, assistants, and more."}),"\n",(0,o.jsx)(r.p,{children:(0,o.jsx)(r.img,{alt:"alt text",src:t(59126).A+"",width:"1440",height:"1493"})}),"\n",(0,o.jsx)(r.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,o.jsxs)(r.ul,{children:["\n",(0,o.jsxs)(r.li,{children:["Users can discover recommended models (Jan ships with a few preconfigured ",(0,o.jsx)(r.code,{children:"model.json"})," files)"]}),"\n",(0,o.jsx)(r.li,{children:"Users can download models suitable for their devices, e.g. compatible with their RAM"}),"\n",(0,o.jsx)(r.li,{children:"Users can download models via a HuggingFace URL (coming soon)"}),"\n"]})]})}function u(e={}){const{wrapper:r}={...(0,n.R)(),...e.components};return r?(0,o.jsx)(r,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},59126:(e,r,t)=>{t.d(r,{A:()=>o});const o=t.p+"assets/images/hub-screen-d53177b85949f0ae1691b00216ccd32e.png"},28453:(e,r,t)=>{t.d(r,{R:()=>a,x:()=>i});var o=t(96540);const n={},s=o.createContext(n);function a(e){const r=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(r):{...r,...e}}),[r,e])}function i(e){let r;return r=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:a(e.components),o.createElement(s.Provider,{value:r},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/286abf9a.a466e946.js b/assets/js/286abf9a.a466e946.js deleted file mode 100644 index 6c1c5b89..00000000 --- a/assets/js/286abf9a.a466e946.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1860],{62935:(e,r,t)=>{t.r(r),t.d(r,{assets:()=>l,contentTitle:()=>a,default:()=>u,frontMatter:()=>s,metadata:()=>i,toc:()=>c});var o=t(74848),n=t(28453);const s={title:"Hub",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},a=void 0,i={id:"developer/framework/product/hub",title:"Hub",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/hub.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/hub",permalink:"/developer/framework/product/hub",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/hub.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Hub",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Chat",permalink:"/developer/framework/product/chat"},next:{title:"Jan (The Default Assistant)",permalink:"/developer/framework/product/jan"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2}];function d(e){const r={code:"code",h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,n.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(r.h2,{id:"overview",children:"Overview"}),"\n",(0,o.jsx)(r.p,{children:"The Hub is like a store for everything, where users can discover and download models, assistants, and more."}),"\n",(0,o.jsx)(r.p,{children:(0,o.jsx)(r.img,{alt:"alt text",src:t(59126).A+"",width:"1440",height:"1493"})}),"\n",(0,o.jsx)(r.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,o.jsxs)(r.ul,{children:["\n",(0,o.jsxs)(r.li,{children:["Users can discover recommended models (Jan ships with a few preconfigured ",(0,o.jsx)(r.code,{children:"model.json"})," files)"]}),"\n",(0,o.jsx)(r.li,{children:"Users can download models suitable for their devices, e.g. compatible with their RAM"}),"\n",(0,o.jsx)(r.li,{children:"Users can download models via a HuggingFace URL (coming soon)"}),"\n"]})]})}function u(e={}){const{wrapper:r}={...(0,n.R)(),...e.components};return r?(0,o.jsx)(r,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},59126:(e,r,t)=>{t.d(r,{A:()=>o});const o=t.p+"assets/images/hub-screen-d53177b85949f0ae1691b00216ccd32e.png"},28453:(e,r,t)=>{t.d(r,{R:()=>a,x:()=>i});var o=t(96540);const n={},s=o.createContext(n);function a(e){const r=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(r):{...r,...e}}),[r,e])}function i(e){let r;return r=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:a(e.components),o.createElement(s.Provider,{value:r},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/29484a29.1b3cac3a.js b/assets/js/29484a29.1b3cac3a.js new file mode 100644 index 00000000..56865624 --- /dev/null +++ b/assets/js/29484a29.1b3cac3a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2222],{22379:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>l,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=n(74848),o=n(28453);const r={title:"CrewAI",sidebar_position:19,description:"A step-by-step guide on how to integrate Jan with CrewAI.",slug:"/integrations/crewai",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","CrewAI integration","CrewAI"]},s=void 0,a={id:"guides/integrations/crewai",title:"CrewAI",description:"A step-by-step guide on how to integrate Jan with CrewAI.",source:"@site/docs/guides/integrations/crewai.mdx",sourceDirName:"guides/integrations",slug:"/integrations/crewai",permalink:"/integrations/crewai",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/crewai.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:19,frontMatter:{title:"CrewAI",sidebar_position:19,description:"A step-by-step guide on how to integrate Jan with CrewAI.",slug:"/integrations/crewai",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","CrewAI integration","CrewAI"]}},c={},d=[];function u(e){const t={p:"p",...(0,o.R)(),...e.components};return(0,i.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,i.jsx)(t,{...e,children:(0,i.jsx)(u,{...e})}):u(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>a});var i=n(96540);const o={},r=i.createContext(o);function s(e){const t=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),i.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/29484a29.f1540980.js b/assets/js/29484a29.f1540980.js deleted file mode 100644 index 2820a04c..00000000 --- a/assets/js/29484a29.f1540980.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2222],{22379:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>l,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=n(74848),o=n(28453);const r={title:"CrewAI",sidebar_position:19,description:"A step-by-step guide on how to integrate Jan with CrewAI.",slug:"/integrations/crewai",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","CrewAI integration","CrewAI"]},s=void 0,a={id:"guides/integrations/crewai",title:"CrewAI",description:"A step-by-step guide on how to integrate Jan with CrewAI.",source:"@site/docs/guides/integrations/crewai.mdx",sourceDirName:"guides/integrations",slug:"/integrations/crewai",permalink:"/integrations/crewai",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/crewai.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:19,frontMatter:{title:"CrewAI",sidebar_position:19,description:"A step-by-step guide on how to integrate Jan with CrewAI.",slug:"/integrations/crewai",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","CrewAI integration","CrewAI"]}},c={},d=[];function u(e){const t={p:"p",...(0,o.R)(),...e.components};return(0,i.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,i.jsx)(t,{...e,children:(0,i.jsx)(u,{...e})}):u(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>a});var i=n(96540);const o={},r=i.createContext(o);function s(e){const t=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),i.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2a036e2a.01b32ec7.js b/assets/js/2a036e2a.01b32ec7.js new file mode 100644 index 00000000..16e2a396 --- /dev/null +++ b/assets/js/2a036e2a.01b32ec7.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9307],{49932:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>r,default:()=>p,frontMatter:()=>s,metadata:()=>a,toc:()=>l});var i=t(74848),o=t(28453);const s={title:"OpenAI"},r=void 0,a={id:"integrations/openai",title:"OpenAI",description:"Quicklinks",source:"@site/docs/integrations/openai.md",sourceDirName:"integrations",slug:"/integrations/openai",permalink:"/integrations/openai",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/openai.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"OpenAI"},sidebar:"ecosystemSidebar",previous:{title:"Ollama",permalink:"/integrations/ollama"},next:{title:"OpenRouter",permalink:"/integrations/openrouter"}},c={},l=[{value:"Quicklinks",id:"quicklinks",level:2}];function d(e){const n={a:"a",h2:"h2",li:"li",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"quicklinks",children:"Quicklinks"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Jan Framework ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/extensions/inference-openai-extension",children:"Extension Code"})]}),"\n",(0,i.jsxs)(n.li,{children:["OpenAI API ",(0,i.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference",children:"Reference Docs"})]}),"\n"]})]})}function p(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>a});var i=t(96540);const o={},s=i.createContext(o);function r(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2a036e2a.ccc163c3.js b/assets/js/2a036e2a.ccc163c3.js deleted file mode 100644 index a9e631c5..00000000 --- a/assets/js/2a036e2a.ccc163c3.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9307],{49932:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>r,default:()=>u,frontMatter:()=>s,metadata:()=>a,toc:()=>l});var i=t(74848),o=t(28453);const s={title:"OpenAI"},r=void 0,a={id:"integrations/openai",title:"OpenAI",description:"Quicklinks",source:"@site/docs/integrations/openai.md",sourceDirName:"integrations",slug:"/integrations/openai",permalink:"/integrations/openai",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/openai.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"OpenAI"},sidebar:"ecosystemSidebar",previous:{title:"Ollama",permalink:"/integrations/ollama"},next:{title:"OpenRouter",permalink:"/integrations/openrouter"}},c={},l=[{value:"Quicklinks",id:"quicklinks",level:2}];function d(e){const n={a:"a",h2:"h2",li:"li",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"quicklinks",children:"Quicklinks"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Jan Framework ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/extensions/inference-openai-extension",children:"Extension Code"})]}),"\n",(0,i.jsxs)(n.li,{children:["OpenAI API ",(0,i.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference",children:"Reference Docs"})]}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>a});var i=t(96540);const o={},s=i.createContext(o);function r(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2a4d3a22.398b399a.js b/assets/js/2a4d3a22.398b399a.js deleted file mode 100644 index 6ff26168..00000000 --- a/assets/js/2a4d3a22.398b399a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6312],{12093:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>o,contentTitle:()=>a,default:()=>l,frontMatter:()=>r,metadata:()=>c,toc:()=>h});var s=n(74848),i=n(28453);const r={title:"Jan's AI Hacker House (Ho Chi Minh City)",description:"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai",slug:"/events/hcmc-oct23",image:"/img/hcmc-launch-party.png",keywords:["AI","Hacker House","Ho Chi Minh City","HCMC","Jan.ai"]},a=void 0,c={id:"events/hcmc-oct23",title:"Jan's AI Hacker House (Ho Chi Minh City)",description:"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai",source:"@site/docs/events/hcmc-oct23.md",sourceDirName:"events",slug:"/events/hcmc-oct23",permalink:"/events/hcmc-oct23",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/events/hcmc-oct23.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan's AI Hacker House (Ho Chi Minh City)",description:"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai",slug:"/events/hcmc-oct23",image:"/img/hcmc-launch-party.png",keywords:["AI","Hacker House","Ho Chi Minh City","HCMC","Jan.ai"]}},o={},h=[{value:"Ho Chi Minh City",id:"ho-chi-minh-city",level:2},{value:"Date & Time",id:"date--time",level:3},{value:"Location",id:"location",level:3},{value:"Agenda",id:"agenda",level:2},{value:"OKRs",id:"okrs",level:3},{value:"Photos",id:"photos",level:2}];function d(e){const t={a:"a",em:"em",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:(0,s.jsx)(t.img,{src:n(28683).A+"",width:"3240",height:"1620"})}),"\n",(0,s.jsxs)(t.p,{children:["\ud83c\udf89 Join us at our Friday Launch Party for an evening of AI talks from other builders! ",(0,s.jsx)(t.a,{href:"https://jan-launch-party.eventbrite.sg/",children:"(RSVP here)"})," \ud83c\udf89"]}),"\n",(0,s.jsx)(t.h2,{id:"ho-chi-minh-city",children:"Ho Chi Minh City"}),"\n",(0,s.jsxs)(t.p,{children:[(0,s.jsx)(t.a,{href:"https://jan.ai",children:"Jan's Hacker House"})," is a 4-day event where we host an open AI Hacker House and invite the local AI community to join us. There is fast wifi, free snacks, drinks and pizza."]}),"\n",(0,s.jsx)(t.p,{children:'We also host a series of talks, workshops and social events at night. We usually start off the week with a "Intro to LLMs" that targets local university students, and then progress to more in-depth technical and research areas.'}),"\n",(0,s.jsx)(t.p,{children:"Jan is a fully remote team. We use the money we save from not having an office, to hold Hack Weeks where we meet in a city, eat pizza and work to ship major releases."}),"\n",(0,s.jsx)(t.h3,{id:"date--time",children:"Date & Time"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"24-27 October 2023"}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"location",children:"Location"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Districts 1 & 3, Ho Chi Minh City"}),"\n",(0,s.jsx)(t.li,{children:"Exact location in Evenbrite (see below)"}),"\n"]}),"\n",(0,s.jsx)(t.h2,{id:"agenda",children:"Agenda"}),"\n",(0,s.jsx)(t.p,{children:"To help us manage RSVPs, please use the Eventbrite links below to RSVP for each event."}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:"Day"}),(0,s.jsx)(t.th,{children:"Eventbrite Link"}),(0,s.jsx)(t.th,{children:"Signups"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Mon (23 Oct)"}),(0,s.jsx)(t.td,{children:"Jan Team & Partners Dinner"}),(0,s.jsx)(t.td,{children:"Invite-only"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Thu (26 Oct)"}),(0,s.jsx)(t.td,{children:"HCMC Startups & VC Night"}),(0,s.jsx)(t.td,{children:"Invite-only"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Fri (27 Oct)"}),(0,s.jsx)(t.td,{children:"Jan Launch Party + Build your own LLM"}),(0,s.jsx)(t.td,{children:(0,s.jsx)(t.a,{href:"https://jan-launch-party.eventbrite.sg/",children:"RSVP here"})})]})]})]}),"\n",(0,s.jsx)(t.h3,{id:"okrs",children:"OKRs"}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:(0,s.jsx)(t.strong,{children:"Objective"})}),(0,s.jsx)(t.th,{children:"Jan v1.0 should be bug-free and run on Windows, Max, Linux"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsx)(t.td,{children:'Polished UI with "Create Bot" w/ saved prompts'})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsx)(t.td,{children:"Documentation of Jan Codebase for Plugin Developers"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsx)(t.td,{children:"Roadmap for 4Q 2023"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsxs)(t.td,{children:[(0,s.jsx)(t.em,{children:"Stretch Goal:"})," Core Process API for Plugins"]})]})]})]}),"\n",(0,s.jsx)(t.h2,{id:"photos",children:"Photos"}),"\n",(0,s.jsx)(t.p,{children:(0,s.jsx)(t.img,{src:n(28683).A+"",width:"3240",height:"1620"})}),"\n",(0,s.jsxs)(t.p,{children:["\ud83c\udf89 Join us at our Friday Launch Party for an evening of AI talks from other builders! ",(0,s.jsx)(t.a,{href:"https://jan-launch-party.eventbrite.sg/",children:"(RSVP here)"})," \ud83c\udf89"]})]})}function l(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28683:(e,t,n)=>{n.d(t,{A:()=>s});const s=n.p+"assets/images/hcmc-launch-party-d542c9b8f75ab9593b8635b01194a8e6.png"},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>c});var s=n(96540);const i={},r=s.createContext(i);function a(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2a4d3a22.92f8c112.js b/assets/js/2a4d3a22.92f8c112.js new file mode 100644 index 00000000..481a8bbd --- /dev/null +++ b/assets/js/2a4d3a22.92f8c112.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6312],{12093:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>o,contentTitle:()=>a,default:()=>l,frontMatter:()=>r,metadata:()=>c,toc:()=>h});var s=n(74848),i=n(28453);const r={title:"Jan's AI Hacker House (Ho Chi Minh City)",description:"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai",slug:"/events/hcmc-oct23",image:"/img/hcmc-launch-party.png",keywords:["AI","Hacker House","Ho Chi Minh City","HCMC","Jan.ai"]},a=void 0,c={id:"events/hcmc-oct23",title:"Jan's AI Hacker House (Ho Chi Minh City)",description:"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai",source:"@site/docs/events/hcmc-oct23.md",sourceDirName:"events",slug:"/events/hcmc-oct23",permalink:"/events/hcmc-oct23",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/events/hcmc-oct23.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan's AI Hacker House (Ho Chi Minh City)",description:"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai",slug:"/events/hcmc-oct23",image:"/img/hcmc-launch-party.png",keywords:["AI","Hacker House","Ho Chi Minh City","HCMC","Jan.ai"]}},o={},h=[{value:"Ho Chi Minh City",id:"ho-chi-minh-city",level:2},{value:"Date & Time",id:"date--time",level:3},{value:"Location",id:"location",level:3},{value:"Agenda",id:"agenda",level:2},{value:"OKRs",id:"okrs",level:3},{value:"Photos",id:"photos",level:2}];function d(e){const t={a:"a",em:"em",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:(0,s.jsx)(t.img,{src:n(28683).A+"",width:"3240",height:"1620"})}),"\n",(0,s.jsxs)(t.p,{children:["\ud83c\udf89 Join us at our Friday Launch Party for an evening of AI talks from other builders! ",(0,s.jsx)(t.a,{href:"https://jan-launch-party.eventbrite.sg/",children:"(RSVP here)"})," \ud83c\udf89"]}),"\n",(0,s.jsx)(t.h2,{id:"ho-chi-minh-city",children:"Ho Chi Minh City"}),"\n",(0,s.jsxs)(t.p,{children:[(0,s.jsx)(t.a,{href:"https://jan.ai",children:"Jan's Hacker House"})," is a 4-day event where we host an open AI Hacker House and invite the local AI community to join us. There is fast wifi, free snacks, drinks and pizza."]}),"\n",(0,s.jsx)(t.p,{children:'We also host a series of talks, workshops and social events at night. We usually start off the week with a "Intro to LLMs" that targets local university students, and then progress to more in-depth technical and research areas.'}),"\n",(0,s.jsx)(t.p,{children:"Jan is a fully remote team. We use the money we save from not having an office, to hold Hack Weeks where we meet in a city, eat pizza and work to ship major releases."}),"\n",(0,s.jsx)(t.h3,{id:"date--time",children:"Date & Time"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"24-27 October 2023"}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"location",children:"Location"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Districts 1 & 3, Ho Chi Minh City"}),"\n",(0,s.jsx)(t.li,{children:"Exact location in Evenbrite (see below)"}),"\n"]}),"\n",(0,s.jsx)(t.h2,{id:"agenda",children:"Agenda"}),"\n",(0,s.jsx)(t.p,{children:"To help us manage RSVPs, please use the Eventbrite links below to RSVP for each event."}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:"Day"}),(0,s.jsx)(t.th,{children:"Eventbrite Link"}),(0,s.jsx)(t.th,{children:"Signups"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Mon (23 Oct)"}),(0,s.jsx)(t.td,{children:"Jan Team & Partners Dinner"}),(0,s.jsx)(t.td,{children:"Invite-only"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Thu (26 Oct)"}),(0,s.jsx)(t.td,{children:"HCMC Startups & VC Night"}),(0,s.jsx)(t.td,{children:"Invite-only"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Fri (27 Oct)"}),(0,s.jsx)(t.td,{children:"Jan Launch Party + Build your own LLM"}),(0,s.jsx)(t.td,{children:(0,s.jsx)(t.a,{href:"https://jan-launch-party.eventbrite.sg/",children:"RSVP here"})})]})]})]}),"\n",(0,s.jsx)(t.h3,{id:"okrs",children:"OKRs"}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:(0,s.jsx)(t.strong,{children:"Objective"})}),(0,s.jsx)(t.th,{children:"Jan v1.0 should be bug-free and run on Windows, Max, Linux"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsx)(t.td,{children:'Polished UI with "Create Bot" w/ saved prompts'})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsx)(t.td,{children:"Documentation of Jan Codebase for Plugin Developers"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsx)(t.td,{children:"Roadmap for 4Q 2023"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Key Result"}),(0,s.jsxs)(t.td,{children:[(0,s.jsx)(t.em,{children:"Stretch Goal:"})," Core Process API for Plugins"]})]})]})]}),"\n",(0,s.jsx)(t.h2,{id:"photos",children:"Photos"}),"\n",(0,s.jsx)(t.p,{children:(0,s.jsx)(t.img,{src:n(28683).A+"",width:"3240",height:"1620"})}),"\n",(0,s.jsxs)(t.p,{children:["\ud83c\udf89 Join us at our Friday Launch Party for an evening of AI talks from other builders! ",(0,s.jsx)(t.a,{href:"https://jan-launch-party.eventbrite.sg/",children:"(RSVP here)"})," \ud83c\udf89"]})]})}function l(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28683:(e,t,n)=>{n.d(t,{A:()=>s});const s=n.p+"assets/images/hcmc-launch-party-d542c9b8f75ab9593b8635b01194a8e6.png"},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>c});var s=n(96540);const i={},r=s.createContext(i);function a(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2c3f1425.57786fc4.js b/assets/js/2c3f1425.57786fc4.js new file mode 100644 index 00000000..ea13413d --- /dev/null +++ b/assets/js/2c3f1425.57786fc4.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8965],{475:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>r,default:()=>h,frontMatter:()=>s,metadata:()=>o,toc:()=>t});var l=i(74848),a=i(28453);const s={sidebar_position:6,slug:"/changelog/changelog-v0.4.4"},r="v0.4.4",o={id:"releases/changelog/changelog-v0.4.4",title:"v0.4.4",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.4.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.4",permalink:"/changelog/changelog-v0.4.4",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.4.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:6,frontMatter:{sidebar_position:6,slug:"/changelog/changelog-v0.4.4"},sidebar:"releasesSidebar",previous:{title:"v0.4.5",permalink:"/changelog/changelog-v0.4.5"},next:{title:"v0.4.3",permalink:"/changelog/changelog-v0.4.3"}},d={},t=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v044",children:"v0.4.4"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.4",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1587",children:"Issue #1587: Update 2023-11-05-hello-world.md"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Update 2023-11-05-hello-world.md @Ssstars (#1587)"}),"\n",(0,l.jsx)(n.li,{children:"fix(API): #1511 update swagger page @namchuai (#1572)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Thread): #1212 thread.json not created when user change thread settings @namchuai (#1570)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Thread): #1336 not allow creating too many unfinished thread @namchuai (#1538)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-to-get-involved-and-FAQ.mdx @Ssstars (#1555)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-to-get-involved-and-FAQ.mdx @Ssstars (#1553)"}),"\n",(0,l.jsx)(n.li,{children:"Update 02-embracing-pod-structure.mdx @Ssstars (#1550)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-we-hire.mdx @Ssstars (#1551)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-we-hire.mdx @Ssstars (#1524)"}),"\n",(0,l.jsx)(n.li,{children:"fix(InferenceExtension): #1067 sync the nitro process state @namchuai (#1493)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Messages): #1434 create message via api does not display on app correctly @namchuai (#1479)"}),"\n",(0,l.jsx)(n.li,{children:"Docs for the Integration of Continue and Jan in VSCode @0xgokuz (#1467)"}),"\n",(0,l.jsx)(n.li,{children:"Chore: Update model.json for UI @hahuyhoang411 (#1448)"}),"\n",(0,l.jsx)(n.li,{children:"Docs for Installing Models from Hub @0xgokuz (#1450)"}),"\n",(0,l.jsx)(n.li,{children:"Update about.md @Ssstars (#1436)"}),"\n",(0,l.jsx)(n.li,{children:"feat(UI): #1404 make left side bar collapsible by hot key @namchuai (#1420)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Typo in 06-hardware.md @akaMrNagar (#1408)"}),"\n",(0,l.jsx)(n.li,{children:"fix(API): #1409 fix wrong prefix for threads api @namchuai (#1410)"}),"\n",(0,l.jsx)(n.li,{children:"Update model hub @hahuyhoang411 (#1383)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Model): remove unsupported default model setting params @namchuai (#1382)"}),"\n",(0,l.jsx)(n.li,{children:"fix(trinity): update cover path for trinity v1.2 @hahuyhoang411 (#1380)"}),"\n",(0,l.jsx)(n.li,{children:"Chore/update model hub @hahuyhoang411 (#1342)"}),"\n",(0,l.jsx)(n.li,{children:"Update about.md @Ssstars (#1359)"}),"\n",(0,l.jsx)(n.li,{children:"fix(JanHub): #1158 sort model list @namchuai (#1257)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Message): open link with external browser @namchuai (#1339)"}),"\n",(0,l.jsx)(n.li,{children:"feat(Model): #1028 made model.json optional @namchuai (#1314)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update onboarding.md @Diane0111 (#1293)"}),"\n",(0,l.jsx)(n.li,{children:"fix: clean resource on exit @louis-jan (#1290)"}),"\n",(0,l.jsx)(n.li,{children:"fix: posthog configuration @hieu-jan (#1283)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update README.md @eltociear (#1277)"}),"\n",(0,l.jsx)(n.li,{children:"Enable scrolling in the message chat box @Gri-ffin (#1280)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update README.md @sr-albert (#1263)"}),"\n",(0,l.jsx)(n.li,{children:"Adding new model to the Hub @hahuyhoang411 (#1213)"}),"\n",(0,l.jsx)(n.li,{children:"Feature GPU detection for Jan on Windows and Linux @hiento09 (#1242)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Thread): #1168 fix newly created thread cannot select model after restart @namchuai (#1176)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: add compatibility tag to model selection in right panel @urmauur (#1552)"}),"\n",(0,l.jsx)(n.li,{children:"Feature integrate antivirus scanner to ci @hiento09 (#1529)"}),"\n",(0,l.jsx)(n.li,{children:"feat: [hub] update compatibility tags colors @urmauur (#1516)"}),"\n",(0,l.jsx)(n.li,{children:"feat: hub recommendation labels @urmauur (#1440)"}),"\n",(0,l.jsx)(n.li,{children:"Feature linux support app image format @hiento09 (#1442)"}),"\n",(0,l.jsx)(n.li,{children:"fix: render external links @urmauur (#1441)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add icon collapsible left panel and update keyboard shortcut page @urmauur (#1439)"}),"\n",(0,l.jsx)(n.li,{children:"feat(UI): update UI footer @urmauur (#1424)"}),"\n",(0,l.jsx)(n.li,{children:"Fix Bug for Chat Reply Goes off Screen @mishrababhishek (#1393)"}),"\n",(0,l.jsx)(n.li,{children:"feat: move social media from left panel into footer @urmauur (#1325)"}),"\n",(0,l.jsx)(n.li,{children:"feat: implementation new UI thread settings @urmauur (#1301)"}),"\n",(0,l.jsx)(n.li,{children:"Bring social media links @Gri-ffin (#1295)"}),"\n",(0,l.jsx)(n.li,{children:"feat: added keyboard shortcut list in setting page @urmauur (#1275)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add swagger /docs to localhost:1337 @louis-jan (#1268)"}),"\n",(0,l.jsx)(n.li,{children:"feat: update posthog configuration @hieu-jan (#1258)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Deprecate model.json ready state in favor of .download ext @louis-jan (#1238)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add engine settings @namchuai (#1199)"}),"\n",(0,l.jsx)(n.li,{children:"feat: users should be able to switch models mid-thread @louis-jan (#1226)"}),"\n",(0,l.jsx)(n.li,{children:"feat: temporary link how to import model @urmauur (#1209)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: #1594 - Model settings - change thread model - go back does not see according settings @louis-jan (#1595)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1548 - duplicate command shortcut instruction @louis-jan (#1600)"}),"\n",(0,l.jsx)(n.li,{children:"fix: switch model caused app crash @louis-jan (#1597)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1559 Inference Parameters displayed on new thread with Openai GPT Model @louis-jan (#1588)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable user set value manually model setting from input @urmauur (#1585)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1569 - Does not apply thread settings when loading model @louis-jan (#1576)"}),"\n",(0,l.jsx)(n.li,{children:"fix: could not change model params settings @louis-jan (#1547)"}),"\n",(0,l.jsx)(n.li,{children:"fix: gpu check module export does not work in extension @louis-jan (#1536)"}),"\n",(0,l.jsx)(n.li,{children:"fix: adjust calculation hub labels using total RAM instead remaining RAM @urmauur (#1522)"}),"\n",(0,l.jsx)(n.li,{children:"Feature integrate antivirus scanner to ci @hiento09 (#1529)"}),"\n",(0,l.jsx)(n.li,{children:"fix: allow users to set max tokens variably @urmauur (#1513)"}),"\n",(0,l.jsx)(n.li,{children:"fix: stop word update @louis-jan (#1457)"}),"\n",(0,l.jsx)(n.li,{children:"Revert nitro to 0.2.6 @hiento09 (#1491)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable text selection codeblock @urmauur (#1466)"}),"\n",(0,l.jsx)(n.li,{children:"fix: suppress all main node JS error message dialog @louis-jan (#1460)"}),"\n",(0,l.jsx)(n.li,{children:"Correct AppImage path @hiento09 (#1446)"}),"\n",(0,l.jsx)(n.li,{children:"fix: render external links @urmauur (#1441)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add icon collapsible left panel and update keyboard shortcut page @urmauur (#1439)"}),"\n",(0,l.jsx)(n.li,{children:"fix: GET /models does not work due to new default model dir @louis-jan (#1392)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model migration stopped working @louis-jan (#1378)"}),"\n",(0,l.jsx)(n.li,{children:"fix: wrong condition for displaying error message @louis-jan (#1376)"}),"\n",(0,l.jsx)(n.li,{children:"fix: show hide section engine params @urmauur (#1374)"}),"\n",(0,l.jsx)(n.li,{children:"fix: copy stream tooltip and hide section when no params setting @urmauur (#1373)"}),"\n",(0,l.jsx)(n.li,{children:"bugs: fix stop streaming when user delete or clean thread @urmauur (#1347)"}),"\n",(0,l.jsx)(n.li,{children:"fix: show a proper error message on download failure @louis-jan (#1345)"}),"\n",(0,l.jsx)(n.li,{children:"Add detect cuda version jan app @hiento09 (#1351)"}),"\n",(0,l.jsx)(n.li,{children:'fix: Error occurred: Unexpected token "d", "data: ..." is not a valid JSON @louis-jan (#1332)'}),"\n",(0,l.jsx)(n.li,{children:"fix: app getting stuck at downloading 99% while downloading model @louis-jan (#1320)"}),"\n",(0,l.jsx)(n.li,{children:"correct type utf-8 @hiento09 (#1311)"}),"\n",(0,l.jsx)(n.li,{children:"Fix memory on mac included cached and swap @hiento09 (#1298)"}),"\n",(0,l.jsx)(n.li,{children:"fix: should check app dir before spawning log @louis-jan (#1297)"}),"\n",(0,l.jsx)(n.li,{children:"fix: disable process logging from server @louis-jan (#1296)"}),"\n",(0,l.jsx)(n.li,{children:"fix: user should be able to access Swagger docs from localhost:1337 @louis-jan (#1292)"}),"\n",(0,l.jsx)(n.li,{children:"Switch from Gigabyte to Gibibyte - System monitor @hiento09 (#1286)"}),"\n",(0,l.jsx)(n.li,{children:"Switch from systeminformation to os-utils to resolve Bitdefender false positive and memory leak issue @hiento09 (#1282)"}),"\n",(0,l.jsx)(n.li,{children:"fix: swagger CSP issue @louis-jan (#1284)"}),"\n",(0,l.jsx)(n.li,{children:"fix: support markdown break line @urmauur (#1274)"}),"\n",(0,l.jsx)(n.li,{children:"fix ci test run failed @hiento09 (#1267)"}),"\n",(0,l.jsx)(n.li,{children:"Fix wrong linux nitro path @hiento09 (#1266)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable command enter on dialog confirmation clean thread @urmauur (#1261)"}),"\n",(0,l.jsx)(n.li,{children:"fix: input message duplicated due with some input sources @louis-jan (#1259)"}),"\n",(0,l.jsx)(n.li,{children:"fix: mac users should not see GPU settings @louis-jan (#1255)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove redundant gpu detection prompt event @louis-jan (#1254)"}),"\n",(0,l.jsx)(n.li,{children:"fix: engine settings GUI - feature toggle @louis-jan (#1252)"}),"\n",(0,l.jsx)(n.li,{children:"Fix bug #1178 high ram on windows @hiento09 (#1241)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1183 Reveal in finder does not work on windows @namchuai (#1239)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove delay tooltip and click event @urmauur (#1217)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable enter command on dialog confirmation delete thread @urmauur (#1218)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Cleared thread last message is not updated @louis-jan (#1225)"}),"\n",(0,l.jsx)(n.li,{children:"Fix switch thread crash nitro windows linux @hiento09 (#1214)"}),"\n",(0,l.jsx)(n.li,{children:"fix: darkmode broken color @urmauur (#1186)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: typo model.json @louis-jan (#1599)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add 04-how-to-get-error-logs.mdx @hieu-jan (#1580)"}),"\n",(0,l.jsx)(n.li,{children:"chore: teach how to attach logs @0xSage (#1578)"}),"\n",(0,l.jsx)(n.li,{children:"chore: issues should auto close with PRs through template @0xSage (#1577)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update issue templates @0xSage (#1568)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix x handles @0xSage (#1532)"}),"\n",(0,l.jsx)(n.li,{children:"Docs to integrate OpenRouter with Jan without UI/UX @0xgokuz (#1495)"}),"\n",(0,l.jsx)(n.li,{children:"chore: fix darkmode docs @hieu-jan (#1520)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix algolia configuration @hieu-jan (#1518)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix algolia configuration @hieu-jan (#1517)"}),"\n",(0,l.jsx)(n.li,{children:"Revert URL release in readme to version 0.4.3 @hiento09 (#1502)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: add app and nitro log - resolve dependencies issue @louis-jan (#1447)"}),"\n",(0,l.jsx)(n.li,{children:"chore: enable agolia @hieu-jan (#1497)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update troubleshooting and redirects old pages @hieu-jan (#1492)"}),"\n",(0,l.jsx)(n.li,{children:"docs: minor fix @hieu-jan (#1478)"}),"\n",(0,l.jsx)(n.li,{children:"docs: initial handbook structure @hieu-jan (#1477)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro to 0.2.8 and change Jan App to support cuda >= 11.7 @hiento09 (#1476)"}),"\n",(0,l.jsx)(n.li,{children:"Chore update docs jan - add AppImage instruction to docusaurus @hiento09 (#1480)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro to 0.2.7 @hiento09 (#1474)"}),"\n",(0,l.jsx)(n.li,{children:"chore: error message update @louis-jan (#1473)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 02-import-manually.mdx @0xSage (#1469)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update about.md @0xSage (#1465)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro version to 0.2.6 @hiento09 (#1458)"}),"\n",(0,l.jsx)(n.li,{children:"docs: adding customize engine settings @hieu-jan (#1455)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add-missing-path @hieu-jan (#1454)"}),"\n",(0,l.jsx)(n.li,{children:"docs: resize gif @hieu-jan (#1453)"}),"\n",(0,l.jsx)(n.li,{children:"docs: revenue philosophy @0xSage (#1443)"}),"\n",(0,l.jsx)(n.li,{children:"docs: jan framework principles @0xSage (#1438)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix typo in docs @hieu-jan (#1419)"}),"\n",(0,l.jsx)(n.li,{children:"chore: clean up use os hook @namchuai (#1418)"}),"\n",(0,l.jsx)(n.li,{children:"docs: explain each docs page intent @0xSage (#1417)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 01-server.md @0xSage (#1416)"}),"\n",(0,l.jsx)(n.li,{children:"Update warning url from github md file to jan.ai docs site @hiento09 (#1414)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve gpu not used guide @hieu-jan (#1405)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update README.md @eltociear (#1406)"}),"\n",(0,l.jsx)(n.li,{children:"Update USAGE docs for linux @hiento09 (#1401)"}),"\n",(0,l.jsx)(n.li,{children:"docs: gpu not detected @0xSage (#1399)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Troubleshoot Failed To Fetch @gabrielle-ong (#1398)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve docs syntax @hieu-jan (#1394)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add-install-nightly-guide @hieu-jan (#1390)"}),"\n",(0,l.jsx)(n.li,{children:"docs: correct href link @hieu-jan (#1338)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix chat payload and cURL @hieu-jan (#1360)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add Chatting Guide @hieu-jan (#1184)"}),"\n",(0,l.jsx)(n.li,{children:"Chore add docs usage how to switch run mode jan app @hiento09 (#1353)"}),"\n",(0,l.jsx)(n.li,{children:"docs: configure index page @hieu-jan (#1330)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update product.md @0xSage (#1326)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 01-server.md @0xSage (#1327)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: deprecate the appVersion IPC and use the predefined VERSION @louis-jan (#1309)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update using models documentation @hieu-jan (#1288)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update pm handbook @0xSage (#1307)"}),"\n",(0,l.jsx)(n.li,{children:"docs: contributor docs overview @0xSage (#1305)"}),"\n",(0,l.jsx)(n.li,{children:"chore: github PR template @0xSage (#1304)"}),"\n",(0,l.jsx)(n.li,{children:"Fix memory on mac included cached and swap @hiento09 (#1298)"}),"\n",(0,l.jsx)(n.li,{children:"Enrich discord message for nightly build url @hiento09 (#1294)"}),"\n",(0,l.jsx)(n.li,{children:"Refactor CI by create shared jobs output @hiento09 (#1287)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update README.md @hieu-jan (#1281)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update README.md @0xSage (#1248)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Jan Server, API and decoupled clients @louis-jan (#948)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve 02-import-manually @hieu-jan (#1222)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update issue templates @0xSage (#1229)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 02-import-manually.mdx @0xSage (#1197)"}),"\n",(0,l.jsx)(n.li,{children:"add sleep 500ms if platform is windows before starting nitro process @hiento09 (#1215)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve troubleshoot documentation @hieu-jan (#1173)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update bug report template @hieu-jan (#1180)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add troubleshooting @hieu-jan (#1169)"}),"\n",(0,l.jsx)(n.li,{children:"chore: copy fixes @0xSage (#1167)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 01-start-thread.md @0xSage (#1122)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @0xgokuz, @Diane0111, @Gri-ffin, @Ssstars, @akaMrNagar, @eltociear, @gabrielle-ong, @hahuyhoang411, @hiento09, @hieu-jan, @jan-service-account, @louis-jan, @mishrababhishek, @namchuai, @sr-albert, @urmauur and Abhishek Mishra"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>o});var l=i(96540);const a={},s=l.createContext(a);function r(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2c3f1425.7dc0a3a1.js b/assets/js/2c3f1425.7dc0a3a1.js deleted file mode 100644 index 60a2ff34..00000000 --- a/assets/js/2c3f1425.7dc0a3a1.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8965],{475:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>r,default:()=>h,frontMatter:()=>s,metadata:()=>o,toc:()=>t});var l=i(74848),a=i(28453);const s={sidebar_position:6,slug:"/changelog/changelog-v0.4.4"},r="v0.4.4",o={id:"releases/changelog/changelog-v0.4.4",title:"v0.4.4",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.4.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.4",permalink:"/changelog/changelog-v0.4.4",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.4.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:6,frontMatter:{sidebar_position:6,slug:"/changelog/changelog-v0.4.4"},sidebar:"releasesSidebar",previous:{title:"v0.4.5",permalink:"/changelog/changelog-v0.4.5"},next:{title:"v0.4.3",permalink:"/changelog/changelog-v0.4.3"}},d={},t=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v044",children:"v0.4.4"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.4",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1587",children:"Issue #1587: Update 2023-11-05-hello-world.md"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Update 2023-11-05-hello-world.md @Ssstars (#1587)"}),"\n",(0,l.jsx)(n.li,{children:"fix(API): #1511 update swagger page @namchuai (#1572)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Thread): #1212 thread.json not created when user change thread settings @namchuai (#1570)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Thread): #1336 not allow creating too many unfinished thread @namchuai (#1538)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-to-get-involved-and-FAQ.mdx @Ssstars (#1555)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-to-get-involved-and-FAQ.mdx @Ssstars (#1553)"}),"\n",(0,l.jsx)(n.li,{children:"Update 02-embracing-pod-structure.mdx @Ssstars (#1550)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-we-hire.mdx @Ssstars (#1551)"}),"\n",(0,l.jsx)(n.li,{children:"Update 01-how-we-hire.mdx @Ssstars (#1524)"}),"\n",(0,l.jsx)(n.li,{children:"fix(InferenceExtension): #1067 sync the nitro process state @namchuai (#1493)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Messages): #1434 create message via api does not display on app correctly @namchuai (#1479)"}),"\n",(0,l.jsx)(n.li,{children:"Docs for the Integration of Continue and Jan in VSCode @0xgokuz (#1467)"}),"\n",(0,l.jsx)(n.li,{children:"Chore: Update model.json for UI @hahuyhoang411 (#1448)"}),"\n",(0,l.jsx)(n.li,{children:"Docs for Installing Models from Hub @0xgokuz (#1450)"}),"\n",(0,l.jsx)(n.li,{children:"Update about.md @Ssstars (#1436)"}),"\n",(0,l.jsx)(n.li,{children:"feat(UI): #1404 make left side bar collapsible by hot key @namchuai (#1420)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Typo in 06-hardware.md @akaMrNagar (#1408)"}),"\n",(0,l.jsx)(n.li,{children:"fix(API): #1409 fix wrong prefix for threads api @namchuai (#1410)"}),"\n",(0,l.jsx)(n.li,{children:"Update model hub @hahuyhoang411 (#1383)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Model): remove unsupported default model setting params @namchuai (#1382)"}),"\n",(0,l.jsx)(n.li,{children:"fix(trinity): update cover path for trinity v1.2 @hahuyhoang411 (#1380)"}),"\n",(0,l.jsx)(n.li,{children:"Chore/update model hub @hahuyhoang411 (#1342)"}),"\n",(0,l.jsx)(n.li,{children:"Update about.md @Ssstars (#1359)"}),"\n",(0,l.jsx)(n.li,{children:"fix(JanHub): #1158 sort model list @namchuai (#1257)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Message): open link with external browser @namchuai (#1339)"}),"\n",(0,l.jsx)(n.li,{children:"feat(Model): #1028 made model.json optional @namchuai (#1314)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update onboarding.md @Diane0111 (#1293)"}),"\n",(0,l.jsx)(n.li,{children:"fix: clean resource on exit @louis-jan (#1290)"}),"\n",(0,l.jsx)(n.li,{children:"fix: posthog configuration @hieu-jan (#1283)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update README.md @eltociear (#1277)"}),"\n",(0,l.jsx)(n.li,{children:"Enable scrolling in the message chat box @Gri-ffin (#1280)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update README.md @sr-albert (#1263)"}),"\n",(0,l.jsx)(n.li,{children:"Adding new model to the Hub @hahuyhoang411 (#1213)"}),"\n",(0,l.jsx)(n.li,{children:"Feature GPU detection for Jan on Windows and Linux @hiento09 (#1242)"}),"\n",(0,l.jsx)(n.li,{children:"fix(Thread): #1168 fix newly created thread cannot select model after restart @namchuai (#1176)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: add compatibility tag to model selection in right panel @urmauur (#1552)"}),"\n",(0,l.jsx)(n.li,{children:"Feature integrate antivirus scanner to ci @hiento09 (#1529)"}),"\n",(0,l.jsx)(n.li,{children:"feat: [hub] update compatibility tags colors @urmauur (#1516)"}),"\n",(0,l.jsx)(n.li,{children:"feat: hub recommendation labels @urmauur (#1440)"}),"\n",(0,l.jsx)(n.li,{children:"Feature linux support app image format @hiento09 (#1442)"}),"\n",(0,l.jsx)(n.li,{children:"fix: render external links @urmauur (#1441)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add icon collapsible left panel and update keyboard shortcut page @urmauur (#1439)"}),"\n",(0,l.jsx)(n.li,{children:"feat(UI): update UI footer @urmauur (#1424)"}),"\n",(0,l.jsx)(n.li,{children:"Fix Bug for Chat Reply Goes off Screen @mishrababhishek (#1393)"}),"\n",(0,l.jsx)(n.li,{children:"feat: move social media from left panel into footer @urmauur (#1325)"}),"\n",(0,l.jsx)(n.li,{children:"feat: implementation new UI thread settings @urmauur (#1301)"}),"\n",(0,l.jsx)(n.li,{children:"Bring social media links @Gri-ffin (#1295)"}),"\n",(0,l.jsx)(n.li,{children:"feat: added keyboard shortcut list in setting page @urmauur (#1275)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add swagger /docs to localhost:1337 @louis-jan (#1268)"}),"\n",(0,l.jsx)(n.li,{children:"feat: update posthog configuration @hieu-jan (#1258)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Deprecate model.json ready state in favor of .download ext @louis-jan (#1238)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add engine settings @namchuai (#1199)"}),"\n",(0,l.jsx)(n.li,{children:"feat: users should be able to switch models mid-thread @louis-jan (#1226)"}),"\n",(0,l.jsx)(n.li,{children:"feat: temporary link how to import model @urmauur (#1209)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: #1594 - Model settings - change thread model - go back does not see according settings @louis-jan (#1595)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1548 - duplicate command shortcut instruction @louis-jan (#1600)"}),"\n",(0,l.jsx)(n.li,{children:"fix: switch model caused app crash @louis-jan (#1597)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1559 Inference Parameters displayed on new thread with Openai GPT Model @louis-jan (#1588)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable user set value manually model setting from input @urmauur (#1585)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1569 - Does not apply thread settings when loading model @louis-jan (#1576)"}),"\n",(0,l.jsx)(n.li,{children:"fix: could not change model params settings @louis-jan (#1547)"}),"\n",(0,l.jsx)(n.li,{children:"fix: gpu check module export does not work in extension @louis-jan (#1536)"}),"\n",(0,l.jsx)(n.li,{children:"fix: adjust calculation hub labels using total RAM instead remaining RAM @urmauur (#1522)"}),"\n",(0,l.jsx)(n.li,{children:"Feature integrate antivirus scanner to ci @hiento09 (#1529)"}),"\n",(0,l.jsx)(n.li,{children:"fix: allow users to set max tokens variably @urmauur (#1513)"}),"\n",(0,l.jsx)(n.li,{children:"fix: stop word update @louis-jan (#1457)"}),"\n",(0,l.jsx)(n.li,{children:"Revert nitro to 0.2.6 @hiento09 (#1491)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable text selection codeblock @urmauur (#1466)"}),"\n",(0,l.jsx)(n.li,{children:"fix: suppress all main node JS error message dialog @louis-jan (#1460)"}),"\n",(0,l.jsx)(n.li,{children:"Correct AppImage path @hiento09 (#1446)"}),"\n",(0,l.jsx)(n.li,{children:"fix: render external links @urmauur (#1441)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add icon collapsible left panel and update keyboard shortcut page @urmauur (#1439)"}),"\n",(0,l.jsx)(n.li,{children:"fix: GET /models does not work due to new default model dir @louis-jan (#1392)"}),"\n",(0,l.jsx)(n.li,{children:"fix: model migration stopped working @louis-jan (#1378)"}),"\n",(0,l.jsx)(n.li,{children:"fix: wrong condition for displaying error message @louis-jan (#1376)"}),"\n",(0,l.jsx)(n.li,{children:"fix: show hide section engine params @urmauur (#1374)"}),"\n",(0,l.jsx)(n.li,{children:"fix: copy stream tooltip and hide section when no params setting @urmauur (#1373)"}),"\n",(0,l.jsx)(n.li,{children:"bugs: fix stop streaming when user delete or clean thread @urmauur (#1347)"}),"\n",(0,l.jsx)(n.li,{children:"fix: show a proper error message on download failure @louis-jan (#1345)"}),"\n",(0,l.jsx)(n.li,{children:"Add detect cuda version jan app @hiento09 (#1351)"}),"\n",(0,l.jsx)(n.li,{children:'fix: Error occurred: Unexpected token "d", "data: ..." is not a valid JSON @louis-jan (#1332)'}),"\n",(0,l.jsx)(n.li,{children:"fix: app getting stuck at downloading 99% while downloading model @louis-jan (#1320)"}),"\n",(0,l.jsx)(n.li,{children:"correct type utf-8 @hiento09 (#1311)"}),"\n",(0,l.jsx)(n.li,{children:"Fix memory on mac included cached and swap @hiento09 (#1298)"}),"\n",(0,l.jsx)(n.li,{children:"fix: should check app dir before spawning log @louis-jan (#1297)"}),"\n",(0,l.jsx)(n.li,{children:"fix: disable process logging from server @louis-jan (#1296)"}),"\n",(0,l.jsx)(n.li,{children:"fix: user should be able to access Swagger docs from localhost:1337 @louis-jan (#1292)"}),"\n",(0,l.jsx)(n.li,{children:"Switch from Gigabyte to Gibibyte - System monitor @hiento09 (#1286)"}),"\n",(0,l.jsx)(n.li,{children:"Switch from systeminformation to os-utils to resolve Bitdefender false positive and memory leak issue @hiento09 (#1282)"}),"\n",(0,l.jsx)(n.li,{children:"fix: swagger CSP issue @louis-jan (#1284)"}),"\n",(0,l.jsx)(n.li,{children:"fix: support markdown break line @urmauur (#1274)"}),"\n",(0,l.jsx)(n.li,{children:"fix ci test run failed @hiento09 (#1267)"}),"\n",(0,l.jsx)(n.li,{children:"Fix wrong linux nitro path @hiento09 (#1266)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable command enter on dialog confirmation clean thread @urmauur (#1261)"}),"\n",(0,l.jsx)(n.li,{children:"fix: input message duplicated due with some input sources @louis-jan (#1259)"}),"\n",(0,l.jsx)(n.li,{children:"fix: mac users should not see GPU settings @louis-jan (#1255)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove redundant gpu detection prompt event @louis-jan (#1254)"}),"\n",(0,l.jsx)(n.li,{children:"fix: engine settings GUI - feature toggle @louis-jan (#1252)"}),"\n",(0,l.jsx)(n.li,{children:"Fix bug #1178 high ram on windows @hiento09 (#1241)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #1183 Reveal in finder does not work on windows @namchuai (#1239)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove delay tooltip and click event @urmauur (#1217)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable enter command on dialog confirmation delete thread @urmauur (#1218)"}),"\n",(0,l.jsx)(n.li,{children:"fix: Cleared thread last message is not updated @louis-jan (#1225)"}),"\n",(0,l.jsx)(n.li,{children:"Fix switch thread crash nitro windows linux @hiento09 (#1214)"}),"\n",(0,l.jsx)(n.li,{children:"fix: darkmode broken color @urmauur (#1186)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: typo model.json @louis-jan (#1599)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add 04-how-to-get-error-logs.mdx @hieu-jan (#1580)"}),"\n",(0,l.jsx)(n.li,{children:"chore: teach how to attach logs @0xSage (#1578)"}),"\n",(0,l.jsx)(n.li,{children:"chore: issues should auto close with PRs through template @0xSage (#1577)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update issue templates @0xSage (#1568)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix x handles @0xSage (#1532)"}),"\n",(0,l.jsx)(n.li,{children:"Docs to integrate OpenRouter with Jan without UI/UX @0xgokuz (#1495)"}),"\n",(0,l.jsx)(n.li,{children:"chore: fix darkmode docs @hieu-jan (#1520)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix algolia configuration @hieu-jan (#1518)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix algolia configuration @hieu-jan (#1517)"}),"\n",(0,l.jsx)(n.li,{children:"Revert URL release in readme to version 0.4.3 @hiento09 (#1502)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: add app and nitro log - resolve dependencies issue @louis-jan (#1447)"}),"\n",(0,l.jsx)(n.li,{children:"chore: enable agolia @hieu-jan (#1497)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update troubleshooting and redirects old pages @hieu-jan (#1492)"}),"\n",(0,l.jsx)(n.li,{children:"docs: minor fix @hieu-jan (#1478)"}),"\n",(0,l.jsx)(n.li,{children:"docs: initial handbook structure @hieu-jan (#1477)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro to 0.2.8 and change Jan App to support cuda >= 11.7 @hiento09 (#1476)"}),"\n",(0,l.jsx)(n.li,{children:"Chore update docs jan - add AppImage instruction to docusaurus @hiento09 (#1480)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro to 0.2.7 @hiento09 (#1474)"}),"\n",(0,l.jsx)(n.li,{children:"chore: error message update @louis-jan (#1473)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 02-import-manually.mdx @0xSage (#1469)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update about.md @0xSage (#1465)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro version to 0.2.6 @hiento09 (#1458)"}),"\n",(0,l.jsx)(n.li,{children:"docs: adding customize engine settings @hieu-jan (#1455)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add-missing-path @hieu-jan (#1454)"}),"\n",(0,l.jsx)(n.li,{children:"docs: resize gif @hieu-jan (#1453)"}),"\n",(0,l.jsx)(n.li,{children:"docs: revenue philosophy @0xSage (#1443)"}),"\n",(0,l.jsx)(n.li,{children:"docs: jan framework principles @0xSage (#1438)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix typo in docs @hieu-jan (#1419)"}),"\n",(0,l.jsx)(n.li,{children:"chore: clean up use os hook @namchuai (#1418)"}),"\n",(0,l.jsx)(n.li,{children:"docs: explain each docs page intent @0xSage (#1417)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 01-server.md @0xSage (#1416)"}),"\n",(0,l.jsx)(n.li,{children:"Update warning url from github md file to jan.ai docs site @hiento09 (#1414)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve gpu not used guide @hieu-jan (#1405)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update README.md @eltociear (#1406)"}),"\n",(0,l.jsx)(n.li,{children:"Update USAGE docs for linux @hiento09 (#1401)"}),"\n",(0,l.jsx)(n.li,{children:"docs: gpu not detected @0xSage (#1399)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Troubleshoot Failed To Fetch @gabrielle-ong (#1398)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve docs syntax @hieu-jan (#1394)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add-install-nightly-guide @hieu-jan (#1390)"}),"\n",(0,l.jsx)(n.li,{children:"docs: correct href link @hieu-jan (#1338)"}),"\n",(0,l.jsx)(n.li,{children:"docs: fix chat payload and cURL @hieu-jan (#1360)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add Chatting Guide @hieu-jan (#1184)"}),"\n",(0,l.jsx)(n.li,{children:"Chore add docs usage how to switch run mode jan app @hiento09 (#1353)"}),"\n",(0,l.jsx)(n.li,{children:"docs: configure index page @hieu-jan (#1330)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update product.md @0xSage (#1326)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 01-server.md @0xSage (#1327)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: deprecate the appVersion IPC and use the predefined VERSION @louis-jan (#1309)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update using models documentation @hieu-jan (#1288)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update pm handbook @0xSage (#1307)"}),"\n",(0,l.jsx)(n.li,{children:"docs: contributor docs overview @0xSage (#1305)"}),"\n",(0,l.jsx)(n.li,{children:"chore: github PR template @0xSage (#1304)"}),"\n",(0,l.jsx)(n.li,{children:"Fix memory on mac included cached and swap @hiento09 (#1298)"}),"\n",(0,l.jsx)(n.li,{children:"Enrich discord message for nightly build url @hiento09 (#1294)"}),"\n",(0,l.jsx)(n.li,{children:"Refactor CI by create shared jobs output @hiento09 (#1287)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update README.md @hieu-jan (#1281)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update README.md @0xSage (#1248)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Jan Server, API and decoupled clients @louis-jan (#948)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve 02-import-manually @hieu-jan (#1222)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update issue templates @0xSage (#1229)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 02-import-manually.mdx @0xSage (#1197)"}),"\n",(0,l.jsx)(n.li,{children:"add sleep 500ms if platform is windows before starting nitro process @hiento09 (#1215)"}),"\n",(0,l.jsx)(n.li,{children:"docs: improve troubleshoot documentation @hieu-jan (#1173)"}),"\n",(0,l.jsx)(n.li,{children:"docs: update bug report template @hieu-jan (#1180)"}),"\n",(0,l.jsx)(n.li,{children:"docs: add troubleshooting @hieu-jan (#1169)"}),"\n",(0,l.jsx)(n.li,{children:"chore: copy fixes @0xSage (#1167)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Update 01-start-thread.md @0xSage (#1122)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @0xgokuz, @Diane0111, @Gri-ffin, @Ssstars, @akaMrNagar, @eltociear, @gabrielle-ong, @hahuyhoang411, @hiento09, @hieu-jan, @jan-service-account, @louis-jan, @mishrababhishek, @namchuai, @sr-albert, @urmauur and Abhishek Mishra"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>o});var l=i(96540);const a={},s=l.createContext(a);function r(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2c9d0a4b.9f7632d7.js b/assets/js/2c9d0a4b.9f7632d7.js new file mode 100644 index 00000000..d6ffccbf --- /dev/null +++ b/assets/js/2c9d0a4b.9f7632d7.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6258],{83986:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>h,contentTitle:()=>s,default:()=>d,frontMatter:()=>o,metadata:()=>r,toc:()=>l});var t=i(74848),a=i(28453);const o={title:"Jan's Vision",slug:"/vision",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model","about Jan","desktop application","thinking machine","jan vision"]},s=void 0,r={id:"about/vision",title:"Jan's Vision",description:"Jan is a desktop application that turns computers into thinking machines.",source:"@site/docs/about/vision.md",sourceDirName:"about",slug:"/vision",permalink:"/vision",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/vision.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan's Vision",slug:"/vision",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model","about Jan","desktop application","thinking machine","jan vision"]}},h={},l=[{value:"Jan's vision is to shape a future where humans and machines collaborate, continuing our legacy as toolmakers",id:"jans-vision-is-to-shape-a-future-where-humans-and-machines-collaborate-continuing-our-legacy-as-toolmakers",level:2},{value:"Inspired by Science Fiction, Grounded in Optimism",id:"inspired-by-science-fiction-grounded-in-optimism",level:3},{value:"Jan's Role in Shaping the Future",id:"jans-role-in-shaping-the-future",level:3},{value:"How we imagine the world in the future",id:"how-we-imagine-the-world-in-the-future",level:2},{value:"A Day in the Life of Emre in 2050",id:"a-day-in-the-life-of-emre-in-2050",level:2}];function c(e){const n={a:"a",blockquote:"blockquote",h2:"h2",h3:"h3",hr:"hr",img:"img",p:"p",strong:"strong",...(0,a.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"jans-vision-is-to-shape-a-future-where-humans-and-machines-collaborate-continuing-our-legacy-as-toolmakers",children:"Jan's vision is to shape a future where humans and machines collaborate, continuing our legacy as toolmakers"}),"\n",(0,t.jsxs)(n.p,{children:["Throughout history, humanity has thrived by mastering tools, from ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Control_of_fire_by_early_humans",children:"controlling fire"})," to ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Wheel",children:"inventing the wheel"}),". These leaps weren't just about survival, they were foundational to our civilization."]}),"\n",(0,t.jsx)(n.p,{children:"Today, we stand on the brink of a new frontier with artificial intelligence. AI is not merely another tool, it represents a new form of collaboration between humans and machines - promising to enhance our creativity, augment our lives, and deepen our understanding of the world."}),"\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.img,{alt:"jan ai shapes the future",src:i(18009).A+"",width:"1280",height:"720"})}),"\n",(0,t.jsx)(n.p,{children:"In the future we envision, AI will be as integral to our lives as fire and the wheel once were, with each individual having their own machines/robots. Mastering AI, like mastering fire, will require understanding its potential, respecting its power, and learning to control it for the betterment of humanity."}),"\n",(0,t.jsx)(n.h3,{id:"inspired-by-science-fiction-grounded-in-optimism",children:"Inspired by Science Fiction, Grounded in Optimism"}),"\n",(0,t.jsxs)(n.p,{children:["Our vision is influenced by the harmonious coexistence of humans and machines in science fiction. From the helpful companionship of ",(0,t.jsx)(n.a,{href:"https://tr.wikipedia.org/wiki/C-3PO",children:"C3PO"})," and ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/J.A.R.V.I.S.",children:"Jarvis"})," to the strategic alliances in ",(0,t.jsx)(n.a,{href:"https://www.imdb.com/title/tt2934286/",children:"Halo"}),", these stories showcase a future where technology amplifies human potential."]}),"\n",(0,t.jsx)(n.h3,{id:"jans-role-in-shaping-the-future",children:"Jan's Role in Shaping the Future"}),"\n",(0,t.jsx)(n.p,{children:"Jan is our contribution to this future - a tool designed to augment human capabilities, not replace them. We are committed to developing AI that works for humanity, enhancing our creativity, productivity, and well-being. With Jan, we aim to empower individuals and communities to achieve more, together."}),"\n",(0,t.jsx)(n.p,{children:"Our vision is not just a dream, it's a blueprint for a future where technology and humanity harmonize to unlock unprecedented possibilities."}),"\n",(0,t.jsx)(n.h2,{id:"how-we-imagine-the-world-in-the-future",children:"How we imagine the world in the future"}),"\n",(0,t.jsxs)(n.p,{children:["We are fundamentally optimistic about the future. Jan aligns with the ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Solarpunk",children:"Solarpunk movement"}),", which envisions a world where technology and nature coexist and flourish together. We reject the notion of climate doomerism and instead, focus on the positive impact we can make with AI."]}),"\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.img,{alt:"solarpunk and jan",src:i(74543).A+"",width:"1228",height:"906"})}),"\n",(0,t.jsx)(n.p,{children:"Imagine a world where every individual is empowered by their own robots, where machines are not just tools but partners in our journey. This is the future Jan is striving to create."}),"\n",(0,t.jsx)(n.p,{children:"Now, let's take a glimpse into this future through a day in the life of Emre, a reflection of how Jan's vision manifests in everyday life."}),"\n",(0,t.jsx)(n.h2,{id:"a-day-in-the-life-of-emre-in-2050",children:"A Day in the Life of Emre in 2050"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsxs)(n.p,{children:["In 2050, Emre wakes up to the gentle sound of birds chirping, a soothing alarm created by ",(0,t.jsx)(n.strong,{children:"his own AI robot, Jan"}),". As he gets ready for the day, ",(0,t.jsx)(n.strong,{children:"Jan has already prepared"})," his schedule, factoring in his preferences and the day's weather."]}),"\n",(0,t.jsxs)(n.p,{children:["At breakfast, Emre discusses his upcoming project with ",(0,t.jsx)(n.strong,{children:"Jan, who offers insights and suggestions"}),", enhancing Emre's creativity. As he heads to work, his self-driving car, ",(0,t.jsx)(n.strong,{children:"integrated with Jan"}),", takes the most scenic and efficient route, allowing Emre to enjoy a moment of tranquility."]}),"\n",(0,t.jsxs)(n.p,{children:["In the office, Emre collaborates with colleagues from around the globe in a virtual workspace. ",(0,t.jsx)(n.strong,{children:"Jan assists"})," by translating languages in real-time and organizing ideas, making collaboration seamless and productive."]}),"\n",(0,t.jsxs)(n.p,{children:["During lunch, Emre decides to explore a new hobby. ",(0,t.jsx)(n.strong,{children:"Jan quickly curates"})," a list of resources and connects Emre with a virtual mentor, making learning accessible and enjoyable."]}),"\n",(0,t.jsxs)(n.p,{children:["In the afternoon, Emre takes a break to connect with nature. His smart garden, ",(0,t.jsx)(n.strong,{children:"managed by Jan"}),", is thriving, blending technology with the natural world in perfect harmony."]}),"\n",(0,t.jsxs)(n.p,{children:["As the day winds down, Emre reflects on his accomplishments. ",(0,t.jsx)(n.strong,{children:"With Jan's help"}),", he's been able to focus on what truly matters, achieving a balance between work, personal growth, and well-being."]}),"\n",(0,t.jsxs)(n.p,{children:["In 2050, Jan is more than just a tool, it's an integral part of Emre's life, ",(0,t.jsx)(n.strong,{children:"augmenting his abilities"})," and enabling him to live a more fulfilling life."]}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"What a day, hah!"}),"\n",(0,t.jsx)(n.hr,{}),"\n",(0,t.jsx)(n.p,{children:"Jan's vision commits to developing thinking machines that work alongside humans - learning, adapting, and contributing to a broader, smarter society. This journey isn't just about technology. It's about creating a future where humans and machines collaborate."}),"\n",(0,t.jsx)(n.p,{children:"Let's build the future together - join the journey!"})]})}function d(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},74543:(e,n,i)=>{i.d(n,{A:()=>t});const t=i.p+"assets/images/solar-punk-ae041e735df021ac9ce8d29019deb9ed.webp"},18009:(e,n,i)=>{i.d(n,{A:()=>t});const t=i.p+"assets/images/vision-1-8f3b584333940bb52f0588debd26dcf6.webp"},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>r});var t=i(96540);const a={},o=t.createContext(a);function s(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2c9d0a4b.a495c231.js b/assets/js/2c9d0a4b.a495c231.js deleted file mode 100644 index 15366511..00000000 --- a/assets/js/2c9d0a4b.a495c231.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6258],{83986:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>h,contentTitle:()=>s,default:()=>d,frontMatter:()=>o,metadata:()=>r,toc:()=>l});var t=i(74848),a=i(28453);const o={title:"Jan's Vision",slug:"/vision",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model","about Jan","desktop application","thinking machine","jan vision"]},s=void 0,r={id:"about/vision",title:"Jan's Vision",description:"Jan is a desktop application that turns computers into thinking machines.",source:"@site/docs/about/vision.md",sourceDirName:"about",slug:"/vision",permalink:"/vision",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/vision.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan's Vision",slug:"/vision",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model","about Jan","desktop application","thinking machine","jan vision"]}},h={},l=[{value:"Jan's vision is to shape a future where humans and machines collaborate, continuing our legacy as toolmakers",id:"jans-vision-is-to-shape-a-future-where-humans-and-machines-collaborate-continuing-our-legacy-as-toolmakers",level:2},{value:"Inspired by Science Fiction, Grounded in Optimism",id:"inspired-by-science-fiction-grounded-in-optimism",level:3},{value:"Jan's Role in Shaping the Future",id:"jans-role-in-shaping-the-future",level:3},{value:"How we imagine the world in the future",id:"how-we-imagine-the-world-in-the-future",level:2},{value:"A Day in the Life of Emre in 2050",id:"a-day-in-the-life-of-emre-in-2050",level:2}];function c(e){const n={a:"a",blockquote:"blockquote",h2:"h2",h3:"h3",hr:"hr",img:"img",p:"p",strong:"strong",...(0,a.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"jans-vision-is-to-shape-a-future-where-humans-and-machines-collaborate-continuing-our-legacy-as-toolmakers",children:"Jan's vision is to shape a future where humans and machines collaborate, continuing our legacy as toolmakers"}),"\n",(0,t.jsxs)(n.p,{children:["Throughout history, humanity has thrived by mastering tools, from ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Control_of_fire_by_early_humans",children:"controlling fire"})," to ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Wheel",children:"inventing the wheel"}),". These leaps weren't just about survival, they were foundational to our civilization."]}),"\n",(0,t.jsx)(n.p,{children:"Today, we stand on the brink of a new frontier with artificial intelligence. AI is not merely another tool, it represents a new form of collaboration between humans and machines - promising to enhance our creativity, augment our lives, and deepen our understanding of the world."}),"\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.img,{alt:"jan ai shapes the future",src:i(18009).A+"",width:"1280",height:"720"})}),"\n",(0,t.jsx)(n.p,{children:"In the future we envision, AI will be as integral to our lives as fire and the wheel once were, with each individual having their own machines/robots. Mastering AI, like mastering fire, will require understanding its potential, respecting its power, and learning to control it for the betterment of humanity."}),"\n",(0,t.jsx)(n.h3,{id:"inspired-by-science-fiction-grounded-in-optimism",children:"Inspired by Science Fiction, Grounded in Optimism"}),"\n",(0,t.jsxs)(n.p,{children:["Our vision is influenced by the harmonious coexistence of humans and machines in science fiction. From the helpful companionship of ",(0,t.jsx)(n.a,{href:"https://tr.wikipedia.org/wiki/C-3PO",children:"C3PO"})," and ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/J.A.R.V.I.S.",children:"Jarvis"})," to the strategic alliances in ",(0,t.jsx)(n.a,{href:"https://www.imdb.com/title/tt2934286/",children:"Halo"}),", these stories showcase a future where technology amplifies human potential."]}),"\n",(0,t.jsx)(n.h3,{id:"jans-role-in-shaping-the-future",children:"Jan's Role in Shaping the Future"}),"\n",(0,t.jsx)(n.p,{children:"Jan is our contribution to this future - a tool designed to augment human capabilities, not replace them. We are committed to developing AI that works for humanity, enhancing our creativity, productivity, and well-being. With Jan, we aim to empower individuals and communities to achieve more, together."}),"\n",(0,t.jsx)(n.p,{children:"Our vision is not just a dream, it's a blueprint for a future where technology and humanity harmonize to unlock unprecedented possibilities."}),"\n",(0,t.jsx)(n.h2,{id:"how-we-imagine-the-world-in-the-future",children:"How we imagine the world in the future"}),"\n",(0,t.jsxs)(n.p,{children:["We are fundamentally optimistic about the future. Jan aligns with the ",(0,t.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Solarpunk",children:"Solarpunk movement"}),", which envisions a world where technology and nature coexist and flourish together. We reject the notion of climate doomerism and instead, focus on the positive impact we can make with AI."]}),"\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.img,{alt:"solarpunk and jan",src:i(74543).A+"",width:"1228",height:"906"})}),"\n",(0,t.jsx)(n.p,{children:"Imagine a world where every individual is empowered by their own robots, where machines are not just tools but partners in our journey. This is the future Jan is striving to create."}),"\n",(0,t.jsx)(n.p,{children:"Now, let's take a glimpse into this future through a day in the life of Emre, a reflection of how Jan's vision manifests in everyday life."}),"\n",(0,t.jsx)(n.h2,{id:"a-day-in-the-life-of-emre-in-2050",children:"A Day in the Life of Emre in 2050"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsxs)(n.p,{children:["In 2050, Emre wakes up to the gentle sound of birds chirping, a soothing alarm created by ",(0,t.jsx)(n.strong,{children:"his own AI robot, Jan"}),". As he gets ready for the day, ",(0,t.jsx)(n.strong,{children:"Jan has already prepared"})," his schedule, factoring in his preferences and the day's weather."]}),"\n",(0,t.jsxs)(n.p,{children:["At breakfast, Emre discusses his upcoming project with ",(0,t.jsx)(n.strong,{children:"Jan, who offers insights and suggestions"}),", enhancing Emre's creativity. As he heads to work, his self-driving car, ",(0,t.jsx)(n.strong,{children:"integrated with Jan"}),", takes the most scenic and efficient route, allowing Emre to enjoy a moment of tranquility."]}),"\n",(0,t.jsxs)(n.p,{children:["In the office, Emre collaborates with colleagues from around the globe in a virtual workspace. ",(0,t.jsx)(n.strong,{children:"Jan assists"})," by translating languages in real-time and organizing ideas, making collaboration seamless and productive."]}),"\n",(0,t.jsxs)(n.p,{children:["During lunch, Emre decides to explore a new hobby. ",(0,t.jsx)(n.strong,{children:"Jan quickly curates"})," a list of resources and connects Emre with a virtual mentor, making learning accessible and enjoyable."]}),"\n",(0,t.jsxs)(n.p,{children:["In the afternoon, Emre takes a break to connect with nature. His smart garden, ",(0,t.jsx)(n.strong,{children:"managed by Jan"}),", is thriving, blending technology with the natural world in perfect harmony."]}),"\n",(0,t.jsxs)(n.p,{children:["As the day winds down, Emre reflects on his accomplishments. ",(0,t.jsx)(n.strong,{children:"With Jan's help"}),", he's been able to focus on what truly matters, achieving a balance between work, personal growth, and well-being."]}),"\n",(0,t.jsxs)(n.p,{children:["In 2050, Jan is more than just a tool, it's an integral part of Emre's life, ",(0,t.jsx)(n.strong,{children:"augmenting his abilities"})," and enabling him to live a more fulfilling life."]}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"What a day, hah!"}),"\n",(0,t.jsx)(n.hr,{}),"\n",(0,t.jsx)(n.p,{children:"Jan's vision commits to developing thinking machines that work alongside humans - learning, adapting, and contributing to a broader, smarter society. This journey isn't just about technology. It's about creating a future where humans and machines collaborate."}),"\n",(0,t.jsx)(n.p,{children:"Let's build the future together - join the journey!"})]})}function d(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},74543:(e,n,i)=>{i.d(n,{A:()=>t});const t=i.p+"assets/images/solar-punk-ae041e735df021ac9ce8d29019deb9ed.webp"},18009:(e,n,i)=>{i.d(n,{A:()=>t});const t=i.p+"assets/images/vision-1-8f3b584333940bb52f0588debd26dcf6.webp"},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>r});var t=i(96540);const a={},o=t.createContext(a);function s(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2f9d99a9.1b7afe31.js b/assets/js/2f9d99a9.1b7afe31.js deleted file mode 100644 index 837be4b5..00000000 --- a/assets/js/2f9d99a9.1b7afe31.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3088],{10320:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var s=t(74848),i=t(28453);const r={title:"Selecting AI Hardware"},o=void 0,a={id:"hardware/recommendations/by-hardware",title:"Selecting AI Hardware",description:"When selecting a GPU for LLMs, remember that it's not just about the GPU itself. Consider the synergy with other components in your PC:",source:"@site/docs/hardware/recommendations/by-hardware.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-hardware",permalink:"/hardware/recommendations/by-hardware",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-hardware.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Selecting AI Hardware"}},l={},d=[{value:"GPU Selection",id:"gpu-selection",level:2},{value:"GPU Comparison",id:"gpu-comparison",level:3},{value:"Other Considerations",id:"other-considerations",level:3},{value:"CPU Selection",id:"cpu-selection",level:2},{value:"Here are some CPU options for running LLMs:",id:"here-are-some-cpu-options-for-running-llms",level:3},{value:"RAM Selection",id:"ram-selection",level:2},{value:"Here is a general guide to RAM selection for running LLMs:",id:"here-is-a-general-guide-to-ram-selection-for-running-llms",level:3},{value:"Motherboard Selection",id:"motherboard-selection",level:2},{value:"Cooling System Selection",id:"cooling-system-selection",level:2},{value:"Use MacBook to run LLMs",id:"use-macbook-to-run-llms",level:2},{value:"Calculating vRAM Requirements for an LLM",id:"calculating-vram-requirements-for-an-llm",level:2}];function c(e){const n={blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.p,{children:"When selecting a GPU for LLMs, remember that it's not just about the GPU itself. Consider the synergy with other components in your PC:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"CPU"}),": To ensure efficient processing, pair your GPU with a powerful CPU. LLMs benefit from fast processors, so having a capable CPU is essential."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"RAM"}),": Sufficient RAM is crucial for LLMs. They can be memory-intensive, and having enough RAM ensures smooth operation."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Cooling System"}),": LLMs can push your PC's hardware to the limit. A robust cooling system helps maintain optimal temperatures, preventing overheating and performance throttling."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"By taking all of these factors into account, you can build a home PC setup that's well-equipped to handle the demands of running LLMs effectively and efficiently."}),"\n",(0,s.jsx)(n.h2,{id:"gpu-selection",children:"GPU Selection"}),"\n",(0,s.jsx)(n.p,{children:"Selecting the optimal GPU for running Large Language Models (LLMs) on your home PC is a decision influenced by your budget and the specific LLMs you intend to work with. Your choice should strike a balance between performance, efficiency, and cost-effectiveness."}),"\n",(0,s.jsx)(n.h3,{id:"gpu-comparison",children:"GPU Comparison"}),"\n",(0,s.jsxs)(n.table,{children:[(0,s.jsx)(n.thead,{children:(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.th,{children:"GPU"}),(0,s.jsx)(n.th,{children:"Price"}),(0,s.jsx)(n.th,{children:"Cores"}),(0,s.jsx)(n.th,{children:"VRAM (GB)"}),(0,s.jsx)(n.th,{children:"Bandwth (T/s)"}),(0,s.jsx)(n.th,{children:"Power"})]})}),(0,s.jsxs)(n.tbody,{children:[(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia H100"}),(0,s.jsx)(n.td,{children:"40000"}),(0,s.jsx)(n.td,{children:"18432"}),(0,s.jsx)(n.td,{children:"80"}),(0,s.jsx)(n.td,{children:"2"}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia A100"}),(0,s.jsx)(n.td,{children:"15000"}),(0,s.jsx)(n.td,{children:"6912"}),(0,s.jsx)(n.td,{children:"80"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia A100"}),(0,s.jsx)(n.td,{children:"7015"}),(0,s.jsx)(n.td,{children:"6912"}),(0,s.jsx)(n.td,{children:"40"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia A10"}),(0,s.jsx)(n.td,{children:"2799"}),(0,s.jsx)(n.td,{children:"9216"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX A6000"}),(0,s.jsx)(n.td,{children:"4100"}),(0,s.jsx)(n.td,{children:"10752"}),(0,s.jsx)(n.td,{children:"48"}),(0,s.jsx)(n.td,{children:"0.768"}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 6000"}),(0,s.jsx)(n.td,{children:"6800"}),(0,s.jsx)(n.td,{children:"4608"}),(0,s.jsx)(n.td,{children:"46"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 4090 Ti"}),(0,s.jsx)(n.td,{children:"2000"}),(0,s.jsx)(n.td,{children:"18176"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 4090"}),(0,s.jsx)(n.td,{children:"1800"}),(0,s.jsx)(n.td,{children:"16384"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{children:"1.008"}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 3090"}),(0,s.jsx)(n.td,{children:"1450"}),(0,s.jsx)(n.td,{children:"10496"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 3080"}),(0,s.jsx)(n.td,{children:"700"}),(0,s.jsx)(n.td,{children:"8704"}),(0,s.jsx)(n.td,{children:"12"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 3070"}),(0,s.jsx)(n.td,{children:"900"}),(0,s.jsx)(n.td,{children:"6144"}),(0,s.jsx)(n.td,{children:"8"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia L4"}),(0,s.jsx)(n.td,{children:"2711"}),(0,s.jsx)(n.td,{children:"7424"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia T4"}),(0,s.jsx)(n.td,{children:"2299"}),(0,s.jsx)(n.td,{children:"2560"}),(0,s.jsx)(n.td,{children:"16"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"AMD Radeon RX 6900 XT"}),(0,s.jsx)(n.td,{children:"1000"}),(0,s.jsx)(n.td,{children:"5120"}),(0,s.jsx)(n.td,{children:"16"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"AMD Radeon RX 6800 XT"}),(0,s.jsx)(n.td,{children:"420"}),(0,s.jsx)(n.td,{children:"4608"}),(0,s.jsx)(n.td,{children:"16"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]})]})]}),"\n",(0,s.jsx)(n.p,{children:"*Market prices as of Oct 2023 via Amazon/PCMag"}),"\n",(0,s.jsx)(n.h3,{id:"other-considerations",children:"Other Considerations"}),"\n",(0,s.jsx)(n.p,{children:"In general, the following GPU features are important for running LLMs:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"High VRAM:"}),"\xa0LLMs are typically very large and complex models, so they require a GPU with a high amount of VRAM. This will allow the model to be loaded into memory and processed efficiently."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"CUDA Compatibility:"})," When running LLMs on a GPU, CUDA compatibility is paramount. CUDA is NVIDIA's parallel computing platform, and it plays a vital role in accelerating deep learning tasks. LLMs, with their extensive matrix calculations, heavily rely on parallel processing. Ensuring your GPU supports CUDA is like having the right tool for the job. It allows the LLM to leverage the GPU's parallel processing capabilities, significantly speeding up model training and inference."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Number of CUDA, Tensor, and RT Cores:"})," High-performance NVIDIA GPUs have both CUDA and Tensor cores. These cores are responsible for executing the neural network computations that underpin LLMs' language understanding and generation. The more CUDA cores your GPU has, the better equipped it is to handle the massive computational load that LLMs impose. Tensor cores in your GPU, further enhance LLM performance by accelerating the critical matrix operations integral to language modeling tasks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Generation (Series)"}),": When selecting a GPU for LLMs, consider its generation or series (e.g., RTX 30 series). Newer GPU generations often come with improved architectures and features. For LLM tasks, opting for the latest generation can mean better performance, energy efficiency, and support for emerging AI technologies. Avoid purchasing, RTX-2000 series GPUs which are much outdated nowadays."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"cpu-selection",children:"CPU Selection"}),"\n",(0,s.jsx)(n.p,{children:"Selecting the right CPU for running Large Language Models (LLMs) on your home PC is contingent on your budget and the specific LLMs you intend to work with. It's a decision that warrants careful consideration, as the CPU plays a pivotal role in determining the overall performance of your system."}),"\n",(0,s.jsx)(n.p,{children:"In general, the following CPU features are important for running LLMs:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Number of Cores and Threads:"}),"\xa0the number of CPU cores and threads influences parallel processing. More cores and threads help handle the complex computations involved in language models. For tasks like training and inference, a higher core/thread count can significantly improve processing speed and efficiency, enabling quicker results."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"High clock speed:"}),"\xa0The base clock speed, or base frequency, represents the CPU's default operating speed. So having a CPU with a high clock speed. This will allow the model to process instructions more quickly, which can further improve performance."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Base Power (TDP):"})," LLMs often involve long training sessions and demanding computations. Therefore, a lower Thermal Design Power (TDP) is desirable. A CPU with a lower TDP consumes less power and generates less heat during prolonged LLM operations. This not only contributes to energy efficiency but also helps maintain stable temperatures in your system, preventing overheating and potential performance throttling."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Generation (Series):"})," Consider its generation or series (e.g., 9th Gen, 11th Gen Intel Core). Newer CPU generations often come with architectural improvements that enhance performance and efficiency. For LLM tasks, opting for a more recent generation can lead to faster and more efficient language model training and inference."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Support for AVX512:"}),"\xa0AVX512 is a set of vector instruction extensions that can be used to accelerate machine learning workloads. Many LLMs are optimized to take advantage of AVX512, so it is important to make sure that your CPU supports this instruction set."]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"here-are-some-cpu-options-for-running-llms",children:"Here are some CPU options for running LLMs:"}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Intel Core i7-12700K"}),": Slightly less potent than the Core i9-12900K, the Intel Core i7-12700K is still a powerful CPU. With 12 cores and 20 threads, it strikes a balance between performance and cost-effectiveness. This CPU is well-suited for running mid-sized and large LLMs, making it a compelling option."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Intel Core i9-12900K"}),": Positioned as a high-end CPU, the Intel Core i9-12900K packs a formidable punch with its 16 cores and 24 threads. It's one of the fastest CPUs available, making it an excellent choice for handling large and intricate LLMs. The abundance of cores and threads translates to exceptional parallel processing capabilities, which is crucial for tasks involving massive language models."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"AMD Ryzen 9 5950X"}),": Representing AMD's high-end CPU offering, the Ryzen 9 5950X boasts 16 cores and 32 threads. While it may not quite match the speed of the Core i9-12900K, it remains a robust and cost-effective choice. Its multicore prowess enables smooth handling of LLM workloads, and its affordability makes it an attractive alternative."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"AMD Ryzen 7 5800X"}),": Slightly less potent than the Ryzen 9 5950X, the Ryzen 7 5800X is still a formidable CPU with 8 cores and 16 threads. It's well-suited for running mid-sized and smaller LLMs, providing a compelling blend of performance and value."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"For those operating within budget constraints, there are more budget-friendly CPU options:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Intel Core i5-12600K"}),": The Core i5-12600K is a capable mid-range CPU that can still handle LLMs effectively, though it may not be optimized for the largest or most complex models."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"AMD Ryzen 5 5600X"}),": The Ryzen 5 5600X offers a balance of performance and affordability. It's suitable for running smaller to mid-sized LLMs without breaking the bank."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"When selecting a CPU for LLMs, consider the synergy with other components in your PC:"})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"GPU"}),": Pair your CPU with a powerful GPU to ensure smooth processing of LLMs. Some language models, particularly those used for AI, rely on GPU acceleration for optimal performance."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"RAM"}),": Adequate RAM is essential for LLMs, as these models can be memory-intensive. Having enough RAM ensures that your CPU can operate efficiently without bottlenecks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Cooling System"}),": Given the resource-intensive nature of LLMs, a robust cooling system is crucial to maintain optimal temperatures and prevent performance throttling."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"By carefully weighing your budget and performance requirements and considering the interplay of components in your PC, you can assemble a well-rounded system that's up to the task of running LLMs efficiently."}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["\ud83d\udcdd"," ",(0,s.jsx)(n.strong,{children:"Note:"})," It is important to note that these are just general recommendations. The specific CPU requirements for your LLM will vary depending on the specific model you are using and the tasks that you want to perform with it. If you are unsure what CPU to get, it is best to consult with an expert."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"ram-selection",children:"RAM Selection"}),"\n",(0,s.jsx)(n.p,{children:"The amount of RAM you need to run an LLM depends on the size and complexity of the model, as well as the tasks you want to perform with it. For example, if you are simply running inference on a pre-trained LLM, you may be able to get away with using a relatively modest amount of RAM. However, if you are training a new LLM from scratch, or if you are running complex tasks like fine-tuning or code generation, you will need more RAM."}),"\n",(0,s.jsx)(n.h3,{id:"here-is-a-general-guide-to-ram-selection-for-running-llms",children:"Here is a general guide to RAM selection for running LLMs:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Capacity:"}),"\xa0The amount of RAM you need will depend on the size and complexity of the LLM model you want to run. For inference, you will need at least 16GB of RAM, but 32GB or more is ideal for larger models and more complex tasks. For training, you will need at least 64GB of RAM, but 128GB or more is ideal for larger models and more complex tasks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Speed:"}),"\xa0LLMs can benefit from having fast RAM, so it is recommended to use DDR4 or DDR5 RAM with a speed of at least 3200MHz."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Latency:"}),"\xa0RAM latency is the amount of time it takes for the CPU to access data in memory. Lower latency is better for performance, so it is recommended to look for RAM with a low latency rating."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Timing:"}),"\xa0RAM timing is a set of parameters that control how the RAM operates. It is important to make sure that the RAM timing is compatible with your motherboard and CPU."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["R",(0,s.jsx)(n.strong,{children:"ecommended RAM"})," ",(0,s.jsx)(n.strong,{children:"options for running LLMs:"})]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Inference:"}),"\xa0For inference on pre-trained LLMs, you will need at least 16GB of RAM. However, 32GB or more is ideal for larger models and more complex tasks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Training:"}),"\xa0For training LLMs from scratch, you will need at least 64GB of RAM. However, 128GB or more is ideal for larger models and more complex tasks."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"In addition to the amount of RAM, it is also important to consider the speed of the RAM. LLMs can benefit from having fast RAM, so it is recommended to use DDR4 or DDR5 RAM with a speed of at least 3200MHz."}),"\n",(0,s.jsx)(n.h2,{id:"motherboard-selection",children:"Motherboard Selection"}),"\n",(0,s.jsx)(n.p,{children:"When picking a motherboard to run advanced language models, you need to think about a few things. First, consider the specific language model you want to use, the type of CPU and GPU in your computer, and your budget. Here are some suggestions:"}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"ASUS ROG Maximus Z790 Hero:"})," This is a top-notch motherboard with lots of great features. It works well with Intel's latest CPUs, fast DDR5 memory, and PCIe 5.0 devices. It's also good at keeping things cool, which is important for running demanding language models."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"MSI MEG Z790 Ace:"})," Similar to the ASUS ROG Maximus, this motherboard is high-end and has similar features. It's good for running language models too."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Gigabyte Z790 Aorus Master:"})," This one is more budget-friendly but still works great with Intel's latest CPUs, DDR5 memory, and fast PCIe 5.0 devices. It's got a strong power system, which helps with running language models."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["If you're on a tighter budget, you might want to check out mid-range options like the ",(0,s.jsx)(n.strong,{children:"ASUS TUF Gaming Z790-Plus WiFi"})," or the ",(0,s.jsx)(n.strong,{children:"MSI MPG Z790 Edge WiFi DDR5"}),". They offer good performance without breaking the bank."]}),"\n",(0,s.jsx)(n.p,{children:"No matter which motherboard you pick, make sure it works with your CPU and GPU. Also, check that it has the features you need, like enough slots for your GPU and storage drives."}),"\n",(0,s.jsx)(n.p,{children:"Other things to think about when choosing a motherboard for language models:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Cooling:"})," Language models can make your CPU work hard, so a motherboard with good cooling is a must. This keeps your CPU from getting too hot."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Memory:"})," Language models need lots of memory, so make sure your motherboard supports a good amount of it. Check if it works with the type of memory you want to use, like DDR5 or DDR4."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Storage:"})," Language models can create and store a ton of data. So, look for a motherboard with enough slots for your storage drives."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"BIOS:"})," The BIOS controls your motherboard. Make sure it's up-to-date and has the latest features, especially if you plan to overclock or undervolt your system."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"cooling-system-selection",children:"Cooling System Selection"}),"\n",(0,s.jsx)(n.p,{children:"Modern computers have two critical components, the CPU and GPU, which can heat up during high-performance tasks. To prevent overheating, they come with built-in temperature controls that automatically reduce performance when temperatures rise. To keep them cool and maintain optimal performance, you need a reliable cooling system."}),"\n",(0,s.jsx)(n.p,{children:"For laptops, the only choice is a fan-based cooling system. Laptops have built-in fans and copper pipes to dissipate heat. Many gaming laptops even have two separate fans: one for the CPU and another for the GPU."}),"\n",(0,s.jsx)(n.p,{children:"For desktop computers, you have the option to install more efficient water cooling systems. These are highly effective but can be expensive. Or you can install more cooling fans to keep you components cool."}),"\n",(0,s.jsx)(n.p,{children:"Keep in mind that dust can accumulate in fan-based cooling systems, leading to malfunctions. So periodically clean the dust to keep your cooling system running smoothly."}),"\n",(0,s.jsx)(n.h2,{id:"use-macbook-to-run-llms",children:"Use MacBook to run LLMs"}),"\n",(0,s.jsx)(n.p,{children:"An Apple MacBook equipped with either the M1 or the newer M2 Pro/Max processor. These cutting-edge chips leverage Apple's innovative Unified Memory Architecture (UMA), which revolutionizes the way the CPU and GPU interact with memory resources. This advancement plays a pivotal role in enhancing the performance and capabilities of LLMs."}),"\n",(0,s.jsxs)(n.p,{children:["Unified Memory Architecture, as implemented in Apple's M1 and M2 series processors, facilitates seamless and efficient data access for both the CPU and GPU. Unlike traditional systems where data needs to be shuttled between various memory pools, UMA offers a unified and expansive memory pool that can be accessed by both processing units without unnecessary data transfers. This transformative approach significantly minimizes latency while concurrently boosting data access bandwidth, resulting in substantial improvements in both the speed and quality of outputs.\n",(0,s.jsx)(n.img,{src:"https://media.discordapp.net/attachments/1148534242104574012/1156600109967089714/IMG_3722.webp?ex=6516380a&is=6514e68a&hm=ebe3b6ecb1edb44cde58bd8d3fdd46cef66b60aa41ea6c03b51325fa65f8517e&=&width=807&height=426",alt:"UMA"})]}),"\n",(0,s.jsx)(n.p,{children:"The M1 and M2 Pro/Max chips offer varying levels of unified memory bandwidth, further underscoring their prowess in handling data-intensive tasks like AI processing. The M1/M2 Pro chip boasts an impressive capacity of up to 200 GB/s of unified memory bandwidth, while the M1/M2 Max takes it a step further, supporting up to a staggering 400 GB/s of unified memory bandwidth. This means that regardless of the complexity and demands of the AI tasks at hand, these Apple laptops armed with M1 or M2 processors are well-equipped to handle them with unparalleled efficiency and speed."}),"\n",(0,s.jsx)(n.h2,{id:"calculating-vram-requirements-for-an-llm",children:"Calculating vRAM Requirements for an LLM"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"For example:"})," Calculating the VRAM required to run a 13-billion-parameter Large Language Model (LLM) involves considering the model size, batch size, sequence length, token size, and any additional overhead. Here's how you can estimate the VRAM required for a 13B LLM:"]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Model Size"}),": Find out the size of the 13B LLM in terms of the number of parameters. This information is typically provided in the model's documentation. A 13-billion-parameter model has 13,000,000,000 parameters."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Batch Size"}),": Decide on the batch size you want to use during inference. The batch size represents how many input samples you process simultaneously. Smaller batch sizes require less VRAM."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Sequence Length"}),": Determine the average length of the input text sequences you'll be working with. Sequence length can impact VRAM requirements; longer sequences need more memory."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Token Size"}),": Understand the memory required to store one token in bytes. Most LLMs use 4 bytes per token."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Overhead"}),": Consider any additional memory overhead for intermediate computations and framework requirements. Overhead can vary but should be estimated based on your specific setup."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"Use the following formula to estimate the VRAM required:"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"VRAM Required (in gigabytes)"})," = ",(0,s.jsx)(n.code,{children:"Model Parameters x Token Size x Batch Size x Sequence Length + Overhead"})]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Model Parameters"}),": 13,000,000,000 parameters for a 13B LLM."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Token Size"}),": Usually 4 bytes per token."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Batch Size"}),": Choose your batch size."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Sequence Length"}),": The average length of input sequences."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Overhead"}),": Any additional VRAM required based on your setup."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"Here's an example:"}),"\n",(0,s.jsx)(n.p,{children:"Suppose you want to run a 13B LLM with the following parameters:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Batch Size"}),": 4"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Sequence Length"}),": 512 tokens"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Token Size"}),": 4 bytes"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Estimated Overhead"}),": 2 GB"]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) = ",(0,s.jsx)(n.code,{children:"(13,000,000,000 x 4 x 4 x 512) + 2"})]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) = ",(0,s.jsx)(n.code,{children:"(8,388,608,000) + 2,000"})]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) \u2248 ",(0,s.jsx)(n.code,{children:"8,390,608,000 bytes"})]}),"\n",(0,s.jsxs)(n.p,{children:["To convert this to gigabytes, divide by ",(0,s.jsx)(n.code,{children:"1,073,741,824 (1 GB)"})]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) \u2248 ",(0,s.jsx)(n.code,{children:"8,390,608,000 / 1,073,741,824 \u2248 7.8 GB"})]}),"\n",(0,s.jsx)(n.p,{children:"So, to run a 13-billion-parameter LLM with the specified parameters and overhead, you would need approximately 7.8 gigabytes of VRAM on your GPU. Make sure to have some additional VRAM for stable operation and consider testing the setup in practice to monitor VRAM usage accurately."})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>a});var s=t(96540);const i={},r=s.createContext(i);function o(e){const n=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),s.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/2f9d99a9.f82abd7d.js b/assets/js/2f9d99a9.f82abd7d.js new file mode 100644 index 00000000..d5f75c61 --- /dev/null +++ b/assets/js/2f9d99a9.f82abd7d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3088],{10320:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var s=t(74848),i=t(28453);const r={title:"Selecting AI Hardware"},o=void 0,a={id:"hardware/recommendations/by-hardware",title:"Selecting AI Hardware",description:"When selecting a GPU for LLMs, remember that it's not just about the GPU itself. Consider the synergy with other components in your PC:",source:"@site/docs/hardware/recommendations/by-hardware.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-hardware",permalink:"/hardware/recommendations/by-hardware",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-hardware.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Selecting AI Hardware"}},l={},d=[{value:"GPU Selection",id:"gpu-selection",level:2},{value:"GPU Comparison",id:"gpu-comparison",level:3},{value:"Other Considerations",id:"other-considerations",level:3},{value:"CPU Selection",id:"cpu-selection",level:2},{value:"Here are some CPU options for running LLMs:",id:"here-are-some-cpu-options-for-running-llms",level:3},{value:"RAM Selection",id:"ram-selection",level:2},{value:"Here is a general guide to RAM selection for running LLMs:",id:"here-is-a-general-guide-to-ram-selection-for-running-llms",level:3},{value:"Motherboard Selection",id:"motherboard-selection",level:2},{value:"Cooling System Selection",id:"cooling-system-selection",level:2},{value:"Use MacBook to run LLMs",id:"use-macbook-to-run-llms",level:2},{value:"Calculating vRAM Requirements for an LLM",id:"calculating-vram-requirements-for-an-llm",level:2}];function c(e){const n={blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.p,{children:"When selecting a GPU for LLMs, remember that it's not just about the GPU itself. Consider the synergy with other components in your PC:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"CPU"}),": To ensure efficient processing, pair your GPU with a powerful CPU. LLMs benefit from fast processors, so having a capable CPU is essential."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"RAM"}),": Sufficient RAM is crucial for LLMs. They can be memory-intensive, and having enough RAM ensures smooth operation."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Cooling System"}),": LLMs can push your PC's hardware to the limit. A robust cooling system helps maintain optimal temperatures, preventing overheating and performance throttling."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"By taking all of these factors into account, you can build a home PC setup that's well-equipped to handle the demands of running LLMs effectively and efficiently."}),"\n",(0,s.jsx)(n.h2,{id:"gpu-selection",children:"GPU Selection"}),"\n",(0,s.jsx)(n.p,{children:"Selecting the optimal GPU for running Large Language Models (LLMs) on your home PC is a decision influenced by your budget and the specific LLMs you intend to work with. Your choice should strike a balance between performance, efficiency, and cost-effectiveness."}),"\n",(0,s.jsx)(n.h3,{id:"gpu-comparison",children:"GPU Comparison"}),"\n",(0,s.jsxs)(n.table,{children:[(0,s.jsx)(n.thead,{children:(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.th,{children:"GPU"}),(0,s.jsx)(n.th,{children:"Price"}),(0,s.jsx)(n.th,{children:"Cores"}),(0,s.jsx)(n.th,{children:"VRAM (GB)"}),(0,s.jsx)(n.th,{children:"Bandwth (T/s)"}),(0,s.jsx)(n.th,{children:"Power"})]})}),(0,s.jsxs)(n.tbody,{children:[(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia H100"}),(0,s.jsx)(n.td,{children:"40000"}),(0,s.jsx)(n.td,{children:"18432"}),(0,s.jsx)(n.td,{children:"80"}),(0,s.jsx)(n.td,{children:"2"}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia A100"}),(0,s.jsx)(n.td,{children:"15000"}),(0,s.jsx)(n.td,{children:"6912"}),(0,s.jsx)(n.td,{children:"80"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia A100"}),(0,s.jsx)(n.td,{children:"7015"}),(0,s.jsx)(n.td,{children:"6912"}),(0,s.jsx)(n.td,{children:"40"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia A10"}),(0,s.jsx)(n.td,{children:"2799"}),(0,s.jsx)(n.td,{children:"9216"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX A6000"}),(0,s.jsx)(n.td,{children:"4100"}),(0,s.jsx)(n.td,{children:"10752"}),(0,s.jsx)(n.td,{children:"48"}),(0,s.jsx)(n.td,{children:"0.768"}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 6000"}),(0,s.jsx)(n.td,{children:"6800"}),(0,s.jsx)(n.td,{children:"4608"}),(0,s.jsx)(n.td,{children:"46"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 4090 Ti"}),(0,s.jsx)(n.td,{children:"2000"}),(0,s.jsx)(n.td,{children:"18176"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 4090"}),(0,s.jsx)(n.td,{children:"1800"}),(0,s.jsx)(n.td,{children:"16384"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{children:"1.008"}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 3090"}),(0,s.jsx)(n.td,{children:"1450"}),(0,s.jsx)(n.td,{children:"10496"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 3080"}),(0,s.jsx)(n.td,{children:"700"}),(0,s.jsx)(n.td,{children:"8704"}),(0,s.jsx)(n.td,{children:"12"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia RTX 3070"}),(0,s.jsx)(n.td,{children:"900"}),(0,s.jsx)(n.td,{children:"6144"}),(0,s.jsx)(n.td,{children:"8"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia L4"}),(0,s.jsx)(n.td,{children:"2711"}),(0,s.jsx)(n.td,{children:"7424"}),(0,s.jsx)(n.td,{children:"24"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Nvidia T4"}),(0,s.jsx)(n.td,{children:"2299"}),(0,s.jsx)(n.td,{children:"2560"}),(0,s.jsx)(n.td,{children:"16"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"AMD Radeon RX 6900 XT"}),(0,s.jsx)(n.td,{children:"1000"}),(0,s.jsx)(n.td,{children:"5120"}),(0,s.jsx)(n.td,{children:"16"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"AMD Radeon RX 6800 XT"}),(0,s.jsx)(n.td,{children:"420"}),(0,s.jsx)(n.td,{children:"4608"}),(0,s.jsx)(n.td,{children:"16"}),(0,s.jsx)(n.td,{}),(0,s.jsx)(n.td,{})]})]})]}),"\n",(0,s.jsx)(n.p,{children:"*Market prices as of Oct 2023 via Amazon/PCMag"}),"\n",(0,s.jsx)(n.h3,{id:"other-considerations",children:"Other Considerations"}),"\n",(0,s.jsx)(n.p,{children:"In general, the following GPU features are important for running LLMs:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"High VRAM:"}),"\xa0LLMs are typically very large and complex models, so they require a GPU with a high amount of VRAM. This will allow the model to be loaded into memory and processed efficiently."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"CUDA Compatibility:"})," When running LLMs on a GPU, CUDA compatibility is paramount. CUDA is NVIDIA's parallel computing platform, and it plays a vital role in accelerating deep learning tasks. LLMs, with their extensive matrix calculations, heavily rely on parallel processing. Ensuring your GPU supports CUDA is like having the right tool for the job. It allows the LLM to leverage the GPU's parallel processing capabilities, significantly speeding up model training and inference."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Number of CUDA, Tensor, and RT Cores:"})," High-performance NVIDIA GPUs have both CUDA and Tensor cores. These cores are responsible for executing the neural network computations that underpin LLMs' language understanding and generation. The more CUDA cores your GPU has, the better equipped it is to handle the massive computational load that LLMs impose. Tensor cores in your GPU, further enhance LLM performance by accelerating the critical matrix operations integral to language modeling tasks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Generation (Series)"}),": When selecting a GPU for LLMs, consider its generation or series (e.g., RTX 30 series). Newer GPU generations often come with improved architectures and features. For LLM tasks, opting for the latest generation can mean better performance, energy efficiency, and support for emerging AI technologies. Avoid purchasing, RTX-2000 series GPUs which are much outdated nowadays."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"cpu-selection",children:"CPU Selection"}),"\n",(0,s.jsx)(n.p,{children:"Selecting the right CPU for running Large Language Models (LLMs) on your home PC is contingent on your budget and the specific LLMs you intend to work with. It's a decision that warrants careful consideration, as the CPU plays a pivotal role in determining the overall performance of your system."}),"\n",(0,s.jsx)(n.p,{children:"In general, the following CPU features are important for running LLMs:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Number of Cores and Threads:"}),"\xa0the number of CPU cores and threads influences parallel processing. More cores and threads help handle the complex computations involved in language models. For tasks like training and inference, a higher core/thread count can significantly improve processing speed and efficiency, enabling quicker results."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"High clock speed:"}),"\xa0The base clock speed, or base frequency, represents the CPU's default operating speed. So having a CPU with a high clock speed. This will allow the model to process instructions more quickly, which can further improve performance."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Base Power (TDP):"})," LLMs often involve long training sessions and demanding computations. Therefore, a lower Thermal Design Power (TDP) is desirable. A CPU with a lower TDP consumes less power and generates less heat during prolonged LLM operations. This not only contributes to energy efficiency but also helps maintain stable temperatures in your system, preventing overheating and potential performance throttling."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Generation (Series):"})," Consider its generation or series (e.g., 9th Gen, 11th Gen Intel Core). Newer CPU generations often come with architectural improvements that enhance performance and efficiency. For LLM tasks, opting for a more recent generation can lead to faster and more efficient language model training and inference."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Support for AVX512:"}),"\xa0AVX512 is a set of vector instruction extensions that can be used to accelerate machine learning workloads. Many LLMs are optimized to take advantage of AVX512, so it is important to make sure that your CPU supports this instruction set."]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"here-are-some-cpu-options-for-running-llms",children:"Here are some CPU options for running LLMs:"}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Intel Core i7-12700K"}),": Slightly less potent than the Core i9-12900K, the Intel Core i7-12700K is still a powerful CPU. With 12 cores and 20 threads, it strikes a balance between performance and cost-effectiveness. This CPU is well-suited for running mid-sized and large LLMs, making it a compelling option."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Intel Core i9-12900K"}),": Positioned as a high-end CPU, the Intel Core i9-12900K packs a formidable punch with its 16 cores and 24 threads. It's one of the fastest CPUs available, making it an excellent choice for handling large and intricate LLMs. The abundance of cores and threads translates to exceptional parallel processing capabilities, which is crucial for tasks involving massive language models."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"AMD Ryzen 9 5950X"}),": Representing AMD's high-end CPU offering, the Ryzen 9 5950X boasts 16 cores and 32 threads. While it may not quite match the speed of the Core i9-12900K, it remains a robust and cost-effective choice. Its multicore prowess enables smooth handling of LLM workloads, and its affordability makes it an attractive alternative."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"AMD Ryzen 7 5800X"}),": Slightly less potent than the Ryzen 9 5950X, the Ryzen 7 5800X is still a formidable CPU with 8 cores and 16 threads. It's well-suited for running mid-sized and smaller LLMs, providing a compelling blend of performance and value."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"For those operating within budget constraints, there are more budget-friendly CPU options:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Intel Core i5-12600K"}),": The Core i5-12600K is a capable mid-range CPU that can still handle LLMs effectively, though it may not be optimized for the largest or most complex models."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"AMD Ryzen 5 5600X"}),": The Ryzen 5 5600X offers a balance of performance and affordability. It's suitable for running smaller to mid-sized LLMs without breaking the bank."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"When selecting a CPU for LLMs, consider the synergy with other components in your PC:"})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"GPU"}),": Pair your CPU with a powerful GPU to ensure smooth processing of LLMs. Some language models, particularly those used for AI, rely on GPU acceleration for optimal performance."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"RAM"}),": Adequate RAM is essential for LLMs, as these models can be memory-intensive. Having enough RAM ensures that your CPU can operate efficiently without bottlenecks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Cooling System"}),": Given the resource-intensive nature of LLMs, a robust cooling system is crucial to maintain optimal temperatures and prevent performance throttling."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"By carefully weighing your budget and performance requirements and considering the interplay of components in your PC, you can assemble a well-rounded system that's up to the task of running LLMs efficiently."}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["\ud83d\udcdd"," ",(0,s.jsx)(n.strong,{children:"Note:"})," It is important to note that these are just general recommendations. The specific CPU requirements for your LLM will vary depending on the specific model you are using and the tasks that you want to perform with it. If you are unsure what CPU to get, it is best to consult with an expert."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"ram-selection",children:"RAM Selection"}),"\n",(0,s.jsx)(n.p,{children:"The amount of RAM you need to run an LLM depends on the size and complexity of the model, as well as the tasks you want to perform with it. For example, if you are simply running inference on a pre-trained LLM, you may be able to get away with using a relatively modest amount of RAM. However, if you are training a new LLM from scratch, or if you are running complex tasks like fine-tuning or code generation, you will need more RAM."}),"\n",(0,s.jsx)(n.h3,{id:"here-is-a-general-guide-to-ram-selection-for-running-llms",children:"Here is a general guide to RAM selection for running LLMs:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Capacity:"}),"\xa0The amount of RAM you need will depend on the size and complexity of the LLM model you want to run. For inference, you will need at least 16GB of RAM, but 32GB or more is ideal for larger models and more complex tasks. For training, you will need at least 64GB of RAM, but 128GB or more is ideal for larger models and more complex tasks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Speed:"}),"\xa0LLMs can benefit from having fast RAM, so it is recommended to use DDR4 or DDR5 RAM with a speed of at least 3200MHz."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Latency:"}),"\xa0RAM latency is the amount of time it takes for the CPU to access data in memory. Lower latency is better for performance, so it is recommended to look for RAM with a low latency rating."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Timing:"}),"\xa0RAM timing is a set of parameters that control how the RAM operates. It is important to make sure that the RAM timing is compatible with your motherboard and CPU."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["R",(0,s.jsx)(n.strong,{children:"ecommended RAM"})," ",(0,s.jsx)(n.strong,{children:"options for running LLMs:"})]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Inference:"}),"\xa0For inference on pre-trained LLMs, you will need at least 16GB of RAM. However, 32GB or more is ideal for larger models and more complex tasks."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Training:"}),"\xa0For training LLMs from scratch, you will need at least 64GB of RAM. However, 128GB or more is ideal for larger models and more complex tasks."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"In addition to the amount of RAM, it is also important to consider the speed of the RAM. LLMs can benefit from having fast RAM, so it is recommended to use DDR4 or DDR5 RAM with a speed of at least 3200MHz."}),"\n",(0,s.jsx)(n.h2,{id:"motherboard-selection",children:"Motherboard Selection"}),"\n",(0,s.jsx)(n.p,{children:"When picking a motherboard to run advanced language models, you need to think about a few things. First, consider the specific language model you want to use, the type of CPU and GPU in your computer, and your budget. Here are some suggestions:"}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"ASUS ROG Maximus Z790 Hero:"})," This is a top-notch motherboard with lots of great features. It works well with Intel's latest CPUs, fast DDR5 memory, and PCIe 5.0 devices. It's also good at keeping things cool, which is important for running demanding language models."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"MSI MEG Z790 Ace:"})," Similar to the ASUS ROG Maximus, this motherboard is high-end and has similar features. It's good for running language models too."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Gigabyte Z790 Aorus Master:"})," This one is more budget-friendly but still works great with Intel's latest CPUs, DDR5 memory, and fast PCIe 5.0 devices. It's got a strong power system, which helps with running language models."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["If you're on a tighter budget, you might want to check out mid-range options like the ",(0,s.jsx)(n.strong,{children:"ASUS TUF Gaming Z790-Plus WiFi"})," or the ",(0,s.jsx)(n.strong,{children:"MSI MPG Z790 Edge WiFi DDR5"}),". They offer good performance without breaking the bank."]}),"\n",(0,s.jsx)(n.p,{children:"No matter which motherboard you pick, make sure it works with your CPU and GPU. Also, check that it has the features you need, like enough slots for your GPU and storage drives."}),"\n",(0,s.jsx)(n.p,{children:"Other things to think about when choosing a motherboard for language models:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Cooling:"})," Language models can make your CPU work hard, so a motherboard with good cooling is a must. This keeps your CPU from getting too hot."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Memory:"})," Language models need lots of memory, so make sure your motherboard supports a good amount of it. Check if it works with the type of memory you want to use, like DDR5 or DDR4."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Storage:"})," Language models can create and store a ton of data. So, look for a motherboard with enough slots for your storage drives."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"BIOS:"})," The BIOS controls your motherboard. Make sure it's up-to-date and has the latest features, especially if you plan to overclock or undervolt your system."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"cooling-system-selection",children:"Cooling System Selection"}),"\n",(0,s.jsx)(n.p,{children:"Modern computers have two critical components, the CPU and GPU, which can heat up during high-performance tasks. To prevent overheating, they come with built-in temperature controls that automatically reduce performance when temperatures rise. To keep them cool and maintain optimal performance, you need a reliable cooling system."}),"\n",(0,s.jsx)(n.p,{children:"For laptops, the only choice is a fan-based cooling system. Laptops have built-in fans and copper pipes to dissipate heat. Many gaming laptops even have two separate fans: one for the CPU and another for the GPU."}),"\n",(0,s.jsx)(n.p,{children:"For desktop computers, you have the option to install more efficient water cooling systems. These are highly effective but can be expensive. Or you can install more cooling fans to keep you components cool."}),"\n",(0,s.jsx)(n.p,{children:"Keep in mind that dust can accumulate in fan-based cooling systems, leading to malfunctions. So periodically clean the dust to keep your cooling system running smoothly."}),"\n",(0,s.jsx)(n.h2,{id:"use-macbook-to-run-llms",children:"Use MacBook to run LLMs"}),"\n",(0,s.jsx)(n.p,{children:"An Apple MacBook equipped with either the M1 or the newer M2 Pro/Max processor. These cutting-edge chips leverage Apple's innovative Unified Memory Architecture (UMA), which revolutionizes the way the CPU and GPU interact with memory resources. This advancement plays a pivotal role in enhancing the performance and capabilities of LLMs."}),"\n",(0,s.jsxs)(n.p,{children:["Unified Memory Architecture, as implemented in Apple's M1 and M2 series processors, facilitates seamless and efficient data access for both the CPU and GPU. Unlike traditional systems where data needs to be shuttled between various memory pools, UMA offers a unified and expansive memory pool that can be accessed by both processing units without unnecessary data transfers. This transformative approach significantly minimizes latency while concurrently boosting data access bandwidth, resulting in substantial improvements in both the speed and quality of outputs.\n",(0,s.jsx)(n.img,{src:"https://media.discordapp.net/attachments/1148534242104574012/1156600109967089714/IMG_3722.webp?ex=6516380a&is=6514e68a&hm=ebe3b6ecb1edb44cde58bd8d3fdd46cef66b60aa41ea6c03b51325fa65f8517e&=&width=807&height=426",alt:"UMA"})]}),"\n",(0,s.jsx)(n.p,{children:"The M1 and M2 Pro/Max chips offer varying levels of unified memory bandwidth, further underscoring their prowess in handling data-intensive tasks like AI processing. The M1/M2 Pro chip boasts an impressive capacity of up to 200 GB/s of unified memory bandwidth, while the M1/M2 Max takes it a step further, supporting up to a staggering 400 GB/s of unified memory bandwidth. This means that regardless of the complexity and demands of the AI tasks at hand, these Apple laptops armed with M1 or M2 processors are well-equipped to handle them with unparalleled efficiency and speed."}),"\n",(0,s.jsx)(n.h2,{id:"calculating-vram-requirements-for-an-llm",children:"Calculating vRAM Requirements for an LLM"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"For example:"})," Calculating the VRAM required to run a 13-billion-parameter Large Language Model (LLM) involves considering the model size, batch size, sequence length, token size, and any additional overhead. Here's how you can estimate the VRAM required for a 13B LLM:"]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Model Size"}),": Find out the size of the 13B LLM in terms of the number of parameters. This information is typically provided in the model's documentation. A 13-billion-parameter model has 13,000,000,000 parameters."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Batch Size"}),": Decide on the batch size you want to use during inference. The batch size represents how many input samples you process simultaneously. Smaller batch sizes require less VRAM."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Sequence Length"}),": Determine the average length of the input text sequences you'll be working with. Sequence length can impact VRAM requirements; longer sequences need more memory."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Token Size"}),": Understand the memory required to store one token in bytes. Most LLMs use 4 bytes per token."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Overhead"}),": Consider any additional memory overhead for intermediate computations and framework requirements. Overhead can vary but should be estimated based on your specific setup."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"Use the following formula to estimate the VRAM required:"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"VRAM Required (in gigabytes)"})," = ",(0,s.jsx)(n.code,{children:"Model Parameters x Token Size x Batch Size x Sequence Length + Overhead"})]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Model Parameters"}),": 13,000,000,000 parameters for a 13B LLM."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Token Size"}),": Usually 4 bytes per token."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Batch Size"}),": Choose your batch size."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Sequence Length"}),": The average length of input sequences."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Overhead"}),": Any additional VRAM required based on your setup."]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"Here's an example:"}),"\n",(0,s.jsx)(n.p,{children:"Suppose you want to run a 13B LLM with the following parameters:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Batch Size"}),": 4"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Sequence Length"}),": 512 tokens"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Token Size"}),": 4 bytes"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Estimated Overhead"}),": 2 GB"]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) = ",(0,s.jsx)(n.code,{children:"(13,000,000,000 x 4 x 4 x 512) + 2"})]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) = ",(0,s.jsx)(n.code,{children:"(8,388,608,000) + 2,000"})]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) \u2248 ",(0,s.jsx)(n.code,{children:"8,390,608,000 bytes"})]}),"\n",(0,s.jsxs)(n.p,{children:["To convert this to gigabytes, divide by ",(0,s.jsx)(n.code,{children:"1,073,741,824 (1 GB)"})]}),"\n",(0,s.jsxs)(n.p,{children:["VRAM Required (in gigabytes) \u2248 ",(0,s.jsx)(n.code,{children:"8,390,608,000 / 1,073,741,824 \u2248 7.8 GB"})]}),"\n",(0,s.jsx)(n.p,{children:"So, to run a 13-billion-parameter LLM with the specified parameters and overhead, you would need approximately 7.8 gigabytes of VRAM on your GPU. Make sure to have some additional VRAM for stable operation and consider testing the setup in practice to monitor VRAM usage accurately."})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>a});var s=t(96540);const i={},r=s.createContext(i);function o(e){const n=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),s.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/30c31013.852c46fd.js b/assets/js/30c31013.852c46fd.js new file mode 100644 index 00000000..d0a233d7 --- /dev/null +++ b/assets/js/30c31013.852c46fd.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6511],{15264:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>l,default:()=>h,frontMatter:()=>s,metadata:()=>d,toc:()=>a});var t=i(74848),o=i(28453);const s={title:"LM Studio",slug:"/guides/engines/lmstudio",sidebar_position:8,description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","LM Studio integration"]},l=void 0,d={id:"guides/local-providers/lmstudio",title:"LM Studio",description:"A step-by-step guide on how to integrate Jan with LM Studio.",source:"@site/docs/guides/local-providers/lmstudio.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/lmstudio",permalink:"/guides/engines/lmstudio",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/lmstudio.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:8,frontMatter:{title:"LM Studio",slug:"/guides/engines/lmstudio",sidebar_position:8,description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","LM Studio integration"]},sidebar:"guidesSidebar",previous:{title:"TensorRT-LLM Extension",permalink:"/guides/engines/tensorrt-llm"},next:{title:"Ollama",permalink:"/guides/engines/ollama"}},r={},a=[{value:"Integrate LM Studio with Jan",id:"integrate-lm-studio-with-jan",level:2},{value:"Step 1: Server Setup",id:"step-1-server-setup",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Starting the Model",id:"step-3-starting-the-model",level:3},{value:"Migrating Models from LM Studio to Jan (version 0.4.6 and older)",id:"migrating-models-from-lm-studio-to-jan-version-046-and-older",level:2},{value:"Step 1: Model Migration",id:"step-1-model-migration",level:3},{value:"Step 2: Activating the Model",id:"step-2-activating-the-model",level:3},{value:"Direct Access to LM Studio Models from Jan (version 0.4.7+)",id:"direct-access-to-lm-studio-models-from-jan-version-047",level:2},{value:"Step 1: Locating the Model Path",id:"step-1-locating-the-model-path",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration-1",level:3},{value:"Step 3: Starting the Model",id:"step-3-starting-the-model-1",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"integrate-lm-studio-with-jan",children:"Integrate LM Studio with Jan"}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.a,{href:"https://lmstudio.ai/",children:"LM Studio"})," enables you to explore, download, and run local Large Language Models (LLMs). You can integrate Jan with LM Studio using two methods:"]}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Integrate the LM Studio server with Jan UI"}),"\n",(0,t.jsx)(n.li,{children:"Migrate your downloaded model from LM Studio to Jan."}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"To integrate LM Studio with Jan follow the steps below:"}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["In this guide, we're going to show you how to connect Jan to ",(0,t.jsx)(n.a,{href:"https://lmstudio.ai/",children:"LM Studio"})," using the second method. We'll use the ",(0,t.jsx)(n.a,{href:"https://huggingface.co/TheBloke/phi-2-GGUF",children:"Phi 2 - GGUF"})," model from Hugging Face as our example."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-1-server-setup",children:"Step 1: Server Setup"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Access the ",(0,t.jsx)(n.code,{children:"Local Inference Server"})," within LM Studio."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"Select your desired model."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"Start the server after configuring the port and options."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Update the ",(0,t.jsx)(n.code,{children:"openai.json"})," file in ",(0,t.jsx)(n.code,{children:"~/jan/engines"})," to include the LM Studio server's full URL."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "http://localhost:/v1/chat/completions"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"tip",children:(0,t.jsxs)(n.p,{children:["Replace ",(0,t.jsx)(n.code,{children:"(port)"})," with your chosen port number. The default is 1234."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Navigate to ",(0,t.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a folder named ",(0,t.jsx)(n.code,{children:"lmstudio-(modelname)"}),", like ",(0,t.jsx)(n.code,{children:"lmstudio-phi-2"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Inside, create a ",(0,t.jsx)(n.code,{children:"model.json"})," file with these options:","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"format"})," to ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Specify ",(0,t.jsx)(n.code,{children:"engine"})," as ",(0,t.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"state"})," to ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/lmstudio-phi-2/model.json"',children:'{\n "sources": [\n {\n "filename": "phi-2-GGUF",\n "url": "https://huggingface.co/TheBloke/phi-2-GGUF"\n }\n ],\n "id": "lmstudio-phi-2",\n "object": "model",\n "name": "LM Studio - Phi 2 - GGUF",\n "version": "1.0",\n "description": "TheBloke/phi-2-GGUF",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Microsoft",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["For more details regarding the ",(0,t.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,t.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-starting-the-model",children:"Step 3: Starting the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and proceed to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click ",(0,t.jsx)(n.strong,{children:"Use"})," to activate it."]}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"migrating-models-from-lm-studio-to-jan-version-046-and-older",children:"Migrating Models from LM Studio to Jan (version 0.4.6 and older)"}),"\n",(0,t.jsx)(n.h3,{id:"step-1-model-migration",children:"Step 1: Model Migration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["In LM Studio, navigate to ",(0,t.jsx)(n.code,{children:"My Models"})," and access your model folder."]}),"\n",(0,t.jsxs)(n.li,{children:["Copy the model folder to ",(0,t.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Ensure the folder name matches the model name in the ",(0,t.jsx)(n.code,{children:".gguf"})," filename. Rename as necessary."]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"step-2-activating-the-model",children:"Step 2: Activating the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,t.jsx)(n.strong,{children:"Hub"}),", where the model will be automatically detected."]}),"\n",(0,t.jsxs)(n.li,{children:["Click ",(0,t.jsx)(n.strong,{children:"Use"})," to use the model."]}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"direct-access-to-lm-studio-models-from-jan-version-047",children:"Direct Access to LM Studio Models from Jan (version 0.4.7+)"}),"\n",(0,t.jsx)(n.p,{children:"Starting from version 0.4.7, Jan enables direct import of LM Studio models using absolute file paths."}),"\n",(0,t.jsx)(n.h3,{id:"step-1-locating-the-model-path",children:"Step 1: Locating the Model Path"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Access ",(0,t.jsx)(n.code,{children:"My Models"})," in LM Studio and locate your model folder."]}),"\n",(0,t.jsx)(n.li,{children:"Obtain the absolute path of your model."}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration-1",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Go to ",(0,t.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a folder named ",(0,t.jsx)(n.code,{children:"(modelname)"})," (e.g., ",(0,t.jsx)(n.code,{children:"phi-2.Q4_K_S"}),")."]}),"\n",(0,t.jsxs)(n.li,{children:["Inside, craft a ",(0,t.jsx)(n.code,{children:"model.json"})," file:","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"id"})," to match the folder name."]}),"\n",(0,t.jsxs)(n.li,{children:["Use the direct binary download link ending in ",(0,t.jsx)(n.code,{children:".gguf"})," as the ",(0,t.jsx)(n.code,{children:"url"}),". You can now use the absolute filepath of the model file."]}),"\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"engine"})," as ",(0,t.jsx)(n.code,{children:"nitro"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",children:'{\n "object": "model",\n "version": 1,\n "format": "gguf",\n "sources": [\n {\n "filename": "phi-2.Q4_K_S.gguf",\n "url": ""\n }\n ],\n "id": "phi-2.Q4_K_S",\n "name": "phi-2.Q4_K_S",\n "created": 1708308111506,\n "description": "phi-2.Q4_K_S - user self import model",\n "settings": {\n "ctx_len": 4096,\n "embedding": false,\n "prompt_template": "{system_message}\\n### Instruction: {prompt}\\n### Response:",\n "llama_model_path": "phi-2.Q4_K_S.gguf"\n },\n "parameters": {\n "temperature": 0.7,\n "top_p": 0.95,\n "stream": true,\n "max_tokens": 2048,\n "stop": [""],\n "frequency_penalty": 0,\n "presence_penalty": 0\n },\n "metadata": {\n "size": 1615568736,\n "author": "User",\n "tags": []\n },\n "engine": "nitro"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"warning",children:(0,t.jsxs)(n.p,{children:["For Windows users, ensure to include double backslashes in the URL property, such as ",(0,t.jsx)(n.code,{children:"C:\\\\Users\\\\username\\\\filename.gguf"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-starting-the-model-1",children:"Step 3: Starting the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and proceed to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click ",(0,t.jsx)(n.strong,{children:"Use"})," to activate it."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>l,x:()=>d});var t=i(96540);const o={},s=t.createContext(o);function l(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:l(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/30c31013.db029583.js b/assets/js/30c31013.db029583.js deleted file mode 100644 index 51eec588..00000000 --- a/assets/js/30c31013.db029583.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6511],{15264:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>l,default:()=>h,frontMatter:()=>s,metadata:()=>d,toc:()=>a});var t=i(74848),o=i(28453);const s={title:"LM Studio",slug:"/guides/engines/lmstudio",sidebar_position:8,description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","LM Studio integration"]},l=void 0,d={id:"guides/local-providers/lmstudio",title:"LM Studio",description:"A step-by-step guide on how to integrate Jan with LM Studio.",source:"@site/docs/guides/local-providers/lmstudio.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/lmstudio",permalink:"/guides/engines/lmstudio",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/lmstudio.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:8,frontMatter:{title:"LM Studio",slug:"/guides/engines/lmstudio",sidebar_position:8,description:"A step-by-step guide on how to integrate Jan with LM Studio.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","LM Studio integration"]},sidebar:"guidesSidebar",previous:{title:"TensorRT-LLM Extension",permalink:"/guides/engines/tensorrt-llm"},next:{title:"Ollama",permalink:"/guides/engines/ollama"}},r={},a=[{value:"Integrate LM Studio with Jan",id:"integrate-lm-studio-with-jan",level:2},{value:"Step 1: Server Setup",id:"step-1-server-setup",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Starting the Model",id:"step-3-starting-the-model",level:3},{value:"Migrating Models from LM Studio to Jan (version 0.4.6 and older)",id:"migrating-models-from-lm-studio-to-jan-version-046-and-older",level:2},{value:"Step 1: Model Migration",id:"step-1-model-migration",level:3},{value:"Step 2: Activating the Model",id:"step-2-activating-the-model",level:3},{value:"Direct Access to LM Studio Models from Jan (version 0.4.7+)",id:"direct-access-to-lm-studio-models-from-jan-version-047",level:2},{value:"Step 1: Locating the Model Path",id:"step-1-locating-the-model-path",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration-1",level:3},{value:"Step 3: Starting the Model",id:"step-3-starting-the-model-1",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"integrate-lm-studio-with-jan",children:"Integrate LM Studio with Jan"}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.a,{href:"https://lmstudio.ai/",children:"LM Studio"})," enables you to explore, download, and run local Large Language Models (LLMs). You can integrate Jan with LM Studio using two methods:"]}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Integrate the LM Studio server with Jan UI"}),"\n",(0,t.jsx)(n.li,{children:"Migrate your downloaded model from LM Studio to Jan."}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"To integrate LM Studio with Jan follow the steps below:"}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["In this guide, we're going to show you how to connect Jan to ",(0,t.jsx)(n.a,{href:"https://lmstudio.ai/",children:"LM Studio"})," using the second method. We'll use the ",(0,t.jsx)(n.a,{href:"https://huggingface.co/TheBloke/phi-2-GGUF",children:"Phi 2 - GGUF"})," model from Hugging Face as our example."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-1-server-setup",children:"Step 1: Server Setup"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Access the ",(0,t.jsx)(n.code,{children:"Local Inference Server"})," within LM Studio."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"Select your desired model."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"Start the server after configuring the port and options."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Update the ",(0,t.jsx)(n.code,{children:"openai.json"})," file in ",(0,t.jsx)(n.code,{children:"~/jan/engines"})," to include the LM Studio server's full URL."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "http://localhost:/v1/chat/completions"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"tip",children:(0,t.jsxs)(n.p,{children:["Replace ",(0,t.jsx)(n.code,{children:"(port)"})," with your chosen port number. The default is 1234."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Navigate to ",(0,t.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a folder named ",(0,t.jsx)(n.code,{children:"lmstudio-(modelname)"}),", like ",(0,t.jsx)(n.code,{children:"lmstudio-phi-2"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Inside, create a ",(0,t.jsx)(n.code,{children:"model.json"})," file with these options:","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"format"})," to ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Specify ",(0,t.jsx)(n.code,{children:"engine"})," as ",(0,t.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"state"})," to ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/lmstudio-phi-2/model.json"',children:'{\n "sources": [\n {\n "filename": "phi-2-GGUF",\n "url": "https://huggingface.co/TheBloke/phi-2-GGUF"\n }\n ],\n "id": "lmstudio-phi-2",\n "object": "model",\n "name": "LM Studio - Phi 2 - GGUF",\n "version": "1.0",\n "description": "TheBloke/phi-2-GGUF",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Microsoft",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["For more details regarding the ",(0,t.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,t.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-starting-the-model",children:"Step 3: Starting the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and proceed to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click ",(0,t.jsx)(n.strong,{children:"Use"})," to activate it."]}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"migrating-models-from-lm-studio-to-jan-version-046-and-older",children:"Migrating Models from LM Studio to Jan (version 0.4.6 and older)"}),"\n",(0,t.jsx)(n.h3,{id:"step-1-model-migration",children:"Step 1: Model Migration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["In LM Studio, navigate to ",(0,t.jsx)(n.code,{children:"My Models"})," and access your model folder."]}),"\n",(0,t.jsxs)(n.li,{children:["Copy the model folder to ",(0,t.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Ensure the folder name matches the model name in the ",(0,t.jsx)(n.code,{children:".gguf"})," filename. Rename as necessary."]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"step-2-activating-the-model",children:"Step 2: Activating the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,t.jsx)(n.strong,{children:"Hub"}),", where the model will be automatically detected."]}),"\n",(0,t.jsxs)(n.li,{children:["Click ",(0,t.jsx)(n.strong,{children:"Use"})," to use the model."]}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"direct-access-to-lm-studio-models-from-jan-version-047",children:"Direct Access to LM Studio Models from Jan (version 0.4.7+)"}),"\n",(0,t.jsx)(n.p,{children:"Starting from version 0.4.7, Jan enables direct import of LM Studio models using absolute file paths."}),"\n",(0,t.jsx)(n.h3,{id:"step-1-locating-the-model-path",children:"Step 1: Locating the Model Path"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Access ",(0,t.jsx)(n.code,{children:"My Models"})," in LM Studio and locate your model folder."]}),"\n",(0,t.jsx)(n.li,{children:"Obtain the absolute path of your model."}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration-1",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Go to ",(0,t.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a folder named ",(0,t.jsx)(n.code,{children:"(modelname)"})," (e.g., ",(0,t.jsx)(n.code,{children:"phi-2.Q4_K_S"}),")."]}),"\n",(0,t.jsxs)(n.li,{children:["Inside, craft a ",(0,t.jsx)(n.code,{children:"model.json"})," file:","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"id"})," to match the folder name."]}),"\n",(0,t.jsxs)(n.li,{children:["Use the direct binary download link ending in ",(0,t.jsx)(n.code,{children:".gguf"})," as the ",(0,t.jsx)(n.code,{children:"url"}),". You can now use the absolute filepath of the model file."]}),"\n",(0,t.jsxs)(n.li,{children:["Set ",(0,t.jsx)(n.code,{children:"engine"})," as ",(0,t.jsx)(n.code,{children:"nitro"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",children:'{\n "object": "model",\n "version": 1,\n "format": "gguf",\n "sources": [\n {\n "filename": "phi-2.Q4_K_S.gguf",\n "url": ""\n }\n ],\n "id": "phi-2.Q4_K_S",\n "name": "phi-2.Q4_K_S",\n "created": 1708308111506,\n "description": "phi-2.Q4_K_S - user self import model",\n "settings": {\n "ctx_len": 4096,\n "embedding": false,\n "prompt_template": "{system_message}\\n### Instruction: {prompt}\\n### Response:",\n "llama_model_path": "phi-2.Q4_K_S.gguf"\n },\n "parameters": {\n "temperature": 0.7,\n "top_p": 0.95,\n "stream": true,\n "max_tokens": 2048,\n "stop": [""],\n "frequency_penalty": 0,\n "presence_penalty": 0\n },\n "metadata": {\n "size": 1615568736,\n "author": "User",\n "tags": []\n },\n "engine": "nitro"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"warning",children:(0,t.jsxs)(n.p,{children:["For Windows users, ensure to include double backslashes in the URL property, such as ",(0,t.jsx)(n.code,{children:"C:\\\\Users\\\\username\\\\filename.gguf"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-starting-the-model-1",children:"Step 3: Starting the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and proceed to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click ",(0,t.jsx)(n.strong,{children:"Use"})," to activate it."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>l,x:()=>d});var t=i(96540);const o={},s=t.createContext(o);function l(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:l(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/32016656.0641f1f7.js b/assets/js/32016656.0641f1f7.js deleted file mode 100644 index 8e33f122..00000000 --- a/assets/js/32016656.0641f1f7.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5404],{17503:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>s,default:()=>p,frontMatter:()=>o,metadata:()=>r,toc:()=>c});var a=n(74848),i=n(28453);const o={title:"Analytics",slug:"/how-we-work/analytics",description:"Jan's Analytics philosophy and implementation",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","analytics"]},s=void 0,r={id:"how-we-work/analytics/analytics",title:"Analytics",description:"Jan's Analytics philosophy and implementation",source:"@site/docs/how-we-work/analytics/analytics.md",sourceDirName:"how-we-work/analytics",slug:"/how-we-work/analytics",permalink:"/how-we-work/analytics",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/analytics/analytics.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Analytics",slug:"/how-we-work/analytics",description:"Jan's Analytics philosophy and implementation",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","analytics"]},sidebar:"aboutSidebar",previous:{title:"Product & Design",permalink:"/how-we-work/product-design"},next:{title:"Website & Docs",permalink:"/how-we-work/website-docs/"}},l={},c=[{value:"What is tracked",id:"what-is-tracked",level:4}];function d(e){const t={a:"a",code:"code",h4:"h4",li:"li",ol:"ol",p:"p",...(0,i.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(t.p,{children:"Adhering to Jan's privacy preserving philosophy, our analytics philosophy is to get \"barely-enough-to-function'."}),"\n",(0,a.jsx)(t.h4,{id:"what-is-tracked",children:"What is tracked"}),"\n",(0,a.jsxs)(t.ol,{children:["\n",(0,a.jsx)(t.li,{children:"By default, Github tracks downloads and device metadata for all public GitHub repositories. This helps us troubleshoot & ensure cross-platform support."}),"\n",(0,a.jsxs)(t.li,{children:["We use ",(0,a.jsx)(t.a,{href:"https://umami.is/",children:"Umami"})," to collect, analyze, and understand application data while maintaining visitor privacy and data ownership. We are using the Umami Cloud in Europe to ensure GDPR compliance. Please see ",(0,a.jsx)(t.a,{href:"https://umami.is/privacy",children:"Umami Privacy Policy"})," for more details."]}),"\n",(0,a.jsxs)(t.li,{children:["We use Umami to track a single ",(0,a.jsx)(t.code,{children:"app.opened"})," event without additional user metadata, in order to understand retention. In addition, we track ",(0,a.jsx)(t.code,{children:"app.version"})," to understand app version usage."]}),"\n",(0,a.jsxs)(t.li,{children:["Additionally, we plan to enable a ",(0,a.jsx)(t.code,{children:"Settings"})," feature for users to turn off all tracking."]}),"\n"]})]})}function p(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,a.jsx)(t,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>r});var a=n(96540);const i={},o=a.createContext(i);function s(e){const t=a.useContext(o);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),a.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/32016656.28609d7e.js b/assets/js/32016656.28609d7e.js new file mode 100644 index 00000000..472cd0ce --- /dev/null +++ b/assets/js/32016656.28609d7e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5404],{17503:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>s,default:()=>p,frontMatter:()=>o,metadata:()=>r,toc:()=>c});var a=n(74848),i=n(28453);const o={title:"Analytics",slug:"/how-we-work/analytics",description:"Jan's Analytics philosophy and implementation",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","analytics"]},s=void 0,r={id:"how-we-work/analytics/analytics",title:"Analytics",description:"Jan's Analytics philosophy and implementation",source:"@site/docs/how-we-work/analytics/analytics.md",sourceDirName:"how-we-work/analytics",slug:"/how-we-work/analytics",permalink:"/how-we-work/analytics",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/analytics/analytics.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Analytics",slug:"/how-we-work/analytics",description:"Jan's Analytics philosophy and implementation",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","analytics"]},sidebar:"aboutSidebar",previous:{title:"Product & Design",permalink:"/how-we-work/product-design"},next:{title:"Website & Docs",permalink:"/how-we-work/website-docs/"}},l={},c=[{value:"What is tracked",id:"what-is-tracked",level:4}];function d(e){const t={a:"a",code:"code",h4:"h4",li:"li",ol:"ol",p:"p",...(0,i.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(t.p,{children:"Adhering to Jan's privacy preserving philosophy, our analytics philosophy is to get \"barely-enough-to-function'."}),"\n",(0,a.jsx)(t.h4,{id:"what-is-tracked",children:"What is tracked"}),"\n",(0,a.jsxs)(t.ol,{children:["\n",(0,a.jsx)(t.li,{children:"By default, Github tracks downloads and device metadata for all public GitHub repositories. This helps us troubleshoot & ensure cross-platform support."}),"\n",(0,a.jsxs)(t.li,{children:["We use ",(0,a.jsx)(t.a,{href:"https://umami.is/",children:"Umami"})," to collect, analyze, and understand application data while maintaining visitor privacy and data ownership. We are using the Umami Cloud in Europe to ensure GDPR compliance. Please see ",(0,a.jsx)(t.a,{href:"https://umami.is/privacy",children:"Umami Privacy Policy"})," for more details."]}),"\n",(0,a.jsxs)(t.li,{children:["We use Umami to track a single ",(0,a.jsx)(t.code,{children:"app.opened"})," event without additional user metadata, in order to understand retention. In addition, we track ",(0,a.jsx)(t.code,{children:"app.version"})," to understand app version usage."]}),"\n",(0,a.jsxs)(t.li,{children:["Additionally, we plan to enable a ",(0,a.jsx)(t.code,{children:"Settings"})," feature for users to turn off all tracking."]}),"\n"]})]})}function p(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,a.jsx)(t,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>r});var a=n(96540);const i={},o=a.createContext(i);function s(e){const t=a.useContext(o);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),a.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/333fadac.46a5019c.js b/assets/js/333fadac.46a5019c.js deleted file mode 100644 index 458f364d..00000000 --- a/assets/js/333fadac.46a5019c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1641],{8552:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>l,metadata:()=>a,toc:()=>o});var r=i(74848),t=i(28453);const l={title:"Engine"},s=void 0,a={id:"developer/framework/engineering/engine",title:"Engine",description:"Currently Under Development",source:"@site/docs/developer/05-framework/03-engineering/engine.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/engine",permalink:"/developer/framework/engineering/engine",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/engine.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Engine"},sidebar:"developerSidebar",previous:{title:"Chats",permalink:"/developer/framework/engineering/chats"},next:{title:"Files",permalink:"/developer/framework/engineering/files"}},d={},o=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"Engine Default Parameter Files",id:"engine-default-parameter-files",level:2},{value:"Example",id:"example",level:3},{value:"Adding an Engine",id:"adding-an-engine",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",hr:"hr",li:"li",p:"p",pre:"pre",ul:"ul",...(0,t.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"Currently Under Development"})}),"\n",(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsx)(n.p,{children:"In the Jan application, engines serve as primary entities with the following capabilities:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Engine will be installed through ",(0,r.jsx)(n.code,{children:"inference-extensions"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["Models will depend on engines to do ",(0,r.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Inference_engine",children:"inference"}),"."]}),"\n",(0,r.jsx)(n.li,{children:"Engine configuration and required metadata will be stored in a json file."}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Default parameters for engines are stored in JSON files located in the ",(0,r.jsx)(n.code,{children:"/engines"})," folder."]}),"\n",(0,r.jsxs)(n.li,{children:["These parameter files are named uniquely with ",(0,r.jsx)(n.code,{children:"engine_id"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["Engines are referenced directly using ",(0,r.jsx)(n.code,{children:"engine_id"})," in the ",(0,r.jsx)(n.code,{children:"model.json"})," file."]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-yaml",children:"jan/\nengines/\nnitro.json\nopenai.json\n.....\n"})}),"\n",(0,r.jsx)(n.h2,{id:"engine-default-parameter-files",children:"Engine Default Parameter Files"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Each inference engine requires default parameters to function in cases where user-provided parameters are absent."}),"\n",(0,r.jsx)(n.li,{children:"These parameters are stored in JSON files, structured as simple key-value pairs."}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"example",children:"Example"}),"\n",(0,r.jsxs)(n.p,{children:["Here is an example of an engine file for ",(0,r.jsx)(n.code,{children:"engine_id"})," ",(0,r.jsx)(n.code,{children:"nitro"}),":"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-js",children:'{\n "ctx_len": 512,\n "ngl": 100,\n "embedding": false,\n "n_parallel": 1,\n "cont_batching": false\n "prompt_template": "<|im_start|>system\\n{system_message}<|im_end|>\\n<|im_start|>user\\n{prompt}<|im_end|>\\n<|im_start|>assistant"\n}\n'})}),"\n",(0,r.jsxs)(n.p,{children:["For detailed engine parameters, refer to: ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/load-unload#table-of-parameters",children:"Nitro's Model Settings"})]}),"\n",(0,r.jsx)(n.h2,{id:"adding-an-engine",children:"Adding an Engine"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Engine parameter files are automatically generated upon installing an ",(0,r.jsx)(n.code,{children:"inference-extension"})," in the Jan application."]}),"\n"]}),"\n",(0,r.jsx)(n.hr,{})]})}function p(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>a});var r=i(96540);const t={},l=r.createContext(t);function s(e){const n=r.useContext(l);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:s(e.components),r.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/333fadac.7fee2f09.js b/assets/js/333fadac.7fee2f09.js new file mode 100644 index 00000000..bb4467c3 --- /dev/null +++ b/assets/js/333fadac.7fee2f09.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1641],{8552:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>l,metadata:()=>a,toc:()=>o});var r=i(74848),t=i(28453);const l={title:"Engine"},s=void 0,a={id:"developer/framework/engineering/engine",title:"Engine",description:"Currently Under Development",source:"@site/docs/developer/05-framework/03-engineering/engine.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/engine",permalink:"/developer/framework/engineering/engine",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/engine.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Engine"},sidebar:"developerSidebar",previous:{title:"Chats",permalink:"/developer/framework/engineering/chats"},next:{title:"Files",permalink:"/developer/framework/engineering/files"}},d={},o=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"Engine Default Parameter Files",id:"engine-default-parameter-files",level:2},{value:"Example",id:"example",level:3},{value:"Adding an Engine",id:"adding-an-engine",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",hr:"hr",li:"li",p:"p",pre:"pre",ul:"ul",...(0,t.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"Currently Under Development"})}),"\n",(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsx)(n.p,{children:"In the Jan application, engines serve as primary entities with the following capabilities:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Engine will be installed through ",(0,r.jsx)(n.code,{children:"inference-extensions"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["Models will depend on engines to do ",(0,r.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Inference_engine",children:"inference"}),"."]}),"\n",(0,r.jsx)(n.li,{children:"Engine configuration and required metadata will be stored in a json file."}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Default parameters for engines are stored in JSON files located in the ",(0,r.jsx)(n.code,{children:"/engines"})," folder."]}),"\n",(0,r.jsxs)(n.li,{children:["These parameter files are named uniquely with ",(0,r.jsx)(n.code,{children:"engine_id"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["Engines are referenced directly using ",(0,r.jsx)(n.code,{children:"engine_id"})," in the ",(0,r.jsx)(n.code,{children:"model.json"})," file."]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-yaml",children:"jan/\nengines/\nnitro.json\nopenai.json\n.....\n"})}),"\n",(0,r.jsx)(n.h2,{id:"engine-default-parameter-files",children:"Engine Default Parameter Files"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Each inference engine requires default parameters to function in cases where user-provided parameters are absent."}),"\n",(0,r.jsx)(n.li,{children:"These parameters are stored in JSON files, structured as simple key-value pairs."}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"example",children:"Example"}),"\n",(0,r.jsxs)(n.p,{children:["Here is an example of an engine file for ",(0,r.jsx)(n.code,{children:"engine_id"})," ",(0,r.jsx)(n.code,{children:"nitro"}),":"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-js",children:'{\n "ctx_len": 512,\n "ngl": 100,\n "embedding": false,\n "n_parallel": 1,\n "cont_batching": false\n "prompt_template": "<|im_start|>system\\n{system_message}<|im_end|>\\n<|im_start|>user\\n{prompt}<|im_end|>\\n<|im_start|>assistant"\n}\n'})}),"\n",(0,r.jsxs)(n.p,{children:["For detailed engine parameters, refer to: ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/load-unload#table-of-parameters",children:"Nitro's Model Settings"})]}),"\n",(0,r.jsx)(n.h2,{id:"adding-an-engine",children:"Adding an Engine"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Engine parameter files are automatically generated upon installing an ",(0,r.jsx)(n.code,{children:"inference-extension"})," in the Jan application."]}),"\n"]}),"\n",(0,r.jsx)(n.hr,{})]})}function p(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>a});var r=i(96540);const t={},l=r.createContext(t);function s(e){const n=r.useContext(l);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:s(e.components),r.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3adc484d.07321136.js b/assets/js/3adc484d.07321136.js deleted file mode 100644 index d3953074..00000000 --- a/assets/js/3adc484d.07321136.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[168],{3657:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>f,frontMatter:()=>o,metadata:()=>i,toc:()=>u});var n=r(74848),s=r(28453);const o={title:"Extensions Framework"},a=void 0,i={id:"features/extensions-framework",title:"Extensions Framework",description:"",source:"@site/docs/features/extensions-framework.md",sourceDirName:"features",slug:"/features/extensions-framework",permalink:"/features/extensions-framework",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/extensions-framework.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Extensions Framework"},sidebar:"productSidebar",previous:{title:"API Server",permalink:"/features/api-server"},next:{title:"Agents Framework",permalink:"/features/agents-framework"}},c={},u=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function f(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>i});var n=r(96540);const s={},o=n.createContext(s);function a(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3adc484d.bb3896b5.js b/assets/js/3adc484d.bb3896b5.js new file mode 100644 index 00000000..68257ce6 --- /dev/null +++ b/assets/js/3adc484d.bb3896b5.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[168],{3657:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>f,frontMatter:()=>o,metadata:()=>i,toc:()=>u});var n=r(74848),s=r(28453);const o={title:"Extensions Framework"},a=void 0,i={id:"features/extensions-framework",title:"Extensions Framework",description:"",source:"@site/docs/features/extensions-framework.md",sourceDirName:"features",slug:"/features/extensions-framework",permalink:"/features/extensions-framework",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/extensions-framework.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Extensions Framework"},sidebar:"productSidebar",previous:{title:"API Server",permalink:"/features/api-server"},next:{title:"Agents Framework",permalink:"/features/agents-framework"}},c={},u=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function f(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>i});var n=r(96540);const s={},o=n.createContext(s);function a(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3afe9044.414c36b0.js b/assets/js/3afe9044.414c36b0.js new file mode 100644 index 00000000..13e644da --- /dev/null +++ b/assets/js/3afe9044.414c36b0.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9419],{23603:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>p,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=t(74848),o=t(28453);const r={title:"Overview",slug:"/developer",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,a={id:"developer/overview/README",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/README.md",sourceDirName:"developer/01-overview",slug:"/developer",permalink:"/developer",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/README.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Overview",slug:"/developer",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",next:{title:"Architecture",permalink:"/developer/architecture"}},l={},d=[{value:"Extensions",id:"extensions",level:2},{value:"Building Extensions",id:"building-extensions",level:3},{value:"Jan in Action",id:"jan-in-action",level:2}];function c(e){const n={a:"a",admonition:"admonition",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.p,{children:"The following docs are aimed at developers who want to build extensions on top of the Jan Framework."}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsxs)(n.p,{children:["If you are interested to ",(0,i.jsx)(n.strong,{children:"contribute to the framework's Core SDK itself"}),", like adding new drivers, runtimes, and infrastructure level support, please refer to ",(0,i.jsx)(n.a,{href:"/developer/framework",children:"framework docs"})," instead."]})}),"\n",(0,i.jsx)(n.h2,{id:"extensions",children:"Extensions"}),"\n",(0,i.jsxs)(n.p,{children:["Jan an ",(0,i.jsx)(n.strong,{children:"extensible framework"})," (like VSCode or Obsidian) that lets you build, customize and run AI applications everywhere, with an emphasis on local first."]}),"\n",(0,i.jsx)(n.p,{children:"Extensions are automatically available across Mac, Windows, Linux Desktops."}),"\n",(0,i.jsx)(n.p,{children:"Extensions can also be made available in local API server-mode, which can be deployed on any VM."}),"\n",(0,i.jsx)(n.h3,{id:"building-extensions",children:"Building Extensions"}),"\n",(0,i.jsxs)(n.p,{children:["This framework is packaged and regularly published as an SDK through ",(0,i.jsx)(n.a,{href:"https://www.npmjs.com/org/janhq",children:"npm"})," and ",(0,i.jsx)(n.a,{href:"https://pypi.org/",children:"pip"}),"."]}),"\n",(0,i.jsx)(n.p,{children:"The framework provides built-in support for the following:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Native OS integrations with Electron and Chromium"}),"\n",(0,i.jsx)(n.li,{children:"Native server integrations with Nodejs"}),"\n",(0,i.jsx)(n.li,{children:"Native mobile integrations with Capacitor (coming soon)"}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsx)(n.p,{children:"Build once, deploy everywhere"})}),"\n",(0,i.jsx)(n.h2,{id:"jan-in-action",children:"Jan in Action"}),"\n",(0,i.jsxs)(n.p,{children:["The ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/releases",children:"Jan Desktop client"})," is built with Jan SDK. This means you can customize any part of the application from the branding to the features, and truly make it your own."]}),"\n",(0,i.jsx)(n.p,{children:"[Gif: show desktop & server side by side]"})]})}function p(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var i=t(96540);const o={},r=i.createContext(o);function s(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3afe9044.c61c7cae.js b/assets/js/3afe9044.c61c7cae.js deleted file mode 100644 index 88b58f3b..00000000 --- a/assets/js/3afe9044.c61c7cae.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9419],{23603:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=t(74848),o=t(28453);const r={title:"Overview",slug:"/developer",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,a={id:"developer/overview/README",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/README.md",sourceDirName:"developer/01-overview",slug:"/developer",permalink:"/developer",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/README.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Overview",slug:"/developer",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",next:{title:"Architecture",permalink:"/developer/architecture"}},l={},d=[{value:"Extensions",id:"extensions",level:2},{value:"Building Extensions",id:"building-extensions",level:3},{value:"Jan in Action",id:"jan-in-action",level:2}];function c(e){const n={a:"a",admonition:"admonition",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.p,{children:"The following docs are aimed at developers who want to build extensions on top of the Jan Framework."}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsxs)(n.p,{children:["If you are interested to ",(0,i.jsx)(n.strong,{children:"contribute to the framework's Core SDK itself"}),", like adding new drivers, runtimes, and infrastructure level support, please refer to ",(0,i.jsx)(n.a,{href:"/developer/framework",children:"framework docs"})," instead."]})}),"\n",(0,i.jsx)(n.h2,{id:"extensions",children:"Extensions"}),"\n",(0,i.jsxs)(n.p,{children:["Jan an ",(0,i.jsx)(n.strong,{children:"extensible framework"})," (like VSCode or Obsidian) that lets you build, customize and run AI applications everywhere, with an emphasis on local first."]}),"\n",(0,i.jsx)(n.p,{children:"Extensions are automatically available across Mac, Windows, Linux Desktops."}),"\n",(0,i.jsx)(n.p,{children:"Extensions can also be made available in local API server-mode, which can be deployed on any VM."}),"\n",(0,i.jsx)(n.h3,{id:"building-extensions",children:"Building Extensions"}),"\n",(0,i.jsxs)(n.p,{children:["This framework is packaged and regularly published as an SDK through ",(0,i.jsx)(n.a,{href:"https://www.npmjs.com/org/janhq",children:"npm"})," and ",(0,i.jsx)(n.a,{href:"https://pypi.org/",children:"pip"}),"."]}),"\n",(0,i.jsx)(n.p,{children:"The framework provides built-in support for the following:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Native OS integrations with Electron and Chromium"}),"\n",(0,i.jsx)(n.li,{children:"Native server integrations with Nodejs"}),"\n",(0,i.jsx)(n.li,{children:"Native mobile integrations with Capacitor (coming soon)"}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsx)(n.p,{children:"Build once, deploy everywhere"})}),"\n",(0,i.jsx)(n.h2,{id:"jan-in-action",children:"Jan in Action"}),"\n",(0,i.jsxs)(n.p,{children:["The ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/releases",children:"Jan Desktop client"})," is built with Jan SDK. This means you can customize any part of the application from the branding to the features, and truly make it your own."]}),"\n",(0,i.jsx)(n.p,{children:"[Gif: show desktop & server side by side]"})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var i=t(96540);const o={},r=i.createContext(o);function s(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3b8fdfae.96669f05.js b/assets/js/3b8fdfae.96669f05.js new file mode 100644 index 00000000..e366c1c6 --- /dev/null +++ b/assets/js/3b8fdfae.96669f05.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7226],{28430:(e,t,s)=>{s.r(t),s.d(t,{assets:()=>o,contentTitle:()=>c,default:()=>l,frontMatter:()=>i,metadata:()=>d,toc:()=>a});var r=s(74848),n=s(28453);const i={title:"GPU vs CPU What's the Difference?"},c=void 0,d={id:"hardware/overview/cpu-vs-gpu",title:"GPU vs CPU What's the Difference?",description:"CPU vs. GPU",source:"@site/docs/hardware/overview/cpu-vs-gpu.md",sourceDirName:"hardware/overview",slug:"/hardware/overview/cpu-vs-gpu",permalink:"/hardware/overview/cpu-vs-gpu",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/overview/cpu-vs-gpu.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"GPU vs CPU What's the Difference?"}},o={},a=[{value:"CPU vs. GPU",id:"cpu-vs-gpu",level:2}];function h(e){const t={h2:"h2",img:"img",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,n.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(t.h2,{id:"cpu-vs-gpu",children:"CPU vs. GPU"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{}),(0,r.jsx)(t.th,{children:"CPU"}),(0,r.jsx)(t.th,{children:"GPU"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Function"})}),(0,r.jsx)(t.td,{children:"Generalized component that handles main processing functions of a server"}),(0,r.jsx)(t.td,{children:"Specialized component that excels at parallel computing"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Processing"})}),(0,r.jsx)(t.td,{children:"Designed for serial instruction processing"}),(0,r.jsx)(t.td,{children:"Designed for parallel instruction processing"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Design"})}),(0,r.jsx)(t.td,{children:"Fewer, more powerful cores"}),(0,r.jsx)(t.td,{children:"More cores than CPUs, but less powerful than CPU cores"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Best suited for"})}),(0,r.jsx)(t.td,{children:"General-purpose computing applications"}),(0,r.jsx)(t.td,{children:"High-performance computing applications"})]})]})]}),"\n",(0,r.jsx)(t.p,{children:(0,r.jsx)(t.img,{src:"https://media.discordapp.net/attachments/964896173401976932/1157998193741660222/CPU-vs-GPU-rendering.png?ex=651aa55b&is=651953db&hm=a22c80ed108a0d25106a20aa25236f7d0fa74167a50788194470f57ce7f4a6ca&=&width=807&height=426",alt:"CPU VS GPU"})})]})}function l(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},28453:(e,t,s)=>{s.d(t,{R:()=>c,x:()=>d});var r=s(96540);const n={},i=r.createContext(n);function c(e){const t=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:c(e.components),r.createElement(i.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3b8fdfae.c2092c59.js b/assets/js/3b8fdfae.c2092c59.js deleted file mode 100644 index 5e800ba0..00000000 --- a/assets/js/3b8fdfae.c2092c59.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7226],{28430:(e,t,s)=>{s.r(t),s.d(t,{assets:()=>o,contentTitle:()=>c,default:()=>l,frontMatter:()=>i,metadata:()=>d,toc:()=>a});var r=s(74848),n=s(28453);const i={title:"GPU vs CPU What's the Difference?"},c=void 0,d={id:"hardware/overview/cpu-vs-gpu",title:"GPU vs CPU What's the Difference?",description:"CPU vs. GPU",source:"@site/docs/hardware/overview/cpu-vs-gpu.md",sourceDirName:"hardware/overview",slug:"/hardware/overview/cpu-vs-gpu",permalink:"/hardware/overview/cpu-vs-gpu",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/overview/cpu-vs-gpu.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"GPU vs CPU What's the Difference?"}},o={},a=[{value:"CPU vs. GPU",id:"cpu-vs-gpu",level:2}];function h(e){const t={h2:"h2",img:"img",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,n.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(t.h2,{id:"cpu-vs-gpu",children:"CPU vs. GPU"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{}),(0,r.jsx)(t.th,{children:"CPU"}),(0,r.jsx)(t.th,{children:"GPU"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Function"})}),(0,r.jsx)(t.td,{children:"Generalized component that handles main processing functions of a server"}),(0,r.jsx)(t.td,{children:"Specialized component that excels at parallel computing"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Processing"})}),(0,r.jsx)(t.td,{children:"Designed for serial instruction processing"}),(0,r.jsx)(t.td,{children:"Designed for parallel instruction processing"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Design"})}),(0,r.jsx)(t.td,{children:"Fewer, more powerful cores"}),(0,r.jsx)(t.td,{children:"More cores than CPUs, but less powerful than CPU cores"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:(0,r.jsx)(t.strong,{children:"Best suited for"})}),(0,r.jsx)(t.td,{children:"General-purpose computing applications"}),(0,r.jsx)(t.td,{children:"High-performance computing applications"})]})]})]}),"\n",(0,r.jsx)(t.p,{children:(0,r.jsx)(t.img,{src:"https://media.discordapp.net/attachments/964896173401976932/1157998193741660222/CPU-vs-GPU-rendering.png?ex=651aa55b&is=651953db&hm=a22c80ed108a0d25106a20aa25236f7d0fa74167a50788194470f57ce7f4a6ca&=&width=807&height=426",alt:"CPU VS GPU"})})]})}function l(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},28453:(e,t,s)=>{s.d(t,{R:()=>c,x:()=>d});var r=s(96540);const n={},i=r.createContext(n);function c(e){const t=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:c(e.components),r.createElement(i.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3c009e50.301af127.js b/assets/js/3c009e50.301af127.js deleted file mode 100644 index f0b2a188..00000000 --- a/assets/js/3c009e50.301af127.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[996],{79791:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>l,toc:()=>c});var a=i(74848),r=i(28453);const s={sidebar_position:2,slug:"/changelog/changelog-v0.4.8"},o="v0.4.8",l={id:"releases/changelog/changelog-v0.4.8",title:"v0.4.8",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.8.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.8",permalink:"/changelog/changelog-v0.4.8",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.8.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{sidebar_position:2,slug:"/changelog/changelog-v0.4.8"},sidebar:"releasesSidebar",previous:{title:"v0.4.9",permalink:"/changelog/changelog-v0.4.9"},next:{title:"v0.4.7",permalink:"/changelog/changelog-v0.4.7"}},d={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function t(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v048",children:"v0.4.8"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.8",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/2267",children:"Issue #2267: Release cut v0.4.8"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Release cut v0.4.8 @louis-jan (#2267)"}),"\n",(0,a.jsx)(n.li,{children:"Add modify notary team in CI @hiento09 (#2265)"}),"\n",(0,a.jsx)(n.li,{children:"Chore: Update new models to model hub @hahuyhoang411 (#2192)"}),"\n",(0,a.jsx)(n.li,{children:"Macos Notarize migrage to new Team ID @hiento09 (#2228)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference assistants_id endpoint from DevDocs @avb-is-me (#2195)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference assistants endpoint from DevDocs @avb-is-me (#2194)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference threads endpoint from DevDocs @avb-is-me (#2182)"}),"\n",(0,a.jsx)(n.li,{children:"fix: wrong profile parameter in docker command @mooncool (#2159)"}),"\n",(0,a.jsx)(n.li,{children:"Sync release 0.4.7 to dev @louis-jan (#2151)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add upstream acknowledgements @hieu-jan (#2136)"}),"\n",(0,a.jsx)(n.li,{children:"Sync dev branch to docs branch @hieu-jan (#2131)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: prompt user to download an update manually @louis-jan (#2261)"}),"\n",(0,a.jsx)(n.li,{children:"feat: Jan can see @hiro-v (#2069)"}),"\n",(0,a.jsx)(n.li,{children:"Revert feat: temporary remove dark mode @urmauur (#2221)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add turborepo @louis-jan (#2220)"}),"\n",(0,a.jsx)(n.li,{children:"fix: change button import model on hub page @urmauur (#2178)"}),"\n",(0,a.jsx)(n.li,{children:"feat: temporary remove dark mode :( @urmauur (#2168)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add import model feature @namchuai (#2104)"}),"\n",(0,a.jsx)(n.li,{children:"feat: restore docusaurus style @urmauur (#2152)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add a simple way to convert Hugging Face model to GGUF @Helloyunho (#1972)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"codesign script force sign @hiento09 (#2291)"}),"\n",(0,a.jsx)(n.li,{children:"fix: should not attach error messages to the completion request @louis-jan (#2258)"}),"\n",(0,a.jsx)(n.li,{children:"fix: image upload button and drag event are not enabled @louis-jan (#2248)"}),"\n",(0,a.jsx)(n.li,{children:"fix: error message being sent along with conversation when inference @namchuai (#2242)"}),"\n",(0,a.jsx)(n.li,{children:"fix: replaced user path from app log @namchuai (#2238)"}),"\n",(0,a.jsx)(n.li,{children:"fix: drag and drop support image format to support vision model @urmauur (#2237)"}),"\n",(0,a.jsx)(n.li,{children:"fix: re-configure changelog sections @hieu-jan (#2230)"}),"\n",(0,a.jsx)(n.li,{children:"fix: import from HuggingFace with random string is causing app crash @louis-jan (#2214)"}),"\n",(0,a.jsx)(n.li,{children:"fix: comment from QA regarding import model @namchuai (#2213)"}),"\n",(0,a.jsx)(n.li,{children:"fix: download model error does not reset state in model hub @namchuai (#2199)"}),"\n",(0,a.jsx)(n.li,{children:"fix: minor ui missing secondary background @urmauur (#2198)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update docker command @hieu-jan (#2180)"}),"\n",(0,a.jsx)(n.li,{children:"fix: some bugs for import model @namchuai (#2181)"}),"\n",(0,a.jsx)(n.li,{children:"fix: change button import model on hub page @urmauur (#2178)"}),"\n",(0,a.jsx)(n.li,{children:"fix space between progress bar and title list of gpu @urmauur (#2177)"}),"\n",(0,a.jsx)(n.li,{children:"fix: disabled prompt user using dangerouslySetInnerHTML @urmauur (#2176)"}),"\n",(0,a.jsx)(n.li,{children:"fix: style list of gpus on system monitor @urmauur (#2172)"}),"\n",(0,a.jsx)(n.li,{children:"fix: system monitor expand overlap tooltip ribbon @urmauur (#2158)"}),"\n",(0,a.jsx)(n.li,{children:"Huggingface extension add codesign step for building on darwin @hiento09 (#2166)"}),"\n",(0,a.jsx)(n.li,{children:"Add run codesign for huggingface extension @hiento09 (#2163)"}),"\n",(0,a.jsx)(n.li,{children:"fix: system monitor ui @urmauur (#2135)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: temporary remove convert model @namchuai (#2266)"}),"\n",(0,a.jsx)(n.li,{children:"docs: sync slug fix from dev branch to docs branch @hieu-jan (#2264)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update broken link and fix the slug @aindrajaya (#2260)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Fix navbar issues. Keep stay when clicked other menu items from the sidebar @aindrajaya (#2253)"}),"\n",(0,a.jsx)(n.li,{children:"docs: sync docs hub fixes from dev to docs branch @hieu-jan (#2247)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update content for Hub page and Guides section @aindrajaya (#2245)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Fix Dark Mode on the Hub page and Update the Navbar functionality @aindrajaya (#2243)"}),"\n",(0,a.jsx)(n.li,{children:"chore: sync dev branch to docs branch @hieu-jan (#2239)"}),"\n",(0,a.jsx)(n.li,{children:"Chore: add prefix latest for task clean r2 bucket @hiento09 (#2233)"}),"\n",(0,a.jsx)(n.li,{children:"fix: re-configure changelog sections @hieu-jan (#2230)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add command run API server without frontend @hieu-jan (#2231)"}),"\n",(0,a.jsx)(n.li,{children:"docs: revamp entire Jan guides @hieu-jan (#2139)"}),"\n",(0,a.jsx)(n.li,{children:"chore: clean up some redundant code @namchuai (#2215)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference chatCompletions from DevDocs @avb-is-me (#2171)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference download model from DevDocs @avb-is-me (#2170)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference model_id from DevDocs @avb-is-me (#2169)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference listModel from DevDocs @avb-is-me (#2161)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update 08-antivirus-compatibility-testing.md @0xSage (#2186)"}),"\n",(0,a.jsx)(n.li,{children:"docs: adding new feature for v0.4.7 to release checklist @Van-QA (#2189)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update 01-integrate-continue.mdx @0xSage (#2187)"}),"\n",(0,a.jsx)(n.li,{children:"chore: bump nitro 0.3.14 @louis-jan (#2183)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Sync dev branch to docs branch @hieu-jan (#2185)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update docker command @hieu-jan (#2180)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update wall of love @hieu-jan (#2179)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add Jan newsletter @hieu-jan (#2174)"}),"\n",(0,a.jsx)(n.li,{children:"chore: make convert gguf as experimental feature @namchuai (#2156)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update acknowledgements @hieu-jan (#2147)"}),"\n",(0,a.jsx)(n.li,{children:"feat: restore docusaurus style @urmauur (#2152)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update run Jan in Docker mode @hieu-jan (#2150)"}),"\n",(0,a.jsx)(n.li,{children:"Docs pena team - Add Quickstart Docs @aindrajaya (#2138)"}),"\n",(0,a.jsx)(n.li,{children:"docs: hide incomplete pages @hieu-jan (#2127)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @Helloyunho, @Van-QA, @aindrajaya, @avb-is-me, @hahuyhoang411, @hiento09, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @mooncool, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(t,{...e})}):t(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>l});var a=i(96540);const r={},s=a.createContext(r);function o(e){const n=a.useContext(s);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),a.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3c009e50.d04f9bf1.js b/assets/js/3c009e50.d04f9bf1.js new file mode 100644 index 00000000..55d12261 --- /dev/null +++ b/assets/js/3c009e50.d04f9bf1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[996],{79791:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>l,toc:()=>c});var a=i(74848),r=i(28453);const s={sidebar_position:2,slug:"/changelog/changelog-v0.4.8"},o="v0.4.8",l={id:"releases/changelog/changelog-v0.4.8",title:"v0.4.8",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.8.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.8",permalink:"/changelog/changelog-v0.4.8",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.8.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{sidebar_position:2,slug:"/changelog/changelog-v0.4.8"},sidebar:"releasesSidebar",previous:{title:"v0.4.9",permalink:"/changelog/changelog-v0.4.9"},next:{title:"v0.4.7",permalink:"/changelog/changelog-v0.4.7"}},d={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function t(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v048",children:"v0.4.8"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.8",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/2267",children:"Issue #2267: Release cut v0.4.8"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Release cut v0.4.8 @louis-jan (#2267)"}),"\n",(0,a.jsx)(n.li,{children:"Add modify notary team in CI @hiento09 (#2265)"}),"\n",(0,a.jsx)(n.li,{children:"Chore: Update new models to model hub @hahuyhoang411 (#2192)"}),"\n",(0,a.jsx)(n.li,{children:"Macos Notarize migrage to new Team ID @hiento09 (#2228)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference assistants_id endpoint from DevDocs @avb-is-me (#2195)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference assistants endpoint from DevDocs @avb-is-me (#2194)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference threads endpoint from DevDocs @avb-is-me (#2182)"}),"\n",(0,a.jsx)(n.li,{children:"fix: wrong profile parameter in docker command @mooncool (#2159)"}),"\n",(0,a.jsx)(n.li,{children:"Sync release 0.4.7 to dev @louis-jan (#2151)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add upstream acknowledgements @hieu-jan (#2136)"}),"\n",(0,a.jsx)(n.li,{children:"Sync dev branch to docs branch @hieu-jan (#2131)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: prompt user to download an update manually @louis-jan (#2261)"}),"\n",(0,a.jsx)(n.li,{children:"feat: Jan can see @hiro-v (#2069)"}),"\n",(0,a.jsx)(n.li,{children:"Revert feat: temporary remove dark mode @urmauur (#2221)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add turborepo @louis-jan (#2220)"}),"\n",(0,a.jsx)(n.li,{children:"fix: change button import model on hub page @urmauur (#2178)"}),"\n",(0,a.jsx)(n.li,{children:"feat: temporary remove dark mode :( @urmauur (#2168)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add import model feature @namchuai (#2104)"}),"\n",(0,a.jsx)(n.li,{children:"feat: restore docusaurus style @urmauur (#2152)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add a simple way to convert Hugging Face model to GGUF @Helloyunho (#1972)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"codesign script force sign @hiento09 (#2291)"}),"\n",(0,a.jsx)(n.li,{children:"fix: should not attach error messages to the completion request @louis-jan (#2258)"}),"\n",(0,a.jsx)(n.li,{children:"fix: image upload button and drag event are not enabled @louis-jan (#2248)"}),"\n",(0,a.jsx)(n.li,{children:"fix: error message being sent along with conversation when inference @namchuai (#2242)"}),"\n",(0,a.jsx)(n.li,{children:"fix: replaced user path from app log @namchuai (#2238)"}),"\n",(0,a.jsx)(n.li,{children:"fix: drag and drop support image format to support vision model @urmauur (#2237)"}),"\n",(0,a.jsx)(n.li,{children:"fix: re-configure changelog sections @hieu-jan (#2230)"}),"\n",(0,a.jsx)(n.li,{children:"fix: import from HuggingFace with random string is causing app crash @louis-jan (#2214)"}),"\n",(0,a.jsx)(n.li,{children:"fix: comment from QA regarding import model @namchuai (#2213)"}),"\n",(0,a.jsx)(n.li,{children:"fix: download model error does not reset state in model hub @namchuai (#2199)"}),"\n",(0,a.jsx)(n.li,{children:"fix: minor ui missing secondary background @urmauur (#2198)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update docker command @hieu-jan (#2180)"}),"\n",(0,a.jsx)(n.li,{children:"fix: some bugs for import model @namchuai (#2181)"}),"\n",(0,a.jsx)(n.li,{children:"fix: change button import model on hub page @urmauur (#2178)"}),"\n",(0,a.jsx)(n.li,{children:"fix space between progress bar and title list of gpu @urmauur (#2177)"}),"\n",(0,a.jsx)(n.li,{children:"fix: disabled prompt user using dangerouslySetInnerHTML @urmauur (#2176)"}),"\n",(0,a.jsx)(n.li,{children:"fix: style list of gpus on system monitor @urmauur (#2172)"}),"\n",(0,a.jsx)(n.li,{children:"fix: system monitor expand overlap tooltip ribbon @urmauur (#2158)"}),"\n",(0,a.jsx)(n.li,{children:"Huggingface extension add codesign step for building on darwin @hiento09 (#2166)"}),"\n",(0,a.jsx)(n.li,{children:"Add run codesign for huggingface extension @hiento09 (#2163)"}),"\n",(0,a.jsx)(n.li,{children:"fix: system monitor ui @urmauur (#2135)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: temporary remove convert model @namchuai (#2266)"}),"\n",(0,a.jsx)(n.li,{children:"docs: sync slug fix from dev branch to docs branch @hieu-jan (#2264)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update broken link and fix the slug @aindrajaya (#2260)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Fix navbar issues. Keep stay when clicked other menu items from the sidebar @aindrajaya (#2253)"}),"\n",(0,a.jsx)(n.li,{children:"docs: sync docs hub fixes from dev to docs branch @hieu-jan (#2247)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update content for Hub page and Guides section @aindrajaya (#2245)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Fix Dark Mode on the Hub page and Update the Navbar functionality @aindrajaya (#2243)"}),"\n",(0,a.jsx)(n.li,{children:"chore: sync dev branch to docs branch @hieu-jan (#2239)"}),"\n",(0,a.jsx)(n.li,{children:"Chore: add prefix latest for task clean r2 bucket @hiento09 (#2233)"}),"\n",(0,a.jsx)(n.li,{children:"fix: re-configure changelog sections @hieu-jan (#2230)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add command run API server without frontend @hieu-jan (#2231)"}),"\n",(0,a.jsx)(n.li,{children:"docs: revamp entire Jan guides @hieu-jan (#2139)"}),"\n",(0,a.jsx)(n.li,{children:"chore: clean up some redundant code @namchuai (#2215)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference chatCompletions from DevDocs @avb-is-me (#2171)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference download model from DevDocs @avb-is-me (#2170)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference model_id from DevDocs @avb-is-me (#2169)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update API Reference listModel from DevDocs @avb-is-me (#2161)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update 08-antivirus-compatibility-testing.md @0xSage (#2186)"}),"\n",(0,a.jsx)(n.li,{children:"docs: adding new feature for v0.4.7 to release checklist @Van-QA (#2189)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update 01-integrate-continue.mdx @0xSage (#2187)"}),"\n",(0,a.jsx)(n.li,{children:"chore: bump nitro 0.3.14 @louis-jan (#2183)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Sync dev branch to docs branch @hieu-jan (#2185)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update docker command @hieu-jan (#2180)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update wall of love @hieu-jan (#2179)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add Jan newsletter @hieu-jan (#2174)"}),"\n",(0,a.jsx)(n.li,{children:"chore: make convert gguf as experimental feature @namchuai (#2156)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update acknowledgements @hieu-jan (#2147)"}),"\n",(0,a.jsx)(n.li,{children:"feat: restore docusaurus style @urmauur (#2152)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update run Jan in Docker mode @hieu-jan (#2150)"}),"\n",(0,a.jsx)(n.li,{children:"Docs pena team - Add Quickstart Docs @aindrajaya (#2138)"}),"\n",(0,a.jsx)(n.li,{children:"docs: hide incomplete pages @hieu-jan (#2127)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @Helloyunho, @Van-QA, @aindrajaya, @avb-is-me, @hahuyhoang411, @hiento09, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @mooncool, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(t,{...e})}):t(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>l});var a=i(96540);const r={},s=a.createContext(r);function o(e){const n=a.useContext(s);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),a.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3c380bbe.1d2311e6.js b/assets/js/3c380bbe.1d2311e6.js new file mode 100644 index 00000000..d32ec679 --- /dev/null +++ b/assets/js/3c380bbe.1d2311e6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5033],{81972:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>l,default:()=>p,frontMatter:()=>a,metadata:()=>u,toc:()=>d});var i=t(74848),o=t(28453),s=t(11470),r=t(19365);const a={title:"Continue Integration",sidebar_position:18,slug:"/integrations/continue",description:"A step-by-step guide on how to integrate Jan with Continue and VS Code.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","VSCode integration"]},l=void 0,u={id:"guides/integrations/vscode",title:"Continue Integration",description:"A step-by-step guide on how to integrate Jan with Continue and VS Code.",source:"@site/docs/guides/integrations/vscode.mdx",sourceDirName:"guides/integrations",slug:"/integrations/continue",permalink:"/integrations/continue",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/vscode.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:18,frontMatter:{title:"Continue Integration",sidebar_position:18,slug:"/integrations/continue",description:"A step-by-step guide on how to integrate Jan with Continue and VS Code.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","VSCode integration"]},sidebar:"guidesSidebar",previous:{title:"OpenRouter",permalink:"/integrations/openrouter"},next:{title:"Troubleshooting",permalink:"/troubleshooting"}},c={},d=[{value:"Integrate with Continue VS Code",id:"integrate-with-continue-vs-code",level:2},{value:"Step 1: Installing Continue on Visal Studio Code",id:"step-1-installing-continue-on-visal-studio-code",level:3},{value:"Step 2: Enable the Jan API Server",id:"step-2-enable-the-jan-api-server",level:3},{value:"Step 3: Configure Continue to Use Jan's Local Server",id:"step-3-configure-continue-to-use-jans-local-server",level:3},{value:"Step 4: Ensure the Using Model Is Activated in Jan",id:"step-4-ensure-the-using-model-is-activated-in-jan",level:3},{value:"Try out Jan integration with Continue in Visual Studio Code",id:"try-out-jan-integration-with-continue-in-visual-studio-code",level:2},{value:"1. Asking questions about the code",id:"1-asking-questions-about-the-code",level:3},{value:"2. Editing the code with the help of a large language model",id:"2-editing-the-code-with-the-help-of-a-large-language-model",level:3}];function h(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"integrate-with-continue-vs-code",children:"Integrate with Continue VS Code"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://continue.dev/docs/intro",children:"Continue"})," is an open-source autopilot compatible with Visual Studio Code and JetBrains, offering the simplest method to code with any LLM (Local Language Model)."]}),"\n",(0,i.jsx)(n.p,{children:"To integrate Jan with a local AI language model, follow the steps below:"}),"\n",(0,i.jsx)(n.h3,{id:"step-1-installing-continue-on-visal-studio-code",children:"Step 1: Installing Continue on Visal Studio Code"}),"\n",(0,i.jsxs)(n.p,{children:["Follow this ",(0,i.jsx)(n.a,{href:"https://continue.dev/docs/quickstart",children:"guide to install the Continue extension on Visual Studio Code"})]}),"\n",(0,i.jsx)(n.h3,{id:"step-2-enable-the-jan-api-server",children:"Step 2: Enable the Jan API Server"}),"\n",(0,i.jsx)(n.p,{children:"To set up Continue for use with Jan's Local Server, you must activate the Jan API Server with your chosen model."}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Press the ",(0,i.jsx)(n.code,{children:"<>"})," button. Jan will take you to the ",(0,i.jsx)(n.strong,{children:"Local API Server"})," section."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Setup the server, which includes the ",(0,i.jsx)(n.strong,{children:"IP Port"}),", ",(0,i.jsx)(n.strong,{children:"Cross-Origin-Resource-Sharing (CORS)"})," and ",(0,i.jsx)(n.strong,{children:"Verbose Server Logs"}),"."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Press the ",(0,i.jsx)(n.strong,{children:"Start Server"})," button"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"step-3-configure-continue-to-use-jans-local-server",children:"Step 3: Configure Continue to Use Jan's Local Server"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to the ",(0,i.jsx)(n.code,{children:"~/.continue"})," directory."]}),"\n"]}),"\n",(0,i.jsxs)(s.A,{children:[(0,i.jsx)(r.A,{value:"mac",label:"Mac",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"cd ~/.continue\n"})})}),(0,i.jsx)(r.A,{value:"windows",label:"Windows",children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"C:/Users//.continue\n"})})}),(0,i.jsx)(r.A,{value:"linux",label:"Linux",children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"cd ~/.continue\n"})})})]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/.continue/config.json"',children:'{\n "models": [\n {\n "title": "Jan",\n "provider": "openai",\n "model": "mistral-ins-7b-q4",\n "apiKey": "EMPTY",\n "apiBase": "http://localhost:1337/v1"\n }\n ]\n}\n'})}),"\n",(0,i.jsxs)(n.ol,{start:"2",children:["\n",(0,i.jsxs)(n.li,{children:["Ensure the file has the following configurations:","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Ensure ",(0,i.jsx)(n.code,{children:"openai"})," is selected as the ",(0,i.jsx)(n.code,{children:"provider"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Match the ",(0,i.jsx)(n.code,{children:"model"})," with the one enabled in the Jan API Server."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"apiBase"})," to ",(0,i.jsx)(n.code,{children:"http://localhost:1337"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Leave the ",(0,i.jsx)(n.code,{children:"apiKey"})," field to ",(0,i.jsx)(n.code,{children:"EMPTY"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"step-4-ensure-the-using-model-is-activated-in-jan",children:"Step 4: Ensure the Using Model Is Activated in Jan"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"Settings"})," > ",(0,i.jsx)(n.code,{children:"Models"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Activate the model you want to use in Jan by clicking the ",(0,i.jsx)(n.strong,{children:"three dots (\u22ee)"})," and select ",(0,i.jsx)(n.strong,{children:"Start Model"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"try-out-jan-integration-with-continue-in-visual-studio-code",children:"Try out Jan integration with Continue in Visual Studio Code"}),"\n",(0,i.jsx)(n.h3,{id:"1-asking-questions-about-the-code",children:"1. Asking questions about the code"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Highlight a code snippet and press ",(0,i.jsx)(n.code,{children:"Command + Shift + M"})," to open the Left Panel."]}),"\n",(0,i.jsxs)(n.li,{children:["Select Jan at the bottom and ask a question about the code, for example, ",(0,i.jsx)(n.code,{children:"Explain this code"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"2-editing-the-code-with-the-help-of-a-large-language-model",children:"2. Editing the code with the help of a large language model"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Select a code snippet and use ",(0,i.jsx)(n.code,{children:"Command + Shift + L"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Enter your editing request, such as ",(0,i.jsx)(n.code,{children:"Add comments to this code"}),"."]}),"\n"]})]})}function p(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(h,{...e})}):h(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>r});t(96540);var i=t(18215);const o={tabItem:"tabItem_Ymn6"};var s=t(74848);function r(e){let{children:n,hidden:t,className:r}=e;return(0,s.jsx)("div",{role:"tabpanel",className:(0,i.A)(o.tabItem,r),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>S});var i=t(96540),o=t(18215),s=t(23104),r=t(56347),a=t(205),l=t(57485),u=t(31682),c=t(89466);function d(e){return i.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,i.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function h(e){const{values:n,children:t}=e;return(0,i.useMemo)((()=>{const e=n??function(e){return d(e).map((e=>{let{props:{value:n,label:t,attributes:i,default:o}}=e;return{value:n,label:t,attributes:i,default:o}}))}(t);return function(e){const n=(0,u.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function g(e){let{queryString:n=!1,groupId:t}=e;const o=(0,r.W6)(),s=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,l.aZ)(s),(0,i.useCallback)((e=>{if(!s)return;const n=new URLSearchParams(o.location.search);n.set(s,e),o.replace({...o.location,search:n.toString()})}),[s,o])]}function v(e){const{defaultValue:n,queryString:t=!1,groupId:o}=e,s=h(e),[r,l]=(0,i.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const i=t.find((e=>e.default))??t[0];if(!i)throw new Error("Unexpected error: 0 tabValues");return i.value}({defaultValue:n,tabValues:s}))),[u,d]=g({queryString:t,groupId:o}),[v,f]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[o,s]=(0,c.Dv)(t);return[o,(0,i.useCallback)((e=>{t&&s.set(e)}),[t,s])]}({groupId:o}),x=(()=>{const e=u??v;return p({value:e,tabValues:s})?e:null})();(0,a.A)((()=>{x&&l(x)}),[x]);return{selectedValue:r,selectValue:(0,i.useCallback)((e=>{if(!p({value:e,tabValues:s}))throw new Error(`Can't select invalid tab value=${e}`);l(e),d(e),f(e)}),[d,f,s]),tabValues:s}}var f=t(92303);const x={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var m=t(74848);function b(e){let{className:n,block:t,selectedValue:i,selectValue:r,tabValues:a}=e;const l=[],{blockElementScrollPositionUntilNextRender:u}=(0,s.a_)(),c=e=>{const n=e.currentTarget,t=l.indexOf(n),o=a[t].value;o!==i&&(u(n),r(o))},d=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const t=l.indexOf(e.currentTarget)+1;n=l[t]??l[0];break}case"ArrowLeft":{const t=l.indexOf(e.currentTarget)-1;n=l[t]??l[l.length-1];break}}n?.focus()};return(0,m.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,o.A)("tabs",{"tabs--block":t},n),children:a.map((e=>{let{value:n,label:t,attributes:s}=e;return(0,m.jsx)("li",{role:"tab",tabIndex:i===n?0:-1,"aria-selected":i===n,ref:e=>l.push(e),onKeyDown:d,onClick:c,...s,className:(0,o.A)("tabs__item",x.tabItem,s?.className,{"tabs__item--active":i===n}),children:t??n},n)}))})}function j(e){let{lazy:n,children:t,selectedValue:o}=e;const s=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=s.find((e=>e.props.value===o));return e?(0,i.cloneElement)(e,{className:"margin-top--md"}):null}return(0,m.jsx)("div",{className:"margin-top--md",children:s.map(((e,n)=>(0,i.cloneElement)(e,{key:n,hidden:e.props.value!==o})))})}function w(e){const n=v(e);return(0,m.jsxs)("div",{className:(0,o.A)("tabs-container",x.tabList),children:[(0,m.jsx)(b,{...e,...n}),(0,m.jsx)(j,{...e,...n})]})}function S(e){const n=(0,f.A)();return(0,m.jsx)(w,{...e,children:d(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>a});var i=t(96540);const o={},s=i.createContext(o);function r(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3c380bbe.6a48a509.js b/assets/js/3c380bbe.6a48a509.js deleted file mode 100644 index f807a554..00000000 --- a/assets/js/3c380bbe.6a48a509.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5033],{81972:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>l,default:()=>p,frontMatter:()=>a,metadata:()=>u,toc:()=>d});var i=t(74848),o=t(28453),s=t(11470),r=t(19365);const a={title:"Continue Integration",sidebar_position:18,slug:"/integrations/continue",description:"A step-by-step guide on how to integrate Jan with Continue and VS Code.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","VSCode integration"]},l=void 0,u={id:"guides/integrations/vscode",title:"Continue Integration",description:"A step-by-step guide on how to integrate Jan with Continue and VS Code.",source:"@site/docs/guides/integrations/vscode.mdx",sourceDirName:"guides/integrations",slug:"/integrations/continue",permalink:"/integrations/continue",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/vscode.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:18,frontMatter:{title:"Continue Integration",sidebar_position:18,slug:"/integrations/continue",description:"A step-by-step guide on how to integrate Jan with Continue and VS Code.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","VSCode integration"]},sidebar:"guidesSidebar",previous:{title:"OpenRouter",permalink:"/integrations/openrouter"},next:{title:"Troubleshooting",permalink:"/troubleshooting"}},c={},d=[{value:"Integrate with Continue VS Code",id:"integrate-with-continue-vs-code",level:2},{value:"Step 1: Installing Continue on Visal Studio Code",id:"step-1-installing-continue-on-visal-studio-code",level:3},{value:"Step 2: Enable the Jan API Server",id:"step-2-enable-the-jan-api-server",level:3},{value:"Step 3: Configure Continue to Use Jan's Local Server",id:"step-3-configure-continue-to-use-jans-local-server",level:3},{value:"Step 4: Ensure the Using Model Is Activated in Jan",id:"step-4-ensure-the-using-model-is-activated-in-jan",level:3},{value:"Try out Jan integration with Continue in Visual Studio Code",id:"try-out-jan-integration-with-continue-in-visual-studio-code",level:2},{value:"1. Asking questions about the code",id:"1-asking-questions-about-the-code",level:3},{value:"2. Editing the code with the help of a large language model",id:"2-editing-the-code-with-the-help-of-a-large-language-model",level:3}];function h(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"integrate-with-continue-vs-code",children:"Integrate with Continue VS Code"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://continue.dev/docs/intro",children:"Continue"})," is an open-source autopilot compatible with Visual Studio Code and JetBrains, offering the simplest method to code with any LLM (Local Language Model)."]}),"\n",(0,i.jsx)(n.p,{children:"To integrate Jan with a local AI language model, follow the steps below:"}),"\n",(0,i.jsx)(n.h3,{id:"step-1-installing-continue-on-visal-studio-code",children:"Step 1: Installing Continue on Visal Studio Code"}),"\n",(0,i.jsxs)(n.p,{children:["Follow this ",(0,i.jsx)(n.a,{href:"https://continue.dev/docs/quickstart",children:"guide to install the Continue extension on Visual Studio Code"})]}),"\n",(0,i.jsx)(n.h3,{id:"step-2-enable-the-jan-api-server",children:"Step 2: Enable the Jan API Server"}),"\n",(0,i.jsx)(n.p,{children:"To set up Continue for use with Jan's Local Server, you must activate the Jan API Server with your chosen model."}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Press the ",(0,i.jsx)(n.code,{children:"<>"})," button. Jan will take you to the ",(0,i.jsx)(n.strong,{children:"Local API Server"})," section."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Setup the server, which includes the ",(0,i.jsx)(n.strong,{children:"IP Port"}),", ",(0,i.jsx)(n.strong,{children:"Cross-Origin-Resource-Sharing (CORS)"})," and ",(0,i.jsx)(n.strong,{children:"Verbose Server Logs"}),"."]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{children:["\n",(0,i.jsxs)(n.p,{children:["Press the ",(0,i.jsx)(n.strong,{children:"Start Server"})," button"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"step-3-configure-continue-to-use-jans-local-server",children:"Step 3: Configure Continue to Use Jan's Local Server"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to the ",(0,i.jsx)(n.code,{children:"~/.continue"})," directory."]}),"\n"]}),"\n",(0,i.jsxs)(s.A,{children:[(0,i.jsx)(r.A,{value:"mac",label:"Mac",default:!0,children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"cd ~/.continue\n"})})}),(0,i.jsx)(r.A,{value:"windows",label:"Windows",children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"C:/Users//.continue\n"})})}),(0,i.jsx)(r.A,{value:"linux",label:"Linux",children:(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"cd ~/.continue\n"})})})]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/.continue/config.json"',children:'{\n "models": [\n {\n "title": "Jan",\n "provider": "openai",\n "model": "mistral-ins-7b-q4",\n "apiKey": "EMPTY",\n "apiBase": "http://localhost:1337/v1"\n }\n ]\n}\n'})}),"\n",(0,i.jsxs)(n.ol,{start:"2",children:["\n",(0,i.jsxs)(n.li,{children:["Ensure the file has the following configurations:","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Ensure ",(0,i.jsx)(n.code,{children:"openai"})," is selected as the ",(0,i.jsx)(n.code,{children:"provider"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Match the ",(0,i.jsx)(n.code,{children:"model"})," with the one enabled in the Jan API Server."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"apiBase"})," to ",(0,i.jsx)(n.code,{children:"http://localhost:1337"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Leave the ",(0,i.jsx)(n.code,{children:"apiKey"})," field to ",(0,i.jsx)(n.code,{children:"EMPTY"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"step-4-ensure-the-using-model-is-activated-in-jan",children:"Step 4: Ensure the Using Model Is Activated in Jan"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"Settings"})," > ",(0,i.jsx)(n.code,{children:"Models"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Activate the model you want to use in Jan by clicking the ",(0,i.jsx)(n.strong,{children:"three dots (\u22ee)"})," and select ",(0,i.jsx)(n.strong,{children:"Start Model"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"try-out-jan-integration-with-continue-in-visual-studio-code",children:"Try out Jan integration with Continue in Visual Studio Code"}),"\n",(0,i.jsx)(n.h3,{id:"1-asking-questions-about-the-code",children:"1. Asking questions about the code"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Highlight a code snippet and press ",(0,i.jsx)(n.code,{children:"Command + Shift + M"})," to open the Left Panel."]}),"\n",(0,i.jsxs)(n.li,{children:["Select Jan at the bottom and ask a question about the code, for example, ",(0,i.jsx)(n.code,{children:"Explain this code"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"2-editing-the-code-with-the-help-of-a-large-language-model",children:"2. Editing the code with the help of a large language model"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Select a code snippet and use ",(0,i.jsx)(n.code,{children:"Command + Shift + L"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Enter your editing request, such as ",(0,i.jsx)(n.code,{children:"Add comments to this code"}),"."]}),"\n"]})]})}function p(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(h,{...e})}):h(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>r});t(96540);var i=t(18215);const o={tabItem:"tabItem_Ymn6"};var s=t(74848);function r(e){let{children:n,hidden:t,className:r}=e;return(0,s.jsx)("div",{role:"tabpanel",className:(0,i.A)(o.tabItem,r),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>S});var i=t(96540),o=t(18215),s=t(23104),r=t(56347),a=t(205),l=t(57485),u=t(31682),c=t(89466);function d(e){return i.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,i.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function h(e){const{values:n,children:t}=e;return(0,i.useMemo)((()=>{const e=n??function(e){return d(e).map((e=>{let{props:{value:n,label:t,attributes:i,default:o}}=e;return{value:n,label:t,attributes:i,default:o}}))}(t);return function(e){const n=(0,u.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function g(e){let{queryString:n=!1,groupId:t}=e;const o=(0,r.W6)(),s=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,l.aZ)(s),(0,i.useCallback)((e=>{if(!s)return;const n=new URLSearchParams(o.location.search);n.set(s,e),o.replace({...o.location,search:n.toString()})}),[s,o])]}function v(e){const{defaultValue:n,queryString:t=!1,groupId:o}=e,s=h(e),[r,l]=(0,i.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const i=t.find((e=>e.default))??t[0];if(!i)throw new Error("Unexpected error: 0 tabValues");return i.value}({defaultValue:n,tabValues:s}))),[u,d]=g({queryString:t,groupId:o}),[v,f]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[o,s]=(0,c.Dv)(t);return[o,(0,i.useCallback)((e=>{t&&s.set(e)}),[t,s])]}({groupId:o}),x=(()=>{const e=u??v;return p({value:e,tabValues:s})?e:null})();(0,a.A)((()=>{x&&l(x)}),[x]);return{selectedValue:r,selectValue:(0,i.useCallback)((e=>{if(!p({value:e,tabValues:s}))throw new Error(`Can't select invalid tab value=${e}`);l(e),d(e),f(e)}),[d,f,s]),tabValues:s}}var f=t(92303);const x={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var m=t(74848);function b(e){let{className:n,block:t,selectedValue:i,selectValue:r,tabValues:a}=e;const l=[],{blockElementScrollPositionUntilNextRender:u}=(0,s.a_)(),c=e=>{const n=e.currentTarget,t=l.indexOf(n),o=a[t].value;o!==i&&(u(n),r(o))},d=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const t=l.indexOf(e.currentTarget)+1;n=l[t]??l[0];break}case"ArrowLeft":{const t=l.indexOf(e.currentTarget)-1;n=l[t]??l[l.length-1];break}}n?.focus()};return(0,m.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,o.A)("tabs",{"tabs--block":t},n),children:a.map((e=>{let{value:n,label:t,attributes:s}=e;return(0,m.jsx)("li",{role:"tab",tabIndex:i===n?0:-1,"aria-selected":i===n,ref:e=>l.push(e),onKeyDown:d,onClick:c,...s,className:(0,o.A)("tabs__item",x.tabItem,s?.className,{"tabs__item--active":i===n}),children:t??n},n)}))})}function j(e){let{lazy:n,children:t,selectedValue:o}=e;const s=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=s.find((e=>e.props.value===o));return e?(0,i.cloneElement)(e,{className:"margin-top--md"}):null}return(0,m.jsx)("div",{className:"margin-top--md",children:s.map(((e,n)=>(0,i.cloneElement)(e,{key:n,hidden:e.props.value!==o})))})}function w(e){const n=v(e);return(0,m.jsxs)("div",{className:(0,o.A)("tabs-container",x.tabList),children:[(0,m.jsx)(b,{...e,...n}),(0,m.jsx)(j,{...e,...n})]})}function S(e){const n=(0,f.A)();return(0,m.jsx)(w,{...e,children:d(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>a});var i=t(96540);const o={},s=i.createContext(o);function r(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/3cca42cf.7f3ad9e5.js b/assets/js/3cca42cf.7f3ad9e5.js deleted file mode 100644 index b441eb0d..00000000 --- a/assets/js/3cca42cf.7f3ad9e5.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2244],{53955:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var o=e(74848),s=e(28453);const i={title:"Unsloth",sidebar_position:20,slug:"/integrations/unsloth",description:"A step-by-step guide on how to integrate Jan with Unsloth.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","Unsloth integration"]},r=void 0,a={id:"guides/integrations/unsloth",title:"Unsloth",description:"A step-by-step guide on how to integrate Jan with Unsloth.",source:"@site/docs/guides/integrations/unsloth.mdx",sourceDirName:"guides/integrations",slug:"/integrations/unsloth",permalink:"/integrations/unsloth",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/unsloth.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:20,frontMatter:{title:"Unsloth",sidebar_position:20,slug:"/integrations/unsloth",description:"A step-by-step guide on how to integrate Jan with Unsloth.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","Unsloth integration"]}},l={},c=[];function u(t){const n={p:"p",...(0,s.R)(),...t.components};return(0,o.jsx)(n.p,{children:"Coming Soon"})}function d(t={}){const{wrapper:n}={...(0,s.R)(),...t.components};return n?(0,o.jsx)(n,{...t,children:(0,o.jsx)(u,{...t})}):u(t)}},28453:(t,n,e)=>{e.d(n,{R:()=>r,x:()=>a});var o=e(96540);const s={},i=o.createContext(s);function r(t){const n=o.useContext(i);return o.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function a(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:r(t.components),o.createElement(i.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/3cca42cf.acf9c0bc.js b/assets/js/3cca42cf.acf9c0bc.js new file mode 100644 index 00000000..aee79932 --- /dev/null +++ b/assets/js/3cca42cf.acf9c0bc.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2244],{53955:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var o=e(74848),s=e(28453);const i={title:"Unsloth",sidebar_position:20,slug:"/integrations/unsloth",description:"A step-by-step guide on how to integrate Jan with Unsloth.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","Unsloth integration"]},r=void 0,a={id:"guides/integrations/unsloth",title:"Unsloth",description:"A step-by-step guide on how to integrate Jan with Unsloth.",source:"@site/docs/guides/integrations/unsloth.mdx",sourceDirName:"guides/integrations",slug:"/integrations/unsloth",permalink:"/integrations/unsloth",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/unsloth.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:20,frontMatter:{title:"Unsloth",sidebar_position:20,slug:"/integrations/unsloth",description:"A step-by-step guide on how to integrate Jan with Unsloth.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Continue integration","Unsloth integration"]}},l={},c=[];function u(t){const n={p:"p",...(0,s.R)(),...t.components};return(0,o.jsx)(n.p,{children:"Coming Soon"})}function d(t={}){const{wrapper:n}={...(0,s.R)(),...t.components};return n?(0,o.jsx)(n,{...t,children:(0,o.jsx)(u,{...t})}):u(t)}},28453:(t,n,e)=>{e.d(n,{R:()=>r,x:()=>a});var o=e(96540);const s={},i=o.createContext(s);function r(t){const n=o.useContext(i);return o.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function a(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:r(t.components),o.createElement(i.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/3f026702.26f48047.js b/assets/js/3f026702.26f48047.js deleted file mode 100644 index cb3996ee..00000000 --- a/assets/js/3f026702.26f48047.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6505],{93672:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>l,frontMatter:()=>r,metadata:()=>i,toc:()=>u});var o=e(74848),s=e(28453);const r={title:"Jan's Vision for 2035"},a=void 0,i={id:"about/2035",title:"Jan's Vision for 2035",description:"Jan 2035: A Robotics Company",source:"@site/docs/about/2035.mdx",sourceDirName:"about",slug:"/about/2035",permalink:"/about/2035",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/2035.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan's Vision for 2035"}},c={},u=[];function d(t){const n={a:"a",li:"li",p:"p",ul:"ul",...(0,s.R)(),...t.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.p,{children:(0,o.jsx)(n.a,{href:"https://hackmd.io/QIWyYbNNQVWVbupuI3kjAA",children:"Jan 2035: A Robotics Company"})}),"\n",(0,o.jsx)(n.p,{children:"We only have 2 planning parameters:"}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsx)(n.li,{children:"10 year vision"}),"\n",(0,o.jsx)(n.li,{children:"2 week sprint"}),"\n"]}),"\n",(0,o.jsx)(n.p,{children:"And we measure our success on Quarterly OKRs"})]})}function l(t={}){const{wrapper:n}={...(0,s.R)(),...t.components};return n?(0,o.jsx)(n,{...t,children:(0,o.jsx)(d,{...t})}):d(t)}},28453:(t,n,e)=>{e.d(n,{R:()=>a,x:()=>i});var o=e(96540);const s={},r=o.createContext(s);function a(t){const n=o.useContext(r);return o.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function i(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:a(t.components),o.createElement(r.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/3f026702.933bc4f3.js b/assets/js/3f026702.933bc4f3.js new file mode 100644 index 00000000..4783b277 --- /dev/null +++ b/assets/js/3f026702.933bc4f3.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6505],{93672:(t,n,e)=>{e.r(n),e.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>l,frontMatter:()=>r,metadata:()=>i,toc:()=>u});var o=e(74848),s=e(28453);const r={title:"Jan's Vision for 2035"},a=void 0,i={id:"about/2035",title:"Jan's Vision for 2035",description:"Jan 2035: A Robotics Company",source:"@site/docs/about/2035.mdx",sourceDirName:"about",slug:"/about/2035",permalink:"/about/2035",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/2035.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan's Vision for 2035"}},c={},u=[];function d(t){const n={a:"a",li:"li",p:"p",ul:"ul",...(0,s.R)(),...t.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.p,{children:(0,o.jsx)(n.a,{href:"https://hackmd.io/QIWyYbNNQVWVbupuI3kjAA",children:"Jan 2035: A Robotics Company"})}),"\n",(0,o.jsx)(n.p,{children:"We only have 2 planning parameters:"}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsx)(n.li,{children:"10 year vision"}),"\n",(0,o.jsx)(n.li,{children:"2 week sprint"}),"\n"]}),"\n",(0,o.jsx)(n.p,{children:"And we measure our success on Quarterly OKRs"})]})}function l(t={}){const{wrapper:n}={...(0,s.R)(),...t.components};return n?(0,o.jsx)(n,{...t,children:(0,o.jsx)(d,{...t})}):d(t)}},28453:(t,n,e)=>{e.d(n,{R:()=>a,x:()=>i});var o=e(96540);const s={},r=o.createContext(s);function a(t){const n=o.useContext(r);return o.useMemo((function(){return"function"==typeof t?t(n):{...n,...t}}),[n,t])}function i(t){let n;return n=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:a(t.components),o.createElement(r.Provider,{value:n},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/3f2d68e5.7c8c54c1.js b/assets/js/3f2d68e5.7c8c54c1.js new file mode 100644 index 00000000..2bab2909 --- /dev/null +++ b/assets/js/3f2d68e5.7c8c54c1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6470],{36529:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>u,frontMatter:()=>i,metadata:()=>r,toc:()=>c});var s=n(74848),o=n(28453);const i={title:"Use Tools",slug:"/guides/tools",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","use tools","rag","retrieval","chat with pdf"]},a=void 0,r={id:"guides/user-guides/use-tools",title:"Use Tools",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/use-tools.mdx",sourceDirName:"guides/user-guides",slug:"/guides/tools",permalink:"/guides/tools",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/use-tools.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Use Tools",slug:"/guides/tools",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","use tools","rag","retrieval","chat with pdf"]},sidebar:"guidesSidebar",previous:{title:"Manage Threads",permalink:"/guides/threads"},next:{title:"Local API Server",permalink:"/guides/local-api"}},l={},c=[{value:"Retrieval",id:"retrieval",level:2},{value:"Web Search",id:"web-search",level:2},{value:"Desktop Search",id:"desktop-search",level:2}];function d(e){const t={a:"a",admonition:"admonition",h2:"h2",li:"li",ol:"ol",p:"p",strong:"strong",...(0,o.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:"This article lists the capabilities of the Jan platform and guides you through using RAG to chat with PDF documents, web and desktop searches."}),"\n",(0,s.jsx)(t.h2,{id:"retrieval",children:"Retrieval"}),"\n",(0,s.jsx)(t.p,{children:"To chat with PDFs using RAG in Jan, follow these steps:"}),"\n",(0,s.jsx)(t.admonition,{type:"caution",children:(0,s.jsxs)(t.p,{children:["Please turn on Experimental mode in Settings to use this feature. ",(0,s.jsx)(t.a,{href:"/guides/advanced/#enable-the-experimental-mode",children:"Read more"}),"."]})}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsxs)(t.li,{children:["Create a ",(0,s.jsx)(t.strong,{children:"new thread"}),"."]}),"\n",(0,s.jsx)(t.li,{children:"Click on the \ud83d\udcce icon in the chat input field."}),"\n",(0,s.jsx)(t.li,{children:"Upload your PDF."}),"\n",(0,s.jsx)(t.li,{children:"Chat with your PDF."}),"\n"]}),"\n",(0,s.jsx)(t.h2,{id:"web-search",children:"Web Search"}),"\n",(0,s.jsx)(t.admonition,{type:"info",children:(0,s.jsx)(t.p,{children:"Coming soon"})}),"\n",(0,s.jsx)(t.h2,{id:"desktop-search",children:"Desktop Search"}),"\n",(0,s.jsx)(t.admonition,{type:"info",children:(0,s.jsx)(t.p,{children:"Coming soon"})})]})}function u(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>r});var s=n(96540);const o={},i=s.createContext(o);function a(e){const t=s.useContext(i);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),s.createElement(i.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/43e2ca0d.97f51c02.js b/assets/js/43e2ca0d.97f51c02.js new file mode 100644 index 00000000..689116fa --- /dev/null +++ b/assets/js/43e2ca0d.97f51c02.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3929],{7383:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>s,default:()=>p,frontMatter:()=>i,metadata:()=>a,toc:()=>d});var o=n(74848),r=n(28453);const i={title:"OpenRouter"},s=void 0,a={id:"integrations/openrouter",title:"OpenRouter",description:"Requested, committed, but not started",source:"@site/docs/integrations/openrouter.md",sourceDirName:"integrations",slug:"/integrations/openrouter",permalink:"/integrations/openrouter",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/openrouter.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"OpenRouter"},sidebar:"ecosystemSidebar",previous:{title:"OpenAI",permalink:"/integrations/openai"}},c={},d=[];function u(t){const e={admonition:"admonition",p:"p",...(0,r.R)(),...t.components};return(0,o.jsx)(e.admonition,{type:"caution",children:(0,o.jsx)(e.p,{children:"Requested, committed, but not started"})})}function p(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(u,{...t})}):u(t)}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>a});var o=n(96540);const r={},i=o.createContext(r);function s(t){const e=o.useContext(i);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:s(t.components),o.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/43e2ca0d.d4930fab.js b/assets/js/43e2ca0d.d4930fab.js deleted file mode 100644 index 41012cc1..00000000 --- a/assets/js/43e2ca0d.d4930fab.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3929],{7383:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>s,default:()=>p,frontMatter:()=>i,metadata:()=>a,toc:()=>d});var o=n(74848),r=n(28453);const i={title:"OpenRouter"},s=void 0,a={id:"integrations/openrouter",title:"OpenRouter",description:"Requested, committed, but not started",source:"@site/docs/integrations/openrouter.md",sourceDirName:"integrations",slug:"/integrations/openrouter",permalink:"/integrations/openrouter",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/openrouter.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"OpenRouter"},sidebar:"ecosystemSidebar",previous:{title:"OpenAI",permalink:"/integrations/openai"}},c={},d=[];function u(t){const e={admonition:"admonition",p:"p",...(0,r.R)(),...t.components};return(0,o.jsx)(e.admonition,{type:"caution",children:(0,o.jsx)(e.p,{children:"Requested, committed, but not started"})})}function p(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(u,{...t})}):u(t)}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>a});var o=n(96540);const r={},i=o.createContext(r);function s(t){const e=o.useContext(i);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:s(t.components),o.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/44215aaa.260981c8.js b/assets/js/44215aaa.260981c8.js new file mode 100644 index 00000000..5c9a32aa --- /dev/null +++ b/assets/js/44215aaa.260981c8.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4940],{73688:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>o,default:()=>m,frontMatter:()=>c,metadata:()=>i,toc:()=>d});var s=n(74848),r=n(28453);const c={title:"Identity & Access Control"},o=void 0,i={id:"server-suite/identity-access-management",title:"Identity & Access Control",description:"",source:"@site/docs/server-suite/identity-access-management.md",sourceDirName:"server-suite",slug:"/server-suite/identity-access-management",permalink:"/server-suite/identity-access-management",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/identity-access-management.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Identity & Access Control"}},a={},d=[];function u(e){return(0,s.jsx)(s.Fragment,{})}function m(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(u,{...e})}):u()}},28453:(e,t,n)=>{n.d(t,{R:()=>o,x:()=>i});var s=n(96540);const r={},c=s.createContext(r);function o(e){const t=s.useContext(c);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),s.createElement(c.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/44215aaa.8ea1686a.js b/assets/js/44215aaa.8ea1686a.js deleted file mode 100644 index 0e9c4963..00000000 --- a/assets/js/44215aaa.8ea1686a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4940],{73688:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>o,default:()=>m,frontMatter:()=>c,metadata:()=>i,toc:()=>d});var s=n(74848),r=n(28453);const c={title:"Identity & Access Control"},o=void 0,i={id:"server-suite/identity-access-management",title:"Identity & Access Control",description:"",source:"@site/docs/server-suite/identity-access-management.md",sourceDirName:"server-suite",slug:"/server-suite/identity-access-management",permalink:"/server-suite/identity-access-management",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/identity-access-management.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Identity & Access Control"}},a={},d=[];function u(e){return(0,s.jsx)(s.Fragment,{})}function m(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(u,{...e})}):u()}},28453:(e,t,n)=>{n.d(t,{R:()=>o,x:()=>i});var s=n(96540);const r={},c=s.createContext(r);function o(e){const t=s.useContext(c);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),s.createElement(c.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/47cd42b6.4c64b24b.js b/assets/js/47cd42b6.4c64b24b.js new file mode 100644 index 00000000..b681ecfa --- /dev/null +++ b/assets/js/47cd42b6.4c64b24b.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7523],{30364:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>o,contentTitle:()=>a,default:()=>h,frontMatter:()=>i,metadata:()=>l,toc:()=>d});var s=t(74848),r=t(28453);const i={title:"Architecture",slug:"/developer/architecture",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","architecture"]},a=void 0,l={id:"developer/overview/architecture",title:"Architecture",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/01-architecture.md",sourceDirName:"developer/01-overview",slug:"/developer/architecture",permalink:"/developer/architecture",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/01-architecture.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Architecture",slug:"/developer/architecture",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","architecture"]},sidebar:"developerSidebar",previous:{title:"Overview",permalink:"/developer"},next:{title:"File-based Approach",permalink:"/developer/file-based"}},o={},d=[{value:"Overview",id:"overview",level:2},{value:"Extensions",id:"extensions",level:2},{value:"Modules",id:"modules",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",li:"li",p:"p",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.admonition,{type:"warning",children:(0,s.jsx)(n.p,{children:"This page is still under construction, and should be read as a scratchpad"})}),"\n",(0,s.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Jan has a modular architecture and is largely built on top of its own modules."}),"\n",(0,s.jsxs)(n.li,{children:["Jan uses a local ",(0,s.jsx)(n.a,{href:"/developer/file-based",children:"file-based approach"})," for data persistence."]}),"\n",(0,s.jsxs)(n.li,{children:["Jan provides an Electron-based ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Desktop UI"}),"."]}),"\n",(0,s.jsxs)(n.li,{children:["Jan provides an embeddable inference engine, written in C++, called ",(0,s.jsx)(n.a,{href:"https://nitro.jan.ai/docs/",children:"Nitro"}),"."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"extensions",children:"Extensions"}),"\n",(0,s.jsx)(n.p,{children:"Jan has an Extensions API inspired by VSCode. In fact, most of Jan's core services are built as extensions."}),"\n",(0,s.jsx)(n.p,{children:"Jan supports the following OpenAI compatible extensions:"}),"\n",(0,s.jsxs)(n.table,{children:[(0,s.jsx)(n.thead,{children:(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.th,{children:"Jan Module"}),(0,s.jsx)(n.th,{children:"Description"}),(0,s.jsx)(n.th,{children:"API Docs"})]})}),(0,s.jsxs)(n.tbody,{children:[(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Chat"}),(0,s.jsx)(n.td,{children:"Inference"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Chat-Completion",children:"/chats"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Models"}),(0,s.jsx)(n.td,{children:"Models"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Models",children:"/models"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Assistants"}),(0,s.jsx)(n.td,{children:"Apps"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Assistants",children:"/assistants"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Threads"}),(0,s.jsx)(n.td,{children:"Conversations"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Threads",children:"/threads"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Messages"}),(0,s.jsx)(n.td,{children:"Messages"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Messages",children:"/messages"})})]})]})]}),"\n",(0,s.jsx)(n.h2,{id:"modules",children:"Modules"}),"\n",(0,s.jsx)(n.p,{children:"Modules are low level, system services. It is similar to OS kernel modules. Modules provide abstractions to basic, device level functionality like working with the filesystem, device system, databases, AI inference engines, etc."}),"\n",(0,s.jsxs)(n.p,{children:["Jan follows the ",(0,s.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Dependency_inversion_principle",children:"dependency inversion principle"})," such that ",(0,s.jsx)(n.code,{children:"modules"})," expose the interfaces that ",(0,s.jsx)(n.code,{children:"extensions"})," can then implement."]})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>l});var s=t(96540);const r={},i=s.createContext(r);function a(e){const n=s.useContext(i);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),s.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/47cd42b6.83d5b356.js b/assets/js/47cd42b6.83d5b356.js deleted file mode 100644 index 0e166792..00000000 --- a/assets/js/47cd42b6.83d5b356.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7523],{30364:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>o,contentTitle:()=>a,default:()=>h,frontMatter:()=>i,metadata:()=>l,toc:()=>d});var s=t(74848),r=t(28453);const i={title:"Architecture",slug:"/developer/architecture",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","architecture"]},a=void 0,l={id:"developer/overview/architecture",title:"Architecture",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/01-architecture.md",sourceDirName:"developer/01-overview",slug:"/developer/architecture",permalink:"/developer/architecture",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/01-architecture.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Architecture",slug:"/developer/architecture",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","architecture"]},sidebar:"developerSidebar",previous:{title:"Overview",permalink:"/developer"},next:{title:"File-based Approach",permalink:"/developer/file-based"}},o={},d=[{value:"Overview",id:"overview",level:2},{value:"Extensions",id:"extensions",level:2},{value:"Modules",id:"modules",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",li:"li",p:"p",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.admonition,{type:"warning",children:(0,s.jsx)(n.p,{children:"This page is still under construction, and should be read as a scratchpad"})}),"\n",(0,s.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Jan has a modular architecture and is largely built on top of its own modules."}),"\n",(0,s.jsxs)(n.li,{children:["Jan uses a local ",(0,s.jsx)(n.a,{href:"/developer/file-based",children:"file-based approach"})," for data persistence."]}),"\n",(0,s.jsxs)(n.li,{children:["Jan provides an Electron-based ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Desktop UI"}),"."]}),"\n",(0,s.jsxs)(n.li,{children:["Jan provides an embeddable inference engine, written in C++, called ",(0,s.jsx)(n.a,{href:"https://nitro.jan.ai/docs/",children:"Nitro"}),"."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"extensions",children:"Extensions"}),"\n",(0,s.jsx)(n.p,{children:"Jan has an Extensions API inspired by VSCode. In fact, most of Jan's core services are built as extensions."}),"\n",(0,s.jsx)(n.p,{children:"Jan supports the following OpenAI compatible extensions:"}),"\n",(0,s.jsxs)(n.table,{children:[(0,s.jsx)(n.thead,{children:(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.th,{children:"Jan Module"}),(0,s.jsx)(n.th,{children:"Description"}),(0,s.jsx)(n.th,{children:"API Docs"})]})}),(0,s.jsxs)(n.tbody,{children:[(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Chat"}),(0,s.jsx)(n.td,{children:"Inference"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Chat-Completion",children:"/chats"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Models"}),(0,s.jsx)(n.td,{children:"Models"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Models",children:"/models"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Assistants"}),(0,s.jsx)(n.td,{children:"Apps"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Assistants",children:"/assistants"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Threads"}),(0,s.jsx)(n.td,{children:"Conversations"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Threads",children:"/threads"})})]}),(0,s.jsxs)(n.tr,{children:[(0,s.jsx)(n.td,{children:"Messages"}),(0,s.jsx)(n.td,{children:"Messages"}),(0,s.jsx)(n.td,{children:(0,s.jsx)(n.a,{href:"/api-reference/#tag/Messages",children:"/messages"})})]})]})]}),"\n",(0,s.jsx)(n.h2,{id:"modules",children:"Modules"}),"\n",(0,s.jsx)(n.p,{children:"Modules are low level, system services. It is similar to OS kernel modules. Modules provide abstractions to basic, device level functionality like working with the filesystem, device system, databases, AI inference engines, etc."}),"\n",(0,s.jsxs)(n.p,{children:["Jan follows the ",(0,s.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Dependency_inversion_principle",children:"dependency inversion principle"})," such that ",(0,s.jsx)(n.code,{children:"modules"})," expose the interfaces that ",(0,s.jsx)(n.code,{children:"extensions"})," can then implement."]})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>l});var s=t(96540);const r={},i=s.createContext(r);function a(e){const n=s.useContext(i);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),s.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/4a916acb.07709420.js b/assets/js/4a916acb.07709420.js new file mode 100644 index 00000000..f6115a94 --- /dev/null +++ b/assets/js/4a916acb.07709420.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4368],{89734:(e,s,t)=>{t.r(s),t.d(s,{assets:()=>c,contentTitle:()=>o,default:()=>l,frontMatter:()=>i,metadata:()=>a,toc:()=>h});var n=t(74848),r=t(28453);const i={title:"GPUs and VRAM"},o=void 0,a={id:"hardware/concepts/gpu-and-vram",title:"GPUs and VRAM",description:"What Is a GPU?",source:"@site/docs/hardware/concepts/gpu-and-vram.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/gpu-and-vram",permalink:"/hardware/concepts/gpu-and-vram",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/gpu-and-vram.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"GPUs and VRAM"}},c={},h=[{value:"What Is a GPU?",id:"what-is-a-gpu",level:2},{value:"What Are GPUs Used For?",id:"what-are-gpus-used-for",level:2},{value:"Here are some example use cases:",id:"here-are-some-example-use-cases",level:3},{value:"What is VRAM In GPU?",id:"what-is-vram-in-gpu",level:2},{value:"What makes VRAM and RAM different from each other?",id:"what-makes-vram-and-ram-different-from-each-other",level:2},{value:"RAM (Random Access Memory):",id:"ram-random-access-memory",level:3},{value:"VRAM (Video Random Access Memory):",id:"vram-video-random-access-memory",level:3},{value:"How to Connect GPU to the Motherboard via PCIe",id:"how-to-connect-gpu-to-the-motherboard-via-pcie",level:2},{value:"How to Choose a Graphics Card for your AI works",id:"how-to-choose-a-graphics-card-for-your-ai-works",level:2},{value:"Here are some of the best GPU options for this purpose:",id:"here-are-some-of-the-best-gpu-options-for-this-purpose",level:3}];function d(e){const s={a:"a",blockquote:"blockquote",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,r.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(s.h2,{id:"what-is-a-gpu",children:"What Is a GPU?"}),"\n",(0,n.jsxs)(s.p,{children:["A Graphics Card, or GPU (Graphics Processing Unit), is a fundamental component in modern computing. Think of it as the powerhouse behind rendering the stunning visuals you see on your screen. Similar to the motherboard in your computer, the graphics card is a printed circuit board. However, it's not just a passive piece of hardware; it's a sophisticated device equipped with essential components like fans, onboard RAM, a dedicated memory controller, BIOS, and various other features. If you want to learn more about GPUs then read here to ",(0,n.jsx)(s.a,{href:"https://medium.com/codex/understanding-the-architecture-of-a-gpu-d5d2d2e8978b",children:"Understand the architecture of a GPU."})]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"GPU Image",src:t(72156).A+"",width:"1200",height:"674"})}),"\n",(0,n.jsx)(s.h2,{id:"what-are-gpus-used-for",children:"What Are GPUs Used For?"}),"\n",(0,n.jsx)(s.p,{children:"Two decades ago, GPUs primarily enhanced real-time 3D graphics in gaming. But as the 21st century dawned, a revelation occurred among computer scientists. They recognized that GPUs held untapped potential to solve some of the world's most intricate computing tasks.\nThis revelation marked the dawn of the general-purpose GPU era. Today's GPUs have evolved into versatile tools, more adaptable than ever before. They now have the capability to accelerate a diverse range of applications that stretch well beyond their original graphics-focused purpose."}),"\n",(0,n.jsx)(s.h3,{id:"here-are-some-example-use-cases",children:(0,n.jsx)(s.strong,{children:"Here are some example use cases:"})}),"\n",(0,n.jsxs)(s.ol,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Gaming"}),": They make games look good and run smoothly."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Content Creation"}),": Help with video editing, 3D design, and graphics work."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"AI and Machine Learning"}),": Used for training smart machines."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Science"}),": Speed up scientific calculations and simulations."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Cryptocurrency Mining"}),": Mine digital currencies like Bitcoin."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Medical Imaging"}),": Aid in analyzing medical images."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Self-Driving Cars"}),": Help cars navigate autonomously."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Simulations"}),": Create realistic virtual experiences."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Data Analysis"}),": Speed up data processing and visualization."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Video Streaming"}),": Improve video quality and streaming efficiency."]}),"\n"]}),"\n",(0,n.jsx)(s.h2,{id:"what-is-vram-in-gpu",children:"What is VRAM In GPU?"}),"\n",(0,n.jsx)(s.p,{children:"VRAM, or video random-access memory, is a type of high-speed memory that is specifically designed for use with graphics processing units (GPUs). VRAM is used to store the textures, images, and other data that the GPU needs to render graphics. Its allows the GPU to access the data it needs quickly and efficiently. This is essential for rendering complex graphics at high frame rates."}),"\n",(0,n.jsx)(s.p,{children:"VRAM is different from other types of memory, such as the system RAM that is used by the CPU. VRAM is optimized for high bandwidth and low latency, which means that it can read and write data very quickly. The amount of VRAM that a GPU has is one of the factors that determines its performance. More VRAM allows the GPU to store more data and render more complex graphics. However, VRAM is also one of the most expensive components of a GPU. So when choosing a graphics card, it is important to consider the amount of VRAM that it has. If you are planning on running demanding LLMs or video games, or 3D graphics software, you will need a graphics card with more VRAM."}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"VRAM",src:t(41560).A+"",width:"1500",height:"900"})}),"\n",(0,n.jsx)(s.h2,{id:"what-makes-vram-and-ram-different-from-each-other",children:"What makes VRAM and RAM different from each other?"}),"\n",(0,n.jsx)(s.p,{children:"RAM (Random Access Memory) and VRAM (Video Random Access Memory) are both types of memory used in computers, but they have different functions and characteristics. Here are the differences between RAM and VRAM."}),"\n",(0,n.jsx)(s.h3,{id:"ram-random-access-memory",children:"RAM (Random Access Memory):"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"RAM is a general-purpose memory that stores data and instructions that the CPU needs to access quickly."}),"\n",(0,n.jsx)(s.li,{children:"RAM is used for short-term data storage and is volatile, meaning that it loses its contents when the computer is turned off."}),"\n",(0,n.jsx)(s.li,{children:"RAM is connected to the motherboard and is accessed by the CPU."}),"\n",(0,n.jsx)(s.li,{children:"RAM typically has a larger capacity compared to VRAM, which is designed to store smaller amounts of data with faster access times."}),"\n",(0,n.jsx)(s.li,{children:"RAM stores data related to the operating system and the various programs that are running, including code, program files, and user data."}),"\n"]}),"\n",(0,n.jsx)(s.h3,{id:"vram-video-random-access-memory",children:"VRAM (Video Random Access Memory):"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"VRAM is a type of RAM that is specifically used to store image data for a computer display."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is a graphics card component that is connected to the GPU (Graphics Processing Unit)."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is used exclusively by the GPU and doesn\u2019t need to store as much data as the CPU."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is similar to RAM in that it is volatile and loses its contents when the computer is turned off."}),"\n",(0,n.jsx)(s.li,{children:"VRAM stores data related specifically to graphics, such as textures, frames, and other graphical data."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is designed to store smaller amounts of data with faster access times than RAM."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"In summary, RAM is used for general-purpose memory, while VRAM is used for graphics-related tasks. RAM has a larger capacity and is accessed by the CPU, while VRAM has a smaller capacity and is accessed by the GPU."}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.strong,{children:"Key differences between VRAM and RAM:"})}),"\n",(0,n.jsxs)(s.table,{children:[(0,n.jsx)(s.thead,{children:(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.th,{children:"Characteristic"}),(0,n.jsx)(s.th,{children:"VRAM"}),(0,n.jsx)(s.th,{children:"RAM"})]})}),(0,n.jsxs)(s.tbody,{children:[(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Purpose"}),(0,n.jsx)(s.td,{children:"Graphics processing"}),(0,n.jsx)(s.td,{children:"General processing"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Speed"}),(0,n.jsx)(s.td,{children:"Faster"}),(0,n.jsx)(s.td,{children:"Slower"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Latency"}),(0,n.jsx)(s.td,{children:"Lower"}),(0,n.jsx)(s.td,{children:"Higher"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Bandwidth"}),(0,n.jsx)(s.td,{children:"Higher"}),(0,n.jsx)(s.td,{children:"Lower"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Cost"}),(0,n.jsx)(s.td,{children:"More expensive"}),(0,n.jsx)(s.td,{children:"Less expensive"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Availability"}),(0,n.jsx)(s.td,{children:"Less widely available"}),(0,n.jsx)(s.td,{children:"More widely available"})]})]})]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"RAM-VRAM",src:t(36165).A+"",width:"824",height:"207"})}),"\n",(0,n.jsx)(s.h2,{id:"how-to-connect-gpu-to-the-motherboard-via-pcie",children:"How to Connect GPU to the Motherboard via PCIe"}),"\n",(0,n.jsx)(s.p,{children:"Connecting hardware components to a motherboard is often likened to assembling LEGO pieces. If the parts fit together seamlessly, you're on the right track. Experienced PC builders find this process straightforward. However, for first-time builders, identifying where each hardware component belongs on the motherboard can be a bit perplexing."}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.strong,{children:"So follow the below 5 steps to Connect your GPU to the Motherboard:"})}),"\n",(0,n.jsxs)(s.ol,{children:["\n",(0,n.jsx)(s.li,{children:"First, make sure your computer is powered off and unplugged from the electrical outlet to ensure safety."}),"\n",(0,n.jsx)(s.li,{children:"Open your computer case if necessary to access the motherboard. Locate the PCIe x16 on the motherboard where you'll install the GPU. These slots are typically longer than other expansion slots and are used for graphics cards.\nRemove Slot Covers (if applicable): Some PCIe slots may have protective covers or brackets covering them. Remove these covers by unscrewing them from the case using a Phillips-head screwdriver. And PCIe x16 will have plastic lock on one side only. There may be more than one PCIe x16 slot depending on the motherboard. You can use any of the slots according to your choice."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"PCIe x16",src:t(65306).A+"",width:"1600",height:"870"})}),"\n",(0,n.jsxs)(s.ol,{start:"3",children:["\n",(0,n.jsx)(s.li,{children:"Now Insert the Graphics Card slowly:"}),"\n"]}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"Unlock the plastic lock on one side of the PCIe x16 slot by pulling it outwards."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"slot",src:t(3602).A+"",width:"784",height:"461"})}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"Align the PCIe slot with your graphics card, making sure that the HDMI port side of the GPU faces the rear side of the CPU case."}),"\n",(0,n.jsx)(s.li,{children:"Gently press on the card until you hear it securely snap in place."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"GPU",src:t(65958).A+"",width:"743",height:"348"})}),"\n",(0,n.jsxs)(s.ol,{start:"4",children:["\n",(0,n.jsx)(s.li,{children:"Insert the Power Connector: If your GPU requires additional power (most modern GPUs do), connect the necessary power cables from your power supply to the GPU's power connectors. These connectors are usually located on the top or side of the GPU."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"Power",src:t(7011).A+"",width:"742",height:"415"})}),"\n",(0,n.jsxs)(s.ol,{start:"5",children:["\n",(0,n.jsx)(s.li,{children:"Power on the System: After turning on the PC see if the fans on your graphics card spin. If it does not spin, remove the power cable from the GPU, reconnect it, and power on the PC again."}),"\n"]}),"\n",(0,n.jsxs)(s.blockquote,{children:["\n",(0,n.jsxs)(s.p,{children:["\ud83d\udcdd"," Note: To better understand you can also watch YouTube tutorials on how to Connect the GPU to the Motherboard via PCIe"]}),"\n"]}),"\n",(0,n.jsx)(s.h2,{id:"how-to-choose-a-graphics-card-for-your-ai-works",children:"How to Choose a Graphics Card for your AI works"}),"\n",(0,n.jsx)(s.p,{children:"Selecting the optimal GPU for running Large Language Models (LLMs) on your home PC is a decision influenced by your budget and the specific LLMs you intend to work with. Your choice should strike a balance between performance, efficiency, and cost-effectiveness."}),"\n",(0,n.jsx)(s.p,{children:"In general, the following GPU features are important for running LLMs:"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"High VRAM:"}),"\xa0LLMs are typically very large and complex models, so they require a GPU with a high amount of VRAM. This will allow the model to be loaded into memory and processed efficiently."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"CUDA Compatibility:"}),"\xa0When running LLMs on a GPU, CUDA compatibility is paramount. CUDA is NVIDIA's parallel computing platform, and it plays a vital role in accelerating deep learning tasks. LLMs, with their extensive matrix calculations, heavily rely on parallel processing. Ensuring your GPU supports CUDA is like having the right tool for the job. It allows the LLM to leverage the GPU's parallel processing capabilities, significantly speeding up model training and inference."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Number of CUDA, Tensor, and RT Cores:"}),"\xa0High-performance NVIDIA GPUs have both CUDA and Tensor cores. These cores are responsible for executing the neural network computations that underpin LLMs' language understanding and generation. The more CUDA cores your GPU has, the better equipped it is to handle the massive computational load that LLMs impose. Tensor cores in your GPU, further enhance LLM performance by accelerating the critical matrix operations integral to language modeling tasks."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Generation (Series)"}),": When selecting a GPU for LLMs, consider its generation or series (e.g., RTX 30 series). Newer GPU generations often come with improved architectures and features. For LLM tasks, opting for the latest generation can mean better performance, energy efficiency, and support for emerging AI technologies. Avoid purchasing, RTX-2000 series GPUs which are much outdated nowadays."]}),"\n"]}),"\n",(0,n.jsx)(s.h3,{id:"here-are-some-of-the-best-gpu-options-for-this-purpose",children:"Here are some of the best GPU options for this purpose:"}),"\n",(0,n.jsxs)(s.ol,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"NVIDIA RTX 3090"}),": The NVIDIA RTX 3090 is a high-end GPU with a substantial 24GB of VRAM. This copious VRAM capacity makes it exceptionally well-suited for handling large LLMs. Moreover, it's known for its relative efficiency, meaning it won't overheat or strain your home PC's cooling system excessively. The RTX 3090's robust capabilities are a boon for those who need to work with hefty language models."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"NVIDIA RTX 4090"}),": If you're looking for peak performance and can afford the investment, the NVIDIA RTX 4090 represents the pinnacle of GPU power. Boasting 24GB of VRAM and featuring a cutting-edge Tensor Core architecture tailored for AI workloads, it outshines the RTX 3090 in terms of sheer capability. However, it's important to note that the RTX 4090 is also pricier and more power-hungry than its predecessor, the RTX 3090."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"AMD Radeon RX 6900 XT"}),": On the AMD side, the Radeon RX 6900 XT stands out as a high-end GPU with 16GB of VRAM. While it may not quite match the raw power of the RTX 3090 or RTX 4090, it strikes a balance between performance and affordability. Additionally, it tends to be more power-efficient, which could translate to a more sustainable and quieter setup in your home PC."]}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"If budget constraints are a consideration, there are more cost-effective GPU options available:"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"NVIDIA RTX 3070"}),": The RTX 3070 is a solid mid-range GPU that can handle LLMs effectively. While it may not excel with the most massive or complex language models, it's a reliable choice for users looking for a balance between price and performance."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"AMD Radeon RX 6800 XT"}),": Similarly, the RX 6800 XT from AMD offers commendable performance without breaking the bank. It's well-suited for running mid-sized LLMs and provides a competitive option in terms of both power and cost."]}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"When selecting a GPU for LLMs, remember that it's not just about the GPU itself. Consider the synergy with other components in your PC:"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"CPU"}),": To ensure efficient processing, pair your GPU with a powerful CPU. LLMs benefit from fast processors, so having a capable CPU is essential."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"RAM"}),": Sufficient RAM is crucial for LLMs. They can be memory-intensive, and having enough RAM ensures smooth operation."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Cooling System"}),": LLMs can push your PC's hardware to the limit. A robust cooling system helps maintain optimal temperatures, preventing overheating and performance throttling."]}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"By taking all of these factors into account, you can build a home PC setup that's well-equipped to handle the demands of running LLMs effectively and efficiently."})]})}function l(e={}){const{wrapper:s}={...(0,r.R)(),...e.components};return s?(0,n.jsx)(s,{...e,children:(0,n.jsx)(d,{...e})}):d(e)}},65958:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/GPU-5c5cbdea44506dcd4af8cf75b9aac52b.png"},72156:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/GPU_Image-231c0b8e4b585ac1d18c2330840bb1d6.png"},65306:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/PCIex16-83af51562c34bc672cda33199e42464d.png"},7011:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/Power-76f62f2aba4379d9f7368014d52484f8.png"},36165:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/RAM-VRAM-8ecee89416490242a132a14073e166fc.png"},41560:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/VRAM-Image-a29fe70e7f4d5782f1ef912a49fd0636.png"},3602:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/slot-e0b9ed4b774e0ae2fd485650de82f089.png"},28453:(e,s,t)=>{t.d(s,{R:()=>o,x:()=>a});var n=t(96540);const r={},i=n.createContext(r);function o(e){const s=n.useContext(i);return n.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function a(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),n.createElement(i.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/4a916acb.dcacf5f9.js b/assets/js/4a916acb.dcacf5f9.js deleted file mode 100644 index 77032c80..00000000 --- a/assets/js/4a916acb.dcacf5f9.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4368],{89734:(e,s,t)=>{t.r(s),t.d(s,{assets:()=>c,contentTitle:()=>o,default:()=>l,frontMatter:()=>i,metadata:()=>a,toc:()=>h});var n=t(74848),r=t(28453);const i={title:"GPUs and VRAM"},o=void 0,a={id:"hardware/concepts/gpu-and-vram",title:"GPUs and VRAM",description:"What Is a GPU?",source:"@site/docs/hardware/concepts/gpu-and-vram.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/gpu-and-vram",permalink:"/hardware/concepts/gpu-and-vram",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/gpu-and-vram.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"GPUs and VRAM"}},c={},h=[{value:"What Is a GPU?",id:"what-is-a-gpu",level:2},{value:"What Are GPUs Used For?",id:"what-are-gpus-used-for",level:2},{value:"Here are some example use cases:",id:"here-are-some-example-use-cases",level:3},{value:"What is VRAM In GPU?",id:"what-is-vram-in-gpu",level:2},{value:"What makes VRAM and RAM different from each other?",id:"what-makes-vram-and-ram-different-from-each-other",level:2},{value:"RAM (Random Access Memory):",id:"ram-random-access-memory",level:3},{value:"VRAM (Video Random Access Memory):",id:"vram-video-random-access-memory",level:3},{value:"How to Connect GPU to the Motherboard via PCIe",id:"how-to-connect-gpu-to-the-motherboard-via-pcie",level:2},{value:"How to Choose a Graphics Card for your AI works",id:"how-to-choose-a-graphics-card-for-your-ai-works",level:2},{value:"Here are some of the best GPU options for this purpose:",id:"here-are-some-of-the-best-gpu-options-for-this-purpose",level:3}];function d(e){const s={a:"a",blockquote:"blockquote",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,r.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(s.h2,{id:"what-is-a-gpu",children:"What Is a GPU?"}),"\n",(0,n.jsxs)(s.p,{children:["A Graphics Card, or GPU (Graphics Processing Unit), is a fundamental component in modern computing. Think of it as the powerhouse behind rendering the stunning visuals you see on your screen. Similar to the motherboard in your computer, the graphics card is a printed circuit board. However, it's not just a passive piece of hardware; it's a sophisticated device equipped with essential components like fans, onboard RAM, a dedicated memory controller, BIOS, and various other features. If you want to learn more about GPUs then read here to ",(0,n.jsx)(s.a,{href:"https://medium.com/codex/understanding-the-architecture-of-a-gpu-d5d2d2e8978b",children:"Understand the architecture of a GPU."})]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"GPU Image",src:t(72156).A+"",width:"1200",height:"674"})}),"\n",(0,n.jsx)(s.h2,{id:"what-are-gpus-used-for",children:"What Are GPUs Used For?"}),"\n",(0,n.jsx)(s.p,{children:"Two decades ago, GPUs primarily enhanced real-time 3D graphics in gaming. But as the 21st century dawned, a revelation occurred among computer scientists. They recognized that GPUs held untapped potential to solve some of the world's most intricate computing tasks.\nThis revelation marked the dawn of the general-purpose GPU era. Today's GPUs have evolved into versatile tools, more adaptable than ever before. They now have the capability to accelerate a diverse range of applications that stretch well beyond their original graphics-focused purpose."}),"\n",(0,n.jsx)(s.h3,{id:"here-are-some-example-use-cases",children:(0,n.jsx)(s.strong,{children:"Here are some example use cases:"})}),"\n",(0,n.jsxs)(s.ol,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Gaming"}),": They make games look good and run smoothly."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Content Creation"}),": Help with video editing, 3D design, and graphics work."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"AI and Machine Learning"}),": Used for training smart machines."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Science"}),": Speed up scientific calculations and simulations."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Cryptocurrency Mining"}),": Mine digital currencies like Bitcoin."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Medical Imaging"}),": Aid in analyzing medical images."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Self-Driving Cars"}),": Help cars navigate autonomously."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Simulations"}),": Create realistic virtual experiences."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Data Analysis"}),": Speed up data processing and visualization."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Video Streaming"}),": Improve video quality and streaming efficiency."]}),"\n"]}),"\n",(0,n.jsx)(s.h2,{id:"what-is-vram-in-gpu",children:"What is VRAM In GPU?"}),"\n",(0,n.jsx)(s.p,{children:"VRAM, or video random-access memory, is a type of high-speed memory that is specifically designed for use with graphics processing units (GPUs). VRAM is used to store the textures, images, and other data that the GPU needs to render graphics. Its allows the GPU to access the data it needs quickly and efficiently. This is essential for rendering complex graphics at high frame rates."}),"\n",(0,n.jsx)(s.p,{children:"VRAM is different from other types of memory, such as the system RAM that is used by the CPU. VRAM is optimized for high bandwidth and low latency, which means that it can read and write data very quickly. The amount of VRAM that a GPU has is one of the factors that determines its performance. More VRAM allows the GPU to store more data and render more complex graphics. However, VRAM is also one of the most expensive components of a GPU. So when choosing a graphics card, it is important to consider the amount of VRAM that it has. If you are planning on running demanding LLMs or video games, or 3D graphics software, you will need a graphics card with more VRAM."}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"VRAM",src:t(41560).A+"",width:"1500",height:"900"})}),"\n",(0,n.jsx)(s.h2,{id:"what-makes-vram-and-ram-different-from-each-other",children:"What makes VRAM and RAM different from each other?"}),"\n",(0,n.jsx)(s.p,{children:"RAM (Random Access Memory) and VRAM (Video Random Access Memory) are both types of memory used in computers, but they have different functions and characteristics. Here are the differences between RAM and VRAM."}),"\n",(0,n.jsx)(s.h3,{id:"ram-random-access-memory",children:"RAM (Random Access Memory):"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"RAM is a general-purpose memory that stores data and instructions that the CPU needs to access quickly."}),"\n",(0,n.jsx)(s.li,{children:"RAM is used for short-term data storage and is volatile, meaning that it loses its contents when the computer is turned off."}),"\n",(0,n.jsx)(s.li,{children:"RAM is connected to the motherboard and is accessed by the CPU."}),"\n",(0,n.jsx)(s.li,{children:"RAM typically has a larger capacity compared to VRAM, which is designed to store smaller amounts of data with faster access times."}),"\n",(0,n.jsx)(s.li,{children:"RAM stores data related to the operating system and the various programs that are running, including code, program files, and user data."}),"\n"]}),"\n",(0,n.jsx)(s.h3,{id:"vram-video-random-access-memory",children:"VRAM (Video Random Access Memory):"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"VRAM is a type of RAM that is specifically used to store image data for a computer display."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is a graphics card component that is connected to the GPU (Graphics Processing Unit)."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is used exclusively by the GPU and doesn\u2019t need to store as much data as the CPU."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is similar to RAM in that it is volatile and loses its contents when the computer is turned off."}),"\n",(0,n.jsx)(s.li,{children:"VRAM stores data related specifically to graphics, such as textures, frames, and other graphical data."}),"\n",(0,n.jsx)(s.li,{children:"VRAM is designed to store smaller amounts of data with faster access times than RAM."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"In summary, RAM is used for general-purpose memory, while VRAM is used for graphics-related tasks. RAM has a larger capacity and is accessed by the CPU, while VRAM has a smaller capacity and is accessed by the GPU."}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.strong,{children:"Key differences between VRAM and RAM:"})}),"\n",(0,n.jsxs)(s.table,{children:[(0,n.jsx)(s.thead,{children:(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.th,{children:"Characteristic"}),(0,n.jsx)(s.th,{children:"VRAM"}),(0,n.jsx)(s.th,{children:"RAM"})]})}),(0,n.jsxs)(s.tbody,{children:[(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Purpose"}),(0,n.jsx)(s.td,{children:"Graphics processing"}),(0,n.jsx)(s.td,{children:"General processing"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Speed"}),(0,n.jsx)(s.td,{children:"Faster"}),(0,n.jsx)(s.td,{children:"Slower"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Latency"}),(0,n.jsx)(s.td,{children:"Lower"}),(0,n.jsx)(s.td,{children:"Higher"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Bandwidth"}),(0,n.jsx)(s.td,{children:"Higher"}),(0,n.jsx)(s.td,{children:"Lower"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Cost"}),(0,n.jsx)(s.td,{children:"More expensive"}),(0,n.jsx)(s.td,{children:"Less expensive"})]}),(0,n.jsxs)(s.tr,{children:[(0,n.jsx)(s.td,{children:"Availability"}),(0,n.jsx)(s.td,{children:"Less widely available"}),(0,n.jsx)(s.td,{children:"More widely available"})]})]})]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"RAM-VRAM",src:t(36165).A+"",width:"824",height:"207"})}),"\n",(0,n.jsx)(s.h2,{id:"how-to-connect-gpu-to-the-motherboard-via-pcie",children:"How to Connect GPU to the Motherboard via PCIe"}),"\n",(0,n.jsx)(s.p,{children:"Connecting hardware components to a motherboard is often likened to assembling LEGO pieces. If the parts fit together seamlessly, you're on the right track. Experienced PC builders find this process straightforward. However, for first-time builders, identifying where each hardware component belongs on the motherboard can be a bit perplexing."}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.strong,{children:"So follow the below 5 steps to Connect your GPU to the Motherboard:"})}),"\n",(0,n.jsxs)(s.ol,{children:["\n",(0,n.jsx)(s.li,{children:"First, make sure your computer is powered off and unplugged from the electrical outlet to ensure safety."}),"\n",(0,n.jsx)(s.li,{children:"Open your computer case if necessary to access the motherboard. Locate the PCIe x16 on the motherboard where you'll install the GPU. These slots are typically longer than other expansion slots and are used for graphics cards.\nRemove Slot Covers (if applicable): Some PCIe slots may have protective covers or brackets covering them. Remove these covers by unscrewing them from the case using a Phillips-head screwdriver. And PCIe x16 will have plastic lock on one side only. There may be more than one PCIe x16 slot depending on the motherboard. You can use any of the slots according to your choice."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"PCIe x16",src:t(65306).A+"",width:"1600",height:"870"})}),"\n",(0,n.jsxs)(s.ol,{start:"3",children:["\n",(0,n.jsx)(s.li,{children:"Now Insert the Graphics Card slowly:"}),"\n"]}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"Unlock the plastic lock on one side of the PCIe x16 slot by pulling it outwards."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"slot",src:t(3602).A+"",width:"784",height:"461"})}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsx)(s.li,{children:"Align the PCIe slot with your graphics card, making sure that the HDMI port side of the GPU faces the rear side of the CPU case."}),"\n",(0,n.jsx)(s.li,{children:"Gently press on the card until you hear it securely snap in place."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"GPU",src:t(65958).A+"",width:"743",height:"348"})}),"\n",(0,n.jsxs)(s.ol,{start:"4",children:["\n",(0,n.jsx)(s.li,{children:"Insert the Power Connector: If your GPU requires additional power (most modern GPUs do), connect the necessary power cables from your power supply to the GPU's power connectors. These connectors are usually located on the top or side of the GPU."}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:(0,n.jsx)(s.img,{alt:"Power",src:t(7011).A+"",width:"742",height:"415"})}),"\n",(0,n.jsxs)(s.ol,{start:"5",children:["\n",(0,n.jsx)(s.li,{children:"Power on the System: After turning on the PC see if the fans on your graphics card spin. If it does not spin, remove the power cable from the GPU, reconnect it, and power on the PC again."}),"\n"]}),"\n",(0,n.jsxs)(s.blockquote,{children:["\n",(0,n.jsxs)(s.p,{children:["\ud83d\udcdd"," Note: To better understand you can also watch YouTube tutorials on how to Connect the GPU to the Motherboard via PCIe"]}),"\n"]}),"\n",(0,n.jsx)(s.h2,{id:"how-to-choose-a-graphics-card-for-your-ai-works",children:"How to Choose a Graphics Card for your AI works"}),"\n",(0,n.jsx)(s.p,{children:"Selecting the optimal GPU for running Large Language Models (LLMs) on your home PC is a decision influenced by your budget and the specific LLMs you intend to work with. Your choice should strike a balance between performance, efficiency, and cost-effectiveness."}),"\n",(0,n.jsx)(s.p,{children:"In general, the following GPU features are important for running LLMs:"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"High VRAM:"}),"\xa0LLMs are typically very large and complex models, so they require a GPU with a high amount of VRAM. This will allow the model to be loaded into memory and processed efficiently."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"CUDA Compatibility:"}),"\xa0When running LLMs on a GPU, CUDA compatibility is paramount. CUDA is NVIDIA's parallel computing platform, and it plays a vital role in accelerating deep learning tasks. LLMs, with their extensive matrix calculations, heavily rely on parallel processing. Ensuring your GPU supports CUDA is like having the right tool for the job. It allows the LLM to leverage the GPU's parallel processing capabilities, significantly speeding up model training and inference."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Number of CUDA, Tensor, and RT Cores:"}),"\xa0High-performance NVIDIA GPUs have both CUDA and Tensor cores. These cores are responsible for executing the neural network computations that underpin LLMs' language understanding and generation. The more CUDA cores your GPU has, the better equipped it is to handle the massive computational load that LLMs impose. Tensor cores in your GPU, further enhance LLM performance by accelerating the critical matrix operations integral to language modeling tasks."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Generation (Series)"}),": When selecting a GPU for LLMs, consider its generation or series (e.g., RTX 30 series). Newer GPU generations often come with improved architectures and features. For LLM tasks, opting for the latest generation can mean better performance, energy efficiency, and support for emerging AI technologies. Avoid purchasing, RTX-2000 series GPUs which are much outdated nowadays."]}),"\n"]}),"\n",(0,n.jsx)(s.h3,{id:"here-are-some-of-the-best-gpu-options-for-this-purpose",children:"Here are some of the best GPU options for this purpose:"}),"\n",(0,n.jsxs)(s.ol,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"NVIDIA RTX 3090"}),": The NVIDIA RTX 3090 is a high-end GPU with a substantial 24GB of VRAM. This copious VRAM capacity makes it exceptionally well-suited for handling large LLMs. Moreover, it's known for its relative efficiency, meaning it won't overheat or strain your home PC's cooling system excessively. The RTX 3090's robust capabilities are a boon for those who need to work with hefty language models."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"NVIDIA RTX 4090"}),": If you're looking for peak performance and can afford the investment, the NVIDIA RTX 4090 represents the pinnacle of GPU power. Boasting 24GB of VRAM and featuring a cutting-edge Tensor Core architecture tailored for AI workloads, it outshines the RTX 3090 in terms of sheer capability. However, it's important to note that the RTX 4090 is also pricier and more power-hungry than its predecessor, the RTX 3090."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"AMD Radeon RX 6900 XT"}),": On the AMD side, the Radeon RX 6900 XT stands out as a high-end GPU with 16GB of VRAM. While it may not quite match the raw power of the RTX 3090 or RTX 4090, it strikes a balance between performance and affordability. Additionally, it tends to be more power-efficient, which could translate to a more sustainable and quieter setup in your home PC."]}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"If budget constraints are a consideration, there are more cost-effective GPU options available:"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"NVIDIA RTX 3070"}),": The RTX 3070 is a solid mid-range GPU that can handle LLMs effectively. While it may not excel with the most massive or complex language models, it's a reliable choice for users looking for a balance between price and performance."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"AMD Radeon RX 6800 XT"}),": Similarly, the RX 6800 XT from AMD offers commendable performance without breaking the bank. It's well-suited for running mid-sized LLMs and provides a competitive option in terms of both power and cost."]}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"When selecting a GPU for LLMs, remember that it's not just about the GPU itself. Consider the synergy with other components in your PC:"}),"\n",(0,n.jsxs)(s.ul,{children:["\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"CPU"}),": To ensure efficient processing, pair your GPU with a powerful CPU. LLMs benefit from fast processors, so having a capable CPU is essential."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"RAM"}),": Sufficient RAM is crucial for LLMs. They can be memory-intensive, and having enough RAM ensures smooth operation."]}),"\n",(0,n.jsxs)(s.li,{children:[(0,n.jsx)(s.strong,{children:"Cooling System"}),": LLMs can push your PC's hardware to the limit. A robust cooling system helps maintain optimal temperatures, preventing overheating and performance throttling."]}),"\n"]}),"\n",(0,n.jsx)(s.p,{children:"By taking all of these factors into account, you can build a home PC setup that's well-equipped to handle the demands of running LLMs effectively and efficiently."})]})}function l(e={}){const{wrapper:s}={...(0,r.R)(),...e.components};return s?(0,n.jsx)(s,{...e,children:(0,n.jsx)(d,{...e})}):d(e)}},65958:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/GPU-5c5cbdea44506dcd4af8cf75b9aac52b.png"},72156:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/GPU_Image-231c0b8e4b585ac1d18c2330840bb1d6.png"},65306:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/PCIex16-83af51562c34bc672cda33199e42464d.png"},7011:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/Power-76f62f2aba4379d9f7368014d52484f8.png"},36165:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/RAM-VRAM-8ecee89416490242a132a14073e166fc.png"},41560:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/VRAM-Image-a29fe70e7f4d5782f1ef912a49fd0636.png"},3602:(e,s,t)=>{t.d(s,{A:()=>n});const n=t.p+"assets/images/slot-e0b9ed4b774e0ae2fd485650de82f089.png"},28453:(e,s,t)=>{t.d(s,{R:()=>o,x:()=>a});var n=t(96540);const r={},i=n.createContext(r);function o(e){const s=n.useContext(i);return n.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function a(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),n.createElement(i.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/4ed5f22c.26283435.js b/assets/js/4ed5f22c.26283435.js new file mode 100644 index 00000000..49624a56 --- /dev/null +++ b/assets/js/4ed5f22c.26283435.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6330],{25751:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>i,contentTitle:()=>s,default:()=>p,frontMatter:()=>a,metadata:()=>d,toc:()=>c});var n=r(74848),o=r(28453);const a={sidebar_position:1,title:"Introduction"},s=void 0,d={id:"hardware/hardware",title:"Introduction",description:"",source:"@site/docs/hardware/hardware.md",sourceDirName:"hardware",slug:"/hardware/",permalink:"/hardware/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/hardware.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{sidebar_position:1,title:"Introduction"}},i={},c=[];function u(t){return(0,n.jsx)(n.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u()}},28453:(t,e,r)=>{r.d(e,{R:()=>s,x:()=>d});var n=r(96540);const o={},a=n.createContext(o);function s(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function d(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/4ed5f22c.aaebd7f2.js b/assets/js/4ed5f22c.aaebd7f2.js deleted file mode 100644 index 99c75e4b..00000000 --- a/assets/js/4ed5f22c.aaebd7f2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6330],{25751:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>i,contentTitle:()=>s,default:()=>l,frontMatter:()=>a,metadata:()=>d,toc:()=>c});var n=r(74848),o=r(28453);const a={sidebar_position:1,title:"Introduction"},s=void 0,d={id:"hardware/hardware",title:"Introduction",description:"",source:"@site/docs/hardware/hardware.md",sourceDirName:"hardware",slug:"/hardware/",permalink:"/hardware/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/hardware.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{sidebar_position:1,title:"Introduction"}},i={},c=[];function u(t){return(0,n.jsx)(n.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u()}},28453:(t,e,r)=>{r.d(e,{R:()=>s,x:()=>d});var n=r(96540);const o={},a=n.createContext(o);function s(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function d(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/50318dff.2fb67516.js b/assets/js/50318dff.2fb67516.js deleted file mode 100644 index 858330a8..00000000 --- a/assets/js/50318dff.2fb67516.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9816],{22484:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>s,metadata:()=>a,toc:()=>c});var o=r(74848),n=r(28453);const s={title:"System Monitor",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,a={id:"developer/framework/product/system-monitor",title:"System Monitor",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/system-monitor.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/system-monitor",permalink:"/developer/framework/product/system-monitor",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/system-monitor.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"System Monitor",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Settings",permalink:"/developer/framework/product/settings"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2}];function d(e){const t={h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,n.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(t.h2,{id:"overview",children:"Overview"}),"\n",(0,o.jsx)(t.p,{children:"An activity screen to monitor system health and running models."}),"\n",(0,o.jsx)(t.p,{children:(0,o.jsx)(t.img,{alt:"alt text",src:r(11342).A+"",width:"1440",height:"1009"})}),"\n",(0,o.jsx)(t.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,o.jsxs)(t.ul,{children:["\n",(0,o.jsx)(t.li,{children:"Users can see disk and ram utilization"}),"\n",(0,o.jsx)(t.li,{children:"Users can start and stop models based on system health"}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},11342:(e,t,r)=>{r.d(t,{A:()=>o});const o=r.p+"assets/images/system-screen-b4977783cfd02b5b0e5b88949215af12.png"},28453:(e,t,r)=>{r.d(t,{R:()=>i,x:()=>a});var o=r(96540);const n={},s=o.createContext(n);function i(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:i(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/50318dff.46dfb232.js b/assets/js/50318dff.46dfb232.js new file mode 100644 index 00000000..82dd8574 --- /dev/null +++ b/assets/js/50318dff.46dfb232.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9816],{22484:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>s,metadata:()=>a,toc:()=>c});var o=r(74848),n=r(28453);const s={title:"System Monitor",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,a={id:"developer/framework/product/system-monitor",title:"System Monitor",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/system-monitor.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/system-monitor",permalink:"/developer/framework/product/system-monitor",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/system-monitor.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"System Monitor",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Settings",permalink:"/developer/framework/product/settings"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2}];function d(e){const t={h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,n.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(t.h2,{id:"overview",children:"Overview"}),"\n",(0,o.jsx)(t.p,{children:"An activity screen to monitor system health and running models."}),"\n",(0,o.jsx)(t.p,{children:(0,o.jsx)(t.img,{alt:"alt text",src:r(11342).A+"",width:"1440",height:"1009"})}),"\n",(0,o.jsx)(t.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,o.jsxs)(t.ul,{children:["\n",(0,o.jsx)(t.li,{children:"Users can see disk and ram utilization"}),"\n",(0,o.jsx)(t.li,{children:"Users can start and stop models based on system health"}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},11342:(e,t,r)=>{r.d(t,{A:()=>o});const o=r.p+"assets/images/system-screen-b4977783cfd02b5b0e5b88949215af12.png"},28453:(e,t,r)=>{r.d(t,{R:()=>i,x:()=>a});var o=r(96540);const n={},s=o.createContext(n);function i(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:i(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/516c1eaf.7d7165c6.js b/assets/js/516c1eaf.7d7165c6.js new file mode 100644 index 00000000..2328325a --- /dev/null +++ b/assets/js/516c1eaf.7d7165c6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2691],{64396:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>p,frontMatter:()=>s,metadata:()=>u,toc:()=>i});var n=r(74848),o=r(28453);const s={title:"OpenAI API Support (and others)"},a=void 0,u={id:"features/remote",title:"OpenAI API Support (and others)",description:"",source:"@site/docs/features/remote.md",sourceDirName:"features",slug:"/features/remote",permalink:"/features/remote",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/remote.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"OpenAI API Support (and others)"},sidebar:"productSidebar",previous:{title:"Local & Self-Hosted AI",permalink:"/features/local"},next:{title:"API Server",permalink:"/features/api-server"}},c={},i=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function p(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>u});var n=r(96540);const o={},s=n.createContext(o);function a(e){const t=n.useContext(s);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function u(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),n.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/516c1eaf.8bbf9505.js b/assets/js/516c1eaf.8bbf9505.js deleted file mode 100644 index 7db584c2..00000000 --- a/assets/js/516c1eaf.8bbf9505.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2691],{64396:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>p,frontMatter:()=>s,metadata:()=>u,toc:()=>i});var n=r(74848),o=r(28453);const s={title:"OpenAI API Support (and others)"},a=void 0,u={id:"features/remote",title:"OpenAI API Support (and others)",description:"",source:"@site/docs/features/remote.md",sourceDirName:"features",slug:"/features/remote",permalink:"/features/remote",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/remote.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"OpenAI API Support (and others)"},sidebar:"productSidebar",previous:{title:"Local & Self-Hosted AI",permalink:"/features/local"},next:{title:"API Server",permalink:"/features/api-server"}},c={},i=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function p(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>u});var n=r(96540);const o={},s=n.createContext(o);function a(e){const t=n.useContext(s);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function u(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),n.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/5578256f.66016ef0.js b/assets/js/5578256f.66016ef0.js deleted file mode 100644 index 669130eb..00000000 --- a/assets/js/5578256f.66016ef0.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8611],{68051:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>o,metadata:()=>r,toc:()=>c});var t=s(74848),a=s(28453);const o={title:"Assistants",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,r={id:"developer/framework/engineering/assistants",title:"Assistants",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/assistants.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/assistants",permalink:"/developer/framework/engineering/assistants",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/assistants.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Assistants",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Engineering Specs",permalink:"/developer/engineering"},next:{title:"Chats",permalink:"/developer/framework/engineering/chats"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"assistant.json",id:"assistantjson",level:2},{value:"Examples",id:"examples",level:3},{value:"Events",id:"events",level:2},{value:"Custom Code",id:"custom-code",level:2},{value:"Tools",id:"tools",level:2},{value:"Functions",id:"functions",level:2},{value:"Files",id:"files",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,a.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.admonition,{type:"caution",children:(0,t.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,t.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,t.jsxs)(n.p,{children:["In Jan, assistants are ",(0,t.jsx)(n.code,{children:"primary"})," entities with the following capabilities:"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Assistants can use ",(0,t.jsx)(n.code,{children:"models"}),", ",(0,t.jsx)(n.code,{children:"tools"}),", handle and emit ",(0,t.jsx)(n.code,{children:"events"}),", and invoke ",(0,t.jsx)(n.code,{children:"custom code"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Users can create custom assistants with saved ",(0,t.jsx)(n.code,{children:"model"})," settings and parameters."]}),"\n",(0,t.jsxs)(n.li,{children:["An ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/assistants",children:"OpenAI Assistants API"})," compatible endpoint at ",(0,t.jsx)(n.code,{children:"localhost:1337/v1/assistants"}),"."]}),"\n",(0,t.jsx)(n.li,{children:'Jan ships with a default assistant called "Jan" that lets you use all models.'}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-yaml",children:"/jan\n /models/\n /threads/\n /assistants\n /jan # An assistant available to you by default\n assistant.json # See below\n /src # Assistants can invoke custom code\n index.js # Entrypoint\n process.js # For server processes (needs better name)\n package.json # Import any npm libraries, e.g. Langchain, Llamaindex\n /shakespeare # You can create custom assistants\n assistant.json\n /chicken_man\n"})}),"\n",(0,t.jsx)(n.h2,{id:"assistantjson",children:(0,t.jsx)(n.code,{children:"assistant.json"})}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Each ",(0,t.jsx)(n.code,{children:"assistant"})," folder contains an ",(0,t.jsx)(n.code,{children:"assistant.json"})," file, which is a representation of an assistant."]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"assistant.json"})," contains metadata and model parameter overrides"]}),"\n",(0,t.jsx)(n.li,{children:"There are no required fields."}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-js",children:'{\n "id": "asst_abc123", // Defaults to foldername\n "object": "assistant", // Always "assistant"\n "version": 1, // Defaults to 1\n "created_at": 1698984975,\n "name": "Math Tutor", // Defaults to foldername\n "description": null,\n "avatar": "https://pic.png",\n "models": [ // Defaults to "*" all models\n { ...model_0 }\n ],\n "instructions": "Be concise", // A system prompt for the assistant\n "events": [], // Defaults to "*"\n "metadata": {}, // Defaults to {}\n // "tools": [], // Coming soon\n // "file_ids": [], // Coming soon\n // "memory/threads": true, // Coming soon\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"examples",children:"Examples"}),"\n",(0,t.jsx)(n.p,{children:"Here's what the default Jan assistant's json file looks like:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-js",children:'{\n "name": "Jan",\n "description": "A global assistant that lets you chat with all downloaded models",\n "avatar": "https://jan.ai/img/logo.svg",\n // All other properties are not explicitly declared and use the default values (see above).\n}\n'})}),"\n",(0,t.jsx)(n.h2,{id:"events",children:"Events"}),"\n",(0,t.jsx)(n.p,{children:"Jan assistants can respond to event hooks. More powerfully, Jan assistants can register their own pubsub, so other entities, like other assistants can respond to your assistants events."}),"\n",(0,t.jsx)(n.h2,{id:"custom-code",children:"Custom Code"}),"\n",(0,t.jsx)(n.p,{children:"Jan assistants are Turing complete. This means you can write freeform code, and use any dependencies, when customizing your assistant."}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-typescript",children:'import {events, models} from "@janhq/core"\nimport {retrieval} from "@hiro/best-rag-ever" // This can be featured on Jan hub but install from npm\n\nevents.on(\'assistant:asst_abc123\', (event) => async {\n const result = models[0].process(event)\n events.emit("assistant:asst_abc123", result)\n resolve()\n})\n'})}),"\n",(0,t.jsx)(n.h2,{id:"tools",children:"Tools"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:"Coming soon"}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"functions",children:"Functions"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:"Coming soon"}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"files",children:"Files"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:"Coming soon"}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(d,{...e})}):d(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>i,x:()=>r});var t=s(96540);const a={},o=t.createContext(a);function i(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:i(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/5578256f.d01aa964.js b/assets/js/5578256f.d01aa964.js new file mode 100644 index 00000000..0a41709e --- /dev/null +++ b/assets/js/5578256f.d01aa964.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8611],{68051:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>o,metadata:()=>r,toc:()=>c});var t=s(74848),a=s(28453);const o={title:"Assistants",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,r={id:"developer/framework/engineering/assistants",title:"Assistants",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/assistants.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/assistants",permalink:"/developer/framework/engineering/assistants",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/assistants.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Assistants",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Engineering Specs",permalink:"/developer/engineering"},next:{title:"Chats",permalink:"/developer/framework/engineering/chats"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"assistant.json",id:"assistantjson",level:2},{value:"Examples",id:"examples",level:3},{value:"Events",id:"events",level:2},{value:"Custom Code",id:"custom-code",level:2},{value:"Tools",id:"tools",level:2},{value:"Functions",id:"functions",level:2},{value:"Files",id:"files",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,a.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.admonition,{type:"caution",children:(0,t.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,t.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,t.jsxs)(n.p,{children:["In Jan, assistants are ",(0,t.jsx)(n.code,{children:"primary"})," entities with the following capabilities:"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Assistants can use ",(0,t.jsx)(n.code,{children:"models"}),", ",(0,t.jsx)(n.code,{children:"tools"}),", handle and emit ",(0,t.jsx)(n.code,{children:"events"}),", and invoke ",(0,t.jsx)(n.code,{children:"custom code"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Users can create custom assistants with saved ",(0,t.jsx)(n.code,{children:"model"})," settings and parameters."]}),"\n",(0,t.jsxs)(n.li,{children:["An ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/assistants",children:"OpenAI Assistants API"})," compatible endpoint at ",(0,t.jsx)(n.code,{children:"localhost:1337/v1/assistants"}),"."]}),"\n",(0,t.jsx)(n.li,{children:'Jan ships with a default assistant called "Jan" that lets you use all models.'}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-yaml",children:"/jan\n /models/\n /threads/\n /assistants\n /jan # An assistant available to you by default\n assistant.json # See below\n /src # Assistants can invoke custom code\n index.js # Entrypoint\n process.js # For server processes (needs better name)\n package.json # Import any npm libraries, e.g. Langchain, Llamaindex\n /shakespeare # You can create custom assistants\n assistant.json\n /chicken_man\n"})}),"\n",(0,t.jsx)(n.h2,{id:"assistantjson",children:(0,t.jsx)(n.code,{children:"assistant.json"})}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Each ",(0,t.jsx)(n.code,{children:"assistant"})," folder contains an ",(0,t.jsx)(n.code,{children:"assistant.json"})," file, which is a representation of an assistant."]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"assistant.json"})," contains metadata and model parameter overrides"]}),"\n",(0,t.jsx)(n.li,{children:"There are no required fields."}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-js",children:'{\n "id": "asst_abc123", // Defaults to foldername\n "object": "assistant", // Always "assistant"\n "version": 1, // Defaults to 1\n "created_at": 1698984975,\n "name": "Math Tutor", // Defaults to foldername\n "description": null,\n "avatar": "https://pic.png",\n "models": [ // Defaults to "*" all models\n { ...model_0 }\n ],\n "instructions": "Be concise", // A system prompt for the assistant\n "events": [], // Defaults to "*"\n "metadata": {}, // Defaults to {}\n // "tools": [], // Coming soon\n // "file_ids": [], // Coming soon\n // "memory/threads": true, // Coming soon\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"examples",children:"Examples"}),"\n",(0,t.jsx)(n.p,{children:"Here's what the default Jan assistant's json file looks like:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-js",children:'{\n "name": "Jan",\n "description": "A global assistant that lets you chat with all downloaded models",\n "avatar": "https://jan.ai/img/logo.svg",\n // All other properties are not explicitly declared and use the default values (see above).\n}\n'})}),"\n",(0,t.jsx)(n.h2,{id:"events",children:"Events"}),"\n",(0,t.jsx)(n.p,{children:"Jan assistants can respond to event hooks. More powerfully, Jan assistants can register their own pubsub, so other entities, like other assistants can respond to your assistants events."}),"\n",(0,t.jsx)(n.h2,{id:"custom-code",children:"Custom Code"}),"\n",(0,t.jsx)(n.p,{children:"Jan assistants are Turing complete. This means you can write freeform code, and use any dependencies, when customizing your assistant."}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-typescript",children:'import {events, models} from "@janhq/core"\nimport {retrieval} from "@hiro/best-rag-ever" // This can be featured on Jan hub but install from npm\n\nevents.on(\'assistant:asst_abc123\', (event) => async {\n const result = models[0].process(event)\n events.emit("assistant:asst_abc123", result)\n resolve()\n})\n'})}),"\n",(0,t.jsx)(n.h2,{id:"tools",children:"Tools"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:"Coming soon"}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"functions",children:"Functions"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:"Coming soon"}),"\n"]}),"\n",(0,t.jsx)(n.h2,{id:"files",children:"Files"}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:"Coming soon"}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(d,{...e})}):d(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>i,x:()=>r});var t=s(96540);const a={},o=t.createContext(a);function i(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:i(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/5682c91a.e7fffb29.js b/assets/js/5682c91a.e7fffb29.js deleted file mode 100644 index 48c9bcae..00000000 --- a/assets/js/5682c91a.e7fffb29.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[670],{84147:(t,e,o)=>{o.r(e),o.d(e,{assets:()=>u,contentTitle:()=>d,default:()=>l,frontMatter:()=>r,metadata:()=>i,toc:()=>c});var n=o(74848),s=o(28453);const r={},d=void 0,i={id:"studio/studio",title:"studio",description:"",source:"@site/docs/studio/studio.md",sourceDirName:"studio",slug:"/studio/",permalink:"/studio/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/studio/studio.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{}},u={},c=[];function a(t){return(0,n.jsx)(n.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,s.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(a,{...t})}):a()}},28453:(t,e,o)=>{o.d(e,{R:()=>d,x:()=>i});var n=o(96540);const s={},r=n.createContext(s);function d(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:d(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/5682c91a.ede6926f.js b/assets/js/5682c91a.ede6926f.js new file mode 100644 index 00000000..bbf1a4da --- /dev/null +++ b/assets/js/5682c91a.ede6926f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[670],{84147:(t,e,o)=>{o.r(e),o.d(e,{assets:()=>u,contentTitle:()=>d,default:()=>p,frontMatter:()=>r,metadata:()=>i,toc:()=>c});var n=o(74848),s=o(28453);const r={},d=void 0,i={id:"studio/studio",title:"studio",description:"",source:"@site/docs/studio/studio.md",sourceDirName:"studio",slug:"/studio/",permalink:"/studio/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/studio/studio.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{}},u={},c=[];function a(t){return(0,n.jsx)(n.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,s.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(a,{...t})}):a()}},28453:(t,e,o)=>{o.d(e,{R:()=>d,x:()=>i});var n=o(96540);const s={},r=n.createContext(s);function d(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:d(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/57902419.43f877a6.js b/assets/js/57902419.43f877a6.js new file mode 100644 index 00000000..917d2b6a --- /dev/null +++ b/assets/js/57902419.43f877a6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7176],{34764:(t,e,a)=>{a.r(e),a.d(e,{assets:()=>c,contentTitle:()=>r,default:()=>l,frontMatter:()=>s,metadata:()=>i,toc:()=>d});var n=a(74848),o=a(28453);const s={title:"Roadmap"},r=void 0,i={id:"about/roadmap",title:"Roadmap",description:"- ] [Immediate Roadmap on Github",source:"@site/docs/about/roadmap.md",sourceDirName:"about",slug:"/about/roadmap",permalink:"/about/roadmap",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/roadmap.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Roadmap"}},c={},d=[];function u(t){const e={a:"a",input:"input",li:"li",ul:"ul",...(0,o.R)(),...t.components};return(0,n.jsxs)(e.ul,{className:"contains-task-list",children:["\n",(0,n.jsxs)(e.li,{className:"task-list-item",children:[(0,n.jsx)(e.input,{type:"checkbox",disabled:!0})," ",(0,n.jsx)(e.a,{href:"https://github.com/orgs/janhq/projects/5/views/16",children:"Immediate Roadmap on Github"})]}),"\n",(0,n.jsxs)(e.li,{className:"task-list-item",children:[(0,n.jsx)(e.input,{type:"checkbox",disabled:!0})," ",(0,n.jsx)(e.a,{href:"https://discord.gg/Ey62mynnYr",children:"Longer-term Roadmap on Discord"})]}),"\n"]})}function l(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u(t)}},28453:(t,e,a)=>{a.d(e,{R:()=>r,x:()=>i});var n=a(96540);const o={},s=n.createContext(o);function r(t){const e=n.useContext(s);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),n.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/57902419.d0a20ca2.js b/assets/js/57902419.d0a20ca2.js deleted file mode 100644 index 2f4c25fb..00000000 --- a/assets/js/57902419.d0a20ca2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7176],{34764:(t,e,a)=>{a.r(e),a.d(e,{assets:()=>c,contentTitle:()=>r,default:()=>l,frontMatter:()=>s,metadata:()=>i,toc:()=>d});var n=a(74848),o=a(28453);const s={title:"Roadmap"},r=void 0,i={id:"about/roadmap",title:"Roadmap",description:"- ] [Immediate Roadmap on Github",source:"@site/docs/about/roadmap.md",sourceDirName:"about",slug:"/about/roadmap",permalink:"/about/roadmap",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/roadmap.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Roadmap"}},c={},d=[];function u(t){const e={a:"a",input:"input",li:"li",ul:"ul",...(0,o.R)(),...t.components};return(0,n.jsxs)(e.ul,{className:"contains-task-list",children:["\n",(0,n.jsxs)(e.li,{className:"task-list-item",children:[(0,n.jsx)(e.input,{type:"checkbox",disabled:!0})," ",(0,n.jsx)(e.a,{href:"https://github.com/orgs/janhq/projects/5/views/16",children:"Immediate Roadmap on Github"})]}),"\n",(0,n.jsxs)(e.li,{className:"task-list-item",children:[(0,n.jsx)(e.input,{type:"checkbox",disabled:!0})," ",(0,n.jsx)(e.a,{href:"https://discord.gg/Ey62mynnYr",children:"Longer-term Roadmap on Discord"})]}),"\n"]})}function l(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(u,{...t})}):u(t)}},28453:(t,e,a)=>{a.d(e,{R:()=>r,x:()=>i});var n=a(96540);const o={},s=n.createContext(o);function r(t){const e=n.useContext(s);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),n.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/58a762cd.18ddaa83.js b/assets/js/58a762cd.18ddaa83.js new file mode 100644 index 00000000..a354db26 --- /dev/null +++ b/assets/js/58a762cd.18ddaa83.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2689],{31477:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>d,frontMatter:()=>s,metadata:()=>i,toc:()=>l});var r=n(74848),o=n(28453);const s={title:"Who we are"},a=void 0,i={id:"team/team",title:"Who we are",description:"What's Jan the company about?",source:"@site/docs/team/team.md",sourceDirName:"team",slug:"/team/",permalink:"/team/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/team/team.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Who we are"},sidebar:"aboutSidebar",previous:{title:"Jan's Community",permalink:"/community"},next:{title:"Join us",permalink:"/team/join-us"}},c={},l=[{value:"Open Source",id:"open-source",level:3},{value:"Bootstrapped",id:"bootstrapped",level:3},{value:"Our Team",id:"our-team",level:2}];function u(e){const t={a:"a",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(t.p,{children:"What's Jan the company about?\nWe aim to build the cognitive framework for future robots"}),"\n",(0,r.jsx)(t.h3,{id:"open-source",children:"Open Source"}),"\n",(0,r.jsx)(t.p,{children:"Jan is a startup with an open source business model. We believe in the need for an open source AI ecosystem, and are committed to building it."}),"\n",(0,r.jsxs)(t.ul,{children:["\n",(0,r.jsxs)(t.li,{children:[(0,r.jsx)(t.a,{href:"https://github.com/janhq/jan",children:"Jan Framework"})," (AGPLv3)"]}),"\n",(0,r.jsxs)(t.li,{children:[(0,r.jsx)(t.a,{href:"https://jan.ai",children:"Jan Desktop Client & Local server"})," (AGPLv3, built on Jan Framework)"]}),"\n",(0,r.jsxs)(t.li,{children:[(0,r.jsx)(t.a,{href:"https://github.com/janhq/nitro",children:"Nitro: run Local AI"})," (AGPLv3)"]}),"\n"]}),"\n",(0,r.jsx)(t.h3,{id:"bootstrapped",children:"Bootstrapped"}),"\n",(0,r.jsx)(t.p,{children:"Jan is currently a bootstrapped startup."}),"\n",(0,r.jsx)(t.p,{children:"We balance technical invention with the search for a sustainable business model. Thus, we appreciate any business inquiries that can balance growth with cashflow."}),"\n",(0,r.jsxs)(t.p,{children:[(0,r.jsx)(t.strong,{children:"We invite you to join us on our journey to find PMF"}),". Join our ",(0,r.jsx)(t.a,{href:"https://discord.gg/BnHRr3Q7Ms",children:"Discord here"})]}),"\n",(0,r.jsx)(t.h2,{id:"our-team",children:"Our Team"}),"\n",(0,r.jsxs)(t.ul,{children:["\n",(0,r.jsx)(t.li,{children:"Contributors"}),"\n",(0,r.jsx)(t.li,{children:"Core Team"}),"\n"]})]})}function d(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>i});var r=n(96540);const o={},s=r.createContext(o);function a(e){const t=r.useContext(s);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),r.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/58a762cd.f252c7da.js b/assets/js/58a762cd.f252c7da.js deleted file mode 100644 index a626d241..00000000 --- a/assets/js/58a762cd.f252c7da.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2689],{31477:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>d,frontMatter:()=>s,metadata:()=>i,toc:()=>l});var r=n(74848),o=n(28453);const s={title:"Who we are"},a=void 0,i={id:"team/team",title:"Who we are",description:"What's Jan the company about?",source:"@site/docs/team/team.md",sourceDirName:"team",slug:"/team/",permalink:"/team/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/team/team.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Who we are"},sidebar:"aboutSidebar",previous:{title:"Jan's Community",permalink:"/community"},next:{title:"Join us",permalink:"/team/join-us"}},c={},l=[{value:"Open Source",id:"open-source",level:3},{value:"Bootstrapped",id:"bootstrapped",level:3},{value:"Our Team",id:"our-team",level:2}];function u(e){const t={a:"a",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(t.p,{children:"What's Jan the company about?\nWe aim to build the cognitive framework for future robots"}),"\n",(0,r.jsx)(t.h3,{id:"open-source",children:"Open Source"}),"\n",(0,r.jsx)(t.p,{children:"Jan is a startup with an open source business model. We believe in the need for an open source AI ecosystem, and are committed to building it."}),"\n",(0,r.jsxs)(t.ul,{children:["\n",(0,r.jsxs)(t.li,{children:[(0,r.jsx)(t.a,{href:"https://github.com/janhq/jan",children:"Jan Framework"})," (AGPLv3)"]}),"\n",(0,r.jsxs)(t.li,{children:[(0,r.jsx)(t.a,{href:"https://jan.ai",children:"Jan Desktop Client & Local server"})," (AGPLv3, built on Jan Framework)"]}),"\n",(0,r.jsxs)(t.li,{children:[(0,r.jsx)(t.a,{href:"https://github.com/janhq/nitro",children:"Nitro: run Local AI"})," (AGPLv3)"]}),"\n"]}),"\n",(0,r.jsx)(t.h3,{id:"bootstrapped",children:"Bootstrapped"}),"\n",(0,r.jsx)(t.p,{children:"Jan is currently a bootstrapped startup."}),"\n",(0,r.jsx)(t.p,{children:"We balance technical invention with the search for a sustainable business model. Thus, we appreciate any business inquiries that can balance growth with cashflow."}),"\n",(0,r.jsxs)(t.p,{children:[(0,r.jsx)(t.strong,{children:"We invite you to join us on our journey to find PMF"}),". Join our ",(0,r.jsx)(t.a,{href:"https://discord.gg/BnHRr3Q7Ms",children:"Discord here"})]}),"\n",(0,r.jsx)(t.h2,{id:"our-team",children:"Our Team"}),"\n",(0,r.jsxs)(t.ul,{children:["\n",(0,r.jsx)(t.li,{children:"Contributors"}),"\n",(0,r.jsx)(t.li,{children:"Core Team"}),"\n"]})]})}function d(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>i});var r=n(96540);const o={},s=r.createContext(o);function a(e){const t=r.useContext(s);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),r.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/58dab583.6936f817.js b/assets/js/58dab583.6936f817.js new file mode 100644 index 00000000..26955bff --- /dev/null +++ b/assets/js/58dab583.6936f817.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8545],{45473:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>u,contentTitle:()=>i,default:()=>l,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var n=s(74848),r=s(28453);const o={title:"Enterprises",tags:["audiences"]},i=void 0,a={id:"solutions/enterprises",title:"Enterprises",description:"",source:"@site/docs/solutions/enterprises.md",sourceDirName:"solutions",slug:"/solutions/enterprises",permalink:"/solutions/enterprises",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/enterprises.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Enterprises",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Startups",permalink:"/solutions/startups"}},u={},c=[];function d(t){return(0,n.jsx)(n.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(d,{...t})}):d()}},28453:(t,e,s)=>{s.d(e,{R:()=>i,x:()=>a});var n=s(96540);const r={},o=n.createContext(r);function i(t){const e=n.useContext(o);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:i(t.components),n.createElement(o.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/58dab583.de3de000.js b/assets/js/58dab583.de3de000.js deleted file mode 100644 index b92d6b62..00000000 --- a/assets/js/58dab583.de3de000.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8545],{45473:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>u,contentTitle:()=>i,default:()=>l,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var n=s(74848),r=s(28453);const o={title:"Enterprises",tags:["audiences"]},i=void 0,a={id:"solutions/enterprises",title:"Enterprises",description:"",source:"@site/docs/solutions/enterprises.md",sourceDirName:"solutions",slug:"/solutions/enterprises",permalink:"/solutions/enterprises",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/enterprises.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Enterprises",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Startups",permalink:"/solutions/startups"}},u={},c=[];function d(t){return(0,n.jsx)(n.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(d,{...t})}):d()}},28453:(t,e,s)=>{s.d(e,{R:()=>i,x:()=>a});var n=s(96540);const r={},o=n.createContext(r);function i(t){const e=n.useContext(o);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:i(t.components),n.createElement(o.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/5b9b123e.4e6aa489.js b/assets/js/5b9b123e.4e6aa489.js deleted file mode 100644 index cf0aa42f..00000000 --- a/assets/js/5b9b123e.4e6aa489.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7785],{60365:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>o,default:()=>p,frontMatter:()=>l,metadata:()=>c,toc:()=>u});var r=t(74848),s=t(28453),i=t(11470),a=t(19365);const l={title:"Llama.cpp Extension",slug:"/guides/engines/llamacpp",sidebar_position:1,description:"A step-by-step guide on how to customize the LlamaCPP extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Llama CPP integration","LlamaCPP Extension"]},o=void 0,c={id:"guides/local-providers/llamacpp",title:"Llama.cpp Extension",description:"A step-by-step guide on how to customize the LlamaCPP extension.",source:"@site/docs/guides/local-providers/llamacpp.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/llamacpp",permalink:"/guides/engines/llamacpp",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/llamacpp.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Llama.cpp Extension",slug:"/guides/engines/llamacpp",sidebar_position:1,description:"A step-by-step guide on how to customize the LlamaCPP extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Llama CPP integration","LlamaCPP Extension"]},sidebar:"guidesSidebar",previous:{title:"Local Engines",permalink:"/guides/engines/local"},next:{title:"TensorRT-LLM Extension",permalink:"/guides/engines/tensorrt-llm"}},d={},u=[{value:"Overview",id:"overview",level:2},{value:"LlamaCPP Extension",id:"llamacpp-extension",level:2}];function h(e){const n={a:"a",admonition:"admonition",code:"code",em:"em",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"Nitro"})," is an inference server on top of ",(0,r.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp",children:"llama.cpp"}),". It provides an OpenAI-compatible API, queue, & scaling."]}),"\n",(0,r.jsx)(n.h2,{id:"llamacpp-extension",children:"LlamaCPP Extension"}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"Nitro is the default AI engine downloaded with Jan. There is no additional setup needed."})}),"\n",(0,r.jsxs)(n.p,{children:["In this guide, we'll walk you through the process of customizing your engine settings by configuring the ",(0,r.jsx)(n.code,{children:"nitro.json"})," file"]}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:["Navigate to the ",(0,r.jsx)(n.code,{children:"App Settings"})," > ",(0,r.jsx)(n.code,{children:"Advanced"})," > ",(0,r.jsx)(n.code,{children:"Open App Directory"})," > ",(0,r.jsx)(n.code,{children:"~/jan/engine"})," folder."]}),"\n"]}),"\n",(0,r.jsxs)(i.A,{children:[(0,r.jsx)(a.A,{value:"mac",label:"MacOS",default:!0,children:(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"cd ~/jan/engines\n"})})}),(0,r.jsx)(a.A,{value:"windows",label:"Windows",default:!0,children:(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"C:/Users//jan/engines\n"})})}),(0,r.jsx)(a.A,{value:"linux",label:"Linux",default:!0,children:(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"cd ~/jan/engines\n"})})})]}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsxs)(n.li,{children:["Modify the ",(0,r.jsx)(n.code,{children:"nitro.json"})," file based on your needs. The default settings are shown below."]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/nitro.json"',children:'{\n "ctx_len": 2048,\n "ngl": 100,\n "cpu_threads": 1,\n "cont_batching": false,\n "embedding": false\n}\n'})}),"\n",(0,r.jsxs)(n.p,{children:["The table below describes the parameters in the ",(0,r.jsx)(n.code,{children:"nitro.json"})," file."]}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Parameter"}),(0,r.jsx)(n.th,{children:"Type"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"ctx_len"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsxs)(n.td,{children:["Typically set at ",(0,r.jsx)(n.code,{children:"2048"}),", ",(0,r.jsx)(n.code,{children:"ctx_len"})," provides ample context for model operations like ",(0,r.jsx)(n.code,{children:"GPT-3.5"}),". (",(0,r.jsx)(n.em,{children:"Maximum"}),": ",(0,r.jsx)(n.code,{children:"4096"}),", ",(0,r.jsx)(n.em,{children:"Minimum"}),": ",(0,r.jsx)(n.code,{children:"1"}),")"]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"ngl"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsxs)(n.td,{children:["Defaulted at ",(0,r.jsx)(n.code,{children:"100"}),", ",(0,r.jsx)(n.code,{children:"ngl"})," determines GPU layer usage."]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"cpu_threads"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsxs)(n.td,{children:["Determines CPU inference threads, limited by hardware and OS. (",(0,r.jsx)(n.em,{children:"Maximum"})," determined by system)"]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"cont_batching"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsx)(n.td,{children:"Controls continuous batching, enhancing throughput for LLM inference."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"embedding"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsx)(n.td,{children:"Enables embedding utilization for tasks like document-enhanced chat in RAG-based applications."})]})]})]}),"\n",(0,r.jsx)(n.admonition,{type:"tip",children:(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["By default, the value of ",(0,r.jsx)(n.code,{children:"ngl"})," is set to 100, which indicates that it will offload all. If you wish to offload only 50% of the GPU, you can set ",(0,r.jsx)(n.code,{children:"ngl"})," to 15 because most models on Mistral or Llama are around ~ 30 layers."]}),"\n",(0,r.jsxs)(n.li,{children:["To utilize the embedding feature, include the JSON parameter ",(0,r.jsx)(n.code,{children:'"embedding": true'}),". It will enable Nitro to process inferences with embedding capabilities. Please refer to the ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/embed",children:"Embedding in the Nitro documentation"})," for a more detailed explanation."]}),"\n",(0,r.jsxs)(n.li,{children:["To utilize the continuous batching feature for boosting throughput and minimizing latency in large language model (LLM) inference, include ",(0,r.jsx)(n.code,{children:"cont_batching: true"}),". For details, please refer to the ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/cont-batch",children:"Continuous Batching in the Nitro documentation"}),"."]}),"\n"]})}),"\n",(0,r.jsx)(n.admonition,{title:"Assistance and Support",type:"info",children:(0,r.jsxs)(n.p,{children:["If you have questions, please join our ",(0,r.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," for support, updates, and discussions."]})})]})}function p(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>a});t(96540);var r=t(18215);const s={tabItem:"tabItem_Ymn6"};var i=t(74848);function a(e){let{children:n,hidden:t,className:a}=e;return(0,i.jsx)("div",{role:"tabpanel",className:(0,r.A)(s.tabItem,a),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>w});var r=t(96540),s=t(18215),i=t(23104),a=t(56347),l=t(205),o=t(57485),c=t(31682),d=t(89466);function u(e){return r.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function h(e){const{values:n,children:t}=e;return(0,r.useMemo)((()=>{const e=n??function(e){return u(e).map((e=>{let{props:{value:n,label:t,attributes:r,default:s}}=e;return{value:n,label:t,attributes:r,default:s}}))}(t);return function(e){const n=(0,c.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function m(e){let{queryString:n=!1,groupId:t}=e;const s=(0,a.W6)(),i=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,o.aZ)(i),(0,r.useCallback)((e=>{if(!i)return;const n=new URLSearchParams(s.location.search);n.set(i,e),s.replace({...s.location,search:n.toString()})}),[i,s])]}function x(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,i=h(e),[a,o]=(0,r.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const r=t.find((e=>e.default))??t[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:n,tabValues:i}))),[c,u]=m({queryString:t,groupId:s}),[x,g]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,i]=(0,d.Dv)(t);return[s,(0,r.useCallback)((e=>{t&&i.set(e)}),[t,i])]}({groupId:s}),f=(()=>{const e=c??x;return p({value:e,tabValues:i})?e:null})();(0,l.A)((()=>{f&&o(f)}),[f]);return{selectedValue:a,selectValue:(0,r.useCallback)((e=>{if(!p({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);o(e),u(e),g(e)}),[u,g,i]),tabValues:i}}var g=t(92303);const f={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var j=t(74848);function b(e){let{className:n,block:t,selectedValue:r,selectValue:a,tabValues:l}=e;const o=[],{blockElementScrollPositionUntilNextRender:c}=(0,i.a_)(),d=e=>{const n=e.currentTarget,t=o.indexOf(n),s=l[t].value;s!==r&&(c(n),a(s))},u=e=>{let n=null;switch(e.key){case"Enter":d(e);break;case"ArrowRight":{const t=o.indexOf(e.currentTarget)+1;n=o[t]??o[0];break}case"ArrowLeft":{const t=o.indexOf(e.currentTarget)-1;n=o[t]??o[o.length-1];break}}n?.focus()};return(0,j.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:l.map((e=>{let{value:n,label:t,attributes:i}=e;return(0,j.jsx)("li",{role:"tab",tabIndex:r===n?0:-1,"aria-selected":r===n,ref:e=>o.push(e),onKeyDown:u,onClick:d,...i,className:(0,s.A)("tabs__item",f.tabItem,i?.className,{"tabs__item--active":r===n}),children:t??n},n)}))})}function v(e){let{lazy:n,children:t,selectedValue:s}=e;const i=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=i.find((e=>e.props.value===s));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return(0,j.jsx)("div",{className:"margin-top--md",children:i.map(((e,n)=>(0,r.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function y(e){const n=x(e);return(0,j.jsxs)("div",{className:(0,s.A)("tabs-container",f.tabList),children:[(0,j.jsx)(b,{...e,...n}),(0,j.jsx)(v,{...e,...n})]})}function w(e){const n=(0,g.A)();return(0,j.jsx)(y,{...e,children:u(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>l});var r=t(96540);const s={},i=r.createContext(s);function a(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/5b9b123e.e78e1055.js b/assets/js/5b9b123e.e78e1055.js new file mode 100644 index 00000000..e5421ebe --- /dev/null +++ b/assets/js/5b9b123e.e78e1055.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7785],{60365:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>o,default:()=>p,frontMatter:()=>l,metadata:()=>c,toc:()=>u});var r=t(74848),s=t(28453),i=t(11470),a=t(19365);const l={title:"Llama.cpp Extension",slug:"/guides/engines/llamacpp",sidebar_position:1,description:"A step-by-step guide on how to customize the LlamaCPP extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Llama CPP integration","LlamaCPP Extension"]},o=void 0,c={id:"guides/local-providers/llamacpp",title:"Llama.cpp Extension",description:"A step-by-step guide on how to customize the LlamaCPP extension.",source:"@site/docs/guides/local-providers/llamacpp.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/llamacpp",permalink:"/guides/engines/llamacpp",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/llamacpp.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Llama.cpp Extension",slug:"/guides/engines/llamacpp",sidebar_position:1,description:"A step-by-step guide on how to customize the LlamaCPP extension.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Llama CPP integration","LlamaCPP Extension"]},sidebar:"guidesSidebar",previous:{title:"Local Engines",permalink:"/guides/engines/local"},next:{title:"TensorRT-LLM Extension",permalink:"/guides/engines/tensorrt-llm"}},d={},u=[{value:"Overview",id:"overview",level:2},{value:"LlamaCPP Extension",id:"llamacpp-extension",level:2}];function h(e){const n={a:"a",admonition:"admonition",code:"code",em:"em",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"Nitro"})," is an inference server on top of ",(0,r.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp",children:"llama.cpp"}),". It provides an OpenAI-compatible API, queue, & scaling."]}),"\n",(0,r.jsx)(n.h2,{id:"llamacpp-extension",children:"LlamaCPP Extension"}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"Nitro is the default AI engine downloaded with Jan. There is no additional setup needed."})}),"\n",(0,r.jsxs)(n.p,{children:["In this guide, we'll walk you through the process of customizing your engine settings by configuring the ",(0,r.jsx)(n.code,{children:"nitro.json"})," file"]}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:["Navigate to the ",(0,r.jsx)(n.code,{children:"App Settings"})," > ",(0,r.jsx)(n.code,{children:"Advanced"})," > ",(0,r.jsx)(n.code,{children:"Open App Directory"})," > ",(0,r.jsx)(n.code,{children:"~/jan/engine"})," folder."]}),"\n"]}),"\n",(0,r.jsxs)(i.A,{children:[(0,r.jsx)(a.A,{value:"mac",label:"MacOS",default:!0,children:(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"cd ~/jan/engines\n"})})}),(0,r.jsx)(a.A,{value:"windows",label:"Windows",default:!0,children:(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"C:/Users//jan/engines\n"})})}),(0,r.jsx)(a.A,{value:"linux",label:"Linux",default:!0,children:(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-sh",children:"cd ~/jan/engines\n"})})})]}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsxs)(n.li,{children:["Modify the ",(0,r.jsx)(n.code,{children:"nitro.json"})," file based on your needs. The default settings are shown below."]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/nitro.json"',children:'{\n "ctx_len": 2048,\n "ngl": 100,\n "cpu_threads": 1,\n "cont_batching": false,\n "embedding": false\n}\n'})}),"\n",(0,r.jsxs)(n.p,{children:["The table below describes the parameters in the ",(0,r.jsx)(n.code,{children:"nitro.json"})," file."]}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Parameter"}),(0,r.jsx)(n.th,{children:"Type"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"ctx_len"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsxs)(n.td,{children:["Typically set at ",(0,r.jsx)(n.code,{children:"2048"}),", ",(0,r.jsx)(n.code,{children:"ctx_len"})," provides ample context for model operations like ",(0,r.jsx)(n.code,{children:"GPT-3.5"}),". (",(0,r.jsx)(n.em,{children:"Maximum"}),": ",(0,r.jsx)(n.code,{children:"4096"}),", ",(0,r.jsx)(n.em,{children:"Minimum"}),": ",(0,r.jsx)(n.code,{children:"1"}),")"]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"ngl"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsxs)(n.td,{children:["Defaulted at ",(0,r.jsx)(n.code,{children:"100"}),", ",(0,r.jsx)(n.code,{children:"ngl"})," determines GPU layer usage."]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"cpu_threads"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsxs)(n.td,{children:["Determines CPU inference threads, limited by hardware and OS. (",(0,r.jsx)(n.em,{children:"Maximum"})," determined by system)"]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"cont_batching"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsx)(n.td,{children:"Controls continuous batching, enhancing throughput for LLM inference."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"embedding"})}),(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Integer"})}),(0,r.jsx)(n.td,{children:"Enables embedding utilization for tasks like document-enhanced chat in RAG-based applications."})]})]})]}),"\n",(0,r.jsx)(n.admonition,{type:"tip",children:(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["By default, the value of ",(0,r.jsx)(n.code,{children:"ngl"})," is set to 100, which indicates that it will offload all. If you wish to offload only 50% of the GPU, you can set ",(0,r.jsx)(n.code,{children:"ngl"})," to 15 because most models on Mistral or Llama are around ~ 30 layers."]}),"\n",(0,r.jsxs)(n.li,{children:["To utilize the embedding feature, include the JSON parameter ",(0,r.jsx)(n.code,{children:'"embedding": true'}),". It will enable Nitro to process inferences with embedding capabilities. Please refer to the ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/embed",children:"Embedding in the Nitro documentation"})," for a more detailed explanation."]}),"\n",(0,r.jsxs)(n.li,{children:["To utilize the continuous batching feature for boosting throughput and minimizing latency in large language model (LLM) inference, include ",(0,r.jsx)(n.code,{children:"cont_batching: true"}),". For details, please refer to the ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/cont-batch",children:"Continuous Batching in the Nitro documentation"}),"."]}),"\n"]})}),"\n",(0,r.jsx)(n.admonition,{title:"Assistance and Support",type:"info",children:(0,r.jsxs)(n.p,{children:["If you have questions, please join our ",(0,r.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," for support, updates, and discussions."]})})]})}function p(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>a});t(96540);var r=t(18215);const s={tabItem:"tabItem_Ymn6"};var i=t(74848);function a(e){let{children:n,hidden:t,className:a}=e;return(0,i.jsx)("div",{role:"tabpanel",className:(0,r.A)(s.tabItem,a),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>w});var r=t(96540),s=t(18215),i=t(23104),a=t(56347),l=t(205),o=t(57485),c=t(31682),d=t(89466);function u(e){return r.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function h(e){const{values:n,children:t}=e;return(0,r.useMemo)((()=>{const e=n??function(e){return u(e).map((e=>{let{props:{value:n,label:t,attributes:r,default:s}}=e;return{value:n,label:t,attributes:r,default:s}}))}(t);return function(e){const n=(0,c.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function m(e){let{queryString:n=!1,groupId:t}=e;const s=(0,a.W6)(),i=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,o.aZ)(i),(0,r.useCallback)((e=>{if(!i)return;const n=new URLSearchParams(s.location.search);n.set(i,e),s.replace({...s.location,search:n.toString()})}),[i,s])]}function x(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,i=h(e),[a,o]=(0,r.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const r=t.find((e=>e.default))??t[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:n,tabValues:i}))),[c,u]=m({queryString:t,groupId:s}),[x,g]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,i]=(0,d.Dv)(t);return[s,(0,r.useCallback)((e=>{t&&i.set(e)}),[t,i])]}({groupId:s}),f=(()=>{const e=c??x;return p({value:e,tabValues:i})?e:null})();(0,l.A)((()=>{f&&o(f)}),[f]);return{selectedValue:a,selectValue:(0,r.useCallback)((e=>{if(!p({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);o(e),u(e),g(e)}),[u,g,i]),tabValues:i}}var g=t(92303);const f={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var j=t(74848);function b(e){let{className:n,block:t,selectedValue:r,selectValue:a,tabValues:l}=e;const o=[],{blockElementScrollPositionUntilNextRender:c}=(0,i.a_)(),d=e=>{const n=e.currentTarget,t=o.indexOf(n),s=l[t].value;s!==r&&(c(n),a(s))},u=e=>{let n=null;switch(e.key){case"Enter":d(e);break;case"ArrowRight":{const t=o.indexOf(e.currentTarget)+1;n=o[t]??o[0];break}case"ArrowLeft":{const t=o.indexOf(e.currentTarget)-1;n=o[t]??o[o.length-1];break}}n?.focus()};return(0,j.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:l.map((e=>{let{value:n,label:t,attributes:i}=e;return(0,j.jsx)("li",{role:"tab",tabIndex:r===n?0:-1,"aria-selected":r===n,ref:e=>o.push(e),onKeyDown:u,onClick:d,...i,className:(0,s.A)("tabs__item",f.tabItem,i?.className,{"tabs__item--active":r===n}),children:t??n},n)}))})}function v(e){let{lazy:n,children:t,selectedValue:s}=e;const i=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=i.find((e=>e.props.value===s));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return(0,j.jsx)("div",{className:"margin-top--md",children:i.map(((e,n)=>(0,r.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function y(e){const n=x(e);return(0,j.jsxs)("div",{className:(0,s.A)("tabs-container",f.tabList),children:[(0,j.jsx)(b,{...e,...n}),(0,j.jsx)(v,{...e,...n})]})}function w(e){const n=(0,g.A)();return(0,j.jsx)(y,{...e,children:u(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>l});var r=t(96540);const s={},i=r.createContext(s);function a(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/5d1d7bd5.09d49ef4.js b/assets/js/5d1d7bd5.09d49ef4.js new file mode 100644 index 00000000..124e1e2c --- /dev/null +++ b/assets/js/5d1d7bd5.09d49ef4.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2873],{49205:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>a,default:()=>h,frontMatter:()=>o,metadata:()=>r,toc:()=>c});var l=i(74848),s=i(28453);const o={sidebar_position:8,slug:"/changelog/changelog-v0.4.2"},a="v0.4.2",r={id:"releases/changelog/changelog-v0.4.2",title:"v0.4.2",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.2.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.2",permalink:"/changelog/changelog-v0.4.2",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.2.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:8,frontMatter:{sidebar_position:8,slug:"/changelog/changelog-v0.4.2"},sidebar:"releasesSidebar",previous:{title:"v0.4.3",permalink:"/changelog/changelog-v0.4.3"},next:{title:"v0.4.1",permalink:"/changelog/changelog-v0.4.1"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v042",children:"v0.4.2"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.2",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1033",children:"Issue #1033: Hotfix model hub"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Hotfix model hub @hahuyhoang411 (#1033)"}),"\n",(0,l.jsx)(n.li,{children:"Update Model.json @hahuyhoang411 (#1005)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: app theme depend on local storage instead native theme electron @urmauur (#1014)"}),"\n",(0,l.jsx)(n.li,{children:"feat: move stop inference button into the send button @urmauur (#1011)"}),"\n",(0,l.jsx)(n.li,{children:"feat: loader when starting model @urmauur (#945)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable download app linux @urmauur (#993)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove coming soon windows @urmauur (#986)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: migrate new models @louis-jan (#1034)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add input for api key remote model @urmauur (#1031)"}),"\n",(0,l.jsx)(n.li,{children:"fix bug #1013, enable posthog for release app version only @hiento09 (#1019)"}),"\n",(0,l.jsx)(n.li,{children:"fix: delete first message then regenerate again will break the thread @louis-jan (#1015)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #995 - Fix onboarding state and model sorting @louis-jan (#1009)"}),"\n",(0,l.jsx)(n.li,{children:"fix: limit analytics events capture @louis-jan (#1012)"}),"\n",(0,l.jsx)(n.li,{children:"fix: wrong selected model right panel @urmauur (#1001)"}),"\n",(0,l.jsx)(n.li,{children:"fix: review finder and view as json @louis-jan (#1000)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable download app linux @urmauur (#993)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: remigrate if there is no models dir @louis-jan (#1038)"}),"\n",(0,l.jsx)(n.li,{children:"bump nitro version to 0.1.30 @hiento09 (#1036)"}),"\n",(0,l.jsx)(n.li,{children:"chore: in app copy fixes @0xSage (#1032)"}),"\n",(0,l.jsx)(n.li,{children:"Separate posthog project for jan app and docs @hiento09 (#1029)"}),"\n",(0,l.jsx)(n.li,{children:"Update posthog capture url list @hiento09 (#1022)"}),"\n",(0,l.jsx)(n.li,{children:'docs: second half of "import model docs" PR @0xSage (#1021)'}),"\n",(0,l.jsx)(n.li,{children:"docs: how to import models @0xSage (#1020)"}),"\n",(0,l.jsx)(n.li,{children:"fix bug #1013, enable posthog for release app version only @hiento09 (#1019)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @jan-service-account, @louis-jan and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>a,x:()=>r});var l=i(96540);const s={},o=l.createContext(s);function a(e){const n=l.useContext(o);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),l.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/5d1d7bd5.d859ce42.js b/assets/js/5d1d7bd5.d859ce42.js deleted file mode 100644 index 947f8670..00000000 --- a/assets/js/5d1d7bd5.d859ce42.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2873],{49205:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>a,default:()=>h,frontMatter:()=>o,metadata:()=>r,toc:()=>c});var l=i(74848),s=i(28453);const o={sidebar_position:8,slug:"/changelog/changelog-v0.4.2"},a="v0.4.2",r={id:"releases/changelog/changelog-v0.4.2",title:"v0.4.2",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.2.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.2",permalink:"/changelog/changelog-v0.4.2",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.2.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:8,frontMatter:{sidebar_position:8,slug:"/changelog/changelog-v0.4.2"},sidebar:"releasesSidebar",previous:{title:"v0.4.3",permalink:"/changelog/changelog-v0.4.3"},next:{title:"v0.4.1",permalink:"/changelog/changelog-v0.4.1"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v042",children:"v0.4.2"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.2",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1033",children:"Issue #1033: Hotfix model hub"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Hotfix model hub @hahuyhoang411 (#1033)"}),"\n",(0,l.jsx)(n.li,{children:"Update Model.json @hahuyhoang411 (#1005)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: app theme depend on local storage instead native theme electron @urmauur (#1014)"}),"\n",(0,l.jsx)(n.li,{children:"feat: move stop inference button into the send button @urmauur (#1011)"}),"\n",(0,l.jsx)(n.li,{children:"feat: loader when starting model @urmauur (#945)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable download app linux @urmauur (#993)"}),"\n",(0,l.jsx)(n.li,{children:"fix: remove coming soon windows @urmauur (#986)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: migrate new models @louis-jan (#1034)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add input for api key remote model @urmauur (#1031)"}),"\n",(0,l.jsx)(n.li,{children:"fix bug #1013, enable posthog for release app version only @hiento09 (#1019)"}),"\n",(0,l.jsx)(n.li,{children:"fix: delete first message then regenerate again will break the thread @louis-jan (#1015)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #995 - Fix onboarding state and model sorting @louis-jan (#1009)"}),"\n",(0,l.jsx)(n.li,{children:"fix: limit analytics events capture @louis-jan (#1012)"}),"\n",(0,l.jsx)(n.li,{children:"fix: wrong selected model right panel @urmauur (#1001)"}),"\n",(0,l.jsx)(n.li,{children:"fix: review finder and view as json @louis-jan (#1000)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable download app linux @urmauur (#993)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: remigrate if there is no models dir @louis-jan (#1038)"}),"\n",(0,l.jsx)(n.li,{children:"bump nitro version to 0.1.30 @hiento09 (#1036)"}),"\n",(0,l.jsx)(n.li,{children:"chore: in app copy fixes @0xSage (#1032)"}),"\n",(0,l.jsx)(n.li,{children:"Separate posthog project for jan app and docs @hiento09 (#1029)"}),"\n",(0,l.jsx)(n.li,{children:"Update posthog capture url list @hiento09 (#1022)"}),"\n",(0,l.jsx)(n.li,{children:'docs: second half of "import model docs" PR @0xSage (#1021)'}),"\n",(0,l.jsx)(n.li,{children:"docs: how to import models @0xSage (#1020)"}),"\n",(0,l.jsx)(n.li,{children:"fix bug #1013, enable posthog for release app version only @hiento09 (#1019)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @jan-service-account, @louis-jan and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>a,x:()=>r});var l=i(96540);const s={},o=l.createContext(s);function a(e){const n=l.useContext(o);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),l.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/623a8400.a9906d94.js b/assets/js/623a8400.a9906d94.js deleted file mode 100644 index ae9ab059..00000000 --- a/assets/js/623a8400.a9906d94.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9651],{89916:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>c,default:()=>u,frontMatter:()=>o,metadata:()=>s,toc:()=>a});var i=t(74848),r=t(28453);const o={title:"CI & CD",slug:"/engineering/ci-cd"},c=void 0,s={id:"how-we-work/engineering/ci-cd",title:"CI & CD",description:"Gitflow",source:"@site/docs/how-we-work/engineering/ci-cd.md",sourceDirName:"how-we-work/engineering",slug:"/engineering/ci-cd",permalink:"/engineering/ci-cd",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/engineering/ci-cd.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"CI & CD",slug:"/engineering/ci-cd"},sidebar:"aboutSidebar",previous:{title:"Engineering",permalink:"/engineering"},next:{title:"QA",permalink:"/engineering/qa"}},d={},a=[{value:"Gitflow",id:"gitflow",level:2}];function l(e){const n={h2:"h2",p:"p",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"gitflow",children:"Gitflow"}),"\n",(0,i.jsx)(n.p,{children:"Previously we were trunk based. Now we use the following Gitflow:"}),"\n",(0,i.jsx)(n.p,{children:"TODO: @van to include her Mermaid diagram"})]})}function u(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(l,{...e})}):l(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>c,x:()=>s});var i=t(96540);const r={},o=i.createContext(r);function c(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:c(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/623a8400.f729996f.js b/assets/js/623a8400.f729996f.js new file mode 100644 index 00000000..0f803a12 --- /dev/null +++ b/assets/js/623a8400.f729996f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9651],{89916:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>c,default:()=>u,frontMatter:()=>o,metadata:()=>s,toc:()=>a});var i=t(74848),r=t(28453);const o={title:"CI & CD",slug:"/engineering/ci-cd"},c=void 0,s={id:"how-we-work/engineering/ci-cd",title:"CI & CD",description:"Gitflow",source:"@site/docs/how-we-work/engineering/ci-cd.md",sourceDirName:"how-we-work/engineering",slug:"/engineering/ci-cd",permalink:"/engineering/ci-cd",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/engineering/ci-cd.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"CI & CD",slug:"/engineering/ci-cd"},sidebar:"aboutSidebar",previous:{title:"Engineering",permalink:"/engineering"},next:{title:"QA",permalink:"/engineering/qa"}},d={},a=[{value:"Gitflow",id:"gitflow",level:2}];function l(e){const n={h2:"h2",p:"p",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"gitflow",children:"Gitflow"}),"\n",(0,i.jsx)(n.p,{children:"Previously we were trunk based. Now we use the following Gitflow:"}),"\n",(0,i.jsx)(n.p,{children:"TODO: @van to include her Mermaid diagram"})]})}function u(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(l,{...e})}):l(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>c,x:()=>s});var i=t(96540);const r={},o=i.createContext(r);function c(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:c(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/637ab85d.83cb35d9.js b/assets/js/637ab85d.83cb35d9.js new file mode 100644 index 00000000..721cdea9 --- /dev/null +++ b/assets/js/637ab85d.83cb35d9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4207],{95199:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>i,default:()=>l,frontMatter:()=>r,metadata:()=>a,toc:()=>c});var o=n(74848),s=n(28453);const r={title:"Overview",slug:"/guides/overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,a={id:"guides/user-guides/overview-guides",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/overview-guides.mdx",sourceDirName:"guides/user-guides",slug:"/guides/overview",permalink:"/guides/overview",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/overview-guides.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Overview",slug:"/guides/overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},u={},c=[];function d(e){const t={p:"p",...(0,s.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>a});var o=n(96540);const s={},r=o.createContext(s);function i(e){const t=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),o.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/637ab85d.e4582c46.js b/assets/js/637ab85d.e4582c46.js deleted file mode 100644 index 34c088a9..00000000 --- a/assets/js/637ab85d.e4582c46.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4207],{95199:(e,t,o)=>{o.r(t),o.d(t,{assets:()=>u,contentTitle:()=>r,default:()=>l,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var n=o(74848),s=o(28453);const i={title:"Overview",slug:"/guides/overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:5,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,a={id:"guides/user-guides/overview-guides",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/overview-guides.mdx",sourceDirName:"guides/user-guides",slug:"/guides/overview",permalink:"/guides/overview",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/overview-guides.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:5,frontMatter:{title:"Overview",slug:"/guides/overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:5,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},u={},c=[];function d(e){const t={p:"p",...(0,s.R)(),...e.components};return(0,n.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d(e)}},28453:(e,t,o)=>{o.d(t,{R:()=>r,x:()=>a});var n=o(96540);const s={},i=n.createContext(s);function r(e){const t=n.useContext(i);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),n.createElement(i.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/63f5f85b.2e9002b9.js b/assets/js/63f5f85b.2e9002b9.js new file mode 100644 index 00000000..a78802f1 --- /dev/null +++ b/assets/js/63f5f85b.2e9002b9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4558],{20820:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>c,contentTitle:()=>o,default:()=>l,frontMatter:()=>i,metadata:()=>a,toc:()=>u});var s=r(74848),n=r(28453);const i={title:"Observability"},o=void 0,a={id:"server-suite/observability",title:"Observability",description:"",source:"@site/docs/server-suite/observability.md",sourceDirName:"server-suite",slug:"/server-suite/observability",permalink:"/server-suite/observability",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/observability.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Observability"}},c={},u=[];function d(t){return(0,s.jsx)(s.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(d,{...t})}):d()}},28453:(t,e,r)=>{r.d(e,{R:()=>o,x:()=>a});var s=r(96540);const n={},i=s.createContext(n);function o(t){const e=s.useContext(i);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:o(t.components),s.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/63f5f85b.b650fc0d.js b/assets/js/63f5f85b.b650fc0d.js deleted file mode 100644 index f51f25ce..00000000 --- a/assets/js/63f5f85b.b650fc0d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4558],{20820:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>c,contentTitle:()=>o,default:()=>l,frontMatter:()=>i,metadata:()=>a,toc:()=>u});var s=r(74848),n=r(28453);const i={title:"Observability"},o=void 0,a={id:"server-suite/observability",title:"Observability",description:"",source:"@site/docs/server-suite/observability.md",sourceDirName:"server-suite",slug:"/server-suite/observability",permalink:"/server-suite/observability",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/observability.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Observability"}},c={},u=[];function d(t){return(0,s.jsx)(s.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(d,{...t})}):d()}},28453:(t,e,r)=>{r.d(e,{R:()=>o,x:()=>a});var s=r(96540);const n={},i=s.createContext(n);function o(t){const e=s.useContext(i);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:o(t.components),s.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/6477de9f.7092cd20.js b/assets/js/6477de9f.7092cd20.js new file mode 100644 index 00000000..7025dd15 --- /dev/null +++ b/assets/js/6477de9f.7092cd20.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3919],{20582:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>o,contentTitle:()=>d,default:()=>x,frontMatter:()=>r,metadata:()=>i,toc:()=>a});var n=s(74848),l=s(28453);const r={title:"2 x 4090 Workstation"},d=void 0,i={id:"hardware/examples/4090x2-@dan-jan",title:"2 x 4090 Workstation",description:"Jan uses a 2 x 4090 Workstation to run Codellama for internal use.",source:"@site/docs/hardware/examples/4090x2-@dan-jan.md",sourceDirName:"hardware/examples",slug:"/hardware/examples/4090x2-@dan-jan",permalink:"/hardware/examples/4090x2-@dan-jan",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/examples/4090x2-@dan-jan.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"2 x 4090 Workstation"}},o={},a=[{value:"Component List",id:"component-list",level:2}];function c(t){const e={a:"a",h2:"h2",img:"img",li:"li",ol:"ol",p:"p",section:"section",strong:"strong",sup:"sup",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,l.R)(),...t.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(e.p,{children:(0,n.jsx)(e.img,{src:s(26106).A+"",width:"1080",height:"810"})}),"\n",(0,n.jsxs)(e.p,{children:["Jan uses a 2 x 4090 Workstation to run Codellama for internal use.",(0,n.jsx)(e.sup,{children:(0,n.jsx)(e.a,{href:"#user-content-fn-1",id:"user-content-fnref-1","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"1"})})]}),"\n",(0,n.jsx)(e.h2,{id:"component-list",children:"Component List"}),"\n",(0,n.jsxs)(e.table,{children:[(0,n.jsx)(e.thead,{children:(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.th,{style:{textAlign:"left"},children:"Type"}),(0,n.jsx)(e.th,{style:{textAlign:"left"},children:"Item"}),(0,n.jsx)(e.th,{style:{textAlign:"left"},children:"Unit Price"}),(0,n.jsx)(e.th,{children:"Total Price"})]})}),(0,n.jsxs)(e.tbody,{children:[(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"CPU"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Ryzen Threadripper Pro 5965WX 280W SP3 WOF"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$2,229"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Motherboard"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Asus Pro WS WRX80E Sage SE WiFi"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$933"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"RAM"})}),(0,n.jsxs)(e.td,{style:{textAlign:"left"},children:["4 x ",(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"G.Skill Ripjaw S5 2x32 6000C32"})]}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$92.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"GPU"})}),(0,n.jsxs)(e.td,{style:{textAlign:"left"},children:["2 x ",(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Asus Strix RTX 4090 24GB OC"})]}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$4,345"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Storage PCIe-SSD"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Samsung 990 Pro 2TB NVME 2.0"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$134.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Cooler"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"BeQuiet Dark Rock 4 Pro TR4"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$89.90"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Power Supply"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"FSP Cannon 2000W Pro 92+ Full Modular PSU"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$449.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Case"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Veddha 6GPUs Frame Black"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$59.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Total cost"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"}}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$8,334"}),(0,n.jsx)(e.td,{})]})]})]}),"\n",(0,n.jsxs)(e.section,{"data-footnotes":!0,className:"footnotes",children:[(0,n.jsx)(e.h2,{className:"sr-only",id:"footnote-label",children:"Footnotes"}),"\n",(0,n.jsxs)(e.ol,{children:["\n",(0,n.jsxs)(e.li,{id:"user-content-fn-1",children:["\n",(0,n.jsxs)(e.p,{children:[(0,n.jsx)(e.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/16lxt6a/case_for_dual_4090s/",children:"https://www.reddit.com/r/LocalLLaMA/comments/16lxt6a/case_for_dual_4090s/"}),". ideb ",(0,n.jsx)(e.a,{href:"#user-content-fnref-1","data-footnote-backref":"","aria-label":"Back to reference 1",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n"]}),"\n"]})]})}function x(t={}){const{wrapper:e}={...(0,l.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(c,{...t})}):c(t)}},26106:(t,e,s)=>{s.d(e,{A:()=>n});const n=s.p+"assets/images/2x4090-workstation-671a6aa851d801e403ec9cb851475c33.png"},28453:(t,e,s)=>{s.d(e,{R:()=>d,x:()=>i});var n=s(96540);const l={},r=n.createContext(l);function d(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(l):t.components||l:d(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/6477de9f.f0568966.js b/assets/js/6477de9f.f0568966.js deleted file mode 100644 index 01fe7880..00000000 --- a/assets/js/6477de9f.f0568966.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3919],{20582:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>a,contentTitle:()=>d,default:()=>x,frontMatter:()=>r,metadata:()=>i,toc:()=>o});var n=s(74848),l=s(28453);const r={title:"2 x 4090 Workstation"},d=void 0,i={id:"hardware/examples/4090x2-@dan-jan",title:"2 x 4090 Workstation",description:"Jan uses a 2 x 4090 Workstation to run Codellama for internal use.",source:"@site/docs/hardware/examples/4090x2-@dan-jan.md",sourceDirName:"hardware/examples",slug:"/hardware/examples/4090x2-@dan-jan",permalink:"/hardware/examples/4090x2-@dan-jan",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/examples/4090x2-@dan-jan.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"2 x 4090 Workstation"}},a={},o=[{value:"Component List",id:"component-list",level:2}];function c(t){const e={a:"a",h2:"h2",img:"img",li:"li",ol:"ol",p:"p",section:"section",strong:"strong",sup:"sup",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,l.R)(),...t.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(e.p,{children:(0,n.jsx)(e.img,{src:s(26106).A+"",width:"1080",height:"810"})}),"\n",(0,n.jsxs)(e.p,{children:["Jan uses a 2 x 4090 Workstation to run Codellama for internal use.",(0,n.jsx)(e.sup,{children:(0,n.jsx)(e.a,{href:"#user-content-fn-1",id:"user-content-fnref-1","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"1"})})]}),"\n",(0,n.jsx)(e.h2,{id:"component-list",children:"Component List"}),"\n",(0,n.jsxs)(e.table,{children:[(0,n.jsx)(e.thead,{children:(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.th,{style:{textAlign:"left"},children:"Type"}),(0,n.jsx)(e.th,{style:{textAlign:"left"},children:"Item"}),(0,n.jsx)(e.th,{style:{textAlign:"left"},children:"Unit Price"}),(0,n.jsx)(e.th,{children:"Total Price"})]})}),(0,n.jsxs)(e.tbody,{children:[(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"CPU"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Ryzen Threadripper Pro 5965WX 280W SP3 WOF"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$2,229"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Motherboard"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Asus Pro WS WRX80E Sage SE WiFi"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$933"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"RAM"})}),(0,n.jsxs)(e.td,{style:{textAlign:"left"},children:["4 x ",(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"G.Skill Ripjaw S5 2x32 6000C32"})]}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$92.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"GPU"})}),(0,n.jsxs)(e.td,{style:{textAlign:"left"},children:["2 x ",(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Asus Strix RTX 4090 24GB OC"})]}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$4,345"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Storage PCIe-SSD"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Samsung 990 Pro 2TB NVME 2.0"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$134.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Cooler"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"BeQuiet Dark Rock 4 Pro TR4"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$89.90"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Power Supply"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"FSP Cannon 2000W Pro 92+ Full Modular PSU"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$449.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Case"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.a,{href:"AMAZON-LINK-HERE",children:"Veddha 6GPUs Frame Black"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$59.99"}),(0,n.jsx)(e.td,{})]}),(0,n.jsxs)(e.tr,{children:[(0,n.jsx)(e.td,{style:{textAlign:"left"},children:(0,n.jsx)(e.strong,{children:"Total cost"})}),(0,n.jsx)(e.td,{style:{textAlign:"left"}}),(0,n.jsx)(e.td,{style:{textAlign:"left"},children:"$8,334"}),(0,n.jsx)(e.td,{})]})]})]}),"\n",(0,n.jsxs)(e.section,{"data-footnotes":!0,className:"footnotes",children:[(0,n.jsx)(e.h2,{className:"sr-only",id:"footnote-label",children:"Footnotes"}),"\n",(0,n.jsxs)(e.ol,{children:["\n",(0,n.jsxs)(e.li,{id:"user-content-fn-1",children:["\n",(0,n.jsxs)(e.p,{children:[(0,n.jsx)(e.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/16lxt6a/case_for_dual_4090s/",children:"https://www.reddit.com/r/LocalLLaMA/comments/16lxt6a/case_for_dual_4090s/"}),". ideb ",(0,n.jsx)(e.a,{href:"#user-content-fnref-1","data-footnote-backref":"","aria-label":"Back to reference 1",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n"]}),"\n"]})]})}function x(t={}){const{wrapper:e}={...(0,l.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(c,{...t})}):c(t)}},26106:(t,e,s)=>{s.d(e,{A:()=>n});const n=s.p+"assets/images/2x4090-workstation-671a6aa851d801e403ec9cb851475c33.png"},28453:(t,e,s)=>{s.d(e,{R:()=>d,x:()=>i});var n=s(96540);const l={},r=n.createContext(l);function d(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(l):t.components||l:d(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/667ed12c.a555f5cb.js b/assets/js/667ed12c.a555f5cb.js new file mode 100644 index 00000000..d4c87e29 --- /dev/null +++ b/assets/js/667ed12c.a555f5cb.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[259],{30749:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>a,contentTitle:()=>r,default:()=>h,frontMatter:()=>s,metadata:()=>l,toc:()=>d});var t=o(74848),i=o(28453);const s={title:"Any OAI Compatible Server",sidebar_position:1,slug:"/guides/engines/remote-server",description:"A step-by-step guide on how to set up Jan to connect with any remote or local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","import-models-manually","remote server","OAI compatible"]},r=void 0,l={id:"guides/remote-providers/remote-server-integration",title:"Any OAI Compatible Server",description:"A step-by-step guide on how to set up Jan to connect with any remote or local API server.",source:"@site/docs/guides/remote-providers/remote-server-integration.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/remote-server",permalink:"/guides/engines/remote-server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/remote-server-integration.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Any OAI Compatible Server",sidebar_position:1,slug:"/guides/engines/remote-server",description:"A step-by-step guide on how to set up Jan to connect with any remote or local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","import-models-manually","remote server","OAI compatible"]},sidebar:"guidesSidebar",previous:{title:"OpenAI API",permalink:"/guides/engines/openai"},next:{title:"What are Jan Extensions?",permalink:"/extensions"}},a={},d=[{value:"1. Configure a Client Connection",id:"1-configure-a-client-connection",level:3},{value:"2. Create a Model JSON",id:"2-create-a-model-json",level:3},{value:"3. Start the Model",id:"3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.p,{children:"This guide will show you how to configure Jan as a client and point it to any remote or local (self-hosted) API server."}),"\n",(0,t.jsxs)(n.p,{children:["This section will show you how to configure a client connection to a remote/local server using Jan's API server running model ",(0,t.jsx)(n.code,{children:"mistral-ins-7b-q4"})," as an example."]}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsx)(n.p,{children:"Currently, you can only connect to one OpenAI-compatible endpoint at a time."})}),"\n",(0,t.jsx)(n.h3,{id:"1-configure-a-client-connection",children:"1. Configure a Client Connection"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Navigate to the ",(0,t.jsx)(n.code,{children:"~/jan/engines"})," folder."]}),"\n",(0,t.jsxs)(n.li,{children:["Modify the ",(0,t.jsx)(n.code,{children:"openai.json file"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["Please note that currently, the code that supports any OpenAI-compatible endpoint only reads ",(0,t.jsx)(n.code,{children:"engine/openai.json"})," file. Thus, it will not search any other files in this directory."]})}),"\n",(0,t.jsxs)(n.ol,{start:"3",children:["\n",(0,t.jsxs)(n.li,{children:["Configure ",(0,t.jsx)(n.code,{children:"full_url"})," properties with the endpoint server that you want to connect. For example, if you're going to communicate to Jan's API server, you can configure it as follows:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n // "full_url": "https://:/v1/chat/completions"\n "full_url": "https://:1337/v1/chat/completions"\n // Skip api_key if your local server does not require authentication\n // "api_key": "sk-"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"2-create-a-model-json",children:"2. Create a Model JSON"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In ",(0,t.jsx)(n.code,{children:"~/jan/models"}),", create a folder named ",(0,t.jsx)(n.code,{children:"mistral-ins-7b-q4"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In this folder, add a ",(0,t.jsx)(n.code,{children:"model.json"})," file with Filename as ",(0,t.jsx)(n.code,{children:"model.json"}),", ensure the following configurations:"]}),"\n"]}),"\n"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"id"})," matching folder name."]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"Format"})," set to ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"Engine"})," set to ",(0,t.jsx)(n.code,{children:"openai"})]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"State"})," set to ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/mistral-ins-7b-q4/model.json"',children:'{\n "sources": [\n {\n "filename": "janai",\n "url": "https://jan.ai"\n }\n ],\n "id": "mistral-ins-7b-q4",\n "object": "model",\n "name": "Mistral Instruct 7B Q4 on Jan API Server",\n "version": "1.0",\n "description": "Jan integration with remote Jan API server",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "MistralAI, The Bloke",\n "tags": ["remote", "awesome"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"3-start-the-model",children:"3. Start the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click the ",(0,t.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]}),"\n",(0,t.jsx)(n.admonition,{title:"Assistance and Support",type:"info",children:(0,t.jsxs)(n.p,{children:["If you have questions or want more preconfigured GGUF models, please join our ",(0,t.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," for support, updates, and discussions."]})})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>r,x:()=>l});var t=o(96540);const i={},s=t.createContext(i);function r(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:r(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/667ed12c.eb08604f.js b/assets/js/667ed12c.eb08604f.js deleted file mode 100644 index e37d54fc..00000000 --- a/assets/js/667ed12c.eb08604f.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[259],{30749:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>a,contentTitle:()=>r,default:()=>h,frontMatter:()=>s,metadata:()=>l,toc:()=>d});var t=o(74848),i=o(28453);const s={title:"Any OAI Compatible Server",sidebar_position:1,slug:"/guides/engines/remote-server",description:"A step-by-step guide on how to set up Jan to connect with any remote or local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","import-models-manually","remote server","OAI compatible"]},r=void 0,l={id:"guides/remote-providers/remote-server-integration",title:"Any OAI Compatible Server",description:"A step-by-step guide on how to set up Jan to connect with any remote or local API server.",source:"@site/docs/guides/remote-providers/remote-server-integration.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/remote-server",permalink:"/guides/engines/remote-server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/remote-server-integration.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Any OAI Compatible Server",sidebar_position:1,slug:"/guides/engines/remote-server",description:"A step-by-step guide on how to set up Jan to connect with any remote or local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","import-models-manually","remote server","OAI compatible"]},sidebar:"guidesSidebar",previous:{title:"OpenAI API",permalink:"/guides/engines/openai"},next:{title:"What are Jan Extensions?",permalink:"/extensions"}},a={},d=[{value:"1. Configure a Client Connection",id:"1-configure-a-client-connection",level:3},{value:"2. Create a Model JSON",id:"2-create-a-model-json",level:3},{value:"3. Start the Model",id:"3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.p,{children:"This guide will show you how to configure Jan as a client and point it to any remote or local (self-hosted) API server."}),"\n",(0,t.jsxs)(n.p,{children:["This section will show you how to configure a client connection to a remote/local server using Jan's API server running model ",(0,t.jsx)(n.code,{children:"mistral-ins-7b-q4"})," as an example."]}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsx)(n.p,{children:"Currently, you can only connect to one OpenAI-compatible endpoint at a time."})}),"\n",(0,t.jsx)(n.h3,{id:"1-configure-a-client-connection",children:"1. Configure a Client Connection"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Navigate to the ",(0,t.jsx)(n.code,{children:"~/jan/engines"})," folder."]}),"\n",(0,t.jsxs)(n.li,{children:["Modify the ",(0,t.jsx)(n.code,{children:"openai.json file"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["Please note that currently, the code that supports any OpenAI-compatible endpoint only reads ",(0,t.jsx)(n.code,{children:"engine/openai.json"})," file. Thus, it will not search any other files in this directory."]})}),"\n",(0,t.jsxs)(n.ol,{start:"3",children:["\n",(0,t.jsxs)(n.li,{children:["Configure ",(0,t.jsx)(n.code,{children:"full_url"})," properties with the endpoint server that you want to connect. For example, if you're going to communicate to Jan's API server, you can configure it as follows:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n // "full_url": "https://:/v1/chat/completions"\n "full_url": "https://:1337/v1/chat/completions"\n // Skip api_key if your local server does not require authentication\n // "api_key": "sk-"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"2-create-a-model-json",children:"2. Create a Model JSON"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In ",(0,t.jsx)(n.code,{children:"~/jan/models"}),", create a folder named ",(0,t.jsx)(n.code,{children:"mistral-ins-7b-q4"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In this folder, add a ",(0,t.jsx)(n.code,{children:"model.json"})," file with Filename as ",(0,t.jsx)(n.code,{children:"model.json"}),", ensure the following configurations:"]}),"\n"]}),"\n"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"id"})," matching folder name."]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"Format"})," set to ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"Engine"})," set to ",(0,t.jsx)(n.code,{children:"openai"})]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"State"})," set to ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/mistral-ins-7b-q4/model.json"',children:'{\n "sources": [\n {\n "filename": "janai",\n "url": "https://jan.ai"\n }\n ],\n "id": "mistral-ins-7b-q4",\n "object": "model",\n "name": "Mistral Instruct 7B Q4 on Jan API Server",\n "version": "1.0",\n "description": "Jan integration with remote Jan API server",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "MistralAI, The Bloke",\n "tags": ["remote", "awesome"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"3-start-the-model",children:"3. Start the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click the ",(0,t.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]}),"\n",(0,t.jsx)(n.admonition,{title:"Assistance and Support",type:"info",children:(0,t.jsxs)(n.p,{children:["If you have questions or want more preconfigured GGUF models, please join our ",(0,t.jsx)(n.a,{href:"https://discord.gg/Dt7MxDyNNZ",children:"Discord community"})," for support, updates, and discussions."]})})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>r,x:()=>l});var t=o(96540);const i={},s=t.createContext(i);function r(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:r(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/6e9fbade.38992ae7.js b/assets/js/6e9fbade.38992ae7.js deleted file mode 100644 index 6429fcd9..00000000 --- a/assets/js/6e9fbade.38992ae7.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5483],{10394:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var s=r(74848),t=r(28453);const i={title:"Framework",slug:"/developer/framework/",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,a={id:"developer/framework/README",title:"Framework",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/README.md",sourceDirName:"developer/05-framework",slug:"/developer/framework/",permalink:"/developer/framework/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/README.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Framework",slug:"/developer/framework/",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Installation and Prerequisites",permalink:"/developer/prereq"},next:{title:"Engineering Specs",permalink:"/developer/engineering"}},l={},c=[{value:"Jan Framework",id:"jan-framework",level:2},{value:"Extensions",id:"extensions",level:3},{value:"Cross Platform",id:"cross-platform",level:3},{value:"Local First",id:"local-first",level:3},{value:"AI Native",id:"ai-native",level:3},{value:"Fun Project Ideas",id:"fun-project-ideas",level:2}];function d(e){const n={a:"a",admonition:"admonition",code:"code",em:"em",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.p,{children:"The following low-level docs are aimed at core contributors."}),"\n",(0,s.jsxs)(n.p,{children:["We cover how to contribute to the core framework (aka the ",(0,s.jsx)(n.code,{children:"Core SDK"}),")."]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsxs)(n.p,{children:["If you are interested to ",(0,s.jsx)(n.strong,{children:"build on top of the framework"}),", like creating assistants or adding app level extensions, please refer to ",(0,s.jsx)(n.a,{href:"/developer",children:"developer docs"})," instead."]})}),"\n",(0,s.jsx)(n.h2,{id:"jan-framework",children:"Jan Framework"}),"\n",(0,s.jsxs)(n.p,{children:["At its core, Jan is a ",(0,s.jsx)(n.strong,{children:"cross-platform, local-first and AI native framework"})," that can be used to build anything."]}),"\n",(0,s.jsx)(n.h3,{id:"extensions",children:"Extensions"}),"\n",(0,s.jsxs)(n.p,{children:["Ultimately, we aim for a ",(0,s.jsx)(n.code,{children:"VSCode"})," or ",(0,s.jsx)(n.code,{children:"Obsidian"})," like SDK that allows ",(0,s.jsx)(n.strong,{children:"devs to build and customize complex and ethical AI applications for any use case"}),", in less than 30 minutes."]}),"\n",(0,s.jsxs)(n.p,{children:["In fact, the current Jan ",(0,s.jsx)(n.a,{href:"https://jan.ai/",children:"Desktop Client"})," is actually just a specific set of extensions & integrations built on top of this framework."]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Desktop is Extensions",src:r(39110).A+"",width:"2706",height:"1770"})}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsx)(n.p,{children:"We encourage devs to fork, customize, and open source your improvements for the greater community."})}),"\n",(0,s.jsx)(n.h3,{id:"cross-platform",children:"Cross Platform"}),"\n",(0,s.jsxs)(n.p,{children:["Jan follows ",(0,s.jsx)(n.a,{href:"https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html",children:"Clean Architecture"})," to the best of our ability. Though leaky abstractions remain (we're a fast moving, open source codebase), we do our best to build an SDK that allows devs to ",(0,s.jsx)(n.strong,{children:"build once, deploy everywhere."})]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Clean Architecture",src:r(86171).A+"",width:"772",height:"567"})}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"Supported Runtimes:"})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Node Native Runtime"}),", good for server side apps"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Electron Chromium"}),", good for Desktop Native apps"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Capacitor"}),", good for Mobile apps (planned, not built yet)"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Python Runtime"}),", good for MLOps workflows (planned, not built yet)"]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"Supported OS & Architectures:"})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Mac Intel & Silicon"}),"\n",(0,s.jsx)(n.li,{children:"Windows"}),"\n",(0,s.jsx)(n.li,{children:"Linux (through AppImage)"}),"\n",(0,s.jsx)(n.li,{children:"Nvidia GPUs"}),"\n",(0,s.jsx)(n.li,{children:"AMD ROCm (coming soon)"}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"Read more:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core",children:"Code Entrypoint"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Dependency_inversion_principle",children:"Dependency Inversion"})}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"local-first",children:"Local First"}),"\n",(0,s.jsx)(n.p,{children:"Jan's data persistence happens on the user's local filesystem."}),"\n",(0,s.jsxs)(n.p,{children:["We implemented abstractions on top of ",(0,s.jsx)(n.code,{children:"fs"})," and other core modules in an opinionated way, s.t. user data is saved in a folder-based framework that lets users easily package, export, and manage their data."]}),"\n",(0,s.jsx)(n.p,{children:"Future endeavors on this front include cross device syncing, multi user experience, and more."}),"\n",(0,s.jsxs)(n.p,{children:["Long term, we want to integrate with folks working on ",(0,s.jsx)(n.a,{href:"https://www.inkandswitch.com/local-first/",children:"CRDTs"}),", e.g. ",(0,s.jsx)(n.a,{href:"https://www.theregister.com/2023/04/11/socket_runtime/",children:"Socket Runtime"})," to deeply enable local-first software."]}),"\n",(0,s.jsx)(n.p,{children:"Read more:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/main/core/src/fs.ts",children:"Folder-based wrappers entrypoint"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/node",children:"Piping Node modules across infrastructures"})}),"\n"]}),"\n",(0,s.jsx)(n.admonition,{type:"caution",children:(0,s.jsx)(n.p,{children:"Our local first approach at the moment needs a lot of work. Please don't hesitate to refactor as you make your way through the codebase."})}),"\n",(0,s.jsx)(n.h3,{id:"ai-native",children:"AI Native"}),"\n",(0,s.jsx)(n.p,{children:"We believe all software applications can be natively supercharged with AI primitives and embedded AI servers."}),"\n",(0,s.jsx)(n.p,{children:"Including:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Compatible AI ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/types",children:"types"})," and ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/extensions",children:"core extensions"})," to support common functionality like making an inference call."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:["Multiple inference engines through ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/extensions/inference-nitro-extension",children:"extensions, integrations & wrappers"})," ",(0,s.jsxs)(n.em,{children:["On this, we'd like to appreciate the folks at ",(0,s.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp",children:"llamacpp"})," and ",(0,s.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"})," for. To which we'll continue to make commits & fixes back upstream."]})]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/api",children:"Code Entrypoint"})}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"fun-project-ideas",children:"Fun Project Ideas"}),"\n",(0,s.jsx)(n.p,{children:"Beyond the current Jan client and UX, the Core SDK can be used to build many other AI-powered and privacy preserving applications."}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Game engine"}),": For AI enabled character games, procedural generation games"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Health app"}),": For a personal healthcare app that improves habits"]}),"\n",(0,s.jsx)(n.li,{children:"Got ideas? Make a PR into this docs page!"}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["If you are interested to tackle these issues, or have suggestions for integrations and other OSS tools we can use, please hit us up in ",(0,s.jsx)(n.a,{href:"https://discord.gg/5rQ2zTv3be",children:"Discord"}),"."]}),"\n",(0,s.jsx)(n.admonition,{type:"caution",children:(0,s.jsx)(n.p,{children:"Our open source license is copy left, which means we encourage forks to stay open source, and allow core contributors to merge things upstream."})})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},86171:(e,n,r)=>{r.d(n,{A:()=>s});const s=r.p+"assets/images/CleanArchitecture-26ac5f08c770e19c35a8ef38b905373f.jpg"},39110:(e,n,r)=>{r.d(n,{A:()=>s});const s=r.p+"assets/images/ExtensionCallouts-f5153831c0519e3eab145eed8be4f67d.png"},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>a});var s=r(96540);const t={},i=s.createContext(t);function o(e){const n=s.useContext(i);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),s.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/6e9fbade.9a2f8c4a.js b/assets/js/6e9fbade.9a2f8c4a.js new file mode 100644 index 00000000..5c594a06 --- /dev/null +++ b/assets/js/6e9fbade.9a2f8c4a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5483],{10394:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var s=r(74848),t=r(28453);const i={title:"Framework",slug:"/developer/framework/",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,a={id:"developer/framework/README",title:"Framework",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/README.md",sourceDirName:"developer/05-framework",slug:"/developer/framework/",permalink:"/developer/framework/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/README.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Framework",slug:"/developer/framework/",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Installation and Prerequisites",permalink:"/developer/prereq"},next:{title:"Engineering Specs",permalink:"/developer/engineering"}},l={},c=[{value:"Jan Framework",id:"jan-framework",level:2},{value:"Extensions",id:"extensions",level:3},{value:"Cross Platform",id:"cross-platform",level:3},{value:"Local First",id:"local-first",level:3},{value:"AI Native",id:"ai-native",level:3},{value:"Fun Project Ideas",id:"fun-project-ideas",level:2}];function d(e){const n={a:"a",admonition:"admonition",code:"code",em:"em",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.p,{children:"The following low-level docs are aimed at core contributors."}),"\n",(0,s.jsxs)(n.p,{children:["We cover how to contribute to the core framework (aka the ",(0,s.jsx)(n.code,{children:"Core SDK"}),")."]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsxs)(n.p,{children:["If you are interested to ",(0,s.jsx)(n.strong,{children:"build on top of the framework"}),", like creating assistants or adding app level extensions, please refer to ",(0,s.jsx)(n.a,{href:"/developer",children:"developer docs"})," instead."]})}),"\n",(0,s.jsx)(n.h2,{id:"jan-framework",children:"Jan Framework"}),"\n",(0,s.jsxs)(n.p,{children:["At its core, Jan is a ",(0,s.jsx)(n.strong,{children:"cross-platform, local-first and AI native framework"})," that can be used to build anything."]}),"\n",(0,s.jsx)(n.h3,{id:"extensions",children:"Extensions"}),"\n",(0,s.jsxs)(n.p,{children:["Ultimately, we aim for a ",(0,s.jsx)(n.code,{children:"VSCode"})," or ",(0,s.jsx)(n.code,{children:"Obsidian"})," like SDK that allows ",(0,s.jsx)(n.strong,{children:"devs to build and customize complex and ethical AI applications for any use case"}),", in less than 30 minutes."]}),"\n",(0,s.jsxs)(n.p,{children:["In fact, the current Jan ",(0,s.jsx)(n.a,{href:"https://jan.ai/",children:"Desktop Client"})," is actually just a specific set of extensions & integrations built on top of this framework."]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Desktop is Extensions",src:r(39110).A+"",width:"2706",height:"1770"})}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsx)(n.p,{children:"We encourage devs to fork, customize, and open source your improvements for the greater community."})}),"\n",(0,s.jsx)(n.h3,{id:"cross-platform",children:"Cross Platform"}),"\n",(0,s.jsxs)(n.p,{children:["Jan follows ",(0,s.jsx)(n.a,{href:"https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html",children:"Clean Architecture"})," to the best of our ability. Though leaky abstractions remain (we're a fast moving, open source codebase), we do our best to build an SDK that allows devs to ",(0,s.jsx)(n.strong,{children:"build once, deploy everywhere."})]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Clean Architecture",src:r(86171).A+"",width:"772",height:"567"})}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"Supported Runtimes:"})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Node Native Runtime"}),", good for server side apps"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Electron Chromium"}),", good for Desktop Native apps"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Capacitor"}),", good for Mobile apps (planned, not built yet)"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Python Runtime"}),", good for MLOps workflows (planned, not built yet)"]}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"Supported OS & Architectures:"})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Mac Intel & Silicon"}),"\n",(0,s.jsx)(n.li,{children:"Windows"}),"\n",(0,s.jsx)(n.li,{children:"Linux (through AppImage)"}),"\n",(0,s.jsx)(n.li,{children:"Nvidia GPUs"}),"\n",(0,s.jsx)(n.li,{children:"AMD ROCm (coming soon)"}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:"Read more:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core",children:"Code Entrypoint"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Dependency_inversion_principle",children:"Dependency Inversion"})}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"local-first",children:"Local First"}),"\n",(0,s.jsx)(n.p,{children:"Jan's data persistence happens on the user's local filesystem."}),"\n",(0,s.jsxs)(n.p,{children:["We implemented abstractions on top of ",(0,s.jsx)(n.code,{children:"fs"})," and other core modules in an opinionated way, s.t. user data is saved in a folder-based framework that lets users easily package, export, and manage their data."]}),"\n",(0,s.jsx)(n.p,{children:"Future endeavors on this front include cross device syncing, multi user experience, and more."}),"\n",(0,s.jsxs)(n.p,{children:["Long term, we want to integrate with folks working on ",(0,s.jsx)(n.a,{href:"https://www.inkandswitch.com/local-first/",children:"CRDTs"}),", e.g. ",(0,s.jsx)(n.a,{href:"https://www.theregister.com/2023/04/11/socket_runtime/",children:"Socket Runtime"})," to deeply enable local-first software."]}),"\n",(0,s.jsx)(n.p,{children:"Read more:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/main/core/src/fs.ts",children:"Folder-based wrappers entrypoint"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/node",children:"Piping Node modules across infrastructures"})}),"\n"]}),"\n",(0,s.jsx)(n.admonition,{type:"caution",children:(0,s.jsx)(n.p,{children:"Our local first approach at the moment needs a lot of work. Please don't hesitate to refactor as you make your way through the codebase."})}),"\n",(0,s.jsx)(n.h3,{id:"ai-native",children:"AI Native"}),"\n",(0,s.jsx)(n.p,{children:"We believe all software applications can be natively supercharged with AI primitives and embedded AI servers."}),"\n",(0,s.jsx)(n.p,{children:"Including:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Compatible AI ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/types",children:"types"})," and ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/extensions",children:"core extensions"})," to support common functionality like making an inference call."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:["Multiple inference engines through ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/extensions/inference-nitro-extension",children:"extensions, integrations & wrappers"})," ",(0,s.jsxs)(n.em,{children:["On this, we'd like to appreciate the folks at ",(0,s.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp",children:"llamacpp"})," and ",(0,s.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"})," for. To which we'll continue to make commits & fixes back upstream."]})]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/core/src/api",children:"Code Entrypoint"})}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"fun-project-ideas",children:"Fun Project Ideas"}),"\n",(0,s.jsx)(n.p,{children:"Beyond the current Jan client and UX, the Core SDK can be used to build many other AI-powered and privacy preserving applications."}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Game engine"}),": For AI enabled character games, procedural generation games"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"Health app"}),": For a personal healthcare app that improves habits"]}),"\n",(0,s.jsx)(n.li,{children:"Got ideas? Make a PR into this docs page!"}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["If you are interested to tackle these issues, or have suggestions for integrations and other OSS tools we can use, please hit us up in ",(0,s.jsx)(n.a,{href:"https://discord.gg/5rQ2zTv3be",children:"Discord"}),"."]}),"\n",(0,s.jsx)(n.admonition,{type:"caution",children:(0,s.jsx)(n.p,{children:"Our open source license is copy left, which means we encourage forks to stay open source, and allow core contributors to merge things upstream."})})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},86171:(e,n,r)=>{r.d(n,{A:()=>s});const s=r.p+"assets/images/CleanArchitecture-26ac5f08c770e19c35a8ef38b905373f.jpg"},39110:(e,n,r)=>{r.d(n,{A:()=>s});const s=r.p+"assets/images/ExtensionCallouts-f5153831c0519e3eab145eed8be4f67d.png"},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>a});var s=r(96540);const t={},i=s.createContext(t);function o(e){const n=s.useContext(i);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),s.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/71718d6b.2b379a3f.js b/assets/js/71718d6b.2b379a3f.js new file mode 100644 index 00000000..0dc951c1 --- /dev/null +++ b/assets/js/71718d6b.2b379a3f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4103],{12017:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>i,metadata:()=>s,toc:()=>c});var a=n(74848),o=n(28453);const i={title:"Raycast",slug:"/integrations/raycast",sidebar_position:17,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","raycast integration","Raycast"],description:"A step-by-step guide on how to integrate Jan with Raycast."},r=void 0,s={id:"guides/integrations/raycast",title:"Raycast",description:"A step-by-step guide on how to integrate Jan with Raycast.",source:"@site/docs/guides/integrations/raycast.mdx",sourceDirName:"guides/integrations",slug:"/integrations/raycast",permalink:"/integrations/raycast",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/raycast.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:17,frontMatter:{title:"Raycast",slug:"/integrations/raycast",sidebar_position:17,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","raycast integration","Raycast"],description:"A step-by-step guide on how to integrate Jan with Raycast."},sidebar:"guidesSidebar",previous:{title:"Open Interpreter",permalink:"/integrations/interpreter"},next:{title:"OpenRouter",permalink:"/integrations/openrouter"}},l={},c=[{value:"Integrate Raycast with Jan",id:"integrate-raycast-with-jan",level:2},{value:"Step 1: Download the TinyLlama Model",id:"step-1-download-the-tinyllama-model",level:3},{value:"Step 2: Clone and Run the Program",id:"step-2-clone-and-run-the-program",level:3},{value:"Step 3: Search for Nitro and Run the Model",id:"step-3-search-for-nitro-and-run-the-model",level:3}];function d(e){const t={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",...(0,o.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(t.h2,{id:"integrate-raycast-with-jan",children:"Integrate Raycast with Jan"}),"\n",(0,a.jsxs)(t.p,{children:[(0,a.jsx)(t.a,{href:"https://www.raycast.com/",children:"Raycast"})," is a productivity tool designed for macOS that enhances workflow efficiency by providing quick access to various tasks and functionalities through a keyboard-driven interface. To integrate Raycast with Jan, follow the steps below:"]}),"\n",(0,a.jsx)(t.h3,{id:"step-1-download-the-tinyllama-model",children:"Step 1: Download the TinyLlama Model"}),"\n",(0,a.jsxs)(t.ol,{children:["\n",(0,a.jsxs)(t.li,{children:["Go to the ",(0,a.jsx)(t.strong,{children:"Hub"})," and download the TinyLlama model."]}),"\n",(0,a.jsxs)(t.li,{children:["The model will be available at ",(0,a.jsx)(t.code,{children:"~jan/models/tinyllama-1.1b"}),"."]}),"\n"]}),"\n",(0,a.jsx)(t.h3,{id:"step-2-clone-and-run-the-program",children:"Step 2: Clone and Run the Program"}),"\n",(0,a.jsxs)(t.ol,{children:["\n",(0,a.jsxs)(t.li,{children:["Clone this ",(0,a.jsx)(t.a,{href:"https://github.com/InNoobWeTrust/nitro-raycast",children:"GitHub repository"}),"."]}),"\n",(0,a.jsx)(t.li,{children:"Execute the project using the following command:"}),"\n"]}),"\n",(0,a.jsx)(t.pre,{children:(0,a.jsx)(t.code,{className:"language-sh",metastring:'title="Node.js"',children:"npm i && npm run dev\n"})}),"\n",(0,a.jsx)(t.h3,{id:"step-3-search-for-nitro-and-run-the-model",children:"Step 3: Search for Nitro and Run the Model"}),"\n",(0,a.jsxs)(t.p,{children:["Search for ",(0,a.jsx)(t.code,{children:"Nitro"})," using the program and you can use the models from Jan in RayCast."]})]})}function h(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,a.jsx)(t,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>s});var a=n(96540);const o={},i=a.createContext(o);function r(e){const t=a.useContext(i);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function s(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),a.createElement(i.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/71718d6b.ddf7c895.js b/assets/js/71718d6b.ddf7c895.js deleted file mode 100644 index e45f0c1a..00000000 --- a/assets/js/71718d6b.ddf7c895.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4103],{12017:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>i,metadata:()=>s,toc:()=>c});var a=n(74848),o=n(28453);const i={title:"Raycast",slug:"/integrations/raycast",sidebar_position:17,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","raycast integration","Raycast"],description:"A step-by-step guide on how to integrate Jan with Raycast."},r=void 0,s={id:"guides/integrations/raycast",title:"Raycast",description:"A step-by-step guide on how to integrate Jan with Raycast.",source:"@site/docs/guides/integrations/raycast.mdx",sourceDirName:"guides/integrations",slug:"/integrations/raycast",permalink:"/integrations/raycast",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/raycast.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:17,frontMatter:{title:"Raycast",slug:"/integrations/raycast",sidebar_position:17,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","raycast integration","Raycast"],description:"A step-by-step guide on how to integrate Jan with Raycast."},sidebar:"guidesSidebar",previous:{title:"Open Interpreter",permalink:"/integrations/interpreter"},next:{title:"OpenRouter",permalink:"/integrations/openrouter"}},l={},c=[{value:"Integrate Raycast with Jan",id:"integrate-raycast-with-jan",level:2},{value:"Step 1: Download the TinyLlama Model",id:"step-1-download-the-tinyllama-model",level:3},{value:"Step 2: Clone and Run the Program",id:"step-2-clone-and-run-the-program",level:3},{value:"Step 3: Search for Nitro and Run the Model",id:"step-3-search-for-nitro-and-run-the-model",level:3}];function d(e){const t={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",...(0,o.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(t.h2,{id:"integrate-raycast-with-jan",children:"Integrate Raycast with Jan"}),"\n",(0,a.jsxs)(t.p,{children:[(0,a.jsx)(t.a,{href:"https://www.raycast.com/",children:"Raycast"})," is a productivity tool designed for macOS that enhances workflow efficiency by providing quick access to various tasks and functionalities through a keyboard-driven interface. To integrate Raycast with Jan, follow the steps below:"]}),"\n",(0,a.jsx)(t.h3,{id:"step-1-download-the-tinyllama-model",children:"Step 1: Download the TinyLlama Model"}),"\n",(0,a.jsxs)(t.ol,{children:["\n",(0,a.jsxs)(t.li,{children:["Go to the ",(0,a.jsx)(t.strong,{children:"Hub"})," and download the TinyLlama model."]}),"\n",(0,a.jsxs)(t.li,{children:["The model will be available at ",(0,a.jsx)(t.code,{children:"~jan/models/tinyllama-1.1b"}),"."]}),"\n"]}),"\n",(0,a.jsx)(t.h3,{id:"step-2-clone-and-run-the-program",children:"Step 2: Clone and Run the Program"}),"\n",(0,a.jsxs)(t.ol,{children:["\n",(0,a.jsxs)(t.li,{children:["Clone this ",(0,a.jsx)(t.a,{href:"https://github.com/InNoobWeTrust/nitro-raycast",children:"GitHub repository"}),"."]}),"\n",(0,a.jsx)(t.li,{children:"Execute the project using the following command:"}),"\n"]}),"\n",(0,a.jsx)(t.pre,{children:(0,a.jsx)(t.code,{className:"language-sh",metastring:'title="Node.js"',children:"npm i && npm run dev\n"})}),"\n",(0,a.jsx)(t.h3,{id:"step-3-search-for-nitro-and-run-the-model",children:"Step 3: Search for Nitro and Run the Model"}),"\n",(0,a.jsxs)(t.p,{children:["Search for ",(0,a.jsx)(t.code,{children:"Nitro"})," using the program and you can use the models from Jan in RayCast."]})]})}function h(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,a.jsx)(t,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>s});var a=n(96540);const o={},i=a.createContext(o);function r(e){const t=a.useContext(i);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function s(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),a.createElement(i.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/723a3dd1.0dd08755.js b/assets/js/723a3dd1.0dd08755.js new file mode 100644 index 00000000..488545df --- /dev/null +++ b/assets/js/723a3dd1.0dd08755.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6292],{18157:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>a,metadata:()=>t,toc:()=>d});var s=r(74848),i=r(28453);const a={title:"Recommended AI Hardware by Use Case"},o=void 0,t={id:"hardware/recommendations/by-usecase",title:"Recommended AI Hardware by Use Case",description:"Which AI Hardware to Choose Based on Your Use Case",source:"@site/docs/hardware/recommendations/by-usecase.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-usecase",permalink:"/hardware/recommendations/by-usecase",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-usecase.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Recommended AI Hardware by Use Case"}},l={},d=[{value:"Which AI Hardware to Choose Based on Your Use Case",id:"which-ai-hardware-to-choose-based-on-your-use-case",level:2},{value:"Entry-level Experimentation:",id:"entry-level-experimentation",level:3},{value:"Business Use",id:"business-use",level:2},{value:"For a 10-person Small Business",id:"for-a-10-person-small-business",level:3},{value:"For a 50-person Law Firm",id:"for-a-50-person-law-firm",level:3},{value:"For a 1,000-student School",id:"for-a-1000-student-school",level:3},{value:"Software Engineering",id:"software-engineering",level:2},{value:"Personal Code Assistant",id:"personal-code-assistant",level:3},{value:"For a 10 person Software Team",id:"for-a-10-person-software-team",level:3},{value:"Enterprise",id:"enterprise",level:2},{value:"For a 1000-person Enterprise",id:"for-a-1000-person-enterprise",level:3},{value:"For a 10,000-person Enterprise",id:"for-a-10000-person-enterprise",level:3}];function c(e){const n={h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h2,{id:"which-ai-hardware-to-choose-based-on-your-use-case",children:"Which AI Hardware to Choose Based on Your Use Case"}),"\n",(0,s.jsx)(n.p,{children:"Artificial intelligence (AI) is rapidly changing the world, and AI hardware is becoming increasingly important for businesses and individuals alike. Choosing the right hardware for your AI needs is crucial to get the best performance and results. Here are some tips for selecting AI hardware based on your specific use case and requirements."}),"\n",(0,s.jsx)(n.h3,{id:"entry-level-experimentation",children:"Entry-level Experimentation:"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Personal Use:"}),"\nWhen venturing into the world of AI as an individual, your choice of hardware can significantly impact your experience. Here's a more detailed breakdown:"]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Macbook (16GB):"})," A Macbook equipped with 16GB of RAM and either the M1 or the newer M2 Pro/Max processor is an excellent starting point for AI enthusiasts. These cutting-edge chips leverage Apple's innovative Unified Memory Architecture (UMA), which revolutionizes the way the CPU and GPU interact with memory resources. This advancement plays a pivotal role in enhancing the performance and capabilities of LLMs."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Nvidia GeForce RTX 3090:"})," This powerful graphics card is a solid alternative for AI beginners, offering exceptional performance for basic experiments."]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"2",children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Serious AI Work:"})}),"\n"]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"2 x 3090 RTX Card (48GB RAM):"})," For those committed to more advanced AI projects, this configuration provides the necessary muscle. Its dual Nvidia GeForce RTX 3090 GPUs and ample RAM make it suitable for complex AI tasks and model training."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"business-use",children:"Business Use"}),"\n",(0,s.jsx)(n.h3,{id:"for-a-10-person-small-business",children:"For a 10-person Small Business"}),"\n",(0,s.jsx)(n.p,{children:"Run a LLM trained on enterprise data (i.e. RAG)"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Mac Studio M2 Ultra with 192GB unified memory","\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Cannot train"}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["RTX 6000","\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Should we recommend 2 x 4090 instead?"}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-a-50-person-law-firm",children:"For a 50-person Law Firm"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"LLM, PDF Parsing, OCR"}),"\n",(0,s.jsx)(n.li,{children:"Audit logging and compliance"}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-a-1000-student-school",children:"For a 1,000-student School"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Llama2 with safeguards"}),"\n",(0,s.jsx)(n.li,{children:"RAG with textbook data"}),"\n",(0,s.jsx)(n.li,{children:"Policy engine"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"software-engineering",children:"Software Engineering"}),"\n",(0,s.jsx)(n.h3,{id:"personal-code-assistant",children:"Personal Code Assistant"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Llama34b, needs adequate RAM"}),"\n",(0,s.jsx)(n.li,{children:"Not recommended to run on local device due to RAM"}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-a-10-person-software-team",children:"For a 10 person Software Team"}),"\n",(0,s.jsx)(n.p,{children:"Run Codellama with RAG on existing codebase"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Codellama34b"}),"\n",(0,s.jsx)(n.li,{children:"RTX 6000s (48gb)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"enterprise",children:"Enterprise"}),"\n",(0,s.jsx)(n.h3,{id:"for-a-1000-person-enterprise",children:"For a 1000-person Enterprise"}),"\n",(0,s.jsx)(n.h3,{id:"for-a-10000-person-enterprise",children:"For a 10,000-person Enterprise"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"8 x H100s"}),"\n",(0,s.jsx)(n.li,{children:"NVAIE with vGPUs"}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>t});var s=r(96540);const i={},a=s.createContext(i);function o(e){const n=s.useContext(a);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),s.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/723a3dd1.4a83b80e.js b/assets/js/723a3dd1.4a83b80e.js deleted file mode 100644 index 301db743..00000000 --- a/assets/js/723a3dd1.4a83b80e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6292],{18157:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>a,metadata:()=>t,toc:()=>d});var s=r(74848),i=r(28453);const a={title:"Recommended AI Hardware by Use Case"},o=void 0,t={id:"hardware/recommendations/by-usecase",title:"Recommended AI Hardware by Use Case",description:"Which AI Hardware to Choose Based on Your Use Case",source:"@site/docs/hardware/recommendations/by-usecase.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-usecase",permalink:"/hardware/recommendations/by-usecase",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-usecase.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Recommended AI Hardware by Use Case"}},l={},d=[{value:"Which AI Hardware to Choose Based on Your Use Case",id:"which-ai-hardware-to-choose-based-on-your-use-case",level:2},{value:"Entry-level Experimentation:",id:"entry-level-experimentation",level:3},{value:"Business Use",id:"business-use",level:2},{value:"For a 10-person Small Business",id:"for-a-10-person-small-business",level:3},{value:"For a 50-person Law Firm",id:"for-a-50-person-law-firm",level:3},{value:"For a 1,000-student School",id:"for-a-1000-student-school",level:3},{value:"Software Engineering",id:"software-engineering",level:2},{value:"Personal Code Assistant",id:"personal-code-assistant",level:3},{value:"For a 10 person Software Team",id:"for-a-10-person-software-team",level:3},{value:"Enterprise",id:"enterprise",level:2},{value:"For a 1000-person Enterprise",id:"for-a-1000-person-enterprise",level:3},{value:"For a 10,000-person Enterprise",id:"for-a-10000-person-enterprise",level:3}];function c(e){const n={h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h2,{id:"which-ai-hardware-to-choose-based-on-your-use-case",children:"Which AI Hardware to Choose Based on Your Use Case"}),"\n",(0,s.jsx)(n.p,{children:"Artificial intelligence (AI) is rapidly changing the world, and AI hardware is becoming increasingly important for businesses and individuals alike. Choosing the right hardware for your AI needs is crucial to get the best performance and results. Here are some tips for selecting AI hardware based on your specific use case and requirements."}),"\n",(0,s.jsx)(n.h3,{id:"entry-level-experimentation",children:"Entry-level Experimentation:"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Personal Use:"}),"\nWhen venturing into the world of AI as an individual, your choice of hardware can significantly impact your experience. Here's a more detailed breakdown:"]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Macbook (16GB):"})," A Macbook equipped with 16GB of RAM and either the M1 or the newer M2 Pro/Max processor is an excellent starting point for AI enthusiasts. These cutting-edge chips leverage Apple's innovative Unified Memory Architecture (UMA), which revolutionizes the way the CPU and GPU interact with memory resources. This advancement plays a pivotal role in enhancing the performance and capabilities of LLMs."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Nvidia GeForce RTX 3090:"})," This powerful graphics card is a solid alternative for AI beginners, offering exceptional performance for basic experiments."]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"2",children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Serious AI Work:"})}),"\n"]}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"2 x 3090 RTX Card (48GB RAM):"})," For those committed to more advanced AI projects, this configuration provides the necessary muscle. Its dual Nvidia GeForce RTX 3090 GPUs and ample RAM make it suitable for complex AI tasks and model training."]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"business-use",children:"Business Use"}),"\n",(0,s.jsx)(n.h3,{id:"for-a-10-person-small-business",children:"For a 10-person Small Business"}),"\n",(0,s.jsx)(n.p,{children:"Run a LLM trained on enterprise data (i.e. RAG)"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Mac Studio M2 Ultra with 192GB unified memory","\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Cannot train"}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["RTX 6000","\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Should we recommend 2 x 4090 instead?"}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-a-50-person-law-firm",children:"For a 50-person Law Firm"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"LLM, PDF Parsing, OCR"}),"\n",(0,s.jsx)(n.li,{children:"Audit logging and compliance"}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-a-1000-student-school",children:"For a 1,000-student School"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Llama2 with safeguards"}),"\n",(0,s.jsx)(n.li,{children:"RAG with textbook data"}),"\n",(0,s.jsx)(n.li,{children:"Policy engine"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"software-engineering",children:"Software Engineering"}),"\n",(0,s.jsx)(n.h3,{id:"personal-code-assistant",children:"Personal Code Assistant"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Llama34b, needs adequate RAM"}),"\n",(0,s.jsx)(n.li,{children:"Not recommended to run on local device due to RAM"}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-a-10-person-software-team",children:"For a 10 person Software Team"}),"\n",(0,s.jsx)(n.p,{children:"Run Codellama with RAG on existing codebase"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Codellama34b"}),"\n",(0,s.jsx)(n.li,{children:"RTX 6000s (48gb)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"enterprise",children:"Enterprise"}),"\n",(0,s.jsx)(n.h3,{id:"for-a-1000-person-enterprise",children:"For a 1000-person Enterprise"}),"\n",(0,s.jsx)(n.h3,{id:"for-a-10000-person-enterprise",children:"For a 10,000-person Enterprise"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"8 x H100s"}),"\n",(0,s.jsx)(n.li,{children:"NVAIE with vGPUs"}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>t});var s=r(96540);const i={},a=s.createContext(i);function o(e){const n=s.useContext(a);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),s.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/72d4c782.3c516869.js b/assets/js/72d4c782.3c516869.js new file mode 100644 index 00000000..7a9ef6aa --- /dev/null +++ b/assets/js/72d4c782.3c516869.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4536],{36520:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>c});var s=n(74848),o=n(28453);const a={title:"Self-hosted alternative to OpenAI's Platform",tags:["use-cases"]},r=void 0,i={id:"solutions/chatgpt-alternative",title:"Self-hosted alternative to OpenAI's Platform",description:"",source:"@site/docs/solutions/chatgpt-alternative.md",sourceDirName:"solutions",slug:"/solutions/chatgpt-alternative",permalink:"/solutions/chatgpt-alternative",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/chatgpt-alternative.md",tags:[{label:"use-cases",permalink:"/tags/use-cases"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Self-hosted alternative to OpenAI's Platform",tags:["use-cases"]},sidebar:"solutionSidebar",previous:{title:"AI PC",permalink:"/solutions/ai-pc"},next:{title:"Finance",permalink:"/solutions/finance"}},l={},c=[];function u(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>r,x:()=>i});var s=n(96540);const o={},a=s.createContext(o);function r(t){const e=s.useContext(a);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),s.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/72d4c782.a15b2a43.js b/assets/js/72d4c782.a15b2a43.js deleted file mode 100644 index d4bafae1..00000000 --- a/assets/js/72d4c782.a15b2a43.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4536],{36520:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>c});var s=n(74848),o=n(28453);const a={title:"Self-hosted alternative to OpenAI's Platform",tags:["use-cases"]},r=void 0,i={id:"solutions/chatgpt-alternative",title:"Self-hosted alternative to OpenAI's Platform",description:"",source:"@site/docs/solutions/chatgpt-alternative.md",sourceDirName:"solutions",slug:"/solutions/chatgpt-alternative",permalink:"/solutions/chatgpt-alternative",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/chatgpt-alternative.md",tags:[{label:"use-cases",permalink:"/tags/use-cases"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Self-hosted alternative to OpenAI's Platform",tags:["use-cases"]},sidebar:"solutionSidebar",previous:{title:"AI PC",permalink:"/solutions/ai-pc"},next:{title:"Finance",permalink:"/solutions/finance"}},l={},c=[];function u(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>r,x:()=>i});var s=n(96540);const o={},a=s.createContext(o);function r(t){const e=s.useContext(a);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),s.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/75e6dc85.3239abf7.js b/assets/js/75e6dc85.3239abf7.js new file mode 100644 index 00000000..60ae7215 --- /dev/null +++ b/assets/js/75e6dc85.3239abf7.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[352],{9289:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>s,toc:()=>c});var a=r(74848),n=r(28453);const o={title:"Wall of Love \u2764\ufe0f",slug:"/wall-of-love",description:"Check out what our amazing users are saying about Jan!",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","wall of love"]},i=void 0,s={id:"wall-of-love",title:"Wall of Love \u2764\ufe0f",description:"Check out what our amazing users are saying about Jan!",source:"@site/docs/wall-of-love.md",sourceDirName:".",slug:"/wall-of-love",permalink:"/wall-of-love",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/wall-of-love.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Wall of Love \u2764\ufe0f",slug:"/wall-of-love",description:"Check out what our amazing users are saying about Jan!",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","wall of love"]},sidebar:"aboutSidebar",previous:{title:"Contributor Program",permalink:"/team/contributor-program"},next:{title:"How We Work",permalink:"/how-we-work"}},l={},c=[{value:"Twitter",id:"twitter",level:2},{value:"YouTube",id:"youtube",level:2},{value:"Run Any Chatbot FREE Locally on Your Computer",id:"run-any-chatbot-free-locally-on-your-computer",level:3},{value:"Jan AI: Run Open Source LLM 100% Local with OpenAI endpoints",id:"jan-ai-run-open-source-llm-100-local-with-openai-endpoints",level:3},{value:"Setup Tutorial on Jan.ai. JAN AI: Run open source LLM on local Windows PC. 100% offline LLM and AI.",id:"setup-tutorial-on-janai-jan-ai-run-open-source-llm-on-local-windows-pc-100-offline-llm-and-ai",level:3},{value:"Jan.ai: Like Offline ChatGPT on Your Computer \ud83d\udca1",id:"janai-like-offline-chatgpt-on-your-computer-",level:3},{value:"Jan: Bring AI to your Desktop With 100% Offline AI",id:"jan-bring-ai-to-your-desktop-with-100-offline-ai",level:3},{value:"AI on Your Local PC: Install JanAI (ChatGPT alternative) for Enhanced Privacy",id:"ai-on-your-local-pc-install-janai-chatgpt-alternative-for-enhanced-privacy",level:3},{value:"Install Jan to Run LLM Offline and Local First",id:"install-jan-to-run-llm-offline-and-local-first",level:3}];function d(e){const t={a:"a",h2:"h2",h3:"h3",p:"p",...(0,n.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(t.h2,{id:"twitter",children:"Twitter"}),"\n",(0,a.jsx)(t.p,{children:"Check out our amazing users and what they are saying about Jan!"}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["I can confirm ",(0,a.jsx)("a",{href:"https://t.co/Hvrfp0iaf9",children:(0,a.jsx)(t.a,{href:"https://t.co/Hvrfp0iaf9",children:"https://t.co/Hvrfp0iaf9"})})," is awesome \ud83d\udc4c"]}),"\u2014 Cristian (@cristianmoreno) ",(0,a.jsx)("a",{href:"https://twitter.com/cristianmoreno/status/1757504717519749292?ref_src=twsrc%5Etfw",children:"February 13, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsx)("p",{lang:"en",dir:"ltr",children:"downloaded this a few weeks ago. amazed by the speed and quality"}),"\u2014 siddharth (@siddharthd01) ",(0,a.jsx)("a",{href:"https://twitter.com/siddharthd01/status/1757500111629025788?ref_src=twsrc%5Etfw",children:"February 13, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["Anyone else out there running LLMs on steam deck? ",(0,a.jsx)("a",{href:"https://twitter.com/janframework?ref_src=twsrc%5Etfw",children:"@janframework"})," bringing nerd dreams to life! ",(0,a.jsx)("a",{href:"https://t.co/7XpnBmc8MN",children:"pic.twitter.com/7XpnBmc8MN"})]}),"\u2014 crossdefault (@crossdefault) ",(0,a.jsx)("a",{href:"https://twitter.com/crossdefault/status/1750801065132384302?ref_src=twsrc%5Etfw",children:"January 26, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["If you are like me, always wanting your own ChatGPT and have sufficient coding knowledge, you would watch open sourced ",(0,a.jsx)("a",{href:"https://twitter.com/janframework?ref_src=twsrc%5Etfw",children:"@janframework"})," by ",(0,a.jsx)("a",{href:"https://twitter.com/0xSage?ref_src=twsrc%5Etfw",children:"@0xSage"}),' like a "my-own-ai" hawk',(0,a.jsx)("br",{}),"Still under development, the architecture is really futuristic. The desktop app for Windows, Mac, Linux are\u2026 ",(0,a.jsx)("a",{href:"https://t.co/0HrNquhBsL",children:"pic.twitter.com/0HrNquhBsL"})]}),"\u2014 Umesh = EG = Educated Guess - NGI doing AI (@trading_indian) ",(0,a.jsx)("a",{href:"https://twitter.com/trading_indian/status/1745560583548670250?ref_src=twsrc%5Etfw",children:"January 11, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["came across ",(0,a.jsx)("a",{href:"https://twitter.com/janframework?ref_src=twsrc%5Etfw",children:"@janframework"})," yesterday and it's my fav native Apple Silicon LLM app yet. Love that I can switch to GPT 4 API and offline LLM models seamlessly. Looks promising! ",(0,a.jsx)("a",{href:"https://t.co/gyOX9gHbKQ",children:(0,a.jsx)(t.a,{href:"https://t.co/gyOX9gHbKQ",children:"https://t.co/gyOX9gHbKQ"})})]}),"\u2014 Keith Hawkins (@kph_practice) ",(0,a.jsx)("a",{href:"https://twitter.com/kph_practice/status/1744729548074459310?ref_src=twsrc%5Etfw",children:"January 9, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsx)("p",{lang:"en",dir:"ltr",children:"i just ran some ai models locally on my laptop using @janhq_ and can't believe how easy and cool it is. so, now i can have the same experience as with ChatGPT, but offline and without any data concerns"}),"\u2014 Sergey Kaplich (@sergey_kaplich) ",(0,a.jsx)("a",{href:"https://twitter.com/sergey_kaplich/status/1742993414986068423?ref_src=twsrc%5Etfw",children:"January 4, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:[(0,a.jsx)("a",{href:"https://t.co/scBqJ3kIzj",children:(0,a.jsx)(t.a,{href:"https://t.co/scBqJ3kIzj",children:"https://t.co/scBqJ3kIzj"})})," Great way to try open source all models, like Mixtral8x7b offline. Love to see"]}),"\u2014 Chubby\u2668\ufe0f (@kimmonismus) ",(0,a.jsx)("a",{href:"https://twitter.com/kimmonismus/status/1742843063938994469?ref_src=twsrc%5Etfw",children:"January 4, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)(t.p,{children:["Please share your love for Jan on Twitter and tag us ",(0,a.jsx)(t.a,{href:"https://twitter.com/janframework",children:"@janframework"}),"! We would love to hear from you!"]}),"\n",(0,a.jsx)(t.h2,{id:"youtube",children:"YouTube"}),"\n",(0,a.jsx)(t.p,{children:"Watch these amazing videos to see how Jan is being used and loved by the community!"}),"\n",(0,a.jsx)(t.h3,{id:"run-any-chatbot-free-locally-on-your-computer",children:"Run Any Chatbot FREE Locally on Your Computer"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/zkafOIyQM8s",title:"Run Any Chatbot FREE Locally on Your Computer",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"jan-ai-run-open-source-llm-100-local-with-openai-endpoints",children:"Jan AI: Run Open Source LLM 100% Local with OpenAI endpoints"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"705",src:"https://www.youtube.com/embed/9ta2S425Zu8",title:"Jan AI: Run Open Source LLM 100% Local with OpenAI endpoints",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"setup-tutorial-on-janai-jan-ai-run-open-source-llm-on-local-windows-pc-100-offline-llm-and-ai",children:"Setup Tutorial on Jan.ai. JAN AI: Run open source LLM on local Windows PC. 100% offline LLM and AI."}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"705",src:"https://www.youtube.com/embed/ZCiEQVOjH5U",title:"Setup Tutorial on Jan.ai. JAN AI: Run open source LLM on local Windows PC. 100% offline LLM and AI.",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"janai-like-offline-chatgpt-on-your-computer-",children:"Jan.ai: Like Offline ChatGPT on Your Computer \ud83d\udca1"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/ES021_sY6WQ",title:"Jan.ai: Like Offline ChatGPT on Your Computer \ud83d\udca1",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"jan-bring-ai-to-your-desktop-with-100-offline-ai",children:"Jan: Bring AI to your Desktop With 100% Offline AI"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/QpMQgJL4AZA",title:"Jan: Bring AI to your Desktop With 100% Offline AI",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"ai-on-your-local-pc-install-janai-chatgpt-alternative-for-enhanced-privacy",children:"AI on Your Local PC: Install JanAI (ChatGPT alternative) for Enhanced Privacy"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/CbJGxNmdWws",title:"AI on Your Local PC: Install JanAI (ChatGPT alternative) for Enhanced Privacy",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"install-jan-to-run-llm-offline-and-local-first",children:"Install Jan to Run LLM Offline and Local First"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/7JpzE-_cKo4",title:"Install Jan to Run LLM Offline and Local First",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})})]})}function h(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,a.jsx)(t,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,t,r)=>{r.d(t,{R:()=>i,x:()=>s});var a=r(96540);const n={},o=a.createContext(n);function i(e){const t=a.useContext(o);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function s(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:i(e.components),a.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/75e6dc85.54796428.js b/assets/js/75e6dc85.54796428.js deleted file mode 100644 index 6d435a17..00000000 --- a/assets/js/75e6dc85.54796428.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[352],{9289:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>s,toc:()=>c});var a=r(74848),n=r(28453);const o={title:"Wall of Love \u2764\ufe0f",slug:"/wall-of-love",description:"Check out what our amazing users are saying about Jan!",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","wall of love"]},i=void 0,s={id:"wall-of-love",title:"Wall of Love \u2764\ufe0f",description:"Check out what our amazing users are saying about Jan!",source:"@site/docs/wall-of-love.md",sourceDirName:".",slug:"/wall-of-love",permalink:"/wall-of-love",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/wall-of-love.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Wall of Love \u2764\ufe0f",slug:"/wall-of-love",description:"Check out what our amazing users are saying about Jan!",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","wall of love"]},sidebar:"aboutSidebar",previous:{title:"Contributor Program",permalink:"/team/contributor-program"},next:{title:"How We Work",permalink:"/how-we-work"}},l={},c=[{value:"Twitter",id:"twitter",level:2},{value:"YouTube",id:"youtube",level:2},{value:"Run Any Chatbot FREE Locally on Your Computer",id:"run-any-chatbot-free-locally-on-your-computer",level:3},{value:"Jan AI: Run Open Source LLM 100% Local with OpenAI endpoints",id:"jan-ai-run-open-source-llm-100-local-with-openai-endpoints",level:3},{value:"Setup Tutorial on Jan.ai. JAN AI: Run open source LLM on local Windows PC. 100% offline LLM and AI.",id:"setup-tutorial-on-janai-jan-ai-run-open-source-llm-on-local-windows-pc-100-offline-llm-and-ai",level:3},{value:"Jan.ai: Like Offline ChatGPT on Your Computer \ud83d\udca1",id:"janai-like-offline-chatgpt-on-your-computer-",level:3},{value:"Jan: Bring AI to your Desktop With 100% Offline AI",id:"jan-bring-ai-to-your-desktop-with-100-offline-ai",level:3},{value:"AI on Your Local PC: Install JanAI (ChatGPT alternative) for Enhanced Privacy",id:"ai-on-your-local-pc-install-janai-chatgpt-alternative-for-enhanced-privacy",level:3},{value:"Install Jan to Run LLM Offline and Local First",id:"install-jan-to-run-llm-offline-and-local-first",level:3}];function d(e){const t={a:"a",h2:"h2",h3:"h3",p:"p",...(0,n.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(t.h2,{id:"twitter",children:"Twitter"}),"\n",(0,a.jsx)(t.p,{children:"Check out our amazing users and what they are saying about Jan!"}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["I can confirm ",(0,a.jsx)("a",{href:"https://t.co/Hvrfp0iaf9",children:(0,a.jsx)(t.a,{href:"https://t.co/Hvrfp0iaf9",children:"https://t.co/Hvrfp0iaf9"})})," is awesome \ud83d\udc4c"]}),"\u2014 Cristian (@cristianmoreno) ",(0,a.jsx)("a",{href:"https://twitter.com/cristianmoreno/status/1757504717519749292?ref_src=twsrc%5Etfw",children:"February 13, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsx)("p",{lang:"en",dir:"ltr",children:"downloaded this a few weeks ago. amazed by the speed and quality"}),"\u2014 siddharth (@siddharthd01) ",(0,a.jsx)("a",{href:"https://twitter.com/siddharthd01/status/1757500111629025788?ref_src=twsrc%5Etfw",children:"February 13, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["Anyone else out there running LLMs on steam deck? ",(0,a.jsx)("a",{href:"https://twitter.com/janframework?ref_src=twsrc%5Etfw",children:"@janframework"})," bringing nerd dreams to life! ",(0,a.jsx)("a",{href:"https://t.co/7XpnBmc8MN",children:"pic.twitter.com/7XpnBmc8MN"})]}),"\u2014 crossdefault (@crossdefault) ",(0,a.jsx)("a",{href:"https://twitter.com/crossdefault/status/1750801065132384302?ref_src=twsrc%5Etfw",children:"January 26, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["If you are like me, always wanting your own ChatGPT and have sufficient coding knowledge, you would watch open sourced ",(0,a.jsx)("a",{href:"https://twitter.com/janframework?ref_src=twsrc%5Etfw",children:"@janframework"})," by ",(0,a.jsx)("a",{href:"https://twitter.com/0xSage?ref_src=twsrc%5Etfw",children:"@0xSage"}),' like a "my-own-ai" hawk',(0,a.jsx)("br",{}),"Still under development, the architecture is really futuristic. The desktop app for Windows, Mac, Linux are\u2026 ",(0,a.jsx)("a",{href:"https://t.co/0HrNquhBsL",children:"pic.twitter.com/0HrNquhBsL"})]}),"\u2014 Umesh = EG = Educated Guess - NGI doing AI (@trading_indian) ",(0,a.jsx)("a",{href:"https://twitter.com/trading_indian/status/1745560583548670250?ref_src=twsrc%5Etfw",children:"January 11, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:["came across ",(0,a.jsx)("a",{href:"https://twitter.com/janframework?ref_src=twsrc%5Etfw",children:"@janframework"})," yesterday and it's my fav native Apple Silicon LLM app yet. Love that I can switch to GPT 4 API and offline LLM models seamlessly. Looks promising! ",(0,a.jsx)("a",{href:"https://t.co/gyOX9gHbKQ",children:(0,a.jsx)(t.a,{href:"https://t.co/gyOX9gHbKQ",children:"https://t.co/gyOX9gHbKQ"})})]}),"\u2014 Keith Hawkins (@kph_practice) ",(0,a.jsx)("a",{href:"https://twitter.com/kph_practice/status/1744729548074459310?ref_src=twsrc%5Etfw",children:"January 9, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsx)("p",{lang:"en",dir:"ltr",children:"i just ran some ai models locally on my laptop using @janhq_ and can't believe how easy and cool it is. so, now i can have the same experience as with ChatGPT, but offline and without any data concerns"}),"\u2014 Sergey Kaplich (@sergey_kaplich) ",(0,a.jsx)("a",{href:"https://twitter.com/sergey_kaplich/status/1742993414986068423?ref_src=twsrc%5Etfw",children:"January 4, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)("div",{children:[(0,a.jsxs)("blockquote",{class:"twitter-tweet",children:[(0,a.jsxs)("p",{lang:"en",dir:"ltr",children:[(0,a.jsx)("a",{href:"https://t.co/scBqJ3kIzj",children:(0,a.jsx)(t.a,{href:"https://t.co/scBqJ3kIzj",children:"https://t.co/scBqJ3kIzj"})})," Great way to try open source all models, like Mixtral8x7b offline. Love to see"]}),"\u2014 Chubby\u2668\ufe0f (@kimmonismus) ",(0,a.jsx)("a",{href:"https://twitter.com/kimmonismus/status/1742843063938994469?ref_src=twsrc%5Etfw",children:"January 4, 2024"})]}),(0,a.jsx)("script",{async:!0,src:"https://platform.twitter.com/widgets.js",charset:"utf-8",loading:"lazy"})]}),"\n",(0,a.jsxs)(t.p,{children:["Please share your love for Jan on Twitter and tag us ",(0,a.jsx)(t.a,{href:"https://twitter.com/janframework",children:"@janframework"}),"! We would love to hear from you!"]}),"\n",(0,a.jsx)(t.h2,{id:"youtube",children:"YouTube"}),"\n",(0,a.jsx)(t.p,{children:"Watch these amazing videos to see how Jan is being used and loved by the community!"}),"\n",(0,a.jsx)(t.h3,{id:"run-any-chatbot-free-locally-on-your-computer",children:"Run Any Chatbot FREE Locally on Your Computer"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/zkafOIyQM8s",title:"Run Any Chatbot FREE Locally on Your Computer",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"jan-ai-run-open-source-llm-100-local-with-openai-endpoints",children:"Jan AI: Run Open Source LLM 100% Local with OpenAI endpoints"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"705",src:"https://www.youtube.com/embed/9ta2S425Zu8",title:"Jan AI: Run Open Source LLM 100% Local with OpenAI endpoints",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"setup-tutorial-on-janai-jan-ai-run-open-source-llm-on-local-windows-pc-100-offline-llm-and-ai",children:"Setup Tutorial on Jan.ai. JAN AI: Run open source LLM on local Windows PC. 100% offline LLM and AI."}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"705",src:"https://www.youtube.com/embed/ZCiEQVOjH5U",title:"Setup Tutorial on Jan.ai. JAN AI: Run open source LLM on local Windows PC. 100% offline LLM and AI.",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"janai-like-offline-chatgpt-on-your-computer-",children:"Jan.ai: Like Offline ChatGPT on Your Computer \ud83d\udca1"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/ES021_sY6WQ",title:"Jan.ai: Like Offline ChatGPT on Your Computer \ud83d\udca1",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"jan-bring-ai-to-your-desktop-with-100-offline-ai",children:"Jan: Bring AI to your Desktop With 100% Offline AI"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/QpMQgJL4AZA",title:"Jan: Bring AI to your Desktop With 100% Offline AI",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"ai-on-your-local-pc-install-janai-chatgpt-alternative-for-enhanced-privacy",children:"AI on Your Local PC: Install JanAI (ChatGPT alternative) for Enhanced Privacy"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/CbJGxNmdWws",title:"AI on Your Local PC: Install JanAI (ChatGPT alternative) for Enhanced Privacy",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(t.h3,{id:"install-jan-to-run-llm-offline-and-local-first",children:"Install Jan to Run LLM Offline and Local First"}),"\n",(0,a.jsx)("div",{children:(0,a.jsx)("iframe",{width:"100%",height:"600",src:"https://www.youtube.com/embed/7JpzE-_cKo4",title:"Install Jan to Run LLM Offline and Local First",frameborder:"0",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share",allowfullscreen:!0})})]})}function h(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,a.jsx)(t,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,t,r)=>{r.d(t,{R:()=>i,x:()=>s});var a=r(96540);const n={},o=a.createContext(n);function i(e){const t=a.useContext(o);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function s(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:i(e.components),a.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/7706d644.8ff01b68.js b/assets/js/7706d644.8ff01b68.js deleted file mode 100644 index 326937ef..00000000 --- a/assets/js/7706d644.8ff01b68.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1893],{22555:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>d,contentTitle:()=>n,default:()=>h,frontMatter:()=>t,metadata:()=>l,toc:()=>g});var i=e(74848),s=e(28453);e(64023);const t={title:"Installation",sidebar_position:4,slug:"/guides/install/",hide_table_of_contents:!0,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},n=void 0,l={id:"guides/installation/README",title:"Installation",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/installation/README.mdx",sourceDirName:"guides/installation",slug:"/guides/install/",permalink:"/guides/install/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:4,frontMatter:{title:"Installation",sidebar_position:4,slug:"/guides/install/",hide_table_of_contents:!0,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},d={},g=[{value:"Jan Device Compatible",id:"jan-device-compatible",level:2},{value:"Install Server-Side",id:"install-server-side",level:2},{value:"Pre-requisites",id:"pre-requisites",level:3},{value:"Install Jan Development Build",id:"install-jan-development-build",level:3},{value:"Install Jan Production Build",id:"install-jan-production-build",level:3}];function r(A){const a={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...A.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(a.h2,{id:"jan-device-compatible",children:"Jan Device Compatible"}),"\n",(0,i.jsx)(a.p,{children:"Jan is compatible with macOS, Windows, and Linux, making it accessible for a wide range of users. This compatibility allows users to leverage Jan's AI tools effectively, regardless of their device or operating system."}),"\n",(0,i.jsx)(a.admonition,{type:"note",children:(0,i.jsxs)(a.p,{children:["For detailed system requirements and setup instructions, refer to our ",(0,i.jsx)(a.a,{href:"/guides/hardware/",children:"Hardware Setup"})," guide."]})}),"\n","\n","\n",(0,i.jsx)(a.h2,{id:"install-server-side",children:"Install Server-Side"}),"\n",(0,i.jsx)(a.p,{children:"To install Jan from source, follow the steps below:"}),"\n",(0,i.jsx)(a.h3,{id:"pre-requisites",children:"Pre-requisites"}),"\n",(0,i.jsx)(a.p,{children:"Before proceeding with the installation of Jan from source, ensure that the following software versions are installed on your system:"}),"\n",(0,i.jsxs)(a.ul,{children:["\n",(0,i.jsx)(a.li,{children:"Node.js version 20.0.0 or higher"}),"\n",(0,i.jsx)(a.li,{children:"Yarn version 1.22.0 or higher"}),"\n"]}),"\n",(0,i.jsx)(a.h3,{id:"install-jan-development-build",children:"Install Jan Development Build"}),"\n",(0,i.jsxs)(a.ol,{children:["\n",(0,i.jsx)(a.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ngit checkout DESIRED_BRANCH\ncd jan\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"2",children:["\n",(0,i.jsx)(a.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"3",children:["\n",(0,i.jsx)(a.li,{children:"Run the development server."}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn dev\n"})}),"\n",(0,i.jsxs)(a.p,{children:["This will start the development server and open the desktop app. During this step, you may encounter notifications about installing base plugins. Simply click ",(0,i.jsx)(a.strong,{children:"OK"})," and ",(0,i.jsx)(a.strong,{children:"Next"})," to continue."]}),"\n",(0,i.jsx)(a.h3,{id:"install-jan-production-build",children:"Install Jan Production Build"}),"\n",(0,i.jsxs)(a.ol,{children:["\n",(0,i.jsx)(a.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ncd jan\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"2",children:["\n",(0,i.jsx)(a.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"3",children:["\n",(0,i.jsx)(a.li,{children:"Run the production server."}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn\n"})}),"\n",(0,i.jsx)(a.p,{children:"This completes the installation process for Jan from source. The production-ready app for macOS can be found in the dist folder."})]})}function h(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,i.jsx)(a,{...A,children:(0,i.jsx)(r,{...A})}):r(A)}},64023:(A,a,e)=>{e.d(a,{A:()=>T});e(96540);var i=e(18215),s=e(84142),t=e(20053),n=e(28774),l=e(21312),d=e(51107);const g={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},r="",h="",o="",C="",c="",u="",F="",p="",B="",E="",Y="",w="",v="",I="",V="",R="",b="",U="",W="",K="",m="",N="",Q="",x="",O="",M="",G="",j="",Z="";var X=e(74848);function S(A){let{href:a,children:e}=A;return(0,X.jsx)(n.A,{href:a,className:(0,t.A)("card padding--lg",g.cardContainer),children:e})}function L(A){let{href:a,icon:e,title:i,description:s}=A;return(0,X.jsxs)(S,{href:a,children:[(0,X.jsxs)(d.A,{as:"h2",className:(0,t.A)("text--truncate",g.cardTitle),title:i,children:[e," ",i]}),s&&(0,X.jsx)("p",{className:(0,t.A)(g.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,X.jsx)(L,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,l.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,X.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,X.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,X.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,X.jsx)("img",{src:C,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,X.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,X.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,X.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,X.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,X.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,X.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,X.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,X.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,X.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,X.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,X.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,X.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,X.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,X.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,X.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,X.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,X.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,X.jsx)("img",{src:C,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,X.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,X.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,X.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,X.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,X.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,X.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,X.jsx)("img",{src:j,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,X.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",i=(0,s.cC)(a.docId??void 0);return(0,X.jsx)(L,{href:a.href,icon:e,title:a.label,description:a.description??i?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,X.jsx)(k,{item:a});case"category":return(0,X.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function y(A){let{className:a}=A;const e=(0,s.$S)();return(0,X.jsx)(T,{items:e.items,className:a})}function T(A){const{items:a,className:e}=A;if(!a)return(0,X.jsx)(y,{...A});const t=(0,s.d1)(a);return(0,X.jsx)("section",{className:(0,i.A)("row",e),children:t.map(((A,a)=>(0,X.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,X.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>n,x:()=>l});var i=e(96540);const s={},t=i.createContext(s);function n(A){const a=i.useContext(t);return i.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function l(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:n(A.components),i.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/7706d644.c0e20b60.js b/assets/js/7706d644.c0e20b60.js new file mode 100644 index 00000000..86145fc7 --- /dev/null +++ b/assets/js/7706d644.c0e20b60.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1893],{22555:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>d,contentTitle:()=>n,default:()=>h,frontMatter:()=>t,metadata:()=>l,toc:()=>g});var i=e(74848),s=e(28453);e(64023);const t={title:"Installation",sidebar_position:4,slug:"/guides/install/",hide_table_of_contents:!0,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},n=void 0,l={id:"guides/installation/README",title:"Installation",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/installation/README.mdx",sourceDirName:"guides/installation",slug:"/guides/install/",permalink:"/guides/install/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:4,frontMatter:{title:"Installation",sidebar_position:4,slug:"/guides/install/",hide_table_of_contents:!0,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},d={},g=[{value:"Jan Device Compatible",id:"jan-device-compatible",level:2},{value:"Install Server-Side",id:"install-server-side",level:2},{value:"Pre-requisites",id:"pre-requisites",level:3},{value:"Install Jan Development Build",id:"install-jan-development-build",level:3},{value:"Install Jan Production Build",id:"install-jan-production-build",level:3}];function r(A){const a={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...A.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(a.h2,{id:"jan-device-compatible",children:"Jan Device Compatible"}),"\n",(0,i.jsx)(a.p,{children:"Jan is compatible with macOS, Windows, and Linux, making it accessible for a wide range of users. This compatibility allows users to leverage Jan's AI tools effectively, regardless of their device or operating system."}),"\n",(0,i.jsx)(a.admonition,{type:"note",children:(0,i.jsxs)(a.p,{children:["For detailed system requirements and setup instructions, refer to our ",(0,i.jsx)(a.a,{href:"/guides/hardware/",children:"Hardware Setup"})," guide."]})}),"\n","\n","\n",(0,i.jsx)(a.h2,{id:"install-server-side",children:"Install Server-Side"}),"\n",(0,i.jsx)(a.p,{children:"To install Jan from source, follow the steps below:"}),"\n",(0,i.jsx)(a.h3,{id:"pre-requisites",children:"Pre-requisites"}),"\n",(0,i.jsx)(a.p,{children:"Before proceeding with the installation of Jan from source, ensure that the following software versions are installed on your system:"}),"\n",(0,i.jsxs)(a.ul,{children:["\n",(0,i.jsx)(a.li,{children:"Node.js version 20.0.0 or higher"}),"\n",(0,i.jsx)(a.li,{children:"Yarn version 1.22.0 or higher"}),"\n"]}),"\n",(0,i.jsx)(a.h3,{id:"install-jan-development-build",children:"Install Jan Development Build"}),"\n",(0,i.jsxs)(a.ol,{children:["\n",(0,i.jsx)(a.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ngit checkout DESIRED_BRANCH\ncd jan\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"2",children:["\n",(0,i.jsx)(a.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"3",children:["\n",(0,i.jsx)(a.li,{children:"Run the development server."}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn dev\n"})}),"\n",(0,i.jsxs)(a.p,{children:["This will start the development server and open the desktop app. During this step, you may encounter notifications about installing base plugins. Simply click ",(0,i.jsx)(a.strong,{children:"OK"})," and ",(0,i.jsx)(a.strong,{children:"Next"})," to continue."]}),"\n",(0,i.jsx)(a.h3,{id:"install-jan-production-build",children:"Install Jan Production Build"}),"\n",(0,i.jsxs)(a.ol,{children:["\n",(0,i.jsx)(a.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ncd jan\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"2",children:["\n",(0,i.jsx)(a.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),"\n",(0,i.jsxs)(a.ol,{start:"3",children:["\n",(0,i.jsx)(a.li,{children:"Run the production server."}),"\n"]}),"\n",(0,i.jsx)(a.pre,{children:(0,i.jsx)(a.code,{className:"language-bash",children:"yarn\n"})}),"\n",(0,i.jsx)(a.p,{children:"This completes the installation process for Jan from source. The production-ready app for macOS can be found in the dist folder."})]})}function h(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,i.jsx)(a,{...A,children:(0,i.jsx)(r,{...A})}):r(A)}},64023:(A,a,e)=>{e.d(a,{A:()=>T});e(96540);var i=e(18215),s=e(84142),t=e(20053),n=e(28774),l=e(21312),d=e(51107);const g={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},r="",h="",o="",C="",c="",u="",F="",p="",B="",E="",Y="",w="",v="",I="",V="",R="",b="",U="",W="",K="",m="",N="",Q="",x="",O="",M="",G="",j="",Z="";var X=e(74848);function S(A){let{href:a,children:e}=A;return(0,X.jsx)(n.A,{href:a,className:(0,t.A)("card padding--lg",g.cardContainer),children:e})}function L(A){let{href:a,icon:e,title:i,description:s}=A;return(0,X.jsxs)(S,{href:a,children:[(0,X.jsxs)(d.A,{as:"h2",className:(0,t.A)("text--truncate",g.cardTitle),title:i,children:[e," ",i]}),s&&(0,X.jsx)("p",{className:(0,t.A)(g.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,X.jsx)(L,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,l.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,X.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,X.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,X.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,X.jsx)("img",{src:C,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,X.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,X.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,X.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,X.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,X.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,X.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,X.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,X.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,X.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,X.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,X.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,X.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,X.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,X.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,X.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,X.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,X.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,X.jsx)("img",{src:C,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,X.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,X.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,X.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,X.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,X.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,X.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,X.jsx)("img",{src:j,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,X.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",i=(0,s.cC)(a.docId??void 0);return(0,X.jsx)(L,{href:a.href,icon:e,title:a.label,description:a.description??i?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,X.jsx)(k,{item:a});case"category":return(0,X.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function y(A){let{className:a}=A;const e=(0,s.$S)();return(0,X.jsx)(T,{items:e.items,className:a})}function T(A){const{items:a,className:e}=A;if(!a)return(0,X.jsx)(y,{...A});const t=(0,s.d1)(a);return(0,X.jsx)("section",{className:(0,i.A)("row",e),children:t.map(((A,a)=>(0,X.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,X.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>n,x:()=>l});var i=e(96540);const s={},t=i.createContext(s);function n(A){const a=i.useContext(t);return i.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function l(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:n(A.components),i.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/7918b82f.3d5787fa.js b/assets/js/7918b82f.3d5787fa.js new file mode 100644 index 00000000..fc80cb3b --- /dev/null +++ b/assets/js/7918b82f.3d5787fa.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8402],{60709:(e,a,n)=>{n.r(a),n.d(a,{assets:()=>c,contentTitle:()=>r,default:()=>p,frontMatter:()=>o,metadata:()=>s,toc:()=>l});var t=n(74848),i=n(28453);const o={title:"Privacy - Jan"},r="Privacy Policy",s={id:"privacy/privacy",title:"Privacy - Jan",description:"\u2757This privacy policy only pertains to the DEPRECATED Jan Mobile Application in the iOS and Android app store.",source:"@site/docs/privacy/privacy.md",sourceDirName:"privacy",slug:"/privacy/",permalink:"/privacy/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/privacy/privacy.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Privacy - Jan"}},c={},l=[{value:"Data Collection and Usage",id:"data-collection-and-usage",level:2},{value:"Data Sharing",id:"data-sharing",level:2},{value:"Data Security",id:"data-security",level:2},{value:"Your Choices",id:"your-choices",level:2},{value:"Contact Us",id:"contact-us",level:2}];function d(e){const a={a:"a",h1:"h1",h2:"h2",p:"p",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(a.h1,{id:"privacy-policy",children:"Privacy Policy"}),"\n",(0,t.jsx)(a.p,{children:"\u2757This privacy policy only pertains to the DEPRECATED Jan Mobile Application in the iOS and Android app store.\n\u2757\u2757Jan Desktop DOES NOT collect identifying data at all."}),"\n",(0,t.jsx)(a.p,{children:"Jan is committed to protecting your privacy and ensuring that your personal information is handled in a safe and responsible way. This policy outlines how we collect, store, and use your personal information when you use our mobile application."}),"\n",(0,t.jsx)(a.h2,{id:"data-collection-and-usage",children:"Data Collection and Usage"}),"\n",(0,t.jsx)(a.p,{children:"When you use Jan, we may collect certain information about you, including your name, email address, and other personal information that you provide to us. We use this information to provide you with the best possible experience when using our app."}),"\n",(0,t.jsx)(a.p,{children:"We may also collect certain non-personal information, such as your device type, operating system, and app usage data. This information is used to improve our app and to provide you with a better user experience."}),"\n",(0,t.jsx)(a.h2,{id:"data-sharing",children:"Data Sharing"}),"\n",(0,t.jsx)(a.p,{children:"We do not share your personal information with third parties except as required by law or as necessary to provide you with the services you have requested. We may share non-personal information with third parties for the purpose of improving our app and providing you with a better user experience."}),"\n",(0,t.jsx)(a.h2,{id:"data-security",children:"Data Security"}),"\n",(0,t.jsx)(a.p,{children:"We take the security of your personal information seriously and have implemented appropriate technical and organizational measures to protect your personal information from unauthorized access, disclosure, or misuse."}),"\n",(0,t.jsx)(a.h2,{id:"your-choices",children:"Your Choices"}),"\n",(0,t.jsx)(a.p,{children:"You have the right to access, update, and delete your personal information at any time. You may also opt-out of receiving marketing communications from us by following the unsubscribe link included in our emails."}),"\n",(0,t.jsx)(a.h2,{id:"contact-us",children:"Contact Us"}),"\n",(0,t.jsxs)(a.p,{children:["If you have any questions or concerns about our privacy policy, please contact us at ",(0,t.jsx)(a.a,{href:"mailto:hello@jan.ai",children:"hello@jan.ai"}),"."]})]})}function p(e={}){const{wrapper:a}={...(0,i.R)(),...e.components};return a?(0,t.jsx)(a,{...e,children:(0,t.jsx)(d,{...e})}):d(e)}},28453:(e,a,n)=>{n.d(a,{R:()=>r,x:()=>s});var t=n(96540);const i={},o=t.createContext(i);function r(e){const a=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(a):{...a,...e}}),[a,e])}function s(e){let a;return a=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:r(e.components),t.createElement(o.Provider,{value:a},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/7918b82f.708daca9.js b/assets/js/7918b82f.708daca9.js deleted file mode 100644 index 18f26a88..00000000 --- a/assets/js/7918b82f.708daca9.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8402],{60709:(e,a,n)=>{n.r(a),n.d(a,{assets:()=>c,contentTitle:()=>r,default:()=>p,frontMatter:()=>o,metadata:()=>s,toc:()=>l});var t=n(74848),i=n(28453);const o={title:"Privacy - Jan"},r="Privacy Policy",s={id:"privacy/privacy",title:"Privacy - Jan",description:"\u2757This privacy policy only pertains to the DEPRECATED Jan Mobile Application in the iOS and Android app store.",source:"@site/docs/privacy/privacy.md",sourceDirName:"privacy",slug:"/privacy/",permalink:"/privacy/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/privacy/privacy.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Privacy - Jan"}},c={},l=[{value:"Data Collection and Usage",id:"data-collection-and-usage",level:2},{value:"Data Sharing",id:"data-sharing",level:2},{value:"Data Security",id:"data-security",level:2},{value:"Your Choices",id:"your-choices",level:2},{value:"Contact Us",id:"contact-us",level:2}];function d(e){const a={a:"a",h1:"h1",h2:"h2",p:"p",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(a.h1,{id:"privacy-policy",children:"Privacy Policy"}),"\n",(0,t.jsx)(a.p,{children:"\u2757This privacy policy only pertains to the DEPRECATED Jan Mobile Application in the iOS and Android app store.\n\u2757\u2757Jan Desktop DOES NOT collect identifying data at all."}),"\n",(0,t.jsx)(a.p,{children:"Jan is committed to protecting your privacy and ensuring that your personal information is handled in a safe and responsible way. This policy outlines how we collect, store, and use your personal information when you use our mobile application."}),"\n",(0,t.jsx)(a.h2,{id:"data-collection-and-usage",children:"Data Collection and Usage"}),"\n",(0,t.jsx)(a.p,{children:"When you use Jan, we may collect certain information about you, including your name, email address, and other personal information that you provide to us. We use this information to provide you with the best possible experience when using our app."}),"\n",(0,t.jsx)(a.p,{children:"We may also collect certain non-personal information, such as your device type, operating system, and app usage data. This information is used to improve our app and to provide you with a better user experience."}),"\n",(0,t.jsx)(a.h2,{id:"data-sharing",children:"Data Sharing"}),"\n",(0,t.jsx)(a.p,{children:"We do not share your personal information with third parties except as required by law or as necessary to provide you with the services you have requested. We may share non-personal information with third parties for the purpose of improving our app and providing you with a better user experience."}),"\n",(0,t.jsx)(a.h2,{id:"data-security",children:"Data Security"}),"\n",(0,t.jsx)(a.p,{children:"We take the security of your personal information seriously and have implemented appropriate technical and organizational measures to protect your personal information from unauthorized access, disclosure, or misuse."}),"\n",(0,t.jsx)(a.h2,{id:"your-choices",children:"Your Choices"}),"\n",(0,t.jsx)(a.p,{children:"You have the right to access, update, and delete your personal information at any time. You may also opt-out of receiving marketing communications from us by following the unsubscribe link included in our emails."}),"\n",(0,t.jsx)(a.h2,{id:"contact-us",children:"Contact Us"}),"\n",(0,t.jsxs)(a.p,{children:["If you have any questions or concerns about our privacy policy, please contact us at ",(0,t.jsx)(a.a,{href:"mailto:hello@jan.ai",children:"hello@jan.ai"}),"."]})]})}function p(e={}){const{wrapper:a}={...(0,i.R)(),...e.components};return a?(0,t.jsx)(a,{...e,children:(0,t.jsx)(d,{...e})}):d(e)}},28453:(e,a,n)=>{n.d(a,{R:()=>r,x:()=>s});var t=n(96540);const i={},o=t.createContext(i);function r(e){const a=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(a):{...a,...e}}),[a,e])}function s(e){let a;return a=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:r(e.components),t.createElement(o.Provider,{value:a},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/7f23cee5.381f5973.js b/assets/js/7f23cee5.381f5973.js deleted file mode 100644 index 3a9c6766..00000000 --- a/assets/js/7f23cee5.381f5973.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2591],{75491:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>m,frontMatter:()=>o,metadata:()=>s,toc:()=>l});var i=t(74848),r=t(28453);const o={title:"Jan's Community",slug:"/community",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine","community","socials"]},a=void 0,s={id:"community/community",title:"Jan's Community",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/community/community.mdx",sourceDirName:"community",slug:"/community",permalink:"/community",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/community/community.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan's Community",slug:"/community",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine","community","socials"]},sidebar:"aboutSidebar",previous:{title:"About Jan",permalink:"/about"},next:{title:"Who we are",permalink:"/team/"}},c={},l=[{value:"Socials",id:"socials",level:2},{value:"Community Run",id:"community-run",level:2},{value:"Careers",id:"careers",level:2},{value:"Newsletter",id:"newsletter",level:2}];function u(e){const n={a:"a",h2:"h2",li:"li",ul:"ul",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"socials",children:"Socials"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://discord.gg/SH3DGmUs6b",children:"Discord"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://twitter.com/janframework",children:"X"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://huggingface.co/janhq",children:"HuggingFace"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://www.linkedin.com/company/janframework/",children:"LinkedIn"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"community-run",children:"Community Run"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://www.reddit.com/r/janframework/",children:"Reddit"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"careers",children:"Careers"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://janai.bamboohr.com/careers",children:"Jobs"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"newsletter",children:"Newsletter"}),"\n",(0,i.jsx)("iframe",{width:"100%",height:"600px",src:"https://c0c7c086.sibforms.com/serve/MUIFAEWm49nC1OONIibGnlV44yxPMw6Fu1Yc8pK7nP3jp7rZ6rvrb5uOmCD8IIhrRj6-h-_AYrw-sz7JNpcUZ8LAAZoUIOjGmSvNWHwoFhxX5lb-38-fxXj933yIdGzEMBZJv4Nu2BqC2A4uThDGmjM-n_DZBV1v_mKbTcVUWVUE7VutWhRqrDr69IWI4SgbuIMACkcTiWX8ZNLw",frameborder:"0",scrolling:"auto",allowfullscreen:!0,style:{margin:"auto",maxWidth:"100%"}})]})}function m(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(u,{...e})}):u(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>s});var i=t(96540);const r={},o=i.createContext(r);function a(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/7f23cee5.d7b19c2c.js b/assets/js/7f23cee5.d7b19c2c.js new file mode 100644 index 00000000..65ae9352 --- /dev/null +++ b/assets/js/7f23cee5.d7b19c2c.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2591],{75491:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>m,frontMatter:()=>o,metadata:()=>s,toc:()=>l});var i=t(74848),r=t(28453);const o={title:"Jan's Community",slug:"/community",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine","community","socials"]},a=void 0,s={id:"community/community",title:"Jan's Community",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/community/community.mdx",sourceDirName:"community",slug:"/community",permalink:"/community",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/community/community.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan's Community",slug:"/community",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine","community","socials"]},sidebar:"aboutSidebar",previous:{title:"About Jan",permalink:"/about"},next:{title:"Who we are",permalink:"/team/"}},c={},l=[{value:"Socials",id:"socials",level:2},{value:"Community Run",id:"community-run",level:2},{value:"Careers",id:"careers",level:2},{value:"Newsletter",id:"newsletter",level:2}];function u(e){const n={a:"a",h2:"h2",li:"li",ul:"ul",...(0,r.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"socials",children:"Socials"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://discord.gg/SH3DGmUs6b",children:"Discord"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://twitter.com/janframework",children:"X"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://huggingface.co/janhq",children:"HuggingFace"})}),"\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://www.linkedin.com/company/janframework/",children:"LinkedIn"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"community-run",children:"Community Run"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://www.reddit.com/r/janframework/",children:"Reddit"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"careers",children:"Careers"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:(0,i.jsx)(n.a,{href:"https://janai.bamboohr.com/careers",children:"Jobs"})}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"newsletter",children:"Newsletter"}),"\n",(0,i.jsx)("iframe",{width:"100%",height:"600px",src:"https://c0c7c086.sibforms.com/serve/MUIFAEWm49nC1OONIibGnlV44yxPMw6Fu1Yc8pK7nP3jp7rZ6rvrb5uOmCD8IIhrRj6-h-_AYrw-sz7JNpcUZ8LAAZoUIOjGmSvNWHwoFhxX5lb-38-fxXj933yIdGzEMBZJv4Nu2BqC2A4uThDGmjM-n_DZBV1v_mKbTcVUWVUE7VutWhRqrDr69IWI4SgbuIMACkcTiWX8ZNLw",frameborder:"0",scrolling:"auto",allowfullscreen:!0,style:{margin:"auto",maxWidth:"100%"}})]})}function m(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(u,{...e})}):u(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>s});var i=t(96540);const r={},o=i.createContext(r);function a(e){const n=i.useContext(o);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),i.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/7fa78872.999a4ebf.js b/assets/js/7fa78872.999a4ebf.js deleted file mode 100644 index e421caee..00000000 --- a/assets/js/7fa78872.999a4ebf.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4571],{18222:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>a,contentTitle:()=>d,default:()=>h,frontMatter:()=>s,metadata:()=>t,toc:()=>r});var l=o(74848),i=o(28453);const s={title:"Manage Models",slug:"/guides/models",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:7,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","models","remote models","local models","manage models"]},d=void 0,t={id:"guides/user-guides/manage-models",title:"Manage Models",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/manage-models.mdx",sourceDirName:"guides/user-guides",slug:"/guides/models",permalink:"/guides/models",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/manage-models.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:7,frontMatter:{title:"Manage Models",slug:"/guides/models",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:7,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","models","remote models","local models","manage models"]},sidebar:"guidesSidebar",previous:{title:"Quickstart",permalink:"/guides/quickstart"},next:{title:"Manage Threads",permalink:"/guides/threads"}},a={},r=[{value:"Add Models",id:"add-models",level:2},{value:"Download from Jan Hub",id:"download-from-jan-hub",level:3},{value:"Import or Symlink Local Models",id:"import-or-symlink-local-models",level:3},{value:"Download with HuggingFace URL",id:"download-with-huggingface-url",level:3},{value:"Download with Nvidia NGC",id:"download-with-nvidia-ngc",level:3},{value:"Customize Models",id:"customize-models",level:2},{value:"Delete Models",id:"delete-models",level:2}];function c(e){const n={admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",ul:"ul",...(0,i.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h2,{id:"add-models",children:"Add Models"}),"\n",(0,l.jsx)(n.p,{children:"There are various ways to add models to Jan."}),"\n",(0,l.jsx)(n.p,{children:"Currently, Jan natively supports the following model formats:"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"GGUF (through a llama.cpp engine)"}),"\n",(0,l.jsx)(n.li,{children:"TensorRT (through a TRT-LLM engine)"}),"\n"]}),"\n",(0,l.jsx)(n.h3,{id:"download-from-jan-hub",children:"Download from Jan Hub"}),"\n",(0,l.jsx)(n.p,{children:"You can choose from a list of popular, recommended models directly from Jan app's Model Hub.\nThese models are preconfigured with optimal runtime parameters. This is the easiest way to get started."}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Navigate to the Hub"}),"\n",(0,l.jsxs)(n.li,{children:["Select models, clicking on the ",(0,l.jsx)(n.code,{children:"v"})," dropdown to see more information. Models with the ",(0,l.jsx)(n.code,{children:"Recommended"})," label are likely to run faster on your computer."]}),"\n",(0,l.jsx)(n.li,{children:"Click use after the model has finished downloading"}),"\n",(0,l.jsx)(n.li,{children:"Ensure that the model is selected in the thread's model dropdown"}),"\n"]}),"\n",(0,l.jsx)(n.h3,{id:"import-or-symlink-local-models",children:"Import or Symlink Local Models"}),"\n",(0,l.jsx)(n.p,{children:"You can also point to existing model binary files on your local filesystem.\nThis is the easiest and most space efficient way if you already use other local AI applications."}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Navigate to the Hub"}),"\n",(0,l.jsxs)(n.li,{children:["Click on ",(0,l.jsx)(n.code,{children:"Import Model"})," at the top"]}),"\n",(0,l.jsx)(n.li,{children:"Select the model or the folder containing multiple models"}),"\n",(0,l.jsx)(n.li,{children:"Optionally, check the box to symlink the model files instead of copying them over the Jan Data Folder. This saves disk space."}),"\n"]}),"\n",(0,l.jsx)(n.admonition,{type:"warning",children:(0,l.jsxs)(n.p,{children:["Windows users must drag & drop the model file. If you select ",(0,l.jsx)(n.code,{children:"Click to Upload"}),", your Folder Preview may not display the model files."]})}),"\n",(0,l.jsx)(n.h3,{id:"download-with-huggingface-url",children:"Download with HuggingFace URL"}),"\n",(0,l.jsx)(n.admonition,{type:"info",children:(0,l.jsx)(n.p,{children:"Coming soon"})}),"\n",(0,l.jsx)(n.h3,{id:"download-with-nvidia-ngc",children:"Download with Nvidia NGC"}),"\n",(0,l.jsx)(n.admonition,{type:"info",children:(0,l.jsx)(n.p,{children:"Coming soon"})}),"\n",(0,l.jsx)(n.h2,{id:"customize-models",children:"Customize Models"}),"\n",(0,l.jsx)(n.p,{children:"You can customize default model run settings."}),"\n",(0,l.jsx)(n.p,{children:"To customize model settings for a specific conversation only:"}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Create a new thread"}),"\n",(0,l.jsx)(n.li,{children:"Expand the right panel"}),"\n",(0,l.jsxs)(n.li,{children:["Change settings under the ",(0,l.jsx)(n.code,{children:"model"})," dropdown"]}),"\n"]}),"\n",(0,l.jsx)(n.p,{children:"To customize default model settings for all conversations:"}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Open any thread"}),"\n",(0,l.jsxs)(n.li,{children:["Select on the 3 dots next to the ",(0,l.jsx)(n.code,{children:"model"})," dropdown"]}),"\n",(0,l.jsxs)(n.li,{children:["Select ",(0,l.jsx)(n.code,{children:"Edit global defaults for [model]"})]}),"\n",(0,l.jsxs)(n.li,{children:["Edit the default settings directly in the ",(0,l.jsx)(n.code,{children:"model.json"})]}),"\n",(0,l.jsx)(n.li,{children:"Save the file and refresh the app"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"delete-models",children:"Delete Models"}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Go to Settings"}),"\n",(0,l.jsx)(n.li,{children:"Go to My Models"}),"\n",(0,l.jsxs)(n.li,{children:["Select the 3 dots next and select ",(0,l.jsx)(n.code,{children:"Delete model"})]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>d,x:()=>t});var l=o(96540);const i={},s=l.createContext(i);function d(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:d(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/7fa78872.a226852b.js b/assets/js/7fa78872.a226852b.js new file mode 100644 index 00000000..47379b0b --- /dev/null +++ b/assets/js/7fa78872.a226852b.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4571],{18222:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>a,contentTitle:()=>d,default:()=>h,frontMatter:()=>i,metadata:()=>t,toc:()=>r});var l=o(74848),s=o(28453);const i={title:"Manage Models",slug:"/guides/models",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","models","remote models","local models","manage models"]},d=void 0,t={id:"guides/user-guides/manage-models",title:"Manage Models",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/manage-models.mdx",sourceDirName:"guides/user-guides",slug:"/guides/models",permalink:"/guides/models",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/manage-models.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Manage Models",slug:"/guides/models",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","models","remote models","local models","manage models"]},sidebar:"guidesSidebar",previous:{title:"Quickstart",permalink:"/guides/quickstart"},next:{title:"Manage Assistants",permalink:"/guides/assistants"}},a={},r=[{value:"Add Models",id:"add-models",level:2},{value:"Download from Jan Hub",id:"download-from-jan-hub",level:3},{value:"Import or Symlink Local Models",id:"import-or-symlink-local-models",level:3},{value:"Download with HuggingFace URL",id:"download-with-huggingface-url",level:3},{value:"Download with Nvidia NGC",id:"download-with-nvidia-ngc",level:3},{value:"Customize Models",id:"customize-models",level:2},{value:"Delete Models",id:"delete-models",level:2}];function c(e){const n={admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h2,{id:"add-models",children:"Add Models"}),"\n",(0,l.jsx)(n.p,{children:"There are various ways to add models to Jan."}),"\n",(0,l.jsx)(n.p,{children:"Currently, Jan natively supports the following model formats:"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"GGUF (through a llama.cpp engine)"}),"\n",(0,l.jsx)(n.li,{children:"TensorRT (through a TRT-LLM engine)"}),"\n"]}),"\n",(0,l.jsx)(n.h3,{id:"download-from-jan-hub",children:"Download from Jan Hub"}),"\n",(0,l.jsx)(n.p,{children:"You can choose from a list of popular, recommended models directly from Jan app's Model Hub.\nThese models are preconfigured with optimal runtime parameters. This is the easiest way to get started."}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Navigate to the Hub"}),"\n",(0,l.jsxs)(n.li,{children:["Select models, clicking on the ",(0,l.jsx)(n.code,{children:"v"})," dropdown to see more information. Models with the ",(0,l.jsx)(n.code,{children:"Recommended"})," label are likely to run faster on your computer."]}),"\n",(0,l.jsx)(n.li,{children:"Click use after the model has finished downloading"}),"\n",(0,l.jsx)(n.li,{children:"Ensure that the model is selected in the thread's model dropdown"}),"\n"]}),"\n",(0,l.jsx)(n.h3,{id:"import-or-symlink-local-models",children:"Import or Symlink Local Models"}),"\n",(0,l.jsx)(n.p,{children:"You can also point to existing model binary files on your local filesystem.\nThis is the easiest and most space efficient way if you already use other local AI applications."}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Navigate to the Hub"}),"\n",(0,l.jsxs)(n.li,{children:["Click on ",(0,l.jsx)(n.code,{children:"Import Model"})," at the top"]}),"\n",(0,l.jsx)(n.li,{children:"Select the model or the folder containing multiple models"}),"\n",(0,l.jsx)(n.li,{children:"Optionally, check the box to symlink the model files instead of copying them over the Jan Data Folder. This saves disk space."}),"\n"]}),"\n",(0,l.jsx)(n.admonition,{type:"warning",children:(0,l.jsxs)(n.p,{children:["Windows users must drag & drop the model file. If you select ",(0,l.jsx)(n.code,{children:"Click to Upload"}),", your Folder Preview may not display the model files."]})}),"\n",(0,l.jsx)(n.h3,{id:"download-with-huggingface-url",children:"Download with HuggingFace URL"}),"\n",(0,l.jsx)(n.admonition,{type:"info",children:(0,l.jsx)(n.p,{children:"Coming soon"})}),"\n",(0,l.jsx)(n.h3,{id:"download-with-nvidia-ngc",children:"Download with Nvidia NGC"}),"\n",(0,l.jsx)(n.admonition,{type:"info",children:(0,l.jsx)(n.p,{children:"Coming soon"})}),"\n",(0,l.jsx)(n.h2,{id:"customize-models",children:"Customize Models"}),"\n",(0,l.jsx)(n.p,{children:"You can customize default model run settings."}),"\n",(0,l.jsx)(n.p,{children:"To customize model settings for a specific conversation only:"}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Create a new thread"}),"\n",(0,l.jsx)(n.li,{children:"Expand the right panel"}),"\n",(0,l.jsxs)(n.li,{children:["Change settings under the ",(0,l.jsx)(n.code,{children:"model"})," dropdown"]}),"\n"]}),"\n",(0,l.jsx)(n.p,{children:"To customize default model settings for all conversations:"}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Open any thread"}),"\n",(0,l.jsxs)(n.li,{children:["Select on the 3 dots next to the ",(0,l.jsx)(n.code,{children:"model"})," dropdown"]}),"\n",(0,l.jsxs)(n.li,{children:["Select ",(0,l.jsx)(n.code,{children:"Edit global defaults for [model]"})]}),"\n",(0,l.jsxs)(n.li,{children:["Edit the default settings directly in the ",(0,l.jsx)(n.code,{children:"model.json"})]}),"\n",(0,l.jsx)(n.li,{children:"Save the file and refresh the app"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"delete-models",children:"Delete Models"}),"\n",(0,l.jsxs)(n.ol,{children:["\n",(0,l.jsx)(n.li,{children:"Go to Settings"}),"\n",(0,l.jsx)(n.li,{children:"Go to My Models"}),"\n",(0,l.jsxs)(n.li,{children:["Select the 3 dots next and select ",(0,l.jsx)(n.code,{children:"Delete model"})]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>d,x:()=>t});var l=o(96540);const s={},i=l.createContext(s);function d(e){const n=l.useContext(i);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:d(e.components),l.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/849af23d.22d7191f.js b/assets/js/849af23d.22d7191f.js new file mode 100644 index 00000000..22d25b1b --- /dev/null +++ b/assets/js/849af23d.22d7191f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8152],{82657:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>i,contentTitle:()=>r,default:()=>u,frontMatter:()=>c,metadata:()=>a,toc:()=>d});var n=s(74848),o=s(28453);const c={title:"Ecosystem"},r=void 0,a={id:"ecosystem/ecosystem",title:"Ecosystem",description:"",source:"@site/docs/ecosystem/ecosystem.md",sourceDirName:"ecosystem",slug:"/ecosystem/",permalink:"/ecosystem/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/ecosystem/ecosystem.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Ecosystem"},sidebar:"ecosystemSidebar",next:{title:"Partners",permalink:"/partners/"}},i={},d=[];function m(t){return(0,n.jsx)(n.Fragment,{})}function u(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(m,{...t})}):m()}},28453:(t,e,s)=>{s.d(e,{R:()=>r,x:()=>a});var n=s(96540);const o={},c=n.createContext(o);function r(t){const e=n.useContext(c);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),n.createElement(c.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/849af23d.b05d22e2.js b/assets/js/849af23d.b05d22e2.js deleted file mode 100644 index 848dd8f9..00000000 --- a/assets/js/849af23d.b05d22e2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8152],{82657:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>i,contentTitle:()=>r,default:()=>u,frontMatter:()=>c,metadata:()=>a,toc:()=>d});var n=s(74848),o=s(28453);const c={title:"Ecosystem"},r=void 0,a={id:"ecosystem/ecosystem",title:"Ecosystem",description:"",source:"@site/docs/ecosystem/ecosystem.md",sourceDirName:"ecosystem",slug:"/ecosystem/",permalink:"/ecosystem/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/ecosystem/ecosystem.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Ecosystem"},sidebar:"ecosystemSidebar",next:{title:"Partners",permalink:"/partners/"}},i={},d=[];function m(t){return(0,n.jsx)(n.Fragment,{})}function u(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(m,{...t})}):m()}},28453:(t,e,s)=>{s.d(e,{R:()=>r,x:()=>a});var n=s(96540);const o={},c=n.createContext(o);function r(t){const e=n.useContext(c);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),n.createElement(c.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/84ee6c7c.3e6178f4.js b/assets/js/84ee6c7c.3e6178f4.js new file mode 100644 index 00000000..f6da616d --- /dev/null +++ b/assets/js/84ee6c7c.3e6178f4.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[202],{46149:(e,t,l)=>{l.r(t),l.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>o,frontMatter:()=>n,metadata:()=>d,toc:()=>x});var r=l(74848),s=l(28453);const n={title:"Recommended AI Hardware by Budget"},i=void 0,d={id:"hardware/recommendations/by-budget",title:"Recommended AI Hardware by Budget",description:"Warning: Do your own research before any purchase. Jan is not liable for compatibility, performance or other issues. Products can become outdated quickly.",source:"@site/docs/hardware/recommendations/by-budget.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-budget",permalink:"/hardware/recommendations/by-budget",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-budget.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Recommended AI Hardware by Budget"}},c={},x=[{value:"Entry-level PC Build at $1000",id:"entry-level-pc-build-at-1000",level:2},{value:"Entry-level PC Build at $1,500",id:"entry-level-pc-build-at-1500",level:2},{value:"Mid-range PC Build at $3000",id:"mid-range-pc-build-at-3000",level:2},{value:"High-End PC Build at $6,000",id:"high-end-pc-build-at-6000",level:2}];function h(e){const t={a:"a",blockquote:"blockquote",h2:"h2",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)(t.blockquote,{children:["\n",(0,r.jsxs)(t.p,{children:["\u26a0\ufe0f"," ",(0,r.jsx)(t.strong,{children:"Warning:"})," Do your own research before any purchase. Jan is not liable for compatibility, performance or other issues. Products can become outdated quickly."]}),"\n"]}),"\n",(0,r.jsx)(t.h2,{id:"entry-level-pc-build-at-1000",children:"Entry-level PC Build at $1000"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Intel Core i5 12400 2.5GHz 6-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$170.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Intel Boxed Cooler (Included with CPU)"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"Included"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ASUS Prime B660-PLUS DDR4 ATX LGA1700"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$169.95"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Nvidia RTX 3050 8GB - ZOTAC Gaming Twin Edge"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$250"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"16GB (2 x 8GB) G.Skill Ripjaws V DDR4-3200 C16"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$49.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage PCIe-SSD"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ADATA XPG SX8200 Pro 512GB NVMe M.2 Solid State Drive"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$46.50"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Corsair CX-M Series CX450M 450W ATX 2.4 Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$89.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"be quiet! Pure Base 600 Black ATX Mid Tower Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$97.00"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$870"})]})]})]}),"\n",(0,r.jsx)(t.h2,{id:"entry-level-pc-build-at-1500",children:"Entry-level PC Build at $1,500"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Intel Core i5 12600K 3.7GHz 6-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$269.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"be quiet! Dark Rock Pro 4"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$99.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ASUS ProArt B660-Creator DDR4 ATX LGA1700"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$229.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Nvidia RTX 3050 8GB - ZOTAC Gaming Twin Edge"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$349.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"32GB (2 x 16GB) G.Skill Ripjaws V DDR4-3200 C16"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$129.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage PCIe-SSD"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ADATA XPG SX8200 Pro 1TB NVMe M.2 Solid State Drive"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$109.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Corsair RMx Series RM650x 650W ATX 2.4 Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$119.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Corsair Carbide Series 200R ATX Mid Tower Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$59.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$1371"})]})]})]}),"\n",(0,r.jsx)(t.h2,{id:"mid-range-pc-build-at-3000",children:"Mid-range PC Build at $3000"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/22XJ7P/amd-ryzen-9-7950x-45-ghz-16-core-processor-100-100000514wof",children:"AMD Ryzen 9 7950X 4.5 GHz 16-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$556"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/476p99/thermalright-peerless-assassin-120-white-6617-cfm-cpu-cooler-pa120-white",children:"Thermalright Peerless Assassin 120 White 66.17 CFM CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$59.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/YZgFf7/gigabyte-b650-gaming-x-ax-atx-am5-motherboard-b650-gaming-x-ax",children:"Gigabyte B650 GAMING X AX ATX AM5 Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$199.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/BJcG3C/gskill-ripjaws-s5-64-gb-2-x-32-gb-ddr5-6000-cl32-memory-f5-6000j3238g32gx2-rs5k",children:"G.Skill Ripjaws S5 64 GB (2 x 32 GB) DDR5-6000 CL32 Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$194"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/VZWzK8/crucial-p5-plus-2-tb-m2-2280-pcie-40-x4-nvme-solid-state-drive-ct2000p5pssd8",children:"Crucial P5 Plus 2 TB M.2-2280 PCIe 4.0 X4 NVME Solid "})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$165.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/TvpzK8/pny-xlr8-gaming-verto-epic-x-rgb-oc-geforce-rtx-4090-24-gb-video-card-vcg409024tfxxpb1-o",children:"PNY XLR8 Gaming VERTO EPIC-X RGB OC GeForce RTX 4090 24 GB"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$1,599.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/QnD7YJ/fractal-design-pop-air-atx-mid-tower-case-fd-c-poa1a-02",children:"Fractal Design Pop Air ATX Mid Tower Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$89.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/4v3NnQ/thermaltake-toughpower-gf-a3-1050-w-80-gold-certified-fully-modular-atx-power-supply-ps-tpd-1050fnfagu-l",children:"Thermaltake Toughpower GF A3 - TT Premium Edition 1050 W 80+ Gold"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$139.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"$3000"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]})]})]}),"\n",(0,r.jsx)(t.h2,{id:"high-end-pc-build-at-6000",children:"High-End PC Build at $6,000"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/tLCD4D/amd-ryzen-9-3900x-36-ghz-12-core-processor-100-100000023box",children:"AMD Ryzen 9 3900X 3.8 GHz 12-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$365.00"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/dMVG3C/noctua-nh-u12s-chromaxblack-55-cfm-cpu-cooler-nh-u12s-chromaxblack",children:"Noctua NH-U12S chromax.black 55 CFM CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$89.95"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/8y8bt6/asus-proart-x570-creator-wifi-atx-am4-motherboard-proart-x570-creator-wifi",children:"Asus ProArt X570-CREATOR WIFI ATX AM4 Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$599.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/tRH8TW/corsair-vengeance-lpx-128-gb-4-x-32-gb-ddr4-3200-memory-cmk128gx4m4e3200c16",children:"Corsair Vengeance LPX 128 GB (4 x 32 GB) DDR4-3200 CL16 Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$249.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/PMBhP6/sabrent-rocket-4-plus-2-tb-m2-2280-nvme-solid-state-drive-sb-rkt4p-2tb",children:"Sabrent Rocket 4 Plus 2 TB M.2-2280 PCIe 4.0 X4 NVME Solid State Drive"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$129.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/HWt9TW/pny-rtx-a-series-rtx-a6000-48-gb-video-card-vcnrtxa6000-pb",children:"PNY RTX A-Series RTX A6000 48 GB Video Card"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$4269.00"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/LCfp99/evga-supernova-850-g2-850-w-80-gold-certified-fully-modular-atx-power-supply-220-g2-0850-xr",children:"EVGA SuperNOVA 850 G2 850 W 80+ Gold "})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$322.42"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"$6026.34"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]})]})]})]})}function o(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},28453:(e,t,l)=>{l.d(t,{R:()=>i,x:()=>d});var r=l(96540);const s={},n=r.createContext(s);function i(e){const t=r.useContext(n);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),r.createElement(n.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/84ee6c7c.cb304649.js b/assets/js/84ee6c7c.cb304649.js deleted file mode 100644 index f153db0f..00000000 --- a/assets/js/84ee6c7c.cb304649.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[202],{46149:(e,t,l)=>{l.r(t),l.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>o,frontMatter:()=>n,metadata:()=>d,toc:()=>x});var r=l(74848),s=l(28453);const n={title:"Recommended AI Hardware by Budget"},i=void 0,d={id:"hardware/recommendations/by-budget",title:"Recommended AI Hardware by Budget",description:"Warning: Do your own research before any purchase. Jan is not liable for compatibility, performance or other issues. Products can become outdated quickly.",source:"@site/docs/hardware/recommendations/by-budget.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-budget",permalink:"/hardware/recommendations/by-budget",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-budget.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Recommended AI Hardware by Budget"}},c={},x=[{value:"Entry-level PC Build at $1000",id:"entry-level-pc-build-at-1000",level:2},{value:"Entry-level PC Build at $1,500",id:"entry-level-pc-build-at-1500",level:2},{value:"Mid-range PC Build at $3000",id:"mid-range-pc-build-at-3000",level:2},{value:"High-End PC Build at $6,000",id:"high-end-pc-build-at-6000",level:2}];function h(e){const t={a:"a",blockquote:"blockquote",h2:"h2",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)(t.blockquote,{children:["\n",(0,r.jsxs)(t.p,{children:["\u26a0\ufe0f"," ",(0,r.jsx)(t.strong,{children:"Warning:"})," Do your own research before any purchase. Jan is not liable for compatibility, performance or other issues. Products can become outdated quickly."]}),"\n"]}),"\n",(0,r.jsx)(t.h2,{id:"entry-level-pc-build-at-1000",children:"Entry-level PC Build at $1000"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Intel Core i5 12400 2.5GHz 6-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$170.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Intel Boxed Cooler (Included with CPU)"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"Included"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ASUS Prime B660-PLUS DDR4 ATX LGA1700"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$169.95"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Nvidia RTX 3050 8GB - ZOTAC Gaming Twin Edge"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$250"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"16GB (2 x 8GB) G.Skill Ripjaws V DDR4-3200 C16"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$49.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage PCIe-SSD"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ADATA XPG SX8200 Pro 512GB NVMe M.2 Solid State Drive"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$46.50"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Corsair CX-M Series CX450M 450W ATX 2.4 Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$89.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"be quiet! Pure Base 600 Black ATX Mid Tower Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$97.00"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$870"})]})]})]}),"\n",(0,r.jsx)(t.h2,{id:"entry-level-pc-build-at-1500",children:"Entry-level PC Build at $1,500"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Intel Core i5 12600K 3.7GHz 6-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$269.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"be quiet! Dark Rock Pro 4"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$99.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ASUS ProArt B660-Creator DDR4 ATX LGA1700"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$229.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Nvidia RTX 3050 8GB - ZOTAC Gaming Twin Edge"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$349.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"32GB (2 x 16GB) G.Skill Ripjaws V DDR4-3200 C16"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$129.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage PCIe-SSD"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"ADATA XPG SX8200 Pro 1TB NVMe M.2 Solid State Drive"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$109.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Corsair RMx Series RM650x 650W ATX 2.4 Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$119.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"#",children:"Corsair Carbide Series 200R ATX Mid Tower Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$59.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$1371"})]})]})]}),"\n",(0,r.jsx)(t.h2,{id:"mid-range-pc-build-at-3000",children:"Mid-range PC Build at $3000"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/22XJ7P/amd-ryzen-9-7950x-45-ghz-16-core-processor-100-100000514wof",children:"AMD Ryzen 9 7950X 4.5 GHz 16-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$556"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/476p99/thermalright-peerless-assassin-120-white-6617-cfm-cpu-cooler-pa120-white",children:"Thermalright Peerless Assassin 120 White 66.17 CFM CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$59.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/YZgFf7/gigabyte-b650-gaming-x-ax-atx-am5-motherboard-b650-gaming-x-ax",children:"Gigabyte B650 GAMING X AX ATX AM5 Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$199.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/BJcG3C/gskill-ripjaws-s5-64-gb-2-x-32-gb-ddr5-6000-cl32-memory-f5-6000j3238g32gx2-rs5k",children:"G.Skill Ripjaws S5 64 GB (2 x 32 GB) DDR5-6000 CL32 Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$194"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/VZWzK8/crucial-p5-plus-2-tb-m2-2280-pcie-40-x4-nvme-solid-state-drive-ct2000p5pssd8",children:"Crucial P5 Plus 2 TB M.2-2280 PCIe 4.0 X4 NVME Solid "})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$165.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/TvpzK8/pny-xlr8-gaming-verto-epic-x-rgb-oc-geforce-rtx-4090-24-gb-video-card-vcg409024tfxxpb1-o",children:"PNY XLR8 Gaming VERTO EPIC-X RGB OC GeForce RTX 4090 24 GB"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$1,599.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/QnD7YJ/fractal-design-pop-air-atx-mid-tower-case-fd-c-poa1a-02",children:"Fractal Design Pop Air ATX Mid Tower Case"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$89.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://de.pcpartpicker.com/product/4v3NnQ/thermaltake-toughpower-gf-a3-1050-w-80-gold-certified-fully-modular-atx-power-supply-ps-tpd-1050fnfagu-l",children:"Thermaltake Toughpower GF A3 - TT Premium Edition 1050 W 80+ Gold"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$139.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"$3000"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]})]})]}),"\n",(0,r.jsx)(t.h2,{id:"high-end-pc-build-at-6000",children:"High-End PC Build at $6,000"}),"\n",(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Type"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Item"}),(0,r.jsx)(t.th,{style:{textAlign:"left"},children:"Price"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/tLCD4D/amd-ryzen-9-3900x-36-ghz-12-core-processor-100-100000023box",children:"AMD Ryzen 9 3900X 3.8 GHz 12-Core Processor"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$365.00"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/dMVG3C/noctua-nh-u12s-chromaxblack-55-cfm-cpu-cooler-nh-u12s-chromaxblack",children:"Noctua NH-U12S chromax.black 55 CFM CPU Cooler"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$89.95"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/8y8bt6/asus-proart-x570-creator-wifi-atx-am4-motherboard-proart-x570-creator-wifi",children:"Asus ProArt X570-CREATOR WIFI ATX AM4 Motherboard"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$599.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/tRH8TW/corsair-vengeance-lpx-128-gb-4-x-32-gb-ddr4-3200-memory-cmk128gx4m4e3200c16",children:"Corsair Vengeance LPX 128 GB (4 x 32 GB) DDR4-3200 CL16 Memory"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$249.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Storage"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/PMBhP6/sabrent-rocket-4-plus-2-tb-m2-2280-nvme-solid-state-drive-sb-rkt4p-2tb",children:"Sabrent Rocket 4 Plus 2 TB M.2-2280 PCIe 4.0 X4 NVME Solid State Drive"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$129.99"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"GPU"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/HWt9TW/pny-rtx-a-series-rtx-a6000-48-gb-video-card-vcnrtxa6000-pb",children:"PNY RTX A-Series RTX A6000 48 GB Video Card"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$4269.00"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Power Supply"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.a,{href:"https://pcpartpicker.com/product/LCfp99/evga-supernova-850-g2-850-w-80-gold-certified-fully-modular-atx-power-supply-220-g2-0850-xr",children:"EVGA SuperNOVA 850 G2 850 W 80+ Gold "})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:"$322.42"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"Total cost"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"},children:(0,r.jsx)(t.strong,{children:"$6026.34"})}),(0,r.jsx)(t.td,{style:{textAlign:"left"}})]})]})]})]})}function o(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},28453:(e,t,l)=>{l.d(t,{R:()=>i,x:()=>d});var r=l(96540);const s={},n=r.createContext(s);function i(e){const t=r.useContext(n);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),r.createElement(n.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/85c092f0.a3e68602.js b/assets/js/85c092f0.a3e68602.js new file mode 100644 index 00000000..73dd7cdc --- /dev/null +++ b/assets/js/85c092f0.a3e68602.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3940],{78379:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>c,metadata:()=>a,toc:()=>i});var r=n(74848),o=n(28453);const c={title:"Network"},s=void 0,a={id:"hardware/concepts/network",title:"Network",description:"",source:"@site/docs/hardware/concepts/network.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/network",permalink:"/hardware/concepts/network",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/network.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Network"}},d={},i=[];function u(t){return(0,r.jsx)(r.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,r.jsx)(e,{...t,children:(0,r.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>a});var r=n(96540);const o={},c=r.createContext(o);function s(t){const e=r.useContext(c);return r.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),r.createElement(c.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/85c092f0.decfd195.js b/assets/js/85c092f0.decfd195.js deleted file mode 100644 index 88458f07..00000000 --- a/assets/js/85c092f0.decfd195.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3940],{78379:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>c,metadata:()=>a,toc:()=>i});var r=n(74848),o=n(28453);const c={title:"Network"},s=void 0,a={id:"hardware/concepts/network",title:"Network",description:"",source:"@site/docs/hardware/concepts/network.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/network",permalink:"/hardware/concepts/network",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/network.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Network"}},d={},i=[];function u(t){return(0,r.jsx)(r.Fragment,{})}function p(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,r.jsx)(e,{...t,children:(0,r.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>a});var r=n(96540);const o={},c=r.createContext(o);function s(t){const e=r.useContext(c);return r.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),r.createElement(c.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/85edfec6.5eb8febc.js b/assets/js/85edfec6.5eb8febc.js new file mode 100644 index 00000000..a8811b86 --- /dev/null +++ b/assets/js/85edfec6.5eb8febc.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1837],{73365:(e,n,l)=>{l.r(n),l.d(n,{assets:()=>r,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>s,toc:()=>d});var t=l(74848),a=l(28453);const o={title:"Ollama",slug:"/guides/engines/ollama",sidebar_position:4,description:"A step-by-step guide on how to integrate Jan with Ollama.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Ollama integration"]},i=void 0,s={id:"guides/local-providers/ollama",title:"Ollama",description:"A step-by-step guide on how to integrate Jan with Ollama.",source:"@site/docs/guides/local-providers/ollama.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/ollama",permalink:"/guides/engines/ollama",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/ollama.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:4,frontMatter:{title:"Ollama",slug:"/guides/engines/ollama",sidebar_position:4,description:"A step-by-step guide on how to integrate Jan with Ollama.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Ollama integration"]},sidebar:"guidesSidebar",previous:{title:"LM Studio",permalink:"/guides/engines/lmstudio"},next:{title:"Remote Engines",permalink:"/guides/engines/remote"}},r={},d=[{value:"Integrate Ollama with Jan",id:"integrate-ollama-with-jan",level:2},{value:"Step 1: Start the Ollama Server",id:"step-1-start-the-ollama-server",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Start the Model",id:"step-3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,a.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"integrate-ollama-with-jan",children:"Integrate Ollama with Jan"}),"\n",(0,t.jsx)(n.p,{children:"Ollama provides you with largen language that you can run locally. There are two methods to integrate Ollama with Jan:"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Integrate Ollama server with Jan."}),"\n",(0,t.jsx)(n.li,{children:"Migrate the downloaded model from Ollama to Jan."}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"To integrate Ollama with Jan, follow the steps below:"}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["In this tutorial, we'll show how to integrate Ollama with Jan using the first method. We will use the ",(0,t.jsx)(n.a,{href:"https://ollama.com/library/llama2",children:"llama2"})," model as an example."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-1-start-the-ollama-server",children:"Step 1: Start the Ollama Server"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Choose your model from the ",(0,t.jsx)(n.a,{href:"https://ollama.com/library",children:"Ollama library"}),"."]}),"\n",(0,t.jsx)(n.li,{children:"Run your model with this command:"}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-sh",children:"ollama run \n"})}),"\n",(0,t.jsxs)(n.ol,{start:"3",children:["\n",(0,t.jsxs)(n.li,{children:["According to the ",(0,t.jsx)(n.a,{href:"https://github.com/ollama/ollama/blob/main/docs/openai.md",children:"Ollama documentation on OpenAI compatibility"}),", you can connect to the Ollama server using the web address ",(0,t.jsx)(n.code,{children:"http://localhost:11434/v1/chat/completions"}),". To do this, change the ",(0,t.jsx)(n.code,{children:"openai.json"})," file in the ",(0,t.jsx)(n.code,{children:"~/jan/engines"})," folder to add the Ollama server's full web address:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "http://localhost:11434/v1/chat/completions"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Navigate to the ",(0,t.jsx)(n.code,{children:"~/jan/models"})," folder."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a folder named ",(0,t.jsx)(n.code,{children:"(ollam-modelname)"}),", for example, ",(0,t.jsx)(n.code,{children:"lmstudio-phi-2"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a ",(0,t.jsx)(n.code,{children:"model.json"})," file inside the folder including the following configurations:"]}),"\n"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"id"})," property to the model name as Ollama model name."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"format"})," property to ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"engine"})," property to ",(0,t.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"state"})," property to ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/llama2/model.json"',children:'{\n "sources": [\n {\n "filename": "llama2",\n "url": "https://ollama.com/library/llama2"\n }\n ],\n "id": "llama2",\n "object": "model",\n "name": "Ollama - Llama2",\n "version": "1.0",\n "description": "Llama 2 is a collection of foundation language models ranging from 7B to 70B parameters.",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Meta",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["For more details regarding the ",(0,t.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,t.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-start-the-model",children:"Step 3: Start the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click the ",(0,t.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,l)=>{l.d(n,{R:()=>i,x:()=>s});var t=l(96540);const a={},o=t.createContext(a);function i(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:i(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/85edfec6.a6232c92.js b/assets/js/85edfec6.a6232c92.js deleted file mode 100644 index 42a073c0..00000000 --- a/assets/js/85edfec6.a6232c92.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1837],{73365:(e,n,l)=>{l.r(n),l.d(n,{assets:()=>r,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>s,toc:()=>d});var t=l(74848),a=l(28453);const o={title:"Ollama",slug:"/guides/engines/ollama",sidebar_position:4,description:"A step-by-step guide on how to integrate Jan with Ollama.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Ollama integration"]},i=void 0,s={id:"guides/local-providers/ollama",title:"Ollama",description:"A step-by-step guide on how to integrate Jan with Ollama.",source:"@site/docs/guides/local-providers/ollama.mdx",sourceDirName:"guides/local-providers",slug:"/guides/engines/ollama",permalink:"/guides/engines/ollama",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/local-providers/ollama.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:4,frontMatter:{title:"Ollama",slug:"/guides/engines/ollama",sidebar_position:4,description:"A step-by-step guide on how to integrate Jan with Ollama.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Ollama integration"]},sidebar:"guidesSidebar",previous:{title:"LM Studio",permalink:"/guides/engines/lmstudio"},next:{title:"Remote Engines",permalink:"/guides/engines/remote"}},r={},d=[{value:"Integrate Ollama with Jan",id:"integrate-ollama-with-jan",level:2},{value:"Step 1: Start the Ollama Server",id:"step-1-start-the-ollama-server",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Start the Model",id:"step-3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,a.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"integrate-ollama-with-jan",children:"Integrate Ollama with Jan"}),"\n",(0,t.jsx)(n.p,{children:"Ollama provides you with largen language that you can run locally. There are two methods to integrate Ollama with Jan:"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Integrate Ollama server with Jan."}),"\n",(0,t.jsx)(n.li,{children:"Migrate the downloaded model from Ollama to Jan."}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"To integrate Ollama with Jan, follow the steps below:"}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["In this tutorial, we'll show how to integrate Ollama with Jan using the first method. We will use the ",(0,t.jsx)(n.a,{href:"https://ollama.com/library/llama2",children:"llama2"})," model as an example."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-1-start-the-ollama-server",children:"Step 1: Start the Ollama Server"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Choose your model from the ",(0,t.jsx)(n.a,{href:"https://ollama.com/library",children:"Ollama library"}),"."]}),"\n",(0,t.jsx)(n.li,{children:"Run your model with this command:"}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-sh",children:"ollama run \n"})}),"\n",(0,t.jsxs)(n.ol,{start:"3",children:["\n",(0,t.jsxs)(n.li,{children:["According to the ",(0,t.jsx)(n.a,{href:"https://github.com/ollama/ollama/blob/main/docs/openai.md",children:"Ollama documentation on OpenAI compatibility"}),", you can connect to the Ollama server using the web address ",(0,t.jsx)(n.code,{children:"http://localhost:11434/v1/chat/completions"}),". To do this, change the ",(0,t.jsx)(n.code,{children:"openai.json"})," file in the ",(0,t.jsx)(n.code,{children:"~/jan/engines"})," folder to add the Ollama server's full web address:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "http://localhost:11434/v1/chat/completions"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Navigate to the ",(0,t.jsx)(n.code,{children:"~/jan/models"})," folder."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a folder named ",(0,t.jsx)(n.code,{children:"(ollam-modelname)"}),", for example, ",(0,t.jsx)(n.code,{children:"lmstudio-phi-2"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a ",(0,t.jsx)(n.code,{children:"model.json"})," file inside the folder including the following configurations:"]}),"\n"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"id"})," property to the model name as Ollama model name."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"format"})," property to ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"engine"})," property to ",(0,t.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"state"})," property to ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/llama2/model.json"',children:'{\n "sources": [\n {\n "filename": "llama2",\n "url": "https://ollama.com/library/llama2"\n }\n ],\n "id": "llama2",\n "object": "model",\n "name": "Ollama - Llama2",\n "version": "1.0",\n "description": "Llama 2 is a collection of foundation language models ranging from 7B to 70B parameters.",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Meta",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["For more details regarding the ",(0,t.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,t.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-start-the-model",children:"Step 3: Start the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,t.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Locate your model and click the ",(0,t.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,l)=>{l.d(n,{R:()=>i,x:()=>s});var t=l(96540);const a={},o=t.createContext(a);function i(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:i(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/89a159d2.0b216225.js b/assets/js/89a159d2.0b216225.js deleted file mode 100644 index edd4ae1f..00000000 --- a/assets/js/89a159d2.0b216225.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4704],{71506:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>u,frontMatter:()=>t,metadata:()=>a,toc:()=>d});var i=r(74848),s=r(28453);const t={title:"Jan Enterprise",slug:"/enterprise",description:"Built for Enterprise Deployments",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o="Customize and run AI across your organization",a={id:"server-suite/enterprise",title:"Jan Enterprise",description:"Built for Enterprise Deployments",source:"@site/docs/server-suite/enterprise.md",sourceDirName:"server-suite",slug:"/enterprise",permalink:"/enterprise",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/enterprise.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan Enterprise",slug:"/enterprise",description:"Built for Enterprise Deployments",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},l={},d=[{value:"Own your AI. Own your data. Own your IP.",id:"own-your-ai-own-your-data-own-your-ip",level:2},{value:"Why Jan Enterprise",id:"why-jan-enterprise",level:2},{value:"Fast deployment",id:"fast-deployment",level:3},{value:"Full customization",id:"full-customization",level:3},{value:"Supported Extensions",id:"supported-extensions",level:2},{value:"Admin console",id:"admin-console",level:3},{value:"Identity access management",id:"identity-access-management",level:3},{value:"Audit compliance",id:"audit-compliance",level:3},{value:"Observability",id:"observability",level:3},{value:"Enterprise support SLA",id:"enterprise-support-sla",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h1:"h1",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h1,{id:"customize-and-run-ai-across-your-organization",children:"Customize and run AI across your organization"}),"\n",(0,i.jsx)(n.p,{children:"Jan can professional backend to create, customize and run AIs at scale, for production-grade data centers."}),"\n",(0,i.jsxs)(n.admonition,{type:"warning",children:[(0,i.jsxs)(n.p,{children:["The server suite is actively under development and lacking documentation.\nYou can find the source code ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/dev/server",children:"here"})," and ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/dev/docker-compose.yml",children:"here"}),"."]}),(0,i.jsx)(n.p,{children:"It is free to use. Your feedback is appreciated \ud83d\ude4f."})]}),"\n",(0,i.jsx)(n.h2,{id:"own-your-ai-own-your-data-own-your-ip",children:"Own your AI. Own your data. Own your IP."}),"\n",(0,i.jsx)(n.p,{children:"Over time, we expect more teams and organizations to turn to running their own AIs on-prem."}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Why?"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Prevent shadow data"}),"\n",(0,i.jsx)(n.li,{children:"Avoid vendor lock-in"}),"\n",(0,i.jsx)(n.li,{children:"Keep your IP in house"}),"\n",(0,i.jsx)(n.li,{children:"Uptime and support predictability"}),"\n",(0,i.jsx)(n.li,{children:"Eliminate monthly API bills - use your existing hardware"}),"\n",(0,i.jsx)(n.li,{children:"Full control over your AI - you can open it up and see what's going on"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"why-jan-enterprise",children:"Why Jan Enterprise"}),"\n",(0,i.jsx)(n.h3,{id:"fast-deployment",children:"Fast deployment"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"1 click deployment"}),". Immediately serve, customize, and scale models and assistants across your org. Scale your AI team so they can focus on the IP instead of fixing plumbing across every computer."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Scale across infrastructures"}),": on premise, with cloud providers, or as a hybrid deployment. Run Jan in completely air-gapped environments."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Optimized for datacenter-grade GPUs"}),": Can run on Nvidia, AMD Hardware, or even normal CPUs. Use TensorRT-LLM for more speedups on A6000s and above."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"full-customization",children:"Full customization"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Runs custom models or popular LLMs like Llama2, Mistral at production scale"}),"\n",(0,i.jsx)(n.li,{children:"API that is fully OpenAI-compatible, i.e. can be a drop-in migration"}),"\n",(0,i.jsx)(n.li,{children:"Powerful Agent framework to customize LLMs using RAG or Enterprise Data integrations."}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsxs)(n.p,{children:["Not a Jan fan but convinced about local AI? No worries, here's a list of ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/awesome-local-ai",children:"awesome local ai"})," alternatives that you can use in your team."]})}),"\n",(0,i.jsx)(n.h2,{id:"supported-extensions",children:"Supported Extensions"}),"\n",(0,i.jsx)(n.p,{children:"The SDK and current implemention accomodate the following potential extensions."}),"\n",(0,i.jsx)(n.h3,{id:"admin-console",children:"Admin console"}),"\n",(0,i.jsx)(n.p,{children:"Integrate SAML, OAUTH, OIDC"}),"\n",(0,i.jsx)(n.h3,{id:"identity-access-management",children:"Identity access management"}),"\n",(0,i.jsx)(n.p,{children:"Grant roles, groups and general ACL"}),"\n",(0,i.jsx)(n.h3,{id:"audit-compliance",children:"Audit compliance"}),"\n",(0,i.jsx)(n.p,{children:"Plug in Guardrails, LLMGuard, your custom rules engine and more"}),"\n",(0,i.jsx)(n.h3,{id:"observability",children:"Observability"}),"\n",(0,i.jsx)(n.p,{children:"Plug in Langfuse, Langsmith, Openllmetry and more"}),"\n",(0,i.jsx)(n.h2,{id:"enterprise-support-sla",children:"Enterprise support SLA"}),"\n",(0,i.jsx)(n.p,{children:"Our core team and AI solutions partners are to help."}),"\n",(0,i.jsxs)(n.p,{children:["Email us at: ",(0,i.jsx)(n.code,{children:"inquiries@jan.ai"})," for:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Priority case routing"}),"\n",(0,i.jsx)(n.li,{children:"Proactive case monitoring"}),"\n",(0,i.jsx)(n.li,{children:"24-hour support response"}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>a});var i=r(96540);const s={},t=i.createContext(s);function o(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/89a159d2.e009ef00.js b/assets/js/89a159d2.e009ef00.js new file mode 100644 index 00000000..1c4bff42 --- /dev/null +++ b/assets/js/89a159d2.e009ef00.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4704],{71506:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>u,frontMatter:()=>t,metadata:()=>a,toc:()=>d});var i=r(74848),s=r(28453);const t={title:"Jan Enterprise",slug:"/enterprise",description:"Built for Enterprise Deployments",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o="Customize and run AI across your organization",a={id:"server-suite/enterprise",title:"Jan Enterprise",description:"Built for Enterprise Deployments",source:"@site/docs/server-suite/enterprise.md",sourceDirName:"server-suite",slug:"/enterprise",permalink:"/enterprise",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/enterprise.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan Enterprise",slug:"/enterprise",description:"Built for Enterprise Deployments",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},l={},d=[{value:"Own your AI. Own your data. Own your IP.",id:"own-your-ai-own-your-data-own-your-ip",level:2},{value:"Why Jan Enterprise",id:"why-jan-enterprise",level:2},{value:"Fast deployment",id:"fast-deployment",level:3},{value:"Full customization",id:"full-customization",level:3},{value:"Supported Extensions",id:"supported-extensions",level:2},{value:"Admin console",id:"admin-console",level:3},{value:"Identity access management",id:"identity-access-management",level:3},{value:"Audit compliance",id:"audit-compliance",level:3},{value:"Observability",id:"observability",level:3},{value:"Enterprise support SLA",id:"enterprise-support-sla",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h1:"h1",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h1,{id:"customize-and-run-ai-across-your-organization",children:"Customize and run AI across your organization"}),"\n",(0,i.jsx)(n.p,{children:"Jan can professional backend to create, customize and run AIs at scale, for production-grade data centers."}),"\n",(0,i.jsxs)(n.admonition,{type:"warning",children:[(0,i.jsxs)(n.p,{children:["The server suite is actively under development and lacking documentation.\nYou can find the source code ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/dev/server",children:"here"})," and ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/dev/docker-compose.yml",children:"here"}),"."]}),(0,i.jsx)(n.p,{children:"It is free to use. Your feedback is appreciated \ud83d\ude4f."})]}),"\n",(0,i.jsx)(n.h2,{id:"own-your-ai-own-your-data-own-your-ip",children:"Own your AI. Own your data. Own your IP."}),"\n",(0,i.jsx)(n.p,{children:"Over time, we expect more teams and organizations to turn to running their own AIs on-prem."}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.strong,{children:"Why?"})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Prevent shadow data"}),"\n",(0,i.jsx)(n.li,{children:"Avoid vendor lock-in"}),"\n",(0,i.jsx)(n.li,{children:"Keep your IP in house"}),"\n",(0,i.jsx)(n.li,{children:"Uptime and support predictability"}),"\n",(0,i.jsx)(n.li,{children:"Eliminate monthly API bills - use your existing hardware"}),"\n",(0,i.jsx)(n.li,{children:"Full control over your AI - you can open it up and see what's going on"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"why-jan-enterprise",children:"Why Jan Enterprise"}),"\n",(0,i.jsx)(n.h3,{id:"fast-deployment",children:"Fast deployment"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"1 click deployment"}),". Immediately serve, customize, and scale models and assistants across your org. Scale your AI team so they can focus on the IP instead of fixing plumbing across every computer."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Scale across infrastructures"}),": on premise, with cloud providers, or as a hybrid deployment. Run Jan in completely air-gapped environments."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Optimized for datacenter-grade GPUs"}),": Can run on Nvidia, AMD Hardware, or even normal CPUs. Use TensorRT-LLM for more speedups on A6000s and above."]}),"\n"]}),"\n",(0,i.jsx)(n.h3,{id:"full-customization",children:"Full customization"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Runs custom models or popular LLMs like Llama2, Mistral at production scale"}),"\n",(0,i.jsx)(n.li,{children:"API that is fully OpenAI-compatible, i.e. can be a drop-in migration"}),"\n",(0,i.jsx)(n.li,{children:"Powerful Agent framework to customize LLMs using RAG or Enterprise Data integrations."}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsxs)(n.p,{children:["Not a Jan fan but convinced about local AI? No worries, here's a list of ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/awesome-local-ai",children:"awesome local ai"})," alternatives that you can use in your team."]})}),"\n",(0,i.jsx)(n.h2,{id:"supported-extensions",children:"Supported Extensions"}),"\n",(0,i.jsx)(n.p,{children:"The SDK and current implemention accomodate the following potential extensions."}),"\n",(0,i.jsx)(n.h3,{id:"admin-console",children:"Admin console"}),"\n",(0,i.jsx)(n.p,{children:"Integrate SAML, OAUTH, OIDC"}),"\n",(0,i.jsx)(n.h3,{id:"identity-access-management",children:"Identity access management"}),"\n",(0,i.jsx)(n.p,{children:"Grant roles, groups and general ACL"}),"\n",(0,i.jsx)(n.h3,{id:"audit-compliance",children:"Audit compliance"}),"\n",(0,i.jsx)(n.p,{children:"Plug in Guardrails, LLMGuard, your custom rules engine and more"}),"\n",(0,i.jsx)(n.h3,{id:"observability",children:"Observability"}),"\n",(0,i.jsx)(n.p,{children:"Plug in Langfuse, Langsmith, Openllmetry and more"}),"\n",(0,i.jsx)(n.h2,{id:"enterprise-support-sla",children:"Enterprise support SLA"}),"\n",(0,i.jsx)(n.p,{children:"Our core team and AI solutions partners are to help."}),"\n",(0,i.jsxs)(n.p,{children:["Email us at: ",(0,i.jsx)(n.code,{children:"inquiries@jan.ai"})," for:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Priority case routing"}),"\n",(0,i.jsx)(n.li,{children:"Proactive case monitoring"}),"\n",(0,i.jsx)(n.li,{children:"24-hour support response"}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>a});var i=r(96540);const s={},t=i.createContext(s);function o(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8abcec24.65440ce3.js b/assets/js/8abcec24.65440ce3.js deleted file mode 100644 index 6eb6dd16..00000000 --- a/assets/js/8abcec24.65440ce3.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2969],{89352:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>s,default:()=>c,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var o=t(74848),a=t(28453);const i={title:"Frequently Asked Questions (FAQ) - Jan"},s="Frequently Asked Questions (FAQ)",r={id:"about/faq",title:"Frequently Asked Questions (FAQ) - Jan",description:"What is Jan?",source:"@site/docs/about/faq.md",sourceDirName:"about",slug:"/about/faq",permalink:"/about/faq",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/faq.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Frequently Asked Questions (FAQ) - Jan"},sidebar:"aboutSidebar",previous:{title:"Acknowledgements",permalink:"/acknowledgements"}},d={},l=[{value:"What is Jan?",id:"what-is-jan",level:2},{value:"How do I use Jan?",id:"how-do-i-use-jan",level:2},{value:"Is Jan compatible with my operating system?",id:"is-jan-compatible-with-my-operating-system",level:2},{value:"Do you use my data?",id:"do-you-use-my-data",level:2},{value:"Do you sell my data?",id:"do-you-sell-my-data",level:2},{value:"How does Jan ensure my data remains private?",id:"how-does-jan-ensure-my-data-remains-private",level:2},{value:"What does "Jan" stand for?",id:"what-does-jan-stand-for",level:2},{value:"Can I use Jan without an internet connection?",id:"can-i-use-jan-without-an-internet-connection",level:2},{value:"Are there any costs associated with using Jan?",id:"are-there-any-costs-associated-with-using-jan",level:2},{value:"What types of AI models can I download or import with Jan?",id:"what-types-of-ai-models-can-i-download-or-import-with-jan",level:2},{value:"How do I customize Jan using the programmable API?",id:"how-do-i-customize-jan-using-the-programmable-api",level:2},{value:"How can I contribute to Jan's development or suggest features?",id:"how-can-i-contribute-to-jans-development-or-suggest-features",level:2},{value:"How can I get involved with the Jan community?",id:"how-can-i-get-involved-with-the-jan-community",level:2},{value:"How do I troubleshoot issues with installing or using Jan?",id:"how-do-i-troubleshoot-issues-with-installing-or-using-jan",level:2},{value:"Can I self-host?",id:"can-i-self-host",level:2},{value:"Are you hiring?",id:"are-you-hiring",level:2}];function u(e){const n={a:"a",admonition:"admonition",code:"code",h1:"h1",h2:"h2",p:"p",...(0,a.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.h1,{id:"frequently-asked-questions-faq",children:"Frequently Asked Questions (FAQ)"}),"\n",(0,o.jsx)(n.h2,{id:"what-is-jan",children:"What is Jan?"}),"\n",(0,o.jsx)(n.p,{children:"Jan runs and trains models (LLMs) on your laptop or desktop computers."}),"\n",(0,o.jsx)(n.h2,{id:"how-do-i-use-jan",children:"How do I use Jan?"}),"\n",(0,o.jsx)(n.p,{children:"Download Jan Desktop on your computer, download a compatible LLM, or connect to a remote AI with the API key, and just start chatting. You can switch between models as needed."}),"\n",(0,o.jsx)(n.h2,{id:"is-jan-compatible-with-my-operating-system",children:"Is Jan compatible with my operating system?"}),"\n",(0,o.jsx)(n.p,{children:"Jan is available for Mac, Windows, and Linux, and via Docker/Helm ensuring wide compatibility."}),"\n",(0,o.jsx)(n.p,{children:"GPU wise, Jan supports Nvidia, AMD (through Vulkan), and Intel."}),"\n",(0,o.jsx)(n.h2,{id:"do-you-use-my-data",children:"Do you use my data?"}),"\n",(0,o.jsx)(n.p,{children:"No. Not even a little. Your usage data is fully local, private, and never leaves your computer."}),"\n",(0,o.jsx)(n.p,{children:"We also don't track IP or other identifying information."}),"\n",(0,o.jsx)(n.admonition,{type:"caution",children:(0,o.jsx)(n.p,{children:"If you use Jan in remote/api mode, ie. chatting with ChatGPT, they may still collect your info."})}),"\n",(0,o.jsx)(n.h2,{id:"do-you-sell-my-data",children:"Do you sell my data?"}),"\n",(0,o.jsx)(n.p,{children:"No, and we never will."}),"\n",(0,o.jsx)(n.h2,{id:"how-does-jan-ensure-my-data-remains-private",children:"How does Jan ensure my data remains private?"}),"\n",(0,o.jsxs)(n.p,{children:["Jan prioritizes your privacy by running open-source AI models 100% offline on your computer. Conversations, documents, and files stay private. You can find your own user data at ",(0,o.jsx)(n.code,{children:"~/jan"})," on your local filesystem."]}),"\n",(0,o.jsx)(n.h2,{id:"what-does-jan-stand-for",children:'What does "Jan" stand for?'}),"\n",(0,o.jsx)(n.p,{children:'Jan stands for \u201cJust a Name". We are, admittedly, bad at marketing \ud83d\ude02.'}),"\n",(0,o.jsx)(n.h2,{id:"can-i-use-jan-without-an-internet-connection",children:"Can I use Jan without an internet connection?"}),"\n",(0,o.jsx)(n.p,{children:"Yes, Jan defaults to running locally, without an internet connection."}),"\n",(0,o.jsx)(n.h2,{id:"are-there-any-costs-associated-with-using-jan",children:"Are there any costs associated with using Jan?"}),"\n",(0,o.jsx)(n.p,{children:"Jan is free to use. However, if you want to connect to remote APIs, like GPT-4, you will need to put in your own API key."}),"\n",(0,o.jsx)(n.h2,{id:"what-types-of-ai-models-can-i-download-or-import-with-jan",children:"What types of AI models can I download or import with Jan?"}),"\n",(0,o.jsx)(n.p,{children:"You can download popular AI models through Jan's Hub or import any model of your choice directly from HuggingFace."}),"\n",(0,o.jsx)(n.h2,{id:"how-do-i-customize-jan-using-the-programmable-api",children:"How do I customize Jan using the programmable API?"}),"\n",(0,o.jsx)(n.p,{children:"Jan is built like VSCode and Obsidian. It supports 3rd party extensions. In fact, most of the UI level features were built with extensions in a few lines of code."}),"\n",(0,o.jsx)(n.h2,{id:"how-can-i-contribute-to-jans-development-or-suggest-features",children:"How can I contribute to Jan's development or suggest features?"}),"\n",(0,o.jsxs)(n.p,{children:["Contributions can be made through ",(0,o.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"GitHub"})," and ",(0,o.jsx)(n.a,{href:"https://discord.gg/Exe46xPMbK",children:"Discord"}),", where you can also suggest features and make pull requests. No need to ask for permission, we're fully open source!"]}),"\n",(0,o.jsx)(n.h2,{id:"how-can-i-get-involved-with-the-jan-community",children:"How can I get involved with the Jan community?"}),"\n",(0,o.jsxs)(n.p,{children:["Joining ",(0,o.jsx)(n.a,{href:"https://discord.gg/qSwXFx6Krr",children:"Jan's Discord server"})," is a great way to get involved with the community."]}),"\n",(0,o.jsx)(n.h2,{id:"how-do-i-troubleshoot-issues-with-installing-or-using-jan",children:"How do I troubleshoot issues with installing or using Jan?"}),"\n",(0,o.jsx)(n.p,{children:"For troubleshooting, you should reach out on Discord and check GitHub for assistance and support from the community and the development team."}),"\n",(0,o.jsx)(n.h2,{id:"can-i-self-host",children:"Can I self-host?"}),"\n",(0,o.jsx)(n.p,{children:"Yes! We love the self-hosted movement. Jan is available as a Helm chart/ Docker composes which can be run across home servers or even production-level environments."}),"\n",(0,o.jsx)(n.h2,{id:"are-you-hiring",children:"Are you hiring?"}),"\n",(0,o.jsxs)(n.p,{children:["We often hire directly from our community. If you are interested in applying, please see our careers page ",(0,o.jsx)(n.a,{href:"https://janai.bamboohr.com/careers",children:"here"}),"."]})]})}function c(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(u,{...e})}):u(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>r});var o=t(96540);const a={},i=o.createContext(a);function s(e){const n=o.useContext(i);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),o.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8abcec24.9b2f77be.js b/assets/js/8abcec24.9b2f77be.js new file mode 100644 index 00000000..4a6fbb62 --- /dev/null +++ b/assets/js/8abcec24.9b2f77be.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2969],{89352:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>d,contentTitle:()=>s,default:()=>c,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var o=t(74848),a=t(28453);const i={title:"Frequently Asked Questions (FAQ) - Jan"},s="Frequently Asked Questions (FAQ)",r={id:"about/faq",title:"Frequently Asked Questions (FAQ) - Jan",description:"What is Jan?",source:"@site/docs/about/faq.md",sourceDirName:"about",slug:"/about/faq",permalink:"/about/faq",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/faq.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Frequently Asked Questions (FAQ) - Jan"},sidebar:"aboutSidebar",previous:{title:"Acknowledgements",permalink:"/acknowledgements"}},d={},l=[{value:"What is Jan?",id:"what-is-jan",level:2},{value:"How do I use Jan?",id:"how-do-i-use-jan",level:2},{value:"Is Jan compatible with my operating system?",id:"is-jan-compatible-with-my-operating-system",level:2},{value:"Do you use my data?",id:"do-you-use-my-data",level:2},{value:"Do you sell my data?",id:"do-you-sell-my-data",level:2},{value:"How does Jan ensure my data remains private?",id:"how-does-jan-ensure-my-data-remains-private",level:2},{value:"What does "Jan" stand for?",id:"what-does-jan-stand-for",level:2},{value:"Can I use Jan without an internet connection?",id:"can-i-use-jan-without-an-internet-connection",level:2},{value:"Are there any costs associated with using Jan?",id:"are-there-any-costs-associated-with-using-jan",level:2},{value:"What types of AI models can I download or import with Jan?",id:"what-types-of-ai-models-can-i-download-or-import-with-jan",level:2},{value:"How do I customize Jan using the programmable API?",id:"how-do-i-customize-jan-using-the-programmable-api",level:2},{value:"How can I contribute to Jan's development or suggest features?",id:"how-can-i-contribute-to-jans-development-or-suggest-features",level:2},{value:"How can I get involved with the Jan community?",id:"how-can-i-get-involved-with-the-jan-community",level:2},{value:"How do I troubleshoot issues with installing or using Jan?",id:"how-do-i-troubleshoot-issues-with-installing-or-using-jan",level:2},{value:"Can I self-host?",id:"can-i-self-host",level:2},{value:"Are you hiring?",id:"are-you-hiring",level:2}];function u(e){const n={a:"a",admonition:"admonition",code:"code",h1:"h1",h2:"h2",p:"p",...(0,a.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.h1,{id:"frequently-asked-questions-faq",children:"Frequently Asked Questions (FAQ)"}),"\n",(0,o.jsx)(n.h2,{id:"what-is-jan",children:"What is Jan?"}),"\n",(0,o.jsx)(n.p,{children:"Jan runs and trains models (LLMs) on your laptop or desktop computers."}),"\n",(0,o.jsx)(n.h2,{id:"how-do-i-use-jan",children:"How do I use Jan?"}),"\n",(0,o.jsx)(n.p,{children:"Download Jan Desktop on your computer, download a compatible LLM, or connect to a remote AI with the API key, and just start chatting. You can switch between models as needed."}),"\n",(0,o.jsx)(n.h2,{id:"is-jan-compatible-with-my-operating-system",children:"Is Jan compatible with my operating system?"}),"\n",(0,o.jsx)(n.p,{children:"Jan is available for Mac, Windows, and Linux, and via Docker/Helm ensuring wide compatibility."}),"\n",(0,o.jsx)(n.p,{children:"GPU wise, Jan supports Nvidia, AMD (through Vulkan), and Intel."}),"\n",(0,o.jsx)(n.h2,{id:"do-you-use-my-data",children:"Do you use my data?"}),"\n",(0,o.jsx)(n.p,{children:"No. Not even a little. Your usage data is fully local, private, and never leaves your computer."}),"\n",(0,o.jsx)(n.p,{children:"We also don't track IP or other identifying information."}),"\n",(0,o.jsx)(n.admonition,{type:"caution",children:(0,o.jsx)(n.p,{children:"If you use Jan in remote/api mode, ie. chatting with ChatGPT, they may still collect your info."})}),"\n",(0,o.jsx)(n.h2,{id:"do-you-sell-my-data",children:"Do you sell my data?"}),"\n",(0,o.jsx)(n.p,{children:"No, and we never will."}),"\n",(0,o.jsx)(n.h2,{id:"how-does-jan-ensure-my-data-remains-private",children:"How does Jan ensure my data remains private?"}),"\n",(0,o.jsxs)(n.p,{children:["Jan prioritizes your privacy by running open-source AI models 100% offline on your computer. Conversations, documents, and files stay private. You can find your own user data at ",(0,o.jsx)(n.code,{children:"~/jan"})," on your local filesystem."]}),"\n",(0,o.jsx)(n.h2,{id:"what-does-jan-stand-for",children:'What does "Jan" stand for?'}),"\n",(0,o.jsx)(n.p,{children:'Jan stands for \u201cJust a Name". We are, admittedly, bad at marketing \ud83d\ude02.'}),"\n",(0,o.jsx)(n.h2,{id:"can-i-use-jan-without-an-internet-connection",children:"Can I use Jan without an internet connection?"}),"\n",(0,o.jsx)(n.p,{children:"Yes, Jan defaults to running locally, without an internet connection."}),"\n",(0,o.jsx)(n.h2,{id:"are-there-any-costs-associated-with-using-jan",children:"Are there any costs associated with using Jan?"}),"\n",(0,o.jsx)(n.p,{children:"Jan is free to use. However, if you want to connect to remote APIs, like GPT-4, you will need to put in your own API key."}),"\n",(0,o.jsx)(n.h2,{id:"what-types-of-ai-models-can-i-download-or-import-with-jan",children:"What types of AI models can I download or import with Jan?"}),"\n",(0,o.jsx)(n.p,{children:"You can download popular AI models through Jan's Hub or import any model of your choice directly from HuggingFace."}),"\n",(0,o.jsx)(n.h2,{id:"how-do-i-customize-jan-using-the-programmable-api",children:"How do I customize Jan using the programmable API?"}),"\n",(0,o.jsx)(n.p,{children:"Jan is built like VSCode and Obsidian. It supports 3rd party extensions. In fact, most of the UI level features were built with extensions in a few lines of code."}),"\n",(0,o.jsx)(n.h2,{id:"how-can-i-contribute-to-jans-development-or-suggest-features",children:"How can I contribute to Jan's development or suggest features?"}),"\n",(0,o.jsxs)(n.p,{children:["Contributions can be made through ",(0,o.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"GitHub"})," and ",(0,o.jsx)(n.a,{href:"https://discord.gg/Exe46xPMbK",children:"Discord"}),", where you can also suggest features and make pull requests. No need to ask for permission, we're fully open source!"]}),"\n",(0,o.jsx)(n.h2,{id:"how-can-i-get-involved-with-the-jan-community",children:"How can I get involved with the Jan community?"}),"\n",(0,o.jsxs)(n.p,{children:["Joining ",(0,o.jsx)(n.a,{href:"https://discord.gg/qSwXFx6Krr",children:"Jan's Discord server"})," is a great way to get involved with the community."]}),"\n",(0,o.jsx)(n.h2,{id:"how-do-i-troubleshoot-issues-with-installing-or-using-jan",children:"How do I troubleshoot issues with installing or using Jan?"}),"\n",(0,o.jsx)(n.p,{children:"For troubleshooting, you should reach out on Discord and check GitHub for assistance and support from the community and the development team."}),"\n",(0,o.jsx)(n.h2,{id:"can-i-self-host",children:"Can I self-host?"}),"\n",(0,o.jsx)(n.p,{children:"Yes! We love the self-hosted movement. Jan is available as a Helm chart/ Docker composes which can be run across home servers or even production-level environments."}),"\n",(0,o.jsx)(n.h2,{id:"are-you-hiring",children:"Are you hiring?"}),"\n",(0,o.jsxs)(n.p,{children:["We often hire directly from our community. If you are interested in applying, please see our careers page ",(0,o.jsx)(n.a,{href:"https://janai.bamboohr.com/careers",children:"here"}),"."]})]})}function c(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(u,{...e})}):u(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>r});var o=t(96540);const a={},i=o.createContext(a);function s(e){const n=o.useContext(i);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),o.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8af60830.3a50eac1.js b/assets/js/8af60830.3a50eac1.js new file mode 100644 index 00000000..a16be775 --- /dev/null +++ b/assets/js/8af60830.3a50eac1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7719],{60865:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>h,frontMatter:()=>t,metadata:()=>a,toc:()=>d});var s=o(74848),r=o(28453);const t={title:"Jan Desktop",slug:"/desktop",description:"Turn your computer into an AI PC",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i="Turn any computer into an AI computer",a={id:"platforms/desktop",title:"Jan Desktop",description:"Turn your computer into an AI PC",source:"@site/docs/platforms/desktop.md",sourceDirName:"platforms",slug:"/desktop",permalink:"/desktop",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/platforms/desktop.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan Desktop",slug:"/desktop",description:"Turn your computer into an AI PC",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"productSidebar",next:{title:"Jan Home Server",permalink:"/home-server"}},l={},d=[{value:"Designed for Everyone",id:"designed-for-everyone",level:3},{value:"Private & Offline",id:"private--offline",level:3},{value:"Customizable AI",id:"customizable-ai",level:3},{value:"Jan Desktop is",id:"jan-desktop-is",level:2},{value:"For Developers",id:"for-developers",level:3},{value:"For Your Home Server",id:"for-your-home-server",level:3},{value:"For People who Tinker",id:"for-people-who-tinker",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h1:"h1",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"turn-any-computer-into-an-ai-computer",children:"Turn any computer into an AI computer"}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Alt text",src:o(26612).A+"",width:"2390",height:"782"})}),"\n",(0,s.jsx)(n.h3,{id:"designed-for-everyone",children:"Designed for Everyone"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Installs with 1 click."})," Jan is easy to use, beautiful, and the core features are free forever."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Runs on consumer laptops."})," Tested by 250k+ users across ",(0,s.jsx)(n.code,{children:"Windows, Mac, and Linux"}),", Jan even works on ",(0,s.jsx)(n.code,{children:"CPU-only mode"}),"."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Automatic GPU acceleration"}),". Models responds faster across ",(0,s.jsx)(n.code,{children:"NVIDIA, AMD, Apple, and Intel"})," when benchmarked against industry alternatives."]}),"\n"]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsx)(n.p,{children:"\u201cNormies\u201d can run LLMs like an AI engineer on the Desktop App - no programming experience needed."})}),"\n",(0,s.jsx)(n.h3,{id:"private--offline",children:"Private & Offline"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Runs 100% locally"}),". AI models run directly on your laptop without an internet connection. ",(0,s.jsx)(n.code,{children:"You own your AI"}),"."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Private conversations."})," Data is saved on your own filesystem in a transparent non-proprietary data format. ",(0,s.jsx)(n.code,{children:"You own your data."})]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Open source security"}),". Jan is open source, so you can scruntinize every line in our codebase. So when we say your data is not our product, we mean it. See ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"the code"})," and our ",(0,s.jsx)(n.a,{href:"/how-we-work/analytics",children:"data policy"}),"."]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"customizable-ai",children:"Customizable AI"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Use AI without limitations."})," Take control of censorship levels. Jan is usable from the classroom to the boardroom (and few other rooms if that\u2019s your jam)."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Use any models"}),". Download open source models from HuggingFace or upload your own custom models. [link]"]}),"\n"]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsxs)(n.p,{children:["Download Jan Desktop Client ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan?tab=readme-ov-file#download",children:"here"}),"."]})}),"\n",(0,s.jsx)(n.h2,{id:"jan-desktop-is",children:"Jan Desktop is"}),"\n",(0,s.jsx)(n.h3,{id:"for-developers",children:"For Developers"}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"You can easily integrate a locally running LLM into your own projects."})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Turn on ",(0,s.jsx)(n.code,{children:"Local API Server"})," mode to start building on an ",(0,s.jsx)(n.code,{children:"OpenAI compatible API"}),"."]}),"\n",(0,s.jsx)(n.li,{children:"Jan Desktop comes with a Developer Console out of the box."}),"\n",(0,s.jsx)(n.li,{children:"The UI makes it easy to see logs, configure models and more."}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Alt text",src:o(89962).A+"",width:"2388",height:"1148"})}),"\n",(0,s.jsx)(n.h3,{id:"for-your-home-server",children:"For Your Home Server"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Use Jan as a UI only, pointing to a different backend. ",(0,s.jsx)(n.a,{href:"/guides/using-models/integrate-with-remote-server",children:"See Docs"})]}),"\n",(0,s.jsxs)(n.li,{children:["Use Jan as a backend only, pointing to a different frontend. ",(0,s.jsx)(n.a,{href:"/guides/using-models/integrate-with-remote-server",children:"See Docs"})]}),"\n",(0,s.jsxs)(n.li,{children:["Run Jan in team-mode on production-grade GPUs. ",(0,s.jsx)(n.a,{href:"/server-suite",children:"See Server Suite"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-people-who-tinker",children:"For People who Tinker"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Customize the app\u2019s look and feel though Themes."}),"\n",(0,s.jsxs)(n.li,{children:["Customize assistants, models and other features with ",(0,s.jsx)(n.strong,{children:"no code"}),"."]}),"\n",(0,s.jsx)(n.li,{children:"Customize the entire Application through Extensions. Inspired by VSCode extensions, the desktop app can be entirely customized."}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/extensions",children:"See the default extensions"})," bundled with every Desktop install.\n",(0,s.jsx)(n.img,{alt:"Alt text",src:o(32055).A+"",width:"2392",height:"1112"})]})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},89962:(e,n,o)=>{o.d(n,{A:()=>s});const s=o.p+"assets/images/image-1-9ef206a8d9596dc4305a953c805ee399.png"},32055:(e,n,o)=>{o.d(n,{A:()=>s});const s=o.p+"assets/images/image-4-c17fc8aeb7f61323be4c7f3bea106f0f.png"},26612:(e,n,o)=>{o.d(n,{A:()=>s});const s=o.p+"assets/images/image-8b62745016147166b887fe954a8546fd.png"},28453:(e,n,o)=>{o.d(n,{R:()=>i,x:()=>a});var s=o(96540);const r={},t=s.createContext(r);function i(e){const n=s.useContext(t);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),s.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8af60830.a202f609.js b/assets/js/8af60830.a202f609.js deleted file mode 100644 index 11f43787..00000000 --- a/assets/js/8af60830.a202f609.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7719],{60865:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>h,frontMatter:()=>t,metadata:()=>a,toc:()=>d});var s=o(74848),r=o(28453);const t={title:"Jan Desktop",slug:"/desktop",description:"Turn your computer into an AI PC",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i="Turn any computer into an AI computer",a={id:"platforms/desktop",title:"Jan Desktop",description:"Turn your computer into an AI PC",source:"@site/docs/platforms/desktop.md",sourceDirName:"platforms",slug:"/desktop",permalink:"/desktop",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/platforms/desktop.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan Desktop",slug:"/desktop",description:"Turn your computer into an AI PC",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"productSidebar",next:{title:"Jan Home Server",permalink:"/home-server"}},l={},d=[{value:"Designed for Everyone",id:"designed-for-everyone",level:3},{value:"Private & Offline",id:"private--offline",level:3},{value:"Customizable AI",id:"customizable-ai",level:3},{value:"Jan Desktop is",id:"jan-desktop-is",level:2},{value:"For Developers",id:"for-developers",level:3},{value:"For Your Home Server",id:"for-your-home-server",level:3},{value:"For People who Tinker",id:"for-people-who-tinker",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h1:"h1",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"turn-any-computer-into-an-ai-computer",children:"Turn any computer into an AI computer"}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Alt text",src:o(26612).A+"",width:"2390",height:"782"})}),"\n",(0,s.jsx)(n.h3,{id:"designed-for-everyone",children:"Designed for Everyone"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Installs with 1 click."})," Jan is easy to use, beautiful, and the core features are free forever."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Runs on consumer laptops."})," Tested by 250k+ users across ",(0,s.jsx)(n.code,{children:"Windows, Mac, and Linux"}),", Jan even works on ",(0,s.jsx)(n.code,{children:"CPU-only mode"}),"."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Automatic GPU acceleration"}),". Models responds faster across ",(0,s.jsx)(n.code,{children:"NVIDIA, AMD, Apple, and Intel"})," when benchmarked against industry alternatives."]}),"\n"]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsx)(n.p,{children:"\u201cNormies\u201d can run LLMs like an AI engineer on the Desktop App - no programming experience needed."})}),"\n",(0,s.jsx)(n.h3,{id:"private--offline",children:"Private & Offline"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Runs 100% locally"}),". AI models run directly on your laptop without an internet connection. ",(0,s.jsx)(n.code,{children:"You own your AI"}),"."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Private conversations."})," Data is saved on your own filesystem in a transparent non-proprietary data format. ",(0,s.jsx)(n.code,{children:"You own your data."})]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Open source security"}),". Jan is open source, so you can scruntinize every line in our codebase. So when we say your data is not our product, we mean it. See ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"the code"})," and our ",(0,s.jsx)(n.a,{href:"/how-we-work/analytics",children:"data policy"}),"."]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"customizable-ai",children:"Customizable AI"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Use AI without limitations."})," Take control of censorship levels. Jan is usable from the classroom to the boardroom (and few other rooms if that\u2019s your jam)."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Use any models"}),". Download open source models from HuggingFace or upload your own custom models. [link]"]}),"\n"]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsxs)(n.p,{children:["Download Jan Desktop Client ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan?tab=readme-ov-file#download",children:"here"}),"."]})}),"\n",(0,s.jsx)(n.h2,{id:"jan-desktop-is",children:"Jan Desktop is"}),"\n",(0,s.jsx)(n.h3,{id:"for-developers",children:"For Developers"}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.strong,{children:"You can easily integrate a locally running LLM into your own projects."})}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Turn on ",(0,s.jsx)(n.code,{children:"Local API Server"})," mode to start building on an ",(0,s.jsx)(n.code,{children:"OpenAI compatible API"}),"."]}),"\n",(0,s.jsx)(n.li,{children:"Jan Desktop comes with a Developer Console out of the box."}),"\n",(0,s.jsx)(n.li,{children:"The UI makes it easy to see logs, configure models and more."}),"\n"]}),"\n",(0,s.jsx)(n.p,{children:(0,s.jsx)(n.img,{alt:"Alt text",src:o(89962).A+"",width:"2388",height:"1148"})}),"\n",(0,s.jsx)(n.h3,{id:"for-your-home-server",children:"For Your Home Server"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Use Jan as a UI only, pointing to a different backend. ",(0,s.jsx)(n.a,{href:"/guides/using-models/integrate-with-remote-server",children:"See Docs"})]}),"\n",(0,s.jsxs)(n.li,{children:["Use Jan as a backend only, pointing to a different frontend. ",(0,s.jsx)(n.a,{href:"/guides/using-models/integrate-with-remote-server",children:"See Docs"})]}),"\n",(0,s.jsxs)(n.li,{children:["Run Jan in team-mode on production-grade GPUs. ",(0,s.jsx)(n.a,{href:"/server-suite",children:"See Server Suite"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"for-people-who-tinker",children:"For People who Tinker"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Customize the app\u2019s look and feel though Themes."}),"\n",(0,s.jsxs)(n.li,{children:["Customize assistants, models and other features with ",(0,s.jsx)(n.strong,{children:"no code"}),"."]}),"\n",(0,s.jsx)(n.li,{children:"Customize the entire Application through Extensions. Inspired by VSCode extensions, the desktop app can be entirely customized."}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/tree/main/extensions",children:"See the default extensions"})," bundled with every Desktop install.\n",(0,s.jsx)(n.img,{alt:"Alt text",src:o(32055).A+"",width:"2392",height:"1112"})]})]})}function h(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},89962:(e,n,o)=>{o.d(n,{A:()=>s});const s=o.p+"assets/images/image-1-9ef206a8d9596dc4305a953c805ee399.png"},32055:(e,n,o)=>{o.d(n,{A:()=>s});const s=o.p+"assets/images/image-4-c17fc8aeb7f61323be4c7f3bea106f0f.png"},26612:(e,n,o)=>{o.d(n,{A:()=>s});const s=o.p+"assets/images/image-8b62745016147166b887fe954a8546fd.png"},28453:(e,n,o)=>{o.d(n,{R:()=>i,x:()=>a});var s=o(96540);const r={},t=s.createContext(r);function i(e){const n=s.useContext(t);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),s.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8c922572.4d58cdd1.js b/assets/js/8c922572.4d58cdd1.js new file mode 100644 index 00000000..d80345a8 --- /dev/null +++ b/assets/js/8c922572.4d58cdd1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1345],{8797:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>u,contentTitle:()=>o,default:()=>f,frontMatter:()=>s,metadata:()=>c,toc:()=>i});var a=r(74848),n=r(28453);const s={title:"Data Security"},o=void 0,c={id:"features/data-security",title:"Data Security",description:"",source:"@site/docs/features/data-security.md",sourceDirName:"features",slug:"/features/data-security",permalink:"/features/data-security",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/data-security.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Data Security"},sidebar:"productSidebar",previous:{title:"Agents Framework",permalink:"/features/agents-framework"}},u={},i=[];function d(t){return(0,a.jsx)(a.Fragment,{})}function f(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,a.jsx)(e,{...t,children:(0,a.jsx)(d,{...t})}):d()}},28453:(t,e,r)=>{r.d(e,{R:()=>o,x:()=>c});var a=r(96540);const n={},s=a.createContext(n);function o(t){const e=a.useContext(s);return a.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:o(t.components),a.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/8c922572.ec84bbf0.js b/assets/js/8c922572.ec84bbf0.js deleted file mode 100644 index 4c8a3b89..00000000 --- a/assets/js/8c922572.ec84bbf0.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1345],{8797:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>u,contentTitle:()=>o,default:()=>f,frontMatter:()=>s,metadata:()=>c,toc:()=>i});var a=r(74848),n=r(28453);const s={title:"Data Security"},o=void 0,c={id:"features/data-security",title:"Data Security",description:"",source:"@site/docs/features/data-security.md",sourceDirName:"features",slug:"/features/data-security",permalink:"/features/data-security",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/data-security.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Data Security"},sidebar:"productSidebar",previous:{title:"Agents Framework",permalink:"/features/agents-framework"}},u={},i=[];function d(t){return(0,a.jsx)(a.Fragment,{})}function f(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,a.jsx)(e,{...t,children:(0,a.jsx)(d,{...t})}):d()}},28453:(t,e,r)=>{r.d(e,{R:()=>o,x:()=>c});var a=r(96540);const n={},s=a.createContext(n);function o(t){const e=a.useContext(s);return a.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:o(t.components),a.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/8d91959a.3d73ffb2.js b/assets/js/8d91959a.3d73ffb2.js new file mode 100644 index 00000000..702789f1 --- /dev/null +++ b/assets/js/8d91959a.3d73ffb2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6977],{92980:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>p,contentTitle:()=>s,default:()=>i,frontMatter:()=>c,metadata:()=>a,toc:()=>d});var n=r(74848),o=r(28453);const c={title:"Power Supply"},s=void 0,a={id:"hardware/concepts/power",title:"Power Supply",description:"",source:"@site/docs/hardware/concepts/power.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/power",permalink:"/hardware/concepts/power",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/power.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Power Supply"}},p={},d=[];function u(e){return(0,n.jsx)(n.Fragment,{})}function i(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(u,{...e})}):u()}},28453:(e,t,r)=>{r.d(t,{R:()=>s,x:()=>a});var n=r(96540);const o={},c=n.createContext(o);function s(e){const t=n.useContext(c);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),n.createElement(c.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8d91959a.7cd228e1.js b/assets/js/8d91959a.7cd228e1.js deleted file mode 100644 index e0c36bee..00000000 --- a/assets/js/8d91959a.7cd228e1.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6977],{92980:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>p,contentTitle:()=>s,default:()=>i,frontMatter:()=>c,metadata:()=>a,toc:()=>d});var n=r(74848),o=r(28453);const c={title:"Power Supply"},s=void 0,a={id:"hardware/concepts/power",title:"Power Supply",description:"",source:"@site/docs/hardware/concepts/power.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/power",permalink:"/hardware/concepts/power",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/power.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Power Supply"}},p={},d=[];function u(e){return(0,n.jsx)(n.Fragment,{})}function i(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(u,{...e})}):u()}},28453:(e,t,r)=>{r.d(t,{R:()=>s,x:()=>a});var n=r(96540);const o={},c=n.createContext(o);function s(e){const t=n.useContext(c);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),n.createElement(c.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8edd84da.bf820ec5.js b/assets/js/8edd84da.bf820ec5.js new file mode 100644 index 00000000..c7f2bae9 --- /dev/null +++ b/assets/js/8edd84da.bf820ec5.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5971],{73972:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>d,toc:()=>c});var s=n(74848),i=n(28453);const r={title:"Discord",slug:"/integrations/discord",sidebar_position:5,description:"A step-by-step guide on how to integrate Jan with a Discord bot.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Discord integration","Discord","bot"]},o=void 0,d={id:"guides/integrations/discord",title:"Discord",description:"A step-by-step guide on how to integrate Jan with a Discord bot.",source:"@site/docs/guides/integrations/discord.mdx",sourceDirName:"guides/integrations",slug:"/integrations/discord",permalink:"/integrations/discord",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/discord.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:5,frontMatter:{title:"Discord",slug:"/integrations/discord",sidebar_position:5,description:"A step-by-step guide on how to integrate Jan with a Discord bot.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Discord integration","Discord","bot"]},sidebar:"guidesSidebar",previous:{title:"Integrations",permalink:"/integrations/"},next:{title:"Open Interpreter",permalink:"/integrations/interpreter"}},l={},c=[{value:"Integrate Discord Bot with Jan",id:"integrate-discord-bot-with-jan",level:2},{value:"Step 1: Clone the repository",id:"step-1-clone-the-repository",level:3},{value:"Step 2: Install the Required Libraries",id:"step-2-install-the-required-libraries",level:3},{value:"Step 3: Set the Environment",id:"step-3-set-the-environment",level:3},{value:"Step 4: Insert the Bot",id:"step-4-insert-the-bot",level:3},{value:"Step 5: Run the bot",id:"step-5-run-the-bot",level:3}];function a(e){const t={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.h2,{id:"integrate-discord-bot-with-jan",children:"Integrate Discord Bot with Jan"}),"\n",(0,s.jsx)(t.p,{children:"Discord bot can enhances your discord server interactions. By integrating Jan with it, you can significantly boost responsiveness and user engaggement in your discord server."}),"\n",(0,s.jsx)(t.p,{children:"To integrate Jan with a Discord bot, follow the steps below:"}),"\n",(0,s.jsx)(t.h3,{id:"step-1-clone-the-repository",children:"Step 1: Clone the repository"}),"\n",(0,s.jsxs)(t.p,{children:["To make this integration successful, it is necessary to clone the discord bot's ",(0,s.jsx)(t.a,{href:"https://github.com/jakobdylanc/discord-llm-chatbot",children:"repository"}),"."]}),"\n",(0,s.jsx)(t.h3,{id:"step-2-install-the-required-libraries",children:"Step 2: Install the Required Libraries"}),"\n",(0,s.jsx)(t.p,{children:"After cloning the repository, run the following command:"}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-sh",children:"pip install -r requirements.txt\n"})}),"\n",(0,s.jsx)(t.h3,{id:"step-3-set-the-environment",children:"Step 3: Set the Environment"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsxs)(t.li,{children:["Create a copy of ",(0,s.jsx)(t.code,{children:".env.example"}),"."]}),"\n",(0,s.jsxs)(t.li,{children:["Change the name to ",(0,s.jsx)(t.code,{children:".env"}),"."]}),"\n",(0,s.jsx)(t.li,{children:"Set the environment with the following options:"}),"\n"]}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:"Setting"}),(0,s.jsx)(t.th,{children:"Instructions"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"DISCORD_BOT_TOKEN"})}),(0,s.jsxs)(t.td,{children:["Generate a new Discord application at ",(0,s.jsx)(t.a,{href:"https://discord.com/developers/applications",children:"discord.com/developers/applications"}),", obtain a token from the Bot tab, and enable MESSAGE CONTENT INTENT."]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"LLM"})}),(0,s.jsxs)(t.td,{children:["For ",(0,s.jsx)(t.a,{href:"https://jan.ai/",children:"Jan"}),", set to ",(0,s.jsx)(t.code,{children:"local/openai/(MODEL_NAME)"}),", where ",(0,s.jsx)(t.code,{children:"(MODEL_NAME)"})," is your loaded model's name."]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"CUSTOM_SYSTEM_PROMPT"})}),(0,s.jsx)(t.td,{children:"Adjust the bot's behavior as needed."})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"CUSTOM_DISCORD_STATUS"})}),(0,s.jsx)(t.td,{children:"Set a custom message for the bot's Discord profile. (Max 128 characters)"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"ALLOWED_CHANNEL_IDS"})}),(0,s.jsx)(t.td,{children:"Enter Discord channel IDs where the bot can send messages, separated by commas. Leave blank to allow all channels."})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"ALLOWED_ROLE_IDS"})}),(0,s.jsx)(t.td,{children:"Enter Discord role IDs allowed to use the bot, separated by commas. Leave blank to allow everyone. Including at least one role also disables DMs."})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"MAX_IMAGES"})}),(0,s.jsxs)(t.td,{children:["Max number of image attachments allowed per message when using a vision model. (Default: ",(0,s.jsx)(t.code,{children:"5"}),")"]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"MAX_MESSAGES"})}),(0,s.jsxs)(t.td,{children:["Max messages allowed in a reply chain. (Default: ",(0,s.jsx)(t.code,{children:"20"}),")"]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"LOCAL_SERVER_URL"})}),(0,s.jsxs)(t.td,{children:["URL of your local API server for LLMs starting with ",(0,s.jsx)(t.code,{children:"local/"}),". (Default: ",(0,s.jsx)(t.code,{children:"http://localhost:5000/v1"}),")"]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"LOCAL_API_KEY"})}),(0,s.jsxs)(t.td,{children:["API key for your local API server with LLMs starting with ",(0,s.jsx)(t.code,{children:"local/"}),". Usually safe to leave blank."]})]})]})]}),"\n",(0,s.jsx)(t.h3,{id:"step-4-insert-the-bot",children:"Step 4: Insert the Bot"}),"\n",(0,s.jsx)(t.p,{children:"Invite the bot to your Discord server using the following URL:"}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{children:"https://discord.com/api/oauth2/authorize?client_id=(CLIENT_ID)&permissions=412317273088&scope=bot\n"})}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsxs)(t.p,{children:["Replace ",(0,s.jsx)(t.code,{children:"CLIENT_ID"})," with your Discord application's client ID from the OAuth2 tab"]})}),"\n",(0,s.jsx)(t.h3,{id:"step-5-run-the-bot",children:"Step 5: Run the bot"}),"\n",(0,s.jsx)(t.p,{children:"Run the bot by using the following command in your command prompt:"}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-sh",children:"python llmcord.py\n"})})]})}function h(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(a,{...e})}):a(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>o,x:()=>d});var s=n(96540);const i={},r=s.createContext(i);function o(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/8edd84da.d813ba50.js b/assets/js/8edd84da.d813ba50.js deleted file mode 100644 index 103da81f..00000000 --- a/assets/js/8edd84da.d813ba50.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5971],{73972:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>d,toc:()=>c});var s=n(74848),i=n(28453);const r={title:"Discord",slug:"/integrations/discord",sidebar_position:5,description:"A step-by-step guide on how to integrate Jan with a Discord bot.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Discord integration","Discord","bot"]},o=void 0,d={id:"guides/integrations/discord",title:"Discord",description:"A step-by-step guide on how to integrate Jan with a Discord bot.",source:"@site/docs/guides/integrations/discord.mdx",sourceDirName:"guides/integrations",slug:"/integrations/discord",permalink:"/integrations/discord",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/discord.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:5,frontMatter:{title:"Discord",slug:"/integrations/discord",sidebar_position:5,description:"A step-by-step guide on how to integrate Jan with a Discord bot.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Discord integration","Discord","bot"]},sidebar:"guidesSidebar",previous:{title:"Integrations",permalink:"/integrations/"},next:{title:"Open Interpreter",permalink:"/integrations/interpreter"}},l={},c=[{value:"Integrate Discord Bot with Jan",id:"integrate-discord-bot-with-jan",level:2},{value:"Step 1: Clone the repository",id:"step-1-clone-the-repository",level:3},{value:"Step 2: Install the Required Libraries",id:"step-2-install-the-required-libraries",level:3},{value:"Step 3: Set the Environment",id:"step-3-set-the-environment",level:3},{value:"Step 4: Insert the Bot",id:"step-4-insert-the-bot",level:3},{value:"Step 5: Run the bot",id:"step-5-run-the-bot",level:3}];function a(e){const t={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.h2,{id:"integrate-discord-bot-with-jan",children:"Integrate Discord Bot with Jan"}),"\n",(0,s.jsx)(t.p,{children:"Discord bot can enhances your discord server interactions. By integrating Jan with it, you can significantly boost responsiveness and user engaggement in your discord server."}),"\n",(0,s.jsx)(t.p,{children:"To integrate Jan with a Discord bot, follow the steps below:"}),"\n",(0,s.jsx)(t.h3,{id:"step-1-clone-the-repository",children:"Step 1: Clone the repository"}),"\n",(0,s.jsxs)(t.p,{children:["To make this integration successful, it is necessary to clone the discord bot's ",(0,s.jsx)(t.a,{href:"https://github.com/jakobdylanc/discord-llm-chatbot",children:"repository"}),"."]}),"\n",(0,s.jsx)(t.h3,{id:"step-2-install-the-required-libraries",children:"Step 2: Install the Required Libraries"}),"\n",(0,s.jsx)(t.p,{children:"After cloning the repository, run the following command:"}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-sh",children:"pip install -r requirements.txt\n"})}),"\n",(0,s.jsx)(t.h3,{id:"step-3-set-the-environment",children:"Step 3: Set the Environment"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsxs)(t.li,{children:["Create a copy of ",(0,s.jsx)(t.code,{children:".env.example"}),"."]}),"\n",(0,s.jsxs)(t.li,{children:["Change the name to ",(0,s.jsx)(t.code,{children:".env"}),"."]}),"\n",(0,s.jsx)(t.li,{children:"Set the environment with the following options:"}),"\n"]}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:"Setting"}),(0,s.jsx)(t.th,{children:"Instructions"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"DISCORD_BOT_TOKEN"})}),(0,s.jsxs)(t.td,{children:["Generate a new Discord application at ",(0,s.jsx)(t.a,{href:"https://discord.com/developers/applications",children:"discord.com/developers/applications"}),", obtain a token from the Bot tab, and enable MESSAGE CONTENT INTENT."]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"LLM"})}),(0,s.jsxs)(t.td,{children:["For ",(0,s.jsx)(t.a,{href:"https://jan.ai/",children:"Jan"}),", set to ",(0,s.jsx)(t.code,{children:"local/openai/(MODEL_NAME)"}),", where ",(0,s.jsx)(t.code,{children:"(MODEL_NAME)"})," is your loaded model's name."]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"CUSTOM_SYSTEM_PROMPT"})}),(0,s.jsx)(t.td,{children:"Adjust the bot's behavior as needed."})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"CUSTOM_DISCORD_STATUS"})}),(0,s.jsx)(t.td,{children:"Set a custom message for the bot's Discord profile. (Max 128 characters)"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"ALLOWED_CHANNEL_IDS"})}),(0,s.jsx)(t.td,{children:"Enter Discord channel IDs where the bot can send messages, separated by commas. Leave blank to allow all channels."})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"ALLOWED_ROLE_IDS"})}),(0,s.jsx)(t.td,{children:"Enter Discord role IDs allowed to use the bot, separated by commas. Leave blank to allow everyone. Including at least one role also disables DMs."})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"MAX_IMAGES"})}),(0,s.jsxs)(t.td,{children:["Max number of image attachments allowed per message when using a vision model. (Default: ",(0,s.jsx)(t.code,{children:"5"}),")"]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"MAX_MESSAGES"})}),(0,s.jsxs)(t.td,{children:["Max messages allowed in a reply chain. (Default: ",(0,s.jsx)(t.code,{children:"20"}),")"]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"LOCAL_SERVER_URL"})}),(0,s.jsxs)(t.td,{children:["URL of your local API server for LLMs starting with ",(0,s.jsx)(t.code,{children:"local/"}),". (Default: ",(0,s.jsx)(t.code,{children:"http://localhost:5000/v1"}),")"]})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"LOCAL_API_KEY"})}),(0,s.jsxs)(t.td,{children:["API key for your local API server with LLMs starting with ",(0,s.jsx)(t.code,{children:"local/"}),". Usually safe to leave blank."]})]})]})]}),"\n",(0,s.jsx)(t.h3,{id:"step-4-insert-the-bot",children:"Step 4: Insert the Bot"}),"\n",(0,s.jsx)(t.p,{children:"Invite the bot to your Discord server using the following URL:"}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{children:"https://discord.com/api/oauth2/authorize?client_id=(CLIENT_ID)&permissions=412317273088&scope=bot\n"})}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsxs)(t.p,{children:["Replace ",(0,s.jsx)(t.code,{children:"CLIENT_ID"})," with your Discord application's client ID from the OAuth2 tab"]})}),"\n",(0,s.jsx)(t.h3,{id:"step-5-run-the-bot",children:"Step 5: Run the bot"}),"\n",(0,s.jsx)(t.p,{children:"Run the bot by using the following command in your command prompt:"}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-sh",children:"python llmcord.py\n"})})]})}function h(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(a,{...e})}):a(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>o,x:()=>d});var s=n(96540);const i={},r=s.createContext(i);function o(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/935f2afb.8a93ea1f.js b/assets/js/935f2afb.8a93ea1f.js deleted file mode 100644 index bcda1c76..00000000 --- a/assets/js/935f2afb.8a93ea1f.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8581],{35610:e=>{e.exports=JSON.parse('{"pluginId":"default","version":"current","label":"Next","banner":null,"badge":false,"noIndex":false,"className":"docs-version-current","isLast":true,"docsSidebars":{"aboutSidebar":[{"type":"category","label":"What is Jan?","items":[{"type":"link","label":"Jan\'s Community","href":"/community","docId":"community/community","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/about"},{"type":"category","label":"Who we are","items":[{"type":"link","label":"Join us","href":"/team/join-us","docId":"team/join-us","unlisted":false},{"type":"link","label":"Contributor Program","href":"/team/contributor-program","docId":"team/contributor-program","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/team/"},{"type":"link","label":"Wall of Love \u2764\ufe0f","href":"/wall-of-love","docId":"wall-of-love","unlisted":false},{"type":"category","label":"How We Work","items":[{"type":"link","label":"Strategy","href":"/how-we-work/strategy/","docId":"how-we-work/strategy/strategy","unlisted":false},{"type":"link","label":"Project Management","href":"/how-we-work/project-management","docId":"how-we-work/project-management/project-management","unlisted":false},{"type":"category","label":"Engineering","items":[{"type":"link","label":"CI & CD","href":"/engineering/ci-cd","docId":"how-we-work/engineering/ci-cd","unlisted":false},{"type":"link","label":"QA","href":"/engineering/qa","docId":"how-we-work/engineering/qa","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/engineering"},{"type":"link","label":"Product & Design","href":"/how-we-work/product-design","docId":"how-we-work/product-design/product-design","unlisted":false},{"type":"link","label":"Analytics","href":"/how-we-work/analytics","docId":"how-we-work/analytics/analytics","unlisted":false},{"type":"link","label":"Website & Docs","href":"/how-we-work/website-docs/","docId":"how-we-work/website-docs/website-docs","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/how-we-work"},{"type":"link","label":"Acknowledgements","href":"/acknowledgements","docId":"acknowledgements","unlisted":false},{"type":"link","label":"FAQ","href":"/about/faq","docId":"about/faq","unlisted":false}],"productSidebar":[{"type":"category","label":"Platforms","collapsible":false,"items":[{"type":"link","label":"Jan Desktop","href":"/desktop","docId":"platforms/desktop","unlisted":false},{"type":"link","label":"Jan Home Server","href":"/home-server","docId":"server-suite/home-server","unlisted":false}],"collapsed":false},{"type":"category","collapsible":true,"collapsed":false,"label":"Features","items":[{"type":"link","label":"Local & Self-Hosted AI","href":"/features/local","docId":"features/local","unlisted":false},{"type":"link","label":"OpenAI API Support (and others)","href":"/features/remote","docId":"features/remote","unlisted":false},{"type":"link","label":"API Server","href":"/features/api-server","docId":"features/api-server","unlisted":false},{"type":"link","label":"Extensions Framework","href":"/features/extensions-framework","docId":"features/extensions-framework","unlisted":false},{"type":"link","label":"Agents Framework","href":"/features/agents-framework","docId":"features/agents-framework","unlisted":false},{"type":"link","label":"Data Security","href":"/features/data-security","docId":"features/data-security","unlisted":false}],"href":"/features/"}],"solutionSidebar":[{"type":"category","label":"Use Cases","collapsed":true,"collapsible":true,"items":[{"type":"link","label":"AI PC","href":"/solutions/ai-pc","docId":"solutions/ai-pc","unlisted":false},{"type":"link","label":"Self-hosted alternative to OpenAI\'s Platform","href":"/solutions/chatgpt-alternative","docId":"solutions/chatgpt-alternative","unlisted":false}]},{"type":"category","label":"Sectors","collapsed":true,"collapsible":true,"items":[{"type":"link","label":"Finance","href":"/solutions/finance","docId":"solutions/finance","unlisted":false},{"type":"link","label":"Healthcare","href":"/solutions/healthcare","docId":"solutions/healthcare","unlisted":false},{"type":"link","label":"Legal","href":"/solutions/legal","docId":"solutions/legal","unlisted":false},{"type":"link","label":"Government","href":"/solutions/government","docId":"solutions/government","unlisted":false}]},{"type":"category","label":"Organization Type","collapsed":true,"collapsible":true,"items":[{"type":"link","label":"Developers","href":"/solutions/developers","docId":"solutions/developers","unlisted":false},{"type":"link","label":"Software Consultants","href":"/solutions/consultants","docId":"solutions/consultants","unlisted":false},{"type":"link","label":"Startups","href":"/solutions/startups","docId":"solutions/startups","unlisted":false},{"type":"link","label":"Enterprises","href":"/solutions/enterprises","docId":"solutions/enterprises","unlisted":false}]}],"pricingSidebar":[{"type":"link","label":"Pricing","href":"/pricing","docId":"pricing/pricing","unlisted":false}],"ecosystemSidebar":[{"type":"link","label":"Ecosystem","href":"/ecosystem/","docId":"ecosystem/ecosystem","unlisted":false},{"type":"category","label":"Partners","collapsible":true,"items":[{"type":"link","label":"Become a Partner","href":"/partners/become-a-partner","docId":"partners/become-a-partner","unlisted":false}],"collapsed":true,"href":"/partners/"},{"type":"category","label":"Integrations","items":[{"type":"link","label":"Langchain","href":"/integrations/langchain","docId":"integrations/langchain","unlisted":false},{"type":"link","label":"llama.cpp","href":"/integrations/llamacpp","docId":"integrations/llamacpp","unlisted":false},{"type":"link","label":"Ollama","href":"/integrations/ollama","docId":"integrations/ollama","unlisted":false},{"type":"link","label":"OpenAI","href":"/integrations/openai","docId":"integrations/openai","unlisted":false},{"type":"link","label":"OpenRouter","href":"/integrations/openrouter","docId":"integrations/openrouter","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/integrations"}],"guidesSidebar":[{"type":"category","label":"Get Started","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"Overview","href":"/guides","docId":"guides/get-started/overview","unlisted":false},{"type":"link","label":"Quickstart","href":"/guides/quickstart","docId":"guides/get-started/quickstart","unlisted":false}],"collapsed":false},{"type":"category","label":"User Guides","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"Manage Models","href":"/guides/models","docId":"guides/user-guides/manage-models","unlisted":false},{"type":"link","label":"Manage Threads","href":"/guides/threads","docId":"guides/user-guides/manage-threads","unlisted":false},{"type":"link","label":"Local API Server","href":"/guides/local-api","docId":"guides/user-guides/local-server","unlisted":false},{"type":"link","label":"Advanced Settings","href":"/guides/advanced","docId":"guides/user-guides/advanced-settings","unlisted":false}],"collapsed":false},{"type":"category","label":"Inference Engines","collapsible":false,"className":"head_Menu","items":[{"type":"category","label":"Local Engines","className":"head_SubMenu","items":[{"type":"link","label":"Llama.cpp Extension","href":"/guides/engines/llamacpp","docId":"guides/local-providers/llamacpp","unlisted":false},{"type":"link","label":"TensorRT-LLM Extension","href":"/guides/engines/tensorrt-llm","docId":"guides/local-providers/tensorrt","unlisted":false},{"type":"link","label":"LM Studio","href":"/guides/engines/lmstudio","docId":"guides/local-providers/lmstudio","unlisted":false},{"type":"link","label":"Ollama","href":"/guides/engines/ollama","docId":"guides/local-providers/ollama","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/guides/engines/local"},{"type":"category","label":"Remote Engines","className":"head_SubMenu","items":[{"type":"link","label":"Groq API","href":"/guides/engines/groq","docId":"guides/remote-providers/groq","unlisted":false},{"type":"link","label":"Mistral API","href":"/guides/engines/mistral","docId":"guides/remote-providers/mistral","unlisted":false},{"type":"link","label":"OpenAI API","href":"/guides/engines/openai","docId":"guides/remote-providers/openai","unlisted":false},{"type":"link","label":"Any OAI Compatible Server","href":"/guides/engines/remote-server","docId":"guides/remote-providers/remote-server-integration","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/guides/engines/remote"}],"collapsed":false},{"type":"category","label":"Extensions","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"What are Jan Extensions?","href":"/extensions","docId":"guides/extensions/extensions","unlisted":false}],"collapsed":false},{"type":"category","label":"Integrations","collapsible":false,"className":"head_Menu","items":[{"type":"category","label":"Integrations","className":"head_SubMenu","items":[{"type":"link","label":"Discord","href":"/integrations/discord","docId":"guides/integrations/discord","unlisted":false},{"type":"link","label":"Open Interpreter","href":"/integrations/interpreter","docId":"guides/integrations/interpreter","unlisted":false},{"type":"link","label":"Raycast","href":"/integrations/raycast","docId":"guides/integrations/raycast","unlisted":false},{"type":"link","label":"OpenRouter","href":"/integrations/openrouter","docId":"guides/integrations/router","unlisted":false},{"type":"link","label":"Continue Integration","href":"/integrations/continue","docId":"guides/integrations/vscode","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/integrations/"}],"collapsed":false},{"type":"category","label":"Troubleshooting","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"Troubleshooting","href":"/troubleshooting","docId":"guides/troubleshooting","unlisted":false}],"collapsed":false}],"developerSidebar":[{"type":"category","label":"Overview","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"Architecture","href":"/developer/architecture","docId":"developer/overview/architecture","unlisted":false},{"type":"link","label":"File-based Approach","href":"/developer/file-based","docId":"developer/overview/file-based","unlisted":false},{"type":"link","label":"User Interface","href":"/developer/ui","docId":"developer/overview/user-interface","unlisted":false},{"type":"link","label":"Installation and Prerequisites","href":"/developer/prereq","docId":"developer/overview/install-and-prerequisites","unlisted":false}],"href":"/developer"},{"type":"category","label":"Framework","collapsible":true,"collapsed":true,"items":[{"type":"category","label":"Engineering Specs","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"Assistants","href":"/developer/framework/engineering/assistants","docId":"developer/framework/engineering/assistants","unlisted":false},{"type":"link","label":"Chats","href":"/developer/framework/engineering/chats","docId":"developer/framework/engineering/chats","unlisted":false},{"type":"link","label":"Engine","href":"/developer/framework/engineering/engine","docId":"developer/framework/engineering/engine","unlisted":false},{"type":"link","label":"Files","href":"/developer/framework/engineering/files","docId":"developer/framework/engineering/files","unlisted":false},{"type":"link","label":"Messages","href":"/developer/framework/engineering/messages","docId":"developer/framework/engineering/messages","unlisted":false},{"type":"link","label":"Models","href":"/developer/framework/engineering/models","docId":"developer/framework/engineering/models","unlisted":false},{"type":"link","label":"Threads","href":"/developer/framework/engineering/threads","docId":"developer/framework/engineering/threads","unlisted":false}],"href":"/developer/engineering"},{"type":"category","label":"Product Specs","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"Chat","href":"/developer/framework/product/chat","docId":"developer/framework/product/chat","unlisted":false},{"type":"link","label":"Hub","href":"/developer/framework/product/hub","docId":"developer/framework/product/hub","unlisted":false},{"type":"link","label":"Jan (The Default Assistant)","href":"/developer/framework/product/jan","docId":"developer/framework/product/jan","unlisted":false},{"type":"link","label":"Settings","href":"/developer/framework/product/settings","docId":"developer/framework/product/settings","unlisted":false},{"type":"link","label":"System Monitor","href":"/developer/framework/product/system-monitor","docId":"developer/framework/product/system-monitor","unlisted":false}],"href":"/developer/product"}],"href":"/developer/framework/"}],"releasesSidebar":[{"type":"category","label":"Changelog","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"v0.4.9","href":"/changelog/changelog-v0.4.9","docId":"releases/changelog/changelog-v0.4.9","unlisted":false},{"type":"link","label":"v0.4.8","href":"/changelog/changelog-v0.4.8","docId":"releases/changelog/changelog-v0.4.8","unlisted":false},{"type":"link","label":"v0.4.7","href":"/changelog/changelog-v0.4.7","docId":"releases/changelog/changelog-v0.4.7","unlisted":false},{"type":"link","label":"v0.4.6","href":"/changelog/changelog-v0.4.6","docId":"releases/changelog/changelog-v0.4.6","unlisted":false},{"type":"link","label":"v0.4.5","href":"/changelog/changelog-v0.4.5","docId":"releases/changelog/changelog-v0.4.5","unlisted":false},{"type":"link","label":"v0.4.4","href":"/changelog/changelog-v0.4.4","docId":"releases/changelog/changelog-v0.4.4","unlisted":false},{"type":"link","label":"v0.4.3","href":"/changelog/changelog-v0.4.3","docId":"releases/changelog/changelog-v0.4.3","unlisted":false},{"type":"link","label":"v0.4.2","href":"/changelog/changelog-v0.4.2","docId":"releases/changelog/changelog-v0.4.2","unlisted":false},{"type":"link","label":"v0.4.1","href":"/changelog/changelog-v0.4.1","docId":"releases/changelog/changelog-v0.4.1","unlisted":false},{"type":"link","label":"v0.4.0","href":"/changelog/changelog-v0.4.0","docId":"releases/changelog/changelog-v0.4.0","unlisted":false},{"type":"link","label":"v0.3.3","href":"/changelog/changelog-v0.3.3","docId":"releases/changelog/changelog-v0.3.3","unlisted":false},{"type":"link","label":"v0.3.2","href":"/changelog/changelog-v0.3.2","docId":"releases/changelog/changelog-v0.3.2","unlisted":false},{"type":"link","label":"v0.3.1","href":"/changelog/changelog-v0.3.1","docId":"releases/changelog/changelog-v0.3.1","unlisted":false},{"type":"link","label":"v0.3.0","href":"/changelog/changelog-v0.3.0","docId":"releases/changelog/changelog-v0.3.0","unlisted":false},{"type":"link","label":"v0.2.3","href":"/changelog/changelog-v0.2.3","docId":"releases/changelog/changelog-v0.2.3","unlisted":false},{"type":"link","label":"v0.2.2","href":"/changelog/changelog-v0.2.2","docId":"releases/changelog/changelog-v0.2.2","unlisted":false},{"type":"link","label":"v0.2.1","href":"/changelog/changelog-v0.2.1","docId":"releases/changelog/changelog-v0.2.1","unlisted":false},{"type":"link","label":"v0.2.0","href":"/changelog/changelog-v0.2.0","docId":"releases/changelog/changelog-v0.2.0","unlisted":false}],"href":"/changelog"}]},"docs":{"about/2035":{"id":"about/2035","title":"Jan\'s Vision for 2035","description":"Jan 2035: A Robotics Company"},"about/about":{"id":"about/about","title":"About Jan","description":"Jan is a desktop application that turns computers into thinking machines.","sidebar":"aboutSidebar"},"about/faq":{"id":"about/faq","title":"Frequently Asked Questions (FAQ) - Jan","description":"What is Jan?","sidebar":"aboutSidebar"},"about/roadmap":{"id":"about/roadmap","title":"Roadmap","description":"- ] [Immediate Roadmap on Github"},"about/vision":{"id":"about/vision","title":"Jan\'s Vision","description":"Jan is a desktop application that turns computers into thinking machines."},"acknowledgements":{"id":"acknowledgements","title":"Acknowledgements","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"community/community":{"id":"community/community","title":"Jan\'s Community","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"developer/framework/engineering/assistants":{"id":"developer/framework/engineering/assistants","title":"Assistants","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/chats":{"id":"developer/framework/engineering/chats","title":"Chats","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/engine":{"id":"developer/framework/engineering/engine","title":"Engine","description":"Currently Under Development","sidebar":"developerSidebar"},"developer/framework/engineering/files":{"id":"developer/framework/engineering/files","title":"Files","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/messages":{"id":"developer/framework/engineering/messages","title":"Messages","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/models":{"id":"developer/framework/engineering/models","title":"Models","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/README":{"id":"developer/framework/engineering/README","title":"Engineering Specs","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/threads":{"id":"developer/framework/engineering/threads","title":"Threads","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/chat":{"id":"developer/framework/product/chat","title":"Chat","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/hub":{"id":"developer/framework/product/hub","title":"Hub","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/jan":{"id":"developer/framework/product/jan","title":"Jan (The Default Assistant)","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/README":{"id":"developer/framework/product/README","title":"Product Specs","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/settings":{"id":"developer/framework/product/settings","title":"Settings","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/system-monitor":{"id":"developer/framework/product/system-monitor","title":"System Monitor","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/README":{"id":"developer/framework/README","title":"Framework","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/architecture":{"id":"developer/overview/architecture","title":"Architecture","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/file-based":{"id":"developer/overview/file-based","title":"File-based Approach","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/install-and-prerequisites":{"id":"developer/overview/install-and-prerequisites","title":"Installation and Prerequisites","description":"Guide to install and setup Jan for development.","sidebar":"developerSidebar"},"developer/overview/README":{"id":"developer/overview/README","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/user-interface":{"id":"developer/overview/user-interface","title":"User Interface","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"ecosystem/ecosystem":{"id":"ecosystem/ecosystem","title":"Ecosystem","description":"","sidebar":"ecosystemSidebar"},"events/hcmc-oct23":{"id":"events/hcmc-oct23","title":"Jan\'s AI Hacker House (Ho Chi Minh City)","description":"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai"},"events/nvidia-llm-day-nov-23":{"id":"events/nvidia-llm-day-nov-23","title":"Nov 23: Nvidia GenAI Day","description":"Nvidia\'s LLM Day"},"features/agents-framework":{"id":"features/agents-framework","title":"Agents Framework","description":"","sidebar":"productSidebar"},"features/api-server":{"id":"features/api-server","title":"API Server","description":"","sidebar":"productSidebar"},"features/data-security":{"id":"features/data-security","title":"Data Security","description":"","sidebar":"productSidebar"},"features/extensions-framework":{"id":"features/extensions-framework","title":"Extensions Framework","description":"","sidebar":"productSidebar"},"features/features":{"id":"features/features","title":"Features","description":"","sidebar":"productSidebar"},"features/local":{"id":"features/local","title":"Local & Self-Hosted AI","description":"","sidebar":"productSidebar"},"features/remote":{"id":"features/remote","title":"OpenAI API Support (and others)","description":"","sidebar":"productSidebar"},"foundry/foundry":{"id":"foundry/foundry","title":"foundry","description":""},"guides/extensions/extensions":{"id":"guides/extensions/extensions","title":"What are Jan Extensions?","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/get-started/hardware-setup":{"id":"guides/get-started/hardware-setup","title":"Hardware Setup","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/get-started/overview":{"id":"guides/get-started/overview","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/get-started/quickstart":{"id":"guides/get-started/quickstart","title":"Quickstart","description":"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.","sidebar":"guidesSidebar"},"guides/get-started/settingup-gpu":{"id":"guides/get-started/settingup-gpu","title":"Setting Up GPU","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/inference/overview-inference":{"id":"guides/inference/overview-inference","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/installation/docker":{"id":"guides/installation/docker","title":"Install with Docker","description":"A step-by-step guide to install Jan using Docker."},"guides/installation/linux":{"id":"guides/installation/linux","title":"Install on Linux","description":"A step-by-step guide to install Jan on your Linux."},"guides/installation/mac":{"id":"guides/installation/mac","title":"Install on Mac","description":"A step-by-step guide to install Jan on your Mac."},"guides/installation/README":{"id":"guides/installation/README","title":"Installation","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/installation/windows":{"id":"guides/installation/windows","title":"Install on Windows","description":"A step-by-step guide to install Jan on your Windows."},"guides/integrations/crewai":{"id":"guides/integrations/crewai","title":"CrewAI","description":"A step-by-step guide on how to integrate Jan with CrewAI."},"guides/integrations/discord":{"id":"guides/integrations/discord","title":"Discord","description":"A step-by-step guide on how to integrate Jan with a Discord bot.","sidebar":"guidesSidebar"},"guides/integrations/interpreter":{"id":"guides/integrations/interpreter","title":"Open Interpreter","description":"A step-by-step guide on how to integrate Jan with Open Interpreter.","sidebar":"guidesSidebar"},"guides/integrations/overview-integration":{"id":"guides/integrations/overview-integration","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/integrations/raycast":{"id":"guides/integrations/raycast","title":"Raycast","description":"A step-by-step guide on how to integrate Jan with Raycast.","sidebar":"guidesSidebar"},"guides/integrations/README":{"id":"guides/integrations/README","title":"Integrations","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/integrations/router":{"id":"guides/integrations/router","title":"OpenRouter","description":"A step-by-step guide on how to integrate Jan with OpenRouter.","sidebar":"guidesSidebar"},"guides/integrations/unsloth":{"id":"guides/integrations/unsloth","title":"Unsloth","description":"A step-by-step guide on how to integrate Jan with Unsloth."},"guides/integrations/vscode":{"id":"guides/integrations/vscode","title":"Continue Integration","description":"A step-by-step guide on how to integrate Jan with Continue and VS Code.","sidebar":"guidesSidebar"},"guides/local-providers/llamacpp":{"id":"guides/local-providers/llamacpp","title":"Llama.cpp Extension","description":"A step-by-step guide on how to customize the LlamaCPP extension.","sidebar":"guidesSidebar"},"guides/local-providers/lmstudio":{"id":"guides/local-providers/lmstudio","title":"LM Studio","description":"A step-by-step guide on how to integrate Jan with LM Studio.","sidebar":"guidesSidebar"},"guides/local-providers/ollama":{"id":"guides/local-providers/ollama","title":"Ollama","description":"A step-by-step guide on how to integrate Jan with Ollama.","sidebar":"guidesSidebar"},"guides/local-providers/README":{"id":"guides/local-providers/README","title":"Local Engines","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/local-providers/tensorrt":{"id":"guides/local-providers/tensorrt","title":"TensorRT-LLM Extension","description":"A step-by-step guide on how to customize the TensorRT-LLM extension.","sidebar":"guidesSidebar"},"guides/providers/tensorrt-llm":{"id":"guides/providers/tensorrt-llm","title":"TensorRT-LLM","description":"TensorRT-LLM support was launched in 0.4.9, and should be regarded as an Experimental feature."},"guides/remote-providers/claude":{"id":"guides/remote-providers/claude","title":"Claude","description":"A step-by-step guide on how to integrate Jan with LM Studio."},"guides/remote-providers/groq":{"id":"guides/remote-providers/groq","title":"Groq API","description":"Learn how to integrate Groq API with Jan for enhanced functionality.","sidebar":"guidesSidebar"},"guides/remote-providers/mistral":{"id":"guides/remote-providers/mistral","title":"Mistral API","description":"A step-by-step guide on how to integrate Jan with Mistral AI.","sidebar":"guidesSidebar"},"guides/remote-providers/openai":{"id":"guides/remote-providers/openai","title":"OpenAI API","description":"A step-by-step guide on how to integrate Jan with Azure OpenAI.","sidebar":"guidesSidebar"},"guides/remote-providers/README":{"id":"guides/remote-providers/README","title":"Remote Engines","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/remote-providers/remote-server-integration":{"id":"guides/remote-providers/remote-server-integration","title":"Any OAI Compatible Server","description":"A step-by-step guide on how to set up Jan to connect with any remote or local API server.","sidebar":"guidesSidebar"},"guides/troubleshooting":{"id":"guides/troubleshooting","title":"Troubleshooting","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/advanced-settings":{"id":"guides/user-guides/advanced-settings","title":"Advanced Settings","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/jan-data-folder":{"id":"guides/user-guides/jan-data-folder","title":"Jan Data Folder","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/user-guides/local-server":{"id":"guides/user-guides/local-server","title":"Local API Server","description":"A step-by-step guide to start Jan Local Server.","sidebar":"guidesSidebar"},"guides/user-guides/manage-assistants":{"id":"guides/user-guides/manage-assistants","title":"Manage Assistants","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/user-guides/manage-models":{"id":"guides/user-guides/manage-models","title":"Manage Models","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/manage-threads":{"id":"guides/user-guides/manage-threads","title":"Manage Threads","description":"Manage your interaction with AI locally.","sidebar":"guidesSidebar"},"guides/user-guides/overview-guides":{"id":"guides/user-guides/overview-guides","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"hardware/community":{"id":"hardware/community","title":"Hardware Examples","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"hardware/concepts/chassis":{"id":"hardware/concepts/chassis","title":"Chassis","description":""},"hardware/concepts/concepts":{"id":"hardware/concepts/concepts","title":"Anatomy of a Thinking Machine","description":"- Cover the difference between CPU/RAM and GPU/VRAM"},"hardware/concepts/cpu-and-ram":{"id":"hardware/concepts/cpu-and-ram","title":"CPU","description":"- CPU\'s role vs GPU"},"hardware/concepts/gpu-and-vram":{"id":"hardware/concepts/gpu-and-vram","title":"GPUs and VRAM","description":"What Is a GPU?"},"hardware/concepts/motherboard":{"id":"hardware/concepts/motherboard","title":"Motherboard","description":"- PCIe lanes that go to the processor (not Chipset)"},"hardware/concepts/network":{"id":"hardware/concepts/network","title":"Network","description":""},"hardware/concepts/power":{"id":"hardware/concepts/power","title":"Power Supply","description":""},"hardware/concepts/storage":{"id":"hardware/concepts/storage","title":"Storage","description":""},"hardware/examples/4090x2-@dan-jan":{"id":"hardware/examples/4090x2-@dan-jan","title":"2 x 4090 Workstation","description":"Jan uses a 2 x 4090 Workstation to run Codellama for internal use."},"hardware/hardware":{"id":"hardware/hardware","title":"Introduction","description":""},"hardware/overview/cloud-vs-self-hosting":{"id":"hardware/overview/cloud-vs-self-hosting","title":"Cloud vs. Self-hosting Your AI","description":"The choice of how to run your AI - on GPU cloud services, on-prem, or just using an API provider - involves various trade-offs. The following is a naive exploration of the pros and cons of renting vs self-hosting."},"hardware/overview/cpu-vs-gpu":{"id":"hardware/overview/cpu-vs-gpu","title":"GPU vs CPU What\'s the Difference?","description":"CPU vs. GPU"},"hardware/recommendations/by-budget":{"id":"hardware/recommendations/by-budget","title":"Recommended AI Hardware by Budget","description":"Warning: Do your own research before any purchase. Jan is not liable for compatibility, performance or other issues. Products can become outdated quickly."},"hardware/recommendations/by-hardware":{"id":"hardware/recommendations/by-hardware","title":"Selecting AI Hardware","description":"When selecting a GPU for LLMs, remember that it\'s not just about the GPU itself. Consider the synergy with other components in your PC:"},"hardware/recommendations/by-model":{"id":"hardware/recommendations/by-model","title":"Recommended AI Hardware by Model","description":"Codellama 34b"},"hardware/recommendations/by-usecase":{"id":"hardware/recommendations/by-usecase","title":"Recommended AI Hardware by Use Case","description":"Which AI Hardware to Choose Based on Your Use Case"},"how-we-work":{"id":"how-we-work","title":"How We Work","description":"How we work at Jan","sidebar":"aboutSidebar"},"how-we-work/analytics/analytics":{"id":"how-we-work/analytics/analytics","title":"Analytics","description":"Jan\'s Analytics philosophy and implementation","sidebar":"aboutSidebar"},"how-we-work/engineering/ci-cd":{"id":"how-we-work/engineering/ci-cd","title":"CI & CD","description":"Gitflow","sidebar":"aboutSidebar"},"how-we-work/engineering/engineering":{"id":"how-we-work/engineering/engineering","title":"Engineering","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"how-we-work/engineering/qa":{"id":"how-we-work/engineering/qa","title":"QA","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"how-we-work/product-design/product-design":{"id":"how-we-work/product-design/product-design","title":"Product & Design","description":"How we work on product design","sidebar":"aboutSidebar"},"how-we-work/project-management/project-management":{"id":"how-we-work/project-management/project-management","title":"Project Management","description":"Project management at Jan","sidebar":"aboutSidebar"},"how-we-work/strategy/strategy":{"id":"how-we-work/strategy/strategy","title":"Strategy","description":"We only have 2 planning parameters:","sidebar":"aboutSidebar"},"how-we-work/website-docs/website-docs":{"id":"how-we-work/website-docs/website-docs","title":"Website & Docs","description":"Information about the Jan website and documentation.","sidebar":"aboutSidebar"},"integrations":{"id":"integrations","title":"Integrations","description":"","sidebar":"ecosystemSidebar"},"integrations/langchain":{"id":"integrations/langchain","title":"Langchain","description":"WIP","sidebar":"ecosystemSidebar"},"integrations/llamacpp":{"id":"integrations/llamacpp","title":"llama.cpp","description":"Quicklinks","sidebar":"ecosystemSidebar"},"integrations/ollama":{"id":"integrations/ollama","title":"Ollama","description":"Requested, committed, but not started","sidebar":"ecosystemSidebar"},"integrations/openai":{"id":"integrations/openai","title":"OpenAI","description":"Quicklinks","sidebar":"ecosystemSidebar"},"integrations/openrouter":{"id":"integrations/openrouter","title":"OpenRouter","description":"Requested, committed, but not started","sidebar":"ecosystemSidebar"},"partners/become-a-partner":{"id":"partners/become-a-partner","title":"Become a Partner","description":"","sidebar":"ecosystemSidebar"},"partners/partners":{"id":"partners/partners","title":"Partners","description":"","sidebar":"ecosystemSidebar"},"pending-content/blogpost/finetune-with-docs":{"id":"pending-content/blogpost/finetune-with-docs","title":"How to Fine-tune Large Language Models - A Tutorial","description":"Guide on Finetuning Large Language Models with Personal Dataset"},"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives":{"id":"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives","title":"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B","description":"Creating Open Source Alternatives to Outperform ChatGPT"},"platforms/desktop":{"id":"platforms/desktop","title":"Jan Desktop","description":"Turn your computer into an AI PC","sidebar":"productSidebar"},"platforms/hub":{"id":"platforms/hub","title":"Jan Hub","description":""},"platforms/mobile":{"id":"platforms/mobile","title":"Jan Mobile","description":"Jan Mobile allows you to bring your AI on the go"},"pricing/pricing":{"id":"pricing/pricing","title":"Pricing","description":"Pricing for Jan","sidebar":"pricingSidebar"},"privacy/privacy":{"id":"privacy/privacy","title":"Privacy - Jan","description":"\u2757This privacy policy only pertains to the DEPRECATED Jan Mobile Application in the iOS and Android app store."},"releases/changelog/changelog-v0.2.0":{"id":"releases/changelog/changelog-v0.2.0","title":"v0.2.0","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.2.1":{"id":"releases/changelog/changelog-v0.2.1","title":"v0.2.1","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.2.2":{"id":"releases/changelog/changelog-v0.2.2","title":"v0.2.2","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.2.3":{"id":"releases/changelog/changelog-v0.2.3","title":"v0.2.3","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.0":{"id":"releases/changelog/changelog-v0.3.0","title":"v0.3.0","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.1":{"id":"releases/changelog/changelog-v0.3.1","title":"v0.3.1","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.2":{"id":"releases/changelog/changelog-v0.3.2","title":"v0.3.2","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.3":{"id":"releases/changelog/changelog-v0.3.3","title":"v0.3.3","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.0":{"id":"releases/changelog/changelog-v0.4.0","title":"v0.4.0","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.1":{"id":"releases/changelog/changelog-v0.4.1","title":"v0.4.1","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.2":{"id":"releases/changelog/changelog-v0.4.2","title":"v0.4.2","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.3":{"id":"releases/changelog/changelog-v0.4.3","title":"v0.4.3","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.4":{"id":"releases/changelog/changelog-v0.4.4","title":"v0.4.4","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.5":{"id":"releases/changelog/changelog-v0.4.5","title":"v0.4.5","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.6":{"id":"releases/changelog/changelog-v0.4.6","title":"v0.4.6","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.7":{"id":"releases/changelog/changelog-v0.4.7","title":"v0.4.7","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.8":{"id":"releases/changelog/changelog-v0.4.8","title":"v0.4.8","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.9":{"id":"releases/changelog/changelog-v0.4.9","title":"v0.4.9","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/README":{"id":"releases/changelog/README","title":"Changelog","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"releasesSidebar"},"server-suite/admin-console":{"id":"server-suite/admin-console","title":"Admin Console","description":""},"server-suite/audit-compliance":{"id":"server-suite/audit-compliance","title":"Audit & Compliance","description":""},"server-suite/enterprise":{"id":"server-suite/enterprise","title":"Jan Enterprise","description":"Built for Enterprise Deployments"},"server-suite/home-server":{"id":"server-suite/home-server","title":"Jan Home Server","description":"Built for Home Servers","sidebar":"productSidebar"},"server-suite/identity-access-management":{"id":"server-suite/identity-access-management","title":"Identity & Access Control","description":""},"server-suite/observability":{"id":"server-suite/observability","title":"Observability","description":""},"solutions/ai-employees":{"id":"solutions/ai-employees","title":"AI Employees","description":""},"solutions/ai-pc":{"id":"solutions/ai-pc","title":"AI PC","description":"","sidebar":"solutionSidebar"},"solutions/chatgpt-alternative":{"id":"solutions/chatgpt-alternative","title":"Self-hosted alternative to OpenAI\'s Platform","description":"","sidebar":"solutionSidebar"},"solutions/consultants":{"id":"solutions/consultants","title":"Software Consultants","description":"","sidebar":"solutionSidebar"},"solutions/developers":{"id":"solutions/developers","title":"Developers","description":"","sidebar":"solutionSidebar"},"solutions/enterprises":{"id":"solutions/enterprises","title":"Enterprises","description":"","sidebar":"solutionSidebar"},"solutions/finance":{"id":"solutions/finance","title":"Finance","description":"","sidebar":"solutionSidebar"},"solutions/government":{"id":"solutions/government","title":"Government","description":"","sidebar":"solutionSidebar"},"solutions/healthcare":{"id":"solutions/healthcare","title":"Healthcare","description":"","sidebar":"solutionSidebar"},"solutions/legal":{"id":"solutions/legal","title":"Legal","description":"","sidebar":"solutionSidebar"},"solutions/startups":{"id":"solutions/startups","title":"Startups","description":"","sidebar":"solutionSidebar"},"studio/studio":{"id":"studio/studio","title":"studio","description":""},"support/support":{"id":"support/support","title":"Support - Jan","description":"- Bugs & requests: file a GitHub ticket here"},"team/contributor-program":{"id":"team/contributor-program","title":"Contributor Program","description":"","sidebar":"aboutSidebar"},"team/join-us":{"id":"team/join-us","title":"Join us","description":"- [ ] Explain Core Team, Contributors and Open Source approach","sidebar":"aboutSidebar"},"team/team":{"id":"team/team","title":"Who we are","description":"What\'s Jan the company about?","sidebar":"aboutSidebar"},"template/QA_script":{"id":"template/QA_script","title":"Regression test","description":"Release Version: v0.4.7"},"wall-of-love":{"id":"wall-of-love","title":"Wall of Love \u2764\ufe0f","description":"Check out what our amazing users are saying about Jan!","sidebar":"aboutSidebar"}}}')}}]); \ No newline at end of file diff --git a/assets/js/935f2afb.949c4046.js b/assets/js/935f2afb.949c4046.js new file mode 100644 index 00000000..373cbb5f --- /dev/null +++ b/assets/js/935f2afb.949c4046.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8581],{35610:e=>{e.exports=JSON.parse('{"pluginId":"default","version":"current","label":"Next","banner":null,"badge":false,"noIndex":false,"className":"docs-version-current","isLast":true,"docsSidebars":{"aboutSidebar":[{"type":"category","label":"What is Jan?","items":[{"type":"link","label":"Jan\'s Community","href":"/community","docId":"community/community","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/about"},{"type":"category","label":"Who we are","items":[{"type":"link","label":"Join us","href":"/team/join-us","docId":"team/join-us","unlisted":false},{"type":"link","label":"Contributor Program","href":"/team/contributor-program","docId":"team/contributor-program","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/team/"},{"type":"link","label":"Wall of Love \u2764\ufe0f","href":"/wall-of-love","docId":"wall-of-love","unlisted":false},{"type":"category","label":"How We Work","items":[{"type":"link","label":"Strategy","href":"/how-we-work/strategy/","docId":"how-we-work/strategy/strategy","unlisted":false},{"type":"link","label":"Project Management","href":"/how-we-work/project-management","docId":"how-we-work/project-management/project-management","unlisted":false},{"type":"category","label":"Engineering","items":[{"type":"link","label":"CI & CD","href":"/engineering/ci-cd","docId":"how-we-work/engineering/ci-cd","unlisted":false},{"type":"link","label":"QA","href":"/engineering/qa","docId":"how-we-work/engineering/qa","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/engineering"},{"type":"link","label":"Product & Design","href":"/how-we-work/product-design","docId":"how-we-work/product-design/product-design","unlisted":false},{"type":"link","label":"Analytics","href":"/how-we-work/analytics","docId":"how-we-work/analytics/analytics","unlisted":false},{"type":"link","label":"Website & Docs","href":"/how-we-work/website-docs/","docId":"how-we-work/website-docs/website-docs","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/how-we-work"},{"type":"link","label":"Acknowledgements","href":"/acknowledgements","docId":"acknowledgements","unlisted":false},{"type":"link","label":"FAQ","href":"/about/faq","docId":"about/faq","unlisted":false}],"productSidebar":[{"type":"category","label":"Platforms","collapsible":false,"items":[{"type":"link","label":"Jan Desktop","href":"/desktop","docId":"platforms/desktop","unlisted":false},{"type":"link","label":"Jan Home Server","href":"/home-server","docId":"server-suite/home-server","unlisted":false}],"collapsed":false},{"type":"category","collapsible":true,"collapsed":false,"label":"Features","items":[{"type":"link","label":"Local & Self-Hosted AI","href":"/features/local","docId":"features/local","unlisted":false},{"type":"link","label":"OpenAI API Support (and others)","href":"/features/remote","docId":"features/remote","unlisted":false},{"type":"link","label":"API Server","href":"/features/api-server","docId":"features/api-server","unlisted":false},{"type":"link","label":"Extensions Framework","href":"/features/extensions-framework","docId":"features/extensions-framework","unlisted":false},{"type":"link","label":"Agents Framework","href":"/features/agents-framework","docId":"features/agents-framework","unlisted":false},{"type":"link","label":"Data Security","href":"/features/data-security","docId":"features/data-security","unlisted":false}],"href":"/features/"}],"solutionSidebar":[{"type":"category","label":"Use Cases","collapsed":true,"collapsible":true,"items":[{"type":"link","label":"AI PC","href":"/solutions/ai-pc","docId":"solutions/ai-pc","unlisted":false},{"type":"link","label":"Self-hosted alternative to OpenAI\'s Platform","href":"/solutions/chatgpt-alternative","docId":"solutions/chatgpt-alternative","unlisted":false}]},{"type":"category","label":"Sectors","collapsed":true,"collapsible":true,"items":[{"type":"link","label":"Finance","href":"/solutions/finance","docId":"solutions/finance","unlisted":false},{"type":"link","label":"Healthcare","href":"/solutions/healthcare","docId":"solutions/healthcare","unlisted":false},{"type":"link","label":"Legal","href":"/solutions/legal","docId":"solutions/legal","unlisted":false},{"type":"link","label":"Government","href":"/solutions/government","docId":"solutions/government","unlisted":false}]},{"type":"category","label":"Organization Type","collapsed":true,"collapsible":true,"items":[{"type":"link","label":"Developers","href":"/solutions/developers","docId":"solutions/developers","unlisted":false},{"type":"link","label":"Software Consultants","href":"/solutions/consultants","docId":"solutions/consultants","unlisted":false},{"type":"link","label":"Startups","href":"/solutions/startups","docId":"solutions/startups","unlisted":false},{"type":"link","label":"Enterprises","href":"/solutions/enterprises","docId":"solutions/enterprises","unlisted":false}]}],"pricingSidebar":[{"type":"link","label":"Pricing","href":"/pricing","docId":"pricing/pricing","unlisted":false}],"ecosystemSidebar":[{"type":"link","label":"Ecosystem","href":"/ecosystem/","docId":"ecosystem/ecosystem","unlisted":false},{"type":"category","label":"Partners","collapsible":true,"items":[{"type":"link","label":"Become a Partner","href":"/partners/become-a-partner","docId":"partners/become-a-partner","unlisted":false}],"collapsed":true,"href":"/partners/"},{"type":"category","label":"Integrations","items":[{"type":"link","label":"Langchain","href":"/integrations/langchain","docId":"integrations/langchain","unlisted":false},{"type":"link","label":"llama.cpp","href":"/integrations/llamacpp","docId":"integrations/llamacpp","unlisted":false},{"type":"link","label":"Ollama","href":"/integrations/ollama","docId":"integrations/ollama","unlisted":false},{"type":"link","label":"OpenAI","href":"/integrations/openai","docId":"integrations/openai","unlisted":false},{"type":"link","label":"OpenRouter","href":"/integrations/openrouter","docId":"integrations/openrouter","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/integrations"}],"guidesSidebar":[{"type":"category","label":"Get Started","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"Overview","href":"/guides","docId":"guides/get-started/overview","unlisted":false},{"type":"link","label":"Quickstart","href":"/guides/quickstart","docId":"guides/get-started/quickstart","unlisted":false}],"collapsed":false},{"type":"category","label":"User Guides","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"Manage Models","href":"/guides/models","docId":"guides/user-guides/manage-models","unlisted":false},{"type":"link","label":"Manage Assistants","href":"/guides/assistants","docId":"guides/user-guides/manage-assistants","unlisted":false},{"type":"link","label":"Manage Threads","href":"/guides/threads","docId":"guides/user-guides/manage-threads","unlisted":false},{"type":"link","label":"Use Tools","href":"/guides/tools","docId":"guides/user-guides/use-tools","unlisted":false},{"type":"link","label":"Local API Server","href":"/guides/local-api","docId":"guides/user-guides/local-server","unlisted":false},{"type":"link","label":"Advanced Settings","href":"/guides/advanced","docId":"guides/user-guides/advanced-settings","unlisted":false}],"collapsed":false},{"type":"category","label":"Inference Engines","collapsible":false,"className":"head_Menu","items":[{"type":"category","label":"Local Engines","className":"head_SubMenu","items":[{"type":"link","label":"Llama.cpp Extension","href":"/guides/engines/llamacpp","docId":"guides/local-providers/llamacpp","unlisted":false},{"type":"link","label":"TensorRT-LLM Extension","href":"/guides/engines/tensorrt-llm","docId":"guides/local-providers/tensorrt","unlisted":false},{"type":"link","label":"LM Studio","href":"/guides/engines/lmstudio","docId":"guides/local-providers/lmstudio","unlisted":false},{"type":"link","label":"Ollama","href":"/guides/engines/ollama","docId":"guides/local-providers/ollama","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/guides/engines/local"},{"type":"category","label":"Remote Engines","className":"head_SubMenu","items":[{"type":"link","label":"Groq API","href":"/guides/engines/groq","docId":"guides/remote-providers/groq","unlisted":false},{"type":"link","label":"Mistral API","href":"/guides/engines/mistral","docId":"guides/remote-providers/mistral","unlisted":false},{"type":"link","label":"OpenAI API","href":"/guides/engines/openai","docId":"guides/remote-providers/openai","unlisted":false},{"type":"link","label":"Any OAI Compatible Server","href":"/guides/engines/remote-server","docId":"guides/remote-providers/remote-server-integration","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/guides/engines/remote"}],"collapsed":false},{"type":"category","label":"Extensions","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"What are Jan Extensions?","href":"/extensions","docId":"guides/extensions/extensions","unlisted":false}],"collapsed":false},{"type":"category","label":"Integrations","collapsible":false,"className":"head_Menu","items":[{"type":"category","label":"Integrations","className":"head_SubMenu","items":[{"type":"link","label":"Discord","href":"/integrations/discord","docId":"guides/integrations/discord","unlisted":false},{"type":"link","label":"Open Interpreter","href":"/integrations/interpreter","docId":"guides/integrations/interpreter","unlisted":false},{"type":"link","label":"Raycast","href":"/integrations/raycast","docId":"guides/integrations/raycast","unlisted":false},{"type":"link","label":"OpenRouter","href":"/integrations/openrouter","docId":"guides/integrations/router","unlisted":false},{"type":"link","label":"Continue Integration","href":"/integrations/continue","docId":"guides/integrations/vscode","unlisted":false}],"collapsed":true,"collapsible":true,"href":"/integrations/"}],"collapsed":false},{"type":"category","label":"Troubleshooting","collapsible":false,"className":"head_Menu","items":[{"type":"link","label":"Troubleshooting","href":"/troubleshooting","docId":"guides/troubleshooting","unlisted":false}],"collapsed":false}],"developerSidebar":[{"type":"category","label":"Overview","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"Architecture","href":"/developer/architecture","docId":"developer/overview/architecture","unlisted":false},{"type":"link","label":"File-based Approach","href":"/developer/file-based","docId":"developer/overview/file-based","unlisted":false},{"type":"link","label":"User Interface","href":"/developer/ui","docId":"developer/overview/user-interface","unlisted":false},{"type":"link","label":"Installation and Prerequisites","href":"/developer/prereq","docId":"developer/overview/install-and-prerequisites","unlisted":false}],"href":"/developer"},{"type":"category","label":"Framework","collapsible":true,"collapsed":true,"items":[{"type":"category","label":"Engineering Specs","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"Assistants","href":"/developer/framework/engineering/assistants","docId":"developer/framework/engineering/assistants","unlisted":false},{"type":"link","label":"Chats","href":"/developer/framework/engineering/chats","docId":"developer/framework/engineering/chats","unlisted":false},{"type":"link","label":"Engine","href":"/developer/framework/engineering/engine","docId":"developer/framework/engineering/engine","unlisted":false},{"type":"link","label":"Files","href":"/developer/framework/engineering/files","docId":"developer/framework/engineering/files","unlisted":false},{"type":"link","label":"Messages","href":"/developer/framework/engineering/messages","docId":"developer/framework/engineering/messages","unlisted":false},{"type":"link","label":"Models","href":"/developer/framework/engineering/models","docId":"developer/framework/engineering/models","unlisted":false},{"type":"link","label":"Threads","href":"/developer/framework/engineering/threads","docId":"developer/framework/engineering/threads","unlisted":false}],"href":"/developer/engineering"},{"type":"category","label":"Product Specs","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"Chat","href":"/developer/framework/product/chat","docId":"developer/framework/product/chat","unlisted":false},{"type":"link","label":"Hub","href":"/developer/framework/product/hub","docId":"developer/framework/product/hub","unlisted":false},{"type":"link","label":"Jan (The Default Assistant)","href":"/developer/framework/product/jan","docId":"developer/framework/product/jan","unlisted":false},{"type":"link","label":"Settings","href":"/developer/framework/product/settings","docId":"developer/framework/product/settings","unlisted":false},{"type":"link","label":"System Monitor","href":"/developer/framework/product/system-monitor","docId":"developer/framework/product/system-monitor","unlisted":false}],"href":"/developer/product"}],"href":"/developer/framework/"}],"releasesSidebar":[{"type":"category","label":"Changelog","collapsible":true,"collapsed":true,"items":[{"type":"link","label":"v0.4.9","href":"/changelog/changelog-v0.4.9","docId":"releases/changelog/changelog-v0.4.9","unlisted":false},{"type":"link","label":"v0.4.8","href":"/changelog/changelog-v0.4.8","docId":"releases/changelog/changelog-v0.4.8","unlisted":false},{"type":"link","label":"v0.4.7","href":"/changelog/changelog-v0.4.7","docId":"releases/changelog/changelog-v0.4.7","unlisted":false},{"type":"link","label":"v0.4.6","href":"/changelog/changelog-v0.4.6","docId":"releases/changelog/changelog-v0.4.6","unlisted":false},{"type":"link","label":"v0.4.5","href":"/changelog/changelog-v0.4.5","docId":"releases/changelog/changelog-v0.4.5","unlisted":false},{"type":"link","label":"v0.4.4","href":"/changelog/changelog-v0.4.4","docId":"releases/changelog/changelog-v0.4.4","unlisted":false},{"type":"link","label":"v0.4.3","href":"/changelog/changelog-v0.4.3","docId":"releases/changelog/changelog-v0.4.3","unlisted":false},{"type":"link","label":"v0.4.2","href":"/changelog/changelog-v0.4.2","docId":"releases/changelog/changelog-v0.4.2","unlisted":false},{"type":"link","label":"v0.4.1","href":"/changelog/changelog-v0.4.1","docId":"releases/changelog/changelog-v0.4.1","unlisted":false},{"type":"link","label":"v0.4.0","href":"/changelog/changelog-v0.4.0","docId":"releases/changelog/changelog-v0.4.0","unlisted":false},{"type":"link","label":"v0.3.3","href":"/changelog/changelog-v0.3.3","docId":"releases/changelog/changelog-v0.3.3","unlisted":false},{"type":"link","label":"v0.3.2","href":"/changelog/changelog-v0.3.2","docId":"releases/changelog/changelog-v0.3.2","unlisted":false},{"type":"link","label":"v0.3.1","href":"/changelog/changelog-v0.3.1","docId":"releases/changelog/changelog-v0.3.1","unlisted":false},{"type":"link","label":"v0.3.0","href":"/changelog/changelog-v0.3.0","docId":"releases/changelog/changelog-v0.3.0","unlisted":false},{"type":"link","label":"v0.2.3","href":"/changelog/changelog-v0.2.3","docId":"releases/changelog/changelog-v0.2.3","unlisted":false},{"type":"link","label":"v0.2.2","href":"/changelog/changelog-v0.2.2","docId":"releases/changelog/changelog-v0.2.2","unlisted":false},{"type":"link","label":"v0.2.1","href":"/changelog/changelog-v0.2.1","docId":"releases/changelog/changelog-v0.2.1","unlisted":false},{"type":"link","label":"v0.2.0","href":"/changelog/changelog-v0.2.0","docId":"releases/changelog/changelog-v0.2.0","unlisted":false}],"href":"/changelog"}]},"docs":{"about/2035":{"id":"about/2035","title":"Jan\'s Vision for 2035","description":"Jan 2035: A Robotics Company"},"about/about":{"id":"about/about","title":"About Jan","description":"Jan is a desktop application that turns computers into thinking machines.","sidebar":"aboutSidebar"},"about/faq":{"id":"about/faq","title":"Frequently Asked Questions (FAQ) - Jan","description":"What is Jan?","sidebar":"aboutSidebar"},"about/roadmap":{"id":"about/roadmap","title":"Roadmap","description":"- ] [Immediate Roadmap on Github"},"about/vision":{"id":"about/vision","title":"Jan\'s Vision","description":"Jan is a desktop application that turns computers into thinking machines."},"acknowledgements":{"id":"acknowledgements","title":"Acknowledgements","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"community/community":{"id":"community/community","title":"Jan\'s Community","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"developer/framework/engineering/assistants":{"id":"developer/framework/engineering/assistants","title":"Assistants","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/chats":{"id":"developer/framework/engineering/chats","title":"Chats","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/engine":{"id":"developer/framework/engineering/engine","title":"Engine","description":"Currently Under Development","sidebar":"developerSidebar"},"developer/framework/engineering/files":{"id":"developer/framework/engineering/files","title":"Files","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/messages":{"id":"developer/framework/engineering/messages","title":"Messages","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/models":{"id":"developer/framework/engineering/models","title":"Models","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/README":{"id":"developer/framework/engineering/README","title":"Engineering Specs","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/engineering/threads":{"id":"developer/framework/engineering/threads","title":"Threads","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/chat":{"id":"developer/framework/product/chat","title":"Chat","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/hub":{"id":"developer/framework/product/hub","title":"Hub","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/jan":{"id":"developer/framework/product/jan","title":"Jan (The Default Assistant)","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/README":{"id":"developer/framework/product/README","title":"Product Specs","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/settings":{"id":"developer/framework/product/settings","title":"Settings","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/product/system-monitor":{"id":"developer/framework/product/system-monitor","title":"System Monitor","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/framework/README":{"id":"developer/framework/README","title":"Framework","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/architecture":{"id":"developer/overview/architecture","title":"Architecture","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/file-based":{"id":"developer/overview/file-based","title":"File-based Approach","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/install-and-prerequisites":{"id":"developer/overview/install-and-prerequisites","title":"Installation and Prerequisites","description":"Guide to install and setup Jan for development.","sidebar":"developerSidebar"},"developer/overview/README":{"id":"developer/overview/README","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"developer/overview/user-interface":{"id":"developer/overview/user-interface","title":"User Interface","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"developerSidebar"},"ecosystem/ecosystem":{"id":"ecosystem/ecosystem","title":"Ecosystem","description":"","sidebar":"ecosystemSidebar"},"events/hcmc-oct23":{"id":"events/hcmc-oct23","title":"Jan\'s AI Hacker House (Ho Chi Minh City)","description":"24-27 Oct 2023, District 3, HCMC. AI-focused talks, workshops and social events. Hosted by Jan.ai"},"events/nvidia-llm-day-nov-23":{"id":"events/nvidia-llm-day-nov-23","title":"Nov 23: Nvidia GenAI Day","description":"Nvidia\'s LLM Day"},"features/agents-framework":{"id":"features/agents-framework","title":"Agents Framework","description":"","sidebar":"productSidebar"},"features/api-server":{"id":"features/api-server","title":"API Server","description":"","sidebar":"productSidebar"},"features/data-security":{"id":"features/data-security","title":"Data Security","description":"","sidebar":"productSidebar"},"features/extensions-framework":{"id":"features/extensions-framework","title":"Extensions Framework","description":"","sidebar":"productSidebar"},"features/features":{"id":"features/features","title":"Features","description":"","sidebar":"productSidebar"},"features/local":{"id":"features/local","title":"Local & Self-Hosted AI","description":"","sidebar":"productSidebar"},"features/remote":{"id":"features/remote","title":"OpenAI API Support (and others)","description":"","sidebar":"productSidebar"},"foundry/foundry":{"id":"foundry/foundry","title":"foundry","description":""},"guides/extensions/extensions":{"id":"guides/extensions/extensions","title":"What are Jan Extensions?","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/get-started/hardware-setup":{"id":"guides/get-started/hardware-setup","title":"Hardware Setup","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/get-started/overview":{"id":"guides/get-started/overview","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/get-started/quickstart":{"id":"guides/get-started/quickstart","title":"Quickstart","description":"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.","sidebar":"guidesSidebar"},"guides/get-started/settingup-gpu":{"id":"guides/get-started/settingup-gpu","title":"Setting Up GPU","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/inference/overview-inference":{"id":"guides/inference/overview-inference","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/installation/docker":{"id":"guides/installation/docker","title":"Install with Docker","description":"A step-by-step guide to install Jan using Docker."},"guides/installation/linux":{"id":"guides/installation/linux","title":"Install on Linux","description":"A step-by-step guide to install Jan on your Linux."},"guides/installation/mac":{"id":"guides/installation/mac","title":"Install on Mac","description":"A step-by-step guide to install Jan on your Mac."},"guides/installation/README":{"id":"guides/installation/README","title":"Installation","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/installation/windows":{"id":"guides/installation/windows","title":"Install on Windows","description":"A step-by-step guide to install Jan on your Windows."},"guides/integrations/crewai":{"id":"guides/integrations/crewai","title":"CrewAI","description":"A step-by-step guide on how to integrate Jan with CrewAI."},"guides/integrations/discord":{"id":"guides/integrations/discord","title":"Discord","description":"A step-by-step guide on how to integrate Jan with a Discord bot.","sidebar":"guidesSidebar"},"guides/integrations/interpreter":{"id":"guides/integrations/interpreter","title":"Open Interpreter","description":"A step-by-step guide on how to integrate Jan with Open Interpreter.","sidebar":"guidesSidebar"},"guides/integrations/overview-integration":{"id":"guides/integrations/overview-integration","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/integrations/raycast":{"id":"guides/integrations/raycast","title":"Raycast","description":"A step-by-step guide on how to integrate Jan with Raycast.","sidebar":"guidesSidebar"},"guides/integrations/README":{"id":"guides/integrations/README","title":"Integrations","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/integrations/router":{"id":"guides/integrations/router","title":"OpenRouter","description":"A step-by-step guide on how to integrate Jan with OpenRouter.","sidebar":"guidesSidebar"},"guides/integrations/unsloth":{"id":"guides/integrations/unsloth","title":"Unsloth","description":"A step-by-step guide on how to integrate Jan with Unsloth."},"guides/integrations/vscode":{"id":"guides/integrations/vscode","title":"Continue Integration","description":"A step-by-step guide on how to integrate Jan with Continue and VS Code.","sidebar":"guidesSidebar"},"guides/local-providers/llamacpp":{"id":"guides/local-providers/llamacpp","title":"Llama.cpp Extension","description":"A step-by-step guide on how to customize the LlamaCPP extension.","sidebar":"guidesSidebar"},"guides/local-providers/lmstudio":{"id":"guides/local-providers/lmstudio","title":"LM Studio","description":"A step-by-step guide on how to integrate Jan with LM Studio.","sidebar":"guidesSidebar"},"guides/local-providers/ollama":{"id":"guides/local-providers/ollama","title":"Ollama","description":"A step-by-step guide on how to integrate Jan with Ollama.","sidebar":"guidesSidebar"},"guides/local-providers/README":{"id":"guides/local-providers/README","title":"Local Engines","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/local-providers/tensorrt":{"id":"guides/local-providers/tensorrt","title":"TensorRT-LLM Extension","description":"A step-by-step guide on how to customize the TensorRT-LLM extension.","sidebar":"guidesSidebar"},"guides/providers/tensorrt-llm":{"id":"guides/providers/tensorrt-llm","title":"TensorRT-LLM","description":"TensorRT-LLM support was launched in 0.4.9, and should be regarded as an Experimental feature."},"guides/remote-providers/claude":{"id":"guides/remote-providers/claude","title":"Claude","description":"A step-by-step guide on how to integrate Jan with LM Studio."},"guides/remote-providers/groq":{"id":"guides/remote-providers/groq","title":"Groq API","description":"Learn how to integrate Groq API with Jan for enhanced functionality.","sidebar":"guidesSidebar"},"guides/remote-providers/mistral":{"id":"guides/remote-providers/mistral","title":"Mistral API","description":"A step-by-step guide on how to integrate Jan with Mistral AI.","sidebar":"guidesSidebar"},"guides/remote-providers/openai":{"id":"guides/remote-providers/openai","title":"OpenAI API","description":"A step-by-step guide on how to integrate Jan with Azure OpenAI.","sidebar":"guidesSidebar"},"guides/remote-providers/README":{"id":"guides/remote-providers/README","title":"Remote Engines","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/remote-providers/remote-server-integration":{"id":"guides/remote-providers/remote-server-integration","title":"Any OAI Compatible Server","description":"A step-by-step guide on how to set up Jan to connect with any remote or local API server.","sidebar":"guidesSidebar"},"guides/troubleshooting":{"id":"guides/troubleshooting","title":"Troubleshooting","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/advanced-settings":{"id":"guides/user-guides/advanced-settings","title":"Advanced Settings","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/jan-data-folder":{"id":"guides/user-guides/jan-data-folder","title":"Jan Data Folder","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/user-guides/local-server":{"id":"guides/user-guides/local-server","title":"Local API Server","description":"A step-by-step guide to start Jan Local Server.","sidebar":"guidesSidebar"},"guides/user-guides/manage-assistants":{"id":"guides/user-guides/manage-assistants","title":"Manage Assistants","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/manage-models":{"id":"guides/user-guides/manage-models","title":"Manage Models","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"guides/user-guides/manage-threads":{"id":"guides/user-guides/manage-threads","title":"Manage Threads","description":"Manage your interaction with AI locally.","sidebar":"guidesSidebar"},"guides/user-guides/overview-guides":{"id":"guides/user-guides/overview-guides","title":"Overview","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"guides/user-guides/use-tools":{"id":"guides/user-guides/use-tools","title":"Use Tools","description":"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"guidesSidebar"},"hardware/community":{"id":"hardware/community","title":"Hardware Examples","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server."},"hardware/concepts/chassis":{"id":"hardware/concepts/chassis","title":"Chassis","description":""},"hardware/concepts/concepts":{"id":"hardware/concepts/concepts","title":"Anatomy of a Thinking Machine","description":"- Cover the difference between CPU/RAM and GPU/VRAM"},"hardware/concepts/cpu-and-ram":{"id":"hardware/concepts/cpu-and-ram","title":"CPU","description":"- CPU\'s role vs GPU"},"hardware/concepts/gpu-and-vram":{"id":"hardware/concepts/gpu-and-vram","title":"GPUs and VRAM","description":"What Is a GPU?"},"hardware/concepts/motherboard":{"id":"hardware/concepts/motherboard","title":"Motherboard","description":"- PCIe lanes that go to the processor (not Chipset)"},"hardware/concepts/network":{"id":"hardware/concepts/network","title":"Network","description":""},"hardware/concepts/power":{"id":"hardware/concepts/power","title":"Power Supply","description":""},"hardware/concepts/storage":{"id":"hardware/concepts/storage","title":"Storage","description":""},"hardware/examples/4090x2-@dan-jan":{"id":"hardware/examples/4090x2-@dan-jan","title":"2 x 4090 Workstation","description":"Jan uses a 2 x 4090 Workstation to run Codellama for internal use."},"hardware/hardware":{"id":"hardware/hardware","title":"Introduction","description":""},"hardware/overview/cloud-vs-self-hosting":{"id":"hardware/overview/cloud-vs-self-hosting","title":"Cloud vs. Self-hosting Your AI","description":"The choice of how to run your AI - on GPU cloud services, on-prem, or just using an API provider - involves various trade-offs. The following is a naive exploration of the pros and cons of renting vs self-hosting."},"hardware/overview/cpu-vs-gpu":{"id":"hardware/overview/cpu-vs-gpu","title":"GPU vs CPU What\'s the Difference?","description":"CPU vs. GPU"},"hardware/recommendations/by-budget":{"id":"hardware/recommendations/by-budget","title":"Recommended AI Hardware by Budget","description":"Warning: Do your own research before any purchase. Jan is not liable for compatibility, performance or other issues. Products can become outdated quickly."},"hardware/recommendations/by-hardware":{"id":"hardware/recommendations/by-hardware","title":"Selecting AI Hardware","description":"When selecting a GPU for LLMs, remember that it\'s not just about the GPU itself. Consider the synergy with other components in your PC:"},"hardware/recommendations/by-model":{"id":"hardware/recommendations/by-model","title":"Recommended AI Hardware by Model","description":"Codellama 34b"},"hardware/recommendations/by-usecase":{"id":"hardware/recommendations/by-usecase","title":"Recommended AI Hardware by Use Case","description":"Which AI Hardware to Choose Based on Your Use Case"},"how-we-work":{"id":"how-we-work","title":"How We Work","description":"How we work at Jan","sidebar":"aboutSidebar"},"how-we-work/analytics/analytics":{"id":"how-we-work/analytics/analytics","title":"Analytics","description":"Jan\'s Analytics philosophy and implementation","sidebar":"aboutSidebar"},"how-we-work/engineering/ci-cd":{"id":"how-we-work/engineering/ci-cd","title":"CI & CD","description":"Gitflow","sidebar":"aboutSidebar"},"how-we-work/engineering/engineering":{"id":"how-we-work/engineering/engineering","title":"Engineering","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"how-we-work/engineering/qa":{"id":"how-we-work/engineering/qa","title":"QA","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"aboutSidebar"},"how-we-work/product-design/product-design":{"id":"how-we-work/product-design/product-design","title":"Product & Design","description":"How we work on product design","sidebar":"aboutSidebar"},"how-we-work/project-management/project-management":{"id":"how-we-work/project-management/project-management","title":"Project Management","description":"Project management at Jan","sidebar":"aboutSidebar"},"how-we-work/strategy/strategy":{"id":"how-we-work/strategy/strategy","title":"Strategy","description":"We only have 2 planning parameters:","sidebar":"aboutSidebar"},"how-we-work/website-docs/website-docs":{"id":"how-we-work/website-docs/website-docs","title":"Website & Docs","description":"Information about the Jan website and documentation.","sidebar":"aboutSidebar"},"integrations":{"id":"integrations","title":"Integrations","description":"","sidebar":"ecosystemSidebar"},"integrations/langchain":{"id":"integrations/langchain","title":"Langchain","description":"WIP","sidebar":"ecosystemSidebar"},"integrations/llamacpp":{"id":"integrations/llamacpp","title":"llama.cpp","description":"Quicklinks","sidebar":"ecosystemSidebar"},"integrations/ollama":{"id":"integrations/ollama","title":"Ollama","description":"Requested, committed, but not started","sidebar":"ecosystemSidebar"},"integrations/openai":{"id":"integrations/openai","title":"OpenAI","description":"Quicklinks","sidebar":"ecosystemSidebar"},"integrations/openrouter":{"id":"integrations/openrouter","title":"OpenRouter","description":"Requested, committed, but not started","sidebar":"ecosystemSidebar"},"partners/become-a-partner":{"id":"partners/become-a-partner","title":"Become a Partner","description":"","sidebar":"ecosystemSidebar"},"partners/partners":{"id":"partners/partners","title":"Partners","description":"","sidebar":"ecosystemSidebar"},"pending-content/blogpost/finetune-with-docs":{"id":"pending-content/blogpost/finetune-with-docs","title":"How to Fine-tune Large Language Models - A Tutorial","description":"Guide on Finetuning Large Language Models with Personal Dataset"},"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives":{"id":"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives","title":"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B","description":"Creating Open Source Alternatives to Outperform ChatGPT"},"platforms/desktop":{"id":"platforms/desktop","title":"Jan Desktop","description":"Turn your computer into an AI PC","sidebar":"productSidebar"},"platforms/hub":{"id":"platforms/hub","title":"Jan Hub","description":""},"platforms/mobile":{"id":"platforms/mobile","title":"Jan Mobile","description":"Jan Mobile allows you to bring your AI on the go"},"pricing/pricing":{"id":"pricing/pricing","title":"Pricing","description":"Pricing for Jan","sidebar":"pricingSidebar"},"privacy/privacy":{"id":"privacy/privacy","title":"Privacy - Jan","description":"\u2757This privacy policy only pertains to the DEPRECATED Jan Mobile Application in the iOS and Android app store."},"releases/changelog/changelog-v0.2.0":{"id":"releases/changelog/changelog-v0.2.0","title":"v0.2.0","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.2.1":{"id":"releases/changelog/changelog-v0.2.1","title":"v0.2.1","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.2.2":{"id":"releases/changelog/changelog-v0.2.2","title":"v0.2.2","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.2.3":{"id":"releases/changelog/changelog-v0.2.3","title":"v0.2.3","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.0":{"id":"releases/changelog/changelog-v0.3.0","title":"v0.3.0","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.1":{"id":"releases/changelog/changelog-v0.3.1","title":"v0.3.1","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.2":{"id":"releases/changelog/changelog-v0.3.2","title":"v0.3.2","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.3.3":{"id":"releases/changelog/changelog-v0.3.3","title":"v0.3.3","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.0":{"id":"releases/changelog/changelog-v0.4.0","title":"v0.4.0","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.1":{"id":"releases/changelog/changelog-v0.4.1","title":"v0.4.1","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.2":{"id":"releases/changelog/changelog-v0.4.2","title":"v0.4.2","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.3":{"id":"releases/changelog/changelog-v0.4.3","title":"v0.4.3","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.4":{"id":"releases/changelog/changelog-v0.4.4","title":"v0.4.4","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.5":{"id":"releases/changelog/changelog-v0.4.5","title":"v0.4.5","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.6":{"id":"releases/changelog/changelog-v0.4.6","title":"v0.4.6","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.7":{"id":"releases/changelog/changelog-v0.4.7","title":"v0.4.7","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.8":{"id":"releases/changelog/changelog-v0.4.8","title":"v0.4.8","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/changelog-v0.4.9":{"id":"releases/changelog/changelog-v0.4.9","title":"v0.4.9","description":"For more details, GitHub Issues","sidebar":"releasesSidebar"},"releases/changelog/README":{"id":"releases/changelog/README","title":"Changelog","description":"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.","sidebar":"releasesSidebar"},"server-suite/admin-console":{"id":"server-suite/admin-console","title":"Admin Console","description":""},"server-suite/audit-compliance":{"id":"server-suite/audit-compliance","title":"Audit & Compliance","description":""},"server-suite/enterprise":{"id":"server-suite/enterprise","title":"Jan Enterprise","description":"Built for Enterprise Deployments"},"server-suite/home-server":{"id":"server-suite/home-server","title":"Jan Home Server","description":"Built for Home Servers","sidebar":"productSidebar"},"server-suite/identity-access-management":{"id":"server-suite/identity-access-management","title":"Identity & Access Control","description":""},"server-suite/observability":{"id":"server-suite/observability","title":"Observability","description":""},"solutions/ai-employees":{"id":"solutions/ai-employees","title":"AI Employees","description":""},"solutions/ai-pc":{"id":"solutions/ai-pc","title":"AI PC","description":"","sidebar":"solutionSidebar"},"solutions/chatgpt-alternative":{"id":"solutions/chatgpt-alternative","title":"Self-hosted alternative to OpenAI\'s Platform","description":"","sidebar":"solutionSidebar"},"solutions/consultants":{"id":"solutions/consultants","title":"Software Consultants","description":"","sidebar":"solutionSidebar"},"solutions/developers":{"id":"solutions/developers","title":"Developers","description":"","sidebar":"solutionSidebar"},"solutions/enterprises":{"id":"solutions/enterprises","title":"Enterprises","description":"","sidebar":"solutionSidebar"},"solutions/finance":{"id":"solutions/finance","title":"Finance","description":"","sidebar":"solutionSidebar"},"solutions/government":{"id":"solutions/government","title":"Government","description":"","sidebar":"solutionSidebar"},"solutions/healthcare":{"id":"solutions/healthcare","title":"Healthcare","description":"","sidebar":"solutionSidebar"},"solutions/legal":{"id":"solutions/legal","title":"Legal","description":"","sidebar":"solutionSidebar"},"solutions/startups":{"id":"solutions/startups","title":"Startups","description":"","sidebar":"solutionSidebar"},"studio/studio":{"id":"studio/studio","title":"studio","description":""},"support/support":{"id":"support/support","title":"Support - Jan","description":"- Bugs & requests: file a GitHub ticket here"},"team/contributor-program":{"id":"team/contributor-program","title":"Contributor Program","description":"","sidebar":"aboutSidebar"},"team/join-us":{"id":"team/join-us","title":"Join us","description":"- [ ] Explain Core Team, Contributors and Open Source approach","sidebar":"aboutSidebar"},"team/team":{"id":"team/team","title":"Who we are","description":"What\'s Jan the company about?","sidebar":"aboutSidebar"},"template/QA_script":{"id":"template/QA_script","title":"Regression test","description":"Release Version: v0.4.7"},"wall-of-love":{"id":"wall-of-love","title":"Wall of Love \u2764\ufe0f","description":"Check out what our amazing users are saying about Jan!","sidebar":"aboutSidebar"}}}')}}]); \ No newline at end of file diff --git a/assets/js/9456c9fc.4ef5d396.js b/assets/js/9456c9fc.4ef5d396.js deleted file mode 100644 index c3431f10..00000000 --- a/assets/js/9456c9fc.4ef5d396.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8236],{80384:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>u,frontMatter:()=>a,metadata:()=>i,toc:()=>l});var n=r(74848),o=r(28453);const a={title:"Chat",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,i={id:"developer/framework/product/chat",title:"Chat",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/chat.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/chat",permalink:"/developer/framework/product/chat",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/chat.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Chat",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Product Specs",permalink:"/developer/product"},next:{title:"Hub",permalink:"/developer/framework/product/hub"}},c={},l=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2}];function d(e){const t={a:"a",code:"code",h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,o.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(t.h2,{id:"overview",children:"Overview"}),"\n",(0,n.jsxs)(t.p,{children:["A home screen for users to chat with ",(0,n.jsx)(t.a,{href:"/docs/engineering/assistants",children:"assistants"})," via conversation ",(0,n.jsx)(t.a,{href:"/docs/engineering/threads",children:"threads"}),"."]}),"\n",(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"alt text",src:r(53505).A+"",width:"1440",height:"1032"})}),"\n",(0,n.jsx)(t.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,n.jsxs)(t.ul,{children:["\n",(0,n.jsxs)(t.li,{children:["Users can chat with ",(0,n.jsx)(t.code,{children:"Jan"})," the default assistant"]}),"\n",(0,n.jsxs)(t.li,{children:["Users can customize chat settings like model parameters via both the GUI & ",(0,n.jsx)(t.code,{children:"thread.json"})]}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d(e)}},53505:(e,t,r)=>{r.d(t,{A:()=>n});const n=r.p+"assets/images/chat-screen-da356fa77a722eed8ab4261067c05197.png"},28453:(e,t,r)=>{r.d(t,{R:()=>s,x:()=>i});var n=r(96540);const o={},a=n.createContext(o);function s(e){const t=n.useContext(a);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),n.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9456c9fc.d1de04e3.js b/assets/js/9456c9fc.d1de04e3.js new file mode 100644 index 00000000..6a76b97b --- /dev/null +++ b/assets/js/9456c9fc.d1de04e3.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8236],{80384:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>u,frontMatter:()=>a,metadata:()=>i,toc:()=>l});var n=r(74848),o=r(28453);const a={title:"Chat",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,i={id:"developer/framework/product/chat",title:"Chat",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/chat.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/chat",permalink:"/developer/framework/product/chat",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/chat.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Chat",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Product Specs",permalink:"/developer/product"},next:{title:"Hub",permalink:"/developer/framework/product/hub"}},c={},l=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2}];function d(e){const t={a:"a",code:"code",h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,o.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(t.h2,{id:"overview",children:"Overview"}),"\n",(0,n.jsxs)(t.p,{children:["A home screen for users to chat with ",(0,n.jsx)(t.a,{href:"/docs/engineering/assistants",children:"assistants"})," via conversation ",(0,n.jsx)(t.a,{href:"/docs/engineering/threads",children:"threads"}),"."]}),"\n",(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"alt text",src:r(53505).A+"",width:"1440",height:"1032"})}),"\n",(0,n.jsx)(t.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,n.jsxs)(t.ul,{children:["\n",(0,n.jsxs)(t.li,{children:["Users can chat with ",(0,n.jsx)(t.code,{children:"Jan"})," the default assistant"]}),"\n",(0,n.jsxs)(t.li,{children:["Users can customize chat settings like model parameters via both the GUI & ",(0,n.jsx)(t.code,{children:"thread.json"})]}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d(e)}},53505:(e,t,r)=>{r.d(t,{A:()=>n});const n=r.p+"assets/images/chat-screen-da356fa77a722eed8ab4261067c05197.png"},28453:(e,t,r)=>{r.d(t,{R:()=>s,x:()=>i});var n=r(96540);const o={},a=n.createContext(o);function s(e){const t=n.useContext(a);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),n.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/96809c51.4a1f39b8.js b/assets/js/96809c51.4a1f39b8.js deleted file mode 100644 index a1cabb53..00000000 --- a/assets/js/96809c51.4a1f39b8.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9364],{34945:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>c,frontMatter:()=>r,metadata:()=>o,toc:()=>d});var s=n(74848),i=n(28453);const r={title:"Manage Threads",slug:"/guides/threads",description:"Manage your interaction with AI locally.",sidebar_position:9,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","threads","chat history","thread history"]},a=void 0,o={id:"guides/user-guides/manage-threads",title:"Manage Threads",description:"Manage your interaction with AI locally.",source:"@site/docs/guides/user-guides/manage-threads.mdx",sourceDirName:"guides/user-guides",slug:"/guides/threads",permalink:"/guides/threads",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/manage-threads.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:9,frontMatter:{title:"Manage Threads",slug:"/guides/threads",description:"Manage your interaction with AI locally.",sidebar_position:9,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","threads","chat history","thread history"]},sidebar:"guidesSidebar",previous:{title:"Manage Models",permalink:"/guides/models"},next:{title:"Local API Server",permalink:"/guides/local-api"}},l={},d=[{value:"View Thread History",id:"view-thread-history",level:3},{value:"Manage the Threads via Folder",id:"manage-the-threads-via-folder",level:3},{value:"Clean Threads History",id:"clean-threads-history",level:3},{value:"Delete Threads History",id:"delete-threads-history",level:3}];function h(e){const t={admonition:"admonition",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:"Jan provides a straightforward and private solution for managing your threads with AI on your own device. As you interact with AI using Jan, you'll accumulate a history of threads.\nJan offers easy tools to organize, delete, or review your past threads with AI. This guide will show you how to keep your threads private and well-organized."}),"\n",(0,s.jsx)(t.h3,{id:"view-thread-history",children:"View Thread History"}),"\n",(0,s.jsx)(t.p,{children:"To view your thread history, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the main dashboard."}),"\n",(0,s.jsx)(t.li,{children:"Locate the list of threads screen on the left side."}),"\n",(0,s.jsx)(t.li,{children:"To view a specific thread, simply choose the one you're interested in and then scroll up or down to explore the entire conversation."}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"manage-the-threads-via-folder",children:"Manage the Threads via Folder"}),"\n",(0,s.jsx)(t.p,{children:"To manage your thread history and configurations, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Thread that you want to manage via the list of threads on the left side of the dashboard."}),"\n",(0,s.jsxs)(t.li,{children:["Click on the ",(0,s.jsx)(t.strong,{children:"three dots (\u22ee)"})," in the Thread section."]}),"\n",(0,s.jsxs)(t.li,{children:["There are two available options to select:","\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsxs)(t.li,{children:[(0,s.jsx)(t.strong,{children:"Reveal in Finder"}),": Opens the folder containing the thread history and configurations."]}),"\n",(0,s.jsxs)(t.li,{children:[(0,s.jsx)(t.strong,{children:"View as JSON"}),": Opens the thread.json file in your default browser."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"clean-threads-history",children:"Clean Threads History"}),"\n",(0,s.jsx)(t.p,{children:"To clean all the messages from a thread, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Thread that you want to clean."}),"\n",(0,s.jsxs)(t.li,{children:["Click on the ",(0,s.jsx)(t.strong,{children:"three dots (\u22ee)"})," in the Thread section."]}),"\n",(0,s.jsxs)(t.li,{children:["Sleect the ",(0,s.jsx)(t.strong,{children:"Clean Thread"})," button."]}),"\n"]}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsx)(t.p,{children:"This will delete all messages in the thread while keeping the thread settings."})}),"\n",(0,s.jsx)(t.h3,{id:"delete-threads-history",children:"Delete Threads History"}),"\n",(0,s.jsx)(t.p,{children:"To delete a thread, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Thread that you want to delete."}),"\n",(0,s.jsxs)(t.li,{children:["Click on the ",(0,s.jsx)(t.strong,{children:"three dots (\u22ee)"})," in the Thread section."]}),"\n",(0,s.jsxs)(t.li,{children:["Sleect the ",(0,s.jsx)(t.strong,{children:"Delete Thread"})," button."]}),"\n"]}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsx)(t.p,{children:"This will delete all messages and the thread settings."})})]})}function c(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>o});var s=n(96540);const i={},r=s.createContext(i);function a(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function o(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/96809c51.94008737.js b/assets/js/96809c51.94008737.js new file mode 100644 index 00000000..cec26e4f --- /dev/null +++ b/assets/js/96809c51.94008737.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9364],{34945:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>c,frontMatter:()=>r,metadata:()=>o,toc:()=>d});var s=n(74848),i=n(28453);const r={title:"Manage Threads",slug:"/guides/threads",description:"Manage your interaction with AI locally.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","threads","chat history","thread history"]},a=void 0,o={id:"guides/user-guides/manage-threads",title:"Manage Threads",description:"Manage your interaction with AI locally.",source:"@site/docs/guides/user-guides/manage-threads.mdx",sourceDirName:"guides/user-guides",slug:"/guides/threads",permalink:"/guides/threads",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/manage-threads.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Manage Threads",slug:"/guides/threads",description:"Manage your interaction with AI locally.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","threads","chat history","thread history"]},sidebar:"guidesSidebar",previous:{title:"Manage Assistants",permalink:"/guides/assistants"},next:{title:"Use Tools",permalink:"/guides/tools"}},l={},d=[{value:"View Thread History",id:"view-thread-history",level:3},{value:"Manage the Threads via Folder",id:"manage-the-threads-via-folder",level:3},{value:"Clean Threads History",id:"clean-threads-history",level:3},{value:"Delete Threads History",id:"delete-threads-history",level:3}];function h(e){const t={admonition:"admonition",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:"Jan provides a straightforward and private solution for managing your threads with AI on your own device. As you interact with AI using Jan, you'll accumulate a history of threads.\nJan offers easy tools to organize, delete, or review your past threads with AI. This guide will show you how to keep your threads private and well-organized."}),"\n",(0,s.jsx)(t.h3,{id:"view-thread-history",children:"View Thread History"}),"\n",(0,s.jsx)(t.p,{children:"To view your thread history, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the main dashboard."}),"\n",(0,s.jsx)(t.li,{children:"Locate the list of threads screen on the left side."}),"\n",(0,s.jsx)(t.li,{children:"To view a specific thread, simply choose the one you're interested in and then scroll up or down to explore the entire conversation."}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"manage-the-threads-via-folder",children:"Manage the Threads via Folder"}),"\n",(0,s.jsx)(t.p,{children:"To manage your thread history and configurations, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Thread that you want to manage via the list of threads on the left side of the dashboard."}),"\n",(0,s.jsxs)(t.li,{children:["Click on the ",(0,s.jsx)(t.strong,{children:"three dots (\u22ee)"})," in the Thread section."]}),"\n",(0,s.jsxs)(t.li,{children:["There are two available options to select:","\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsxs)(t.li,{children:[(0,s.jsx)(t.strong,{children:"Reveal in Finder"}),": Opens the folder containing the thread history and configurations."]}),"\n",(0,s.jsxs)(t.li,{children:[(0,s.jsx)(t.strong,{children:"View as JSON"}),": Opens the thread.json file in your default browser."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"clean-threads-history",children:"Clean Threads History"}),"\n",(0,s.jsx)(t.p,{children:"To clean all the messages from a thread, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Thread that you want to clean."}),"\n",(0,s.jsxs)(t.li,{children:["Click on the ",(0,s.jsx)(t.strong,{children:"three dots (\u22ee)"})," in the Thread section."]}),"\n",(0,s.jsxs)(t.li,{children:["Sleect the ",(0,s.jsx)(t.strong,{children:"Clean Thread"})," button."]}),"\n"]}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsx)(t.p,{children:"This will delete all messages in the thread while keeping the thread settings."})}),"\n",(0,s.jsx)(t.h3,{id:"delete-threads-history",children:"Delete Threads History"}),"\n",(0,s.jsx)(t.p,{children:"To delete a thread, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Thread that you want to delete."}),"\n",(0,s.jsxs)(t.li,{children:["Click on the ",(0,s.jsx)(t.strong,{children:"three dots (\u22ee)"})," in the Thread section."]}),"\n",(0,s.jsxs)(t.li,{children:["Sleect the ",(0,s.jsx)(t.strong,{children:"Delete Thread"})," button."]}),"\n"]}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsx)(t.p,{children:"This will delete all messages and the thread settings."})})]})}function c(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>a,x:()=>o});var s=n(96540);const i={},r=s.createContext(i);function a(e){const t=s.useContext(r);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function o(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:a(e.components),s.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9a70be8c.9aa7a638.js b/assets/js/9a70be8c.9aa7a638.js deleted file mode 100644 index 79f352fe..00000000 --- a/assets/js/9a70be8c.9aa7a638.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2712],{99942:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>u,contentTitle:()=>a,default:()=>p,frontMatter:()=>o,metadata:()=>i,toc:()=>c});var n=r(74848),s=r(28453);const o={title:"API Server"},a=void 0,i={id:"features/api-server",title:"API Server",description:"",source:"@site/docs/features/api-server.md",sourceDirName:"features",slug:"/features/api-server",permalink:"/features/api-server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/api-server.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"API Server"},sidebar:"productSidebar",previous:{title:"OpenAI API Support (and others)",permalink:"/features/remote"},next:{title:"Extensions Framework",permalink:"/features/extensions-framework"}},u={},c=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function p(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>i});var n=r(96540);const s={},o=n.createContext(s);function a(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9a70be8c.ae8b6b98.js b/assets/js/9a70be8c.ae8b6b98.js new file mode 100644 index 00000000..e362ab37 --- /dev/null +++ b/assets/js/9a70be8c.ae8b6b98.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2712],{99942:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>u,contentTitle:()=>a,default:()=>p,frontMatter:()=>o,metadata:()=>i,toc:()=>c});var n=r(74848),s=r(28453);const o={title:"API Server"},a=void 0,i={id:"features/api-server",title:"API Server",description:"",source:"@site/docs/features/api-server.md",sourceDirName:"features",slug:"/features/api-server",permalink:"/features/api-server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/api-server.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"API Server"},sidebar:"productSidebar",previous:{title:"OpenAI API Support (and others)",permalink:"/features/remote"},next:{title:"Extensions Framework",permalink:"/features/extensions-framework"}},u={},c=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function p(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>i});var n=r(96540);const s={},o=n.createContext(s);function a(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9b2fae64.0b1d18f3.js b/assets/js/9b2fae64.0b1d18f3.js new file mode 100644 index 00000000..84a9be16 --- /dev/null +++ b/assets/js/9b2fae64.0b1d18f3.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9602],{89455:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>a,default:()=>d,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var s=n(74848),o=n(28453);const i={title:"Finance",tags:["industries"]},a=void 0,r={id:"solutions/finance",title:"Finance",description:"",source:"@site/docs/solutions/finance.md",sourceDirName:"solutions",slug:"/solutions/finance",permalink:"/solutions/finance",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/finance.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Finance",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Self-hosted alternative to OpenAI's Platform",permalink:"/solutions/chatgpt-alternative"},next:{title:"Healthcare",permalink:"/solutions/healthcare"}},c={},l=[];function u(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>a,x:()=>r});var s=n(96540);const o={},i=s.createContext(o);function a(t){const e=s.useContext(i);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function r(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:a(t.components),s.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/9b2fae64.3c186dfd.js b/assets/js/9b2fae64.3c186dfd.js deleted file mode 100644 index 0ae57522..00000000 --- a/assets/js/9b2fae64.3c186dfd.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9602],{89455:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>a,default:()=>d,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var s=n(74848),o=n(28453);const i={title:"Finance",tags:["industries"]},a=void 0,r={id:"solutions/finance",title:"Finance",description:"",source:"@site/docs/solutions/finance.md",sourceDirName:"solutions",slug:"/solutions/finance",permalink:"/solutions/finance",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/finance.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Finance",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Self-hosted alternative to OpenAI's Platform",permalink:"/solutions/chatgpt-alternative"},next:{title:"Healthcare",permalink:"/solutions/healthcare"}},c={},l=[];function u(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>a,x:()=>r});var s=n(96540);const o={},i=s.createContext(o);function a(t){const e=s.useContext(i);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function r(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:a(t.components),s.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/9b95d7dc.2d1cfb72.js b/assets/js/9b95d7dc.2d1cfb72.js new file mode 100644 index 00000000..e18c14c1 --- /dev/null +++ b/assets/js/9b95d7dc.2d1cfb72.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1032],{90054:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>i});var r=n(74848),c=n(28453);const o={title:"CPU"},s=void 0,a={id:"hardware/concepts/cpu-and-ram",title:"CPU",description:"- CPU's role vs GPU",source:"@site/docs/hardware/concepts/cpu-and-ram.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/cpu-and-ram",permalink:"/hardware/concepts/cpu-and-ram",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/cpu-and-ram.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"CPU"}},d={},i=[];function l(e){const t={li:"li",ul:"ul",...(0,c.R)(),...e.components};return(0,r.jsxs)(t.ul,{children:["\n",(0,r.jsx)(t.li,{children:"CPU's role vs GPU"}),"\n",(0,r.jsx)(t.li,{children:"Cooler + Thermal Paste"}),"\n",(0,r.jsx)(t.li,{children:"RAM"}),"\n"]})}function u(e={}){const{wrapper:t}={...(0,c.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(l,{...e})}):l(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>a});var r=n(96540);const c={},o=r.createContext(c);function s(e){const t=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(c):e.components||c:s(e.components),r.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9b95d7dc.52a4cc59.js b/assets/js/9b95d7dc.52a4cc59.js deleted file mode 100644 index 58742631..00000000 --- a/assets/js/9b95d7dc.52a4cc59.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1032],{90054:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>i});var r=n(74848),c=n(28453);const o={title:"CPU"},s=void 0,a={id:"hardware/concepts/cpu-and-ram",title:"CPU",description:"- CPU's role vs GPU",source:"@site/docs/hardware/concepts/cpu-and-ram.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/cpu-and-ram",permalink:"/hardware/concepts/cpu-and-ram",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/cpu-and-ram.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"CPU"}},d={},i=[];function l(e){const t={li:"li",ul:"ul",...(0,c.R)(),...e.components};return(0,r.jsxs)(t.ul,{children:["\n",(0,r.jsx)(t.li,{children:"CPU's role vs GPU"}),"\n",(0,r.jsx)(t.li,{children:"Cooler + Thermal Paste"}),"\n",(0,r.jsx)(t.li,{children:"RAM"}),"\n"]})}function u(e={}){const{wrapper:t}={...(0,c.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(l,{...e})}):l(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>a});var r=n(96540);const c={},o=r.createContext(c);function s(e){const t=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(c):e.components||c:s(e.components),r.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9c214a64.2a9c5346.js b/assets/js/9c214a64.2a9c5346.js new file mode 100644 index 00000000..30d32722 --- /dev/null +++ b/assets/js/9c214a64.2a9c5346.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[379],{96513:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>i,contentTitle:()=>o,default:()=>u,frontMatter:()=>a,metadata:()=>c,toc:()=>p});var n=r(74848),s=r(28453);const a={title:"Partners"},o=void 0,c={id:"partners/partners",title:"Partners",description:"",source:"@site/docs/partners/partners.md",sourceDirName:"partners",slug:"/partners/",permalink:"/partners/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/partners/partners.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Partners"},sidebar:"ecosystemSidebar",previous:{title:"Ecosystem",permalink:"/ecosystem/"},next:{title:"Become a Partner",permalink:"/partners/become-a-partner"}},i={},p=[];function d(t){return(0,n.jsx)(n.Fragment,{})}function u(t={}){const{wrapper:e}={...(0,s.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(d,{...t})}):d()}},28453:(t,e,r)=>{r.d(e,{R:()=>o,x:()=>c});var n=r(96540);const s={},a=n.createContext(s);function o(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:o(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/9c214a64.c7da1015.js b/assets/js/9c214a64.c7da1015.js deleted file mode 100644 index dffed01a..00000000 --- a/assets/js/9c214a64.c7da1015.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[379],{96513:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>i,contentTitle:()=>o,default:()=>u,frontMatter:()=>a,metadata:()=>c,toc:()=>p});var n=r(74848),s=r(28453);const a={title:"Partners"},o=void 0,c={id:"partners/partners",title:"Partners",description:"",source:"@site/docs/partners/partners.md",sourceDirName:"partners",slug:"/partners/",permalink:"/partners/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/partners/partners.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Partners"},sidebar:"ecosystemSidebar",previous:{title:"Ecosystem",permalink:"/ecosystem/"},next:{title:"Become a Partner",permalink:"/partners/become-a-partner"}},i={},p=[];function d(t){return(0,n.jsx)(n.Fragment,{})}function u(t={}){const{wrapper:e}={...(0,s.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(d,{...t})}):d()}},28453:(t,e,r)=>{r.d(e,{R:()=>o,x:()=>c});var n=r(96540);const s={},a=n.createContext(s);function o(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:o(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/9d26486f.5e2f2c14.js b/assets/js/9d26486f.5e2f2c14.js new file mode 100644 index 00000000..e2124379 --- /dev/null +++ b/assets/js/9d26486f.5e2f2c14.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9208],{84457:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>r,default:()=>l,frontMatter:()=>s,metadata:()=>i,toc:()=>c});var o=n(74848),a=n(28453);const s={title:"Setting Up GPU",slug:"/guides/hardware/gpu",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,i={id:"guides/get-started/settingup-gpu",title:"Setting Up GPU",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/get-started/settingup-gpu.mdx",sourceDirName:"guides/get-started",slug:"/guides/hardware/gpu",permalink:"/guides/hardware/gpu",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/settingup-gpu.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Setting Up GPU",slug:"/guides/hardware/gpu",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},u={},c=[];function d(e){const t={p:"p",...(0,a.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,a.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>i});var o=n(96540);const a={},s=o.createContext(a);function r(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9d26486f.f5c2cb6e.js b/assets/js/9d26486f.f5c2cb6e.js deleted file mode 100644 index 5c075ae9..00000000 --- a/assets/js/9d26486f.f5c2cb6e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9208],{84457:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>r,default:()=>l,frontMatter:()=>s,metadata:()=>i,toc:()=>c});var o=n(74848),a=n(28453);const s={title:"Setting Up GPU",slug:"/guides/hardware/gpu",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,i={id:"guides/get-started/settingup-gpu",title:"Setting Up GPU",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/get-started/settingup-gpu.mdx",sourceDirName:"guides/get-started",slug:"/guides/hardware/gpu",permalink:"/guides/hardware/gpu",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/settingup-gpu.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Setting Up GPU",slug:"/guides/hardware/gpu",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},u={},c=[];function d(e){const t={p:"p",...(0,a.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,a.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>i});var o=n(96540);const a={},s=o.createContext(a);function r(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9ffacb83.0ff52ecf.js b/assets/js/9ffacb83.0ff52ecf.js deleted file mode 100644 index b44dc262..00000000 --- a/assets/js/9ffacb83.0ff52ecf.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8321],{82592:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>u,frontMatter:()=>a,metadata:()=>l,toc:()=>r});var o=n(74848),s=n(28453);const a={title:"Install on Mac",sidebar_position:1,slug:"/guides/install/mac",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Mac.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","MacOs","Install on Mac","Apple devices"]},i=void 0,l={id:"guides/installation/mac",title:"Install on Mac",description:"A step-by-step guide to install Jan on your Mac.",source:"@site/docs/guides/installation/mac.mdx",sourceDirName:"guides/installation",slug:"/guides/install/mac",permalink:"/guides/install/mac",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/mac.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Install on Mac",sidebar_position:1,slug:"/guides/install/mac",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Mac.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","MacOs","Install on Mac","Apple devices"]}},c={},r=[];function d(e){const t={p:"p",...(0,s.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming soon"})}function u(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>l});var o=n(96540);const s={},a=o.createContext(s);function i(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function l(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/9ffacb83.d349a99f.js b/assets/js/9ffacb83.d349a99f.js new file mode 100644 index 00000000..d446d646 --- /dev/null +++ b/assets/js/9ffacb83.d349a99f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8321],{82592:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>u,frontMatter:()=>a,metadata:()=>l,toc:()=>r});var o=n(74848),s=n(28453);const a={title:"Install on Mac",sidebar_position:1,slug:"/guides/install/mac",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Mac.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","MacOs","Install on Mac","Apple devices"]},i=void 0,l={id:"guides/installation/mac",title:"Install on Mac",description:"A step-by-step guide to install Jan on your Mac.",source:"@site/docs/guides/installation/mac.mdx",sourceDirName:"guides/installation",slug:"/guides/install/mac",permalink:"/guides/install/mac",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/mac.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Install on Mac",sidebar_position:1,slug:"/guides/install/mac",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Mac.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","MacOs","Install on Mac","Apple devices"]}},c={},r=[];function d(e){const t={p:"p",...(0,s.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming soon"})}function u(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>l});var o=n(96540);const s={},a=o.createContext(s);function i(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function l(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a070662e.1f740160.js b/assets/js/a070662e.1f740160.js deleted file mode 100644 index 1e5c80ff..00000000 --- a/assets/js/a070662e.1f740160.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2614],{3697:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>a,contentTitle:()=>l,default:()=>u,frontMatter:()=>t,metadata:()=>o,toc:()=>d});var s=r(74848),i=r(28453);const t={title:"Installation and Prerequisites",slug:"/developer/prereq",description:"Guide to install and setup Jan for development.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","installation","prerequisites","developer setup"]},l=void 0,o={id:"developer/overview/install-and-prerequisites",title:"Installation and Prerequisites",description:"Guide to install and setup Jan for development.",source:"@site/docs/developer/01-overview/04-install-and-prerequisites.md",sourceDirName:"developer/01-overview",slug:"/developer/prereq",permalink:"/developer/prereq",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/04-install-and-prerequisites.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:4,frontMatter:{title:"Installation and Prerequisites",slug:"/developer/prereq",description:"Guide to install and setup Jan for development.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","installation","prerequisites","developer setup"]},sidebar:"developerSidebar",previous:{title:"User Interface",permalink:"/developer/ui"},next:{title:"Framework",permalink:"/developer/framework/"}},a={},d=[{value:"Requirements",id:"requirements",level:2},{value:"Hardware Requirements",id:"hardware-requirements",level:3},{value:"System Requirements",id:"system-requirements",level:3},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Instructions",id:"instructions",level:2},{value:"For Production Build",id:"for-production-build",level:2},{value:"Troubleshooting",id:"troubleshooting",level:2}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h2,{id:"requirements",children:"Requirements"}),"\n",(0,s.jsx)(n.h3,{id:"hardware-requirements",children:"Hardware Requirements"}),"\n",(0,s.jsx)(n.p,{children:"Ensure your system meets the following specifications to guarantee a smooth development experience:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Hardware Requirements"}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"system-requirements",children:"System Requirements"}),"\n",(0,s.jsx)(n.p,{children:"Make sure your operating system meets the specific requirements for Jan development:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"../../install/windows/#system-requirements",children:"Windows"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"../../install/mac/#system-requirements",children:"MacOS"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"../../install/linux/#system-requirements",children:"Linux"})}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.a,{href:"https://nodejs.org/en/",children:"Node.js"})," (version 20.0.0 or higher)"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.a,{href:"https://yarnpkg.com/",children:"yarn"})," (version 1.22.0 or higher)"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.a,{href:"https://www.gnu.org/software/make/",children:"make"})," (version 3.81 or higher)"]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"instructions",children:"Instructions"}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Clone the Repository:"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ncd jan\ngit checkout -b DESIRED_BRANCH\n"})}),"\n",(0,s.jsxs)(n.ol,{start:"2",children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Install Dependencies"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"yarn install\n"})}),"\n",(0,s.jsxs)(n.ol,{start:"3",children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Run Development and Use Jan Desktop"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"make dev\n"})}),"\n",(0,s.jsx)(n.p,{children:"This command starts the development server and opens the Jan Desktop app."}),"\n",(0,s.jsx)(n.h2,{id:"for-production-build",children:"For Production Build"}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"# Do steps 1 and 2 in the previous section\n# Build the app\nmake build\n"})}),"\n",(0,s.jsxs)(n.p,{children:["This will build the app MacOS (M1/M2/M3) for production (with code signing already done) and place the result in ",(0,s.jsx)(n.code,{children:"/electron/dist"})," folder."]}),"\n",(0,s.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,s.jsxs)(n.p,{children:["If you run into any issues due to a broken build, please check the ",(0,s.jsx)(n.a,{href:"../../troubleshooting/stuck-on-broken-build",children:"Stuck on a Broken Build"})," guide."]})]})}function u(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>l,x:()=>o});var s=r(96540);const i={},t=s.createContext(i);function l(e){const n=s.useContext(t);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:l(e.components),s.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a070662e.c9b37f83.js b/assets/js/a070662e.c9b37f83.js new file mode 100644 index 00000000..2c155fa0 --- /dev/null +++ b/assets/js/a070662e.c9b37f83.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2614],{3697:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>a,contentTitle:()=>l,default:()=>u,frontMatter:()=>t,metadata:()=>o,toc:()=>d});var s=r(74848),i=r(28453);const t={title:"Installation and Prerequisites",slug:"/developer/prereq",description:"Guide to install and setup Jan for development.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","installation","prerequisites","developer setup"]},l=void 0,o={id:"developer/overview/install-and-prerequisites",title:"Installation and Prerequisites",description:"Guide to install and setup Jan for development.",source:"@site/docs/developer/01-overview/04-install-and-prerequisites.md",sourceDirName:"developer/01-overview",slug:"/developer/prereq",permalink:"/developer/prereq",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/04-install-and-prerequisites.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:4,frontMatter:{title:"Installation and Prerequisites",slug:"/developer/prereq",description:"Guide to install and setup Jan for development.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","installation","prerequisites","developer setup"]},sidebar:"developerSidebar",previous:{title:"User Interface",permalink:"/developer/ui"},next:{title:"Framework",permalink:"/developer/framework/"}},a={},d=[{value:"Requirements",id:"requirements",level:2},{value:"Hardware Requirements",id:"hardware-requirements",level:3},{value:"System Requirements",id:"system-requirements",level:3},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Instructions",id:"instructions",level:2},{value:"For Production Build",id:"for-production-build",level:2},{value:"Troubleshooting",id:"troubleshooting",level:2}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h2,{id:"requirements",children:"Requirements"}),"\n",(0,s.jsx)(n.h3,{id:"hardware-requirements",children:"Hardware Requirements"}),"\n",(0,s.jsx)(n.p,{children:"Ensure your system meets the following specifications to guarantee a smooth development experience:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Hardware Requirements"}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"system-requirements",children:"System Requirements"}),"\n",(0,s.jsx)(n.p,{children:"Make sure your operating system meets the specific requirements for Jan development:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"../../install/windows/#system-requirements",children:"Windows"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"../../install/mac/#system-requirements",children:"MacOS"})}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.a,{href:"../../install/linux/#system-requirements",children:"Linux"})}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.a,{href:"https://nodejs.org/en/",children:"Node.js"})," (version 20.0.0 or higher)"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.a,{href:"https://yarnpkg.com/",children:"yarn"})," (version 1.22.0 or higher)"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.a,{href:"https://www.gnu.org/software/make/",children:"make"})," (version 3.81 or higher)"]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"instructions",children:"Instructions"}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Clone the Repository:"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ncd jan\ngit checkout -b DESIRED_BRANCH\n"})}),"\n",(0,s.jsxs)(n.ol,{start:"2",children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Install Dependencies"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"yarn install\n"})}),"\n",(0,s.jsxs)(n.ol,{start:"3",children:["\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.strong,{children:"Run Development and Use Jan Desktop"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"make dev\n"})}),"\n",(0,s.jsx)(n.p,{children:"This command starts the development server and opens the Jan Desktop app."}),"\n",(0,s.jsx)(n.h2,{id:"for-production-build",children:"For Production Build"}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:"# Do steps 1 and 2 in the previous section\n# Build the app\nmake build\n"})}),"\n",(0,s.jsxs)(n.p,{children:["This will build the app MacOS (M1/M2/M3) for production (with code signing already done) and place the result in ",(0,s.jsx)(n.code,{children:"/electron/dist"})," folder."]}),"\n",(0,s.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,s.jsxs)(n.p,{children:["If you run into any issues due to a broken build, please check the ",(0,s.jsx)(n.a,{href:"../../troubleshooting/stuck-on-broken-build",children:"Stuck on a Broken Build"})," guide."]})]})}function u(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>l,x:()=>o});var s=r(96540);const i={},t=s.createContext(i);function l(e){const n=s.useContext(t);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:l(e.components),s.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a0b2d528.2a38e3ef.js b/assets/js/a0b2d528.2a38e3ef.js deleted file mode 100644 index cdef4c37..00000000 --- a/assets/js/a0b2d528.2a38e3ef.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9323],{78039:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>u,frontMatter:()=>r,metadata:()=>i,toc:()=>c});var o=a(74848),n=a(28453);const r={title:"Jan Data Folder",slug:"/guides/data-folder",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:6,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","data folder","source folder","Jan data"]},s=void 0,i={id:"guides/user-guides/jan-data-folder",title:"Jan Data Folder",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/jan-data-folder.mdx",sourceDirName:"guides/user-guides",slug:"/guides/data-folder",permalink:"/guides/data-folder",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/jan-data-folder.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:6,frontMatter:{title:"Jan Data Folder",slug:"/guides/data-folder",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:6,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","data folder","source folder","Jan data"]}},d={},c=[];function l(e){const t={p:"p",...(0,n.R)(),...e.components};return(0,o.jsx)(t.p,{children:"Coming Soon"})}function u(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(l,{...e})}):l(e)}},28453:(e,t,a)=>{a.d(t,{R:()=>s,x:()=>i});var o=a(96540);const n={},r=o.createContext(n);function s(e){const t=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:s(e.components),o.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a0b2d528.2f33b354.js b/assets/js/a0b2d528.2f33b354.js new file mode 100644 index 00000000..23599c8a --- /dev/null +++ b/assets/js/a0b2d528.2f33b354.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9323],{78039:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>i,contentTitle:()=>s,default:()=>u,frontMatter:()=>r,metadata:()=>d,toc:()=>c});var n=a(74848),o=a(28453);const r={title:"Jan Data Folder",slug:"/guides/data-folder",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","data folder","source folder","Jan data"]},s=void 0,d={id:"guides/user-guides/jan-data-folder",title:"Jan Data Folder",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/jan-data-folder.mdx",sourceDirName:"guides/user-guides",slug:"/guides/data-folder",permalink:"/guides/data-folder",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/jan-data-folder.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan Data Folder",slug:"/guides/data-folder",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","data folder","source folder","Jan data"]}},i={},c=[];function l(e){const t={p:"p",...(0,o.R)(),...e.components};return(0,n.jsx)(t.p,{children:"Coming Soon"})}function u(e={}){const{wrapper:t}={...(0,o.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(l,{...e})}):l(e)}},28453:(e,t,a)=>{a.d(t,{R:()=>s,x:()=>d});var n=a(96540);const o={},r=n.createContext(o);function s(e){const t=n.useContext(r);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function d(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),n.createElement(r.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a0b5e9d3.2b7c1dbb.js b/assets/js/a0b5e9d3.2b7c1dbb.js new file mode 100644 index 00000000..8d136950 --- /dev/null +++ b/assets/js/a0b5e9d3.2b7c1dbb.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6718],{2751:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>u,contentTitle:()=>a,default:()=>d,frontMatter:()=>r,metadata:()=>i,toc:()=>c});var n=s(74848),o=s(28453);const r={title:"Startups",tags:["audiences"]},a=void 0,i={id:"solutions/startups",title:"Startups",description:"",source:"@site/docs/solutions/startups.md",sourceDirName:"solutions",slug:"/solutions/startups",permalink:"/solutions/startups",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/startups.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Startups",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Software Consultants",permalink:"/solutions/consultants"},next:{title:"Enterprises",permalink:"/solutions/enterprises"}},u={},c=[];function l(t){return(0,n.jsx)(n.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(l,{...t})}):l()}},28453:(t,e,s)=>{s.d(e,{R:()=>a,x:()=>i});var n=s(96540);const o={},r=n.createContext(o);function a(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:a(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/a0b5e9d3.69eb36af.js b/assets/js/a0b5e9d3.69eb36af.js deleted file mode 100644 index f73f81b4..00000000 --- a/assets/js/a0b5e9d3.69eb36af.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6718],{2751:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>u,contentTitle:()=>a,default:()=>d,frontMatter:()=>r,metadata:()=>i,toc:()=>c});var n=s(74848),o=s(28453);const r={title:"Startups",tags:["audiences"]},a=void 0,i={id:"solutions/startups",title:"Startups",description:"",source:"@site/docs/solutions/startups.md",sourceDirName:"solutions",slug:"/solutions/startups",permalink:"/solutions/startups",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/startups.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Startups",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Software Consultants",permalink:"/solutions/consultants"},next:{title:"Enterprises",permalink:"/solutions/enterprises"}},u={},c=[];function l(t){return(0,n.jsx)(n.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(l,{...t})}):l()}},28453:(t,e,s)=>{s.d(e,{R:()=>a,x:()=>i});var n=s(96540);const o={},r=n.createContext(o);function a(t){const e=n.useContext(r);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:a(t.components),n.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/a422893d.00ca53eb.js b/assets/js/a422893d.00ca53eb.js deleted file mode 100644 index f43d8381..00000000 --- a/assets/js/a422893d.00ca53eb.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9704],{40981:(e,s,t)=>{t.r(s),t.d(s,{assets:()=>d,contentTitle:()=>l,default:()=>h,frontMatter:()=>n,metadata:()=>c,toc:()=>r});var i=t(74848),a=t(28453);const n={},l="Regression test",c={id:"template/QA_script",title:"Regression test",description:"Release Version: v0.4.7",source:"@site/docs/template/QA_script.md",sourceDirName:"template",slug:"/template/QA_script",permalink:"/template/QA_script",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/template/QA_script.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{}},d={},r=[{value:"A. Installation, Update, and Uninstallation",id:"a-installation-update-and-uninstallation",level:2},{value:"1. Users install app",id:"1-users-install-app",level:3},{value:"2. Users update app",id:"2-users-update-app",level:3},{value:"3. Users uninstall / close app",id:"3-users-uninstall--close-app",level:3},{value:"B. Overview",id:"b-overview",level:2},{value:"1. Shortcut key, memory usage / CPU usage",id:"1-shortcut-key-memory-usage--cpu-usage",level:3},{value:"2. Users check the active model",id:"2-users-check-the-active-model",level:3},{value:"C. Thread",id:"c-thread",level:2},{value:"1. Users can chat with Jan, the default assistant",id:"1-users-can-chat-with-jan-the-default-assistant",level:3},{value:"2. Users can customize chat settings like model parameters via both the GUI & thread.json",id:"2-users-can-customize-chat-settings-like-model-parameters-via-both-the-gui--threadjson",level:3},{value:"3. Model dropdown",id:"3-model-dropdown",level:3},{value:"4. Users can click on a history thread",id:"4-users-can-click-on-a-history-thread",level:3},{value:"5. Users can config instructions for the assistant.",id:"5-users-can-config-instructions-for-the-assistant",level:3},{value:"D. Hub",id:"d-hub",level:2},{value:"1. Users can discover recommended models (Jan ships with a few preconfigured model.json files)",id:"1-users-can-discover-recommended-models-jan-ships-with-a-few-preconfigured-modeljson-files",level:3},{value:"2. Users can download models suitable for their devices, e.g. compatible with their RAM",id:"2-users-can-download-models-suitable-for-their-devices-eg-compatible-with-their-ram",level:3},{value:"3. Users can download models via a HuggingFace URL (coming soon)",id:"3-users-can-download-models-via-a-huggingface-url-coming-soon",level:3},{value:"4. Users can import new models to the Hub",id:"4-users-can-import-new-models-to-the-hub",level:3},{value:"5. Users can use the model as they want",id:"5-users-can-use-the-model-as-they-want",level:3},{value:"6. Users can Integrate With a Remote Server",id:"6-users-can-integrate-with-a-remote-server",level:3},{value:"E. System Monitor",id:"e-system-monitor",level:2},{value:"1. Users can see disk and RAM utilization",id:"1-users-can-see-disk-and-ram-utilization",level:3},{value:"2. Users can start and stop models based on system health",id:"2-users-can-start-and-stop-models-based-on-system-health",level:3},{value:"F. Settings",id:"f-settings",level:2},{value:"1. Appearance",id:"1-appearance",level:3},{value:"2. Extensions [TBU]",id:"2-extensions-tbu",level:3},{value:"3. Users can add custom plugins via manual installation [TBU]",id:"3-users-can-add-custom-plugins-via-manual-installation-tbu",level:3},{value:"4. Advanced settings",id:"4-advanced-settings",level:3},{value:"G. Local API server",id:"g-local-api-server",level:2},{value:"1. Local Server Usage with Server Options",id:"1-local-server-usage-with-server-options",level:3}];function o(e){const s={a:"a",code:"code",h1:"h1",h2:"h2",h3:"h3",hr:"hr",input:"input",li:"li",p:"p",strong:"strong",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(s.h1,{id:"regression-test",children:"Regression test"}),"\n",(0,i.jsxs)(s.p,{children:[(0,i.jsx)(s.strong,{children:"Release Version:"})," v0.4.7"]}),"\n",(0,i.jsxs)(s.p,{children:[(0,i.jsx)(s.strong,{children:"Operating System:"})," MacOS"]}),"\n",(0,i.jsx)(s.hr,{}),"\n",(0,i.jsx)(s.h2,{id:"a-installation-update-and-uninstallation",children:"A. Installation, Update, and Uninstallation"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-install-app",children:"1. Users install app"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check that the installation package is not corrupted and passes all security checks."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Confirm that the app launches successfully after installation."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-update-app",children:"2. Users update app"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that the update does not corrupt user data or settings."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Confirm that the app restarts or prompts the user to restart after an update."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","When updating the app, check if the ",(0,i.jsx)(s.code,{children:"/models"})," directory has any JSON files that change according to the update."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Verify if updating the app also updates extensions correctly (test functionality changes, support notifications for necessary tests with each version related to extensions update)."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-users-uninstall--close-app",children:"3. Users uninstall / close app"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that after closing the app, all models are unloaded."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11","\u26a0\ufe0f"," Check that the uninstallation process removes the app successfully from the system."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Clean the Jan root directory and open the app to check if it creates all the necessary folders, especially models and extensions."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"b-overview",children:"B. Overview"}),"\n",(0,i.jsx)(s.h3,{id:"1-shortcut-key-memory-usage--cpu-usage",children:"1. Shortcut key, memory usage / CPU usage"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test each shortcut key to confirm it works as described (My models, navigating, opening, closing, etc.)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that the interface presents the correct numbers for memory and CPU usage."]}),"\n"]}),"\n",(0,i.jsxs)(s.h3,{id:"2-users-check-the-active-model",children:["2. Users check the ",(0,i.jsx)(s.code,{children:"active model"})]}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify that the app correctly displays the state of the loading model (e.g., loading, ready, error)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Confirm that the app allows users to switch between models if multiple are available."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check that the app provides feedback or instructions if the model fails to load."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Verify the troubleshooting assistant correctly capture hardware / log info #1784"]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"c-thread",children:"C. Thread"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-can-chat-with-jan-the-default-assistant",children:"1. Users can chat with Jan, the default assistant"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify sending a message enables users to receive responses from model."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that the conversation thread is maintained without any loss of data upon sending multiple messages."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\u200cUsers should be able to edit msg and the assistant will re-generate the answer based on the edited version of the message."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test for the ability to send different types of messages (e.g., text, emojis, code blocks)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the output format of the AI (code blocks, JSON, markdown, ...)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate the scroll functionality in the chat window for lengthy conversations."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check if the user can copy / delete the response."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the ",(0,i.jsx)(s.code,{children:"clear message"})," / ",(0,i.jsx)(s.code,{children:"delete entire chat"})," button works."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check if deleting all the chat retains the system prompt."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that there is appropriate error handling and messaging if the assistant fails to respond."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test assistant's ability to maintain context over multiple exchanges."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the ",(0,i.jsx)(s.code,{children:"create new chat"})," button, and new conversation will have an automatically generated thread title based on users msg."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that by changing ",(0,i.jsx)(s.code,{children:"models"})," mid-thread the app can still handle it."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the ",(0,i.jsx)(s.code,{children:"regenerate"})," button renews the response (single / multiple times)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the ",(0,i.jsx)(s.code,{children:"Instructions"})," update correctly after the user updates it midway (mid-thread)."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-can-customize-chat-settings-like-model-parameters-via-both-the-gui--threadjson",children:"2. Users can customize chat settings like model parameters via both the GUI & thread.json"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test the functionality to adjust model parameters (e.g., Temperature, Top K, Top P) from the GUI and verify they are reflected in the chat behavior."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that changes can be saved and persisted between sessions."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that users can access and modify the thread.json file."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check that changes made in thread.json are correctly applied to the chat session upon reload or restart."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the maximum and minimum limits of the adjustable parameters and how they affect the assistant's responses."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that users switch between threads with different models, the app can handle it."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-model-dropdown",children:"3. Model dropdown"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Model list should highlight recommended based on user RAM"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Model size should display (for both installed and imported models)"]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"4-users-can-click-on-a-history-thread",children:"4. Users can click on a history thread"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that the chat window displays the entire conversation from the selected history thread without any missing messages."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the performance and accuracy of the history feature when dealing with a large number of threads."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that historical threads reflect the exact state of the chat at that time, including settings."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify the ability to delete or clean old threads."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that changing the title of the thread updates correctly."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"5-users-can-config-instructions-for-the-assistant",children:"5. Users can config instructions for the assistant."}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test if the instructions set by the user are being followed by the assistant in subsequent conversations."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that changes to instructions are updated in real time and do not require a restart of the application or session."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check for the ability to reset instructions to default or clear them completely."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," RAG - Users can import documents and the system should process queries about the uploaded file, providing accurate and appropriate responses in the conversation thread."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"d-hub",children:"D. Hub"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-can-discover-recommended-models-jan-ships-with-a-few-preconfigured-modeljson-files",children:"1. Users can discover recommended models (Jan ships with a few preconfigured model.json files)"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that each model's recommendations are consistent with the user\u2019s activity and preferences."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test the functionality of any filters that refine model recommendations."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-can-download-models-suitable-for-their-devices-eg-compatible-with-their-ram",children:"2. Users can download models suitable for their devices, e.g. compatible with their RAM"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Display the best model for their RAM at the top."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that models are labeled with RAM requirements and compatibility."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the download model functionality and validate if the cancel download feature works correctly."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-users-can-download-models-via-a-huggingface-url-coming-soon",children:"3. Users can download models via a HuggingFace URL (coming soon)"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Have the warning/status when the user enters the URL."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the progress bar reflects the right process."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate the error handling for invalid or inaccessible URLs."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"4-users-can-import-new-models-to-the-hub",children:"4. Users can import new models to the Hub"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure import successfully via drag / drop or upload GGUF."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify Move model binary file / Keep Original Files & Symlink option are working"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\u26a0\ufe0f"," Ensure it raises clear errors for users to fix the problem while adding a new model."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can add more info to the imported model / edit name"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure the new model updates after restarting the app."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"5-users-can-use-the-model-as-they-want",children:"5. Users can use the model as they want"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check ",(0,i.jsx)(s.code,{children:"start"})," / ",(0,i.jsx)(s.code,{children:"stop"})," / ",(0,i.jsx)(s.code,{children:"delete"})," button response exactly what it does."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check if starting another model stops the other model entirely."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\ude80"," Check the ",(0,i.jsx)(s.code,{children:"Explore models"})," navigate correctly to the model panel."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check when deleting a model it will delete all the files on the user's computer."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ",":warning",":The"," recommended tags should present right for the user's hardware."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"6-users-can-integrate-with-a-remote-server",children:"6. Users can Integrate With a Remote Server"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Import openAI GPT model ",(0,i.jsx)(s.a,{href:"https://jan.ai/guides/using-models/integrate-with-remote-server/",children:"https://jan.ai/guides/using-models/integrate-with-remote-server/"})," and the model displayed in Hub / Thread dropdown"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can use the remote model properly"]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"e-system-monitor",children:"E. System Monitor"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-can-see-disk-and-ram-utilization",children:"1. Users can see disk and RAM utilization"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify that the RAM and VRAM utilization graphs display accurate information."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check that the CPU usage is accurately reported in real time."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that the utilization percentages reflect the actual usage compared to the system's total available resources."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that the system monitors updates dynamically as the models run and stop."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-can-start-and-stop-models-based-on-system-health",children:"2. Users can start and stop models based on system health"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test the 'Start' action for a model to ensure it initiates and the system resource usage reflects this change."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify the 'Stop' action for a model to confirm it ceases operation and frees up the system resources accordingly."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that any changes in model status (start/stop) are logged or reported to the user for transparency."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"f-settings",children:"F. Settings"}),"\n",(0,i.jsx)(s.h3,{id:"1-appearance",children:"1. Appearance"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test the ",(0,i.jsx)(s.code,{children:"Light"}),", ",(0,i.jsx)(s.code,{children:"Dark"}),", and ",(0,i.jsx)(s.code,{children:"System"})," theme settings to ensure they are functioning as expected."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that the application saves the theme preference and persists it across sessions."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that all elements of the UI are compatible with the theme changes and maintain legibility and contrast."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-extensions-tbu",children:"2. Extensions [TBU]"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that the ",(0,i.jsx)(s.code,{children:"Extensions"})," tab lists all available plugins."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Test the toggle switch for each plugin to ensure it enables or disables the plugin correctly."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Verify that plugin changes take effect without needing to restart the application unless specified."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Check that the plugin's status (",(0,i.jsx)(s.code,{children:"Installed the latest version"}),") updates accurately after any changes."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Validate the ",(0,i.jsx)(s.code,{children:"Manual Installation"})," process by selecting and installing a plugin file."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Test for proper error handling and user feedback when a plugin installation fails."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-users-can-add-custom-plugins-via-manual-installation-tbu",children:"3. Users can add custom plugins via manual installation [TBU]"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Verify that the ",(0,i.jsx)(s.code,{children:"Manual Installation"})," option is clearly visible and accessible in the ",(0,i.jsx)(s.code,{children:"Extensions"})," section."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Test the functionality of the ",(0,i.jsx)(s.code,{children:"Select"})," button within the ",(0,i.jsx)(s.code,{children:"Manual Installation"})," area."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\u26a0\ufe0f"," Check that the file picker dialog allows for the correct plugin file types (e.g., .tgz)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Validate that the selected plugin file installs correctly and the plugin becomes functional."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Ensure that there is a progress indicator or confirmation message once the installation is complete."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Confirm that if the installation is interrupted or fails, the user is given a clear error message."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Test that the application prevents the installation of incompatible or corrupt plugin files."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Check that the user can uninstall or disable custom plugins as easily as pre-installed ones."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Verify that the application's performance remains stable after the installation of custom plugins."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"4-advanced-settings",children:"4. Advanced settings"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test the ",(0,i.jsx)(s.code,{children:"Experimental Mode"})," toggle to confirm it enables or disables experimental features as intended."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the functionality of ",(0,i.jsx)(s.code,{children:"Open App Directory"})," to ensure it opens the correct folder in the system file explorer."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can move ",(0,i.jsx)(s.strong,{children:"Jan data folder"})]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that changes in advanced settings are applied immediately or provide appropriate instructions if a restart is needed."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Attemp to test downloading model from hub using ",(0,i.jsx)(s.strong,{children:"HTTP Proxy"})," ",(0,i.jsx)(s.a,{href:"https://github.com/janhq/jan/pull/1562",children:"guideline"})]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Logs that are older than 7 days or exceed 1MB in size will be automatically cleared upon starting the application."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can click on Reset button to ",(0,i.jsx)(s.strong,{children:"factory reset"})," app settings to its original state & delete all usage data."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"g-local-api-server",children:"G. Local API server"}),"\n",(0,i.jsx)(s.h3,{id:"1-local-server-usage-with-server-options",children:"1. Local Server Usage with Server Options"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Explore API Reference: Swagger API for sending/receiving requests","\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Use default server option"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Configure and use custom server options"]}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test starting/stopping the local API server with different Model/Model settings"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Server logs captured with correct Server Options provided"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Verify functionality of Open logs/Clear feature"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Ensure that threads and other functions impacting the model are disabled while the local server is running"]}),"\n"]})]})}function h(e={}){const{wrapper:s}={...(0,a.R)(),...e.components};return s?(0,i.jsx)(s,{...e,children:(0,i.jsx)(o,{...e})}):o(e)}},28453:(e,s,t)=>{t.d(s,{R:()=>l,x:()=>c});var i=t(96540);const a={},n=i.createContext(a);function l(e){const s=i.useContext(n);return i.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function c(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:l(e.components),i.createElement(n.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a422893d.c5c375bc.js b/assets/js/a422893d.c5c375bc.js new file mode 100644 index 00000000..7493d0fb --- /dev/null +++ b/assets/js/a422893d.c5c375bc.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9704],{40981:(e,s,t)=>{t.r(s),t.d(s,{assets:()=>d,contentTitle:()=>l,default:()=>h,frontMatter:()=>n,metadata:()=>c,toc:()=>r});var i=t(74848),a=t(28453);const n={},l="Regression test",c={id:"template/QA_script",title:"Regression test",description:"Release Version: v0.4.7",source:"@site/docs/template/QA_script.md",sourceDirName:"template",slug:"/template/QA_script",permalink:"/template/QA_script",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/template/QA_script.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{}},d={},r=[{value:"A. Installation, Update, and Uninstallation",id:"a-installation-update-and-uninstallation",level:2},{value:"1. Users install app",id:"1-users-install-app",level:3},{value:"2. Users update app",id:"2-users-update-app",level:3},{value:"3. Users uninstall / close app",id:"3-users-uninstall--close-app",level:3},{value:"B. Overview",id:"b-overview",level:2},{value:"1. Shortcut key, memory usage / CPU usage",id:"1-shortcut-key-memory-usage--cpu-usage",level:3},{value:"2. Users check the active model",id:"2-users-check-the-active-model",level:3},{value:"C. Thread",id:"c-thread",level:2},{value:"1. Users can chat with Jan, the default assistant",id:"1-users-can-chat-with-jan-the-default-assistant",level:3},{value:"2. Users can customize chat settings like model parameters via both the GUI & thread.json",id:"2-users-can-customize-chat-settings-like-model-parameters-via-both-the-gui--threadjson",level:3},{value:"3. Model dropdown",id:"3-model-dropdown",level:3},{value:"4. Users can click on a history thread",id:"4-users-can-click-on-a-history-thread",level:3},{value:"5. Users can config instructions for the assistant.",id:"5-users-can-config-instructions-for-the-assistant",level:3},{value:"D. Hub",id:"d-hub",level:2},{value:"1. Users can discover recommended models (Jan ships with a few preconfigured model.json files)",id:"1-users-can-discover-recommended-models-jan-ships-with-a-few-preconfigured-modeljson-files",level:3},{value:"2. Users can download models suitable for their devices, e.g. compatible with their RAM",id:"2-users-can-download-models-suitable-for-their-devices-eg-compatible-with-their-ram",level:3},{value:"3. Users can download models via a HuggingFace URL (coming soon)",id:"3-users-can-download-models-via-a-huggingface-url-coming-soon",level:3},{value:"4. Users can import new models to the Hub",id:"4-users-can-import-new-models-to-the-hub",level:3},{value:"5. Users can use the model as they want",id:"5-users-can-use-the-model-as-they-want",level:3},{value:"6. Users can Integrate With a Remote Server",id:"6-users-can-integrate-with-a-remote-server",level:3},{value:"E. System Monitor",id:"e-system-monitor",level:2},{value:"1. Users can see disk and RAM utilization",id:"1-users-can-see-disk-and-ram-utilization",level:3},{value:"2. Users can start and stop models based on system health",id:"2-users-can-start-and-stop-models-based-on-system-health",level:3},{value:"F. Settings",id:"f-settings",level:2},{value:"1. Appearance",id:"1-appearance",level:3},{value:"2. Extensions [TBU]",id:"2-extensions-tbu",level:3},{value:"3. Users can add custom plugins via manual installation [TBU]",id:"3-users-can-add-custom-plugins-via-manual-installation-tbu",level:3},{value:"4. Advanced settings",id:"4-advanced-settings",level:3},{value:"G. Local API server",id:"g-local-api-server",level:2},{value:"1. Local Server Usage with Server Options",id:"1-local-server-usage-with-server-options",level:3}];function o(e){const s={a:"a",code:"code",h1:"h1",h2:"h2",h3:"h3",hr:"hr",input:"input",li:"li",p:"p",strong:"strong",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(s.h1,{id:"regression-test",children:"Regression test"}),"\n",(0,i.jsxs)(s.p,{children:[(0,i.jsx)(s.strong,{children:"Release Version:"})," v0.4.7"]}),"\n",(0,i.jsxs)(s.p,{children:[(0,i.jsx)(s.strong,{children:"Operating System:"})," MacOS"]}),"\n",(0,i.jsx)(s.hr,{}),"\n",(0,i.jsx)(s.h2,{id:"a-installation-update-and-uninstallation",children:"A. Installation, Update, and Uninstallation"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-install-app",children:"1. Users install app"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check that the installation package is not corrupted and passes all security checks."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Confirm that the app launches successfully after installation."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-update-app",children:"2. Users update app"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that the update does not corrupt user data or settings."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Confirm that the app restarts or prompts the user to restart after an update."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","When updating the app, check if the ",(0,i.jsx)(s.code,{children:"/models"})," directory has any JSON files that change according to the update."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Verify if updating the app also updates extensions correctly (test functionality changes, support notifications for necessary tests with each version related to extensions update)."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-users-uninstall--close-app",children:"3. Users uninstall / close app"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that after closing the app, all models are unloaded."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11","\u26a0\ufe0f"," Check that the uninstallation process removes the app successfully from the system."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Clean the Jan root directory and open the app to check if it creates all the necessary folders, especially models and extensions."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"b-overview",children:"B. Overview"}),"\n",(0,i.jsx)(s.h3,{id:"1-shortcut-key-memory-usage--cpu-usage",children:"1. Shortcut key, memory usage / CPU usage"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test each shortcut key to confirm it works as described (My models, navigating, opening, closing, etc.)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that the interface presents the correct numbers for memory and CPU usage."]}),"\n"]}),"\n",(0,i.jsxs)(s.h3,{id:"2-users-check-the-active-model",children:["2. Users check the ",(0,i.jsx)(s.code,{children:"active model"})]}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify that the app correctly displays the state of the loading model (e.g., loading, ready, error)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Confirm that the app allows users to switch between models if multiple are available."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check that the app provides feedback or instructions if the model fails to load."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Verify the troubleshooting assistant correctly capture hardware / log info #1784"]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"c-thread",children:"C. Thread"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-can-chat-with-jan-the-default-assistant",children:"1. Users can chat with Jan, the default assistant"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify sending a message enables users to receive responses from model."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that the conversation thread is maintained without any loss of data upon sending multiple messages."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\u200cUsers should be able to edit msg and the assistant will re-generate the answer based on the edited version of the message."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test for the ability to send different types of messages (e.g., text, emojis, code blocks)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the output format of the AI (code blocks, JSON, markdown, ...)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate the scroll functionality in the chat window for lengthy conversations."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check if the user can copy / delete the response."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the ",(0,i.jsx)(s.code,{children:"clear message"})," / ",(0,i.jsx)(s.code,{children:"delete entire chat"})," button works."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check if deleting all the chat retains the system prompt."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that there is appropriate error handling and messaging if the assistant fails to respond."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test assistant's ability to maintain context over multiple exchanges."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the ",(0,i.jsx)(s.code,{children:"create new chat"})," button, and new conversation will have an automatically generated thread title based on users msg."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that by changing ",(0,i.jsx)(s.code,{children:"models"})," mid-thread the app can still handle it."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the ",(0,i.jsx)(s.code,{children:"regenerate"})," button renews the response (single / multiple times)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the ",(0,i.jsx)(s.code,{children:"Instructions"})," update correctly after the user updates it midway (mid-thread)."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-can-customize-chat-settings-like-model-parameters-via-both-the-gui--threadjson",children:"2. Users can customize chat settings like model parameters via both the GUI & thread.json"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test the functionality to adjust model parameters (e.g., Temperature, Top K, Top P) from the GUI and verify they are reflected in the chat behavior."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that changes can be saved and persisted between sessions."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that users can access and modify the thread.json file."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check that changes made in thread.json are correctly applied to the chat session upon reload or restart."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check the maximum and minimum limits of the adjustable parameters and how they affect the assistant's responses."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that users switch between threads with different models, the app can handle it."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-model-dropdown",children:"3. Model dropdown"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Model list should highlight recommended based on user RAM"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Model size should display (for both installed and imported models)"]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"4-users-can-click-on-a-history-thread",children:"4. Users can click on a history thread"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that the chat window displays the entire conversation from the selected history thread without any missing messages."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the performance and accuracy of the history feature when dealing with a large number of threads."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that historical threads reflect the exact state of the chat at that time, including settings."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify the ability to delete or clean old threads."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that changing the title of the thread updates correctly."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"5-users-can-config-instructions-for-the-assistant",children:"5. Users can config instructions for the assistant."}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test if the instructions set by the user are being followed by the assistant in subsequent conversations."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that changes to instructions are updated in real time and do not require a restart of the application or session."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check for the ability to reset instructions to default or clear them completely."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," RAG - Users can import documents and the system should process queries about the uploaded file, providing accurate and appropriate responses in the conversation thread."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"d-hub",children:"D. Hub"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-can-discover-recommended-models-jan-ships-with-a-few-preconfigured-modeljson-files",children:"1. Users can discover recommended models (Jan ships with a few preconfigured model.json files)"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that each model's recommendations are consistent with the user\u2019s activity and preferences."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test the functionality of any filters that refine model recommendations."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-can-download-models-suitable-for-their-devices-eg-compatible-with-their-ram",children:"2. Users can download models suitable for their devices, e.g. compatible with their RAM"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Display the best model for their RAM at the top."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that models are labeled with RAM requirements and compatibility."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the download model functionality and validate if the cancel download feature works correctly."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-users-can-download-models-via-a-huggingface-url-coming-soon",children:"3. Users can download models via a HuggingFace URL (coming soon)"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Have the warning/status when the user enters the URL."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the progress bar reflects the right process."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate the error handling for invalid or inaccessible URLs."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"4-users-can-import-new-models-to-the-hub",children:"4. Users can import new models to the Hub"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure import successfully via drag / drop or upload GGUF."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify Move model binary file / Keep Original Files & Symlink option are working"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\u26a0\ufe0f"," Ensure it raises clear errors for users to fix the problem while adding a new model."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can add more info to the imported model / edit name"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure the new model updates after restarting the app."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"5-users-can-use-the-model-as-they-want",children:"5. Users can use the model as they want"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check ",(0,i.jsx)(s.code,{children:"start"})," / ",(0,i.jsx)(s.code,{children:"stop"})," / ",(0,i.jsx)(s.code,{children:"delete"})," button response exactly what it does."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Check if starting another model stops the other model entirely."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\ude80"," Check the ",(0,i.jsx)(s.code,{children:"Explore models"})," navigate correctly to the model panel."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check when deleting a model it will delete all the files on the user's computer."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ",":warning",":The"," recommended tags should present right for the user's hardware."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"6-users-can-integrate-with-a-remote-server",children:"6. Users can Integrate With a Remote Server"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Import openAI GPT model ",(0,i.jsx)(s.a,{href:"https://jan.ai/guides/using-models/integrate-with-remote-server/",children:"https://jan.ai/guides/using-models/integrate-with-remote-server/"})," and the model displayed in Hub / Thread dropdown"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can use the remote model properly"]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"e-system-monitor",children:"E. System Monitor"}),"\n",(0,i.jsx)(s.h3,{id:"1-users-can-see-disk-and-ram-utilization",children:"1. Users can see disk and RAM utilization"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify that the RAM and VRAM utilization graphs display accurate information."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check that the CPU usage is accurately reported in real time."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Validate that the utilization percentages reflect the actual usage compared to the system's total available resources."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Ensure that the system monitors updates dynamically as the models run and stop."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-users-can-start-and-stop-models-based-on-system-health",children:"2. Users can start and stop models based on system health"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test the 'Start' action for a model to ensure it initiates and the system resource usage reflects this change."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Verify the 'Stop' action for a model to confirm it ceases operation and frees up the system resources accordingly."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that any changes in model status (start/stop) are logged or reported to the user for transparency."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"f-settings",children:"F. Settings"}),"\n",(0,i.jsx)(s.h3,{id:"1-appearance",children:"1. Appearance"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test the ",(0,i.jsx)(s.code,{children:"Light"}),", ",(0,i.jsx)(s.code,{children:"Dark"}),", and ",(0,i.jsx)(s.code,{children:"System"})," theme settings to ensure they are functioning as expected."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that the application saves the theme preference and persists it across sessions."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that all elements of the UI are compatible with the theme changes and maintain legibility and contrast."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"2-extensions-tbu",children:"2. Extensions [TBU]"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Confirm that the ",(0,i.jsx)(s.code,{children:"Extensions"})," tab lists all available plugins."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Test the toggle switch for each plugin to ensure it enables or disables the plugin correctly."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Verify that plugin changes take effect without needing to restart the application unless specified."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Check that the plugin's status (",(0,i.jsx)(s.code,{children:"Installed the latest version"}),") updates accurately after any changes."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Validate the ",(0,i.jsx)(s.code,{children:"Manual Installation"})," process by selecting and installing a plugin file."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Test for proper error handling and user feedback when a plugin installation fails."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"3-users-can-add-custom-plugins-via-manual-installation-tbu",children:"3. Users can add custom plugins via manual installation [TBU]"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Verify that the ",(0,i.jsx)(s.code,{children:"Manual Installation"})," option is clearly visible and accessible in the ",(0,i.jsx)(s.code,{children:"Extensions"})," section."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Test the functionality of the ",(0,i.jsx)(s.code,{children:"Select"})," button within the ",(0,i.jsx)(s.code,{children:"Manual Installation"})," area."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\u26a0\ufe0f"," Check that the file picker dialog allows for the correct plugin file types (e.g., .tgz)."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Validate that the selected plugin file installs correctly and the plugin becomes functional."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Ensure that there is a progress indicator or confirmation message once the installation is complete."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Confirm that if the installation is interrupted or fails, the user is given a clear error message."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Test that the application prevents the installation of incompatible or corrupt plugin files."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","\ud83d\udd11"," Check that the user can uninstall or disable custom plugins as easily as pre-installed ones."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",checked:!0,disabled:!0})," ","Verify that the application's performance remains stable after the installation of custom plugins."]}),"\n"]}),"\n",(0,i.jsx)(s.h3,{id:"4-advanced-settings",children:"4. Advanced settings"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Test the ",(0,i.jsx)(s.code,{children:"Experimental Mode"})," toggle to confirm it enables or disables experimental features as intended."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Check the functionality of ",(0,i.jsx)(s.code,{children:"Open App Directory"})," to ensure it opens the correct folder in the system file explorer."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can move ",(0,i.jsx)(s.strong,{children:"Jan data folder"})]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Validate that changes in advanced settings are applied immediately or provide appropriate instructions if a restart is needed."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Attemp to test downloading model from hub using ",(0,i.jsx)(s.strong,{children:"HTTP Proxy"})," ",(0,i.jsx)(s.a,{href:"https://github.com/janhq/jan/pull/1562",children:"guideline"})]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Logs that are older than 7 days or exceed 1MB in size will be automatically cleared upon starting the application."]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Users can click on Reset button to ",(0,i.jsx)(s.strong,{children:"factory reset"})," app settings to its original state & delete all usage data."]}),"\n"]}),"\n",(0,i.jsx)(s.h2,{id:"g-local-api-server",children:"G. Local API server"}),"\n",(0,i.jsx)(s.h3,{id:"1-local-server-usage-with-server-options",children:"1. Local Server Usage with Server Options"}),"\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","\ud83d\udd11"," Explore API Reference: Swagger API for sending/receiving requests","\n",(0,i.jsxs)(s.ul,{className:"contains-task-list",children:["\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Use default server option"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Configure and use custom server options"]}),"\n"]}),"\n"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Test starting/stopping the local API server with different Model/Model settings"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Server logs captured with correct Server Options provided"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Verify functionality of Open logs/Clear feature"]}),"\n",(0,i.jsxs)(s.li,{className:"task-list-item",children:[(0,i.jsx)(s.input,{type:"checkbox",disabled:!0})," ","Ensure that threads and other functions impacting the model are disabled while the local server is running"]}),"\n"]})]})}function h(e={}){const{wrapper:s}={...(0,a.R)(),...e.components};return s?(0,i.jsx)(s,{...e,children:(0,i.jsx)(o,{...e})}):o(e)}},28453:(e,s,t)=>{t.d(s,{R:()=>l,x:()=>c});var i=t(96540);const a={},n=i.createContext(a);function l(e){const s=i.useContext(n);return i.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function c(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:l(e.components),i.createElement(n.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a4e65e27.c9370ded.js b/assets/js/a4e65e27.c9370ded.js deleted file mode 100644 index 2f1b55cb..00000000 --- a/assets/js/a4e65e27.c9370ded.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4306],{7058:(n,e,t)=>{t.r(e),t.d(e,{assets:()=>d,contentTitle:()=>a,default:()=>u,frontMatter:()=>i,metadata:()=>l,toc:()=>r});var o=t(74848),s=t(28453);const i={title:"Install on Windows",sidebar_position:2,slug:"/guides/install/windows",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Windows.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Windows 10","Windows 11","Install on Windows","Microsoft devices"]},a=void 0,l={id:"guides/installation/windows",title:"Install on Windows",description:"A step-by-step guide to install Jan on your Windows.",source:"@site/docs/guides/installation/windows.mdx",sourceDirName:"guides/installation",slug:"/guides/install/windows",permalink:"/guides/install/windows",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/windows.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"Install on Windows",sidebar_position:2,slug:"/guides/install/windows",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Windows.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Windows 10","Windows 11","Install on Windows","Microsoft devices"]}},d={},r=[];function c(n){const e={p:"p",...(0,s.R)(),...n.components};return(0,o.jsx)(e.p,{children:"Coming soon"})}function u(n={}){const{wrapper:e}={...(0,s.R)(),...n.components};return e?(0,o.jsx)(e,{...n,children:(0,o.jsx)(c,{...n})}):c(n)}},28453:(n,e,t)=>{t.d(e,{R:()=>a,x:()=>l});var o=t(96540);const s={},i=o.createContext(s);function a(n){const e=o.useContext(i);return o.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function l(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(s):n.components||s:a(n.components),o.createElement(i.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/a4e65e27.cc3ad2a2.js b/assets/js/a4e65e27.cc3ad2a2.js new file mode 100644 index 00000000..764ca1a2 --- /dev/null +++ b/assets/js/a4e65e27.cc3ad2a2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4306],{7058:(n,e,t)=>{t.r(e),t.d(e,{assets:()=>d,contentTitle:()=>a,default:()=>u,frontMatter:()=>i,metadata:()=>l,toc:()=>r});var o=t(74848),s=t(28453);const i={title:"Install on Windows",sidebar_position:2,slug:"/guides/install/windows",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Windows.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Windows 10","Windows 11","Install on Windows","Microsoft devices"]},a=void 0,l={id:"guides/installation/windows",title:"Install on Windows",description:"A step-by-step guide to install Jan on your Windows.",source:"@site/docs/guides/installation/windows.mdx",sourceDirName:"guides/installation",slug:"/guides/install/windows",permalink:"/guides/install/windows",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/installation/windows.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"Install on Windows",sidebar_position:2,slug:"/guides/install/windows",hide_table_of_contents:!0,description:"A step-by-step guide to install Jan on your Windows.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Windows 10","Windows 11","Install on Windows","Microsoft devices"]}},d={},r=[];function c(n){const e={p:"p",...(0,s.R)(),...n.components};return(0,o.jsx)(e.p,{children:"Coming soon"})}function u(n={}){const{wrapper:e}={...(0,s.R)(),...n.components};return e?(0,o.jsx)(e,{...n,children:(0,o.jsx)(c,{...n})}):c(n)}},28453:(n,e,t)=>{t.d(e,{R:()=>a,x:()=>l});var o=t(96540);const s={},i=o.createContext(s);function a(n){const e=o.useContext(i);return o.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function l(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(s):n.components||s:a(n.components),o.createElement(i.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/a6117a95.9710049d.js b/assets/js/a6117a95.9710049d.js new file mode 100644 index 00000000..c4b217b3 --- /dev/null +++ b/assets/js/a6117a95.9710049d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2294],{43159:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>o,metadata:()=>a,toc:()=>d});var t=i(74848),s=i(28453);const o={title:"Website & Docs",slug:"/how-we-work/website-docs/",description:"Information about the Jan website and documentation.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","website","documentation"]},r=void 0,a={id:"how-we-work/website-docs/website-docs",title:"Website & Docs",description:"Information about the Jan website and documentation.",source:"@site/docs/how-we-work/website-docs/website-docs.md",sourceDirName:"how-we-work/website-docs",slug:"/how-we-work/website-docs/",permalink:"/how-we-work/website-docs/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/website-docs/website-docs.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Website & Docs",slug:"/how-we-work/website-docs/",description:"Information about the Jan website and documentation.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","website","documentation"]},sidebar:"aboutSidebar",previous:{title:"Analytics",permalink:"/how-we-work/analytics"},next:{title:"Acknowledgements",permalink:"/acknowledgements"}},l={},d=[{value:"Information Architecture",id:"information-architecture",level:3},{value:"Sidebar Autogeneration",id:"sidebar-autogeneration",level:3},{value:"How to Contribute",id:"how-to-contribute",level:2},{value:"Pre-requisites and Installation",id:"pre-requisites-and-installation",level:3},{value:"Installation",id:"installation",level:4},{value:"Build",id:"build",level:4},{value:"Deployment",id:"deployment",level:3},{value:"Preview URL, Pre-release and Publishing Documentation",id:"preview-url-pre-release-and-publishing-documentation",level:3},{value:"Additional Plugins",id:"additional-plugins",level:3}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsxs)(n.p,{children:["This website is built using ",(0,t.jsx)(n.a,{href:"https://docusaurus.io/",children:"Docusaurus 3.0"}),", a modern static website generator."]}),"\n",(0,t.jsx)(n.h3,{id:"information-architecture",children:"Information Architecture"}),"\n",(0,t.jsxs)(n.p,{children:["We try to ",(0,t.jsx)(n.strong,{children:"keep routes consistent"})," to maintain SEO."]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/guides/"})}),": Guides on how to use the Jan application. For end users who are directly using Jan."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/developer/"})}),": Developer docs on how to extend Jan. These pages are about what people can build with our software."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/api-reference/"})}),": Reference documentation for the Jan API server, written in Swagger/OpenAPI format."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/changelog/"})}),": A list of changes made to the Jan application with each release."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/blog/"})}),": A blog for the Jan application."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"sidebar-autogeneration",children:"Sidebar Autogeneration"}),"\n",(0,t.jsxs)(n.p,{children:["The order of each page is either explicitly defined in ",(0,t.jsx)(n.code,{children:"sidebar.js"})," or follows the ",(0,t.jsx)(n.a,{href:"https://docusaurus.io/docs/next/sidebar/autogenerated",children:"Docusaurus autogenerated"})," naming format, ",(0,t.jsx)(n.code,{children:"##-path-name.md"}),"."]}),"\n",(0,t.jsx)(n.p,{children:"Important slugs are hardcoded at the document level (and shouldn't be rerouted):"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{children:"---\ntitle: Overview\nslug: /docs\n---\n"})}),"\n",(0,t.jsx)(n.h2,{id:"how-to-contribute",children:"How to Contribute"}),"\n",(0,t.jsxs)(n.p,{children:["Refer to the ",(0,t.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/dev/CONTRIBUTING.md",children:"Contributing Guide"})," for more comprehensive information on how to contribute to the Jan project."]}),"\n",(0,t.jsx)(n.h3,{id:"pre-requisites-and-installation",children:"Pre-requisites and Installation"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://nodejs.org/en/",children:"Node.js"})," (version 20.0.0 or higher)"]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://yarnpkg.com/",children:"yarn"})," (version 1.22.0 or higher)"]}),"\n"]}),"\n",(0,t.jsx)(n.h4,{id:"installation",children:"Installation"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"cd jan/docs\nyarn install\nyarn start\n"})}),"\n",(0,t.jsx)(n.p,{children:"This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server."}),"\n",(0,t.jsx)(n.h4,{id:"build",children:"Build"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"yarn build\n"})}),"\n",(0,t.jsxs)(n.p,{children:["This command generates static content into the ",(0,t.jsx)(n.code,{children:"build"})," directory and can be served using any static contents hosting service."]}),"\n",(0,t.jsx)(n.h3,{id:"deployment",children:"Deployment"}),"\n",(0,t.jsx)(n.p,{children:"Using SSH:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"USE_SSH=true yarn deploy\n"})}),"\n",(0,t.jsx)(n.p,{children:"Not using SSH:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"GIT_USER= yarn deploy\n"})}),"\n",(0,t.jsxs)(n.p,{children:["If you are using GitHub pages for hosting, this command is a convenient way to build the website and push to the ",(0,t.jsx)(n.code,{children:"gh-pages"})," branch."]}),"\n",(0,t.jsx)(n.h3,{id:"preview-url-pre-release-and-publishing-documentation",children:"Preview URL, Pre-release and Publishing Documentation"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"When a pull request is created, the preview URL will be automatically commented on the pull request."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["The documentation will then be published to ",(0,t.jsx)(n.a,{href:"https://dev.jan.ai/",children:"https://dev.jan.ai/"})," when the pull request is merged to ",(0,t.jsx)(n.code,{children:"dev"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Our open-source maintainers will sync the updated content from ",(0,t.jsx)(n.code,{children:"dev"})," to ",(0,t.jsx)(n.code,{children:"docs"})," branch, which will then be published to ",(0,t.jsx)(n.a,{href:"https://jan.ai/",children:"https://jan.ai/"}),"."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"additional-plugins",children:"Additional Plugins"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"@docusaurus/theme-live-codeblock"}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://redocusaurus.vercel.app/",children:"Redocusaurus"}),": manually upload swagger files at ",(0,t.jsx)(n.code,{children:"/openapi/jan.yaml"})," to update the API reference documentation."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>a});var t=i(96540);const s={},o=t.createContext(s);function r(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a6117a95.f4b0cc53.js b/assets/js/a6117a95.f4b0cc53.js deleted file mode 100644 index f28b6f69..00000000 --- a/assets/js/a6117a95.f4b0cc53.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2294],{43159:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>o,metadata:()=>a,toc:()=>d});var t=i(74848),s=i(28453);const o={title:"Website & Docs",slug:"/how-we-work/website-docs/",description:"Information about the Jan website and documentation.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","website","documentation"]},r=void 0,a={id:"how-we-work/website-docs/website-docs",title:"Website & Docs",description:"Information about the Jan website and documentation.",source:"@site/docs/how-we-work/website-docs/website-docs.md",sourceDirName:"how-we-work/website-docs",slug:"/how-we-work/website-docs/",permalink:"/how-we-work/website-docs/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/website-docs/website-docs.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Website & Docs",slug:"/how-we-work/website-docs/",description:"Information about the Jan website and documentation.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","website","documentation"]},sidebar:"aboutSidebar",previous:{title:"Analytics",permalink:"/how-we-work/analytics"},next:{title:"Acknowledgements",permalink:"/acknowledgements"}},l={},d=[{value:"Information Architecture",id:"information-architecture",level:3},{value:"Sidebar Autogeneration",id:"sidebar-autogeneration",level:3},{value:"How to Contribute",id:"how-to-contribute",level:2},{value:"Pre-requisites and Installation",id:"pre-requisites-and-installation",level:3},{value:"Installation",id:"installation",level:4},{value:"Build",id:"build",level:4},{value:"Deployment",id:"deployment",level:3},{value:"Preview URL, Pre-release and Publishing Documentation",id:"preview-url-pre-release-and-publishing-documentation",level:3},{value:"Additional Plugins",id:"additional-plugins",level:3}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsxs)(n.p,{children:["This website is built using ",(0,t.jsx)(n.a,{href:"https://docusaurus.io/",children:"Docusaurus 3.0"}),", a modern static website generator."]}),"\n",(0,t.jsx)(n.h3,{id:"information-architecture",children:"Information Architecture"}),"\n",(0,t.jsxs)(n.p,{children:["We try to ",(0,t.jsx)(n.strong,{children:"keep routes consistent"})," to maintain SEO."]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/guides/"})}),": Guides on how to use the Jan application. For end users who are directly using Jan."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/developer/"})}),": Developer docs on how to extend Jan. These pages are about what people can build with our software."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/api-reference/"})}),": Reference documentation for the Jan API server, written in Swagger/OpenAPI format."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/changelog/"})}),": A list of changes made to the Jan application with each release."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.strong,{children:(0,t.jsx)(n.code,{children:"/blog/"})}),": A blog for the Jan application."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"sidebar-autogeneration",children:"Sidebar Autogeneration"}),"\n",(0,t.jsxs)(n.p,{children:["The order of each page is either explicitly defined in ",(0,t.jsx)(n.code,{children:"sidebar.js"})," or follows the ",(0,t.jsx)(n.a,{href:"https://docusaurus.io/docs/next/sidebar/autogenerated",children:"Docusaurus autogenerated"})," naming format, ",(0,t.jsx)(n.code,{children:"##-path-name.md"}),"."]}),"\n",(0,t.jsx)(n.p,{children:"Important slugs are hardcoded at the document level (and shouldn't be rerouted):"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{children:"---\ntitle: Overview\nslug: /docs\n---\n"})}),"\n",(0,t.jsx)(n.h2,{id:"how-to-contribute",children:"How to Contribute"}),"\n",(0,t.jsxs)(n.p,{children:["Refer to the ",(0,t.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/dev/CONTRIBUTING.md",children:"Contributing Guide"})," for more comprehensive information on how to contribute to the Jan project."]}),"\n",(0,t.jsx)(n.h3,{id:"pre-requisites-and-installation",children:"Pre-requisites and Installation"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://nodejs.org/en/",children:"Node.js"})," (version 20.0.0 or higher)"]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://yarnpkg.com/",children:"yarn"})," (version 1.22.0 or higher)"]}),"\n"]}),"\n",(0,t.jsx)(n.h4,{id:"installation",children:"Installation"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"cd jan/docs\nyarn install\nyarn start\n"})}),"\n",(0,t.jsx)(n.p,{children:"This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server."}),"\n",(0,t.jsx)(n.h4,{id:"build",children:"Build"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"yarn build\n"})}),"\n",(0,t.jsxs)(n.p,{children:["This command generates static content into the ",(0,t.jsx)(n.code,{children:"build"})," directory and can be served using any static contents hosting service."]}),"\n",(0,t.jsx)(n.h3,{id:"deployment",children:"Deployment"}),"\n",(0,t.jsx)(n.p,{children:"Using SSH:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"USE_SSH=true yarn deploy\n"})}),"\n",(0,t.jsx)(n.p,{children:"Not using SSH:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-bash",children:"GIT_USER= yarn deploy\n"})}),"\n",(0,t.jsxs)(n.p,{children:["If you are using GitHub pages for hosting, this command is a convenient way to build the website and push to the ",(0,t.jsx)(n.code,{children:"gh-pages"})," branch."]}),"\n",(0,t.jsx)(n.h3,{id:"preview-url-pre-release-and-publishing-documentation",children:"Preview URL, Pre-release and Publishing Documentation"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"When a pull request is created, the preview URL will be automatically commented on the pull request."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["The documentation will then be published to ",(0,t.jsx)(n.a,{href:"https://dev.jan.ai/",children:"https://dev.jan.ai/"})," when the pull request is merged to ",(0,t.jsx)(n.code,{children:"dev"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Our open-source maintainers will sync the updated content from ",(0,t.jsx)(n.code,{children:"dev"})," to ",(0,t.jsx)(n.code,{children:"docs"})," branch, which will then be published to ",(0,t.jsx)(n.a,{href:"https://jan.ai/",children:"https://jan.ai/"}),"."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"additional-plugins",children:"Additional Plugins"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"@docusaurus/theme-live-codeblock"}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://redocusaurus.vercel.app/",children:"Redocusaurus"}),": manually upload swagger files at ",(0,t.jsx)(n.code,{children:"/openapi/jan.yaml"})," to update the API reference documentation."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>a});var t=i(96540);const s={},o=t.createContext(s);function r(e){const n=t.useContext(o);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),t.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a8144d1b.11304562.js b/assets/js/a8144d1b.11304562.js new file mode 100644 index 00000000..a1888cf1 --- /dev/null +++ b/assets/js/a8144d1b.11304562.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7130],{65370:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=t(74848),s=t(28453);const r={title:"Mistral API",sidebar_position:4,slug:"/guides/engines/mistral",description:"A step-by-step guide on how to integrate Jan with Mistral AI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Mistral integration"]},o=void 0,a={id:"guides/remote-providers/mistral",title:"Mistral API",description:"A step-by-step guide on how to integrate Jan with Mistral AI.",source:"@site/docs/guides/remote-providers/mistral.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/mistral",permalink:"/guides/engines/mistral",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/mistral.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:4,frontMatter:{title:"Mistral API",sidebar_position:4,slug:"/guides/engines/mistral",description:"A step-by-step guide on how to integrate Jan with Mistral AI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Mistral integration"]},sidebar:"guidesSidebar",previous:{title:"Groq API",permalink:"/guides/engines/groq"},next:{title:"OpenAI API",permalink:"/guides/engines/openai"}},l={},d=[{value:"How to Integrate Mistral AI with Jan",id:"how-to-integrate-mistral-ai-with-jan",level:2},{value:"Step 1: Configure Mistral API Key",id:"step-1-configure-mistral-api-key",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Start the Model",id:"step-3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"how-to-integrate-mistral-ai-with-jan",children:"How to Integrate Mistral AI with Jan"}),"\n",(0,i.jsx)(n.p,{children:"Jan can be used with Mistral AI API."}),"\n",(0,i.jsx)(n.h3,{id:"step-1-configure-mistral-api-key",children:"Step 1: Configure Mistral API Key"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Obtain Mistral API keys from your ",(0,i.jsx)(n.a,{href:"https://console.mistral.ai/user/api-keys/",children:"Mistral"})," dashboard."]}),"\n",(0,i.jsxs)(n.li,{children:["Insert the Mistral AI API key into ",(0,i.jsx)(n.code,{children:"~/jan/engines/openai.json"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "https://api.mistral.ai/v1/chat/completions",\n "api_key": ""\n}\n'})}),"\n",(0,i.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Create a folder named ",(0,i.jsx)(n.code,{children:"mistral-(modelname)"})," (e.g., ",(0,i.jsx)(n.code,{children:"mistral-tiny"}),")."]}),"\n",(0,i.jsxs)(n.li,{children:["Inside, create a ",(0,i.jsx)(n.code,{children:"model.json"})," file with these settings:","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"id"})," to the Mistral AI model ID."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"format"})," to ",(0,i.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"engine"})," to ",(0,i.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"state"})," to ",(0,i.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/mistral-tiny/model.json"',children:'{\n "sources": [\n {\n "filename": "mistral-tiny",\n "url": "https://mistral.ai/"\n }\n ],\n "id": "mistral-tiny",\n "object": "model",\n "name": "Mistral-7B-v0.2 (Tiny Endpoint)",\n "version": "1.0",\n "description": "Currently powered by Mistral-7B-v0.2, a better fine-tuning of the initial Mistral-7B released, inspired by the fantastic work of the community.",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Mistral AI",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["For more details regarding the ",(0,i.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,i.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Mistral AI offers various endpoints. Refer to their ",(0,i.jsx)(n.a,{href:"https://docs.mistral.ai/platform/endpoints/",children:"endpoint documentation"})," to select the one that fits your requirements. Here, we use the ",(0,i.jsx)(n.code,{children:"mistral-tiny"})," model as an example."]}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"step-3-start-the-model",children:"Step 3: Start the Model"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,i.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Locate your model and click the ",(0,i.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>a});var i=t(96540);const s={},r=i.createContext(s);function o(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/a8144d1b.eb70c7a4.js b/assets/js/a8144d1b.eb70c7a4.js deleted file mode 100644 index c6e8efd5..00000000 --- a/assets/js/a8144d1b.eb70c7a4.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7130],{65370:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=t(74848),s=t(28453);const r={title:"Mistral API",sidebar_position:4,slug:"/guides/engines/mistral",description:"A step-by-step guide on how to integrate Jan with Mistral AI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Mistral integration"]},o=void 0,a={id:"guides/remote-providers/mistral",title:"Mistral API",description:"A step-by-step guide on how to integrate Jan with Mistral AI.",source:"@site/docs/guides/remote-providers/mistral.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/mistral",permalink:"/guides/engines/mistral",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/mistral.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:4,frontMatter:{title:"Mistral API",sidebar_position:4,slug:"/guides/engines/mistral",description:"A step-by-step guide on how to integrate Jan with Mistral AI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Mistral integration"]},sidebar:"guidesSidebar",previous:{title:"Groq API",permalink:"/guides/engines/groq"},next:{title:"OpenAI API",permalink:"/guides/engines/openai"}},l={},d=[{value:"How to Integrate Mistral AI with Jan",id:"how-to-integrate-mistral-ai-with-jan",level:2},{value:"Step 1: Configure Mistral API Key",id:"step-1-configure-mistral-api-key",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Start the Model",id:"step-3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"how-to-integrate-mistral-ai-with-jan",children:"How to Integrate Mistral AI with Jan"}),"\n",(0,i.jsx)(n.p,{children:"Jan can be used with Mistral AI API."}),"\n",(0,i.jsx)(n.h3,{id:"step-1-configure-mistral-api-key",children:"Step 1: Configure Mistral API Key"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Obtain Mistral API keys from your ",(0,i.jsx)(n.a,{href:"https://console.mistral.ai/user/api-keys/",children:"Mistral"})," dashboard."]}),"\n",(0,i.jsxs)(n.li,{children:["Insert the Mistral AI API key into ",(0,i.jsx)(n.code,{children:"~/jan/engines/openai.json"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "https://api.mistral.ai/v1/chat/completions",\n "api_key": ""\n}\n'})}),"\n",(0,i.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Create a folder named ",(0,i.jsx)(n.code,{children:"mistral-(modelname)"})," (e.g., ",(0,i.jsx)(n.code,{children:"mistral-tiny"}),")."]}),"\n",(0,i.jsxs)(n.li,{children:["Inside, create a ",(0,i.jsx)(n.code,{children:"model.json"})," file with these settings:","\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"id"})," to the Mistral AI model ID."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"format"})," to ",(0,i.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"engine"})," to ",(0,i.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Set ",(0,i.jsx)(n.code,{children:"state"})," to ",(0,i.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n"]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/mistral-tiny/model.json"',children:'{\n "sources": [\n {\n "filename": "mistral-tiny",\n "url": "https://mistral.ai/"\n }\n ],\n "id": "mistral-tiny",\n "object": "model",\n "name": "Mistral-7B-v0.2 (Tiny Endpoint)",\n "version": "1.0",\n "description": "Currently powered by Mistral-7B-v0.2, a better fine-tuning of the initial Mistral-7B released, inspired by the fantastic work of the community.",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Mistral AI",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["For more details regarding the ",(0,i.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,i.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Mistral AI offers various endpoints. Refer to their ",(0,i.jsx)(n.a,{href:"https://docs.mistral.ai/platform/endpoints/",children:"endpoint documentation"})," to select the one that fits your requirements. Here, we use the ",(0,i.jsx)(n.code,{children:"mistral-tiny"})," model as an example."]}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"step-3-start-the-model",children:"Step 3: Start the Model"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,i.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Locate your model and click the ",(0,i.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>a});var i=t(96540);const s={},r=i.createContext(s);function o(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ab3966b2.10e5d91b.js b/assets/js/ab3966b2.10e5d91b.js deleted file mode 100644 index 62962359..00000000 --- a/assets/js/ab3966b2.10e5d91b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7778],{81483:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>a,frontMatter:()=>s,metadata:()=>o,toc:()=>c});var r=t(74848),d=t(28453);const s={title:"Recommended AI Hardware by Model"},i=void 0,o={id:"hardware/recommendations/by-model",title:"Recommended AI Hardware by Model",description:"Codellama 34b",source:"@site/docs/hardware/recommendations/by-model.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-model",permalink:"/hardware/recommendations/by-model",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-model.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Recommended AI Hardware by Model"}},l={},c=[{value:"Codellama 34b",id:"codellama-34b",level:2},{value:"System Requirements:",id:"system-requirements",level:3},{value:"Performance Recommendations:",id:"performance-recommendations",level:3}];function h(e){const n={a:"a",blockquote:"blockquote",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,d.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h2,{id:"codellama-34b",children:"Codellama 34b"}),"\n",(0,r.jsx)(n.h3,{id:"system-requirements",children:"System Requirements:"}),"\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.strong,{children:"For example"}),": If you want to use ",(0,r.jsx)(n.a,{href:"https://huggingface.co/TheBloke/CodeLlama-7B-Instruct-GPTQ/tree/main",children:"Codellama 7B"})," models on your own computer, you can take advantage of your GPU and run this with GPTQ file models."]}),"\n",(0,r.jsxs)(n.p,{children:["GPTQ is a format that compresses the model parameters to 4-bit, which reduces the VRAM requirements significantly. You can use the\xa0",(0,r.jsx)(n.a,{href:"https://github.com/oobabooga/text-generation-webui",children:"oobabooga webui"}),"\xa0or ",(0,r.jsx)(n.a,{href:"https://jan.ai/",children:"JanAI"}),", which are simple interfaces that let you interact with different LLMS on your browser. It is pretty easy to set up and run. You can\xa0install it on Windows\xa0or Linux. (linked it to our installation page)"]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 7B Parameter Models (4-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"6GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"6GB"}),(0,r.jsx)(n.td,{children:"GTX 1660, 2060,RTX 3050, 3060 AMD 5700 XT"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"4GB"}),(0,r.jsx)(n.td,{children:"300MB"}),(0,r.jsx)(n.td,{})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 13B Parameter Models (4-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"12GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"8GB"}),(0,r.jsx)(n.td,{children:"500MB"}),(0,r.jsx)(n.td,{children:"AMD 6900 XT, RTX 2060 12GB, 3060 12GB, 3080, A2000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 34B Parameter Models (4-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"32GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"500MB"}),(0,r.jsx)(n.td,{children:"RTX 3080 20GB, A4500, A5000, 3090, 4090, 6000, Tesla V100, Tesla P40"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{children:"4GB"}),(0,r.jsx)(n.td,{})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 7B Parameter Models (8-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"24GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"12GB"}),(0,r.jsx)(n.td,{children:"RTX 3080, RTX 3080 Ti, RTX 3090, A5000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"16GB"}),(0,r.jsx)(n.td,{children:"1GB"}),(0,r.jsx)(n.td,{children:"RTX 3060 12GB, RTX 3070, A2000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"12GB"}),(0,r.jsx)(n.td,{children:"4GB"}),(0,r.jsx)(n.td,{children:"RTX 3060, RTX 3060 Ti, A2000"})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 13B Parameter Models (8-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"36GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"RTX 4090, A6000, A6000 Ti, A8000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"24GB"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{children:"RTX 3080 20GB, RTX 3080 Ti, A5000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"8GB"}),(0,r.jsx)(n.td,{children:"RTX 3080, RTX 3080 Ti, A5000"})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 34B Parameter Models (8-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"64GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"40GB"}),(0,r.jsx)(n.td,{children:"A8000, A8000 Ti, A9000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"40GB"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{children:"RTX 4090, A6000, A6000 Ti, A8000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"48GB"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"RTX 4090, A6000, A6000 Ti, A8000"})]})]})]}),"\n",(0,r.jsxs)(n.blockquote,{children:["\n",(0,r.jsxs)(n.p,{children:["\ud83d\udcdd"," ",(0,r.jsx)(n.strong,{children:"Note"}),": System RAM, not VRAM, required to load the model, in addition to having enough VRAM. Not required to run the model. You can use swap space if you do not have enough RAM."]}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"performance-recommendations",children:"Performance Recommendations:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Optimal Performance"}),": To achieve the best performance when working with CodeLlama models, consider investing in a high-end GPU such as NVIDIA's latest RTX 3090 or RTX 4090. For the largest models like the 65B and 70B, a dual GPU setup is recommended. Additionally, ensure your system boasts sufficient RAM, with a minimum of 16 GB, although 64 GB is ideal for seamless operation."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Budget-Friendly Approach"}),": If budget constraints are a concern, focus on utilizing CodeLlama GGML/GGUF models that can comfortably fit within your system's available RAM. Keep in mind that while you can allocate some model weights to the system RAM to save GPU memory, this may result in a performance trade-off."]}),"\n"]}),"\n",(0,r.jsxs)(n.blockquote,{children:["\n",(0,r.jsxs)(n.p,{children:["\ud83d\udcdd"," ",(0,r.jsx)(n.strong,{children:"Note"}),": It's essential to note that these recommendations are guidelines, and the actual performance you experience will be influenced by various factors. These factors include the specific task you're performing, the implementation of the model, and the concurrent system processes. To optimize your setup, consider these recommendations as a starting point and adapt them to your unique requirements and constraints."]}),"\n"]})]})}function a(e={}){const{wrapper:n}={...(0,d.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>i,x:()=>o});var r=t(96540);const d={},s=r.createContext(d);function i(e){const n=r.useContext(s);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(d):e.components||d:i(e.components),r.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ab3966b2.96dab293.js b/assets/js/ab3966b2.96dab293.js new file mode 100644 index 00000000..7aa23464 --- /dev/null +++ b/assets/js/ab3966b2.96dab293.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7778],{81483:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>a,frontMatter:()=>s,metadata:()=>o,toc:()=>c});var r=t(74848),d=t(28453);const s={title:"Recommended AI Hardware by Model"},i=void 0,o={id:"hardware/recommendations/by-model",title:"Recommended AI Hardware by Model",description:"Codellama 34b",source:"@site/docs/hardware/recommendations/by-model.md",sourceDirName:"hardware/recommendations",slug:"/hardware/recommendations/by-model",permalink:"/hardware/recommendations/by-model",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/recommendations/by-model.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Recommended AI Hardware by Model"}},l={},c=[{value:"Codellama 34b",id:"codellama-34b",level:2},{value:"System Requirements:",id:"system-requirements",level:3},{value:"Performance Recommendations:",id:"performance-recommendations",level:3}];function h(e){const n={a:"a",blockquote:"blockquote",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,d.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.h2,{id:"codellama-34b",children:"Codellama 34b"}),"\n",(0,r.jsx)(n.h3,{id:"system-requirements",children:"System Requirements:"}),"\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.strong,{children:"For example"}),": If you want to use ",(0,r.jsx)(n.a,{href:"https://huggingface.co/TheBloke/CodeLlama-7B-Instruct-GPTQ/tree/main",children:"Codellama 7B"})," models on your own computer, you can take advantage of your GPU and run this with GPTQ file models."]}),"\n",(0,r.jsxs)(n.p,{children:["GPTQ is a format that compresses the model parameters to 4-bit, which reduces the VRAM requirements significantly. You can use the\xa0",(0,r.jsx)(n.a,{href:"https://github.com/oobabooga/text-generation-webui",children:"oobabooga webui"}),"\xa0or ",(0,r.jsx)(n.a,{href:"https://jan.ai/",children:"JanAI"}),", which are simple interfaces that let you interact with different LLMS on your browser. It is pretty easy to set up and run. You can\xa0install it on Windows\xa0or Linux. (linked it to our installation page)"]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 7B Parameter Models (4-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"6GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"6GB"}),(0,r.jsx)(n.td,{children:"GTX 1660, 2060,RTX 3050, 3060 AMD 5700 XT"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"4GB"}),(0,r.jsx)(n.td,{children:"300MB"}),(0,r.jsx)(n.td,{})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 13B Parameter Models (4-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"12GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"8GB"}),(0,r.jsx)(n.td,{children:"500MB"}),(0,r.jsx)(n.td,{children:"AMD 6900 XT, RTX 2060 12GB, 3060 12GB, 3080, A2000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 34B Parameter Models (4-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"32GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"500MB"}),(0,r.jsx)(n.td,{children:"RTX 3080 20GB, A4500, A5000, 3090, 4090, 6000, Tesla V100, Tesla P40"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"10GB"}),(0,r.jsx)(n.td,{children:"4GB"}),(0,r.jsx)(n.td,{})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 7B Parameter Models (8-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"24GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"12GB"}),(0,r.jsx)(n.td,{children:"RTX 3080, RTX 3080 Ti, RTX 3090, A5000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"16GB"}),(0,r.jsx)(n.td,{children:"1GB"}),(0,r.jsx)(n.td,{children:"RTX 3060 12GB, RTX 3070, A2000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"12GB"}),(0,r.jsx)(n.td,{children:"4GB"}),(0,r.jsx)(n.td,{children:"RTX 3060, RTX 3060 Ti, A2000"})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 13B Parameter Models (8-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"36GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"RTX 4090, A6000, A6000 Ti, A8000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"24GB"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{children:"RTX 3080 20GB, RTX 3080 Ti, A5000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"8GB"}),(0,r.jsx)(n.td,{children:"RTX 3080, RTX 3080 Ti, A5000"})]})]})]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.strong,{children:"For 34B Parameter Models (8-bit Quantization)"})}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Format"}),(0,r.jsx)(n.th,{children:"RAM Requirements"}),(0,r.jsx)(n.th,{children:"VRAM Requirements"}),(0,r.jsx)(n.th,{children:"Minimum recommended GPU"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GPTQ (GPU inference)"}),(0,r.jsx)(n.td,{children:"64GB (Swap to Load*)"}),(0,r.jsx)(n.td,{children:"40GB"}),(0,r.jsx)(n.td,{children:"A8000, A8000 Ti, A9000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"GGML / GGUF (CPU inference)"}),(0,r.jsx)(n.td,{children:"40GB"}),(0,r.jsx)(n.td,{children:"2GB"}),(0,r.jsx)(n.td,{children:"RTX 4090, A6000, A6000 Ti, A8000"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:"Combination of GPTQ and GGML / GGUF (offloading)"}),(0,r.jsx)(n.td,{children:"48GB"}),(0,r.jsx)(n.td,{children:"20GB"}),(0,r.jsx)(n.td,{children:"RTX 4090, A6000, A6000 Ti, A8000"})]})]})]}),"\n",(0,r.jsxs)(n.blockquote,{children:["\n",(0,r.jsxs)(n.p,{children:["\ud83d\udcdd"," ",(0,r.jsx)(n.strong,{children:"Note"}),": System RAM, not VRAM, required to load the model, in addition to having enough VRAM. Not required to run the model. You can use swap space if you do not have enough RAM."]}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"performance-recommendations",children:"Performance Recommendations:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Optimal Performance"}),": To achieve the best performance when working with CodeLlama models, consider investing in a high-end GPU such as NVIDIA's latest RTX 3090 or RTX 4090. For the largest models like the 65B and 70B, a dual GPU setup is recommended. Additionally, ensure your system boasts sufficient RAM, with a minimum of 16 GB, although 64 GB is ideal for seamless operation."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Budget-Friendly Approach"}),": If budget constraints are a concern, focus on utilizing CodeLlama GGML/GGUF models that can comfortably fit within your system's available RAM. Keep in mind that while you can allocate some model weights to the system RAM to save GPU memory, this may result in a performance trade-off."]}),"\n"]}),"\n",(0,r.jsxs)(n.blockquote,{children:["\n",(0,r.jsxs)(n.p,{children:["\ud83d\udcdd"," ",(0,r.jsx)(n.strong,{children:"Note"}),": It's essential to note that these recommendations are guidelines, and the actual performance you experience will be influenced by various factors. These factors include the specific task you're performing, the implementation of the model, and the concurrent system processes. To optimize your setup, consider these recommendations as a starting point and adapt them to your unique requirements and constraints."]}),"\n"]})]})}function a(e={}){const{wrapper:n}={...(0,d.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(h,{...e})}):h(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>i,x:()=>o});var r=t(96540);const d={},s=r.createContext(d);function i(e){const n=r.useContext(s);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(d):e.components||d:i(e.components),r.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ab40e686.1f9595da.js b/assets/js/ab40e686.1f9595da.js deleted file mode 100644 index 4473339f..00000000 --- a/assets/js/ab40e686.1f9595da.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2377],{85580:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>r,contentTitle:()=>i,default:()=>h,frontMatter:()=>d,metadata:()=>C,toc:()=>l});var t=e(74848),s=e(28453),g=e(64023);const d={title:"Product Specs",slug:"/developer/product",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","product"]},i=void 0,C={id:"developer/framework/product/README",title:"Product Specs",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/README.mdx",sourceDirName:"developer/05-framework/03-product",slug:"/developer/product",permalink:"/developer/product",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Product Specs",slug:"/developer/product",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","product"]},sidebar:"developerSidebar",previous:{title:"Threads",permalink:"/developer/framework/engineering/threads"},next:{title:"Chat",permalink:"/developer/framework/product/chat"}},r={},l=[];function F(A){return(0,t.jsx)(g.A,{className:"DocCardList--no-description"})}function h(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,t.jsx)(a,{...A,children:(0,t.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var t=e(18215),s=e(84142),g=e(20053),d=e(28774),i=e(21312),C=e(51107);const r={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},l="",F="",h="",o="",n="",u="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",N="",Q="",b="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(d.A,{href:a,className:(0,g.A)("card padding--lg",r.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:t,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,g.A)("text--truncate",r.cardTitle),title:t,children:[e," ",t]}),s&&(0,L.jsx)("p",{className:(0,g.A)(r.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,i.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:l,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",t=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??t?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const g=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,t.A)("row",e),children:g.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>d,x:()=>i});var t=e(96540);const s={},g=t.createContext(s);function d(A){const a=t.useContext(g);return t.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function i(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:d(A.components),t.createElement(g.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/ab40e686.2e05c88a.js b/assets/js/ab40e686.2e05c88a.js new file mode 100644 index 00000000..e61dd205 --- /dev/null +++ b/assets/js/ab40e686.2e05c88a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2377],{85580:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>r,contentTitle:()=>i,default:()=>h,frontMatter:()=>d,metadata:()=>C,toc:()=>l});var t=e(74848),s=e(28453),g=e(64023);const d={title:"Product Specs",slug:"/developer/product",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","product"]},i=void 0,C={id:"developer/framework/product/README",title:"Product Specs",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/README.mdx",sourceDirName:"developer/05-framework/03-product",slug:"/developer/product",permalink:"/developer/product",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Product Specs",slug:"/developer/product",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","spec","product"]},sidebar:"developerSidebar",previous:{title:"Threads",permalink:"/developer/framework/engineering/threads"},next:{title:"Chat",permalink:"/developer/framework/product/chat"}},r={},l=[];function F(A){return(0,t.jsx)(g.A,{className:"DocCardList--no-description"})}function h(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,t.jsx)(a,{...A,children:(0,t.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var t=e(18215),s=e(84142),g=e(20053),d=e(28774),i=e(21312),C=e(51107);const r={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},l="",F="",h="",o="",n="",u="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",N="",Q="",b="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(d.A,{href:a,className:(0,g.A)("card padding--lg",r.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:t,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,g.A)("text--truncate",r.cardTitle),title:t,children:[e," ",t]}),s&&(0,L.jsx)("p",{className:(0,g.A)(r.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,i.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:l,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",t=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??t?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const g=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,t.A)("row",e),children:g.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>d,x:()=>i});var t=e(96540);const s={},g=t.createContext(s);function d(A){const a=t.useContext(g);return t.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function i(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:d(A.components),t.createElement(g.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/ac2eaf96.0e654bd7.js b/assets/js/ac2eaf96.0e654bd7.js new file mode 100644 index 00000000..aef79a62 --- /dev/null +++ b/assets/js/ac2eaf96.0e654bd7.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2076],{89336:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>s,default:()=>m,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var o=n(74848),a=n(28453);const i={title:"Ollama"},s=void 0,r={id:"integrations/ollama",title:"Ollama",description:"Requested, committed, but not started",source:"@site/docs/integrations/ollama.md",sourceDirName:"integrations",slug:"/integrations/ollama",permalink:"/integrations/ollama",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/ollama.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Ollama"},sidebar:"ecosystemSidebar",previous:{title:"llama.cpp",permalink:"/integrations/llamacpp"},next:{title:"OpenAI",permalink:"/integrations/openai"}},c={},l=[];function d(t){const e={admonition:"admonition",p:"p",...(0,a.R)(),...t.components};return(0,o.jsx)(e.admonition,{type:"caution",children:(0,o.jsx)(e.p,{children:"Requested, committed, but not started"})})}function m(t={}){const{wrapper:e}={...(0,a.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(d,{...t})}):d(t)}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>r});var o=n(96540);const a={},i=o.createContext(a);function s(t){const e=o.useContext(i);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function r(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(a):t.components||a:s(t.components),o.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/ac2eaf96.2f6a7cb0.js b/assets/js/ac2eaf96.2f6a7cb0.js deleted file mode 100644 index 36b39ba0..00000000 --- a/assets/js/ac2eaf96.2f6a7cb0.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2076],{89336:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>s,default:()=>m,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var o=n(74848),a=n(28453);const i={title:"Ollama"},s=void 0,r={id:"integrations/ollama",title:"Ollama",description:"Requested, committed, but not started",source:"@site/docs/integrations/ollama.md",sourceDirName:"integrations",slug:"/integrations/ollama",permalink:"/integrations/ollama",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/ollama.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Ollama"},sidebar:"ecosystemSidebar",previous:{title:"llama.cpp",permalink:"/integrations/llamacpp"},next:{title:"OpenAI",permalink:"/integrations/openai"}},c={},l=[];function d(t){const e={admonition:"admonition",p:"p",...(0,a.R)(),...t.components};return(0,o.jsx)(e.admonition,{type:"caution",children:(0,o.jsx)(e.p,{children:"Requested, committed, but not started"})})}function m(t={}){const{wrapper:e}={...(0,a.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(d,{...t})}):d(t)}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>r});var o=n(96540);const a={},i=o.createContext(a);function s(t){const e=o.useContext(i);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function r(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(a):t.components||a:s(t.components),o.createElement(i.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/af41fd2b.18854edd.js b/assets/js/af41fd2b.18854edd.js deleted file mode 100644 index e7965c34..00000000 --- a/assets/js/af41fd2b.18854edd.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9773],{46865:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>o,contentTitle:()=>d,default:()=>h,frontMatter:()=>t,metadata:()=>i,toc:()=>l});var a=r(74848),s=r(28453);const t={title:"Threads",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},d=void 0,i={id:"developer/framework/engineering/threads",title:"Threads",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/threads.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/threads",permalink:"/developer/framework/engineering/threads",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/threads.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Threads",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Models",permalink:"/developer/framework/engineering/models"},next:{title:"Product Specs",permalink:"/developer/product"}},o={},l=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"thread.json",id:"threadjson",level:2},{value:"Example",id:"example",level:3},{value:"API Reference",id:"api-reference",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,s.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.admonition,{type:"caution",children:(0,a.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,a.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,a.jsxs)(n.p,{children:[(0,a.jsx)(n.code,{children:"Threads"})," are conversations between an ",(0,a.jsx)(n.code,{children:"assistant"})," and the user:"]}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsxs)(n.li,{children:["Users can tweak ",(0,a.jsx)(n.code,{children:"model"})," params and ",(0,a.jsx)(n.code,{children:"assistant"})," behavior within each thread."]}),"\n",(0,a.jsx)(n.li,{children:"Users can import and export threads."}),"\n",(0,a.jsxs)(n.li,{children:["An ",(0,a.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/threads",children:"OpenAI Thread API"})," compatible endpoint at ",(0,a.jsx)(n.code,{children:"localhost:1337/v1/threads"}),"."]}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsxs)(n.li,{children:["Threads are saved in the ",(0,a.jsx)(n.code,{children:"/threads"})," folder."]}),"\n",(0,a.jsx)(n.li,{children:"Threads are organized by folders, one for each thread, and can be easily zipped, exported, and cleared."}),"\n",(0,a.jsxs)(n.li,{children:["Thread folders follow the naming: ",(0,a.jsx)(n.code,{children:"assistant_id"})," + ",(0,a.jsx)(n.code,{children:"thread_created_at"}),"."]}),"\n",(0,a.jsxs)(n.li,{children:["Thread folders also contain ",(0,a.jsx)(n.code,{children:"messages.jsonl"})," files. See ",(0,a.jsx)(n.a,{href:"/docs/engineering/messages",children:"messages"}),"."]}),"\n"]}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-yaml",children:"janroot/\n threads/\n assistant_name_unix_timestamp/ # Thread `ID`\n thread.json\n"})}),"\n",(0,a.jsx)(n.h2,{id:"threadjson",children:(0,a.jsx)(n.code,{children:"thread.json"})}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsxs)(n.li,{children:["Each ",(0,a.jsx)(n.code,{children:"thread"})," folder contains a ",(0,a.jsx)(n.code,{children:"thread.json"})," file, which is a representation of a thread."]}),"\n",(0,a.jsxs)(n.li,{children:[(0,a.jsx)(n.code,{children:"thread.json"})," contains metadata and model parameter overrides."]}),"\n",(0,a.jsx)(n.li,{children:"There are no required fields."}),"\n"]}),"\n",(0,a.jsx)(n.h3,{id:"example",children:"Example"}),"\n",(0,a.jsxs)(n.p,{children:["Here's a standard example ",(0,a.jsx)(n.code,{children:"thread.json"})," for a conversation between the user and the default Jan assistant."]}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-js",children:'"id": "thread_....", // Defaults to foldername\n"object": "thread", // Defaults to "thread"\n"title": "funny physics joke", // Defaults to ""\n"assistants": [\n {\n "assistant_id": "jan", // Defaults to "jan"\n "model": { // Defaults to the currently active model (can be changed before thread is begun)\n "id": "...",\n "settings": {}, // Defaults to and overrides assistant.json\'s "settings" (and if none, then model.json "settings")\n "parameters": {}, // Defaults to and overrides assistant.json\'s "parameters" (and if none, then model.json "parameters")\n }\n },\n],\n"created": 1231231 // Defaults to file creation time\n"metadata": {}, // Defaults to {}\n'})}),"\n",(0,a.jsx)(n.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,a.jsxs)(n.p,{children:["Jan's Threads API is compatible with ",(0,a.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/threads",children:"OpenAI's Threads API"}),", with additional methods for managing threads locally."]}),"\n",(0,a.jsxs)(n.p,{children:["See ",(0,a.jsx)(n.a,{href:"https://jan.ai/api-reference#tag/Threads",children:"Jan Threads API"}),"."]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>d,x:()=>i});var a=r(96540);const s={},t=a.createContext(s);function d(e){const n=a.useContext(t);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function i(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:d(e.components),a.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/af41fd2b.3e9bdf19.js b/assets/js/af41fd2b.3e9bdf19.js new file mode 100644 index 00000000..751298a7 --- /dev/null +++ b/assets/js/af41fd2b.3e9bdf19.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9773],{46865:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>o,contentTitle:()=>d,default:()=>h,frontMatter:()=>t,metadata:()=>i,toc:()=>l});var a=r(74848),s=r(28453);const t={title:"Threads",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},d=void 0,i={id:"developer/framework/engineering/threads",title:"Threads",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/threads.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/threads",permalink:"/developer/framework/engineering/threads",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/threads.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Threads",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Models",permalink:"/developer/framework/engineering/models"},next:{title:"Product Specs",permalink:"/developer/product"}},o={},l=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"thread.json",id:"threadjson",level:2},{value:"Example",id:"example",level:3},{value:"API Reference",id:"api-reference",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,s.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.admonition,{type:"caution",children:(0,a.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,a.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,a.jsxs)(n.p,{children:[(0,a.jsx)(n.code,{children:"Threads"})," are conversations between an ",(0,a.jsx)(n.code,{children:"assistant"})," and the user:"]}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsxs)(n.li,{children:["Users can tweak ",(0,a.jsx)(n.code,{children:"model"})," params and ",(0,a.jsx)(n.code,{children:"assistant"})," behavior within each thread."]}),"\n",(0,a.jsx)(n.li,{children:"Users can import and export threads."}),"\n",(0,a.jsxs)(n.li,{children:["An ",(0,a.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/threads",children:"OpenAI Thread API"})," compatible endpoint at ",(0,a.jsx)(n.code,{children:"localhost:1337/v1/threads"}),"."]}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsxs)(n.li,{children:["Threads are saved in the ",(0,a.jsx)(n.code,{children:"/threads"})," folder."]}),"\n",(0,a.jsx)(n.li,{children:"Threads are organized by folders, one for each thread, and can be easily zipped, exported, and cleared."}),"\n",(0,a.jsxs)(n.li,{children:["Thread folders follow the naming: ",(0,a.jsx)(n.code,{children:"assistant_id"})," + ",(0,a.jsx)(n.code,{children:"thread_created_at"}),"."]}),"\n",(0,a.jsxs)(n.li,{children:["Thread folders also contain ",(0,a.jsx)(n.code,{children:"messages.jsonl"})," files. See ",(0,a.jsx)(n.a,{href:"/docs/engineering/messages",children:"messages"}),"."]}),"\n"]}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-yaml",children:"janroot/\n threads/\n assistant_name_unix_timestamp/ # Thread `ID`\n thread.json\n"})}),"\n",(0,a.jsx)(n.h2,{id:"threadjson",children:(0,a.jsx)(n.code,{children:"thread.json"})}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsxs)(n.li,{children:["Each ",(0,a.jsx)(n.code,{children:"thread"})," folder contains a ",(0,a.jsx)(n.code,{children:"thread.json"})," file, which is a representation of a thread."]}),"\n",(0,a.jsxs)(n.li,{children:[(0,a.jsx)(n.code,{children:"thread.json"})," contains metadata and model parameter overrides."]}),"\n",(0,a.jsx)(n.li,{children:"There are no required fields."}),"\n"]}),"\n",(0,a.jsx)(n.h3,{id:"example",children:"Example"}),"\n",(0,a.jsxs)(n.p,{children:["Here's a standard example ",(0,a.jsx)(n.code,{children:"thread.json"})," for a conversation between the user and the default Jan assistant."]}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-js",children:'"id": "thread_....", // Defaults to foldername\n"object": "thread", // Defaults to "thread"\n"title": "funny physics joke", // Defaults to ""\n"assistants": [\n {\n "assistant_id": "jan", // Defaults to "jan"\n "model": { // Defaults to the currently active model (can be changed before thread is begun)\n "id": "...",\n "settings": {}, // Defaults to and overrides assistant.json\'s "settings" (and if none, then model.json "settings")\n "parameters": {}, // Defaults to and overrides assistant.json\'s "parameters" (and if none, then model.json "parameters")\n }\n },\n],\n"created": 1231231 // Defaults to file creation time\n"metadata": {}, // Defaults to {}\n'})}),"\n",(0,a.jsx)(n.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,a.jsxs)(n.p,{children:["Jan's Threads API is compatible with ",(0,a.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/threads",children:"OpenAI's Threads API"}),", with additional methods for managing threads locally."]}),"\n",(0,a.jsxs)(n.p,{children:["See ",(0,a.jsx)(n.a,{href:"https://jan.ai/api-reference#tag/Threads",children:"Jan Threads API"}),"."]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>d,x:()=>i});var a=r(96540);const s={},t=a.createContext(s);function d(e){const n=a.useContext(t);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function i(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:d(e.components),a.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/b0ff4131.6becf100.js b/assets/js/b0ff4131.6becf100.js deleted file mode 100644 index 728a14df..00000000 --- a/assets/js/b0ff4131.6becf100.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9680],{73103:(s,e,t)=>{t.r(e),t.d(e,{assets:()=>c,contentTitle:()=>i,default:()=>l,frontMatter:()=>o,metadata:()=>r,toc:()=>u});var n=t(74848),a=t(28453);const o={title:"Manage Assistants",slug:"/guides/assistants",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:8,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","manage assistants","assistants"]},i=void 0,r={id:"guides/user-guides/manage-assistants",title:"Manage Assistants",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/manage-assistants.mdx",sourceDirName:"guides/user-guides",slug:"/guides/assistants",permalink:"/guides/assistants",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/manage-assistants.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:8,frontMatter:{title:"Manage Assistants",slug:"/guides/assistants",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:8,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","manage assistants","assistants"]}},c={},u=[];function d(s){const e={p:"p",...(0,a.R)(),...s.components};return(0,n.jsx)(e.p,{children:"Coming Soon"})}function l(s={}){const{wrapper:e}={...(0,a.R)(),...s.components};return e?(0,n.jsx)(e,{...s,children:(0,n.jsx)(d,{...s})}):d(s)}},28453:(s,e,t)=>{t.d(e,{R:()=>i,x:()=>r});var n=t(96540);const a={},o=n.createContext(a);function i(s){const e=n.useContext(o);return n.useMemo((function(){return"function"==typeof s?s(e):{...e,...s}}),[e,s])}function r(s){let e;return e=s.disableParentContext?"function"==typeof s.components?s.components(a):s.components||a:i(s.components),n.createElement(o.Provider,{value:e},s.children)}}}]); \ No newline at end of file diff --git a/assets/js/b0ff4131.dd907d86.js b/assets/js/b0ff4131.dd907d86.js new file mode 100644 index 00000000..c9db18d1 --- /dev/null +++ b/assets/js/b0ff4131.dd907d86.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9680],{73103:(s,e,t)=>{t.r(e),t.d(e,{assets:()=>d,contentTitle:()=>o,default:()=>u,frontMatter:()=>i,metadata:()=>r,toc:()=>l});var n=t(74848),a=t(28453);const i={title:"Manage Assistants",slug:"/guides/assistants",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","manage assistants","assistants"]},o=void 0,r={id:"guides/user-guides/manage-assistants",title:"Manage Assistants",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/manage-assistants.mdx",sourceDirName:"guides/user-guides",slug:"/guides/assistants",permalink:"/guides/assistants",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/manage-assistants.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Manage Assistants",slug:"/guides/assistants",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","manage assistants","assistants"]},sidebar:"guidesSidebar",previous:{title:"Manage Models",permalink:"/guides/models"},next:{title:"Manage Threads",permalink:"/guides/threads"}},d={},l=[{value:"Customize the Assistant",id:"customize-the-assistant",level:2},{value:"Add Assistants",id:"add-assistants",level:2}];function c(s){const e={admonition:"admonition",code:"code",h2:"h2",li:"li",ol:"ol",p:"p",strong:"strong",...(0,a.R)(),...s.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(e.p,{children:"This guide explains how to customize the default Assistant settings and add a new assistant."}),"\n",(0,n.jsx)(e.h2,{id:"customize-the-assistant",children:"Customize the Assistant"}),"\n",(0,n.jsx)(e.p,{children:"To change Jan's default settings, follow these steps:"}),"\n",(0,n.jsxs)(e.ol,{children:["\n",(0,n.jsxs)(e.li,{children:["In any thread settings, click on the 3 dots next to the ",(0,n.jsx)(e.strong,{children:"assistant"})," dropdown."]}),"\n",(0,n.jsxs)(e.li,{children:["Select ",(0,n.jsx)(e.strong,{children:"Edit global defaults"}),"."]}),"\n",(0,n.jsxs)(e.li,{children:["Edit the ",(0,n.jsx)(e.code,{children:"assistant.json"})," file based on your preferences. e.g. set a default prompt for ",(0,n.jsx)(e.code,{children:"instructions"}),"."]}),"\n",(0,n.jsx)(e.li,{children:"Refresh the application. Your changes should persist for all future threads."}),"\n"]}),"\n",(0,n.jsx)(e.h2,{id:"add-assistants",children:"Add Assistants"}),"\n",(0,n.jsx)(e.admonition,{type:"info",children:(0,n.jsx)(e.p,{children:"Coming soon"})})]})}function u(s={}){const{wrapper:e}={...(0,a.R)(),...s.components};return e?(0,n.jsx)(e,{...s,children:(0,n.jsx)(c,{...s})}):c(s)}},28453:(s,e,t)=>{t.d(e,{R:()=>o,x:()=>r});var n=t(96540);const a={},i=n.createContext(a);function o(s){const e=n.useContext(i);return n.useMemo((function(){return"function"==typeof s?s(e):{...e,...s}}),[e,s])}function r(s){let e;return e=s.disableParentContext?"function"==typeof s.components?s.components(a):s.components||a:o(s.components),n.createElement(i.Provider,{value:e},s.children)}}}]); \ No newline at end of file diff --git a/assets/js/b2a763b0.30f0385e.js b/assets/js/b2a763b0.30f0385e.js new file mode 100644 index 00000000..8b0e6807 --- /dev/null +++ b/assets/js/b2a763b0.30f0385e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2544],{77487:(e,o,t)=>{t.r(o),t.d(o,{assets:()=>l,contentTitle:()=>s,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>c});var n=t(74848),r=t(28453);const a={title:"Jan Mobile",slug:"/mobile",description:"Jan Mobile allows you to bring your AI on the go",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,i={id:"platforms/mobile",title:"Jan Mobile",description:"Jan Mobile allows you to bring your AI on the go",source:"@site/docs/platforms/mobile.md",sourceDirName:"platforms",slug:"/mobile",permalink:"/mobile",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/platforms/mobile.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan Mobile",slug:"/mobile",description:"Jan Mobile allows you to bring your AI on the go",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},l={},c=[];function u(e){return(0,n.jsx)(n.Fragment,{})}function d(e={}){const{wrapper:o}={...(0,r.R)(),...e.components};return o?(0,n.jsx)(o,{...e,children:(0,n.jsx)(u,{...e})}):u()}},28453:(e,o,t)=>{t.d(o,{R:()=>s,x:()=>i});var n=t(96540);const r={},a=n.createContext(r);function s(e){const o=n.useContext(a);return n.useMemo((function(){return"function"==typeof e?e(o):{...o,...e}}),[o,e])}function i(e){let o;return o=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:s(e.components),n.createElement(a.Provider,{value:o},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/b2a763b0.8e2b995e.js b/assets/js/b2a763b0.8e2b995e.js deleted file mode 100644 index 56d7aa85..00000000 --- a/assets/js/b2a763b0.8e2b995e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2544],{77487:(e,o,t)=>{t.r(o),t.d(o,{assets:()=>l,contentTitle:()=>s,default:()=>d,frontMatter:()=>r,metadata:()=>i,toc:()=>c});var n=t(74848),a=t(28453);const r={title:"Jan Mobile",slug:"/mobile",description:"Jan Mobile allows you to bring your AI on the go",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,i={id:"platforms/mobile",title:"Jan Mobile",description:"Jan Mobile allows you to bring your AI on the go",source:"@site/docs/platforms/mobile.md",sourceDirName:"platforms",slug:"/mobile",permalink:"/mobile",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/platforms/mobile.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan Mobile",slug:"/mobile",description:"Jan Mobile allows you to bring your AI on the go",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},l={},c=[];function u(e){return(0,n.jsx)(n.Fragment,{})}function d(e={}){const{wrapper:o}={...(0,a.R)(),...e.components};return o?(0,n.jsx)(o,{...e,children:(0,n.jsx)(u,{...e})}):u()}},28453:(e,o,t)=>{t.d(o,{R:()=>s,x:()=>i});var n=t(96540);const a={},r=n.createContext(a);function s(e){const o=n.useContext(r);return n.useMemo((function(){return"function"==typeof e?e(o):{...o,...e}}),[o,e])}function i(e){let o;return o=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),n.createElement(r.Provider,{value:o},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/b2e8bd45.624087ee.js b/assets/js/b2e8bd45.624087ee.js new file mode 100644 index 00000000..a16907df --- /dev/null +++ b/assets/js/b2e8bd45.624087ee.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5347],{38800:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var s=n(74848),o=n(28453);const r={title:"Legal",tags:["industries"]},i=void 0,a={id:"solutions/legal",title:"Legal",description:"",source:"@site/docs/solutions/legal.md",sourceDirName:"solutions",slug:"/solutions/legal",permalink:"/solutions/legal",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/legal.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Legal",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Healthcare",permalink:"/solutions/healthcare"},next:{title:"Government",permalink:"/solutions/government"}},l={},u=[];function c(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(c,{...t})}):c()}},28453:(t,e,n)=>{n.d(e,{R:()=>i,x:()=>a});var s=n(96540);const o={},r=s.createContext(o);function i(t){const e=s.useContext(r);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:i(t.components),s.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/b2e8bd45.b17bb000.js b/assets/js/b2e8bd45.b17bb000.js deleted file mode 100644 index 14cc5506..00000000 --- a/assets/js/b2e8bd45.b17bb000.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5347],{38800:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var s=n(74848),o=n(28453);const r={title:"Legal",tags:["industries"]},i=void 0,a={id:"solutions/legal",title:"Legal",description:"",source:"@site/docs/solutions/legal.md",sourceDirName:"solutions",slug:"/solutions/legal",permalink:"/solutions/legal",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/legal.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Legal",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Healthcare",permalink:"/solutions/healthcare"},next:{title:"Government",permalink:"/solutions/government"}},l={},u=[];function c(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(c,{...t})}):c()}},28453:(t,e,n)=>{n.d(e,{R:()=>i,x:()=>a});var s=n(96540);const o={},r=s.createContext(o);function i(t){const e=s.useContext(r);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:i(t.components),s.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/b7c91fb8.33c70335.js b/assets/js/b7c91fb8.33c70335.js deleted file mode 100644 index 964d8b10..00000000 --- a/assets/js/b7c91fb8.33c70335.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1245],{27111:(e,t,o)=>{o.r(t),o.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>d,frontMatter:()=>s,metadata:()=>c,toc:()=>u});var n=o(74848),r=o(28453);const s={title:"Local & Self-Hosted AI"},a=void 0,c={id:"features/local",title:"Local & Self-Hosted AI",description:"",source:"@site/docs/features/local.md",sourceDirName:"features",slug:"/features/local",permalink:"/features/local",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/local.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Local & Self-Hosted AI"},sidebar:"productSidebar",previous:{title:"Features",permalink:"/features/"},next:{title:"OpenAI API Support (and others)",permalink:"/features/remote"}},l={},u=[];function i(e){return(0,n.jsx)(n.Fragment,{})}function d(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(i,{...e})}):i()}},28453:(e,t,o)=>{o.d(t,{R:()=>a,x:()=>c});var n=o(96540);const r={},s=n.createContext(r);function a(e){const t=n.useContext(s);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),n.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/b7c91fb8.ea8b8655.js b/assets/js/b7c91fb8.ea8b8655.js new file mode 100644 index 00000000..d69faad4 --- /dev/null +++ b/assets/js/b7c91fb8.ea8b8655.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1245],{27111:(e,t,o)=>{o.r(t),o.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>d,frontMatter:()=>s,metadata:()=>c,toc:()=>u});var n=o(74848),r=o(28453);const s={title:"Local & Self-Hosted AI"},a=void 0,c={id:"features/local",title:"Local & Self-Hosted AI",description:"",source:"@site/docs/features/local.md",sourceDirName:"features",slug:"/features/local",permalink:"/features/local",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/local.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Local & Self-Hosted AI"},sidebar:"productSidebar",previous:{title:"Features",permalink:"/features/"},next:{title:"OpenAI API Support (and others)",permalink:"/features/remote"}},l={},u=[];function i(e){return(0,n.jsx)(n.Fragment,{})}function d(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(i,{...e})}):i()}},28453:(e,t,o)=>{o.d(t,{R:()=>a,x:()=>c});var n=o(96540);const r={},s=n.createContext(r);function a(e){const t=n.useContext(s);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function c(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),n.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/b7da00f9.5c641d07.js b/assets/js/b7da00f9.5c641d07.js new file mode 100644 index 00000000..ccb25710 --- /dev/null +++ b/assets/js/b7da00f9.5c641d07.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8600],{79539:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var r=t(74848),s=t(28453);const o={title:"Strategy"},i=void 0,a={id:"how-we-work/strategy/strategy",title:"Strategy",description:"We only have 2 planning parameters:",source:"@site/docs/how-we-work/strategy/strategy.md",sourceDirName:"how-we-work/strategy",slug:"/how-we-work/strategy/",permalink:"/how-we-work/strategy/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/strategy/strategy.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Strategy"},sidebar:"aboutSidebar",previous:{title:"How We Work",permalink:"/how-we-work"},next:{title:"Project Management",permalink:"/how-we-work/project-management"}},l={},c=[{value:"Ideal Customer",id:"ideal-customer",level:3},{value:"Problems",id:"problems",level:3},{value:"Solution",id:"solution",level:3},{value:"Prerequisites",id:"prerequisites",level:2}];function d(e){const n={a:"a",em:"em",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",section:"section",sup:"sup",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.p,{children:"We only have 2 planning parameters:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"10 year vision"}),"\n",(0,r.jsx)(n.li,{children:"2 week sprint"}),"\n",(0,r.jsx)(n.li,{children:"Quarterly OKRs"}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"ideal-customer",children:"Ideal Customer"}),"\n",(0,r.jsx)(n.p,{children:"Our ideal customer is an AI enthusiast or business who has experienced some limitations with current AI solutions and is keen to find open source alternatives."}),"\n",(0,r.jsx)(n.h3,{id:"problems",children:"Problems"}),"\n",(0,r.jsx)(n.p,{children:"Our ideal customer would use Jan to solve one of these problems."}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.em,{children:"Control"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Control (e.g. preventing vendor lock-in)"}),"\n",(0,r.jsx)(n.li,{children:"Stability (e.g. runs predictably every time)"}),"\n",(0,r.jsx)(n.li,{children:"Local-use (e.g. for speed, or for airgapped environments)"}),"\n"]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.em,{children:"Privacy"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Data protection (e.g. personal data or company data)"}),"\n",(0,r.jsx)(n.li,{children:"Privacy (e.g. nsfw)"}),"\n"]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.em,{children:"Customisability"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Tinkerability (e.g. ability to change model, experiment)"}),"\n",(0,r.jsx)(n.li,{children:"Niche Models (e.g. fine-tuned, domain-specific models that outperform OpenAI)"}),"\n"]}),"\n",(0,r.jsxs)(n.p,{children:["Sources: ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-1",id:"user-content-fnref-1","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"1"})})," ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-2",id:"user-content-fnref-2","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"2"})})," ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-3",id:"user-content-fnref-3","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"3"})})," ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-4",id:"user-content-fnref-4","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"4"})})]}),"\n",(0,r.jsx)(n.h3,{id:"solution",children:"Solution"}),"\n",(0,r.jsx)(n.p,{children:"Jan is a seamless user experience that runs on your personal computer, that glues the different pieces of the open source AI ecosystem to provide an alternative to OpenAI's closed platform."}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"We build a comprehensive, seamless platform that takes care of the technical chores across the stack required to run open source AI"}),"\n",(0,r.jsx)(n.li,{children:"We run on top of a local folder of non-proprietary files, that anyone can tinker with (yes, even other apps!)"}),"\n",(0,r.jsx)(n.li,{children:"We provide open formats for packaging and distributing AI to run reproducibly across devices"}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://figma.com",children:"Figma"})}),"\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://www.screen.studio/",children:"ScreenStudio"})}),"\n"]}),"\n",(0,r.jsxs)(n.section,{"data-footnotes":!0,className:"footnotes",children:[(0,r.jsx)(n.h2,{className:"sr-only",id:"footnote-label",children:"Footnotes"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{id:"user-content-fn-1",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/17mghqr/comment/k7ksti6/?utm_source=share&utm_medium=web2x&context=3",children:"What are you guys doing that can't be done with ChatGPT?"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-1","data-footnote-backref":"","aria-label":"Back to reference 1",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,r.jsxs)(n.li,{id:"user-content-fn-2",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/1718a9o/whats_your_main_interest_in_running_a_local_llm/",children:"What's your main interest in running a local LLM instead of an existing API?"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-2","data-footnote-backref":"","aria-label":"Back to reference 2",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,r.jsxs)(n.li,{id:"user-content-fn-3",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://news.ycombinator.com/item?id=36138224",children:"Ask HN: What's the best self-hosted/local alternative to GPT-4?"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-3","data-footnote-backref":"","aria-label":"Back to reference 3",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,r.jsxs)(n.li,{id:"user-content-fn-4",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/17mghqr/comment/k7mdz1i/?utm_source=share&utm_medium=web2x&context=3",children:"LoRAs"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-4","data-footnote-backref":"","aria-label":"Back to reference 4",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n"]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>i,x:()=>a});var r=t(96540);const s={},o=r.createContext(s);function i(e){const n=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),r.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/b7da00f9.80583b77.js b/assets/js/b7da00f9.80583b77.js deleted file mode 100644 index 49e25814..00000000 --- a/assets/js/b7da00f9.80583b77.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8600],{79539:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var r=t(74848),s=t(28453);const o={title:"Strategy"},i=void 0,a={id:"how-we-work/strategy/strategy",title:"Strategy",description:"We only have 2 planning parameters:",source:"@site/docs/how-we-work/strategy/strategy.md",sourceDirName:"how-we-work/strategy",slug:"/how-we-work/strategy/",permalink:"/how-we-work/strategy/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/strategy/strategy.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Strategy"},sidebar:"aboutSidebar",previous:{title:"How We Work",permalink:"/how-we-work"},next:{title:"Project Management",permalink:"/how-we-work/project-management"}},l={},c=[{value:"Ideal Customer",id:"ideal-customer",level:3},{value:"Problems",id:"problems",level:3},{value:"Solution",id:"solution",level:3},{value:"Prerequisites",id:"prerequisites",level:2}];function d(e){const n={a:"a",em:"em",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",section:"section",sup:"sup",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.p,{children:"We only have 2 planning parameters:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"10 year vision"}),"\n",(0,r.jsx)(n.li,{children:"2 week sprint"}),"\n",(0,r.jsx)(n.li,{children:"Quarterly OKRs"}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"ideal-customer",children:"Ideal Customer"}),"\n",(0,r.jsx)(n.p,{children:"Our ideal customer is an AI enthusiast or business who has experienced some limitations with current AI solutions and is keen to find open source alternatives."}),"\n",(0,r.jsx)(n.h3,{id:"problems",children:"Problems"}),"\n",(0,r.jsx)(n.p,{children:"Our ideal customer would use Jan to solve one of these problems."}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.em,{children:"Control"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Control (e.g. preventing vendor lock-in)"}),"\n",(0,r.jsx)(n.li,{children:"Stability (e.g. runs predictably every time)"}),"\n",(0,r.jsx)(n.li,{children:"Local-use (e.g. for speed, or for airgapped environments)"}),"\n"]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.em,{children:"Privacy"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Data protection (e.g. personal data or company data)"}),"\n",(0,r.jsx)(n.li,{children:"Privacy (e.g. nsfw)"}),"\n"]}),"\n",(0,r.jsx)(n.p,{children:(0,r.jsx)(n.em,{children:"Customisability"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Tinkerability (e.g. ability to change model, experiment)"}),"\n",(0,r.jsx)(n.li,{children:"Niche Models (e.g. fine-tuned, domain-specific models that outperform OpenAI)"}),"\n"]}),"\n",(0,r.jsxs)(n.p,{children:["Sources: ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-1",id:"user-content-fnref-1","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"1"})})," ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-2",id:"user-content-fnref-2","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"2"})})," ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-3",id:"user-content-fnref-3","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"3"})})," ",(0,r.jsx)(n.sup,{children:(0,r.jsx)(n.a,{href:"#user-content-fn-4",id:"user-content-fnref-4","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"4"})})]}),"\n",(0,r.jsx)(n.h3,{id:"solution",children:"Solution"}),"\n",(0,r.jsx)(n.p,{children:"Jan is a seamless user experience that runs on your personal computer, that glues the different pieces of the open source AI ecosystem to provide an alternative to OpenAI's closed platform."}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"We build a comprehensive, seamless platform that takes care of the technical chores across the stack required to run open source AI"}),"\n",(0,r.jsx)(n.li,{children:"We run on top of a local folder of non-proprietary files, that anyone can tinker with (yes, even other apps!)"}),"\n",(0,r.jsx)(n.li,{children:"We provide open formats for packaging and distributing AI to run reproducibly across devices"}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://figma.com",children:"Figma"})}),"\n",(0,r.jsx)(n.li,{children:(0,r.jsx)(n.a,{href:"https://www.screen.studio/",children:"ScreenStudio"})}),"\n"]}),"\n",(0,r.jsxs)(n.section,{"data-footnotes":!0,className:"footnotes",children:[(0,r.jsx)(n.h2,{className:"sr-only",id:"footnote-label",children:"Footnotes"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{id:"user-content-fn-1",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/17mghqr/comment/k7ksti6/?utm_source=share&utm_medium=web2x&context=3",children:"What are you guys doing that can't be done with ChatGPT?"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-1","data-footnote-backref":"","aria-label":"Back to reference 1",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,r.jsxs)(n.li,{id:"user-content-fn-2",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/1718a9o/whats_your_main_interest_in_running_a_local_llm/",children:"What's your main interest in running a local LLM instead of an existing API?"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-2","data-footnote-backref":"","aria-label":"Back to reference 2",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,r.jsxs)(n.li,{id:"user-content-fn-3",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://news.ycombinator.com/item?id=36138224",children:"Ask HN: What's the best self-hosted/local alternative to GPT-4?"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-3","data-footnote-backref":"","aria-label":"Back to reference 3",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,r.jsxs)(n.li,{id:"user-content-fn-4",children:["\n",(0,r.jsxs)(n.p,{children:[(0,r.jsx)(n.a,{href:"https://www.reddit.com/r/LocalLLaMA/comments/17mghqr/comment/k7mdz1i/?utm_source=share&utm_medium=web2x&context=3",children:"LoRAs"})," ",(0,r.jsx)(n.a,{href:"#user-content-fnref-4","data-footnote-backref":"","aria-label":"Back to reference 4",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n"]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>i,x:()=>a});var r=t(96540);const s={},o=r.createContext(s);function i(e){const n=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:i(e.components),r.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/bdfdc86d.3950ee20.js b/assets/js/bdfdc86d.3950ee20.js deleted file mode 100644 index 967708cf..00000000 --- a/assets/js/bdfdc86d.3950ee20.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[176],{3750:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>o,default:()=>d,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var s=i(74848),t=i(28453);const a={sidebar_position:15,slug:"/changelog/changelog-v0.2.3"},o="v0.2.3",l={id:"releases/changelog/changelog-v0.2.3",title:"v0.2.3",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.3.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.3",permalink:"/changelog/changelog-v0.2.3",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.3.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:15,frontMatter:{sidebar_position:15,slug:"/changelog/changelog-v0.2.3"},sidebar:"releasesSidebar",previous:{title:"v0.3.0",permalink:"/changelog/changelog-v0.3.0"},next:{title:"v0.2.2",permalink:"/changelog/changelog-v0.2.2"}},r={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function h(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"v023",children:"v0.2.3"}),"\n",(0,s.jsxs)(n.p,{children:["For more details, ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.3",children:"GitHub Issues"})]}),"\n",(0,s.jsxs)(n.p,{children:["Highlighted Issue: ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/482",children:"Issue #482: fix: hide preferences section if empty"})]}),"\n",(0,s.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"fix: hide preferences section if empty @louis-jan (#482)"}),"\n",(0,s.jsx)(n.li,{children:"chore: fix conversation summary @louis-jan (#480)"}),"\n",(0,s.jsx)(n.li,{children:"chore: missing create conversation button when there is no conversation is selected @louis-jan (#478)"}),"\n",(0,s.jsx)(n.li,{children:"fix: download now change state immediately @namchuai (#475)"}),"\n",(0,s.jsx)(n.li,{children:"chore: add required app version to edge release plugin @louis-jan (#471)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"add rebuild for mac x64 @hiento09 (#473)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Add build deps for data-plugin in CI @hiento09 (#472)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,s.jsx)(n.p,{children:"@hiento09, @hientominh, @jan-service-account, @louis-jan and @namchuai"})]})}function d(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>l});var s=i(96540);const t={},a=s.createContext(t);function o(e){const n=s.useContext(a);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),s.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/bdfdc86d.c2134efb.js b/assets/js/bdfdc86d.c2134efb.js new file mode 100644 index 00000000..fdfba87b --- /dev/null +++ b/assets/js/bdfdc86d.c2134efb.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[176],{3750:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>o,default:()=>d,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var s=i(74848),t=i(28453);const a={sidebar_position:15,slug:"/changelog/changelog-v0.2.3"},o="v0.2.3",l={id:"releases/changelog/changelog-v0.2.3",title:"v0.2.3",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.3.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.3",permalink:"/changelog/changelog-v0.2.3",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.3.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:15,frontMatter:{sidebar_position:15,slug:"/changelog/changelog-v0.2.3"},sidebar:"releasesSidebar",previous:{title:"v0.3.0",permalink:"/changelog/changelog-v0.3.0"},next:{title:"v0.2.2",permalink:"/changelog/changelog-v0.2.2"}},r={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function h(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"v023",children:"v0.2.3"}),"\n",(0,s.jsxs)(n.p,{children:["For more details, ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.3",children:"GitHub Issues"})]}),"\n",(0,s.jsxs)(n.p,{children:["Highlighted Issue: ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/482",children:"Issue #482: fix: hide preferences section if empty"})]}),"\n",(0,s.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"fix: hide preferences section if empty @louis-jan (#482)"}),"\n",(0,s.jsx)(n.li,{children:"chore: fix conversation summary @louis-jan (#480)"}),"\n",(0,s.jsx)(n.li,{children:"chore: missing create conversation button when there is no conversation is selected @louis-jan (#478)"}),"\n",(0,s.jsx)(n.li,{children:"fix: download now change state immediately @namchuai (#475)"}),"\n",(0,s.jsx)(n.li,{children:"chore: add required app version to edge release plugin @louis-jan (#471)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"add rebuild for mac x64 @hiento09 (#473)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Add build deps for data-plugin in CI @hiento09 (#472)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,s.jsx)(n.p,{children:"@hiento09, @hientominh, @jan-service-account, @louis-jan and @namchuai"})]})}function d(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>l});var s=i(96540);const t={},a=s.createContext(t);function o(e){const n=s.useContext(a);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),s.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/be9dd107.0d86e6b2.js b/assets/js/be9dd107.0d86e6b2.js new file mode 100644 index 00000000..cbd48963 --- /dev/null +++ b/assets/js/be9dd107.0d86e6b2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1013],{21730:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>r,default:()=>h,frontMatter:()=>l,metadata:()=>o,toc:()=>c});var s=i(74848),a=i(28453);const l={sidebar_position:1,slug:"/changelog/changelog-v0.4.9"},r="v0.4.9",o={id:"releases/changelog/changelog-v0.4.9",title:"v0.4.9",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.9.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.9",permalink:"/changelog/changelog-v0.4.9",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.9.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{sidebar_position:1,slug:"/changelog/changelog-v0.4.9"},sidebar:"releasesSidebar",previous:{title:"Changelog",permalink:"/changelog"},next:{title:"v0.4.8",permalink:"/changelog/changelog-v0.4.8"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h1,{id:"v049",children:"v0.4.9"}),"\n",(0,s.jsxs)(n.p,{children:["For more details, ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.9",children:"GitHub Issues"})]}),"\n",(0,s.jsxs)(n.p,{children:["Highlighted Issue: ",(0,s.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/2421",children:"Issue #2421: Release/v0.4.9"})]}),"\n",(0,s.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Release/v0.4.9 @namchuai (#2421)"}),"\n",(0,s.jsx)(n.li,{children:"Release cut 0.4.9 @louis-jan (#2398)"}),"\n",(0,s.jsx)(n.li,{children:"Update models.json @louis-jan (#2382)"}),"\n",(0,s.jsx)(n.li,{children:"docs: add about/faq @eckartal (#2329)"}),"\n",(0,s.jsx)(n.li,{children:"Update docs 14th mar @dan-jan (#2362)"}),"\n",(0,s.jsx)(n.li,{children:"feat: Nitro-Tensorrt-LLM Extension @louis-jan (#2280)"}),"\n",(0,s.jsx)(n.li,{children:"Sync release 0.4.8 to dev @louis-jan (#2297)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"feat: quick ask support dark mode @urmauur (#2316)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"fix: move tensorrt executable to engine @namchuai (#2400)"}),"\n",(0,s.jsx)(n.li,{children:"fix: unable to start web with quick ask @namchuai (#2402)"}),"\n",(0,s.jsx)(n.li,{children:"fix: fail-fast would cancel matrix jobs as soon as one job fails @louis-jan (#2401)"}),"\n",(0,s.jsx)(n.li,{children:"fix: clean working dir with long space support on Windows @louis-jan (#2399)"}),"\n",(0,s.jsx)(n.li,{children:"fix: line height typography blog and docs @urmauur (#2390)"}),"\n",(0,s.jsx)(n.li,{children:"fix: some regressions for tensorrt nightly build @namchuai (#2380)"}),"\n",(0,s.jsx)(n.li,{children:"fix: use model from model hub not load correct model in thread screen @namchuai (#2368)"}),"\n",(0,s.jsx)(n.li,{children:"fix: wrong engine handling @louis-jan (#2363)"}),"\n",(0,s.jsx)(n.li,{children:"fix: incompatible GPU error message @louis-jan (#2357)"}),"\n",(0,s.jsx)(n.li,{children:"fix: app does not recognize GPU first launch @louis-jan (#2350)"}),"\n",(0,s.jsx)(n.li,{children:"fix: disable rag & stream settings from tensorrt llm model.json @louis-jan (#2351)"}),"\n",(0,s.jsx)(n.li,{children:"fix: badge or progress tensorRtExtensionItem @urmauur (#2349)"}),"\n",(0,s.jsx)(n.li,{children:"fix: ts error when declar var in case @namchuai (#2348)"}),"\n",(0,s.jsx)(n.li,{children:"fix: some costmetic issues: badges corner, recommended for tensorrt models @namchuai (#2346)"}),"\n",(0,s.jsx)(n.li,{children:"Add icon file contain image size in file name to fix linux icon @hiento09 (#2344)"}),"\n",(0,s.jsx)(n.li,{children:"fix: put quick ask feature toggle under experimental feature @louis-jan (#2338)"}),"\n",(0,s.jsx)(n.li,{children:"fix: do not migrate extensions from quick ask window @louis-jan (#2336)"}),"\n",(0,s.jsx)(n.li,{children:"fix: existing changelog @hieu-jan (#2330)"}),"\n",(0,s.jsx)(n.li,{children:"fix: gate quick ask with feature toggle @louis-jan (#2331)"}),"\n",(0,s.jsx)(n.li,{children:"fix: quick app windows, tray and dock behaviors @louis-jan (#2327)"}),"\n",(0,s.jsx)(n.li,{children:"fix: jan app tray blocks app update @louis-jan (#2319)"}),"\n",(0,s.jsx)(n.li,{children:"fix: quick ask not show @louis-jan (#2315)"}),"\n",(0,s.jsx)(n.li,{children:"fix: quick ask blocks app update @louis-jan (#2310)"}),"\n",(0,s.jsx)(n.li,{children:"fix: message from quick ask not get the selected model @namchuai (#2307)"}),"\n",(0,s.jsx)(n.li,{children:"fix: replace robotjs by nutjs (#2295) @louis-jan (#2302)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"docs: Update sidebar and content for http proxy and import model @aindrajaya (#2328)"}),"\n",(0,s.jsx)(n.li,{children:"chore: temporary remove linux from tensorrt support @namchuai (#2386)"}),"\n",(0,s.jsx)(n.li,{children:"docs: Update broken-build.mdx @0xSage (#2385)"}),"\n",(0,s.jsx)(n.li,{children:"docs: sync updated content to main page @hieu-jan (#2384)"}),"\n",(0,s.jsx)(n.li,{children:"docs: fix broken link by redirecting to the right paths @aindrajaya (#2381)"}),"\n",(0,s.jsx)(n.li,{children:"docs: api reference 2.0 @aindrajaya (#2367)"}),"\n",(0,s.jsx)(n.li,{children:"docs: bump changelog v0.4.8 @hieu-jan (#2366)"}),"\n",(0,s.jsx)(n.li,{children:"docs: trt-llm extension guides @0xSage (#2353)"}),"\n",(0,s.jsx)(n.li,{children:"docs: enhance autogenerate changelog configuration @hieu-jan (#2289)"}),"\n",(0,s.jsx)(n.li,{children:"docs: update website-docs content @hieu-jan (#2287)"}),"\n",(0,s.jsx)(n.li,{children:"docs: update slogan @hieu-jan (#2282)"}),"\n",(0,s.jsx)(n.li,{children:"docs: sync updated content from dev to docs branch @hieu-jan (#2283)"}),"\n",(0,s.jsx)(n.li,{children:"docs: Fix install slug and fix navbar style in darkmode @aindrajaya (#2306)"}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,s.jsx)(n.p,{children:"@0xSage, @aindrajaya, @dan-jan, @eckartal, @hiento09, @hieu-jan, @jan-service-account, @louis-jan, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>o});var s=i(96540);const a={},l=s.createContext(a);function r(e){const n=s.useContext(l);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),s.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/be9dd107.ec2c2c53.js b/assets/js/be9dd107.ec2c2c53.js deleted file mode 100644 index e86f6b5e..00000000 --- a/assets/js/be9dd107.ec2c2c53.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1013],{21730:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>r,default:()=>h,frontMatter:()=>l,metadata:()=>o,toc:()=>c});var a=i(74848),s=i(28453);const l={sidebar_position:1,slug:"/changelog/changelog-v0.4.9"},r="v0.4.9",o={id:"releases/changelog/changelog-v0.4.9",title:"v0.4.9",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.9.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.9",permalink:"/changelog/changelog-v0.4.9",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.9.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{sidebar_position:1,slug:"/changelog/changelog-v0.4.9"},sidebar:"releasesSidebar",previous:{title:"Changelog",permalink:"/changelog"},next:{title:"v0.4.8",permalink:"/changelog/changelog-v0.4.8"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v049",children:"v0.4.9"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.9",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/2421",children:"Issue #2421: Release/v0.4.9"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Release/v0.4.9 @namchuai (#2421)"}),"\n",(0,a.jsx)(n.li,{children:"Release cut 0.4.9 @louis-jan (#2398)"}),"\n",(0,a.jsx)(n.li,{children:"Update models.json @louis-jan (#2382)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add about/faq @eckartal (#2329)"}),"\n",(0,a.jsx)(n.li,{children:"Update docs 14th mar @dan-jan (#2362)"}),"\n",(0,a.jsx)(n.li,{children:"feat: Nitro-Tensorrt-LLM Extension @louis-jan (#2280)"}),"\n",(0,a.jsx)(n.li,{children:"Sync release 0.4.8 to dev @louis-jan (#2297)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: quick ask support dark mode @urmauur (#2316)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: move tensorrt executable to engine @namchuai (#2400)"}),"\n",(0,a.jsx)(n.li,{children:"fix: unable to start web with quick ask @namchuai (#2402)"}),"\n",(0,a.jsx)(n.li,{children:"fix: fail-fast would cancel matrix jobs as soon as one job fails @louis-jan (#2401)"}),"\n",(0,a.jsx)(n.li,{children:"fix: clean working dir with long space support on Windows @louis-jan (#2399)"}),"\n",(0,a.jsx)(n.li,{children:"fix: line height typography blog and docs @urmauur (#2390)"}),"\n",(0,a.jsx)(n.li,{children:"fix: some regressions for tensorrt nightly build @namchuai (#2380)"}),"\n",(0,a.jsx)(n.li,{children:"fix: use model from model hub not load correct model in thread screen @namchuai (#2368)"}),"\n",(0,a.jsx)(n.li,{children:"fix: wrong engine handling @louis-jan (#2363)"}),"\n",(0,a.jsx)(n.li,{children:"fix: incompatible GPU error message @louis-jan (#2357)"}),"\n",(0,a.jsx)(n.li,{children:"fix: app does not recognize GPU first launch @louis-jan (#2350)"}),"\n",(0,a.jsx)(n.li,{children:"fix: disable rag & stream settings from tensorrt llm model.json @louis-jan (#2351)"}),"\n",(0,a.jsx)(n.li,{children:"fix: badge or progress tensorRtExtensionItem @urmauur (#2349)"}),"\n",(0,a.jsx)(n.li,{children:"fix: ts error when declar var in case @namchuai (#2348)"}),"\n",(0,a.jsx)(n.li,{children:"fix: some costmetic issues: badges corner, recommended for tensorrt models @namchuai (#2346)"}),"\n",(0,a.jsx)(n.li,{children:"Add icon file contain image size in file name to fix linux icon @hiento09 (#2344)"}),"\n",(0,a.jsx)(n.li,{children:"fix: put quick ask feature toggle under experimental feature @louis-jan (#2338)"}),"\n",(0,a.jsx)(n.li,{children:"fix: do not migrate extensions from quick ask window @louis-jan (#2336)"}),"\n",(0,a.jsx)(n.li,{children:"fix: existing changelog @hieu-jan (#2330)"}),"\n",(0,a.jsx)(n.li,{children:"fix: gate quick ask with feature toggle @louis-jan (#2331)"}),"\n",(0,a.jsx)(n.li,{children:"fix: quick app windows, tray and dock behaviors @louis-jan (#2327)"}),"\n",(0,a.jsx)(n.li,{children:"fix: jan app tray blocks app update @louis-jan (#2319)"}),"\n",(0,a.jsx)(n.li,{children:"fix: quick ask not show @louis-jan (#2315)"}),"\n",(0,a.jsx)(n.li,{children:"fix: quick ask blocks app update @louis-jan (#2310)"}),"\n",(0,a.jsx)(n.li,{children:"fix: message from quick ask not get the selected model @namchuai (#2307)"}),"\n",(0,a.jsx)(n.li,{children:"fix: replace robotjs by nutjs (#2295) @louis-jan (#2302)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"docs: Update sidebar and content for http proxy and import model @aindrajaya (#2328)"}),"\n",(0,a.jsx)(n.li,{children:"chore: temporary remove linux from tensorrt support @namchuai (#2386)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update broken-build.mdx @0xSage (#2385)"}),"\n",(0,a.jsx)(n.li,{children:"docs: sync updated content to main page @hieu-jan (#2384)"}),"\n",(0,a.jsx)(n.li,{children:"docs: fix broken link by redirecting to the right paths @aindrajaya (#2381)"}),"\n",(0,a.jsx)(n.li,{children:"docs: api reference 2.0 @aindrajaya (#2367)"}),"\n",(0,a.jsx)(n.li,{children:"docs: bump changelog v0.4.8 @hieu-jan (#2366)"}),"\n",(0,a.jsx)(n.li,{children:"docs: trt-llm extension guides @0xSage (#2353)"}),"\n",(0,a.jsx)(n.li,{children:"docs: enhance autogenerate changelog configuration @hieu-jan (#2289)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update website-docs content @hieu-jan (#2287)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update slogan @hieu-jan (#2282)"}),"\n",(0,a.jsx)(n.li,{children:"docs: sync updated content from dev to docs branch @hieu-jan (#2283)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Fix install slug and fix navbar style in darkmode @aindrajaya (#2306)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @aindrajaya, @dan-jan, @eckartal, @hiento09, @hieu-jan, @jan-service-account, @louis-jan, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>o});var a=i(96540);const s={},l=a.createContext(s);function r(e){const n=a.useContext(l);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),a.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/bebfba98.3448991c.js b/assets/js/bebfba98.b4d8f819.js similarity index 50% rename from assets/js/bebfba98.3448991c.js rename to assets/js/bebfba98.b4d8f819.js index d4ccc3e5..64110ee7 100644 --- a/assets/js/bebfba98.3448991c.js +++ b/assets/js/bebfba98.b4d8f819.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3100],{46147:(e,t,s)=>{s.r(t),s.d(t,{assets:()=>c,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>l});var o=s(74848),n=s(28453);const a={title:"AI Employees",tags:["use-cases"]},r=void 0,i={id:"solutions/ai-employees",title:"AI Employees",description:"",source:"@site/docs/solutions/ai-employees.md",sourceDirName:"solutions",slug:"/solutions/ai-employees",permalink:"/solutions/ai-employees",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/ai-employees.md",tags:[{label:"use-cases",permalink:"/tags/use-cases"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"AI Employees",tags:["use-cases"]}},c={},l=[];function u(e){return(0,o.jsx)(o.Fragment,{})}function d(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(u,{...e})}):u()}},28453:(e,t,s)=>{s.d(t,{R:()=>r,x:()=>i});var o=s(96540);const n={},a=o.createContext(n);function r(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:r(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3100],{46147:(e,t,s)=>{s.r(t),s.d(t,{assets:()=>c,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>l});var o=s(74848),n=s(28453);const a={title:"AI Employees",tags:["use-cases"]},r=void 0,i={id:"solutions/ai-employees",title:"AI Employees",description:"",source:"@site/docs/solutions/ai-employees.md",sourceDirName:"solutions",slug:"/solutions/ai-employees",permalink:"/solutions/ai-employees",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/ai-employees.md",tags:[{label:"use-cases",permalink:"/tags/use-cases"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"AI Employees",tags:["use-cases"]}},c={},l=[];function u(e){return(0,o.jsx)(o.Fragment,{})}function d(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(u,{...e})}):u()}},28453:(e,t,s)=>{s.d(t,{R:()=>r,x:()=>i});var o=s(96540);const n={},a=o.createContext(n);function r(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:r(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c1ad6153.6b119518.js b/assets/js/c1ad6153.6b119518.js new file mode 100644 index 00000000..04f62da2 --- /dev/null +++ b/assets/js/c1ad6153.6b119518.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6123],{29879:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>o,default:()=>h,frontMatter:()=>l,metadata:()=>r,toc:()=>t});var a=i(74848),s=i(28453);const l={sidebar_position:11,slug:"/changelog/changelog-v0.3.3"},o="v0.3.3",r={id:"releases/changelog/changelog-v0.3.3",title:"v0.3.3",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.3.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.3",permalink:"/changelog/changelog-v0.3.3",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.3.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:11,frontMatter:{sidebar_position:11,slug:"/changelog/changelog-v0.3.3"},sidebar:"releasesSidebar",previous:{title:"v0.4.0",permalink:"/changelog/changelog-v0.4.0"},next:{title:"v0.3.2",permalink:"/changelog/changelog-v0.3.2"}},d={},t=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"\ud83d\udcd6 Documentaion",id:"-documentaion",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v033",children:"v0.3.3"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.3",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/719",children:"Issue #719: docs: cleanup"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"docs: cleanup @0xSage (#719)"}),"\n",(0,a.jsx)(n.li,{children:"docs: threads and messages @0xSage (#681)"}),"\n",(0,a.jsx)(n.li,{children:"Updating Onboarding Kit @Diane0111 (#675)"}),"\n",(0,a.jsx)(n.li,{children:"Update issue templates @0xSage (#685)"}),"\n",(0,a.jsx)(n.li,{children:"docs: polish models spec @0xSage (#680)"}),"\n",(0,a.jsx)(n.li,{children:"Feature: Preview URL for each PR and add pre-release.jan.ai as staging of Jan Docs @hiento09 (#669)"}),"\n",(0,a.jsx)(n.li,{children:"Migrate Model definitions to Swagger/OpenAPI @dan-jan (#659)"}),"\n",(0,a.jsx)(n.li,{children:"[docs] Add Introduction and refactor Models Spec @dan-jan (#657)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Add model methods to swagger @0xSage (#660)"}),"\n",(0,a.jsx)(n.li,{children:"Models Spec: Delete broken Markdown links @dan-jan (#648)"}),"\n",(0,a.jsx)(n.li,{children:"docs: assistants and threads specs @0xSage (#646)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"improvement: styling message action toolbar @urmauur (#737)"}),"\n",(0,a.jsx)(n.li,{children:"experimental: allow user to give instruction for the conversation @louis-jan (#714)"}),"\n",(0,a.jsx)(n.li,{children:"docs/enable-seo-docusaurus @hieu-jan (#725)"}),"\n",(0,a.jsx)(n.li,{children:"Add windows code sign to CI @hiento09 (#712)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update installation guide @hieu-jan (#664)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Update based on team discussion on Nov 20 @vuonghoainam (#673)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add OpenAI swagger file @hieu-jan (#623)"}),"\n",(0,a.jsx)(n.li,{children:"Update landing page Jan @urmauur (#638)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: open app data should lead user to jan root @louis-jan (#749)"}),"\n",(0,a.jsx)(n.li,{children:"fix: cancel download does not work @louis-jan (#746)"}),"\n",(0,a.jsx)(n.li,{children:"fix: error when switching between threads @louis-jan (#736)"}),"\n",(0,a.jsx)(n.li,{children:"chore: app raises error when attempting to start a model that is already starting @louis-jan (#721)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix filter list menu from command base on search type and make a symbol base on OS @urmauur (#723)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix clickable small download button on chat screen @urmauur (#722)"}),"\n",(0,a.jsx)(n.li,{children:"fix: incorrect update progress bar visibility check @louis-jan (#713)"}),"\n",(0,a.jsx)(n.li,{children:"fix: app shows wrong performance tag, all say not enough ram on windows @louis-jan (#699)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix padding quotations and numbering list @urmauur (#695)"}),"\n",(0,a.jsx)(n.li,{children:"fix: local npm module update does not reflect web app @louis-jan (#677)"}),"\n",(0,a.jsx)(n.li,{children:"[bug] fix markdown todo items shifted to the left and remove the dots @urmauur (#694)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix footer and section spacing landing page @urmauur (#683)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix anchor link sidebar openapi @urmauur (#668)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: remove unused hooks and resolve no-explicit-any @louis-jan (#647)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix titles should have spaces in between @urmauur (#652)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix compatibility content not fully display @urmauur (#653)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: fix app grammar @0xSage (#750)"}),"\n",(0,a.jsx)(n.li,{children:"chore: bumb nitro version @louis-jan (#740)"}),"\n",(0,a.jsx)(n.li,{children:"chore: fs module should not cover app logic @louis-jan (#720)"}),"\n",(0,a.jsx)(n.li,{children:"API Reference for Models, Messages, Threads @hahuyhoang411 (#679)"}),"\n",(0,a.jsx)(n.li,{children:"docs: upgrade mdx-js package @hieu-jan (#705)"}),"\n",(0,a.jsx)(n.li,{children:"[docs] Update Docusaurus to 3.0 and fix closing tag issue in Handbook @dan-jan (#704)"}),"\n",(0,a.jsx)(n.li,{children:"Fix error docs pipeline run failed @hiento09 (#702)"}),"\n",(0,a.jsx)(n.li,{children:"Revert docs CICD trigger on push to main instead of tag-based @hiento09 (#698)"}),"\n",(0,a.jsx)(n.li,{children:"fix: local npm module update does not reflect web app @louis-jan (#677)"}),"\n",(0,a.jsx)(n.li,{children:"Chore: refactor to makefile @hiento09 (#691)"}),"\n",(0,a.jsx)(n.li,{children:"Add Instruction to publish docs @hiento09 (#687)"}),"\n",(0,a.jsx)(n.li,{children:"chore/add-mermaid @hieu-jan (#672)"}),"\n",(0,a.jsx)(n.li,{children:"chore/update package docs @hieu-jan (#670)"}),"\n",(0,a.jsx)(n.li,{children:"Enhance Cross-Platform Argument Handling for Nitro Startup Scripts @hiento09 (#674)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: remove unused hooks and resolve no-explicit-any @louis-jan (#647)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add OpenAI swagger file @hieu-jan (#623)"}),"\n",(0,a.jsx)(n.li,{children:"Preliminary Restructure of Docs @dan-jan (#655)"}),"\n",(0,a.jsx)(n.li,{children:"Model specs @vuonghoainam (#641)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: refactor app entities @louis-jan (#626)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: move file to jan root @namchuai (#598)"}),"\n",(0,a.jsx)(n.li,{children:"Add run-script-os @linhtran174 (#620)"}),"\n",(0,a.jsx)(n.li,{children:"Refactor Jan Documentation @dan-jan (#625)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-documentaion",children:"\ud83d\udcd6 Documentaion"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"docs: update specs/product @0xSage (#744)"}),"\n",(0,a.jsx)(n.li,{children:"docs/enable-seo-docusaurus @hieu-jan (#725)"}),"\n",(0,a.jsx)(n.li,{children:"docs: assistant spec @vuonghoainam (#707)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Refactor Jan Site Structure @dan-jan (#706)"}),"\n",(0,a.jsx)(n.li,{children:"docs/improve install docs @hieu-jan (#708)"}),"\n",(0,a.jsx)(n.li,{children:"API Reference for Models, Messages, Threads @hahuyhoang411 (#679)"}),"\n",(0,a.jsx)(n.li,{children:"[docs] Update Docusaurus to 3.0 and fix closing tag issue in Handbook @dan-jan (#704)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update installation guide @hieu-jan (#664)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Update based on team discussion on Nov 20 @vuonghoainam (#673)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add OpenAI swagger file @hieu-jan (#623)"}),"\n",(0,a.jsx)(n.li,{children:"Preliminary Restructure of Docs @dan-jan (#655)"}),"\n",(0,a.jsx)(n.li,{children:"Fix: specs revision @vuonghoainam (#649)"}),"\n",(0,a.jsx)(n.li,{children:"Model specs @vuonghoainam (#641)"}),"\n",(0,a.jsx)(n.li,{children:"Update README.md @imtuyethan (#629)"}),"\n",(0,a.jsx)(n.li,{children:"Refactor Jan Documentation @dan-jan (#625)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @Diane0111, @dan-jan, @hahuyhoang411, @hiento09, @hieu-jan, @imtuyethan, @linhtran174, @louis-jan, @namchuai, @urmauur, @vuonghoainam and Le Tra Mi"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>r});var a=i(96540);const s={},l=a.createContext(s);function o(e){const n=a.useContext(l);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),a.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c1ad6153.ac9356a1.js b/assets/js/c1ad6153.ac9356a1.js deleted file mode 100644 index 861c251c..00000000 --- a/assets/js/c1ad6153.ac9356a1.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6123],{29879:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>d,contentTitle:()=>o,default:()=>h,frontMatter:()=>l,metadata:()=>r,toc:()=>t});var a=i(74848),s=i(28453);const l={sidebar_position:11,slug:"/changelog/changelog-v0.3.3"},o="v0.3.3",r={id:"releases/changelog/changelog-v0.3.3",title:"v0.3.3",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.3.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.3",permalink:"/changelog/changelog-v0.3.3",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.3.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:11,frontMatter:{sidebar_position:11,slug:"/changelog/changelog-v0.3.3"},sidebar:"releasesSidebar",previous:{title:"v0.4.0",permalink:"/changelog/changelog-v0.4.0"},next:{title:"v0.3.2",permalink:"/changelog/changelog-v0.3.2"}},d={},t=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"\ud83d\udcd6 Documentaion",id:"-documentaion",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v033",children:"v0.3.3"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.3",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/719",children:"Issue #719: docs: cleanup"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"docs: cleanup @0xSage (#719)"}),"\n",(0,a.jsx)(n.li,{children:"docs: threads and messages @0xSage (#681)"}),"\n",(0,a.jsx)(n.li,{children:"Updating Onboarding Kit @Diane0111 (#675)"}),"\n",(0,a.jsx)(n.li,{children:"Update issue templates @0xSage (#685)"}),"\n",(0,a.jsx)(n.li,{children:"docs: polish models spec @0xSage (#680)"}),"\n",(0,a.jsx)(n.li,{children:"Feature: Preview URL for each PR and add pre-release.jan.ai as staging of Jan Docs @hiento09 (#669)"}),"\n",(0,a.jsx)(n.li,{children:"Migrate Model definitions to Swagger/OpenAPI @dan-jan (#659)"}),"\n",(0,a.jsx)(n.li,{children:"[docs] Add Introduction and refactor Models Spec @dan-jan (#657)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Add model methods to swagger @0xSage (#660)"}),"\n",(0,a.jsx)(n.li,{children:"Models Spec: Delete broken Markdown links @dan-jan (#648)"}),"\n",(0,a.jsx)(n.li,{children:"docs: assistants and threads specs @0xSage (#646)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"improvement: styling message action toolbar @urmauur (#737)"}),"\n",(0,a.jsx)(n.li,{children:"experimental: allow user to give instruction for the conversation @louis-jan (#714)"}),"\n",(0,a.jsx)(n.li,{children:"docs/enable-seo-docusaurus @hieu-jan (#725)"}),"\n",(0,a.jsx)(n.li,{children:"Add windows code sign to CI @hiento09 (#712)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update installation guide @hieu-jan (#664)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Update based on team discussion on Nov 20 @vuonghoainam (#673)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add OpenAI swagger file @hieu-jan (#623)"}),"\n",(0,a.jsx)(n.li,{children:"Update landing page Jan @urmauur (#638)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: open app data should lead user to jan root @louis-jan (#749)"}),"\n",(0,a.jsx)(n.li,{children:"fix: cancel download does not work @louis-jan (#746)"}),"\n",(0,a.jsx)(n.li,{children:"fix: error when switching between threads @louis-jan (#736)"}),"\n",(0,a.jsx)(n.li,{children:"chore: app raises error when attempting to start a model that is already starting @louis-jan (#721)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix filter list menu from command base on search type and make a symbol base on OS @urmauur (#723)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix clickable small download button on chat screen @urmauur (#722)"}),"\n",(0,a.jsx)(n.li,{children:"fix: incorrect update progress bar visibility check @louis-jan (#713)"}),"\n",(0,a.jsx)(n.li,{children:"fix: app shows wrong performance tag, all say not enough ram on windows @louis-jan (#699)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix padding quotations and numbering list @urmauur (#695)"}),"\n",(0,a.jsx)(n.li,{children:"fix: local npm module update does not reflect web app @louis-jan (#677)"}),"\n",(0,a.jsx)(n.li,{children:"[bug] fix markdown todo items shifted to the left and remove the dots @urmauur (#694)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix footer and section spacing landing page @urmauur (#683)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix anchor link sidebar openapi @urmauur (#668)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: remove unused hooks and resolve no-explicit-any @louis-jan (#647)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix titles should have spaces in between @urmauur (#652)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix compatibility content not fully display @urmauur (#653)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: fix app grammar @0xSage (#750)"}),"\n",(0,a.jsx)(n.li,{children:"chore: bumb nitro version @louis-jan (#740)"}),"\n",(0,a.jsx)(n.li,{children:"chore: fs module should not cover app logic @louis-jan (#720)"}),"\n",(0,a.jsx)(n.li,{children:"API Reference for Models, Messages, Threads @hahuyhoang411 (#679)"}),"\n",(0,a.jsx)(n.li,{children:"docs: upgrade mdx-js package @hieu-jan (#705)"}),"\n",(0,a.jsx)(n.li,{children:"[docs] Update Docusaurus to 3.0 and fix closing tag issue in Handbook @dan-jan (#704)"}),"\n",(0,a.jsx)(n.li,{children:"Fix error docs pipeline run failed @hiento09 (#702)"}),"\n",(0,a.jsx)(n.li,{children:"Revert docs CICD trigger on push to main instead of tag-based @hiento09 (#698)"}),"\n",(0,a.jsx)(n.li,{children:"fix: local npm module update does not reflect web app @louis-jan (#677)"}),"\n",(0,a.jsx)(n.li,{children:"Chore: refactor to makefile @hiento09 (#691)"}),"\n",(0,a.jsx)(n.li,{children:"Add Instruction to publish docs @hiento09 (#687)"}),"\n",(0,a.jsx)(n.li,{children:"chore/add-mermaid @hieu-jan (#672)"}),"\n",(0,a.jsx)(n.li,{children:"chore/update package docs @hieu-jan (#670)"}),"\n",(0,a.jsx)(n.li,{children:"Enhance Cross-Platform Argument Handling for Nitro Startup Scripts @hiento09 (#674)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: remove unused hooks and resolve no-explicit-any @louis-jan (#647)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add OpenAI swagger file @hieu-jan (#623)"}),"\n",(0,a.jsx)(n.li,{children:"Preliminary Restructure of Docs @dan-jan (#655)"}),"\n",(0,a.jsx)(n.li,{children:"Model specs @vuonghoainam (#641)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: refactor app entities @louis-jan (#626)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: move file to jan root @namchuai (#598)"}),"\n",(0,a.jsx)(n.li,{children:"Add run-script-os @linhtran174 (#620)"}),"\n",(0,a.jsx)(n.li,{children:"Refactor Jan Documentation @dan-jan (#625)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-documentaion",children:"\ud83d\udcd6 Documentaion"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"docs: update specs/product @0xSage (#744)"}),"\n",(0,a.jsx)(n.li,{children:"docs/enable-seo-docusaurus @hieu-jan (#725)"}),"\n",(0,a.jsx)(n.li,{children:"docs: assistant spec @vuonghoainam (#707)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Refactor Jan Site Structure @dan-jan (#706)"}),"\n",(0,a.jsx)(n.li,{children:"docs/improve install docs @hieu-jan (#708)"}),"\n",(0,a.jsx)(n.li,{children:"API Reference for Models, Messages, Threads @hahuyhoang411 (#679)"}),"\n",(0,a.jsx)(n.li,{children:"[docs] Update Docusaurus to 3.0 and fix closing tag issue in Handbook @dan-jan (#704)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update installation guide @hieu-jan (#664)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Update based on team discussion on Nov 20 @vuonghoainam (#673)"}),"\n",(0,a.jsx)(n.li,{children:"docs: add OpenAI swagger file @hieu-jan (#623)"}),"\n",(0,a.jsx)(n.li,{children:"Preliminary Restructure of Docs @dan-jan (#655)"}),"\n",(0,a.jsx)(n.li,{children:"Fix: specs revision @vuonghoainam (#649)"}),"\n",(0,a.jsx)(n.li,{children:"Model specs @vuonghoainam (#641)"}),"\n",(0,a.jsx)(n.li,{children:"Update README.md @imtuyethan (#629)"}),"\n",(0,a.jsx)(n.li,{children:"Refactor Jan Documentation @dan-jan (#625)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @Diane0111, @dan-jan, @hahuyhoang411, @hiento09, @hieu-jan, @imtuyethan, @linhtran174, @louis-jan, @namchuai, @urmauur, @vuonghoainam and Le Tra Mi"})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>r});var a=i(96540);const s={},l=a.createContext(s);function o(e){const n=a.useContext(l);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),a.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c236f8c9.30aee786.js b/assets/js/c236f8c9.30aee786.js new file mode 100644 index 00000000..fed599cd --- /dev/null +++ b/assets/js/c236f8c9.30aee786.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4057],{34059:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=t(74848),o=t(28453);const r={title:"Groq API",sidebar_position:5,slug:"/guides/engines/groq",description:"Learn how to integrate Groq API with Jan for enhanced functionality.",keywords:["Groq API","Jan","Jan AI","ChatGPT alternative","conversational AI","large language model","integration","Groq integration","API integration"]},s=void 0,a={id:"guides/remote-providers/groq",title:"Groq API",description:"Learn how to integrate Groq API with Jan for enhanced functionality.",source:"@site/docs/guides/remote-providers/groq.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/groq",permalink:"/guides/engines/groq",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/groq.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:5,frontMatter:{title:"Groq API",sidebar_position:5,slug:"/guides/engines/groq",description:"Learn how to integrate Groq API with Jan for enhanced functionality.",keywords:["Groq API","Jan","Jan AI","ChatGPT alternative","conversational AI","large language model","integration","Groq integration","API integration"]},sidebar:"guidesSidebar",previous:{title:"Remote Engines",permalink:"/guides/engines/remote"},next:{title:"Mistral API",permalink:"/guides/engines/mistral"}},l={},d=[{value:"How to Integrate Mistral AI with Jan",id:"how-to-integrate-mistral-ai-with-jan",level:2},{value:"Integration Steps",id:"integration-steps",level:2},{value:"Step 1: Obtain Groq API Credentials",id:"step-1-obtain-groq-api-credentials",level:3},{value:"Step 2: Configure Jan Settings",id:"step-2-configure-jan-settings",level:3},{value:"Step 3: Enable Groq Integration",id:"step-3-enable-groq-integration",level:3},{value:"Step 4: Start the Model",id:"step-4-start-the-model",level:3},{value:"Troubleshooting",id:"troubleshooting",level:2}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"how-to-integrate-mistral-ai-with-jan",children:"How to Integrate Mistral AI with Jan"}),"\n",(0,i.jsx)(n.p,{children:"This guide provides step-by-step instructions on integrating the Groq API with Jan, enabling users to leverage Groq's capabilities within Jan's conversational interface."}),"\n",(0,i.jsx)(n.p,{children:"Before proceeding, ensure you have the following:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Access to the Jan Application"}),"\n",(0,i.jsx)(n.li,{children:"Groq API credentials"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"integration-steps",children:"Integration Steps"}),"\n",(0,i.jsx)(n.h3,{id:"step-1-obtain-groq-api-credentials",children:"Step 1: Obtain Groq API Credentials"}),"\n",(0,i.jsxs)(n.p,{children:["If you haven't already, sign up for the Groq API and obtain your API credentials.\nObtain Groq API keys from your ",(0,i.jsx)(n.a,{href:"https://console.groq.com/keys",children:"Groq Console"}),"."]}),"\n",(0,i.jsx)(n.h3,{id:"step-2-configure-jan-settings",children:"Step 2: Configure Jan Settings"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Insert the Groq AI API key into ",(0,i.jsx)(n.code,{children:"~/jan/engines/openai.json"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "https://api.groq.com/openai/v1/chat/completions",\n "api_key": ""\n}\n'})}),"\n",(0,i.jsx)(n.h3,{id:"step-3-enable-groq-integration",children:"Step 3: Enable Groq Integration"}),"\n",(0,i.jsx)(n.p,{children:"To set up the configuration for Groq in Jan, follow these steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Create a folder named ",(0,i.jsx)(n.code,{children:"groq"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Inside the groq folder, create a model.json file with the specified settings:"}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/groq/model.json',children:'{\n "id": "mixtral-8x7b-32768",\n "object": "model",\n "name": "Groq Integration",\n "version": "1.0",\n "description": "Integration with Groq API for enhanced functionality.",\n "format": "api",\n "sources": [],\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Mistral",\n "tags": ["Groq Integration"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,i.jsx)(n.h3,{id:"step-4-start-the-model",children:"Step 4: Start the Model"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,i.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Locate your model and click the ",(0,i.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,i.jsx)(n.p,{children:"If you encounter any issues during the integration process or while using Groq with Jan, consider the following troubleshooting steps:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Double-check your API credentials and ensure they are correctly entered."}),"\n",(0,i.jsx)(n.li,{children:"Verify that the Groq integration is enabled within Jan's settings."}),"\n",(0,i.jsx)(n.li,{children:"Check for any error messages or logs that may provide insight into the issue."}),"\n",(0,i.jsx)(n.li,{children:"Reach out to Groq API support for assistance if needed."}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var i=t(96540);const o={},r=i.createContext(o);function s(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c236f8c9.64ff8fdb.js b/assets/js/c236f8c9.64ff8fdb.js deleted file mode 100644 index b42f7806..00000000 --- a/assets/js/c236f8c9.64ff8fdb.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4057],{34059:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var i=t(74848),o=t(28453);const r={title:"Groq API",sidebar_position:5,slug:"/guides/engines/groq",description:"Learn how to integrate Groq API with Jan for enhanced functionality.",keywords:["Groq API","Jan","Jan AI","ChatGPT alternative","conversational AI","large language model","integration","Groq integration","API integration"]},s=void 0,a={id:"guides/remote-providers/groq",title:"Groq API",description:"Learn how to integrate Groq API with Jan for enhanced functionality.",source:"@site/docs/guides/remote-providers/groq.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/groq",permalink:"/guides/engines/groq",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/groq.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:5,frontMatter:{title:"Groq API",sidebar_position:5,slug:"/guides/engines/groq",description:"Learn how to integrate Groq API with Jan for enhanced functionality.",keywords:["Groq API","Jan","Jan AI","ChatGPT alternative","conversational AI","large language model","integration","Groq integration","API integration"]},sidebar:"guidesSidebar",previous:{title:"Remote Engines",permalink:"/guides/engines/remote"},next:{title:"Mistral API",permalink:"/guides/engines/mistral"}},l={},d=[{value:"How to Integrate Mistral AI with Jan",id:"how-to-integrate-mistral-ai-with-jan",level:2},{value:"Integration Steps",id:"integration-steps",level:2},{value:"Step 1: Obtain Groq API Credentials",id:"step-1-obtain-groq-api-credentials",level:3},{value:"Step 2: Configure Jan Settings",id:"step-2-configure-jan-settings",level:3},{value:"Step 3: Enable Groq Integration",id:"step-3-enable-groq-integration",level:3},{value:"Step 4: Start the Model",id:"step-4-start-the-model",level:3},{value:"Troubleshooting",id:"troubleshooting",level:2}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,o.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"how-to-integrate-mistral-ai-with-jan",children:"How to Integrate Mistral AI with Jan"}),"\n",(0,i.jsx)(n.p,{children:"This guide provides step-by-step instructions on integrating the Groq API with Jan, enabling users to leverage Groq's capabilities within Jan's conversational interface."}),"\n",(0,i.jsx)(n.p,{children:"Before proceeding, ensure you have the following:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Access to the Jan Application"}),"\n",(0,i.jsx)(n.li,{children:"Groq API credentials"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"integration-steps",children:"Integration Steps"}),"\n",(0,i.jsx)(n.h3,{id:"step-1-obtain-groq-api-credentials",children:"Step 1: Obtain Groq API Credentials"}),"\n",(0,i.jsxs)(n.p,{children:["If you haven't already, sign up for the Groq API and obtain your API credentials.\nObtain Groq API keys from your ",(0,i.jsx)(n.a,{href:"https://console.groq.com/keys",children:"Groq Console"}),"."]}),"\n",(0,i.jsx)(n.h3,{id:"step-2-configure-jan-settings",children:"Step 2: Configure Jan Settings"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Insert the Groq AI API key into ",(0,i.jsx)(n.code,{children:"~/jan/engines/openai.json"}),"."]}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "https://api.groq.com/openai/v1/chat/completions",\n "api_key": ""\n}\n'})}),"\n",(0,i.jsx)(n.h3,{id:"step-3-enable-groq-integration",children:"Step 3: Enable Groq Integration"}),"\n",(0,i.jsx)(n.p,{children:"To set up the configuration for Groq in Jan, follow these steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Navigate to ",(0,i.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Create a folder named ",(0,i.jsx)(n.code,{children:"groq"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Inside the groq folder, create a model.json file with the specified settings:"}),"\n"]}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/groq/model.json',children:'{\n "id": "mixtral-8x7b-32768",\n "object": "model",\n "name": "Groq Integration",\n "version": "1.0",\n "description": "Integration with Groq API for enhanced functionality.",\n "format": "api",\n "sources": [],\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "Mistral",\n "tags": ["Groq Integration"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,i.jsx)(n.h3,{id:"step-4-start-the-model",children:"Step 4: Start the Model"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Restart Jan and navigate to the ",(0,i.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,i.jsxs)(n.li,{children:["Locate your model and click the ",(0,i.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"troubleshooting",children:"Troubleshooting"}),"\n",(0,i.jsx)(n.p,{children:"If you encounter any issues during the integration process or while using Groq with Jan, consider the following troubleshooting steps:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Double-check your API credentials and ensure they are correctly entered."}),"\n",(0,i.jsx)(n.li,{children:"Verify that the Groq integration is enabled within Jan's settings."}),"\n",(0,i.jsx)(n.li,{children:"Check for any error messages or logs that may provide insight into the issue."}),"\n",(0,i.jsx)(n.li,{children:"Reach out to Groq API support for assistance if needed."}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var i=t(96540);const o={},r=i.createContext(o);function s(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:s(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c469c680.362e900c.js b/assets/js/c469c680.362e900c.js deleted file mode 100644 index 51c75e9f..00000000 --- a/assets/js/c469c680.362e900c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2170],{82274:(n,e,i)=>{i.r(e),i.d(e,{assets:()=>r,contentTitle:()=>s,default:()=>v,frontMatter:()=>o,metadata:()=>d,toc:()=>c});var t=i(74848),a=i(28453);const o={title:"Nov 23: Nvidia GenAI Day",description:"Nvidia's LLM Day"},s=void 0,d={id:"events/nvidia-llm-day-nov-23",title:"Nov 23: Nvidia GenAI Day",description:"Nvidia's LLM Day",source:"@site/docs/events/nvidia-llm-day-nov-23.md",sourceDirName:"events",slug:"/events/nvidia-llm-day-nov-23",permalink:"/events/nvidia-llm-day-nov-23",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/events/nvidia-llm-day-nov-23.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Nov 23: Nvidia GenAI Day",description:"Nvidia's LLM Day"}},r={},c=[{value:"Nvidia GenAI Innovation Day",id:"nvidia-genai-innovation-day",level:2},{value:"Location",id:"location",level:3},{value:"Programme",id:"programme",level:3}];function l(n){const e={a:"a",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",ul:"ul",...(0,a.R)(),...n.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(e.p,{children:(0,t.jsx)(e.img,{src:i(57077).A+"",width:"1920",height:"480"})}),"\n",(0,t.jsx)(e.h2,{id:"nvidia-genai-innovation-day",children:"Nvidia GenAI Innovation Day"}),"\n",(0,t.jsx)(e.p,{children:"Jan will be at Nvidia's GenAI Innovation Day in Nov '23, focusing on Enterprise use-cases of LLMs."}),"\n",(0,t.jsx)(e.h3,{id:"location",children:"Location"}),"\n",(0,t.jsxs)(e.ul,{children:["\n",(0,t.jsx)(e.li,{children:"JW Marriott Hanoi Hotel"}),"\n",(0,t.jsx)(e.li,{children:"8:30am November 8th 2023"}),"\n",(0,t.jsxs)(e.li,{children:["Registration: ",(0,t.jsx)(e.a,{href:"https://gmcgroup.com.vn/nvidia-genai-event/",children:"https://gmcgroup.com.vn/nvidia-genai-event/"})]}),"\n"]}),"\n",(0,t.jsx)(e.h3,{id:"programme",children:"Programme"}),"\n",(0,t.jsx)(e.p,{children:(0,t.jsx)(e.img,{src:i(45375).A+"",width:"2398",height:"1518"})})]})}function v(n={}){const{wrapper:e}={...(0,a.R)(),...n.components};return e?(0,t.jsx)(e,{...n,children:(0,t.jsx)(l,{...n})}):l(n)}},57077:(n,e,i)=>{i.d(e,{A:()=>t});const t=i.p+"assets/images/nvidia-llm-day-header-8de73af2ce6d0ba1965c74b43136c87d.png"},45375:(n,e,i)=>{i.d(e,{A:()=>t});const t=i.p+"assets/images/nvidia-llm-day-d178ba92484312398ed2f8e59734d829.png"},28453:(n,e,i)=>{i.d(e,{R:()=>s,x:()=>d});var t=i(96540);const a={},o=t.createContext(a);function s(n){const e=t.useContext(o);return t.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function d(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(a):n.components||a:s(n.components),t.createElement(o.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/c469c680.c40ce254.js b/assets/js/c469c680.c40ce254.js new file mode 100644 index 00000000..7a534c11 --- /dev/null +++ b/assets/js/c469c680.c40ce254.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2170],{82274:(n,e,i)=>{i.r(e),i.d(e,{assets:()=>r,contentTitle:()=>s,default:()=>v,frontMatter:()=>o,metadata:()=>d,toc:()=>c});var t=i(74848),a=i(28453);const o={title:"Nov 23: Nvidia GenAI Day",description:"Nvidia's LLM Day"},s=void 0,d={id:"events/nvidia-llm-day-nov-23",title:"Nov 23: Nvidia GenAI Day",description:"Nvidia's LLM Day",source:"@site/docs/events/nvidia-llm-day-nov-23.md",sourceDirName:"events",slug:"/events/nvidia-llm-day-nov-23",permalink:"/events/nvidia-llm-day-nov-23",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/events/nvidia-llm-day-nov-23.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Nov 23: Nvidia GenAI Day",description:"Nvidia's LLM Day"}},r={},c=[{value:"Nvidia GenAI Innovation Day",id:"nvidia-genai-innovation-day",level:2},{value:"Location",id:"location",level:3},{value:"Programme",id:"programme",level:3}];function l(n){const e={a:"a",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",ul:"ul",...(0,a.R)(),...n.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(e.p,{children:(0,t.jsx)(e.img,{src:i(57077).A+"",width:"1920",height:"480"})}),"\n",(0,t.jsx)(e.h2,{id:"nvidia-genai-innovation-day",children:"Nvidia GenAI Innovation Day"}),"\n",(0,t.jsx)(e.p,{children:"Jan will be at Nvidia's GenAI Innovation Day in Nov '23, focusing on Enterprise use-cases of LLMs."}),"\n",(0,t.jsx)(e.h3,{id:"location",children:"Location"}),"\n",(0,t.jsxs)(e.ul,{children:["\n",(0,t.jsx)(e.li,{children:"JW Marriott Hanoi Hotel"}),"\n",(0,t.jsx)(e.li,{children:"8:30am November 8th 2023"}),"\n",(0,t.jsxs)(e.li,{children:["Registration: ",(0,t.jsx)(e.a,{href:"https://gmcgroup.com.vn/nvidia-genai-event/",children:"https://gmcgroup.com.vn/nvidia-genai-event/"})]}),"\n"]}),"\n",(0,t.jsx)(e.h3,{id:"programme",children:"Programme"}),"\n",(0,t.jsx)(e.p,{children:(0,t.jsx)(e.img,{src:i(45375).A+"",width:"2398",height:"1518"})})]})}function v(n={}){const{wrapper:e}={...(0,a.R)(),...n.components};return e?(0,t.jsx)(e,{...n,children:(0,t.jsx)(l,{...n})}):l(n)}},57077:(n,e,i)=>{i.d(e,{A:()=>t});const t=i.p+"assets/images/nvidia-llm-day-header-8de73af2ce6d0ba1965c74b43136c87d.png"},45375:(n,e,i)=>{i.d(e,{A:()=>t});const t=i.p+"assets/images/nvidia-llm-day-d178ba92484312398ed2f8e59734d829.png"},28453:(n,e,i)=>{i.d(e,{R:()=>s,x:()=>d});var t=i(96540);const a={},o=t.createContext(a);function s(n){const e=t.useContext(o);return t.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function d(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(a):n.components||a:s(n.components),t.createElement(o.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/c494d087.7cb3e36b.js b/assets/js/c494d087.7cb3e36b.js deleted file mode 100644 index 8cb14fdf..00000000 --- a/assets/js/c494d087.7cb3e36b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1014],{1959:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>o,default:()=>c,frontMatter:()=>s,metadata:()=>t,toc:()=>h});var a=i(74848),l=i(28453);const s={sidebar_position:10,slug:"/changelog/changelog-v0.4.0"},o="v0.4.0",t={id:"releases/changelog/changelog-v0.4.0",title:"v0.4.0",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.0.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.0",permalink:"/changelog/changelog-v0.4.0",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.0.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:10,frontMatter:{sidebar_position:10,slug:"/changelog/changelog-v0.4.0"},sidebar:"releasesSidebar",previous:{title:"v0.4.1",permalink:"/changelog/changelog-v0.4.1"},next:{title:"v0.3.3",permalink:"/changelog/changelog-v0.3.3"}},r={},h=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,l.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v040",children:"v0.4.0"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.0",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/878",children:"Issue #878: bug: fix tag description showing a title and fix card right panel"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"bug: fix tag description showing a title and fix card right panel @urmauur (#878)"}),"\n",(0,a.jsx)(n.li,{children:"fix/no-assistant-available-fresh-install @louis-jan (#876)"}),"\n",(0,a.jsx)(n.li,{children:"Model.json update @hahuyhoang411 (#870)"}),"\n",(0,a.jsx)(n.li,{children:"Hotfix desc for openhermes @hahuyhoang411 (#864)"}),"\n",(0,a.jsx)(n.li,{children:"Openhermes update v1 @hahuyhoang411 (#863)"}),"\n",(0,a.jsx)(n.li,{children:"update deepseek 1.3b @hahuyhoang411 (#858)"}),"\n",(0,a.jsx)(n.li,{children:"Update tags @hahuyhoang411 (#857)"}),"\n",(0,a.jsx)(n.li,{children:"Update model hub @hahuyhoang411 (#829)"}),"\n",(0,a.jsx)(n.li,{children:"hotfix: fix typo @tikikun (#836)"}),"\n",(0,a.jsx)(n.li,{children:"chore: pre-populate Jan's /models folder with model.jsons @hahuyhoang411 (#775)"}),"\n",(0,a.jsx)(n.li,{children:"chore: clarification changes to the model settings and model parameters @tikikun (#742)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: revamp landing page @urmauur (#745)"}),"\n",(0,a.jsx)(n.li,{children:"feat : add cover image model hub screen @urmauur (#872)"}),"\n",(0,a.jsx)(n.li,{children:"feat: boilerplate for express server localhost 1337 @linhtran174 (#803)"}),"\n",(0,a.jsx)(n.li,{children:"enhancement: revamp hub screen @urmauur (#825)"}),"\n",(0,a.jsx)(n.li,{children:"feat: revamp thread screen @urmauur (#802)"}),"\n",(0,a.jsx)(n.li,{children:"docs/update-api-reference @hieu-jan (#739)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: model plugin to follow new specs @namchuai (#682)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: Nitro interface update to prevent warning @vuonghoainam (#877)"}),"\n",(0,a.jsx)(n.li,{children:"fix: delete message break the entire thread @louis-jan (#869)"}),"\n",(0,a.jsx)(n.li,{children:"fix: can not download multiple models at once @louis-jan (#867)"}),"\n",(0,a.jsx)(n.li,{children:"fix: production CI workflow does not populate models @louis-jan (#862)"}),"\n",(0,a.jsx)(n.li,{children:"fix: update wrong main view state when use a model @namchuai (#861)"}),"\n",(0,a.jsx)(n.li,{children:"fix: handle crash issue on hljs highlighting @louis-jan (#859)"}),"\n",(0,a.jsx)(n.li,{children:"fix: empty assistant instruction by default @louis-jan (#855)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix broken banner position hub screen @urmauur (#846)"}),"\n",(0,a.jsx)(n.li,{children:"fix: not update active model when using resend button @namchuai (#834)"}),"\n",(0,a.jsx)(n.li,{children:"Hotfix jan windows download nitro failed @hiento09 (#838)"}),"\n",(0,a.jsx)(n.li,{children:"Switch to download nitro .tar.gz file instead of .zip file on windows @hiento09 (#832)"}),"\n",(0,a.jsx)(n.li,{children:"fix/docusaurus-seo @hieu-jan (#818)"}),"\n",(0,a.jsx)(n.li,{children:"fix: CI script - reorder copy models action @louis-jan (#819)"}),"\n",(0,a.jsx)(n.li,{children:"fix: messages sync is not threadsafe @louis-jan (#784)"}),"\n",(0,a.jsx)(n.li,{children:"Fix Makefile Indentation Issue @hiento09 (#788)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: update model ranking @louis-jan (#874)"}),"\n",(0,a.jsx)(n.li,{children:"Bump nitro version to 0.1.21 - nitro has windows codesign @hiento09 (#843)"}),"\n",(0,a.jsx)(n.li,{children:"Hotfix jan windows download nitro failed @hiento09 (#838)"}),"\n",(0,a.jsx)(n.li,{children:"810 docs add modeljson and revamp models specs page @tikikun (#816)"}),"\n",(0,a.jsx)(n.li,{children:"Add document for nightly build and update message for manual build @hiento09 (#831)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Bump nitro to 0.1.20 @vuonghoainam (#830)"}),"\n",(0,a.jsxs)(n.li,{children:["Refactor build",":extension"," command @hiento09 (#822)"]}),"\n",(0,a.jsx)(n.li,{children:"feat: pre-populate Jan's /models folder @namchuai (#796)"}),"\n",(0,a.jsx)(n.li,{children:"chore: fix pr auto labeling @0xSage (#812)"}),"\n",(0,a.jsx)(n.li,{children:"chore: add gi automations @0xSage (#809)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: jan extensions @louis-jan (#799)"}),"\n",(0,a.jsx)(n.li,{children:"Remove .zip in artifact name @hiento09 (#800)"}),"\n",(0,a.jsx)(n.li,{children:"docs/update-api-reference @hieu-jan (#739)"}),"\n",(0,a.jsx)(n.li,{children:"Add nightly build ci @hiento09 (#794)"}),"\n",(0,a.jsx)(n.li,{children:"Fix Makefile Indentation Issue @hiento09 (#788)"}),"\n",(0,a.jsx)(n.li,{children:"Switch from .zip to .tar.gz for nitro url inference plugin @hiento09 (#781)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @hieu-jan, @linhtran174, @louis-jan, @namchuai, @tikikun, @urmauur and @vuonghoainam"})]})}function c(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>t});var a=i(96540);const l={},s=a.createContext(l);function o(e){const n=a.useContext(s);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:o(e.components),a.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c494d087.b6e48560.js b/assets/js/c494d087.b6e48560.js new file mode 100644 index 00000000..1d4cf178 --- /dev/null +++ b/assets/js/c494d087.b6e48560.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1014],{1959:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>o,default:()=>c,frontMatter:()=>s,metadata:()=>t,toc:()=>h});var a=i(74848),l=i(28453);const s={sidebar_position:10,slug:"/changelog/changelog-v0.4.0"},o="v0.4.0",t={id:"releases/changelog/changelog-v0.4.0",title:"v0.4.0",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.0.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.0",permalink:"/changelog/changelog-v0.4.0",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.0.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:10,frontMatter:{sidebar_position:10,slug:"/changelog/changelog-v0.4.0"},sidebar:"releasesSidebar",previous:{title:"v0.4.1",permalink:"/changelog/changelog-v0.4.1"},next:{title:"v0.3.3",permalink:"/changelog/changelog-v0.3.3"}},r={},h=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,l.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v040",children:"v0.4.0"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.0",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/878",children:"Issue #878: bug: fix tag description showing a title and fix card right panel"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"bug: fix tag description showing a title and fix card right panel @urmauur (#878)"}),"\n",(0,a.jsx)(n.li,{children:"fix/no-assistant-available-fresh-install @louis-jan (#876)"}),"\n",(0,a.jsx)(n.li,{children:"Model.json update @hahuyhoang411 (#870)"}),"\n",(0,a.jsx)(n.li,{children:"Hotfix desc for openhermes @hahuyhoang411 (#864)"}),"\n",(0,a.jsx)(n.li,{children:"Openhermes update v1 @hahuyhoang411 (#863)"}),"\n",(0,a.jsx)(n.li,{children:"update deepseek 1.3b @hahuyhoang411 (#858)"}),"\n",(0,a.jsx)(n.li,{children:"Update tags @hahuyhoang411 (#857)"}),"\n",(0,a.jsx)(n.li,{children:"Update model hub @hahuyhoang411 (#829)"}),"\n",(0,a.jsx)(n.li,{children:"hotfix: fix typo @tikikun (#836)"}),"\n",(0,a.jsx)(n.li,{children:"chore: pre-populate Jan's /models folder with model.jsons @hahuyhoang411 (#775)"}),"\n",(0,a.jsx)(n.li,{children:"chore: clarification changes to the model settings and model parameters @tikikun (#742)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: revamp landing page @urmauur (#745)"}),"\n",(0,a.jsx)(n.li,{children:"feat : add cover image model hub screen @urmauur (#872)"}),"\n",(0,a.jsx)(n.li,{children:"feat: boilerplate for express server localhost 1337 @linhtran174 (#803)"}),"\n",(0,a.jsx)(n.li,{children:"enhancement: revamp hub screen @urmauur (#825)"}),"\n",(0,a.jsx)(n.li,{children:"feat: revamp thread screen @urmauur (#802)"}),"\n",(0,a.jsx)(n.li,{children:"docs/update-api-reference @hieu-jan (#739)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: model plugin to follow new specs @namchuai (#682)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: Nitro interface update to prevent warning @vuonghoainam (#877)"}),"\n",(0,a.jsx)(n.li,{children:"fix: delete message break the entire thread @louis-jan (#869)"}),"\n",(0,a.jsx)(n.li,{children:"fix: can not download multiple models at once @louis-jan (#867)"}),"\n",(0,a.jsx)(n.li,{children:"fix: production CI workflow does not populate models @louis-jan (#862)"}),"\n",(0,a.jsx)(n.li,{children:"fix: update wrong main view state when use a model @namchuai (#861)"}),"\n",(0,a.jsx)(n.li,{children:"fix: handle crash issue on hljs highlighting @louis-jan (#859)"}),"\n",(0,a.jsx)(n.li,{children:"fix: empty assistant instruction by default @louis-jan (#855)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix broken banner position hub screen @urmauur (#846)"}),"\n",(0,a.jsx)(n.li,{children:"fix: not update active model when using resend button @namchuai (#834)"}),"\n",(0,a.jsx)(n.li,{children:"Hotfix jan windows download nitro failed @hiento09 (#838)"}),"\n",(0,a.jsx)(n.li,{children:"Switch to download nitro .tar.gz file instead of .zip file on windows @hiento09 (#832)"}),"\n",(0,a.jsx)(n.li,{children:"fix/docusaurus-seo @hieu-jan (#818)"}),"\n",(0,a.jsx)(n.li,{children:"fix: CI script - reorder copy models action @louis-jan (#819)"}),"\n",(0,a.jsx)(n.li,{children:"fix: messages sync is not threadsafe @louis-jan (#784)"}),"\n",(0,a.jsx)(n.li,{children:"Fix Makefile Indentation Issue @hiento09 (#788)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: update model ranking @louis-jan (#874)"}),"\n",(0,a.jsx)(n.li,{children:"Bump nitro version to 0.1.21 - nitro has windows codesign @hiento09 (#843)"}),"\n",(0,a.jsx)(n.li,{children:"Hotfix jan windows download nitro failed @hiento09 (#838)"}),"\n",(0,a.jsx)(n.li,{children:"810 docs add modeljson and revamp models specs page @tikikun (#816)"}),"\n",(0,a.jsx)(n.li,{children:"Add document for nightly build and update message for manual build @hiento09 (#831)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Bump nitro to 0.1.20 @vuonghoainam (#830)"}),"\n",(0,a.jsxs)(n.li,{children:["Refactor build",":extension"," command @hiento09 (#822)"]}),"\n",(0,a.jsx)(n.li,{children:"feat: pre-populate Jan's /models folder @namchuai (#796)"}),"\n",(0,a.jsx)(n.li,{children:"chore: fix pr auto labeling @0xSage (#812)"}),"\n",(0,a.jsx)(n.li,{children:"chore: add gi automations @0xSage (#809)"}),"\n",(0,a.jsx)(n.li,{children:"refactor: jan extensions @louis-jan (#799)"}),"\n",(0,a.jsx)(n.li,{children:"Remove .zip in artifact name @hiento09 (#800)"}),"\n",(0,a.jsx)(n.li,{children:"docs/update-api-reference @hieu-jan (#739)"}),"\n",(0,a.jsx)(n.li,{children:"Add nightly build ci @hiento09 (#794)"}),"\n",(0,a.jsx)(n.li,{children:"Fix Makefile Indentation Issue @hiento09 (#788)"}),"\n",(0,a.jsx)(n.li,{children:"Switch from .zip to .tar.gz for nitro url inference plugin @hiento09 (#781)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @hieu-jan, @linhtran174, @louis-jan, @namchuai, @tikikun, @urmauur and @vuonghoainam"})]})}function c(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>t});var a=i(96540);const l={},s=a.createContext(l);function o(e){const n=a.useContext(s);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:o(e.components),a.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c5483ccc.df3c5b6e.js b/assets/js/c5483ccc.df3c5b6e.js new file mode 100644 index 00000000..a0abc26a --- /dev/null +++ b/assets/js/c5483ccc.df3c5b6e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8911],{46812:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>l,contentTitle:()=>d,default:()=>a,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var t=n(74848),i=n(28453);const r={title:"Cloud vs. Self-hosting Your AI"},d=void 0,o={id:"hardware/overview/cloud-vs-self-hosting",title:"Cloud vs. Self-hosting Your AI",description:"The choice of how to run your AI - on GPU cloud services, on-prem, or just using an API provider - involves various trade-offs. The following is a naive exploration of the pros and cons of renting vs self-hosting.",source:"@site/docs/hardware/overview/cloud-vs-self-hosting.md",sourceDirName:"hardware/overview",slug:"/hardware/overview/cloud-vs-self-hosting",permalink:"/hardware/overview/cloud-vs-self-hosting",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/overview/cloud-vs-self-hosting.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Cloud vs. Self-hosting Your AI"}},l={},c=[{value:"Cost Comparison",id:"cost-comparison",level:2},{value:"Low Usage",id:"low-usage",level:3},{value:"High Usage",id:"high-usage",level:3},{value:"Incremental Costs",id:"incremental-costs",level:3},{value:"Business Considerations",id:"business-considerations",level:2},{value:"Conclusion",id:"conclusion",level:2}];function h(e){const s={blockquote:"blockquote",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(s.p,{children:"The choice of how to run your AI - on GPU cloud services, on-prem, or just using an API provider - involves various trade-offs. The following is a naive exploration of the pros and cons of renting vs self-hosting."}),"\n",(0,t.jsx)(s.h2,{id:"cost-comparison",children:"Cost Comparison"}),"\n",(0,t.jsx)(s.p,{children:"The following estimations use these general assumptions:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Unit Costs"}),(0,t.jsx)(s.td,{children:"$10k upfront for 2x4090s (5 year amort.)"}),(0,t.jsx)(s.td,{children:"$0.00012/token"}),(0,t.jsx)(s.td,{children:"$4.42 for 1xH100/h"})]})})]}),"\n",(0,t.jsxs)(s.ul,{children:["\n",(0,t.jsx)(s.li,{children:"800 average tokens (input & output) in a single request"}),"\n",(0,t.jsx)(s.li,{children:"Inference speed is at 24 tokens per second"}),"\n"]}),"\n",(0,t.jsx)(s.h3,{id:"low-usage",children:"Low Usage"}),"\n",(0,t.jsx)(s.p,{children:"When operating at low capacity:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Cost per Request"}),(0,t.jsx)(s.td,{children:"$2.33"}),(0,t.jsx)(s.td,{children:"$0.10"}),(0,t.jsx)(s.td,{children:"$0.04"})]})})]}),"\n",(0,t.jsx)(s.h3,{id:"high-usage",children:"High Usage"}),"\n",(0,t.jsx)(s.p,{children:"When operating at high capacity, i.e. 24 hours in a day, ~77.8k requests per month:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Cost per Month"}),(0,t.jsx)(s.td,{children:"$166 (fixed)"}),(0,t.jsx)(s.td,{children:"$7465"}),(0,t.jsx)(s.td,{children:"$3182"})]})})]}),"\n",(0,t.jsx)(s.h3,{id:"incremental-costs",children:"Incremental Costs"}),"\n",(0,t.jsx)(s.p,{children:'Large context use cases are also interesting to evaluate. For example, if you had to write a 500 word essay summarizing Tolstoy\'s "War and Peace":'}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:'Cost of "War and Peace"'}),(0,t.jsx)(s.td,{children:"(upfront fixed cost)"}),(0,t.jsx)(s.td,{children:"$94"}),(0,t.jsx)(s.td,{children:"$40"})]})})]}),"\n",(0,t.jsxs)(s.blockquote,{children:["\n",(0,t.jsxs)(s.p,{children:[(0,t.jsx)(s.strong,{children:"Takeaway"}),": Renting on cloud or using an API is great for initially scaling. However, it can quickly become expensive when dealing with large datasets and context windows. For predictable costs, self-hosting is an attractive option."]}),"\n"]}),"\n",(0,t.jsx)(s.h2,{id:"business-considerations",children:"Business Considerations"}),"\n",(0,t.jsx)(s.p,{children:"Other business level considerations may include:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsxs)(s.tbody,{children:[(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Data Privacy"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u274c"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Offline Mode"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u274c"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Customization & Control"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Auditing"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Setup Complexity"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Setup Cost"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Maintenance"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"})]})]})]}),"\n",(0,t.jsx)(s.h2,{id:"conclusion",children:"Conclusion"}),"\n",(0,t.jsx)(s.p,{children:"The decision to run LLMs in the cloud or on in-house servers is not one-size-fits-all. It depends on your business's specific needs, budget, and security considerations. Cloud-based LLMs offer scalability and cost-efficiency but come with potential security concerns, while in-house servers provide greater control, customization, and cost predictability."}),"\n",(0,t.jsx)(s.p,{children:"In some situations, using a mix of cloud and in-house resources can be the best way to go. Businesses need to assess their needs and assets carefully to pick the right method for using LLMs in the ever-changing world of AI technology."})]})}function a(e={}){const{wrapper:s}={...(0,i.R)(),...e.components};return s?(0,t.jsx)(s,{...e,children:(0,t.jsx)(h,{...e})}):h(e)}},28453:(e,s,n)=>{n.d(s,{R:()=>d,x:()=>o});var t=n(96540);const i={},r=t.createContext(i);function d(e){const s=t.useContext(r);return t.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function o(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:d(e.components),t.createElement(r.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c5483ccc.eb43abd5.js b/assets/js/c5483ccc.eb43abd5.js deleted file mode 100644 index 6584b819..00000000 --- a/assets/js/c5483ccc.eb43abd5.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8911],{46812:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>l,contentTitle:()=>d,default:()=>a,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var t=n(74848),i=n(28453);const r={title:"Cloud vs. Self-hosting Your AI"},d=void 0,o={id:"hardware/overview/cloud-vs-self-hosting",title:"Cloud vs. Self-hosting Your AI",description:"The choice of how to run your AI - on GPU cloud services, on-prem, or just using an API provider - involves various trade-offs. The following is a naive exploration of the pros and cons of renting vs self-hosting.",source:"@site/docs/hardware/overview/cloud-vs-self-hosting.md",sourceDirName:"hardware/overview",slug:"/hardware/overview/cloud-vs-self-hosting",permalink:"/hardware/overview/cloud-vs-self-hosting",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/overview/cloud-vs-self-hosting.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Cloud vs. Self-hosting Your AI"}},l={},c=[{value:"Cost Comparison",id:"cost-comparison",level:2},{value:"Low Usage",id:"low-usage",level:3},{value:"High Usage",id:"high-usage",level:3},{value:"Incremental Costs",id:"incremental-costs",level:3},{value:"Business Considerations",id:"business-considerations",level:2},{value:"Conclusion",id:"conclusion",level:2}];function h(e){const s={blockquote:"blockquote",h2:"h2",h3:"h3",li:"li",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(s.p,{children:"The choice of how to run your AI - on GPU cloud services, on-prem, or just using an API provider - involves various trade-offs. The following is a naive exploration of the pros and cons of renting vs self-hosting."}),"\n",(0,t.jsx)(s.h2,{id:"cost-comparison",children:"Cost Comparison"}),"\n",(0,t.jsx)(s.p,{children:"The following estimations use these general assumptions:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Unit Costs"}),(0,t.jsx)(s.td,{children:"$10k upfront for 2x4090s (5 year amort.)"}),(0,t.jsx)(s.td,{children:"$0.00012/token"}),(0,t.jsx)(s.td,{children:"$4.42 for 1xH100/h"})]})})]}),"\n",(0,t.jsxs)(s.ul,{children:["\n",(0,t.jsx)(s.li,{children:"800 average tokens (input & output) in a single request"}),"\n",(0,t.jsx)(s.li,{children:"Inference speed is at 24 tokens per second"}),"\n"]}),"\n",(0,t.jsx)(s.h3,{id:"low-usage",children:"Low Usage"}),"\n",(0,t.jsx)(s.p,{children:"When operating at low capacity:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Cost per Request"}),(0,t.jsx)(s.td,{children:"$2.33"}),(0,t.jsx)(s.td,{children:"$0.10"}),(0,t.jsx)(s.td,{children:"$0.04"})]})})]}),"\n",(0,t.jsx)(s.h3,{id:"high-usage",children:"High Usage"}),"\n",(0,t.jsx)(s.p,{children:"When operating at high capacity, i.e. 24 hours in a day, ~77.8k requests per month:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Cost per Month"}),(0,t.jsx)(s.td,{children:"$166 (fixed)"}),(0,t.jsx)(s.td,{children:"$7465"}),(0,t.jsx)(s.td,{children:"$3182"})]})})]}),"\n",(0,t.jsx)(s.h3,{id:"incremental-costs",children:"Incremental Costs"}),"\n",(0,t.jsx)(s.p,{children:'Large context use cases are also interesting to evaluate. For example, if you had to write a 500 word essay summarizing Tolstoy\'s "War and Peace":'}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsx)(s.tbody,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:'Cost of "War and Peace"'}),(0,t.jsx)(s.td,{children:"(upfront fixed cost)"}),(0,t.jsx)(s.td,{children:"$94"}),(0,t.jsx)(s.td,{children:"$40"})]})})]}),"\n",(0,t.jsxs)(s.blockquote,{children:["\n",(0,t.jsxs)(s.p,{children:[(0,t.jsx)(s.strong,{children:"Takeaway"}),": Renting on cloud or using an API is great for initially scaling. However, it can quickly become expensive when dealing with large datasets and context windows. For predictable costs, self-hosting is an attractive option."]}),"\n"]}),"\n",(0,t.jsx)(s.h2,{id:"business-considerations",children:"Business Considerations"}),"\n",(0,t.jsx)(s.p,{children:"Other business level considerations may include:"}),"\n",(0,t.jsxs)(s.table,{children:[(0,t.jsx)(s.thead,{children:(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.th,{}),(0,t.jsx)(s.th,{children:"Self-Hosted"}),(0,t.jsx)(s.th,{children:"GPT 4.0"}),(0,t.jsx)(s.th,{children:"GPU Rental"})]})}),(0,t.jsxs)(s.tbody,{children:[(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Data Privacy"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u274c"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Offline Mode"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u274c"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Customization & Control"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Auditing"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Setup Complexity"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Setup Cost"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u2705"})]}),(0,t.jsxs)(s.tr,{children:[(0,t.jsx)(s.td,{children:"Maintenance"}),(0,t.jsx)(s.td,{children:"\u274c"}),(0,t.jsx)(s.td,{children:"\u2705"}),(0,t.jsx)(s.td,{children:"\u274c"})]})]})]}),"\n",(0,t.jsx)(s.h2,{id:"conclusion",children:"Conclusion"}),"\n",(0,t.jsx)(s.p,{children:"The decision to run LLMs in the cloud or on in-house servers is not one-size-fits-all. It depends on your business's specific needs, budget, and security considerations. Cloud-based LLMs offer scalability and cost-efficiency but come with potential security concerns, while in-house servers provide greater control, customization, and cost predictability."}),"\n",(0,t.jsx)(s.p,{children:"In some situations, using a mix of cloud and in-house resources can be the best way to go. Businesses need to assess their needs and assets carefully to pick the right method for using LLMs in the ever-changing world of AI technology."})]})}function a(e={}){const{wrapper:s}={...(0,i.R)(),...e.components};return s?(0,t.jsx)(s,{...e,children:(0,t.jsx)(h,{...e})}):h(e)}},28453:(e,s,n)=>{n.d(s,{R:()=>d,x:()=>o});var t=n(96540);const i={},r=t.createContext(i);function d(e){const s=t.useContext(r);return t.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function o(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:d(e.components),t.createElement(r.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c582042f.77948601.js b/assets/js/c582042f.77948601.js deleted file mode 100644 index 839f7f8d..00000000 --- a/assets/js/c582042f.77948601.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9493],{69493:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>u,contentTitle:()=>i,default:()=>l,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var n=s(74848),r=s(28453);const o={title:"Support - Jan"},i="Support",a={id:"support/support",title:"Support - Jan",description:"- Bugs & requests: file a GitHub ticket here",source:"@site/docs/support/support.md",sourceDirName:"support",slug:"/support/",permalink:"/support/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/support/support.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Support - Jan"}},u={},c=[];function p(t){const e={a:"a",h1:"h1",li:"li",ul:"ul",...(0,r.R)(),...t.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(e.h1,{id:"support",children:"Support"}),"\n",(0,n.jsxs)(e.ul,{children:["\n",(0,n.jsxs)(e.li,{children:["Bugs & requests: file a GitHub ticket ",(0,n.jsx)(e.a,{href:"https://github.com/janhq/jan/issues",children:"here"})]}),"\n",(0,n.jsxs)(e.li,{children:["For discussion: join our Discord ",(0,n.jsx)(e.a,{href:"https://discord.gg/FTk2MvZwJH",children:"here"})]}),"\n",(0,n.jsxs)(e.li,{children:["For business inquiries: email ",(0,n.jsx)(e.a,{href:"mailto:hello@jan.ai",children:"hello@jan.ai"})]}),"\n",(0,n.jsxs)(e.li,{children:["For jobs: please email ",(0,n.jsx)(e.a,{href:"mailto:hr@jan.ai",children:"hr@jan.ai"})]}),"\n"]})]})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(p,{...t})}):p(t)}},28453:(t,e,s)=>{s.d(e,{R:()=>i,x:()=>a});var n=s(96540);const r={},o=n.createContext(r);function i(t){const e=n.useContext(o);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:i(t.components),n.createElement(o.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/c582042f.c3aeabaf.js b/assets/js/c582042f.c3aeabaf.js new file mode 100644 index 00000000..529e4306 --- /dev/null +++ b/assets/js/c582042f.c3aeabaf.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9493],{69493:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>u,contentTitle:()=>i,default:()=>l,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var n=s(74848),r=s(28453);const o={title:"Support - Jan"},i="Support",a={id:"support/support",title:"Support - Jan",description:"- Bugs & requests: file a GitHub ticket here",source:"@site/docs/support/support.md",sourceDirName:"support",slug:"/support/",permalink:"/support/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/support/support.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Support - Jan"}},u={},c=[];function p(t){const e={a:"a",h1:"h1",li:"li",ul:"ul",...(0,r.R)(),...t.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(e.h1,{id:"support",children:"Support"}),"\n",(0,n.jsxs)(e.ul,{children:["\n",(0,n.jsxs)(e.li,{children:["Bugs & requests: file a GitHub ticket ",(0,n.jsx)(e.a,{href:"https://github.com/janhq/jan/issues",children:"here"})]}),"\n",(0,n.jsxs)(e.li,{children:["For discussion: join our Discord ",(0,n.jsx)(e.a,{href:"https://discord.gg/FTk2MvZwJH",children:"here"})]}),"\n",(0,n.jsxs)(e.li,{children:["For business inquiries: email ",(0,n.jsx)(e.a,{href:"mailto:hello@jan.ai",children:"hello@jan.ai"})]}),"\n",(0,n.jsxs)(e.li,{children:["For jobs: please email ",(0,n.jsx)(e.a,{href:"mailto:hr@jan.ai",children:"hr@jan.ai"})]}),"\n"]})]})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(p,{...t})}):p(t)}},28453:(t,e,s)=>{s.d(e,{R:()=>i,x:()=>a});var n=s(96540);const r={},o=n.createContext(r);function i(t){const e=n.useContext(o);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:i(t.components),n.createElement(o.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/c5e57f2d.6828c960.js b/assets/js/c5e57f2d.6828c960.js deleted file mode 100644 index 347b51b4..00000000 --- a/assets/js/c5e57f2d.6828c960.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3167],{98300:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var l=i(74848),a=i(28453);const r={sidebar_position:17,slug:"/changelog/changelog-v0.2.1"},s="v0.2.1",o={id:"releases/changelog/changelog-v0.2.1",title:"v0.2.1",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.1.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.1",permalink:"/changelog/changelog-v0.2.1",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.1.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:17,frontMatter:{sidebar_position:17,slug:"/changelog/changelog-v0.2.1"},sidebar:"releasesSidebar",previous:{title:"v0.2.2",permalink:"/changelog/changelog-v0.2.2"},next:{title:"v0.2.0",permalink:"/changelog/changelog-v0.2.0"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v021",children:"v0.2.1"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.1",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/446",children:"Issue #446: fix: model is started but the indicator is not stopped loading"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: model is started but the indicator is not stopped loading @louis-jan (#446)"}),"\n",(0,l.jsx)(n.li,{children:"fix: bring back install plugin manually function @louis-jan (#448)"}),"\n",(0,l.jsx)(n.li,{children:"fix: duplicated messages when user switch between conversations @namchuai (#441)"}),"\n",(0,l.jsx)(n.li,{children:"chore: added loader starting and stopping model @urmauur (#438)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Change license to AGPL @dan-jan (#442)"}),"\n",(0,l.jsx)(n.li,{children:"fix: plugin & model catalog import cache are not cleared properly @louis-jan (#437)"}),"\n",(0,l.jsx)(n.li,{children:"fix error codesign @hiento09 (#439)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app version and cleanup unused code @urmauur (#434)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core service - get plugin manifest @louis-jan (#432)"}),"\n",(0,l.jsx)(n.li,{children:"ui: interface revamp @urmauur (#429)"}),"\n",(0,l.jsx)(n.li,{children:"fix: scroll on explore models does not work @namchuai (#427)"}),"\n",(0,l.jsx)(n.li,{children:"feat: adding create bot functionality @namchuai (#368)"}),"\n",(0,l.jsx)(n.li,{children:"chore: install or update a plugin should not interrupt dev process @louis-jan (#420)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update nitro 0.1.2 windows/ linux @vuonghoainam (#421)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core service enums @louis-jan (#414)"}),"\n",(0,l.jsx)(n.li,{children:"feat: chat with documents plugin @louis-jan (#417)"}),"\n",(0,l.jsx)(n.li,{children:"misc: setup prettier @urmauur (#412)"}),"\n",(0,l.jsx)(n.li,{children:"adr: 007 - Jan Plugin Catalog @louis-jan (#408)"}),"\n",(0,l.jsx)(n.li,{children:"adr: 006 - Jan Core Module @louis-jan (#404)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Support for nitro release 0.1.2 @vuonghoainam (#409)"}),"\n",(0,l.jsx)(n.li,{children:"feat: explore plugins from the npm repository and install them remotely @louis-jan (#399)"}),"\n",(0,l.jsx)(n.li,{children:"feat: fix event description @dan-jan (#400)"}),"\n",(0,l.jsx)(n.li,{children:"fix: high cpu usage @louis-jan (#401)"}),"\n",(0,l.jsx)(n.li,{children:"docs: model installation ADR @0xSage (#390)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core events module @louis-jan (#394)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Update Social OG Image and Meta Description @dan-jan (#387)"}),"\n",(0,l.jsx)(n.li,{children:"misc: UI home @urmauur (#392)"}),"\n",(0,l.jsx)(n.li,{children:"Update hcmc-oct23.md @0xSage (#389)"}),"\n",(0,l.jsx)(n.li,{children:"chore: remove deprecated extension functions @louis-jan (#388)"}),"\n",(0,l.jsx)(n.li,{children:"Fix bugs image overlap dropdown button download @urmauur (#384)"}),"\n",(0,l.jsx)(n.li,{children:"chore: resolve fetch models api limit rate @louis-jan (#383)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update convo summary @louis-jan (#378)"}),"\n",(0,l.jsx)(n.li,{children:"Update interface landing page @urmauur (#381)"}),"\n",(0,l.jsx)(n.li,{children:"Add simple copywriting changes @dan-jan (#382)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core services and module export @louis-jan (#376)"}),"\n",(0,l.jsx)(n.li,{children:"chore: #371 - reference to plugin name and module path as variables @louis-jan (#372)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Edit event details, hide all unnecessary website sections @dan-jan (#369)"}),"\n",(0,l.jsx)(n.li,{children:"docs: UI Service ADR @0xSage (#318)"}),"\n",(0,l.jsx)(n.li,{children:"Feat/issue 255 adr 001 jand cloud native @nam-john-ho (#262)"}),"\n",(0,l.jsx)(n.li,{children:"Move plugins folder from electron to root folder @hiento09 (#366)"}),"\n",(0,l.jsx)(n.li,{children:"feature: core plugin support events & preferences modules @louis-jan (#365)"}),"\n",(0,l.jsx)(n.li,{children:"Fix/250 @namchuai (#349)"}),"\n",(0,l.jsx)(n.li,{children:"Change License and update README @dan-jan (#356)"}),"\n",(0,l.jsx)(n.li,{children:"Jan 339 @dan-jan (#348)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Jan 339 @dan-jan (#347)"}),"\n",(0,l.jsxs)(n.li,{children:["Add social og",":image"," @dan-jan (#346)"]}),"\n",(0,l.jsx)(n.li,{children:"feat(ard): Add adr 002 @vuonghoainam (#261)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"#357 plugin & app can subscribe and emit events @louis-jan (#358)"}),"\n",(0,l.jsx)(n.li,{children:"feature: @janhq/plugin-core module & usage @louis-jan (#321)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Change to load nitron on windows and linux from bash/shell script @hiento09 (#451)"}),"\n",(0,l.jsx)(n.li,{children:"Fix data-plugin install failed on mac silicon from npm @hiento09 (#413)"}),"\n",(0,l.jsx)(n.li,{children:"Correct version of plugins @hiento09 (#374)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"upgrade leveldown to newest version @hiento09 (#447)"}),"\n",(0,l.jsx)(n.li,{children:"Update auto-sign plugin by search file permission 664 @hiento09 (#445)"}),"\n",(0,l.jsx)(n.li,{children:"Change codesign plugin folder in ci @hiento09 (#440)"}),"\n",(0,l.jsx)(n.li,{children:"Add continue on error for import cert @hiento09 (#436)"}),"\n",(0,l.jsx)(n.li,{children:"Update code siging for new data plugin @hiento09 (#433)"}),"\n",(0,l.jsx)(n.li,{children:"Add readme inference plugin @hiento09 (#426)"}),"\n",(0,l.jsx)(n.li,{children:"Add username to remote origin @hiento09 (#425)"}),"\n",(0,l.jsx)(n.li,{children:"Add auto create PR to plugin-catalog when a new version of plugin is \u2026 @hiento09 (#416)"}),"\n",(0,l.jsx)(n.li,{children:"Fix data-plugin install failed on mac silicon from npm @hiento09 (#413)"}),"\n",(0,l.jsx)(n.li,{children:"Chore/remove package lock @hiento09 (#398)"}),"\n",(0,l.jsx)(n.li,{children:"Refactor cicd @hiento09 (#397)"}),"\n",(0,l.jsx)(n.li,{children:"Correct version of plugins @hiento09 (#374)"}),"\n",(0,l.jsx)(n.li,{children:"Rename plugin-core to core @hiento09 (#370)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error check change in plugins folder @hiento09 (#367)"}),"\n",(0,l.jsx)(n.li,{children:"chore: jan.ai nits @0xSage (#354)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @dan-jan, @hiento09, @jan-service-account, @louis-jan, @nam-john-ho, @namchuai, @tikikun, @urmauur, @vuonghoainam and Hien To"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>o});var l=i(96540);const a={},r=l.createContext(a);function s(e){const n=l.useContext(r);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),l.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/c5e57f2d.d6d037c6.js b/assets/js/c5e57f2d.d6d037c6.js new file mode 100644 index 00000000..e715c3bd --- /dev/null +++ b/assets/js/c5e57f2d.d6d037c6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3167],{98300:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var l=i(74848),a=i(28453);const r={sidebar_position:17,slug:"/changelog/changelog-v0.2.1"},s="v0.2.1",o={id:"releases/changelog/changelog-v0.2.1",title:"v0.2.1",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.1.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.1",permalink:"/changelog/changelog-v0.2.1",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.1.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:17,frontMatter:{sidebar_position:17,slug:"/changelog/changelog-v0.2.1"},sidebar:"releasesSidebar",previous:{title:"v0.2.2",permalink:"/changelog/changelog-v0.2.2"},next:{title:"v0.2.0",permalink:"/changelog/changelog-v0.2.0"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v021",children:"v0.2.1"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.1",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/446",children:"Issue #446: fix: model is started but the indicator is not stopped loading"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: model is started but the indicator is not stopped loading @louis-jan (#446)"}),"\n",(0,l.jsx)(n.li,{children:"fix: bring back install plugin manually function @louis-jan (#448)"}),"\n",(0,l.jsx)(n.li,{children:"fix: duplicated messages when user switch between conversations @namchuai (#441)"}),"\n",(0,l.jsx)(n.li,{children:"chore: added loader starting and stopping model @urmauur (#438)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Change license to AGPL @dan-jan (#442)"}),"\n",(0,l.jsx)(n.li,{children:"fix: plugin & model catalog import cache are not cleared properly @louis-jan (#437)"}),"\n",(0,l.jsx)(n.li,{children:"fix error codesign @hiento09 (#439)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app version and cleanup unused code @urmauur (#434)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core service - get plugin manifest @louis-jan (#432)"}),"\n",(0,l.jsx)(n.li,{children:"ui: interface revamp @urmauur (#429)"}),"\n",(0,l.jsx)(n.li,{children:"fix: scroll on explore models does not work @namchuai (#427)"}),"\n",(0,l.jsx)(n.li,{children:"feat: adding create bot functionality @namchuai (#368)"}),"\n",(0,l.jsx)(n.li,{children:"chore: install or update a plugin should not interrupt dev process @louis-jan (#420)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update nitro 0.1.2 windows/ linux @vuonghoainam (#421)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core service enums @louis-jan (#414)"}),"\n",(0,l.jsx)(n.li,{children:"feat: chat with documents plugin @louis-jan (#417)"}),"\n",(0,l.jsx)(n.li,{children:"misc: setup prettier @urmauur (#412)"}),"\n",(0,l.jsx)(n.li,{children:"adr: 007 - Jan Plugin Catalog @louis-jan (#408)"}),"\n",(0,l.jsx)(n.li,{children:"adr: 006 - Jan Core Module @louis-jan (#404)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Support for nitro release 0.1.2 @vuonghoainam (#409)"}),"\n",(0,l.jsx)(n.li,{children:"feat: explore plugins from the npm repository and install them remotely @louis-jan (#399)"}),"\n",(0,l.jsx)(n.li,{children:"feat: fix event description @dan-jan (#400)"}),"\n",(0,l.jsx)(n.li,{children:"fix: high cpu usage @louis-jan (#401)"}),"\n",(0,l.jsx)(n.li,{children:"docs: model installation ADR @0xSage (#390)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core events module @louis-jan (#394)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Update Social OG Image and Meta Description @dan-jan (#387)"}),"\n",(0,l.jsx)(n.li,{children:"misc: UI home @urmauur (#392)"}),"\n",(0,l.jsx)(n.li,{children:"Update hcmc-oct23.md @0xSage (#389)"}),"\n",(0,l.jsx)(n.li,{children:"chore: remove deprecated extension functions @louis-jan (#388)"}),"\n",(0,l.jsx)(n.li,{children:"Fix bugs image overlap dropdown button download @urmauur (#384)"}),"\n",(0,l.jsx)(n.li,{children:"chore: resolve fetch models api limit rate @louis-jan (#383)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update convo summary @louis-jan (#378)"}),"\n",(0,l.jsx)(n.li,{children:"Update interface landing page @urmauur (#381)"}),"\n",(0,l.jsx)(n.li,{children:"Add simple copywriting changes @dan-jan (#382)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update core services and module export @louis-jan (#376)"}),"\n",(0,l.jsx)(n.li,{children:"chore: #371 - reference to plugin name and module path as variables @louis-jan (#372)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Edit event details, hide all unnecessary website sections @dan-jan (#369)"}),"\n",(0,l.jsx)(n.li,{children:"docs: UI Service ADR @0xSage (#318)"}),"\n",(0,l.jsx)(n.li,{children:"Feat/issue 255 adr 001 jand cloud native @nam-john-ho (#262)"}),"\n",(0,l.jsx)(n.li,{children:"Move plugins folder from electron to root folder @hiento09 (#366)"}),"\n",(0,l.jsx)(n.li,{children:"feature: core plugin support events & preferences modules @louis-jan (#365)"}),"\n",(0,l.jsx)(n.li,{children:"Fix/250 @namchuai (#349)"}),"\n",(0,l.jsx)(n.li,{children:"Change License and update README @dan-jan (#356)"}),"\n",(0,l.jsx)(n.li,{children:"Jan 339 @dan-jan (#348)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Jan 339 @dan-jan (#347)"}),"\n",(0,l.jsxs)(n.li,{children:["Add social og",":image"," @dan-jan (#346)"]}),"\n",(0,l.jsx)(n.li,{children:"feat(ard): Add adr 002 @vuonghoainam (#261)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"#357 plugin & app can subscribe and emit events @louis-jan (#358)"}),"\n",(0,l.jsx)(n.li,{children:"feature: @janhq/plugin-core module & usage @louis-jan (#321)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Change to load nitron on windows and linux from bash/shell script @hiento09 (#451)"}),"\n",(0,l.jsx)(n.li,{children:"Fix data-plugin install failed on mac silicon from npm @hiento09 (#413)"}),"\n",(0,l.jsx)(n.li,{children:"Correct version of plugins @hiento09 (#374)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"upgrade leveldown to newest version @hiento09 (#447)"}),"\n",(0,l.jsx)(n.li,{children:"Update auto-sign plugin by search file permission 664 @hiento09 (#445)"}),"\n",(0,l.jsx)(n.li,{children:"Change codesign plugin folder in ci @hiento09 (#440)"}),"\n",(0,l.jsx)(n.li,{children:"Add continue on error for import cert @hiento09 (#436)"}),"\n",(0,l.jsx)(n.li,{children:"Update code siging for new data plugin @hiento09 (#433)"}),"\n",(0,l.jsx)(n.li,{children:"Add readme inference plugin @hiento09 (#426)"}),"\n",(0,l.jsx)(n.li,{children:"Add username to remote origin @hiento09 (#425)"}),"\n",(0,l.jsx)(n.li,{children:"Add auto create PR to plugin-catalog when a new version of plugin is \u2026 @hiento09 (#416)"}),"\n",(0,l.jsx)(n.li,{children:"Fix data-plugin install failed on mac silicon from npm @hiento09 (#413)"}),"\n",(0,l.jsx)(n.li,{children:"Chore/remove package lock @hiento09 (#398)"}),"\n",(0,l.jsx)(n.li,{children:"Refactor cicd @hiento09 (#397)"}),"\n",(0,l.jsx)(n.li,{children:"Correct version of plugins @hiento09 (#374)"}),"\n",(0,l.jsx)(n.li,{children:"Rename plugin-core to core @hiento09 (#370)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error check change in plugins folder @hiento09 (#367)"}),"\n",(0,l.jsx)(n.li,{children:"chore: jan.ai nits @0xSage (#354)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @dan-jan, @hiento09, @jan-service-account, @louis-jan, @nam-john-ho, @namchuai, @tikikun, @urmauur, @vuonghoainam and Hien To"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>o});var l=i(96540);const a={},r=l.createContext(a);function s(e){const n=l.useContext(r);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),l.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ca7f0669.b5b17f3a.js b/assets/js/ca7f0669.b5b17f3a.js deleted file mode 100644 index 54c38fa4..00000000 --- a/assets/js/ca7f0669.b5b17f3a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7401],{72797:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>c,metadata:()=>o,toc:()=>a});var r=n(74848),i=n(28453);const c={title:"Pricing",slug:"/pricing",description:"Pricing for Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","pricing"]},s=void 0,o={id:"pricing/pricing",title:"Pricing",description:"Pricing for Jan",source:"@site/docs/pricing/pricing.md",sourceDirName:"pricing",slug:"/pricing",permalink:"/pricing",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/pricing/pricing.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Pricing",slug:"/pricing",description:"Pricing for Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","pricing"]},sidebar:"pricingSidebar"},d={},a=[];function l(e){const t={table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...e.components};return(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{children:"$0"}),(0,r.jsx)(t.th,{children:"$1"}),(0,r.jsx)(t.th,{children:"Enterprise"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:"Free"}),(0,r.jsx)(t.td,{children:"Premium"}),(0,r.jsx)(t.td,{children:"TBA"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:"\u2705 Core features"}),(0,r.jsx)(t.td,{children:"\u2705 Discord badge"}),(0,r.jsx)(t.td,{children:"\u2705 Enterprise-level SLA"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:"\u2705 free forever"}),(0,r.jsx)(t.td,{}),(0,r.jsx)(t.td,{})]})]})]})}function p(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(l,{...e})}):l(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>o});var r=n(96540);const i={},c=r.createContext(i);function s(e){const t=r.useContext(c);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function o(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),r.createElement(c.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ca7f0669.b8ba1302.js b/assets/js/ca7f0669.b8ba1302.js new file mode 100644 index 00000000..2dab35d5 --- /dev/null +++ b/assets/js/ca7f0669.b8ba1302.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7401],{72797:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>p,frontMatter:()=>c,metadata:()=>o,toc:()=>a});var r=n(74848),i=n(28453);const c={title:"Pricing",slug:"/pricing",description:"Pricing for Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","pricing"]},s=void 0,o={id:"pricing/pricing",title:"Pricing",description:"Pricing for Jan",source:"@site/docs/pricing/pricing.md",sourceDirName:"pricing",slug:"/pricing",permalink:"/pricing",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/pricing/pricing.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Pricing",slug:"/pricing",description:"Pricing for Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","pricing"]},sidebar:"pricingSidebar"},d={},a=[];function l(e){const t={table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...e.components};return(0,r.jsxs)(t.table,{children:[(0,r.jsx)(t.thead,{children:(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.th,{children:"$0"}),(0,r.jsx)(t.th,{children:"$1"}),(0,r.jsx)(t.th,{children:"Enterprise"})]})}),(0,r.jsxs)(t.tbody,{children:[(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:"Free"}),(0,r.jsx)(t.td,{children:"Premium"}),(0,r.jsx)(t.td,{children:"TBA"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:"\u2705 Core features"}),(0,r.jsx)(t.td,{children:"\u2705 Discord badge"}),(0,r.jsx)(t.td,{children:"\u2705 Enterprise-level SLA"})]}),(0,r.jsxs)(t.tr,{children:[(0,r.jsx)(t.td,{children:"\u2705 free forever"}),(0,r.jsx)(t.td,{}),(0,r.jsx)(t.td,{})]})]})]})}function p(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(l,{...e})}):l(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>s,x:()=>o});var r=n(96540);const i={},c=r.createContext(i);function s(e){const t=r.useContext(c);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function o(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),r.createElement(c.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ceb5ae55.d59ed533.js b/assets/js/ceb5ae55.d59ed533.js deleted file mode 100644 index a6755baf..00000000 --- a/assets/js/ceb5ae55.d59ed533.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2992],{74285:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>l});var i=t(74848),s=t(28453);const r={title:"About Jan",slug:"/about",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine"]},o=void 0,a={id:"about/about",title:"About Jan",description:"Jan is a desktop application that turns computers into thinking machines.",source:"@site/docs/about/about.md",sourceDirName:"about",slug:"/about",permalink:"/about",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/about.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"About Jan",slug:"/about",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine"]},sidebar:"aboutSidebar",next:{title:"Jan's Community",permalink:"/community"}},c={},l=[{value:"Jan\u2019s principles",id:"jans-principles",level:2},{value:"Why do we exist?",id:"why-do-we-exist",level:2},{value:"What are the things Jan committed on?",id:"what-are-the-things-jan-committed-on",level:3},{value:"What's different about it?",id:"whats-different-about-it",level:4},{value:"How we work",id:"how-we-work",level:2},{value:"How to get it?",id:"how-to-get-it",level:2},{value:"What license is the code under?",id:"what-license-is-the-code-under",level:2},{value:"What was it built with?",id:"what-was-it-built-with",level:2},{value:"Join the team",id:"join-the-team",level:2},{value:"Contact",id:"contact",level:2},{value:"Footnotes",id:"footnotes",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",em:"em",h2:"h2",h3:"h3",h4:"h4",img:"img",li:"li",ol:"ol",p:"p",section:"section",strong:"strong",sup:"sup",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.p,{children:"Jan turns computers into thinking machines."}),"\n",(0,i.jsx)(n.p,{children:"Jan is created and maintained by Jan Labs, a robotics company."}),"\n",(0,i.jsx)(n.p,{children:"With Jan, you can:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Run ",(0,i.jsx)(n.a,{href:"https://huggingface.co/models?pipeline_tag=text-generation",children:"open-source LLMs"})," locally or connect to cloud AIs like ",(0,i.jsx)(n.a,{href:"https://openai.com/blog/openai-api",children:"ChatGPT"})," or ",(0,i.jsx)(n.a,{href:"https://ai.google.dev/",children:"Google"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Fine-tune AI with specific knowledge."}),"\n",(0,i.jsx)(n.li,{children:"Supercharge your productivity by leveraging AI."}),"\n",(0,i.jsx)(n.li,{children:"Search the web and databases."}),"\n",(0,i.jsx)(n.li,{children:"Integrate AI with everyday tools to work on your behalf (with permission)."}),"\n",(0,i.jsx)(n.li,{children:"Customize and add features with Extensions."}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsx)(n.p,{children:"Jan aims for long-term human-robot collaboration, envisioning AI as a harmonious extension of human capabilities. Our goal is to build customizable robots that we continually improve and customize, growing together."})}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Human repairing a Droid",src:t(69681).A+"",width:"1441",height:"812"})}),"\n",(0,i.jsx)(n.h2,{id:"jans-principles",children:"Jan\u2019s principles"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Ownership"}),": Jan is committed to developing a product that fully belongs to users. You're the true owner, free from data tracking and storage by us."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Privacy"}),": Jan works locally by default, allowing use without an internet connection. Your data stays on your device in a universal format, giving you complete privacy control."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"100% User Supported"}),": Every user can access, develop, and customize Jan's codebases to suit their needs."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Rejecting Dark Patterns"}),": We never use tricks to extract more money or lock you into an ecosystem."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"why-do-we-exist",children:"Why do we exist?"}),"\n",(0,i.jsxs)(n.blockquote,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.em,{children:'"I do not fear computers. I fear the lack of them." - Isaac Asimov'})}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:"Jan was founded on the belief that AI should coexist with humans, not replace them. Our mission is to democratize AI access, ensuring everyone can easily utilize it with full ownership and control over their data, free from privacy concerns."}),"\n",(0,i.jsx)(n.h3,{id:"what-are-the-things-jan-committed-on",children:"What are the things Jan committed on?"}),"\n",(0,i.jsx)(n.p,{children:"We are committed to creating open, local-first products that extend individual freedom, rejecting dark patterns and ecosystem lock-ins, and embracing an open-source ethos."}),"\n",(0,i.jsx)(n.h4,{id:"whats-different-about-it",children:"What's different about it?"}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{}),(0,i.jsx)(n.th,{children:"Status Quo"}),(0,i.jsx)(n.th,{children:"Jan"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Ownership"})}),(0,i.jsx)(n.td,{children:"Owned by Big Tech"}),(0,i.jsx)(n.td,{children:"Fully owned by you"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Openness"})}),(0,i.jsx)(n.td,{children:"Closed-source"}),(0,i.jsx)(n.td,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/main/LICENSE",children:"Open-source (AGPLv3)"})})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Your Role"})}),(0,i.jsx)(n.td,{children:"Consumer"}),(0,i.jsx)(n.td,{children:"Creator"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Approach"})}),(0,i.jsx)(n.td,{children:"Cloud-based"}),(0,i.jsx)(n.td,{children:(0,i.jsx)(n.a,{href:"https://www.inkandswitch.com/local-first/",children:"Local-first"})})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Data Handling"})}),(0,i.jsx)(n.td,{children:"Stored on external servers"}),(0,i.jsx)(n.td,{children:"Stored locally, openly accessible"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Privacy"})}),(0,i.jsx)(n.td,{children:"Questionable"}),(0,i.jsx)(n.td,{children:"Private and offline"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Transparency"})}),(0,i.jsx)(n.td,{children:'Opaque "Black Box"'}),(0,i.jsx)(n.td,{children:"Open-source and customizable"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Outage Resilience"})}),(0,i.jsx)(n.td,{children:"Potential data hostage"}),(0,i.jsx)(n.td,{children:"Continues to work on your device"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Philosophy"})}),(0,i.jsx)(n.td,{children:"User monetization"}),(0,i.jsx)(n.td,{children:"Empowerment with the right to repair"})]})]})]}),"\n",(0,i.jsx)(n.h2,{id:"how-we-work",children:"How we work"}),"\n",(0,i.jsx)(n.p,{children:"Jan is an open-source product with transparent development and future features. Users have the right to modify and customize Jan. We are committed to building an open-source AI ecosystem."}),"\n",(0,i.jsxs)(n.p,{children:["Jan is building in public using GitHub, where anyone is welcome to join. Key resources include Jan's ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/7",children:"Kanban"})," and Jan's ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/29",children:"Roadmap"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["Jan has a fully-remote team, primarily based in the APAC timezone, and we use Discord and GitHub for collaboration. Our community is central to our operations, and we embrace asynchronous work. We hold meetings only for synchronization and vision sharing, using ",(0,i.jsx)(n.a,{href:"https://excalidraw.com/",children:"Excalidraw"})," or ",(0,i.jsx)(n.a,{href:"https://miro.com/",children:"Miro"})," for visualization and sharing notes on Discord for alignment. We also use ",(0,i.jsx)(n.a,{href:"https://hackmd.io/",children:"HackMD"})," to document our ideas and build a Jan library."]}),"\n",(0,i.jsx)(n.h2,{id:"how-to-get-it",children:"How to get it?"}),"\n",(0,i.jsxs)(n.p,{children:["You can install and start using Jan in less than 5 minutes, from ",(0,i.jsx)(n.a,{href:"https://jan.ai",children:"Jan.ai"})," or our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Github repo"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"what-license-is-the-code-under",children:"What license is the code under?"}),"\n",(0,i.jsxs)(n.p,{children:["Jan is licensed under the ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/main/LICENSE",children:"AGPLv3 License"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["We happily accept pull requests, however, we do ask that you sign a ",(0,i.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Contributor_License_Agreement",children:"Contributor License Agreement"})," so that we have the right to relicense your contributions",(0,i.jsx)(n.sup,{children:(0,i.jsx)(n.a,{href:"#user-content-fn-2",id:"user-content-fnref-2","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"1"})}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"what-was-it-built-with",children:"What was it built with?"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Jan"})," is pragmatically built using ",(0,i.jsx)(n.code,{children:"Typescript"})," at the application level and ",(0,i.jsx)(n.code,{children:"C++"})," at the Inference level (which we have refactored into ",(0,i.jsx)(n.a,{href:"https://nitro.jan.ai",children:"Nitro"}),(0,i.jsx)(n.sup,{children:(0,i.jsx)(n.a,{href:"#user-content-fn-3",id:"user-content-fnref-3","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"2"})}),")."]}),"\n",(0,i.jsxs)(n.p,{children:["We follow ",(0,i.jsx)(n.a,{href:"https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html",children:"clean architecture"})," and currently support multiple frameworks and runtimes:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["A desktop client with ",(0,i.jsx)(n.a,{href:"https://www.electronjs.org/",children:"Electron"})]}),"\n",(0,i.jsxs)(n.li,{children:["A headless server-mode with ",(0,i.jsx)(n.a,{href:"https://nodejs.org/en",children:"Nodejs"})]}),"\n",(0,i.jsxs)(n.li,{children:["Planned support for mobile with ",(0,i.jsx)(n.a,{href:"https://capacitorjs.com/",children:"Capacitor"})]}),"\n",(0,i.jsx)(n.li,{children:"Planned support for Python runtime"}),"\n"]}),"\n",(0,i.jsxs)(n.p,{children:["Architecturally, we have made similar choices to the ",(0,i.jsx)(n.a,{href:"https://vercel.com/templates/next.js/nextjs-enterprise-boilerplate",children:"Next.js Enterprise Javascript Stack"}),", which is a ",(0,i.jsx)(n.a,{href:"https://nextjs.org/showcase/enterprise",children:"battle-tested"})," framework for building enterprise-grade applications that scale."]}),"\n",(0,i.jsx)(n.h2,{id:"join-the-team",children:"Join the team"}),"\n",(0,i.jsxs)(n.p,{children:["Join us on this journey at Jan Labs, where we embrace open-source collaboration and transparency. Together, let's shape a future where Jan becomes an essential companion in the open-source community. Explore ",(0,i.jsx)(n.a,{href:"https://janai.bamboohr.com/careers",children:"careers"})," with us."]}),"\n",(0,i.jsx)(n.h2,{id:"contact",children:"Contact"}),"\n",(0,i.jsxs)(n.p,{children:["Drop us a message in our ",(0,i.jsx)(n.a,{href:"https://discord.gg/af6SaTdzpx",children:"Discord"})," and we'll get back to you."]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"#general"}),": for general discussion"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"#get-help"}),": for bug reports and troubleshooting"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"#roadmap"}),": for feature requests and ideas"]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"footnotes",children:"Footnotes"}),"\n",(0,i.jsxs)(n.section,{"data-footnotes":!0,className:"footnotes",children:[(0,i.jsx)(n.h2,{className:"sr-only",id:"footnote-label",children:"Footnotes"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{id:"user-content-fn-2",children:["\n",(0,i.jsxs)(n.p,{children:["Credit to ",(0,i.jsx)(n.a,{href:"https://www.discourse.org/about",children:"Discourse's About Page"})," ",(0,i.jsx)(n.a,{href:"#user-content-fnref-2","data-footnote-backref":"","aria-label":"Back to reference 1",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{id:"user-content-fn-3",children:["\n",(0,i.jsxs)(n.p,{children:["Credit to ",(0,i.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp",children:"Llama.cpp"}),", ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"}),", ",(0,i.jsx)(n.a,{href:"https://github.com/vllm-project/vllm",children:"vLLM"}),", ",(0,i.jsx)(n.a,{href:"https://github.com/InternLM/lmdeploy",children:"LMDeploy"})," and more. ",(0,i.jsx)(n.a,{href:"#user-content-fnref-3","data-footnote-backref":"","aria-label":"Back to reference 2",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n"]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(d,{...e})}):d(e)}},69681:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/star-wars-droids-776530079e5c0b4ebad027378f5dd1f3.png"},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>a});var i=t(96540);const s={},r=i.createContext(s);function o(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ceb5ae55.d6a68798.js b/assets/js/ceb5ae55.d6a68798.js new file mode 100644 index 00000000..c059c780 --- /dev/null +++ b/assets/js/ceb5ae55.d6a68798.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2992],{74285:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>a,toc:()=>l});var i=t(74848),s=t(28453);const r={title:"About Jan",slug:"/about",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine"]},o=void 0,a={id:"about/about",title:"About Jan",description:"Jan is a desktop application that turns computers into thinking machines.",source:"@site/docs/about/about.md",sourceDirName:"about",slug:"/about",permalink:"/about",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/about/about.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"About Jan",slug:"/about",description:"Jan is a desktop application that turns computers into thinking machines.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","about Jan","desktop application","thinking machine"]},sidebar:"aboutSidebar",next:{title:"Jan's Community",permalink:"/community"}},c={},l=[{value:"Jan\u2019s principles",id:"jans-principles",level:2},{value:"Why do we exist?",id:"why-do-we-exist",level:2},{value:"What are the things Jan committed on?",id:"what-are-the-things-jan-committed-on",level:3},{value:"What's different about it?",id:"whats-different-about-it",level:4},{value:"How we work",id:"how-we-work",level:2},{value:"How to get it?",id:"how-to-get-it",level:2},{value:"What license is the code under?",id:"what-license-is-the-code-under",level:2},{value:"What was it built with?",id:"what-was-it-built-with",level:2},{value:"Join the team",id:"join-the-team",level:2},{value:"Contact",id:"contact",level:2},{value:"Footnotes",id:"footnotes",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",em:"em",h2:"h2",h3:"h3",h4:"h4",img:"img",li:"li",ol:"ol",p:"p",section:"section",strong:"strong",sup:"sup",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.p,{children:"Jan turns computers into thinking machines."}),"\n",(0,i.jsx)(n.p,{children:"Jan is created and maintained by Jan Labs, a robotics company."}),"\n",(0,i.jsx)(n.p,{children:"With Jan, you can:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["Run ",(0,i.jsx)(n.a,{href:"https://huggingface.co/models?pipeline_tag=text-generation",children:"open-source LLMs"})," locally or connect to cloud AIs like ",(0,i.jsx)(n.a,{href:"https://openai.com/blog/openai-api",children:"ChatGPT"})," or ",(0,i.jsx)(n.a,{href:"https://ai.google.dev/",children:"Google"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Fine-tune AI with specific knowledge."}),"\n",(0,i.jsx)(n.li,{children:"Supercharge your productivity by leveraging AI."}),"\n",(0,i.jsx)(n.li,{children:"Search the web and databases."}),"\n",(0,i.jsx)(n.li,{children:"Integrate AI with everyday tools to work on your behalf (with permission)."}),"\n",(0,i.jsx)(n.li,{children:"Customize and add features with Extensions."}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsx)(n.p,{children:"Jan aims for long-term human-robot collaboration, envisioning AI as a harmonious extension of human capabilities. Our goal is to build customizable robots that we continually improve and customize, growing together."})}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Human repairing a Droid",src:t(69681).A+"",width:"1441",height:"812"})}),"\n",(0,i.jsx)(n.h2,{id:"jans-principles",children:"Jan\u2019s principles"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Ownership"}),": Jan is committed to developing a product that fully belongs to users. You're the true owner, free from data tracking and storage by us."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Privacy"}),": Jan works locally by default, allowing use without an internet connection. Your data stays on your device in a universal format, giving you complete privacy control."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"100% User Supported"}),": Every user can access, develop, and customize Jan's codebases to suit their needs."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.strong,{children:"Rejecting Dark Patterns"}),": We never use tricks to extract more money or lock you into an ecosystem."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"why-do-we-exist",children:"Why do we exist?"}),"\n",(0,i.jsxs)(n.blockquote,{children:["\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.em,{children:'"I do not fear computers. I fear the lack of them." - Isaac Asimov'})}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:"Jan was founded on the belief that AI should coexist with humans, not replace them. Our mission is to democratize AI access, ensuring everyone can easily utilize it with full ownership and control over their data, free from privacy concerns."}),"\n",(0,i.jsx)(n.h3,{id:"what-are-the-things-jan-committed-on",children:"What are the things Jan committed on?"}),"\n",(0,i.jsx)(n.p,{children:"We are committed to creating open, local-first products that extend individual freedom, rejecting dark patterns and ecosystem lock-ins, and embracing an open-source ethos."}),"\n",(0,i.jsx)(n.h4,{id:"whats-different-about-it",children:"What's different about it?"}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{}),(0,i.jsx)(n.th,{children:"Status Quo"}),(0,i.jsx)(n.th,{children:"Jan"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Ownership"})}),(0,i.jsx)(n.td,{children:"Owned by Big Tech"}),(0,i.jsx)(n.td,{children:"Fully owned by you"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Openness"})}),(0,i.jsx)(n.td,{children:"Closed-source"}),(0,i.jsx)(n.td,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/main/LICENSE",children:"Open-source (AGPLv3)"})})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Your Role"})}),(0,i.jsx)(n.td,{children:"Consumer"}),(0,i.jsx)(n.td,{children:"Creator"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Approach"})}),(0,i.jsx)(n.td,{children:"Cloud-based"}),(0,i.jsx)(n.td,{children:(0,i.jsx)(n.a,{href:"https://www.inkandswitch.com/local-first/",children:"Local-first"})})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Data Handling"})}),(0,i.jsx)(n.td,{children:"Stored on external servers"}),(0,i.jsx)(n.td,{children:"Stored locally, openly accessible"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Privacy"})}),(0,i.jsx)(n.td,{children:"Questionable"}),(0,i.jsx)(n.td,{children:"Private and offline"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Transparency"})}),(0,i.jsx)(n.td,{children:'Opaque "Black Box"'}),(0,i.jsx)(n.td,{children:"Open-source and customizable"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Outage Resilience"})}),(0,i.jsx)(n.td,{children:"Potential data hostage"}),(0,i.jsx)(n.td,{children:"Continues to work on your device"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:(0,i.jsx)(n.strong,{children:"Philosophy"})}),(0,i.jsx)(n.td,{children:"User monetization"}),(0,i.jsx)(n.td,{children:"Empowerment with the right to repair"})]})]})]}),"\n",(0,i.jsx)(n.h2,{id:"how-we-work",children:"How we work"}),"\n",(0,i.jsx)(n.p,{children:"Jan is an open-source product with transparent development and future features. Users have the right to modify and customize Jan. We are committed to building an open-source AI ecosystem."}),"\n",(0,i.jsxs)(n.p,{children:["Jan is building in public using GitHub, where anyone is welcome to join. Key resources include Jan's ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/7",children:"Kanban"})," and Jan's ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/29",children:"Roadmap"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["Jan has a fully-remote team, primarily based in the APAC timezone, and we use Discord and GitHub for collaboration. Our community is central to our operations, and we embrace asynchronous work. We hold meetings only for synchronization and vision sharing, using ",(0,i.jsx)(n.a,{href:"https://excalidraw.com/",children:"Excalidraw"})," or ",(0,i.jsx)(n.a,{href:"https://miro.com/",children:"Miro"})," for visualization and sharing notes on Discord for alignment. We also use ",(0,i.jsx)(n.a,{href:"https://hackmd.io/",children:"HackMD"})," to document our ideas and build a Jan library."]}),"\n",(0,i.jsx)(n.h2,{id:"how-to-get-it",children:"How to get it?"}),"\n",(0,i.jsxs)(n.p,{children:["You can install and start using Jan in less than 5 minutes, from ",(0,i.jsx)(n.a,{href:"https://jan.ai",children:"Jan.ai"})," or our ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Github repo"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"what-license-is-the-code-under",children:"What license is the code under?"}),"\n",(0,i.jsxs)(n.p,{children:["Jan is licensed under the ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/blob/main/LICENSE",children:"AGPLv3 License"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["We happily accept pull requests, however, we do ask that you sign a ",(0,i.jsx)(n.a,{href:"https://en.wikipedia.org/wiki/Contributor_License_Agreement",children:"Contributor License Agreement"})," so that we have the right to relicense your contributions",(0,i.jsx)(n.sup,{children:(0,i.jsx)(n.a,{href:"#user-content-fn-2",id:"user-content-fnref-2","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"1"})}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"what-was-it-built-with",children:"What was it built with?"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Jan"})," is pragmatically built using ",(0,i.jsx)(n.code,{children:"Typescript"})," at the application level and ",(0,i.jsx)(n.code,{children:"C++"})," at the Inference level (which we have refactored into ",(0,i.jsx)(n.a,{href:"https://nitro.jan.ai",children:"Nitro"}),(0,i.jsx)(n.sup,{children:(0,i.jsx)(n.a,{href:"#user-content-fn-3",id:"user-content-fnref-3","data-footnote-ref":!0,"aria-describedby":"footnote-label",children:"2"})}),")."]}),"\n",(0,i.jsxs)(n.p,{children:["We follow ",(0,i.jsx)(n.a,{href:"https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html",children:"clean architecture"})," and currently support multiple frameworks and runtimes:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["A desktop client with ",(0,i.jsx)(n.a,{href:"https://www.electronjs.org/",children:"Electron"})]}),"\n",(0,i.jsxs)(n.li,{children:["A headless server-mode with ",(0,i.jsx)(n.a,{href:"https://nodejs.org/en",children:"Nodejs"})]}),"\n",(0,i.jsxs)(n.li,{children:["Planned support for mobile with ",(0,i.jsx)(n.a,{href:"https://capacitorjs.com/",children:"Capacitor"})]}),"\n",(0,i.jsx)(n.li,{children:"Planned support for Python runtime"}),"\n"]}),"\n",(0,i.jsxs)(n.p,{children:["Architecturally, we have made similar choices to the ",(0,i.jsx)(n.a,{href:"https://vercel.com/templates/next.js/nextjs-enterprise-boilerplate",children:"Next.js Enterprise Javascript Stack"}),", which is a ",(0,i.jsx)(n.a,{href:"https://nextjs.org/showcase/enterprise",children:"battle-tested"})," framework for building enterprise-grade applications that scale."]}),"\n",(0,i.jsx)(n.h2,{id:"join-the-team",children:"Join the team"}),"\n",(0,i.jsxs)(n.p,{children:["Join us on this journey at Jan Labs, where we embrace open-source collaboration and transparency. Together, let's shape a future where Jan becomes an essential companion in the open-source community. Explore ",(0,i.jsx)(n.a,{href:"https://janai.bamboohr.com/careers",children:"careers"})," with us."]}),"\n",(0,i.jsx)(n.h2,{id:"contact",children:"Contact"}),"\n",(0,i.jsxs)(n.p,{children:["Drop us a message in our ",(0,i.jsx)(n.a,{href:"https://discord.gg/af6SaTdzpx",children:"Discord"})," and we'll get back to you."]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"#general"}),": for general discussion"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"#get-help"}),": for bug reports and troubleshooting"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"#roadmap"}),": for feature requests and ideas"]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"footnotes",children:"Footnotes"}),"\n",(0,i.jsxs)(n.section,{"data-footnotes":!0,className:"footnotes",children:[(0,i.jsx)(n.h2,{className:"sr-only",id:"footnote-label",children:"Footnotes"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{id:"user-content-fn-2",children:["\n",(0,i.jsxs)(n.p,{children:["Credit to ",(0,i.jsx)(n.a,{href:"https://www.discourse.org/about",children:"Discourse's About Page"})," ",(0,i.jsx)(n.a,{href:"#user-content-fnref-2","data-footnote-backref":"","aria-label":"Back to reference 1",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n",(0,i.jsxs)(n.li,{id:"user-content-fn-3",children:["\n",(0,i.jsxs)(n.p,{children:["Credit to ",(0,i.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp",children:"Llama.cpp"}),", ",(0,i.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM",children:"TensorRT-LLM"}),", ",(0,i.jsx)(n.a,{href:"https://github.com/vllm-project/vllm",children:"vLLM"}),", ",(0,i.jsx)(n.a,{href:"https://github.com/InternLM/lmdeploy",children:"LMDeploy"})," and more. ",(0,i.jsx)(n.a,{href:"#user-content-fnref-3","data-footnote-backref":"","aria-label":"Back to reference 2",className:"data-footnote-backref",children:"\u21a9"})]}),"\n"]}),"\n"]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(d,{...e})}):d(e)}},69681:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/star-wars-droids-776530079e5c0b4ebad027378f5dd1f3.png"},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>a});var i=t(96540);const s={},r=i.createContext(s);function o(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d05ec3cd.414dc534.js b/assets/js/d05ec3cd.414dc534.js deleted file mode 100644 index 68e9fc33..00000000 --- a/assets/js/d05ec3cd.414dc534.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8538],{77861:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>c,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>r,toc:()=>u});var n=s(74848),o=s(28453);const a={title:"AI PC",tags:["use-cases"]},i=void 0,r={id:"solutions/ai-pc",title:"AI PC",description:"",source:"@site/docs/solutions/ai-pc.md",sourceDirName:"solutions",slug:"/solutions/ai-pc",permalink:"/solutions/ai-pc",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/ai-pc.md",tags:[{label:"use-cases",permalink:"/tags/use-cases"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"AI PC",tags:["use-cases"]},sidebar:"solutionSidebar",next:{title:"Self-hosted alternative to OpenAI's Platform",permalink:"/solutions/chatgpt-alternative"}},c={},u=[];function l(t){return(0,n.jsx)(n.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(l,{...t})}):l()}},28453:(t,e,s)=>{s.d(e,{R:()=>i,x:()=>r});var n=s(96540);const o={},a=n.createContext(o);function i(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function r(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:i(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/d05ec3cd.7fe918f2.js b/assets/js/d05ec3cd.7fe918f2.js new file mode 100644 index 00000000..a9ea6f0d --- /dev/null +++ b/assets/js/d05ec3cd.7fe918f2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8538],{77861:(t,e,s)=>{s.r(e),s.d(e,{assets:()=>c,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>r,toc:()=>u});var n=s(74848),o=s(28453);const a={title:"AI PC",tags:["use-cases"]},i=void 0,r={id:"solutions/ai-pc",title:"AI PC",description:"",source:"@site/docs/solutions/ai-pc.md",sourceDirName:"solutions",slug:"/solutions/ai-pc",permalink:"/solutions/ai-pc",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/ai-pc.md",tags:[{label:"use-cases",permalink:"/tags/use-cases"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"AI PC",tags:["use-cases"]},sidebar:"solutionSidebar",next:{title:"Self-hosted alternative to OpenAI's Platform",permalink:"/solutions/chatgpt-alternative"}},c={},u=[];function l(t){return(0,n.jsx)(n.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,n.jsx)(e,{...t,children:(0,n.jsx)(l,{...t})}):l()}},28453:(t,e,s)=>{s.d(e,{R:()=>i,x:()=>r});var n=s(96540);const o={},a=n.createContext(o);function i(t){const e=n.useContext(a);return n.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function r(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:i(t.components),n.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/d1a98e8c.25f28e4d.js b/assets/js/d1a98e8c.25f28e4d.js new file mode 100644 index 00000000..23d77db4 --- /dev/null +++ b/assets/js/d1a98e8c.25f28e4d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5250],{71520:(e,r,n)=>{n.r(r),n.d(r,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var s=n(74848),t=n(28453);const o={title:"Jan Home Server",slug:"/home-server",description:"Built for Home Servers",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i="Customize and run AI across all of your devices",a={id:"server-suite/home-server",title:"Jan Home Server",description:"Built for Home Servers",source:"@site/docs/server-suite/home-server.md",sourceDirName:"server-suite",slug:"/home-server",permalink:"/home-server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/home-server.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan Home Server",slug:"/home-server",description:"Built for Home Servers",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"productSidebar",previous:{title:"Jan Desktop",permalink:"/desktop"},next:{title:"Features",permalink:"/features/"}},l={},c=[{value:"Why Home Servers",id:"why-home-servers",level:2}];function d(e){const r={a:"a",admonition:"admonition",h1:"h1",h2:"h2",li:"li",p:"p",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(r.h1,{id:"customize-and-run-ai-across-all-of-your-devices",children:"Customize and run AI across all of your devices"}),"\n",(0,s.jsx)(r.p,{children:"Self-host and access your AI from anywhere with Jan server suite."}),"\n",(0,s.jsxs)(r.admonition,{type:"warning",children:[(0,s.jsxs)(r.p,{children:["Jan's server suite is actively under development and lacking documentation.\nYou can find the source code ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/jan/tree/dev/server",children:"here"})," and ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/jan/blob/dev/docker-compose.yml",children:"here"}),"."]}),(0,s.jsx)(r.p,{children:"It is free to use. Your feedback is appreciated \ud83d\ude4f."})]}),"\n",(0,s.jsx)(r.h2,{id:"why-home-servers",children:"Why Home Servers"}),"\n",(0,s.jsxs)(r.p,{children:["We built ",(0,s.jsx)(r.a,{href:"/desktop",children:"Jan Desktop"})," for our personal use. We're now building Server Suite, for our team & community use."]}),"\n",(0,s.jsx)(r.p,{children:"Our goal is to help teams, like ours, move past cobbling together demo apps to use AI at work. We should be able to customize and collaborate with AIs that are usable on a daily basis."}),"\n",(0,s.jsx)(r.p,{children:(0,s.jsxs)(r.strong,{children:["Check out ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/jan/tree/dev/server",children:"Server Suite"})," if you need to:"]})}),"\n",(0,s.jsxs)(r.ul,{children:["\n",(0,s.jsx)(r.li,{children:"Self-host Jan, with multi client sync"}),"\n",(0,s.jsx)(r.li,{children:"Customize it with Personal Data Connectors"}),"\n",(0,s.jsx)(r.li,{children:"Simple Authentication (username / pw)"}),"\n",(0,s.jsx)(r.li,{children:"Scales across Consumer-grade Hardware, including GPUs"}),"\n",(0,s.jsx)(r.li,{children:"Everyone has admin level visibility and can see all conversations"}),"\n",(0,s.jsx)(r.li,{children:"Create assistants that has access to the same knowledge base"}),"\n"]}),"\n",(0,s.jsx)(r.admonition,{type:"tip",children:(0,s.jsxs)(r.p,{children:["Not a Jan fan but convinced about running AI locally? No worries, here's a list of ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/awesome-local-ai",children:"awesome local ai"})," alternatives that you can use in your home server."]})})]})}function u(e={}){const{wrapper:r}={...(0,t.R)(),...e.components};return r?(0,s.jsx)(r,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28453:(e,r,n)=>{n.d(r,{R:()=>i,x:()=>a});var s=n(96540);const t={},o=s.createContext(t);function i(e){const r=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(r):{...r,...e}}),[r,e])}function a(e){let r;return r=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:i(e.components),s.createElement(o.Provider,{value:r},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d1a98e8c.dbf9ad3c.js b/assets/js/d1a98e8c.dbf9ad3c.js deleted file mode 100644 index 2935930d..00000000 --- a/assets/js/d1a98e8c.dbf9ad3c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5250],{71520:(e,r,n)=>{n.r(r),n.d(r,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var s=n(74848),t=n(28453);const o={title:"Jan Home Server",slug:"/home-server",description:"Built for Home Servers",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i="Customize and run AI across all of your devices",a={id:"server-suite/home-server",title:"Jan Home Server",description:"Built for Home Servers",source:"@site/docs/server-suite/home-server.md",sourceDirName:"server-suite",slug:"/home-server",permalink:"/home-server",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/home-server.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan Home Server",slug:"/home-server",description:"Built for Home Servers",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"productSidebar",previous:{title:"Jan Desktop",permalink:"/desktop"},next:{title:"Features",permalink:"/features/"}},l={},c=[{value:"Why Home Servers",id:"why-home-servers",level:2}];function d(e){const r={a:"a",admonition:"admonition",h1:"h1",h2:"h2",li:"li",p:"p",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(r.h1,{id:"customize-and-run-ai-across-all-of-your-devices",children:"Customize and run AI across all of your devices"}),"\n",(0,s.jsx)(r.p,{children:"Self-host and access your AI from anywhere with Jan server suite."}),"\n",(0,s.jsxs)(r.admonition,{type:"warning",children:[(0,s.jsxs)(r.p,{children:["Jan's server suite is actively under development and lacking documentation.\nYou can find the source code ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/jan/tree/dev/server",children:"here"})," and ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/jan/blob/dev/docker-compose.yml",children:"here"}),"."]}),(0,s.jsx)(r.p,{children:"It is free to use. Your feedback is appreciated \ud83d\ude4f."})]}),"\n",(0,s.jsx)(r.h2,{id:"why-home-servers",children:"Why Home Servers"}),"\n",(0,s.jsxs)(r.p,{children:["We built ",(0,s.jsx)(r.a,{href:"/desktop",children:"Jan Desktop"})," for our personal use. We're now building Server Suite, for our team & community use."]}),"\n",(0,s.jsx)(r.p,{children:"Our goal is to help teams, like ours, move past cobbling together demo apps to use AI at work. We should be able to customize and collaborate with AIs that are usable on a daily basis."}),"\n",(0,s.jsx)(r.p,{children:(0,s.jsxs)(r.strong,{children:["Check out ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/jan/tree/dev/server",children:"Server Suite"})," if you need to:"]})}),"\n",(0,s.jsxs)(r.ul,{children:["\n",(0,s.jsx)(r.li,{children:"Self-host Jan, with multi client sync"}),"\n",(0,s.jsx)(r.li,{children:"Customize it with Personal Data Connectors"}),"\n",(0,s.jsx)(r.li,{children:"Simple Authentication (username / pw)"}),"\n",(0,s.jsx)(r.li,{children:"Scales across Consumer-grade Hardware, including GPUs"}),"\n",(0,s.jsx)(r.li,{children:"Everyone has admin level visibility and can see all conversations"}),"\n",(0,s.jsx)(r.li,{children:"Create assistants that has access to the same knowledge base"}),"\n"]}),"\n",(0,s.jsx)(r.admonition,{type:"tip",children:(0,s.jsxs)(r.p,{children:["Not a Jan fan but convinced about running AI locally? No worries, here's a list of ",(0,s.jsx)(r.a,{href:"https://github.com/janhq/awesome-local-ai",children:"awesome local ai"})," alternatives that you can use in your home server."]})})]})}function u(e={}){const{wrapper:r}={...(0,t.R)(),...e.components};return r?(0,s.jsx)(r,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28453:(e,r,n)=>{n.d(r,{R:()=>i,x:()=>a});var s=n(96540);const t={},o=s.createContext(t);function i(e){const r=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(r):{...r,...e}}),[r,e])}function a(e){let r;return r=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:i(e.components),s.createElement(o.Provider,{value:r},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d63d6a03.c8d9407d.js b/assets/js/d63d6a03.c8d9407d.js new file mode 100644 index 00000000..51daedd0 --- /dev/null +++ b/assets/js/d63d6a03.c8d9407d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7435],{81149:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>l,frontMatter:()=>o,metadata:()=>u,toc:()=>i});var n=r(74848),s=r(28453);const o={title:"Features"},a=void 0,u={id:"features/features",title:"Features",description:"",source:"@site/docs/features/features.md",sourceDirName:"features",slug:"/features/",permalink:"/features/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/features.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Features"},sidebar:"productSidebar",previous:{title:"Jan Home Server",permalink:"/home-server"},next:{title:"Local & Self-Hosted AI",permalink:"/features/local"}},c={},i=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function l(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>a,x:()=>u});var n=r(96540);const s={},o=n.createContext(s);function a(e){const t=n.useContext(o);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function u(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),n.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d63d6a03.ffc19d17.js b/assets/js/d63d6a03.ffc19d17.js deleted file mode 100644 index aea05c7c..00000000 --- a/assets/js/d63d6a03.ffc19d17.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7435],{81149:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>l,frontMatter:()=>a,metadata:()=>u,toc:()=>i});var n=r(74848),s=r(28453);const a={title:"Features"},o=void 0,u={id:"features/features",title:"Features",description:"",source:"@site/docs/features/features.md",sourceDirName:"features",slug:"/features/",permalink:"/features/",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/features.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Features"},sidebar:"productSidebar",previous:{title:"Jan Home Server",permalink:"/home-server"},next:{title:"Local & Self-Hosted AI",permalink:"/features/local"}},c={},i=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function l(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>o,x:()=>u});var n=r(96540);const s={},a=n.createContext(s);function o(e){const t=n.useContext(a);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function u(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),n.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d6d14160.4a5fa5bd.js b/assets/js/d6d14160.4a5fa5bd.js deleted file mode 100644 index abca6025..00000000 --- a/assets/js/d6d14160.4a5fa5bd.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[747],{38270:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>x,frontMatter:()=>o,metadata:()=>d,toc:()=>h});var r=t(74848),s=t(28453),i=t(11470),l=t(19365);const o={title:"Advanced Settings",slug:"/guides/advanced",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:11,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Advanced Settings","HTTPS Proxy","SSL","settings","Jan settings"]},a=void 0,d={id:"guides/user-guides/advanced-settings",title:"Advanced Settings",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/advanced-settings.mdx",sourceDirName:"guides/user-guides",slug:"/guides/advanced",permalink:"/guides/advanced",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/advanced-settings.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:11,frontMatter:{title:"Advanced Settings",slug:"/guides/advanced",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:11,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Advanced Settings","HTTPS Proxy","SSL","settings","Jan settings"]},sidebar:"guidesSidebar",previous:{title:"Local API Server",permalink:"/guides/local-api"},next:{title:"Local Engines",permalink:"/guides/engines/local"}},c={},h=[{value:"Access the Advanced Settings",id:"access-the-advanced-settings",level:2},{value:"Keyboard Shortcuts",id:"keyboard-shortcuts",level:2},{value:"Enable the Experimental Mode",id:"enable-the-experimental-mode",level:2},{value:"Enable the GPU Acceleration",id:"enable-the-gpu-acceleration",level:2},{value:"Access the Jan Data Folder",id:"access-the-jan-data-folder",level:2},{value:"HTTPS Proxy",id:"https-proxy",level:2},{value:"Setting Up Your Own HTTPS Proxy Server",id:"setting-up-your-own-https-proxy-server",level:3},{value:"Step 1: Choosing a Server",id:"step-1-choosing-a-server",level:4},{value:"Step 2: Installing Squid",id:"step-2-installing-squid",level:4},{value:"Step 3: Configure Squid for HTTPS",id:"step-3-configure-squid-for-https",level:4},{value:"Step 4 (Optional): Configure ACLs and Authentication",id:"step-4-optional-configure-acls-and-authentication",level:4},{value:"Step 5: Restart and Test Your Proxy",id:"step-5-restart-and-test-your-proxy",level:4},{value:"Setting Up Jan to Use Your HTTPS Proxy",id:"setting-up-jan-to-use-your-https-proxy",level:3},{value:"Ignore SSL Certificate",id:"ignore-ssl-certificate",level:2},{value:"Clear Logs",id:"clear-logs",level:2},{value:"Reset To Factory Default",id:"reset-to-factory-default",level:2}];function u(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.p,{children:"This guide will show you how to use the advanced settings in Jan."}),"\n",(0,r.jsx)(n.h2,{id:"access-the-advanced-settings",children:"Access the Advanced Settings"}),"\n",(0,r.jsx)(n.p,{children:"To access the Jan's advanced settings, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsx)(n.li,{children:"You can configure the following settings:"}),"\n"]}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Feature"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Keyboard Shortcuts"})}),(0,r.jsxs)(n.td,{children:["Keyboard shortcuts speed up your workflow. For a quick overview of useful keyboard shortcuts, refer to the list ",(0,r.jsx)(n.a,{href:"/guides/advanced#keyboard-shortcuts",children:"below"}),"."]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Experimental Mode"})}),(0,r.jsx)(n.td,{children:"Enables experimental features that may be unstable."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"GPU Acceleration"})}),(0,r.jsx)(n.td,{children:"Enables the boosting of your model performance by using your GPU devices for acceleration."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Jan Data Folder"})}),(0,r.jsx)(n.td,{children:"Location for messages, model configurations, and user data. Changeable to a different location."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"HTTPS Proxy & Ignore SSL Certificate"})}),(0,r.jsxs)(n.td,{children:["Use a proxy server for internet connections and ignore SSL certificates for self-signed certificates. Please check out the guide on how to set up your own HTTPS proxy server ",(0,r.jsx)(n.a,{href:"/guides/advanced#https-proxy",children:"here"}),"."]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Clear Logs"})}),(0,r.jsx)(n.td,{children:"Removes all logs from the Jan application."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Reset To Factory Default"})}),(0,r.jsx)(n.td,{children:"Resets the application to its original state, deleting all data including model customizations and conversation history."})]})]})]}),"\n",(0,r.jsx)(n.h2,{id:"keyboard-shortcuts",children:"Keyboard Shortcuts"}),"\n",(0,r.jsx)(n.p,{children:"Here are some of the keyboard shortcuts that you can use in Jan."}),"\n",(0,r.jsxs)(i.A,{children:[(0,r.jsx)(l.A,{value:"mac",label:"Mac",default:!0,children:(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Combination"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 E"})}),(0,r.jsx)(n.td,{children:"Show list your models"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 K"})}),(0,r.jsx)(n.td,{children:"Show list navigation pages"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 B"})}),(0,r.jsx)(n.td,{children:"Toggle collapsible left panel"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 ,"})}),(0,r.jsx)(n.td,{children:"Navigate to setting page"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Enter"})}),(0,r.jsx)(n.td,{children:"Send a message"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Shift + Enter"})}),(0,r.jsx)(n.td,{children:"Insert new line in input box"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Up"})}),(0,r.jsx)(n.td,{children:"Navigate to the previous option (within the search dialog)"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Down"})}),(0,r.jsx)(n.td,{children:"Navigate to the next option (within the search dialog)"})]})]})]})}),(0,r.jsx)(l.A,{value:"windows",label:"Windows",default:!0,children:(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Combination"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl E"})}),(0,r.jsx)(n.td,{children:"Show list your models"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl K"})}),(0,r.jsx)(n.td,{children:"Show list navigation pages"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl B"})}),(0,r.jsx)(n.td,{children:"Toggle collapsible left panel"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl ,"})}),(0,r.jsx)(n.td,{children:"Navigate to setting page"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Enter"})}),(0,r.jsx)(n.td,{children:"Send a message"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Shift + Enter"})}),(0,r.jsx)(n.td,{children:"Insert new line in input box"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Up"})}),(0,r.jsx)(n.td,{children:"Navigate to the previous option (within the search dialog)"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Down"})}),(0,r.jsx)(n.td,{children:"Navigate to the next option (within the search dialog)"})]})]})]})}),(0,r.jsx)(l.A,{value:"linux",label:"Linux",default:!0,children:(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Combination"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl E"})}),(0,r.jsx)(n.td,{children:"Show list your models"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl K"})}),(0,r.jsx)(n.td,{children:"Show list navigation pages"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl B"})}),(0,r.jsx)(n.td,{children:"Toggle collapsible left panel"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl ,"})}),(0,r.jsx)(n.td,{children:"Navigate to setting page"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Enter"})}),(0,r.jsx)(n.td,{children:"Send a message"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Shift + Enter"})}),(0,r.jsx)(n.td,{children:"Insert new line in input box"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Up"})}),(0,r.jsx)(n.td,{children:"Navigate to the previous option (within the search dialog)"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Down"})}),(0,r.jsx)(n.td,{children:"Navigate to the next option (within the search dialog)"})]})]})]})})]}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"The keyboard shortcuts are customizable."})}),"\n",(0,r.jsx)(n.h2,{id:"enable-the-experimental-mode",children:"Enable the Experimental Mode"}),"\n",(0,r.jsx)(n.p,{children:"To try out new fetures that are still in testing phase, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Experimental Mode"})," click the slider to enable."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"enable-the-gpu-acceleration",children:"Enable the GPU Acceleration"}),"\n",(0,r.jsx)(n.p,{children:"To enhance your model performance, follow the steps below:"}),"\n",(0,r.jsx)(n.admonition,{type:"warning",children:(0,r.jsxs)(n.p,{children:["Ensure that you have read the ",(0,r.jsx)(n.a,{href:"/troubleshooting/#troubleshooting-nvidia-gpu",children:"troubleshooting guide"})," here for further assistance."]})}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"GPU Acceleration"})," click the slider to enable."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"access-the-jan-data-folder",children:"Access the Jan Data Folder"}),"\n",(0,r.jsx)(n.p,{children:"To access the folder where messages, model configurations and user data are stored, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Jan Data Folder"})," click the ",(0,r.jsx)(n.strong,{children:"folder icon (\ud83d\udcc2)"})," to access the data or the ",(0,r.jsx)(n.strong,{children:"pencil icon (\u270f\ufe0f)"})," to change the folder where you keep your data."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"https-proxy",children:"HTTPS Proxy"}),"\n",(0,r.jsx)(n.p,{children:"HTTPS Proxy encrypts data between your browser and the internet, making it hard for outsiders to intercept or read. It also helps you to maintain your privacy and security while being able to bypass regional restrictions on internet."}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"When configuring Jan using an HTTPS proxy, the speed of the downloading model may be affected due to the encryption and decryption process. It also depends on the networking of the cloud service provider."}),"\n",(0,r.jsx)(n.li,{children:"HTTPS Proxy does not affect the remote model usage."}),"\n"]})}),"\n",(0,r.jsx)(n.h3,{id:"setting-up-your-own-https-proxy-server",children:"Setting Up Your Own HTTPS Proxy Server"}),"\n",(0,r.jsxs)(n.p,{children:["This guide provides a simple overview of setting up an HTTPS proxy server using ",(0,r.jsx)(n.strong,{children:"Squid"}),", a widely used open-source proxy software."]}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"Other software options are also available depending on your requirements."})}),"\n",(0,r.jsx)(n.h4,{id:"step-1-choosing-a-server",children:"Step 1: Choosing a Server"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:["\n",(0,r.jsx)(n.p,{children:"Firstly, you need to choose a server to host your proxy server."}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"We recommend using a well-known cloud provider service like:"})}),"\n"]}),"\n"]}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Amazon AWS"}),"\n",(0,r.jsx)(n.li,{children:"Google Cloud"}),"\n",(0,r.jsx)(n.li,{children:"Microsoft Azure"}),"\n",(0,r.jsx)(n.li,{children:"Digital Ocean\n:::"}),"\n"]}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsx)(n.li,{children:"Ensure that your server has a public IP address and is accessible from the internet."}),"\n"]}),"\n",(0,r.jsx)(n.h4,{id:"step-2-installing-squid",children:"Step 2: Installing Squid"}),"\n",(0,r.jsxs)(n.p,{children:["Instal ",(0,r.jsx)(n.strong,{children:"Squid"})," using the following command:"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"sudo apt-get update\nsudo apt-get install squid\n"})}),"\n",(0,r.jsx)(n.h4,{id:"step-3-configure-squid-for-https",children:"Step 3: Configure Squid for HTTPS"}),"\n",(0,r.jsx)(n.p,{children:"To enable HTTPS, you will need to configure Squid with SSL support."}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Squid requires an SSL certificate to be able to handle HTTPS traffic. You can generate a self-signed certificate or obtain one from a Certificate Authority (CA). For a self-signed certificate, you can use OpenSSL:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"openssl req -new -newkey rsa:2048 -days 365 -nodes -x509 -keyout squid-proxy.pem -out squid-proxy.pem\n"})}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsxs)(n.li,{children:["Edit the Squid configuration file ",(0,r.jsx)(n.code,{children:"/etc/squid/squid.conf"})," to include the path to your SSL certificate and enable the HTTPS port:"]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"http_port 3128 ssl-bump cert=/path/to/your/squid-proxy.pem\nssl_bump server-first all\nssl_bump bump all\n"})}),"\n",(0,r.jsxs)(n.ol,{start:"3",children:["\n",(0,r.jsxs)(n.li,{children:["To intercept HTTPS traffic, Squid uses a process called SSL Bumping. This process allows Squid to decrypt and re-encrypt HTTPS traffic. To enable SSL Bumping, ensure the ",(0,r.jsx)(n.code,{children:"ssl_bump"})," directives are configured correctly in your ",(0,r.jsx)(n.code,{children:"squid.conf"})," file."]}),"\n"]}),"\n",(0,r.jsx)(n.h4,{id:"step-4-optional-configure-acls-and-authentication",children:"Step 4 (Optional): Configure ACLs and Authentication"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"You can define rules to control who can access your proxy. This is done by editing the squid.conf file and defining ACLs:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:'acl allowed_ips src "/etc/squid/allowed_ips.txt"\nhttp_access allow allowed_ips\n'})}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsx)(n.li,{children:"If you want to add an authentication layer, Squid supports several authentication schemes. Basic authentication setup might look like this:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"auth_param basic program /usr/lib/squid/basic_ncsa_auth /etc/squid/passwords\nacl authenticated proxy_auth REQUIRED\nhttp_access allow authenticated\n"})}),"\n",(0,r.jsx)(n.h4,{id:"step-5-restart-and-test-your-proxy",children:"Step 5: Restart and Test Your Proxy"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"After configuring, restart Squid to apply the changes:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"sudo systemctl restart squid\n"})}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsx)(n.li,{children:"To test, configure your browser or another client to use the proxy server with its IP address and port (default is 3128)."}),"\n",(0,r.jsx)(n.li,{children:"Check if you can access the internet through your proxy."}),"\n"]}),"\n",(0,r.jsxs)(n.admonition,{type:"tip",children:[(0,r.jsx)(n.p,{children:"Tips for Secure Your Proxy:"}),(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Firewall rules"}),": Ensure that only intended users or IP addresses can connect to your proxy server. This can be achieved by setting up appropriate firewall rules."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Regular updates"}),": Keep your server and proxy software updated to ensure that you are protected against known vulnerabilities."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Monitoring and logging"}),": Monitor your proxy server for unusual activity and enable logging to keep track of the traffic passing through your proxy."]}),"\n"]})]}),"\n",(0,r.jsx)(n.h3,{id:"setting-up-jan-to-use-your-https-proxy",children:"Setting Up Jan to Use Your HTTPS Proxy"}),"\n",(0,r.jsx)(n.p,{children:"Once you have your HTTPS proxy server set up, you can configure Jan to use it."}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:["Navigate to ",(0,r.jsx)(n.strong,{children:"Settings"})," > ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"HTTPS Proxy"})," click the slider to enable."]}),"\n",(0,r.jsx)(n.li,{children:"Input your domain in the blank field."}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"ignore-ssl-certificate",children:"Ignore SSL Certificate"}),"\n",(0,r.jsx)(n.p,{children:"To Allow self-signed or unverified certificates, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Ignore SSL Certificates"})," click the slider to enable."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"clear-logs",children:"Clear Logs"}),"\n",(0,r.jsx)(n.p,{children:"To clear all logs on your Jan app, follow the steps below:"}),"\n",(0,r.jsx)(n.admonition,{type:"warning",children:(0,r.jsxs)(n.p,{children:["This feature clears all the data in your ",(0,r.jsx)(n.strong,{children:"Jan Data Folder"}),"."]})}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Clear Logs"})," click the the ",(0,r.jsx)(n.strong,{children:"Clear"})," button."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"reset-to-factory-default",children:"Reset To Factory Default"}),"\n",(0,r.jsx)(n.p,{children:"To reset the Jan app to its original state, follow the steps below:"}),"\n",(0,r.jsx)(n.admonition,{title:"Remember!",type:"danger",children:(0,r.jsx)(n.p,{children:"This irreversible action is only recommended if the application is corrupted."})}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Reset To Factory Default"})," click the the ",(0,r.jsx)(n.strong,{children:"Reset"})," button."]}),"\n"]})]})}function x(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>l});t(96540);var r=t(18215);const s={tabItem:"tabItem_Ymn6"};var i=t(74848);function l(e){let{children:n,hidden:t,className:l}=e;return(0,i.jsx)("div",{role:"tabpanel",className:(0,r.A)(s.tabItem,l),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>S});var r=t(96540),s=t(18215),i=t(23104),l=t(56347),o=t(205),a=t(57485),d=t(31682),c=t(89466);function h(e){return r.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function u(e){const{values:n,children:t}=e;return(0,r.useMemo)((()=>{const e=n??function(e){return h(e).map((e=>{let{props:{value:n,label:t,attributes:r,default:s}}=e;return{value:n,label:t,attributes:r,default:s}}))}(t);return function(e){const n=(0,d.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function x(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function j(e){let{queryString:n=!1,groupId:t}=e;const s=(0,l.W6)(),i=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,a.aZ)(i),(0,r.useCallback)((e=>{if(!i)return;const n=new URLSearchParams(s.location.search);n.set(i,e),s.replace({...s.location,search:n.toString()})}),[i,s])]}function p(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,i=u(e),[l,a]=(0,r.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!x({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const r=t.find((e=>e.default))??t[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:n,tabValues:i}))),[d,h]=j({queryString:t,groupId:s}),[p,g]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,i]=(0,c.Dv)(t);return[s,(0,r.useCallback)((e=>{t&&i.set(e)}),[t,i])]}({groupId:s}),f=(()=>{const e=d??p;return x({value:e,tabValues:i})?e:null})();(0,o.A)((()=>{f&&a(f)}),[f]);return{selectedValue:l,selectValue:(0,r.useCallback)((e=>{if(!x({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);a(e),h(e),g(e)}),[h,g,i]),tabValues:i}}var g=t(92303);const f={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var b=t(74848);function v(e){let{className:n,block:t,selectedValue:r,selectValue:l,tabValues:o}=e;const a=[],{blockElementScrollPositionUntilNextRender:d}=(0,i.a_)(),c=e=>{const n=e.currentTarget,t=a.indexOf(n),s=o[t].value;s!==r&&(d(n),l(s))},h=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const t=a.indexOf(e.currentTarget)+1;n=a[t]??a[0];break}case"ArrowLeft":{const t=a.indexOf(e.currentTarget)-1;n=a[t]??a[a.length-1];break}}n?.focus()};return(0,b.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:o.map((e=>{let{value:n,label:t,attributes:i}=e;return(0,b.jsx)("li",{role:"tab",tabIndex:r===n?0:-1,"aria-selected":r===n,ref:e=>a.push(e),onKeyDown:h,onClick:c,...i,className:(0,s.A)("tabs__item",f.tabItem,i?.className,{"tabs__item--active":r===n}),children:t??n},n)}))})}function y(e){let{lazy:n,children:t,selectedValue:s}=e;const i=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=i.find((e=>e.props.value===s));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return(0,b.jsx)("div",{className:"margin-top--md",children:i.map(((e,n)=>(0,r.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function m(e){const n=p(e);return(0,b.jsxs)("div",{className:(0,s.A)("tabs-container",f.tabList),children:[(0,b.jsx)(v,{...e,...n}),(0,b.jsx)(y,{...e,...n})]})}function S(e){const n=(0,g.A)();return(0,b.jsx)(m,{...e,children:h(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>l,x:()=>o});var r=t(96540);const s={},i=r.createContext(s);function l(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:l(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d6d14160.5c69bd52.js b/assets/js/d6d14160.5c69bd52.js new file mode 100644 index 00000000..6d9b52bc --- /dev/null +++ b/assets/js/d6d14160.5c69bd52.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[747],{38270:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>a,default:()=>x,frontMatter:()=>o,metadata:()=>d,toc:()=>h});var r=t(74848),s=t(28453),i=t(11470),l=t(19365);const o={title:"Advanced Settings",slug:"/guides/advanced",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Advanced Settings","HTTPS Proxy","SSL","settings","Jan settings"]},a=void 0,d={id:"guides/user-guides/advanced-settings",title:"Advanced Settings",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/user-guides/advanced-settings.mdx",sourceDirName:"guides/user-guides",slug:"/guides/advanced",permalink:"/guides/advanced",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/advanced-settings.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Advanced Settings",slug:"/guides/advanced",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Advanced Settings","HTTPS Proxy","SSL","settings","Jan settings"]},sidebar:"guidesSidebar",previous:{title:"Local API Server",permalink:"/guides/local-api"},next:{title:"Local Engines",permalink:"/guides/engines/local"}},c={},h=[{value:"Access the Advanced Settings",id:"access-the-advanced-settings",level:2},{value:"Keyboard Shortcuts",id:"keyboard-shortcuts",level:2},{value:"Enable the Experimental Mode",id:"enable-the-experimental-mode",level:2},{value:"Enable the GPU Acceleration",id:"enable-the-gpu-acceleration",level:2},{value:"Access the Jan Data Folder",id:"access-the-jan-data-folder",level:2},{value:"HTTPS Proxy",id:"https-proxy",level:2},{value:"Setting Up Your Own HTTPS Proxy Server",id:"setting-up-your-own-https-proxy-server",level:3},{value:"Step 1: Choosing a Server",id:"step-1-choosing-a-server",level:4},{value:"Step 2: Installing Squid",id:"step-2-installing-squid",level:4},{value:"Step 3: Configure Squid for HTTPS",id:"step-3-configure-squid-for-https",level:4},{value:"Step 4 (Optional): Configure ACLs and Authentication",id:"step-4-optional-configure-acls-and-authentication",level:4},{value:"Step 5: Restart and Test Your Proxy",id:"step-5-restart-and-test-your-proxy",level:4},{value:"Setting Up Jan to Use Your HTTPS Proxy",id:"setting-up-jan-to-use-your-https-proxy",level:3},{value:"Ignore SSL Certificate",id:"ignore-ssl-certificate",level:2},{value:"Clear Logs",id:"clear-logs",level:2},{value:"Reset To Factory Default",id:"reset-to-factory-default",level:2}];function u(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.p,{children:"This guide will show you how to use the advanced settings in Jan."}),"\n",(0,r.jsx)(n.h2,{id:"access-the-advanced-settings",children:"Access the Advanced Settings"}),"\n",(0,r.jsx)(n.p,{children:"To access the Jan's advanced settings, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsx)(n.li,{children:"You can configure the following settings:"}),"\n"]}),"\n",(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Feature"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Keyboard Shortcuts"})}),(0,r.jsxs)(n.td,{children:["Keyboard shortcuts speed up your workflow. For a quick overview of useful keyboard shortcuts, refer to the list ",(0,r.jsx)(n.a,{href:"/guides/advanced#keyboard-shortcuts",children:"below"}),"."]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Experimental Mode"})}),(0,r.jsx)(n.td,{children:"Enables experimental features that may be unstable."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"GPU Acceleration"})}),(0,r.jsx)(n.td,{children:"Enables the boosting of your model performance by using your GPU devices for acceleration."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Jan Data Folder"})}),(0,r.jsx)(n.td,{children:"Location for messages, model configurations, and user data. Changeable to a different location."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"HTTPS Proxy & Ignore SSL Certificate"})}),(0,r.jsxs)(n.td,{children:["Use a proxy server for internet connections and ignore SSL certificates for self-signed certificates. Please check out the guide on how to set up your own HTTPS proxy server ",(0,r.jsx)(n.a,{href:"/guides/advanced#https-proxy",children:"here"}),"."]})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Clear Logs"})}),(0,r.jsx)(n.td,{children:"Removes all logs from the Jan application."})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.strong,{children:"Reset To Factory Default"})}),(0,r.jsx)(n.td,{children:"Resets the application to its original state, deleting all data including model customizations and conversation history."})]})]})]}),"\n",(0,r.jsx)(n.h2,{id:"keyboard-shortcuts",children:"Keyboard Shortcuts"}),"\n",(0,r.jsx)(n.p,{children:"Here are some of the keyboard shortcuts that you can use in Jan."}),"\n",(0,r.jsxs)(i.A,{children:[(0,r.jsx)(l.A,{value:"mac",label:"Mac",default:!0,children:(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Combination"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 E"})}),(0,r.jsx)(n.td,{children:"Show list your models"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 K"})}),(0,r.jsx)(n.td,{children:"Show list navigation pages"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 B"})}),(0,r.jsx)(n.td,{children:"Toggle collapsible left panel"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"\u2318 ,"})}),(0,r.jsx)(n.td,{children:"Navigate to setting page"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Enter"})}),(0,r.jsx)(n.td,{children:"Send a message"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Shift + Enter"})}),(0,r.jsx)(n.td,{children:"Insert new line in input box"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Up"})}),(0,r.jsx)(n.td,{children:"Navigate to the previous option (within the search dialog)"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Down"})}),(0,r.jsx)(n.td,{children:"Navigate to the next option (within the search dialog)"})]})]})]})}),(0,r.jsx)(l.A,{value:"windows",label:"Windows",default:!0,children:(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Combination"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl E"})}),(0,r.jsx)(n.td,{children:"Show list your models"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl K"})}),(0,r.jsx)(n.td,{children:"Show list navigation pages"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl B"})}),(0,r.jsx)(n.td,{children:"Toggle collapsible left panel"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl ,"})}),(0,r.jsx)(n.td,{children:"Navigate to setting page"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Enter"})}),(0,r.jsx)(n.td,{children:"Send a message"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Shift + Enter"})}),(0,r.jsx)(n.td,{children:"Insert new line in input box"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Up"})}),(0,r.jsx)(n.td,{children:"Navigate to the previous option (within the search dialog)"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Down"})}),(0,r.jsx)(n.td,{children:"Navigate to the next option (within the search dialog)"})]})]})]})}),(0,r.jsx)(l.A,{value:"linux",label:"Linux",default:!0,children:(0,r.jsxs)(n.table,{children:[(0,r.jsx)(n.thead,{children:(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.th,{children:"Combination"}),(0,r.jsx)(n.th,{children:"Description"})]})}),(0,r.jsxs)(n.tbody,{children:[(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl E"})}),(0,r.jsx)(n.td,{children:"Show list your models"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl K"})}),(0,r.jsx)(n.td,{children:"Show list navigation pages"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl B"})}),(0,r.jsx)(n.td,{children:"Toggle collapsible left panel"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Ctrl ,"})}),(0,r.jsx)(n.td,{children:"Navigate to setting page"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Enter"})}),(0,r.jsx)(n.td,{children:"Send a message"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Shift + Enter"})}),(0,r.jsx)(n.td,{children:"Insert new line in input box"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Up"})}),(0,r.jsx)(n.td,{children:"Navigate to the previous option (within the search dialog)"})]}),(0,r.jsxs)(n.tr,{children:[(0,r.jsx)(n.td,{children:(0,r.jsx)(n.code,{children:"Arrow Down"})}),(0,r.jsx)(n.td,{children:"Navigate to the next option (within the search dialog)"})]})]})]})})]}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"The keyboard shortcuts are customizable."})}),"\n",(0,r.jsx)(n.h2,{id:"enable-the-experimental-mode",children:"Enable the Experimental Mode"}),"\n",(0,r.jsx)(n.p,{children:"To try out new fetures that are still in testing phase, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Experimental Mode"})," click the slider to enable."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"enable-the-gpu-acceleration",children:"Enable the GPU Acceleration"}),"\n",(0,r.jsx)(n.p,{children:"To enhance your model performance, follow the steps below:"}),"\n",(0,r.jsx)(n.admonition,{type:"warning",children:(0,r.jsxs)(n.p,{children:["Ensure that you have read the ",(0,r.jsx)(n.a,{href:"/troubleshooting/#troubleshooting-nvidia-gpu",children:"troubleshooting guide"})," here for further assistance."]})}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"GPU Acceleration"})," click the slider to enable."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"access-the-jan-data-folder",children:"Access the Jan Data Folder"}),"\n",(0,r.jsx)(n.p,{children:"To access the folder where messages, model configurations and user data are stored, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Jan Data Folder"})," click the ",(0,r.jsx)(n.strong,{children:"folder icon (\ud83d\udcc2)"})," to access the data or the ",(0,r.jsx)(n.strong,{children:"pencil icon (\u270f\ufe0f)"})," to change the folder where you keep your data."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"https-proxy",children:"HTTPS Proxy"}),"\n",(0,r.jsx)(n.p,{children:"HTTPS Proxy encrypts data between your browser and the internet, making it hard for outsiders to intercept or read. It also helps you to maintain your privacy and security while being able to bypass regional restrictions on internet."}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"When configuring Jan using an HTTPS proxy, the speed of the downloading model may be affected due to the encryption and decryption process. It also depends on the networking of the cloud service provider."}),"\n",(0,r.jsx)(n.li,{children:"HTTPS Proxy does not affect the remote model usage."}),"\n"]})}),"\n",(0,r.jsx)(n.h3,{id:"setting-up-your-own-https-proxy-server",children:"Setting Up Your Own HTTPS Proxy Server"}),"\n",(0,r.jsxs)(n.p,{children:["This guide provides a simple overview of setting up an HTTPS proxy server using ",(0,r.jsx)(n.strong,{children:"Squid"}),", a widely used open-source proxy software."]}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"Other software options are also available depending on your requirements."})}),"\n",(0,r.jsx)(n.h4,{id:"step-1-choosing-a-server",children:"Step 1: Choosing a Server"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:["\n",(0,r.jsx)(n.p,{children:"Firstly, you need to choose a server to host your proxy server."}),"\n",(0,r.jsx)(n.admonition,{type:"note",children:(0,r.jsx)(n.p,{children:"We recommend using a well-known cloud provider service like:"})}),"\n"]}),"\n"]}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Amazon AWS"}),"\n",(0,r.jsx)(n.li,{children:"Google Cloud"}),"\n",(0,r.jsx)(n.li,{children:"Microsoft Azure"}),"\n",(0,r.jsx)(n.li,{children:"Digital Ocean\n:::"}),"\n"]}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsx)(n.li,{children:"Ensure that your server has a public IP address and is accessible from the internet."}),"\n"]}),"\n",(0,r.jsx)(n.h4,{id:"step-2-installing-squid",children:"Step 2: Installing Squid"}),"\n",(0,r.jsxs)(n.p,{children:["Instal ",(0,r.jsx)(n.strong,{children:"Squid"})," using the following command:"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"sudo apt-get update\nsudo apt-get install squid\n"})}),"\n",(0,r.jsx)(n.h4,{id:"step-3-configure-squid-for-https",children:"Step 3: Configure Squid for HTTPS"}),"\n",(0,r.jsx)(n.p,{children:"To enable HTTPS, you will need to configure Squid with SSL support."}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Squid requires an SSL certificate to be able to handle HTTPS traffic. You can generate a self-signed certificate or obtain one from a Certificate Authority (CA). For a self-signed certificate, you can use OpenSSL:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"openssl req -new -newkey rsa:2048 -days 365 -nodes -x509 -keyout squid-proxy.pem -out squid-proxy.pem\n"})}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsxs)(n.li,{children:["Edit the Squid configuration file ",(0,r.jsx)(n.code,{children:"/etc/squid/squid.conf"})," to include the path to your SSL certificate and enable the HTTPS port:"]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"http_port 3128 ssl-bump cert=/path/to/your/squid-proxy.pem\nssl_bump server-first all\nssl_bump bump all\n"})}),"\n",(0,r.jsxs)(n.ol,{start:"3",children:["\n",(0,r.jsxs)(n.li,{children:["To intercept HTTPS traffic, Squid uses a process called SSL Bumping. This process allows Squid to decrypt and re-encrypt HTTPS traffic. To enable SSL Bumping, ensure the ",(0,r.jsx)(n.code,{children:"ssl_bump"})," directives are configured correctly in your ",(0,r.jsx)(n.code,{children:"squid.conf"})," file."]}),"\n"]}),"\n",(0,r.jsx)(n.h4,{id:"step-4-optional-configure-acls-and-authentication",children:"Step 4 (Optional): Configure ACLs and Authentication"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"You can define rules to control who can access your proxy. This is done by editing the squid.conf file and defining ACLs:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:'acl allowed_ips src "/etc/squid/allowed_ips.txt"\nhttp_access allow allowed_ips\n'})}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsx)(n.li,{children:"If you want to add an authentication layer, Squid supports several authentication schemes. Basic authentication setup might look like this:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"auth_param basic program /usr/lib/squid/basic_ncsa_auth /etc/squid/passwords\nacl authenticated proxy_auth REQUIRED\nhttp_access allow authenticated\n"})}),"\n",(0,r.jsx)(n.h4,{id:"step-5-restart-and-test-your-proxy",children:"Step 5: Restart and Test Your Proxy"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"After configuring, restart Squid to apply the changes:"}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-bash",children:"sudo systemctl restart squid\n"})}),"\n",(0,r.jsxs)(n.ol,{start:"2",children:["\n",(0,r.jsx)(n.li,{children:"To test, configure your browser or another client to use the proxy server with its IP address and port (default is 3128)."}),"\n",(0,r.jsx)(n.li,{children:"Check if you can access the internet through your proxy."}),"\n"]}),"\n",(0,r.jsxs)(n.admonition,{type:"tip",children:[(0,r.jsx)(n.p,{children:"Tips for Secure Your Proxy:"}),(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Firewall rules"}),": Ensure that only intended users or IP addresses can connect to your proxy server. This can be achieved by setting up appropriate firewall rules."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Regular updates"}),": Keep your server and proxy software updated to ensure that you are protected against known vulnerabilities."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.strong,{children:"Monitoring and logging"}),": Monitor your proxy server for unusual activity and enable logging to keep track of the traffic passing through your proxy."]}),"\n"]})]}),"\n",(0,r.jsx)(n.h3,{id:"setting-up-jan-to-use-your-https-proxy",children:"Setting Up Jan to Use Your HTTPS Proxy"}),"\n",(0,r.jsx)(n.p,{children:"Once you have your HTTPS proxy server set up, you can configure Jan to use it."}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsxs)(n.li,{children:["Navigate to ",(0,r.jsx)(n.strong,{children:"Settings"})," > ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"HTTPS Proxy"})," click the slider to enable."]}),"\n",(0,r.jsx)(n.li,{children:"Input your domain in the blank field."}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"ignore-ssl-certificate",children:"Ignore SSL Certificate"}),"\n",(0,r.jsx)(n.p,{children:"To Allow self-signed or unverified certificates, follow the steps below:"}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Ignore SSL Certificates"})," click the slider to enable."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"clear-logs",children:"Clear Logs"}),"\n",(0,r.jsx)(n.p,{children:"To clear all logs on your Jan app, follow the steps below:"}),"\n",(0,r.jsx)(n.admonition,{type:"warning",children:(0,r.jsxs)(n.p,{children:["This feature clears all the data in your ",(0,r.jsx)(n.strong,{children:"Jan Data Folder"}),"."]})}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Clear Logs"})," click the the ",(0,r.jsx)(n.strong,{children:"Clear"})," button."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"reset-to-factory-default",children:"Reset To Factory Default"}),"\n",(0,r.jsx)(n.p,{children:"To reset the Jan app to its original state, follow the steps below:"}),"\n",(0,r.jsx)(n.admonition,{title:"Remember!",type:"danger",children:(0,r.jsx)(n.p,{children:"This irreversible action is only recommended if the application is corrupted."})}),"\n",(0,r.jsxs)(n.ol,{children:["\n",(0,r.jsx)(n.li,{children:"Navigate to the main dashboard."}),"\n",(0,r.jsxs)(n.li,{children:["Click the ",(0,r.jsx)(n.strong,{children:"gear icon (\u2699\ufe0f)"})," on the bottom left of your screen."]}),"\n",(0,r.jsxs)(n.li,{children:["Under the ",(0,r.jsx)(n.strong,{children:"Settings screen"}),", click the ",(0,r.jsx)(n.strong,{children:"Advanced Settings"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["On the ",(0,r.jsx)(n.strong,{children:"Reset To Factory Default"})," click the the ",(0,r.jsx)(n.strong,{children:"Reset"})," button."]}),"\n"]})]})}function x(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>l});t(96540);var r=t(18215);const s={tabItem:"tabItem_Ymn6"};var i=t(74848);function l(e){let{children:n,hidden:t,className:l}=e;return(0,i.jsx)("div",{role:"tabpanel",className:(0,r.A)(s.tabItem,l),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>S});var r=t(96540),s=t(18215),i=t(23104),l=t(56347),o=t(205),a=t(57485),d=t(31682),c=t(89466);function h(e){return r.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function u(e){const{values:n,children:t}=e;return(0,r.useMemo)((()=>{const e=n??function(e){return h(e).map((e=>{let{props:{value:n,label:t,attributes:r,default:s}}=e;return{value:n,label:t,attributes:r,default:s}}))}(t);return function(e){const n=(0,d.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function x(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function j(e){let{queryString:n=!1,groupId:t}=e;const s=(0,l.W6)(),i=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,a.aZ)(i),(0,r.useCallback)((e=>{if(!i)return;const n=new URLSearchParams(s.location.search);n.set(i,e),s.replace({...s.location,search:n.toString()})}),[i,s])]}function p(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,i=u(e),[l,a]=(0,r.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!x({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const r=t.find((e=>e.default))??t[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:n,tabValues:i}))),[d,h]=j({queryString:t,groupId:s}),[p,g]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,i]=(0,c.Dv)(t);return[s,(0,r.useCallback)((e=>{t&&i.set(e)}),[t,i])]}({groupId:s}),f=(()=>{const e=d??p;return x({value:e,tabValues:i})?e:null})();(0,o.A)((()=>{f&&a(f)}),[f]);return{selectedValue:l,selectValue:(0,r.useCallback)((e=>{if(!x({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);a(e),h(e),g(e)}),[h,g,i]),tabValues:i}}var g=t(92303);const f={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var v=t(74848);function b(e){let{className:n,block:t,selectedValue:r,selectValue:l,tabValues:o}=e;const a=[],{blockElementScrollPositionUntilNextRender:d}=(0,i.a_)(),c=e=>{const n=e.currentTarget,t=a.indexOf(n),s=o[t].value;s!==r&&(d(n),l(s))},h=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const t=a.indexOf(e.currentTarget)+1;n=a[t]??a[0];break}case"ArrowLeft":{const t=a.indexOf(e.currentTarget)-1;n=a[t]??a[a.length-1];break}}n?.focus()};return(0,v.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:o.map((e=>{let{value:n,label:t,attributes:i}=e;return(0,v.jsx)("li",{role:"tab",tabIndex:r===n?0:-1,"aria-selected":r===n,ref:e=>a.push(e),onKeyDown:h,onClick:c,...i,className:(0,s.A)("tabs__item",f.tabItem,i?.className,{"tabs__item--active":r===n}),children:t??n},n)}))})}function y(e){let{lazy:n,children:t,selectedValue:s}=e;const i=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=i.find((e=>e.props.value===s));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return(0,v.jsx)("div",{className:"margin-top--md",children:i.map(((e,n)=>(0,r.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function m(e){const n=p(e);return(0,v.jsxs)("div",{className:(0,s.A)("tabs-container",f.tabList),children:[(0,v.jsx)(b,{...e,...n}),(0,v.jsx)(y,{...e,...n})]})}function S(e){const n=(0,g.A)();return(0,v.jsx)(m,{...e,children:h(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>l,x:()=>o});var r=t(96540);const s={},i=r.createContext(s);function l(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:l(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d8ca778a.be970632.js b/assets/js/d8ca778a.be970632.js new file mode 100644 index 00000000..790169ce --- /dev/null +++ b/assets/js/d8ca778a.be970632.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5488],{69564:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>t,contentTitle:()=>i,default:()=>m,frontMatter:()=>a,metadata:()=>s,toc:()=>d});var r=o(74848),l=o(28453);const a={title:"Models",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,s={id:"developer/framework/engineering/models",title:"Models",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/models.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/models",permalink:"/developer/framework/engineering/models",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/models.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Models",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Messages",permalink:"/developer/framework/engineering/messages"},next:{title:"Threads",permalink:"/developer/framework/engineering/threads"}},t={},d=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"model.json",id:"modeljson",level:2},{value:"Example",id:"example",level:3},{value:"API Reference",id:"api-reference",level:2},{value:"Importing Models",id:"importing-models",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,l.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsx)(n.p,{children:"In Jan, models are primary entities with the following capabilities:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Users can import, configure, and run models locally."}),"\n",(0,r.jsxs)(n.li,{children:["An ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/models",children:"OpenAI Model API"})," compatible endpoint at ",(0,r.jsx)(n.code,{children:"localhost:1337/v1/models"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["Supported model formats: ",(0,r.jsx)(n.code,{children:"ggufv3"}),", and more."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Models are stored in the ",(0,r.jsx)(n.code,{children:"/models"})," folder."]}),"\n",(0,r.jsx)(n.li,{children:"Models are organized by individual folders, each containing the binaries and configurations needed to run the model. This makes for easy packaging and sharing."}),"\n",(0,r.jsxs)(n.li,{children:["Model folder names are unique and used as ",(0,r.jsx)(n.code,{children:"model_id"})," default values."]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-yaml",children:"jan/ # Jan root folder\n models/\n llama2-70b-q4_k_m/ # Example: standard GGUF model\n model.json\n model-binary-1.gguf\n mistral-7b-gguf-q3_k_l/ # Example: quantizations are separate folders\n model.json\n mistral-7b-q3-K-L.gguf\n mistral-7b-gguf-q8_k_m/ # Example: quantizations are separate folders\n model.json\n mistral-7b-q8_k_k.gguf\n llava-ggml-Q5/ # Example: model with many partitions\n model.json\n mmprj.bin\n model_q5.ggml\n"})}),"\n",(0,r.jsx)(n.h2,{id:"modeljson",children:(0,r.jsx)(n.code,{children:"model.json"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Each ",(0,r.jsx)(n.code,{children:"model"})," folder contains a ",(0,r.jsx)(n.code,{children:"model.json"})," file, which is a representation of a model."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.code,{children:"model.json"})," contains metadata and default parameters used to run a model."]}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"example",children:"Example"}),"\n",(0,r.jsxs)(n.p,{children:["Here's a standard example ",(0,r.jsx)(n.code,{children:"model.json"})," for a GGUF model."]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-js",children:'{\n "id": "zephyr-7b", // Defaults to foldername\n "object": "model", // Defaults to "model"\n "sources": [\n {\n "filename": "zephyr-7b-beta.Q4_K_M.gguf",\n "url": "https://huggingface.co/TheBloke/zephyr-7B-beta-GGUF/blob/main/zephyr-7b-beta.Q4_K_M.gguf"\n }\n ],\n "name": "Zephyr 7B", // Defaults to foldername\n "owned_by": "you", // Defaults to "you"\n "version": "1", // Defaults to 1\n "created": 1231231, // Defaults to file creation time\n "description": null, // Defaults to null\n "format": "ggufv3", // Defaults to "ggufv3"\n "engine": "nitro", // engine_id specified in jan/engine folder\n "engine_parameters": {\n // Engine parameters inside model.json can override\n "ctx_len": 4096, // the value inside the base engine.json\n "ngl": 100,\n "embedding": true,\n "n_parallel": 4\n },\n "model_parameters": {\n // Models are called parameters\n "stream": true,\n "max_tokens": 4096,\n "stop": [""], // This usually can be left blank, only used with specific need from model author\n "frequency_penalty": 0,\n "presence_penalty": 0,\n "temperature": 0.7,\n "top_p": 0.95\n },\n "metadata": {}, // Defaults to {}\n "assets": [\n // Defaults to current dir\n "file://.../zephyr-7b-q4_k_m.bin"\n ]\n}\n'})}),"\n",(0,r.jsxs)(n.p,{children:["The engine parameters in the example can be found at: ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/load-unload#table-of-parameters",children:"Nitro's model settings"})]}),"\n",(0,r.jsxs)(n.p,{children:["The model parameters in the example can be found at: ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/api-reference#tag/Chat-Completion",children:"Nitro's model parameters"})]}),"\n",(0,r.jsx)(n.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,r.jsxs)(n.p,{children:["Jan's Model API is compatible with ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/models",children:"OpenAI's Models API"}),", with additional methods for managing and running models locally."]}),"\n",(0,r.jsxs)(n.p,{children:["See ",(0,r.jsx)(n.a,{href:"https://jan.ai/api-reference#tag/Models",children:"Jan Models API"}),"."]}),"\n",(0,r.jsx)(n.h2,{id:"importing-models",children:"Importing Models"}),"\n",(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,r.jsxs)(n.p,{children:["You can import a model by dragging the model binary or gguf file into the ",(0,r.jsx)(n.code,{children:"/models"})," folder."]}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Jan automatically generates a corresponding ",(0,r.jsx)(n.code,{children:"model.json"})," file based on the binary filename."]}),"\n",(0,r.jsxs)(n.li,{children:["Jan automatically organizes it into its own ",(0,r.jsx)(n.code,{children:"/models/model-id"})," folder."]}),"\n",(0,r.jsxs)(n.li,{children:["Jan automatically populates the ",(0,r.jsx)(n.code,{children:"model.json"})," properties, which you can subsequently modify."]}),"\n"]})]})}function m(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(c,{...e})}):c(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>i,x:()=>s});var r=o(96540);const l={},a=r.createContext(l);function i(e){const n=r.useContext(a);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:i(e.components),r.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/d8ca778a.c36c4401.js b/assets/js/d8ca778a.c36c4401.js deleted file mode 100644 index 4782d72d..00000000 --- a/assets/js/d8ca778a.c36c4401.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5488],{69564:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>t,contentTitle:()=>i,default:()=>m,frontMatter:()=>a,metadata:()=>s,toc:()=>d});var r=o(74848),l=o(28453);const a={title:"Models",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,s={id:"developer/framework/engineering/models",title:"Models",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/models.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/models",permalink:"/developer/framework/engineering/models",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/models.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Models",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Messages",permalink:"/developer/framework/engineering/messages"},next:{title:"Threads",permalink:"/developer/framework/engineering/threads"}},t={},d=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"model.json",id:"modeljson",level:2},{value:"Example",id:"example",level:3},{value:"API Reference",id:"api-reference",level:2},{value:"Importing Models",id:"importing-models",level:2}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,l.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsx)(n.p,{children:"In Jan, models are primary entities with the following capabilities:"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Users can import, configure, and run models locally."}),"\n",(0,r.jsxs)(n.li,{children:["An ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/models",children:"OpenAI Model API"})," compatible endpoint at ",(0,r.jsx)(n.code,{children:"localhost:1337/v1/models"}),"."]}),"\n",(0,r.jsxs)(n.li,{children:["Supported model formats: ",(0,r.jsx)(n.code,{children:"ggufv3"}),", and more."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Models are stored in the ",(0,r.jsx)(n.code,{children:"/models"})," folder."]}),"\n",(0,r.jsx)(n.li,{children:"Models are organized by individual folders, each containing the binaries and configurations needed to run the model. This makes for easy packaging and sharing."}),"\n",(0,r.jsxs)(n.li,{children:["Model folder names are unique and used as ",(0,r.jsx)(n.code,{children:"model_id"})," default values."]}),"\n"]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-yaml",children:"jan/ # Jan root folder\n models/\n llama2-70b-q4_k_m/ # Example: standard GGUF model\n model.json\n model-binary-1.gguf\n mistral-7b-gguf-q3_k_l/ # Example: quantizations are separate folders\n model.json\n mistral-7b-q3-K-L.gguf\n mistral-7b-gguf-q8_k_m/ # Example: quantizations are separate folders\n model.json\n mistral-7b-q8_k_k.gguf\n llava-ggml-Q5/ # Example: model with many partitions\n model.json\n mmprj.bin\n model_q5.ggml\n"})}),"\n",(0,r.jsx)(n.h2,{id:"modeljson",children:(0,r.jsx)(n.code,{children:"model.json"})}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Each ",(0,r.jsx)(n.code,{children:"model"})," folder contains a ",(0,r.jsx)(n.code,{children:"model.json"})," file, which is a representation of a model."]}),"\n",(0,r.jsxs)(n.li,{children:[(0,r.jsx)(n.code,{children:"model.json"})," contains metadata and default parameters used to run a model."]}),"\n"]}),"\n",(0,r.jsx)(n.h3,{id:"example",children:"Example"}),"\n",(0,r.jsxs)(n.p,{children:["Here's a standard example ",(0,r.jsx)(n.code,{children:"model.json"})," for a GGUF model."]}),"\n",(0,r.jsx)(n.pre,{children:(0,r.jsx)(n.code,{className:"language-js",children:'{\n "id": "zephyr-7b", // Defaults to foldername\n "object": "model", // Defaults to "model"\n "sources": [\n {\n "filename": "zephyr-7b-beta.Q4_K_M.gguf",\n "url": "https://huggingface.co/TheBloke/zephyr-7B-beta-GGUF/blob/main/zephyr-7b-beta.Q4_K_M.gguf"\n }\n ],\n "name": "Zephyr 7B", // Defaults to foldername\n "owned_by": "you", // Defaults to "you"\n "version": "1", // Defaults to 1\n "created": 1231231, // Defaults to file creation time\n "description": null, // Defaults to null\n "format": "ggufv3", // Defaults to "ggufv3"\n "engine": "nitro", // engine_id specified in jan/engine folder\n "engine_parameters": {\n // Engine parameters inside model.json can override\n "ctx_len": 4096, // the value inside the base engine.json\n "ngl": 100,\n "embedding": true,\n "n_parallel": 4\n },\n "model_parameters": {\n // Models are called parameters\n "stream": true,\n "max_tokens": 4096,\n "stop": [""], // This usually can be left blank, only used with specific need from model author\n "frequency_penalty": 0,\n "presence_penalty": 0,\n "temperature": 0.7,\n "top_p": 0.95\n },\n "metadata": {}, // Defaults to {}\n "assets": [\n // Defaults to current dir\n "file://.../zephyr-7b-q4_k_m.bin"\n ]\n}\n'})}),"\n",(0,r.jsxs)(n.p,{children:["The engine parameters in the example can be found at: ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/features/load-unload#table-of-parameters",children:"Nitro's model settings"})]}),"\n",(0,r.jsxs)(n.p,{children:["The model parameters in the example can be found at: ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/api-reference#tag/Chat-Completion",children:"Nitro's model parameters"})]}),"\n",(0,r.jsx)(n.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,r.jsxs)(n.p,{children:["Jan's Model API is compatible with ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/models",children:"OpenAI's Models API"}),", with additional methods for managing and running models locally."]}),"\n",(0,r.jsxs)(n.p,{children:["See ",(0,r.jsx)(n.a,{href:"https://jan.ai/api-reference#tag/Models",children:"Jan Models API"}),"."]}),"\n",(0,r.jsx)(n.h2,{id:"importing-models",children:"Importing Models"}),"\n",(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,r.jsxs)(n.p,{children:["You can import a model by dragging the model binary or gguf file into the ",(0,r.jsx)(n.code,{children:"/models"})," folder."]}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsxs)(n.li,{children:["Jan automatically generates a corresponding ",(0,r.jsx)(n.code,{children:"model.json"})," file based on the binary filename."]}),"\n",(0,r.jsxs)(n.li,{children:["Jan automatically organizes it into its own ",(0,r.jsx)(n.code,{children:"/models/model-id"})," folder."]}),"\n",(0,r.jsxs)(n.li,{children:["Jan automatically populates the ",(0,r.jsx)(n.code,{children:"model.json"})," properties, which you can subsequently modify."]}),"\n"]})]})}function m(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(c,{...e})}):c(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>i,x:()=>s});var r=o(96540);const l={},a=r.createContext(l);function i(e){const n=r.useContext(a);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:i(e.components),r.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/da5da385.38fdacca.js b/assets/js/da5da385.38fdacca.js deleted file mode 100644 index 59ee5f29..00000000 --- a/assets/js/da5da385.38fdacca.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5460],{62913:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>i,contentTitle:()=>l,default:()=>h,frontMatter:()=>a,metadata:()=>r,toc:()=>c});var o=t(74848),s=t(28453);const a={title:"Acknowledgements",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/acknowledgements",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","acknowledgements","third-party libraries"]},l="Acknowledgements",r={id:"acknowledgements",title:"Acknowledgements",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/acknowledgements.md",sourceDirName:".",slug:"/acknowledgements",permalink:"/acknowledgements",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/acknowledgements.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Acknowledgements",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/acknowledgements",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","acknowledgements","third-party libraries"]},sidebar:"aboutSidebar",previous:{title:"Website & Docs",permalink:"/how-we-work/website-docs/"},next:{title:"Frequently Asked Questions (FAQ) - Jan",permalink:"/about/faq"}},i={},c=[{value:"Core Dependencies",id:"core-dependencies",level:2},{value:"Dev Tools",id:"dev-tools",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.h1,{id:"acknowledgements",children:"Acknowledgements"}),"\n",(0,o.jsx)(n.p,{children:"We would like to express our gratitude to the following third-party libraries and tools that have made the development of Jan possible. \u2764\ufe0f"}),"\n",(0,o.jsx)(n.h2,{id:"core-dependencies",children:"Core Dependencies"}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp/blob/master/LICENSE",children:"Llama.cpp"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/langchain-ai/langchainjs/blob/main/LICENSE",children:"LangChain.js"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM/blob/main/LICENSE",children:"TensorRT-LLM"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://huggingface.co/TheBloke",children:"TheBloke/GGUF"})}),"\n"]}),"\n",(0,o.jsx)(n.h2,{id:"dev-tools",children:"Dev Tools"}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/scalar/scalar",children:"Scalar"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://continue.dev/",children:"Continue"})}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>l,x:()=>r});var o=t(96540);const s={},a=o.createContext(s);function l(e){const n=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:l(e.components),o.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/da5da385.a4d6d112.js b/assets/js/da5da385.a4d6d112.js new file mode 100644 index 00000000..0fdac277 --- /dev/null +++ b/assets/js/da5da385.a4d6d112.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5460],{62913:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>i,contentTitle:()=>l,default:()=>h,frontMatter:()=>a,metadata:()=>r,toc:()=>c});var o=t(74848),s=t(28453);const a={title:"Acknowledgements",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/acknowledgements",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","acknowledgements","third-party libraries"]},l="Acknowledgements",r={id:"acknowledgements",title:"Acknowledgements",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/acknowledgements.md",sourceDirName:".",slug:"/acknowledgements",permalink:"/acknowledgements",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/acknowledgements.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Acknowledgements",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",slug:"/acknowledgements",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","acknowledgements","third-party libraries"]},sidebar:"aboutSidebar",previous:{title:"Website & Docs",permalink:"/how-we-work/website-docs/"},next:{title:"Frequently Asked Questions (FAQ) - Jan",permalink:"/about/faq"}},i={},c=[{value:"Core Dependencies",id:"core-dependencies",level:2},{value:"Dev Tools",id:"dev-tools",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.h1,{id:"acknowledgements",children:"Acknowledgements"}),"\n",(0,o.jsx)(n.p,{children:"We would like to express our gratitude to the following third-party libraries and tools that have made the development of Jan possible. \u2764\ufe0f"}),"\n",(0,o.jsx)(n.h2,{id:"core-dependencies",children:"Core Dependencies"}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/ggerganov/llama.cpp/blob/master/LICENSE",children:"Llama.cpp"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/langchain-ai/langchainjs/blob/main/LICENSE",children:"LangChain.js"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/NVIDIA/TensorRT-LLM/blob/main/LICENSE",children:"TensorRT-LLM"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://huggingface.co/TheBloke",children:"TheBloke/GGUF"})}),"\n"]}),"\n",(0,o.jsx)(n.h2,{id:"dev-tools",children:"Dev Tools"}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://github.com/scalar/scalar",children:"Scalar"})}),"\n",(0,o.jsx)(n.li,{children:(0,o.jsx)(n.a,{href:"https://continue.dev/",children:"Continue"})}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>l,x:()=>r});var o=t(96540);const s={},a=o.createContext(s);function l(e){const n=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:l(e.components),o.createElement(a.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dabe0364.0282cad7.js b/assets/js/dabe0364.0282cad7.js deleted file mode 100644 index 1dbd4628..00000000 --- a/assets/js/dabe0364.0282cad7.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7572],{62574:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>c,frontMatter:()=>a,metadata:()=>o,toc:()=>d});var i=n(74848),s=n(28453);const a={title:"How to Fine-tune Large Language Models - A Tutorial",description:"Guide on Finetuning Large Language Models with Personal Dataset",slug:"/tutorial/how-to-fine-tune-llms",tags:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],keywords:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],authors:[{name:"Rex Ha",title:"LLM Researcher & Content Writer",url:"https://github.com/hahuyhoang411",image_url:"https://avatars.githubusercontent.com/u/64120343?v=4",email:"rex@jan.ai"},{name:"Ed"},{name:"Alan Dao",title:"AI Engineer",url:"https://github.com/tikikun",image_url:"https://avatars.githubusercontent.com/u/22268502?v=4",email:"alan@jan.ai"}]},r=void 0,o={id:"pending-content/blogpost/finetune-with-docs",title:"How to Fine-tune Large Language Models - A Tutorial",description:"Guide on Finetuning Large Language Models with Personal Dataset",source:"@site/docs/pending-content/blogpost/finetune-with-docs.mdx",sourceDirName:"pending-content/blogpost",slug:"/tutorial/how-to-fine-tune-llms",permalink:"/tutorial/how-to-fine-tune-llms",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/pending-content/blogpost/finetune-with-docs.mdx",tags:[{label:"Large Language Models",permalink:"/tags/large-language-models"},{label:"Finetune LLM",permalink:"/tags/finetune-llm"},{label:"Retrieval Augmented Generation",permalink:"/tags/retrieval-augmented-generation"},{label:"Personal Dataset",permalink:"/tags/personal-dataset"},{label:"Customzied Dataset",permalink:"/tags/customzied-dataset"},{label:"Fine Tuning Tutorial",permalink:"/tags/fine-tuning-tutorial"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"How to Fine-tune Large Language Models - A Tutorial",description:"Guide on Finetuning Large Language Models with Personal Dataset",slug:"/tutorial/how-to-fine-tune-llms",tags:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],keywords:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],authors:[{name:"Rex Ha",title:"LLM Researcher & Content Writer",url:"https://github.com/hahuyhoang411",image_url:"https://avatars.githubusercontent.com/u/64120343?v=4",email:"rex@jan.ai"},{name:"Ed"},{name:"Alan Dao",title:"AI Engineer",url:"https://github.com/tikikun",image_url:"https://avatars.githubusercontent.com/u/22268502?v=4",email:"alan@jan.ai"}]}},l={},d=[{value:"1. Environment setup",id:"1-environment-setup",level:2},{value:"2. Data generation",id:"2-data-generation",level:2},{value:"3. Finetuning",id:"3-finetuning",level:2},{value:"4. Test the model",id:"4-test-the-model",level:2},{value:"Limitations",id:"limitations",level:2},{value:"Conclusions",id:"conclusions",level:2},{value:"Terminology",id:"terminology",level:2},{value:"What is Instruction tuning?",id:"what-is-instruction-tuning",level:3},{value:"What is LoRA?",id:"what-is-lora",level:3},{value:"What is Langchain?",id:"what-is-langchain",level:3},{value:"What is Flash Attention?",id:"what-is-flash-attention",level:3}];function h(e){const t={a:"a",code:"code",em:"em",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(t.p,{children:"Large Language Models (LLMs) are all the rage nowadays, with people using them more and more on a daily basis. As our usage increases, many use cases require the LLM to understand our data, and there are two main approaches we can use:"}),"\n",(0,i.jsxs)(t.ol,{children:["\n",(0,i.jsx)(t.li,{children:"Fine-tuning"}),"\n",(0,i.jsx)(t.li,{children:"Retrieval Augmented Generation (RAG)"}),"\n"]}),"\n",(0,i.jsx)(t.p,{children:"This blog will investigate the first approach to see how fine-tuning performs in understanding some technical product documentation. In detail, you will learn how to:"}),"\n",(0,i.jsxs)(t.ol,{children:["\n",(0,i.jsx)(t.li,{children:"Create a Question and Answer dataset from unstructured data"}),"\n",(0,i.jsx)(t.li,{children:"Fine-tune a model using the dataset"}),"\n",(0,i.jsx)(t.li,{children:"Run the fine-tuned model using Jan"}),"\n"]}),"\n",(0,i.jsx)(t.p,{children:"Let\u2019s get started!"}),"\n",(0,i.jsx)(t.h2,{id:"1-environment-setup",children:"1. Environment setup"}),"\n",(0,i.jsx)(t.p,{children:"Our first step is to install the Hugging Face libraries, which provide the backbone for running large language models (LLMs). Additionally, we'll use LangChain as our go-to tool for efficiently handling and processing our data."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-js",metastring:'title="Install libraries"',children:'# Install Hugging Face libraries\npip install --upgrade \\\n "transformers==4.36.2" \\\n "datasets==2.16.1" \\\n "accelerate==0.26.1" \\\n "evaluate==0.4.1" \\\n "bitsandbytes==0.42.0"\n\n# Install libraries for generating data\npip install --upgrade \\\n\t"llama-cpp-python" \\\n\t"pydantic==1.10.11" \\\n\t"sentence-transformers" \\\n\t"chromadb" \\\n\t"langchain" \\\n\t"tiktoken" \\\n\t"openai==0.28"\n'})}),"\n",(0,i.jsx)(t.p,{children:"In this guide, we'll utilize ChatGPT to create our training dataset. To leverage Hugging Face and OpenAI resources, we first sign into these platforms using the commands below:"}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:'title="Setting up credential keys"',children:'# Import libaries\nfrom huggingface_hub import login\nimport openai\n\n# Setting up credential keys\nOPENAI_KEY_FILE = "YOUR_KEY_HERE"\nHUGGINGFACE_KEY_FILE = "YOUR_KEY_HERE"\n\nopenai.api_key = open_file(OPENAI_KEY_FILE)\nlogin(token=HUGGINGFACE_KEY_FILE)\n'})}),"\n",(0,i.jsx)(t.h2,{id:"2-data-generation",children:(0,i.jsx)(t.strong,{children:"2. Data generation"})}),"\n",(0,i.jsxs)(t.p,{children:["In this tutorial, the \u201cdata\u201d we will use will be the ",(0,i.jsx)(t.a,{href:"https://nitro.jan.ai/",children:"Nitro documentation"}),". Nitro is an open-source, lightweight (3 MB) inference server to supercharge apps with local AI."]}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.img,{alt:"About Nitro",src:n(46743).A+"",width:"987",height:"882"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Fig 1. Example of Nitro's documentation."})}),"\n",(0,i.jsx)(t.p,{children:"At a basic level, documentation is just pages filled with just words. If we give these words to the LLM as they are, it can confuse the model about what is important. Moreover, the unstructured nature of plain text doesn't provide the contextual clues that LLMs need to understand and generate meaningful responses."}),"\n",(0,i.jsxs)(t.p,{children:["To teach it, we will use a method called ",(0,i.jsx)(t.a,{href:"#what-is-instruction-tuning",children:(0,i.jsx)(t.strong,{children:'"Instruction tuning"'})}),", which involves refining the model's ability to comprehend and execute text-based instructions more effectively."]}),"\n",(0,i.jsx)(t.p,{children:"But how do we change the text from the documentation into the right data? We need to make pairs of questions and answers."}),"\n",(0,i.jsx)(t.p,{children:"The main idea is that we will break the documents into smaller pieces. Then, we use the LLM to help us develop questions and answers from those pieces."}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsxs)(t.em,{children:["Note: We also open-source the ",(0,i.jsx)(t.a,{href:"https://huggingface.co/datasets/jan-hq/nitro_binarized",children:(0,i.jsx)(t.strong,{children:"Nitro\u2019s documentation training dataset"})})," in our ",(0,i.jsx)(t.a,{href:"https://huggingface.co/jan-hq",children:(0,i.jsx)(t.strong,{children:"Hugging Face Hub"})}),"."]})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Table 1. Example of Question and Answer pairs"})}),"\n",(0,i.jsxs)(t.table,{children:[(0,i.jsx)(t.thead,{children:(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.th,{children:"User"}),(0,i.jsx)(t.th,{children:"Assistant"})]})}),(0,i.jsxs)(t.tbody,{children:[(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Is Nitro an open-source tool?"}),(0,i.jsx)(t.td,{children:"Yes, Nitro is an open-source tool."})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsxs)(t.td,{children:["What does the ",(0,i.jsx)(t.code,{children:"max_tokens"})," parameter in the prompt request do?"]}),(0,i.jsxs)(t.td,{children:["The ",(0,i.jsx)(t.code,{children:"max_tokens"})," parameter in the prompt request is used to specify the maximum number of tokens that the response should contain. A token can be as small as one character or as large as one word. For example, if ",(0,i.jsx)(t.code,{children:"max_tokens"})," is set to 100, the response will contain no more than 100 tokens."]})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"What operating systems does the Nitro library support?"}),(0,i.jsx)(t.td,{children:"The Nitro library supports multiple operating systems including Windows, MacOS, and Linux. This cross-platform compatibility allows it to cater to a wide range of users using different OS."})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Is Nitro compatible with OpenAI?"}),(0,i.jsx)(t.td,{children:"Yes, Nitro is compatible with OpenAI. This means that it can work seamlessly with models and applications built using OpenAI's technology."})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"What is the endpoint '/v1/chat/completions' used for in the curl command?"}),(0,i.jsx)(t.td,{children:"The '/v1/chat/completions' endpoint in the curl command is the specific location in the server where the request is being sent. The purpose of this endpoint is to handle chat completions, likely returning the next predicted response(s) from the chat assistant based on the sent message."})]})]})]}),"\n",(0,i.jsx)(t.p,{children:"You can create your dataset by using the following example code."}),"\n",(0,i.jsx)(t.p,{children:"First, we need to define some helper functions to process the raw documents into QnA pairs."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:'title="Define helper functions"',children:"# Reads and returns the content of a file.\ndef read_file(filepath):\n with open(filepath, 'r', encoding='utf-8') as file:\n return file.read()\n\n# Generates a response from the ChatGPT model\ndef generate_chatgpt_response(messages, temperature=0.5, model=\"gpt-3.5-turbo\", max_tokens=4096):\n response = openai.ChatCompletion.create(\n model=model, messages=messages, temperature=temperature, max_tokens=max_tokens\n )\n return response['choices'][0]['message']['content']\n\n# Process Markdown files\ndef process_markdown_file(file_path, markdown_splitter, text_splitter):\n with open(file_path, 'r') as file:\n markdown_document = file.read()\n md_header_splits = markdown_splitter.split_text(markdown_document)\n return [chunk for split in md_header_splits for chunk in text_splitter.split_documents([split])]\n \n# Extracts question and answer pairs from a given text\ndef extract_qa_pairs(text):\n qa_pairs = []\n current_pair = {}\n lines = text.split('\\n')\n for line in lines:\n if line.startswith('\"question\": '):\n current_pair['question'] = line.split('\"question\": ')[1].strip(' \",')\n elif line.startswith('\"answer\": '):\n current_pair['answer'] = line.split('\"answer\": ')[1].strip(' \",')\n qa_pairs.append(current_pair)\n current_pair = {}\n return qa_pairs\n\n# Parse QnA pairs as JSON\ndef parse_response(response):\n try:\n parsed_data = json.loads(response)\n return parsed_data['qa_pairs']\n except json.JSONDecodeError:\n return extract_qa_pairs(response)\n \n# Create new column in the dataset\ndef create_message(row):\n return [{\"content\": row['question'], \"role\": \"user\"}, {\"content\": row['answer'], \"role\": \"assistant\"}]\n"})}),"\n",(0,i.jsxs)(t.p,{children:["In this case, we're using the Langchain framework to streamline our work, which gives us different ways to handle the processing step with just a few lines of code. Most of our documents are written in a Markdown format, so we'll use the ",(0,i.jsx)(t.code,{children:"MarkdownHeaderTextSplitter"})," function combined with the ",(0,i.jsx)(t.code,{children:"TokenTextSplitter"})," function to ensure we give the LLM the right amount of text to create questions and answers."]}),"\n",(0,i.jsx)(t.p,{children:"We chose a chunk size of 300 tokens to ensure that when we generate QnA pairs, the generation won't be out of context with the token length of the LLM (normally, it\u2019s capped at 4096 tokens). Also, we applied the overlap technique so that each chunk will contain the context from the previous chunk to make the chunk coherent."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:'title="Create logic for processing raw data"',children:'# Chunking settings\nHEADERS_TO_SPLIT_ON = [("#", "Header 1"), ("##", "Header 2"), ("###", "Header 3")]\n\n# Main Script Logic\nmarkdown_splitter = MarkdownHeaderTextSplitter(headers_to_split_on=HEADERS_TO_SPLIT_ON)\ntext_splitter = TokenTextSplitter(chunk_size=300, chunk_overlap=30)\n'})}),"\n",(0,i.jsx)(t.p,{children:"For generating QnA pairs, we need to set up the prompt for the LLM to generate the model. For this task, we used GPT-4 to generate QnA pairs but you can also try with any other Local LLMs with a little bit of tweaking on the system prompt."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{children:"You are a curious assistant. Your task is to make 10 pairs of questions and answers using the given context delimited by triple quotation marks. You are extremely critical and can ask questions at different difficulty levels. You will be more generic and unique and focus on the Nitro library (the given context is from Nitro library). And you can also answer with the code block. Your `answer` must be detailed, comprehensive and step by step guide. Let's think step by step. It's really important to my project. Strictly follow the JSON format for output with 1 field `qa_pairs` and `question`, `answer`.\n"})}),"\n",(0,i.jsx)(t.p,{children:"To generate a diverse dataset, we'll configure the LLM to produce 10 QnA pairs per iteration. We'll execute this process three times to enrich the dataset's variety. After setting everything up, let's generate a training dataset."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:"title",children:"# Set up directory\nROOT_DIR = \"PATH/TO/YOUR/DATA/FOLDER\"\nCSV_FILE_PATH = \"PATH/TO/SAVE/OUTPUT/CSV/FILE\"\nREPO_NAME = \"YOUR/HUGGINGFACE/REPO\"\n\n# Initialize data frame\nall_chunks = []\nmaster_df = pd.DataFrame(columns=['question', 'answer', 'raw'])\n\n# Split raw text into chunks\nfor subdir, dirs, files in os.walk(ROOT_DIR):\n for file in files:\n if file.endswith('.md'):\n file_path = os.path.join(subdir, file)\n file_chunks = process_markdown_file(file_path,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmarkdown_splitter,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttext_splitter)\n all_chunks.extend(file_chunks)\n\n# Generating QnA pairs with GPT\nfor _ in range(3):\n for chunk in all_chunks:\n conversation = [{'role': 'system', 'content': open_file(SYSTEM_FILE_PATH)},\n {'role': 'user', 'content': str(chunk)}]\n response_verification = chatgpt_completion(conversation)\n qa_pairs = extract_qa_pairs_from_response(response_verification)\n qa_df = pd.DataFrame(qa_pairs)\n qa_df['raw'] = [chunk] * len(qa_df)\n master_df = pd.concat([master_df, qa_df], ignore_index=True)\nmaster_df.to_csv(CSV_FILE_PATH, index=False, encoding='utf-8')\n\n# Deduplication\ndf = pd.read_csv(CSV_FILE_PATH)\ndf_deduplicated = df.drop_duplicates()\ndf_deduplicated['messages'] = df_deduplicated.apply(create_message, axis=1)\n\n# Convert data frame to Huggingface dataset format\nmessages = df_deduplicated['message'].tolist()\nrejected = df_deduplicated['rejected'].tolist()\nhf_dataset = Dataset.from_dict({'messages': messages, 'chosen': messages, 'rejected': rejected})\n\n# Split train and test\nsplit_dataset = hf_dataset.train_test_split(test_size=0.1)\n\n# Push to Hugging Face Hub\nsplit_dataset.push_to_hub(REPO_NAME)\n"})}),"\n",(0,i.jsxs)(t.p,{children:["Please refer to ",(0,i.jsx)(t.strong,{children:"Table 1"})," for samples of the generated dataset."]}),"\n",(0,i.jsx)(t.h2,{id:"3-finetuning",children:(0,i.jsx)(t.strong,{children:"3. Finetuning"})}),"\n",(0,i.jsxs)(t.p,{children:["We use the ",(0,i.jsx)(t.a,{href:"https://github.com/huggingface/alignment-handbook",children:"alignment-handbook"})," from Hugging Face for the training code. This is a well-written library that explains in detail everything about finetuning LLMs. It also provides cutting-edge technology implementation like ",(0,i.jsx)(t.a,{href:"#what-is-lora",children:"LORA/QLoRA"})," or ",(0,i.jsx)(t.a,{href:"#what-is-flash-attention",children:"Flash Attention"})," for efficient training on customer GPUs."]}),"\n",(0,i.jsxs)(t.p,{children:["For installing the alignment-handbook, please follow their ",(0,i.jsx)(t.a,{href:"https://github.com/huggingface/alignment-handbook?tab=readme-ov-file#installation-instructions",children:"installation guide"}),"."]}),"\n",(0,i.jsxs)(t.p,{children:["In our training setup, we selected the ",(0,i.jsx)(t.a,{href:"https://huggingface.co/jan-hq/stealth-v1.3",children:"Stealth v1.3"})," model as the foundation. We explored different configurations of LoRA/QLoRA, focusing on the parameters ",(0,i.jsx)(t.code,{children:"r"})," and ",(0,i.jsx)(t.code,{children:"alpha"}),". The ",(0,i.jsx)(t.code,{children:"r"})," parameter, denoting the rank in low-rank adaptation, influences the model's learning capacity and complexity, with higher values offering more flexibility at the risk of overfitting. The ",(0,i.jsx)(t.code,{children:"alpha"})," parameter scales the adaptation's effect, balancing new learning and existing knowledge retention. We found ",(0,i.jsx)(t.code,{children:"r = 256"})," and ",(0,i.jsx)(t.code,{children:"alpha = 512"})," to be effective settings. For more details, see our sample YAML configuration file."]}),"\n",(0,i.jsx)(t.p,{children:"For training the model after installing the repository, you can run the following command:"}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-js",metastring:'title="Command to train LLM with alignment handbook"',children:"ACCELERATE_LOG_LEVEL=info \\\naccelerate launch \\\n --config_file recipes/accelerate_configs/multi_gpu.yaml \\\n --num_processes=1 \\\n scripts/run_sft.py recipes/nitro/sft/config_lora.yaml\n"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Table 2. Training result of Nitro models."})}),"\n",(0,i.jsxs)(t.table,{children:[(0,i.jsx)(t.thead,{children:(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.th,{children:"Model"}),(0,i.jsx)(t.th,{children:"r"}),(0,i.jsx)(t.th,{children:"alpha"}),(0,i.jsx)(t.th,{children:"Loss"}),(0,i.jsx)(t.th,{children:"Time"})]})}),(0,i.jsxs)(t.tbody,{children:[(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E1 LoRA"}),(0,i.jsx)(t.td,{children:"16"}),(0,i.jsx)(t.td,{children:"32"}),(0,i.jsx)(t.td,{children:"1.185"}),(0,i.jsx)(t.td,{children:"3m"})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E3 LoRA"}),(0,i.jsx)(t.td,{children:"16"}),(0,i.jsx)(t.td,{children:"32"}),(0,i.jsx)(t.td,{children:"0.853"}),(0,i.jsx)(t.td,{children:"10m"})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E1 QLoRA"}),(0,i.jsx)(t.td,{children:"256"}),(0,i.jsx)(t.td,{children:"512"}),(0,i.jsx)(t.td,{children:"0.6513"}),(0,i.jsx)(t.td,{children:"6m"})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E3 QLoRA"}),(0,i.jsx)(t.td,{children:"256"}),(0,i.jsx)(t.td,{children:"512"}),(0,i.jsx)(t.td,{children:"0.3123"}),(0,i.jsx)(t.td,{children:"18m"})]})]})]}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.em,{children:"E: epochs, m: minutes"}),"\n",(0,i.jsx)(t.em,{children:"Note: Training times can vary based on hardware specifications. The provided times are for reference purposes only."})]}),"\n",(0,i.jsx)(t.h2,{id:"4-test-the-model",children:(0,i.jsx)(t.strong,{children:"4. Test the model"})}),"\n",(0,i.jsxs)(t.p,{children:["After training the model, it can be tested locally in the GGUF format using ",(0,i.jsx)(t.a,{href:"https://jan.ai/",children:"Jan"}),". To convert the fine-tuned model to GGUF, you can utilize this convenient ",(0,i.jsx)(t.a,{href:"https://colab.research.google.com/github/mlabonne/llm-course/blob/main/Quantize_Llama_2_models_using_GGUF_and_llama_cpp.ipynb",children:"Google Colab notebook by Maxime Labonne"}),"."]}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.img,{alt:"Finetuned Nitro Respond",src:n(52049).A+"",width:"719",height:"385"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Fig 2. Using Jan to run a new fine-tuned model."})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.img,{alt:"Finetuned Nitro Respond 2",src:n(19840).A+"",width:"645",height:"769"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Fig 3. Model answers a technical question related to Nitro."})}),"\n",(0,i.jsxs)(t.p,{children:["As shown in\xa0",(0,i.jsx)(t.code,{children:"Fig 2"}),", the model successfully learned new information from Nitro's documentation. This indicates that it accurately understands details about Nitro."]}),"\n",(0,i.jsx)(t.h2,{id:"limitations",children:"Limitations"}),"\n",(0,i.jsxs)(t.p,{children:["With this straightforward approach, we show that the model is capable of acquiring new knowledge. However, there's a potential risk of ",(0,i.jsx)(t.a,{href:"https://en.wikipedia.org/wiki/Catastrophic_interference",children:"catastrophic forgetting"}),", leading to the model only being good at answering information about Nitro documentation and losing some other abilities."]}),"\n",(0,i.jsx)(t.p,{children:"In our next blog post, we will further discuss this problem and its solution."}),"\n",(0,i.jsx)(t.h2,{id:"conclusions",children:(0,i.jsx)(t.strong,{children:"Conclusions"})}),"\n",(0,i.jsx)(t.p,{children:"In the blog post, we learn how to fine-tune an open-source model using LoRA/QLoRA with documentation of Nitro\u2019s repository on a local machine. We\u2019ve learned:"}),"\n",(0,i.jsxs)(t.ul,{children:["\n",(0,i.jsx)(t.li,{children:"Data generation using LangChain to chunk the documentation and use LLM to make QnA pairs from unstructured data."}),"\n",(0,i.jsx)(t.li,{children:"Finetuning the model on generated data using QLoRA with high r and alpha setting."}),"\n",(0,i.jsx)(t.li,{children:"Test the model using Jan."}),"\n"]}),"\n",(0,i.jsx)(t.p,{children:"Combining all those steps, we can train our model on every documentation to create our chatbot."}),"\n",(0,i.jsx)(t.h2,{id:"terminology",children:"Terminology"}),"\n",(0,i.jsx)(t.h3,{id:"what-is-instruction-tuning",children:"What is Instruction tuning?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://openai.com/research/instruction-following",children:"Instruction tuning"})," in LLMs involves refining the model's ability to comprehend and execute text-based instructions more effectively. By training on a diverse set of tasks presented as instructions, the model learns to generalize and apply its knowledge across a wide range of requests, enhancing its responsiveness and accuracy in fulfilling user commands. This process fine-tunes the model on a curated dataset where the inputs are explicit instructions and the desired outputs are model-generated responses, leading to improved performance on instruction-following tasks and a better alignment with user expectations."]}),"\n",(0,i.jsx)(t.h3,{id:"what-is-lora",children:"What is LoRA?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://arxiv.org/abs/2106.09685",children:"Low-Rank Adaptation"})," (LoRA) is a method that makes fine-tuning large language models more efficient. It breaks down the model's large weight matrices into smaller, trainable matrices. These smaller matrices are the only parts that get updated, leaving the original weights unchanged. This approach significantly reduces the number of parameters that need training, leading to faster and less memory-intensive tuning. Essentially, LoRA is a new way of training LLMs with limited resources but with a little trade-off in performance."]}),"\n",(0,i.jsx)(t.h3,{id:"what-is-langchain",children:"What is Langchain?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://www.langchain.com/",children:"LangChain"})," is an open-source framework designed to simplify the creation of applications powered by large language models (LLMs), such as chatbots and agents. Exactly like its name, it's a chaining language for developers to easily apply advanced prompt techniques to get the most out of it. It also provides developers with a standardized interface and pre-built components, making advanced language understanding and generation more accessible. By abstracting the complexities of LLM integration, LangChain enables the rapid development of intelligent, context-aware applications. Its collaborative ecosystem encourages innovation, leveraging the community's collective expertise to expand the possibilities of AI-driven solutions."]}),"\n",(0,i.jsx)(t.h3,{id:"what-is-flash-attention",children:"What is Flash Attention?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://github.com/Dao-AILab/flash-attention",children:"Flash Attention"})," is an algorithm that speeds up the core attention mechanism in Transformer language models by restructuring computations. It uses techniques like tiling and recomputation to reduce the high memory costs of attention, enabling models to process longer text sequences."]})]})}function c(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,i.jsx)(t,{...e,children:(0,i.jsx)(h,{...e})}):h(e)}},46743:(e,t,n)=>{n.d(t,{A:()=>i});const i=n.p+"assets/images/about-nitro-77d4d2ab8a69afbe7c249c9c617db8a6.png"},19840:(e,t,n)=>{n.d(t,{A:()=>i});const i=n.p+"assets/images/finetuned-respond-2-3bebfa561e4471585b412e14d605ab7a.png"},52049:(e,t,n)=>{n.d(t,{A:()=>i});const i=n.p+"assets/images/finetuned-response-f85b89b18e2705073f0632e6cd87183a.png"},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>o});var i=n(96540);const s={},a=i.createContext(s);function r(e){const t=i.useContext(a);return i.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function o(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),i.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dabe0364.24e7cccc.js b/assets/js/dabe0364.24e7cccc.js new file mode 100644 index 00000000..790388b0 --- /dev/null +++ b/assets/js/dabe0364.24e7cccc.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7572],{62574:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>c,frontMatter:()=>a,metadata:()=>o,toc:()=>d});var i=n(74848),s=n(28453);const a={title:"How to Fine-tune Large Language Models - A Tutorial",description:"Guide on Finetuning Large Language Models with Personal Dataset",slug:"/tutorial/how-to-fine-tune-llms",tags:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],keywords:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],authors:[{name:"Rex Ha",title:"LLM Researcher & Content Writer",url:"https://github.com/hahuyhoang411",image_url:"https://avatars.githubusercontent.com/u/64120343?v=4",email:"rex@jan.ai"},{name:"Ed"},{name:"Alan Dao",title:"AI Engineer",url:"https://github.com/tikikun",image_url:"https://avatars.githubusercontent.com/u/22268502?v=4",email:"alan@jan.ai"}]},r=void 0,o={id:"pending-content/blogpost/finetune-with-docs",title:"How to Fine-tune Large Language Models - A Tutorial",description:"Guide on Finetuning Large Language Models with Personal Dataset",source:"@site/docs/pending-content/blogpost/finetune-with-docs.mdx",sourceDirName:"pending-content/blogpost",slug:"/tutorial/how-to-fine-tune-llms",permalink:"/tutorial/how-to-fine-tune-llms",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/pending-content/blogpost/finetune-with-docs.mdx",tags:[{label:"Large Language Models",permalink:"/tags/large-language-models"},{label:"Finetune LLM",permalink:"/tags/finetune-llm"},{label:"Retrieval Augmented Generation",permalink:"/tags/retrieval-augmented-generation"},{label:"Personal Dataset",permalink:"/tags/personal-dataset"},{label:"Customzied Dataset",permalink:"/tags/customzied-dataset"},{label:"Fine Tuning Tutorial",permalink:"/tags/fine-tuning-tutorial"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"How to Fine-tune Large Language Models - A Tutorial",description:"Guide on Finetuning Large Language Models with Personal Dataset",slug:"/tutorial/how-to-fine-tune-llms",tags:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],keywords:["Large Language Models","Finetune LLM","Retrieval Augmented Generation","Personal Dataset","Customzied Dataset","Fine Tuning Tutorial"],authors:[{name:"Rex Ha",title:"LLM Researcher & Content Writer",url:"https://github.com/hahuyhoang411",image_url:"https://avatars.githubusercontent.com/u/64120343?v=4",email:"rex@jan.ai"},{name:"Ed"},{name:"Alan Dao",title:"AI Engineer",url:"https://github.com/tikikun",image_url:"https://avatars.githubusercontent.com/u/22268502?v=4",email:"alan@jan.ai"}]}},l={},d=[{value:"1. Environment setup",id:"1-environment-setup",level:2},{value:"2. Data generation",id:"2-data-generation",level:2},{value:"3. Finetuning",id:"3-finetuning",level:2},{value:"4. Test the model",id:"4-test-the-model",level:2},{value:"Limitations",id:"limitations",level:2},{value:"Conclusions",id:"conclusions",level:2},{value:"Terminology",id:"terminology",level:2},{value:"What is Instruction tuning?",id:"what-is-instruction-tuning",level:3},{value:"What is LoRA?",id:"what-is-lora",level:3},{value:"What is Langchain?",id:"what-is-langchain",level:3},{value:"What is Flash Attention?",id:"what-is-flash-attention",level:3}];function h(e){const t={a:"a",code:"code",em:"em",h2:"h2",h3:"h3",img:"img",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(t.p,{children:"Large Language Models (LLMs) are all the rage nowadays, with people using them more and more on a daily basis. As our usage increases, many use cases require the LLM to understand our data, and there are two main approaches we can use:"}),"\n",(0,i.jsxs)(t.ol,{children:["\n",(0,i.jsx)(t.li,{children:"Fine-tuning"}),"\n",(0,i.jsx)(t.li,{children:"Retrieval Augmented Generation (RAG)"}),"\n"]}),"\n",(0,i.jsx)(t.p,{children:"This blog will investigate the first approach to see how fine-tuning performs in understanding some technical product documentation. In detail, you will learn how to:"}),"\n",(0,i.jsxs)(t.ol,{children:["\n",(0,i.jsx)(t.li,{children:"Create a Question and Answer dataset from unstructured data"}),"\n",(0,i.jsx)(t.li,{children:"Fine-tune a model using the dataset"}),"\n",(0,i.jsx)(t.li,{children:"Run the fine-tuned model using Jan"}),"\n"]}),"\n",(0,i.jsx)(t.p,{children:"Let\u2019s get started!"}),"\n",(0,i.jsx)(t.h2,{id:"1-environment-setup",children:"1. Environment setup"}),"\n",(0,i.jsx)(t.p,{children:"Our first step is to install the Hugging Face libraries, which provide the backbone for running large language models (LLMs). Additionally, we'll use LangChain as our go-to tool for efficiently handling and processing our data."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-js",metastring:'title="Install libraries"',children:'# Install Hugging Face libraries\npip install --upgrade \\\n "transformers==4.36.2" \\\n "datasets==2.16.1" \\\n "accelerate==0.26.1" \\\n "evaluate==0.4.1" \\\n "bitsandbytes==0.42.0"\n\n# Install libraries for generating data\npip install --upgrade \\\n\t"llama-cpp-python" \\\n\t"pydantic==1.10.11" \\\n\t"sentence-transformers" \\\n\t"chromadb" \\\n\t"langchain" \\\n\t"tiktoken" \\\n\t"openai==0.28"\n'})}),"\n",(0,i.jsx)(t.p,{children:"In this guide, we'll utilize ChatGPT to create our training dataset. To leverage Hugging Face and OpenAI resources, we first sign into these platforms using the commands below:"}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:'title="Setting up credential keys"',children:'# Import libaries\nfrom huggingface_hub import login\nimport openai\n\n# Setting up credential keys\nOPENAI_KEY_FILE = "YOUR_KEY_HERE"\nHUGGINGFACE_KEY_FILE = "YOUR_KEY_HERE"\n\nopenai.api_key = open_file(OPENAI_KEY_FILE)\nlogin(token=HUGGINGFACE_KEY_FILE)\n'})}),"\n",(0,i.jsx)(t.h2,{id:"2-data-generation",children:(0,i.jsx)(t.strong,{children:"2. Data generation"})}),"\n",(0,i.jsxs)(t.p,{children:["In this tutorial, the \u201cdata\u201d we will use will be the ",(0,i.jsx)(t.a,{href:"https://nitro.jan.ai/",children:"Nitro documentation"}),". Nitro is an open-source, lightweight (3 MB) inference server to supercharge apps with local AI."]}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.img,{alt:"About Nitro",src:n(46743).A+"",width:"987",height:"882"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Fig 1. Example of Nitro's documentation."})}),"\n",(0,i.jsx)(t.p,{children:"At a basic level, documentation is just pages filled with just words. If we give these words to the LLM as they are, it can confuse the model about what is important. Moreover, the unstructured nature of plain text doesn't provide the contextual clues that LLMs need to understand and generate meaningful responses."}),"\n",(0,i.jsxs)(t.p,{children:["To teach it, we will use a method called ",(0,i.jsx)(t.a,{href:"#what-is-instruction-tuning",children:(0,i.jsx)(t.strong,{children:'"Instruction tuning"'})}),", which involves refining the model's ability to comprehend and execute text-based instructions more effectively."]}),"\n",(0,i.jsx)(t.p,{children:"But how do we change the text from the documentation into the right data? We need to make pairs of questions and answers."}),"\n",(0,i.jsx)(t.p,{children:"The main idea is that we will break the documents into smaller pieces. Then, we use the LLM to help us develop questions and answers from those pieces."}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsxs)(t.em,{children:["Note: We also open-source the ",(0,i.jsx)(t.a,{href:"https://huggingface.co/datasets/jan-hq/nitro_binarized",children:(0,i.jsx)(t.strong,{children:"Nitro\u2019s documentation training dataset"})})," in our ",(0,i.jsx)(t.a,{href:"https://huggingface.co/jan-hq",children:(0,i.jsx)(t.strong,{children:"Hugging Face Hub"})}),"."]})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Table 1. Example of Question and Answer pairs"})}),"\n",(0,i.jsxs)(t.table,{children:[(0,i.jsx)(t.thead,{children:(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.th,{children:"User"}),(0,i.jsx)(t.th,{children:"Assistant"})]})}),(0,i.jsxs)(t.tbody,{children:[(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Is Nitro an open-source tool?"}),(0,i.jsx)(t.td,{children:"Yes, Nitro is an open-source tool."})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsxs)(t.td,{children:["What does the ",(0,i.jsx)(t.code,{children:"max_tokens"})," parameter in the prompt request do?"]}),(0,i.jsxs)(t.td,{children:["The ",(0,i.jsx)(t.code,{children:"max_tokens"})," parameter in the prompt request is used to specify the maximum number of tokens that the response should contain. A token can be as small as one character or as large as one word. For example, if ",(0,i.jsx)(t.code,{children:"max_tokens"})," is set to 100, the response will contain no more than 100 tokens."]})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"What operating systems does the Nitro library support?"}),(0,i.jsx)(t.td,{children:"The Nitro library supports multiple operating systems including Windows, MacOS, and Linux. This cross-platform compatibility allows it to cater to a wide range of users using different OS."})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Is Nitro compatible with OpenAI?"}),(0,i.jsx)(t.td,{children:"Yes, Nitro is compatible with OpenAI. This means that it can work seamlessly with models and applications built using OpenAI's technology."})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"What is the endpoint '/v1/chat/completions' used for in the curl command?"}),(0,i.jsx)(t.td,{children:"The '/v1/chat/completions' endpoint in the curl command is the specific location in the server where the request is being sent. The purpose of this endpoint is to handle chat completions, likely returning the next predicted response(s) from the chat assistant based on the sent message."})]})]})]}),"\n",(0,i.jsx)(t.p,{children:"You can create your dataset by using the following example code."}),"\n",(0,i.jsx)(t.p,{children:"First, we need to define some helper functions to process the raw documents into QnA pairs."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:'title="Define helper functions"',children:"# Reads and returns the content of a file.\ndef read_file(filepath):\n with open(filepath, 'r', encoding='utf-8') as file:\n return file.read()\n\n# Generates a response from the ChatGPT model\ndef generate_chatgpt_response(messages, temperature=0.5, model=\"gpt-3.5-turbo\", max_tokens=4096):\n response = openai.ChatCompletion.create(\n model=model, messages=messages, temperature=temperature, max_tokens=max_tokens\n )\n return response['choices'][0]['message']['content']\n\n# Process Markdown files\ndef process_markdown_file(file_path, markdown_splitter, text_splitter):\n with open(file_path, 'r') as file:\n markdown_document = file.read()\n md_header_splits = markdown_splitter.split_text(markdown_document)\n return [chunk for split in md_header_splits for chunk in text_splitter.split_documents([split])]\n \n# Extracts question and answer pairs from a given text\ndef extract_qa_pairs(text):\n qa_pairs = []\n current_pair = {}\n lines = text.split('\\n')\n for line in lines:\n if line.startswith('\"question\": '):\n current_pair['question'] = line.split('\"question\": ')[1].strip(' \",')\n elif line.startswith('\"answer\": '):\n current_pair['answer'] = line.split('\"answer\": ')[1].strip(' \",')\n qa_pairs.append(current_pair)\n current_pair = {}\n return qa_pairs\n\n# Parse QnA pairs as JSON\ndef parse_response(response):\n try:\n parsed_data = json.loads(response)\n return parsed_data['qa_pairs']\n except json.JSONDecodeError:\n return extract_qa_pairs(response)\n \n# Create new column in the dataset\ndef create_message(row):\n return [{\"content\": row['question'], \"role\": \"user\"}, {\"content\": row['answer'], \"role\": \"assistant\"}]\n"})}),"\n",(0,i.jsxs)(t.p,{children:["In this case, we're using the Langchain framework to streamline our work, which gives us different ways to handle the processing step with just a few lines of code. Most of our documents are written in a Markdown format, so we'll use the ",(0,i.jsx)(t.code,{children:"MarkdownHeaderTextSplitter"})," function combined with the ",(0,i.jsx)(t.code,{children:"TokenTextSplitter"})," function to ensure we give the LLM the right amount of text to create questions and answers."]}),"\n",(0,i.jsx)(t.p,{children:"We chose a chunk size of 300 tokens to ensure that when we generate QnA pairs, the generation won't be out of context with the token length of the LLM (normally, it\u2019s capped at 4096 tokens). Also, we applied the overlap technique so that each chunk will contain the context from the previous chunk to make the chunk coherent."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:'title="Create logic for processing raw data"',children:'# Chunking settings\nHEADERS_TO_SPLIT_ON = [("#", "Header 1"), ("##", "Header 2"), ("###", "Header 3")]\n\n# Main Script Logic\nmarkdown_splitter = MarkdownHeaderTextSplitter(headers_to_split_on=HEADERS_TO_SPLIT_ON)\ntext_splitter = TokenTextSplitter(chunk_size=300, chunk_overlap=30)\n'})}),"\n",(0,i.jsx)(t.p,{children:"For generating QnA pairs, we need to set up the prompt for the LLM to generate the model. For this task, we used GPT-4 to generate QnA pairs but you can also try with any other Local LLMs with a little bit of tweaking on the system prompt."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{children:"You are a curious assistant. Your task is to make 10 pairs of questions and answers using the given context delimited by triple quotation marks. You are extremely critical and can ask questions at different difficulty levels. You will be more generic and unique and focus on the Nitro library (the given context is from Nitro library). And you can also answer with the code block. Your `answer` must be detailed, comprehensive and step by step guide. Let's think step by step. It's really important to my project. Strictly follow the JSON format for output with 1 field `qa_pairs` and `question`, `answer`.\n"})}),"\n",(0,i.jsx)(t.p,{children:"To generate a diverse dataset, we'll configure the LLM to produce 10 QnA pairs per iteration. We'll execute this process three times to enrich the dataset's variety. After setting everything up, let's generate a training dataset."}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-python",metastring:"title",children:"# Set up directory\nROOT_DIR = \"PATH/TO/YOUR/DATA/FOLDER\"\nCSV_FILE_PATH = \"PATH/TO/SAVE/OUTPUT/CSV/FILE\"\nREPO_NAME = \"YOUR/HUGGINGFACE/REPO\"\n\n# Initialize data frame\nall_chunks = []\nmaster_df = pd.DataFrame(columns=['question', 'answer', 'raw'])\n\n# Split raw text into chunks\nfor subdir, dirs, files in os.walk(ROOT_DIR):\n for file in files:\n if file.endswith('.md'):\n file_path = os.path.join(subdir, file)\n file_chunks = process_markdown_file(file_path,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmarkdown_splitter,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttext_splitter)\n all_chunks.extend(file_chunks)\n\n# Generating QnA pairs with GPT\nfor _ in range(3):\n for chunk in all_chunks:\n conversation = [{'role': 'system', 'content': open_file(SYSTEM_FILE_PATH)},\n {'role': 'user', 'content': str(chunk)}]\n response_verification = chatgpt_completion(conversation)\n qa_pairs = extract_qa_pairs_from_response(response_verification)\n qa_df = pd.DataFrame(qa_pairs)\n qa_df['raw'] = [chunk] * len(qa_df)\n master_df = pd.concat([master_df, qa_df], ignore_index=True)\nmaster_df.to_csv(CSV_FILE_PATH, index=False, encoding='utf-8')\n\n# Deduplication\ndf = pd.read_csv(CSV_FILE_PATH)\ndf_deduplicated = df.drop_duplicates()\ndf_deduplicated['messages'] = df_deduplicated.apply(create_message, axis=1)\n\n# Convert data frame to Huggingface dataset format\nmessages = df_deduplicated['message'].tolist()\nrejected = df_deduplicated['rejected'].tolist()\nhf_dataset = Dataset.from_dict({'messages': messages, 'chosen': messages, 'rejected': rejected})\n\n# Split train and test\nsplit_dataset = hf_dataset.train_test_split(test_size=0.1)\n\n# Push to Hugging Face Hub\nsplit_dataset.push_to_hub(REPO_NAME)\n"})}),"\n",(0,i.jsxs)(t.p,{children:["Please refer to ",(0,i.jsx)(t.strong,{children:"Table 1"})," for samples of the generated dataset."]}),"\n",(0,i.jsx)(t.h2,{id:"3-finetuning",children:(0,i.jsx)(t.strong,{children:"3. Finetuning"})}),"\n",(0,i.jsxs)(t.p,{children:["We use the ",(0,i.jsx)(t.a,{href:"https://github.com/huggingface/alignment-handbook",children:"alignment-handbook"})," from Hugging Face for the training code. This is a well-written library that explains in detail everything about finetuning LLMs. It also provides cutting-edge technology implementation like ",(0,i.jsx)(t.a,{href:"#what-is-lora",children:"LORA/QLoRA"})," or ",(0,i.jsx)(t.a,{href:"#what-is-flash-attention",children:"Flash Attention"})," for efficient training on customer GPUs."]}),"\n",(0,i.jsxs)(t.p,{children:["For installing the alignment-handbook, please follow their ",(0,i.jsx)(t.a,{href:"https://github.com/huggingface/alignment-handbook?tab=readme-ov-file#installation-instructions",children:"installation guide"}),"."]}),"\n",(0,i.jsxs)(t.p,{children:["In our training setup, we selected the ",(0,i.jsx)(t.a,{href:"https://huggingface.co/jan-hq/stealth-v1.3",children:"Stealth v1.3"})," model as the foundation. We explored different configurations of LoRA/QLoRA, focusing on the parameters ",(0,i.jsx)(t.code,{children:"r"})," and ",(0,i.jsx)(t.code,{children:"alpha"}),". The ",(0,i.jsx)(t.code,{children:"r"})," parameter, denoting the rank in low-rank adaptation, influences the model's learning capacity and complexity, with higher values offering more flexibility at the risk of overfitting. The ",(0,i.jsx)(t.code,{children:"alpha"})," parameter scales the adaptation's effect, balancing new learning and existing knowledge retention. We found ",(0,i.jsx)(t.code,{children:"r = 256"})," and ",(0,i.jsx)(t.code,{children:"alpha = 512"})," to be effective settings. For more details, see our sample YAML configuration file."]}),"\n",(0,i.jsx)(t.p,{children:"For training the model after installing the repository, you can run the following command:"}),"\n",(0,i.jsx)(t.pre,{children:(0,i.jsx)(t.code,{className:"language-js",metastring:'title="Command to train LLM with alignment handbook"',children:"ACCELERATE_LOG_LEVEL=info \\\naccelerate launch \\\n --config_file recipes/accelerate_configs/multi_gpu.yaml \\\n --num_processes=1 \\\n scripts/run_sft.py recipes/nitro/sft/config_lora.yaml\n"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Table 2. Training result of Nitro models."})}),"\n",(0,i.jsxs)(t.table,{children:[(0,i.jsx)(t.thead,{children:(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.th,{children:"Model"}),(0,i.jsx)(t.th,{children:"r"}),(0,i.jsx)(t.th,{children:"alpha"}),(0,i.jsx)(t.th,{children:"Loss"}),(0,i.jsx)(t.th,{children:"Time"})]})}),(0,i.jsxs)(t.tbody,{children:[(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E1 LoRA"}),(0,i.jsx)(t.td,{children:"16"}),(0,i.jsx)(t.td,{children:"32"}),(0,i.jsx)(t.td,{children:"1.185"}),(0,i.jsx)(t.td,{children:"3m"})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E3 LoRA"}),(0,i.jsx)(t.td,{children:"16"}),(0,i.jsx)(t.td,{children:"32"}),(0,i.jsx)(t.td,{children:"0.853"}),(0,i.jsx)(t.td,{children:"10m"})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E1 QLoRA"}),(0,i.jsx)(t.td,{children:"256"}),(0,i.jsx)(t.td,{children:"512"}),(0,i.jsx)(t.td,{children:"0.6513"}),(0,i.jsx)(t.td,{children:"6m"})]}),(0,i.jsxs)(t.tr,{children:[(0,i.jsx)(t.td,{children:"Nitro E3 QLoRA"}),(0,i.jsx)(t.td,{children:"256"}),(0,i.jsx)(t.td,{children:"512"}),(0,i.jsx)(t.td,{children:"0.3123"}),(0,i.jsx)(t.td,{children:"18m"})]})]})]}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.em,{children:"E: epochs, m: minutes"}),"\n",(0,i.jsx)(t.em,{children:"Note: Training times can vary based on hardware specifications. The provided times are for reference purposes only."})]}),"\n",(0,i.jsx)(t.h2,{id:"4-test-the-model",children:(0,i.jsx)(t.strong,{children:"4. Test the model"})}),"\n",(0,i.jsxs)(t.p,{children:["After training the model, it can be tested locally in the GGUF format using ",(0,i.jsx)(t.a,{href:"https://jan.ai/",children:"Jan"}),". To convert the fine-tuned model to GGUF, you can utilize this convenient ",(0,i.jsx)(t.a,{href:"https://colab.research.google.com/github/mlabonne/llm-course/blob/main/Quantize_Llama_2_models_using_GGUF_and_llama_cpp.ipynb",children:"Google Colab notebook by Maxime Labonne"}),"."]}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.img,{alt:"Finetuned Nitro Respond",src:n(52049).A+"",width:"719",height:"385"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Fig 2. Using Jan to run a new fine-tuned model."})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.img,{alt:"Finetuned Nitro Respond 2",src:n(19840).A+"",width:"645",height:"769"})}),"\n",(0,i.jsx)(t.p,{children:(0,i.jsx)(t.strong,{children:"Fig 3. Model answers a technical question related to Nitro."})}),"\n",(0,i.jsxs)(t.p,{children:["As shown in\xa0",(0,i.jsx)(t.code,{children:"Fig 2"}),", the model successfully learned new information from Nitro's documentation. This indicates that it accurately understands details about Nitro."]}),"\n",(0,i.jsx)(t.h2,{id:"limitations",children:"Limitations"}),"\n",(0,i.jsxs)(t.p,{children:["With this straightforward approach, we show that the model is capable of acquiring new knowledge. However, there's a potential risk of ",(0,i.jsx)(t.a,{href:"https://en.wikipedia.org/wiki/Catastrophic_interference",children:"catastrophic forgetting"}),", leading to the model only being good at answering information about Nitro documentation and losing some other abilities."]}),"\n",(0,i.jsx)(t.p,{children:"In our next blog post, we will further discuss this problem and its solution."}),"\n",(0,i.jsx)(t.h2,{id:"conclusions",children:(0,i.jsx)(t.strong,{children:"Conclusions"})}),"\n",(0,i.jsx)(t.p,{children:"In the blog post, we learn how to fine-tune an open-source model using LoRA/QLoRA with documentation of Nitro\u2019s repository on a local machine. We\u2019ve learned:"}),"\n",(0,i.jsxs)(t.ul,{children:["\n",(0,i.jsx)(t.li,{children:"Data generation using LangChain to chunk the documentation and use LLM to make QnA pairs from unstructured data."}),"\n",(0,i.jsx)(t.li,{children:"Finetuning the model on generated data using QLoRA with high r and alpha setting."}),"\n",(0,i.jsx)(t.li,{children:"Test the model using Jan."}),"\n"]}),"\n",(0,i.jsx)(t.p,{children:"Combining all those steps, we can train our model on every documentation to create our chatbot."}),"\n",(0,i.jsx)(t.h2,{id:"terminology",children:"Terminology"}),"\n",(0,i.jsx)(t.h3,{id:"what-is-instruction-tuning",children:"What is Instruction tuning?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://openai.com/research/instruction-following",children:"Instruction tuning"})," in LLMs involves refining the model's ability to comprehend and execute text-based instructions more effectively. By training on a diverse set of tasks presented as instructions, the model learns to generalize and apply its knowledge across a wide range of requests, enhancing its responsiveness and accuracy in fulfilling user commands. This process fine-tunes the model on a curated dataset where the inputs are explicit instructions and the desired outputs are model-generated responses, leading to improved performance on instruction-following tasks and a better alignment with user expectations."]}),"\n",(0,i.jsx)(t.h3,{id:"what-is-lora",children:"What is LoRA?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://arxiv.org/abs/2106.09685",children:"Low-Rank Adaptation"})," (LoRA) is a method that makes fine-tuning large language models more efficient. It breaks down the model's large weight matrices into smaller, trainable matrices. These smaller matrices are the only parts that get updated, leaving the original weights unchanged. This approach significantly reduces the number of parameters that need training, leading to faster and less memory-intensive tuning. Essentially, LoRA is a new way of training LLMs with limited resources but with a little trade-off in performance."]}),"\n",(0,i.jsx)(t.h3,{id:"what-is-langchain",children:"What is Langchain?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://www.langchain.com/",children:"LangChain"})," is an open-source framework designed to simplify the creation of applications powered by large language models (LLMs), such as chatbots and agents. Exactly like its name, it's a chaining language for developers to easily apply advanced prompt techniques to get the most out of it. It also provides developers with a standardized interface and pre-built components, making advanced language understanding and generation more accessible. By abstracting the complexities of LLM integration, LangChain enables the rapid development of intelligent, context-aware applications. Its collaborative ecosystem encourages innovation, leveraging the community's collective expertise to expand the possibilities of AI-driven solutions."]}),"\n",(0,i.jsx)(t.h3,{id:"what-is-flash-attention",children:"What is Flash Attention?"}),"\n",(0,i.jsxs)(t.p,{children:[(0,i.jsx)(t.a,{href:"https://github.com/Dao-AILab/flash-attention",children:"Flash Attention"})," is an algorithm that speeds up the core attention mechanism in Transformer language models by restructuring computations. It uses techniques like tiling and recomputation to reduce the high memory costs of attention, enabling models to process longer text sequences."]})]})}function c(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,i.jsx)(t,{...e,children:(0,i.jsx)(h,{...e})}):h(e)}},46743:(e,t,n)=>{n.d(t,{A:()=>i});const i=n.p+"assets/images/about-nitro-77d4d2ab8a69afbe7c249c9c617db8a6.png"},19840:(e,t,n)=>{n.d(t,{A:()=>i});const i=n.p+"assets/images/finetuned-respond-2-3bebfa561e4471585b412e14d605ab7a.png"},52049:(e,t,n)=>{n.d(t,{A:()=>i});const i=n.p+"assets/images/finetuned-response-f85b89b18e2705073f0632e6cd87183a.png"},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>o});var i=n(96540);const s={},a=i.createContext(s);function r(e){const t=i.useContext(a);return i.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function o(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),i.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dae9d1a4.767ff279.js b/assets/js/dae9d1a4.767ff279.js deleted file mode 100644 index 1583b975..00000000 --- a/assets/js/dae9d1a4.767ff279.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8246],{29231:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>i,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>u,toc:()=>l});var s=n(74848),o=n(28453);const a={title:"Software Consultants",tags:["audiences"]},r=void 0,u={id:"solutions/consultants",title:"Software Consultants",description:"",source:"@site/docs/solutions/consultants.md",sourceDirName:"solutions",slug:"/solutions/consultants",permalink:"/solutions/consultants",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/consultants.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Software Consultants",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Developers",permalink:"/solutions/developers"},next:{title:"Startups",permalink:"/solutions/startups"}},i={},l=[];function c(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(c,{...t})}):c()}},28453:(t,e,n)=>{n.d(e,{R:()=>r,x:()=>u});var s=n(96540);const o={},a=s.createContext(o);function r(t){const e=s.useContext(a);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function u(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),s.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/dae9d1a4.f2befd0e.js b/assets/js/dae9d1a4.f2befd0e.js new file mode 100644 index 00000000..d24c316a --- /dev/null +++ b/assets/js/dae9d1a4.f2befd0e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8246],{29231:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>i,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>u,toc:()=>l});var s=n(74848),o=n(28453);const a={title:"Software Consultants",tags:["audiences"]},r=void 0,u={id:"solutions/consultants",title:"Software Consultants",description:"",source:"@site/docs/solutions/consultants.md",sourceDirName:"solutions",slug:"/solutions/consultants",permalink:"/solutions/consultants",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/consultants.md",tags:[{label:"audiences",permalink:"/tags/audiences"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Software Consultants",tags:["audiences"]},sidebar:"solutionSidebar",previous:{title:"Developers",permalink:"/solutions/developers"},next:{title:"Startups",permalink:"/solutions/startups"}},i={},l=[];function c(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(c,{...t})}):c()}},28453:(t,e,n)=>{n.d(e,{R:()=>r,x:()=>u});var s=n(96540);const o={},a=s.createContext(o);function r(t){const e=s.useContext(a);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function u(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),s.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/db6d369b.17d5899d.js b/assets/js/db6d369b.17d5899d.js deleted file mode 100644 index f2d7d6d0..00000000 --- a/assets/js/db6d369b.17d5899d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4401],{83818:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>h,frontMatter:()=>i,metadata:()=>C,toc:()=>r});var s=e(74848),t=e(28453),g=e(64023);const i={title:"Remote Engines",slug:"/guides/engines/remote",sidebar_position:14,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},d=void 0,C={id:"guides/remote-providers/README",title:"Remote Engines",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/remote-providers/README.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/remote",permalink:"/guides/engines/remote",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:14,frontMatter:{title:"Remote Engines",slug:"/guides/engines/remote",sidebar_position:14,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},sidebar:"guidesSidebar",previous:{title:"Ollama",permalink:"/guides/engines/ollama"},next:{title:"Groq API",permalink:"/guides/engines/groq"}},l={},r=[];function F(A){return(0,s.jsx)(g.A,{})}function h(A={}){const{wrapper:a}={...(0,t.R)(),...A.components};return a?(0,s.jsx)(a,{...A,children:(0,s.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var s=e(18215),t=e(84142),g=e(20053),i=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},r="",F="",h="",n="",u="",o="",E="",B="",c="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",b="",N="",Q="",m="",O="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,g.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:s,description:t}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,g.A)("text--truncate",l.cardTitle),title:s,children:[e," ",s]}),t&&(0,L.jsx)("p",{className:(0,g.A)(l.cardDescription),title:t,children:t})]})}function q(A){let{item:a}=A;const e=(0,t.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",s=(0,t.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??s?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,t.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const g=(0,t.d1)(a);return(0,L.jsx)("section",{className:(0,s.A)("row",e),children:g.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var s=e(96540);const t={},g=s.createContext(t);function i(A){const a=s.useContext(g);return s.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(t):A.components||t:i(A.components),s.createElement(g.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/db6d369b.6ccdb7b6.js b/assets/js/db6d369b.6ccdb7b6.js new file mode 100644 index 00000000..7ace02d4 --- /dev/null +++ b/assets/js/db6d369b.6ccdb7b6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4401],{83818:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>h,frontMatter:()=>i,metadata:()=>C,toc:()=>r});var s=e(74848),t=e(28453),g=e(64023);const i={title:"Remote Engines",slug:"/guides/engines/remote",sidebar_position:14,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},d=void 0,C={id:"guides/remote-providers/README",title:"Remote Engines",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/remote-providers/README.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/remote",permalink:"/guides/engines/remote",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:14,frontMatter:{title:"Remote Engines",slug:"/guides/engines/remote",sidebar_position:14,description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build extension"]},sidebar:"guidesSidebar",previous:{title:"Ollama",permalink:"/guides/engines/ollama"},next:{title:"Groq API",permalink:"/guides/engines/groq"}},l={},r=[];function F(A){return(0,s.jsx)(g.A,{})}function h(A={}){const{wrapper:a}={...(0,t.R)(),...A.components};return a?(0,s.jsx)(a,{...A,children:(0,s.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var s=e(18215),t=e(84142),g=e(20053),i=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},r="",F="",h="",n="",u="",o="",E="",B="",c="",p="",Y="",w="",V="",R="",I="",v="",U="",W="",K="",b="",N="",Q="",m="",O="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,g.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:s,description:t}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,g.A)("text--truncate",l.cardTitle),title:s,children:[e," ",s]}),t&&(0,L.jsx)("p",{className:(0,g.A)(l.cardDescription),title:t,children:t})]})}function q(A){let{item:a}=A;const e=(0,t.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",s=(0,t.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??s?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,t.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const g=(0,t.d1)(a);return(0,L.jsx)("section",{className:(0,s.A)("row",e),children:g.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var s=e(96540);const t={},g=s.createContext(t);function i(A){const a=s.useContext(g);return s.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(t):A.components||t:i(A.components),s.createElement(g.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/db7de07b.41eef481.js b/assets/js/db7de07b.41eef481.js new file mode 100644 index 00000000..386a24ac --- /dev/null +++ b/assets/js/db7de07b.41eef481.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6100],{22787:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>o,default:()=>u,frontMatter:()=>s,metadata:()=>r,toc:()=>c});var l=i(74848),a=i(28453);const s={sidebar_position:16,slug:"/changelog/changelog-v0.2.2"},o="v0.2.2",r={id:"releases/changelog/changelog-v0.2.2",title:"v0.2.2",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.2.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.2",permalink:"/changelog/changelog-v0.2.2",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.2.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:16,frontMatter:{sidebar_position:16,slug:"/changelog/changelog-v0.2.2"},sidebar:"releasesSidebar",previous:{title:"v0.2.3",permalink:"/changelog/changelog-v0.2.3"},next:{title:"v0.2.1",permalink:"/changelog/changelog-v0.2.1"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v022",children:"v0.2.2"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.2",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/469",children:"Issue #469: chore: plugin and app version dependency"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: plugin and app version dependency @louis-jan (#469)"}),"\n",(0,l.jsx)(n.li,{children:"bug: showing a modal when user start conf but model not active @urmauur (#466)"}),"\n",(0,l.jsx)(n.li,{children:"fix: duplicated modal and loading state @louis-jan (#465)"}),"\n",(0,l.jsx)(n.li,{children:"bug: fix overflow scroll horizontal message @urmauur (#464)"}),"\n",(0,l.jsx)(n.li,{children:"bug: avoid chat body scroll horizontal @urmauur (#462)"}),"\n",(0,l.jsx)(n.li,{children:"bug: fix logic plugin update plugin and show installed version @urmauur (#459)"}),"\n",(0,l.jsx)(n.li,{children:"bug: chat view drops enumeration @urmauur (#456)"}),"\n",(0,l.jsx)(n.li,{children:"fix: allow switching models when switch between conversations @namchuai (#458)"}),"\n",(0,l.jsx)(n.li,{children:"fix: CI run fails on windows @louis-jan (#463)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to build electron app @louis-jan (#461)"}),"\n",(0,l.jsx)(n.li,{children:"fix: correct app version display @louis-jan (#452)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable link color blue on docusaurus markdown @urmauur (#449)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: Add ADR-008 for extensible Jan @vuonghoainam (#431)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"data-plugin force leveldown to 6.1.1 @hiento09 (#453)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Use electron-rebuild to build leveldown@5.6.0 for darwin arm64 @hiento09 (#455)"}),"\n",(0,l.jsx)(n.li,{children:"data-plugin force leveldown back to 5.6.0 and rebuild for darwin arm64 @hiento09 (#454)"}),"\n",(0,l.jsx)(n.li,{children:"data-plugin force leveldown to 6.1.1 @hiento09 (#453)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@hiento09, @jan-service-account, @louis-jan, @namchuai, @urmauur and @vuonghoainam"})]})}function u(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>r});var l=i(96540);const a={},s=l.createContext(a);function o(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/db7de07b.a2b9152d.js b/assets/js/db7de07b.a2b9152d.js deleted file mode 100644 index 5932d94f..00000000 --- a/assets/js/db7de07b.a2b9152d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6100],{22787:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>t,contentTitle:()=>o,default:()=>u,frontMatter:()=>s,metadata:()=>r,toc:()=>c});var l=i(74848),a=i(28453);const s={sidebar_position:16,slug:"/changelog/changelog-v0.2.2"},o="v0.2.2",r={id:"releases/changelog/changelog-v0.2.2",title:"v0.2.2",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.2.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.2",permalink:"/changelog/changelog-v0.2.2",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.2.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:16,frontMatter:{sidebar_position:16,slug:"/changelog/changelog-v0.2.2"},sidebar:"releasesSidebar",previous:{title:"v0.2.3",permalink:"/changelog/changelog-v0.2.3"},next:{title:"v0.2.1",permalink:"/changelog/changelog-v0.2.1"}},t={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v022",children:"v0.2.2"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.2",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/469",children:"Issue #469: chore: plugin and app version dependency"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: plugin and app version dependency @louis-jan (#469)"}),"\n",(0,l.jsx)(n.li,{children:"bug: showing a modal when user start conf but model not active @urmauur (#466)"}),"\n",(0,l.jsx)(n.li,{children:"fix: duplicated modal and loading state @louis-jan (#465)"}),"\n",(0,l.jsx)(n.li,{children:"bug: fix overflow scroll horizontal message @urmauur (#464)"}),"\n",(0,l.jsx)(n.li,{children:"bug: avoid chat body scroll horizontal @urmauur (#462)"}),"\n",(0,l.jsx)(n.li,{children:"bug: fix logic plugin update plugin and show installed version @urmauur (#459)"}),"\n",(0,l.jsx)(n.li,{children:"bug: chat view drops enumeration @urmauur (#456)"}),"\n",(0,l.jsx)(n.li,{children:"fix: allow switching models when switch between conversations @namchuai (#458)"}),"\n",(0,l.jsx)(n.li,{children:"fix: CI run fails on windows @louis-jan (#463)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to build electron app @louis-jan (#461)"}),"\n",(0,l.jsx)(n.li,{children:"fix: correct app version display @louis-jan (#452)"}),"\n",(0,l.jsx)(n.li,{children:"fix: enable link color blue on docusaurus markdown @urmauur (#449)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: Add ADR-008 for extensible Jan @vuonghoainam (#431)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"data-plugin force leveldown to 6.1.1 @hiento09 (#453)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Use electron-rebuild to build leveldown@5.6.0 for darwin arm64 @hiento09 (#455)"}),"\n",(0,l.jsx)(n.li,{children:"data-plugin force leveldown back to 5.6.0 and rebuild for darwin arm64 @hiento09 (#454)"}),"\n",(0,l.jsx)(n.li,{children:"data-plugin force leveldown to 6.1.1 @hiento09 (#453)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@hiento09, @jan-service-account, @louis-jan, @namchuai, @urmauur and @vuonghoainam"})]})}function u(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>o,x:()=>r});var l=i(96540);const a={},s=l.createContext(a);function o(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dbb31ac1.951e07a9.js b/assets/js/dbb31ac1.951e07a9.js new file mode 100644 index 00000000..0c232117 --- /dev/null +++ b/assets/js/dbb31ac1.951e07a9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5406],{97804:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>t,metadata:()=>o,toc:()=>d});var i=s(74848),a=s(28453);const t={title:"User Interface",slug:"/developer/ui",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","UI kit"]},r=void 0,o={id:"developer/overview/user-interface",title:"User Interface",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/03-user-interface.md",sourceDirName:"developer/01-overview",slug:"/developer/ui",permalink:"/developer/ui",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/03-user-interface.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:3,frontMatter:{title:"User Interface",slug:"/developer/ui",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","UI kit"]},sidebar:"developerSidebar",previous:{title:"File-based Approach",permalink:"/developer/file-based"},next:{title:"Installation and Prerequisites",permalink:"/developer/prereq"}},l={},d=[{value:"Views",id:"views",level:2},{value:"Ribbon",id:"ribbon",level:3},{value:"LeftSidebar",id:"leftsidebar",level:3},{value:"Main",id:"main",level:3},{value:"RightSidebar",id:"rightsidebar",level:3},{value:"StatusBar",id:"statusbar",level:3}];function c(e){const n={admonition:"admonition",code:"code",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",pre:"pre",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsx)(n.p,{children:"This page is still under construction, and should be read as a scratchpad"})}),"\n",(0,i.jsx)(n.p,{children:"Jan provides a UI Kit for customize the UI for your use case. This means you can personalize the entire application according to your own brand and visual styles."}),"\n",(0,i.jsx)(n.p,{children:"This page gives you an overview of how to customize the UI."}),"\n",(0,i.jsx)(n.p,{children:"You can see some of the user interface components when you first open Jan."}),"\n",(0,i.jsx)(n.p,{children:"To Link:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Ribbon"}),"\n",(0,i.jsx)(n.li,{children:"LeftSidebar"}),"\n",(0,i.jsx)(n.li,{children:"Main"}),"\n",(0,i.jsx)(n.li,{children:"RightSidebar"}),"\n",(0,i.jsx)(n.li,{children:"StatusBar"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"views",children:"Views"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.img,{alt:"Jan Views",src:s(2743).A+"",width:"1396",height:"766"}),"\nTODO: add a better image."]}),"\n",(0,i.jsx)(n.h3,{id:"ribbon",children:"Ribbon"}),"\n",(0,i.jsx)(n.p,{children:"Assistants shortcuts and Modules settings show up here."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"leftsidebar",children:"LeftSidebar"}),"\n",(0,i.jsx)(n.p,{children:"Conversation threads show up here. This is customizable, so custom assistants can add additional menu items here."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"main",children:"Main"}),"\n",(0,i.jsx)(n.p,{children:"The main view for interacting with assistants. This is customizable, so custom assistants can add in additional UI components. By default, this is a chat thread with assistants."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"rightsidebar",children:"RightSidebar"}),"\n",(0,i.jsx)(n.p,{children:'A "settings" view for each thread. Users should be able to edit settings or other configs to customize the assistant experience within each thread.'}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"statusbar",children:"StatusBar"}),"\n",(0,i.jsx)(n.p,{children:"A global status bar that shows processes, hardware/disk utilization and more."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},2743:(e,n,s)=>{s.d(n,{A:()=>i});const i=s.p+"assets/images/jan-views-8a6b71fb089ec16a059f4f0f49814ce0.png"},28453:(e,n,s)=>{s.d(n,{R:()=>r,x:()=>o});var i=s(96540);const a={},t=i.createContext(a);function r(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dbb31ac1.d3b04a4c.js b/assets/js/dbb31ac1.d3b04a4c.js deleted file mode 100644 index 0bd7b2bb..00000000 --- a/assets/js/dbb31ac1.d3b04a4c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5406],{97804:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>t,metadata:()=>o,toc:()=>d});var i=s(74848),a=s(28453);const t={title:"User Interface",slug:"/developer/ui",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","UI kit"]},r=void 0,o={id:"developer/overview/user-interface",title:"User Interface",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/03-user-interface.md",sourceDirName:"developer/01-overview",slug:"/developer/ui",permalink:"/developer/ui",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/03-user-interface.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:3,frontMatter:{title:"User Interface",slug:"/developer/ui",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","UI kit"]},sidebar:"developerSidebar",previous:{title:"File-based Approach",permalink:"/developer/file-based"},next:{title:"Installation and Prerequisites",permalink:"/developer/prereq"}},l={},d=[{value:"Views",id:"views",level:2},{value:"Ribbon",id:"ribbon",level:3},{value:"LeftSidebar",id:"leftsidebar",level:3},{value:"Main",id:"main",level:3},{value:"RightSidebar",id:"rightsidebar",level:3},{value:"StatusBar",id:"statusbar",level:3}];function c(e){const n={admonition:"admonition",code:"code",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",pre:"pre",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsx)(n.p,{children:"This page is still under construction, and should be read as a scratchpad"})}),"\n",(0,i.jsx)(n.p,{children:"Jan provides a UI Kit for customize the UI for your use case. This means you can personalize the entire application according to your own brand and visual styles."}),"\n",(0,i.jsx)(n.p,{children:"This page gives you an overview of how to customize the UI."}),"\n",(0,i.jsx)(n.p,{children:"You can see some of the user interface components when you first open Jan."}),"\n",(0,i.jsx)(n.p,{children:"To Link:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Ribbon"}),"\n",(0,i.jsx)(n.li,{children:"LeftSidebar"}),"\n",(0,i.jsx)(n.li,{children:"Main"}),"\n",(0,i.jsx)(n.li,{children:"RightSidebar"}),"\n",(0,i.jsx)(n.li,{children:"StatusBar"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"views",children:"Views"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.img,{alt:"Jan Views",src:s(2743).A+"",width:"1396",height:"766"}),"\nTODO: add a better image."]}),"\n",(0,i.jsx)(n.h3,{id:"ribbon",children:"Ribbon"}),"\n",(0,i.jsx)(n.p,{children:"Assistants shortcuts and Modules settings show up here."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"leftsidebar",children:"LeftSidebar"}),"\n",(0,i.jsx)(n.p,{children:"Conversation threads show up here. This is customizable, so custom assistants can add additional menu items here."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"main",children:"Main"}),"\n",(0,i.jsx)(n.p,{children:"The main view for interacting with assistants. This is customizable, so custom assistants can add in additional UI components. By default, this is a chat thread with assistants."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"rightsidebar",children:"RightSidebar"}),"\n",(0,i.jsx)(n.p,{children:'A "settings" view for each thread. Users should be able to edit settings or other configs to customize the assistant experience within each thread.'}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})}),"\n",(0,i.jsx)(n.h3,{id:"statusbar",children:"StatusBar"}),"\n",(0,i.jsx)(n.p,{children:"A global status bar that shows processes, hardware/disk utilization and more."}),"\n",(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-js",children:'import .. from "@jan"\nsample code here\n'})})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},2743:(e,n,s)=>{s.d(n,{A:()=>i});const i=s.p+"assets/images/jan-views-8a6b71fb089ec16a059f4f0f49814ce0.png"},28453:(e,n,s)=>{s.d(n,{R:()=>r,x:()=>o});var i=s(96540);const a={},t=i.createContext(a);function r(e){const n=i.useContext(t);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),i.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dc051efd.65bf3f72.js b/assets/js/dc051efd.65bf3f72.js new file mode 100644 index 00000000..4dbf2976 --- /dev/null +++ b/assets/js/dc051efd.65bf3f72.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8429],{21999:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>i,metadata:()=>s,toc:()=>c});var r=t(74848),a=t(28453);const i={title:"Chats",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,s={id:"developer/framework/engineering/chats",title:"Chats",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/chats.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/chats",permalink:"/developer/framework/engineering/chats",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/chats.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Chats",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Assistants",permalink:"/developer/framework/engineering/assistants"},next:{title:"Engine",permalink:"/developer/framework/engineering/engine"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"API Reference",id:"api-reference",level:2},{value:"Implementation",id:"implementation",level:2}];function d(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsxs)(n.p,{children:["In Jan, ",(0,r.jsx)(n.code,{children:"chats"})," are LLM responses in the form of OpenAI compatible ",(0,r.jsx)(n.code,{children:"chat completion objects"}),"."]}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Models take a list of messages and return a model-generated response as output."}),"\n",(0,r.jsxs)(n.li,{children:["An ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/chat",children:"OpenAI Chat API"})," compatible endpoint at ",(0,r.jsx)(n.code,{children:"localhost:1337/v1/chats"}),"."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,r.jsxs)(n.p,{children:["Chats are stateless, thus are not saved in ",(0,r.jsx)(n.code,{children:"janroot"}),". Any content and relevant metadata from calling this endpoint is extracted and persisted through ",(0,r.jsx)(n.a,{href:"/docs/engineering/messages",children:"Messages"}),"."]}),"\n",(0,r.jsx)(n.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,r.jsxs)(n.p,{children:["Jan's Chat API is compatible with ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/chat",children:"OpenAI's Chat API"}),"."]}),"\n",(0,r.jsxs)(n.p,{children:["See ",(0,r.jsx)(n.a,{href:"https://jan.ai/api-reference/#tag/Chat-Completion",children:"Jan Chat API"})]}),"\n",(0,r.jsx)(n.h2,{id:"implementation",children:"Implementation"}),"\n",(0,r.jsxs)(n.p,{children:["Under the hood, the ",(0,r.jsx)(n.code,{children:"/chat"})," endpoint simply reroutes an existing endpoint from ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai",children:"Nitro server"}),". Nitro is a lightweight & local inference server, written in C++ and embedded into the Jan app. See ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/docs",children:"Nitro documentation"}),"."]})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>s});var r=t(96540);const a={},i=r.createContext(a);function o(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dc051efd.7bcb5c7f.js b/assets/js/dc051efd.7bcb5c7f.js deleted file mode 100644 index 9ea7e858..00000000 --- a/assets/js/dc051efd.7bcb5c7f.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8429],{21999:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>i,metadata:()=>s,toc:()=>c});var r=t(74848),a=t(28453);const i={title:"Chats",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,s={id:"developer/framework/engineering/chats",title:"Chats",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/chats.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/chats",permalink:"/developer/framework/engineering/chats",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/chats.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Chats",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Assistants",permalink:"/developer/framework/engineering/assistants"},next:{title:"Engine",permalink:"/developer/framework/engineering/engine"}},l={},c=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"API Reference",id:"api-reference",level:2},{value:"Implementation",id:"implementation",level:2}];function d(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(n.admonition,{type:"caution",children:(0,r.jsx)(n.p,{children:"This is currently under development."})}),"\n",(0,r.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,r.jsxs)(n.p,{children:["In Jan, ",(0,r.jsx)(n.code,{children:"chats"})," are LLM responses in the form of OpenAI compatible ",(0,r.jsx)(n.code,{children:"chat completion objects"}),"."]}),"\n",(0,r.jsxs)(n.ul,{children:["\n",(0,r.jsx)(n.li,{children:"Models take a list of messages and return a model-generated response as output."}),"\n",(0,r.jsxs)(n.li,{children:["An ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/chat",children:"OpenAI Chat API"})," compatible endpoint at ",(0,r.jsx)(n.code,{children:"localhost:1337/v1/chats"}),"."]}),"\n"]}),"\n",(0,r.jsx)(n.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,r.jsxs)(n.p,{children:["Chats are stateless, thus are not saved in ",(0,r.jsx)(n.code,{children:"janroot"}),". Any content and relevant metadata from calling this endpoint is extracted and persisted through ",(0,r.jsx)(n.a,{href:"/docs/engineering/messages",children:"Messages"}),"."]}),"\n",(0,r.jsx)(n.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,r.jsxs)(n.p,{children:["Jan's Chat API is compatible with ",(0,r.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/chat",children:"OpenAI's Chat API"}),"."]}),"\n",(0,r.jsxs)(n.p,{children:["See ",(0,r.jsx)(n.a,{href:"https://jan.ai/api-reference/#tag/Chat-Completion",children:"Jan Chat API"})]}),"\n",(0,r.jsx)(n.h2,{id:"implementation",children:"Implementation"}),"\n",(0,r.jsxs)(n.p,{children:["Under the hood, the ",(0,r.jsx)(n.code,{children:"/chat"})," endpoint simply reroutes an existing endpoint from ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai",children:"Nitro server"}),". Nitro is a lightweight & local inference server, written in C++ and embedded into the Jan app. See ",(0,r.jsx)(n.a,{href:"https://nitro.jan.ai/docs",children:"Nitro documentation"}),"."]})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,r.jsx)(n,{...e,children:(0,r.jsx)(d,{...e})}):d(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>s});var r=t(96540);const a={},i=r.createContext(a);function o(e){const n=r.useContext(i);return r.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),r.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dc1725da.4a8ae00c.js b/assets/js/dc1725da.4a8ae00c.js new file mode 100644 index 00000000..7bd65086 --- /dev/null +++ b/assets/js/dc1725da.4a8ae00c.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1722],{40446:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>u,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>c,toc:()=>i});var o=n(74848),r=n(28453);const s={title:"Jan Hub"},a=void 0,c={id:"platforms/hub",title:"Jan Hub",description:"",source:"@site/docs/platforms/hub.md",sourceDirName:"platforms",slug:"/platforms/hub",permalink:"/platforms/hub",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/platforms/hub.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan Hub"}},u={},i=[];function d(t){return(0,o.jsx)(o.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(d,{...t})}):d()}},28453:(t,e,n)=>{n.d(e,{R:()=>a,x:()=>c});var o=n(96540);const r={},s=o.createContext(r);function a(t){const e=o.useContext(s);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:a(t.components),o.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/dc1725da.bf3c1d9a.js b/assets/js/dc1725da.bf3c1d9a.js deleted file mode 100644 index 9042a236..00000000 --- a/assets/js/dc1725da.bf3c1d9a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1722],{40446:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>u,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>c,toc:()=>i});var o=n(74848),r=n(28453);const s={title:"Jan Hub"},a=void 0,c={id:"platforms/hub",title:"Jan Hub",description:"",source:"@site/docs/platforms/hub.md",sourceDirName:"platforms",slug:"/platforms/hub",permalink:"/platforms/hub",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/platforms/hub.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan Hub"}},u={},i=[];function d(t){return(0,o.jsx)(o.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(d,{...t})}):d()}},28453:(t,e,n)=>{n.d(e,{R:()=>a,x:()=>c});var o=n(96540);const r={},s=o.createContext(r);function a(t){const e=o.useContext(s);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:a(t.components),o.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/dfd62110.44564d28.js b/assets/js/dfd62110.44564d28.js deleted file mode 100644 index a0239ed6..00000000 --- a/assets/js/dfd62110.44564d28.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6895],{68868:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>h,contentTitle:()=>r,default:()=>d,frontMatter:()=>s,metadata:()=>o,toc:()=>l});var i=t(74848),a=t(28453);const s={title:"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B",description:"Creating Open Source Alternatives to Outperform ChatGPT",slug:"/blog/surpassing-chatgpt-with-open-source-alternatives",tags:["Open Source ChatGPT Alternatives","Outperform ChatGPT"],authors:["hahuyhoang411","0xsage","automaticcat"],date:new Date("2024-03-17T00:00:00.000Z")},r=void 0,o={id:"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives",title:"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B",description:"Creating Open Source Alternatives to Outperform ChatGPT",source:"@site/docs/pending-content/blogpost/02-surpassing-chatgpt-with-open-source-alternatives.mdx",sourceDirName:"pending-content/blogpost",slug:"/blog/surpassing-chatgpt-with-open-source-alternatives",permalink:"/blog/surpassing-chatgpt-with-open-source-alternatives",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/pending-content/blogpost/02-surpassing-chatgpt-with-open-source-alternatives.mdx",tags:[{label:"Open Source ChatGPT Alternatives",permalink:"/tags/open-source-chat-gpt-alternatives"},{label:"Outperform ChatGPT",permalink:"/tags/outperform-chat-gpt"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B",description:"Creating Open Source Alternatives to Outperform ChatGPT",slug:"/blog/surpassing-chatgpt-with-open-source-alternatives",tags:["Open Source ChatGPT Alternatives","Outperform ChatGPT"],authors:["hahuyhoang411","0xsage","automaticcat"],date:"2024-03-17T00:00:00.000Z"}},h={},l=[{value:"Abstract",id:"abstract",level:2},{value:"Selecting a Strong Foundation Model",id:"selecting-a-strong-foundation-model",level:2},{value:"Cost-Effectively Improving the Base Model",id:"cost-effectively-improving-the-base-model",level:2},{value:"DPO Finetuning",id:"dpo-finetuning",level:2},{value:"Using Our Technical Documentation",id:"using-our-technical-documentation",level:2},{value:"Generating a Training Dataset for GPT-4",id:"generating-a-training-dataset-for-gpt-4",level:2},{value:"Training",id:"training",level:2},{value:"Improving Results With Rag",id:"improving-results-with-rag",level:2},{value:"Benchmarking the Results",id:"benchmarking-the-results",level:2},{value:"Conclusion",id:"conclusion",level:2},{value:"References",id:"references",level:2}];function c(e){const n={a:"a",code:"code",em:"em",h2:"h2",img:"img",li:"li",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"abstract",children:"Abstract"}),"\n",(0,i.jsxs)(n.p,{children:["We present a straightforward approach to adapting small, open-source models for specialized use cases, that can surpass GPT 3.5 performance with RAG. With it, we were able to get superior results on Q&A over ",(0,i.jsx)(n.a,{href:"https://nitro.jan.ai/docs",children:"technical documentation"})," describing a small ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"codebase"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["In short, (3) extending a general foundation model like ",(0,i.jsx)(n.a,{href:"https://huggingface.co/mistralai/Mistral-7B-v0.1",children:"Mistral"})," with strong math and coding, and (7) training it over a high-quality, synthetic dataset generated from the intended corpus, and (2) adding RAG capabilities, can lead to significant accuracy improvements."]}),"\n",(0,i.jsx)(n.p,{children:"Problems still arise with catastrophic forgetting in general tasks, commonly observed during specialized domain fine-tuning. In our case, this is likely exacerbated by our lack of access to Mistral\u2019s original training dataset and various compression techniques used in our approach to keep the model small."}),"\n",(0,i.jsx)(n.h2,{id:"selecting-a-strong-foundation-model",children:"Selecting a Strong Foundation Model"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://huggingface.co/mistralai/Mistral-7B-v0.1",children:"Mistral 7B"})," outshines both ",(0,i.jsx)(n.a,{href:"https://huggingface.co/meta-llama/Llama-2-7b",children:"Meta's Llama-2 7B"})," and ",(0,i.jsx)(n.a,{href:"https://huggingface.co/google/gemma-7b",children:"Google's Gemma 7B"})," in key benchmarks, making it our choice for a base model. Starting with a strong foundation like Mistral allowed us to achieve greater accuracy in our specialized adaptations."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Mistral vs LLama vs Gemma",src:t(5760).A+"",width:"1489",height:"790"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 1."})," Mistral 7B excels in benchmarks, ranking among the top foundational models."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsxs)(n.em,{children:["Note: we are not sponsored by the Mistral team. Though many folks in their community do like to run Mistral locally using our desktop client - ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"cost-effectively-improving-the-base-model",children:"Cost-Effectively Improving the Base Model"}),"\n",(0,i.jsx)(n.p,{children:"Mistral alone has known, poor math capabilities, which we needed for our highly technical use case. Thus, we tested all model variants on top of Mistral, from foundation models to finetunes to model merges, in order to find a stronger base model to receive our own finetuning."}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Merged model vs finetuned models",src:t(11793).A+"",width:"1490",height:"790"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 2."})," The merged model, Stealth, doubles the mathematical capabilities of its foundational model while retaining the performance in other tasks."]}),"\n",(0,i.jsx)(n.p,{children:"We found merging models is quick and cost-effective, enabling fast adjustments based on the result of each iteration."}),"\n",(0,i.jsxs)(n.p,{children:["We ended up with ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/stealth-v1.1",children:"Stealth 7B v1.1"}),", a ",(0,i.jsx)(n.a,{href:"https://github.com/Digitous/LLM-SLERP-Merge",children:"SLERP"})," merge of Mistral with the following:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://huggingface.co/WizardLM/WizardMath-7B-V1.1",children:"WizardMath"})," for its math capabilities."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://huggingface.co/WizardLM/WizardCoder-Python-7B-V1.0",children:"WizardCoder"})," for its coding capabilities."]}),"\n",(0,i.jsxs)(n.li,{children:["Our own ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/trinity-v1.2",children:"Trinity"})," model for its versatility across general tasks."]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:"This particular combination yielded the best tradeoff across mathematical & technical reasoning while retaining the most pre-merge performance on general tasks."}),"\n",(0,i.jsx)(n.h2,{id:"dpo-finetuning",children:"DPO Finetuning"}),"\n",(0,i.jsx)(n.p,{children:"Merging different LLMs can lead to a mixed answering style because each model was originally trained on different types of data."}),"\n",(0,i.jsxs)(n.p,{children:["Thus, we applied Direct Preference Optimization (",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2305.18290",children:"DPO"}),") using the ",(0,i.jsx)(n.a,{href:"https://huggingface.co/datasets/Intel/orca_dpo_pairs",children:"Intel's Orca DPO pairs"})," dataset, chosen for its helpful answering style in general, math and coding concentration."]}),"\n",(0,i.jsxs)(n.p,{children:["This approach results in a final model - ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/stealth-v1.2",children:"Stealth 7B v1.2"}),", with minimal loss, and realign to our technical preferences."]}),"\n",(0,i.jsx)(n.h2,{id:"using-our-technical-documentation",children:"Using Our Technical Documentation"}),"\n",(0,i.jsx)(n.p,{children:"With the base model ready, we started on our specific use case."}),"\n",(0,i.jsx)(n.p,{children:"Jan is an open-source & bootstrapped project - at one point during our unanticipated growth, we received 1 customer support ticket per minute, with no one to handle customer service."}),"\n",(0,i.jsx)(n.p,{children:"So, we directed our efforts toward training a model to answer user questions based on existing technical documentation."}),"\n",(0,i.jsxs)(n.p,{children:["Specifically, we trained it on Nitro ",(0,i.jsx)(n.a,{href:"https://nitro.jan.ai/docs",children:"docs"}),". For context, Nitro is the default inference engine for Jan. It\u2019s a serious server implementation of LlamaCPP, written in C++, with multimodal, queues, and other production-level server capabilities."]}),"\n",(0,i.jsx)(n.p,{children:"It made an interesting corpus because it was rife with post-2023 technical jargon, edge cases, and poor informational layout."}),"\n",(0,i.jsx)(n.h2,{id:"generating-a-training-dataset-for-gpt-4",children:"Generating a Training Dataset for GPT-4"}),"\n",(0,i.jsxs)(n.p,{children:["The first step was to transform Nitro\u2019s unstructured format into a synthetic Q&A dataset designed for ",(0,i.jsx)(n.a,{href:"https://arxiv.org/pdf/2109.01652.pdf",children:"instruction tuning"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["The text was split into chunks of 300-token segments with 30-token overlaps. This helped to avoid a ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2307.03172",children:"lost-in-the-middle"})," problem where LLM can\u2019t use context efficiently to answer given questions."]}),"\n",(0,i.jsxs)(n.p,{children:["The chunks were then given to GPT-4 with 8k context length to generate 3800 Q&A pairs. The ",(0,i.jsx)(n.a,{href:"https://huggingface.co/datasets/jan-hq/nitro_binarized_v2",children:"training dataset"})," is available on HuggingFace."]}),"\n",(0,i.jsx)(n.h2,{id:"training",children:"Training"}),"\n",(0,i.jsxs)(n.p,{children:["The training was done with supervised finetuning (SFT) from the ",(0,i.jsx)(n.a,{href:"https://github.com/huggingface/alignment-handbook",children:"Hugging Face's alignment handbook"})," based on the ",(0,i.jsx)(n.a,{href:"https://github.com/huggingface/alignment-handbook/tree/main/recipes/zephyr-7b-beta",children:"Huggingface's Zephyr Beta"})," guidelines."]}),"\n",(0,i.jsxs)(n.p,{children:["We used consumer-grade, dual Nvidia RTX 4090s for the training. The end-to-end training took 18 minutes. We found optimal hyperparameters in LoRA for this specific task to be ",(0,i.jsx)(n.code,{children:"r = 256"})," and ",(0,i.jsx)(n.code,{children:"alpha = 512"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["This final model is publicly available at ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/nitro-v1.2-e3",children:"https://huggingface.co/jan-hq/nitro-v1.2-e3"}),"."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Using LLM locally",src:t(70595).A+"",width:"1607",height:"896"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 3."})," Using the new finetuned model in ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"improving-results-with-rag",children:"Improving Results With Rag"}),"\n",(0,i.jsxs)(n.p,{children:["As an additional step, we also added ",(0,i.jsx)(n.a,{href:"https://blogs.nvidia.com/blog/what-is-retrieval-augmented-generation/",children:"Retrieval Augmented Generation (RAG)"})," as an experiment parameter."]}),"\n",(0,i.jsxs)(n.p,{children:["A simple RAG setup was done using ",(0,i.jsx)(n.strong,{children:(0,i.jsx)(n.a,{href:"https://www.llamaindex.ai/",children:"Llamaindex"})})," and the ",(0,i.jsx)(n.strong,{children:(0,i.jsx)(n.a,{href:"https://huggingface.co/BAAI/bge-base-en-v1.5",children:"bge-en-base-v1.5 embedding"})})," model for efficient documentation retrieval and question-answering. The RAG implementation is publicly available at at ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/rag/nitro_rag.ipynb",children:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/rag/nitro_rag.ipynb"})]}),"\n",(0,i.jsx)(n.h2,{id:"benchmarking-the-results",children:"Benchmarking the Results"}),"\n",(0,i.jsxs)(n.p,{children:["We curated a new set of ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/rag/mcq_nitro.csv",children:"50 multiple-choice questions"})," (MCQ) based on the Nitro docs. The questions had varying levels of difficulty and had trick components that challenged the model's ability to discern misleading information."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Opensource model outperforms GPT",src:t(90190).A+"",width:"1189",height:"590"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 4."})," Comparison between fine-tuned model and OpenAI's GPT."]}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Table 1."})," Result of Benchmarking Different Model With RAG."]}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{children:"Approach"}),(0,i.jsx)(n.th,{children:"Performance"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"GPT-3.5 with RAG"}),(0,i.jsx)(n.td,{children:"56.7%"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"GPT-4 with RAG"}),(0,i.jsx)(n.td,{children:"64.3%"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsxs)(n.td,{children:["Merged 7B Model (",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/stealth-v1.3",children:"Stealth 7B"}),") with RAG"]}),(0,i.jsx)(n.td,{children:"47.7%"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Finetuned 7B Model (Nitro 7B) with RAG"}),(0,i.jsx)(n.td,{children:"57.8%"})]})]})]}),"\n",(0,i.jsx)(n.p,{children:"This indicates that with task-specific training, we can improve an open-source, Small Language Model to the level of GPT-3.5 on domain knowledge."}),"\n",(0,i.jsx)(n.p,{children:"Notably, the finetuned with RAG approach also demonstrated more consistency across benchmarking, as indicated by its lower standard deviation."}),"\n",(0,i.jsx)(n.h2,{id:"conclusion",children:"Conclusion"}),"\n",(0,i.jsx)(n.p,{children:"We conclude that this combination of model merging finetuning and RAG yields promise. This finding is relevant for teams and individuals that need specialized, technical SLMs that need to run in resource-constrained or highly secured environments, where GPT may not be an option."}),"\n",(0,i.jsx)(n.p,{children:"Anecdotally, we\u2019ve had some success using this model in practice to onboard new team members to the Nitro codebase."}),"\n",(0,i.jsxs)(n.p,{children:["A full research report with more statistics can be found at ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/README.md",children:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/README.md"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"references",children:"References"}),"\n",(0,i.jsxs)(n.p,{children:["[1] Jason Wei, Maarten Bosma, Vincent Y. Zhao, Kelvin Guu, Adams Wei Yu, Brian Lester, Nan Du, Andrew M. Dai, Quoc V. Le. Finetuned Language Models Are Zero-Shot Learners. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2109.01652"}),", 2021. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2109.01652",children:"https://arxiv.org/abs/2109.01652"})]}),"\n",(0,i.jsxs)(n.p,{children:["[2] Haipeng Luo, Qingfeng Sun, Can Xu, Pu Zhao, Jianguang Lou, Chongyang Tao, Xiubo Geng, Qingwei Lin, Shifeng Chen, Dongmei Zhang. WizardMath: Empowering Mathematical Reasoning for Large Language Models via Reinforced Evol-Instruct. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2308.09583"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2308.09583",children:"https://arxiv.org/abs/2308.09583"})]}),"\n",(0,i.jsxs)(n.p,{children:["[3] Luo, Y., Yang, Z., Meng, F., Li, Y., Zhou, J., & Zhang, Y. An Empirical Study of Catastrophic Forgetting in Large Language Models During Continual Fine-tuning. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2308.08747"}),",2023 URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2308.08747",children:"https://arxiv.org/abs/2308.08747"})]}),"\n",(0,i.jsxs)(n.p,{children:["[4] Ziyang Luo, Can Xu, Pu Zhao, Qingfeng Sun, Xiubo Geng, Wenxiang Hu, Chongyang Tao, Jing Ma, Qingwei Lin, Daxin Jiang. WizardCoder: Empowering Code Large Language Models with Evol-Instruct., ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2306.08568"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2306.08568",children:"https://arxiv.org/abs/2306.08568"})]}),"\n",(0,i.jsxs)(n.p,{children:["[5] SciPhi-AI, Agent Search. GitHub. URL: ",(0,i.jsx)(n.a,{href:"https://github.com/SciPhi-AI/agent-search",children:"https://github.com/SciPhi-AI/agent-search"})]}),"\n",(0,i.jsxs)(n.p,{children:['[6] Nelson F. Liu, Kevin Lin, John Hewitt, Ashwin Paranjape, Michele Bevilacqua, Fabio Petroni, Percy Liang. "Lost in the Middle: How Language Models Use Long Contexts." ',(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2307.03172"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2307.03172",children:"https://arxiv.org/abs/2307.03172"})]}),"\n",(0,i.jsxs)(n.p,{children:["[7] Luo, H., Sun, Q., Xu, C., Zhao, P., Lou, J., Tao, C., Geng, X., Lin, Q., Chen, S., & Zhang, D. WizardMath: Empowering Mathematical Reasoning for Large Language Models via Reinforced Evol-Instruct. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2308.09583"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2308.09583",children:"https://arxiv.org/abs/2308.09583"})]}),"\n",(0,i.jsxs)(n.p,{children:["[8] nlpxucan et al., WizardLM. GitHub. URL: ",(0,i.jsx)(n.a,{href:"https://github.com/nlpxucan/WizardLM",children:"https://github.com/nlpxucan/WizardLM"})]})]})}function d(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},5760:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/mistral-comparasion-8c8400408787c7a3a85d1072ab545a1d.png"},70595:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/nitro-on-jan-a26977d030ddcda2ca3e9fb868a8a49c.png"},90190:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/rag-comparasion-d1d1d6f9838abb8f707117cfdfee24d2.png"},11793:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/stealth-comparasion-e4f7494c465c9eaecee0fb2d0997eb1c.png"},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>o});var i=t(96540);const a={},s=i.createContext(a);function r(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/dfd62110.d8dfa17e.js b/assets/js/dfd62110.d8dfa17e.js new file mode 100644 index 00000000..15073d74 --- /dev/null +++ b/assets/js/dfd62110.d8dfa17e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6895],{68868:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>h,contentTitle:()=>r,default:()=>d,frontMatter:()=>s,metadata:()=>o,toc:()=>l});var i=t(74848),a=t(28453);const s={title:"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B",description:"Creating Open Source Alternatives to Outperform ChatGPT",slug:"/blog/surpassing-chatgpt-with-open-source-alternatives",tags:["Open Source ChatGPT Alternatives","Outperform ChatGPT"],authors:["hahuyhoang411","0xsage","automaticcat"],date:new Date("2024-03-17T00:00:00.000Z")},r=void 0,o={id:"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives",title:"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B",description:"Creating Open Source Alternatives to Outperform ChatGPT",source:"@site/docs/pending-content/blogpost/02-surpassing-chatgpt-with-open-source-alternatives.mdx",sourceDirName:"pending-content/blogpost",slug:"/blog/surpassing-chatgpt-with-open-source-alternatives",permalink:"/blog/surpassing-chatgpt-with-open-source-alternatives",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/pending-content/blogpost/02-surpassing-chatgpt-with-open-source-alternatives.mdx",tags:[{label:"Open Source ChatGPT Alternatives",permalink:"/tags/open-source-chat-gpt-alternatives"},{label:"Outperform ChatGPT",permalink:"/tags/outperform-chat-gpt"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"Rag Is Not Enough: Lessons from Beating GPT-3.5 on Specialized Tasks with Mistral 7B",description:"Creating Open Source Alternatives to Outperform ChatGPT",slug:"/blog/surpassing-chatgpt-with-open-source-alternatives",tags:["Open Source ChatGPT Alternatives","Outperform ChatGPT"],authors:["hahuyhoang411","0xsage","automaticcat"],date:"2024-03-17T00:00:00.000Z"}},h={},l=[{value:"Abstract",id:"abstract",level:2},{value:"Selecting a Strong Foundation Model",id:"selecting-a-strong-foundation-model",level:2},{value:"Cost-Effectively Improving the Base Model",id:"cost-effectively-improving-the-base-model",level:2},{value:"DPO Finetuning",id:"dpo-finetuning",level:2},{value:"Using Our Technical Documentation",id:"using-our-technical-documentation",level:2},{value:"Generating a Training Dataset for GPT-4",id:"generating-a-training-dataset-for-gpt-4",level:2},{value:"Training",id:"training",level:2},{value:"Improving Results With Rag",id:"improving-results-with-rag",level:2},{value:"Benchmarking the Results",id:"benchmarking-the-results",level:2},{value:"Conclusion",id:"conclusion",level:2},{value:"References",id:"references",level:2}];function c(e){const n={a:"a",code:"code",em:"em",h2:"h2",img:"img",li:"li",p:"p",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"abstract",children:"Abstract"}),"\n",(0,i.jsxs)(n.p,{children:["We present a straightforward approach to adapting small, open-source models for specialized use cases, that can surpass GPT 3.5 performance with RAG. With it, we were able to get superior results on Q&A over ",(0,i.jsx)(n.a,{href:"https://nitro.jan.ai/docs",children:"technical documentation"})," describing a small ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"codebase"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["In short, (3) extending a general foundation model like ",(0,i.jsx)(n.a,{href:"https://huggingface.co/mistralai/Mistral-7B-v0.1",children:"Mistral"})," with strong math and coding, and (7) training it over a high-quality, synthetic dataset generated from the intended corpus, and (2) adding RAG capabilities, can lead to significant accuracy improvements."]}),"\n",(0,i.jsx)(n.p,{children:"Problems still arise with catastrophic forgetting in general tasks, commonly observed during specialized domain fine-tuning. In our case, this is likely exacerbated by our lack of access to Mistral\u2019s original training dataset and various compression techniques used in our approach to keep the model small."}),"\n",(0,i.jsx)(n.h2,{id:"selecting-a-strong-foundation-model",children:"Selecting a Strong Foundation Model"}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.a,{href:"https://huggingface.co/mistralai/Mistral-7B-v0.1",children:"Mistral 7B"})," outshines both ",(0,i.jsx)(n.a,{href:"https://huggingface.co/meta-llama/Llama-2-7b",children:"Meta's Llama-2 7B"})," and ",(0,i.jsx)(n.a,{href:"https://huggingface.co/google/gemma-7b",children:"Google's Gemma 7B"})," in key benchmarks, making it our choice for a base model. Starting with a strong foundation like Mistral allowed us to achieve greater accuracy in our specialized adaptations."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Mistral vs LLama vs Gemma",src:t(5760).A+"",width:"1489",height:"790"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 1."})," Mistral 7B excels in benchmarks, ranking among the top foundational models."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsxs)(n.em,{children:["Note: we are not sponsored by the Mistral team. Though many folks in their community do like to run Mistral locally using our desktop client - ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"cost-effectively-improving-the-base-model",children:"Cost-Effectively Improving the Base Model"}),"\n",(0,i.jsx)(n.p,{children:"Mistral alone has known, poor math capabilities, which we needed for our highly technical use case. Thus, we tested all model variants on top of Mistral, from foundation models to finetunes to model merges, in order to find a stronger base model to receive our own finetuning."}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Merged model vs finetuned models",src:t(11793).A+"",width:"1490",height:"790"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 2."})," The merged model, Stealth, doubles the mathematical capabilities of its foundational model while retaining the performance in other tasks."]}),"\n",(0,i.jsx)(n.p,{children:"We found merging models is quick and cost-effective, enabling fast adjustments based on the result of each iteration."}),"\n",(0,i.jsxs)(n.p,{children:["We ended up with ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/stealth-v1.1",children:"Stealth 7B v1.1"}),", a ",(0,i.jsx)(n.a,{href:"https://github.com/Digitous/LLM-SLERP-Merge",children:"SLERP"})," merge of Mistral with the following:"]}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://huggingface.co/WizardLM/WizardMath-7B-V1.1",children:"WizardMath"})," for its math capabilities."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://huggingface.co/WizardLM/WizardCoder-Python-7B-V1.0",children:"WizardCoder"})," for its coding capabilities."]}),"\n",(0,i.jsxs)(n.li,{children:["Our own ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/trinity-v1.2",children:"Trinity"})," model for its versatility across general tasks."]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:"This particular combination yielded the best tradeoff across mathematical & technical reasoning while retaining the most pre-merge performance on general tasks."}),"\n",(0,i.jsx)(n.h2,{id:"dpo-finetuning",children:"DPO Finetuning"}),"\n",(0,i.jsx)(n.p,{children:"Merging different LLMs can lead to a mixed answering style because each model was originally trained on different types of data."}),"\n",(0,i.jsxs)(n.p,{children:["Thus, we applied Direct Preference Optimization (",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2305.18290",children:"DPO"}),") using the ",(0,i.jsx)(n.a,{href:"https://huggingface.co/datasets/Intel/orca_dpo_pairs",children:"Intel's Orca DPO pairs"})," dataset, chosen for its helpful answering style in general, math and coding concentration."]}),"\n",(0,i.jsxs)(n.p,{children:["This approach results in a final model - ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/stealth-v1.2",children:"Stealth 7B v1.2"}),", with minimal loss, and realign to our technical preferences."]}),"\n",(0,i.jsx)(n.h2,{id:"using-our-technical-documentation",children:"Using Our Technical Documentation"}),"\n",(0,i.jsx)(n.p,{children:"With the base model ready, we started on our specific use case."}),"\n",(0,i.jsx)(n.p,{children:"Jan is an open-source & bootstrapped project - at one point during our unanticipated growth, we received 1 customer support ticket per minute, with no one to handle customer service."}),"\n",(0,i.jsx)(n.p,{children:"So, we directed our efforts toward training a model to answer user questions based on existing technical documentation."}),"\n",(0,i.jsxs)(n.p,{children:["Specifically, we trained it on Nitro ",(0,i.jsx)(n.a,{href:"https://nitro.jan.ai/docs",children:"docs"}),". For context, Nitro is the default inference engine for Jan. It\u2019s a serious server implementation of LlamaCPP, written in C++, with multimodal, queues, and other production-level server capabilities."]}),"\n",(0,i.jsx)(n.p,{children:"It made an interesting corpus because it was rife with post-2023 technical jargon, edge cases, and poor informational layout."}),"\n",(0,i.jsx)(n.h2,{id:"generating-a-training-dataset-for-gpt-4",children:"Generating a Training Dataset for GPT-4"}),"\n",(0,i.jsxs)(n.p,{children:["The first step was to transform Nitro\u2019s unstructured format into a synthetic Q&A dataset designed for ",(0,i.jsx)(n.a,{href:"https://arxiv.org/pdf/2109.01652.pdf",children:"instruction tuning"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["The text was split into chunks of 300-token segments with 30-token overlaps. This helped to avoid a ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2307.03172",children:"lost-in-the-middle"})," problem where LLM can\u2019t use context efficiently to answer given questions."]}),"\n",(0,i.jsxs)(n.p,{children:["The chunks were then given to GPT-4 with 8k context length to generate 3800 Q&A pairs. The ",(0,i.jsx)(n.a,{href:"https://huggingface.co/datasets/jan-hq/nitro_binarized_v2",children:"training dataset"})," is available on HuggingFace."]}),"\n",(0,i.jsx)(n.h2,{id:"training",children:"Training"}),"\n",(0,i.jsxs)(n.p,{children:["The training was done with supervised finetuning (SFT) from the ",(0,i.jsx)(n.a,{href:"https://github.com/huggingface/alignment-handbook",children:"Hugging Face's alignment handbook"})," based on the ",(0,i.jsx)(n.a,{href:"https://github.com/huggingface/alignment-handbook/tree/main/recipes/zephyr-7b-beta",children:"Huggingface's Zephyr Beta"})," guidelines."]}),"\n",(0,i.jsxs)(n.p,{children:["We used consumer-grade, dual Nvidia RTX 4090s for the training. The end-to-end training took 18 minutes. We found optimal hyperparameters in LoRA for this specific task to be ",(0,i.jsx)(n.code,{children:"r = 256"})," and ",(0,i.jsx)(n.code,{children:"alpha = 512"}),"."]}),"\n",(0,i.jsxs)(n.p,{children:["This final model is publicly available at ",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/nitro-v1.2-e3",children:"https://huggingface.co/jan-hq/nitro-v1.2-e3"}),"."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Using LLM locally",src:t(70595).A+"",width:"1607",height:"896"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 3."})," Using the new finetuned model in ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"improving-results-with-rag",children:"Improving Results With Rag"}),"\n",(0,i.jsxs)(n.p,{children:["As an additional step, we also added ",(0,i.jsx)(n.a,{href:"https://blogs.nvidia.com/blog/what-is-retrieval-augmented-generation/",children:"Retrieval Augmented Generation (RAG)"})," as an experiment parameter."]}),"\n",(0,i.jsxs)(n.p,{children:["A simple RAG setup was done using ",(0,i.jsx)(n.strong,{children:(0,i.jsx)(n.a,{href:"https://www.llamaindex.ai/",children:"Llamaindex"})})," and the ",(0,i.jsx)(n.strong,{children:(0,i.jsx)(n.a,{href:"https://huggingface.co/BAAI/bge-base-en-v1.5",children:"bge-en-base-v1.5 embedding"})})," model for efficient documentation retrieval and question-answering. The RAG implementation is publicly available at at ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/rag/nitro_rag.ipynb",children:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/rag/nitro_rag.ipynb"})]}),"\n",(0,i.jsx)(n.h2,{id:"benchmarking-the-results",children:"Benchmarking the Results"}),"\n",(0,i.jsxs)(n.p,{children:["We curated a new set of ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/rag/mcq_nitro.csv",children:"50 multiple-choice questions"})," (MCQ) based on the Nitro docs. The questions had varying levels of difficulty and had trick components that challenged the model's ability to discern misleading information."]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.img,{alt:"Opensource model outperforms GPT",src:t(90190).A+"",width:"1189",height:"590"})}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Figure 4."})," Comparison between fine-tuned model and OpenAI's GPT."]}),"\n",(0,i.jsxs)(n.p,{children:[(0,i.jsx)(n.em,{children:"Table 1."})," Result of Benchmarking Different Model With RAG."]}),"\n",(0,i.jsxs)(n.table,{children:[(0,i.jsx)(n.thead,{children:(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.th,{children:"Approach"}),(0,i.jsx)(n.th,{children:"Performance"})]})}),(0,i.jsxs)(n.tbody,{children:[(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"GPT-3.5 with RAG"}),(0,i.jsx)(n.td,{children:"56.7%"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"GPT-4 with RAG"}),(0,i.jsx)(n.td,{children:"64.3%"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsxs)(n.td,{children:["Merged 7B Model (",(0,i.jsx)(n.a,{href:"https://huggingface.co/jan-hq/stealth-v1.3",children:"Stealth 7B"}),") with RAG"]}),(0,i.jsx)(n.td,{children:"47.7%"})]}),(0,i.jsxs)(n.tr,{children:[(0,i.jsx)(n.td,{children:"Finetuned 7B Model (Nitro 7B) with RAG"}),(0,i.jsx)(n.td,{children:"57.8%"})]})]})]}),"\n",(0,i.jsx)(n.p,{children:"This indicates that with task-specific training, we can improve an open-source, Small Language Model to the level of GPT-3.5 on domain knowledge."}),"\n",(0,i.jsx)(n.p,{children:"Notably, the finetuned with RAG approach also demonstrated more consistency across benchmarking, as indicated by its lower standard deviation."}),"\n",(0,i.jsx)(n.h2,{id:"conclusion",children:"Conclusion"}),"\n",(0,i.jsx)(n.p,{children:"We conclude that this combination of model merging finetuning and RAG yields promise. This finding is relevant for teams and individuals that need specialized, technical SLMs that need to run in resource-constrained or highly secured environments, where GPT may not be an option."}),"\n",(0,i.jsx)(n.p,{children:"Anecdotally, we\u2019ve had some success using this model in practice to onboard new team members to the Nitro codebase."}),"\n",(0,i.jsxs)(n.p,{children:["A full research report with more statistics can be found at ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/README.md",children:"https://github.com/janhq/open-foundry/blob/main/rag-is-not-enough/README.md"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"references",children:"References"}),"\n",(0,i.jsxs)(n.p,{children:["[1] Jason Wei, Maarten Bosma, Vincent Y. Zhao, Kelvin Guu, Adams Wei Yu, Brian Lester, Nan Du, Andrew M. Dai, Quoc V. Le. Finetuned Language Models Are Zero-Shot Learners. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2109.01652"}),", 2021. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2109.01652",children:"https://arxiv.org/abs/2109.01652"})]}),"\n",(0,i.jsxs)(n.p,{children:["[2] Haipeng Luo, Qingfeng Sun, Can Xu, Pu Zhao, Jianguang Lou, Chongyang Tao, Xiubo Geng, Qingwei Lin, Shifeng Chen, Dongmei Zhang. WizardMath: Empowering Mathematical Reasoning for Large Language Models via Reinforced Evol-Instruct. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2308.09583"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2308.09583",children:"https://arxiv.org/abs/2308.09583"})]}),"\n",(0,i.jsxs)(n.p,{children:["[3] Luo, Y., Yang, Z., Meng, F., Li, Y., Zhou, J., & Zhang, Y. An Empirical Study of Catastrophic Forgetting in Large Language Models During Continual Fine-tuning. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2308.08747"}),",2023 URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2308.08747",children:"https://arxiv.org/abs/2308.08747"})]}),"\n",(0,i.jsxs)(n.p,{children:["[4] Ziyang Luo, Can Xu, Pu Zhao, Qingfeng Sun, Xiubo Geng, Wenxiang Hu, Chongyang Tao, Jing Ma, Qingwei Lin, Daxin Jiang. WizardCoder: Empowering Code Large Language Models with Evol-Instruct., ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2306.08568"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2306.08568",children:"https://arxiv.org/abs/2306.08568"})]}),"\n",(0,i.jsxs)(n.p,{children:["[5] SciPhi-AI, Agent Search. GitHub. URL: ",(0,i.jsx)(n.a,{href:"https://github.com/SciPhi-AI/agent-search",children:"https://github.com/SciPhi-AI/agent-search"})]}),"\n",(0,i.jsxs)(n.p,{children:['[6] Nelson F. Liu, Kevin Lin, John Hewitt, Ashwin Paranjape, Michele Bevilacqua, Fabio Petroni, Percy Liang. "Lost in the Middle: How Language Models Use Long Contexts." ',(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2307.03172"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2307.03172",children:"https://arxiv.org/abs/2307.03172"})]}),"\n",(0,i.jsxs)(n.p,{children:["[7] Luo, H., Sun, Q., Xu, C., Zhao, P., Lou, J., Tao, C., Geng, X., Lin, Q., Chen, S., & Zhang, D. WizardMath: Empowering Mathematical Reasoning for Large Language Models via Reinforced Evol-Instruct. ",(0,i.jsx)(n.em,{children:"arXiv preprint arXiv:2308.09583"}),", 2023. URL: ",(0,i.jsx)(n.a,{href:"https://arxiv.org/abs/2308.09583",children:"https://arxiv.org/abs/2308.09583"})]}),"\n",(0,i.jsxs)(n.p,{children:["[8] nlpxucan et al., WizardLM. GitHub. URL: ",(0,i.jsx)(n.a,{href:"https://github.com/nlpxucan/WizardLM",children:"https://github.com/nlpxucan/WizardLM"})]})]})}function d(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},5760:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/mistral-comparasion-8c8400408787c7a3a85d1072ab545a1d.png"},70595:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/nitro-on-jan-a26977d030ddcda2ca3e9fb868a8a49c.png"},90190:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/rag-comparasion-d1d1d6f9838abb8f707117cfdfee24d2.png"},11793:(e,n,t)=>{t.d(n,{A:()=>i});const i=t.p+"assets/images/stealth-comparasion-e4f7494c465c9eaecee0fb2d0997eb1c.png"},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>o});var i=t(96540);const a={},s=i.createContext(a);function r(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e0f6d58a.eda1438a.js b/assets/js/e0f6d58a.eda1438a.js deleted file mode 100644 index 0d6c7986..00000000 --- a/assets/js/e0f6d58a.eda1438a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[252],{12050:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>r,metadata:()=>i,toc:()=>d});var a=n(74848),t=n(28453);const r={title:"Messages",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,i={id:"developer/framework/engineering/messages",title:"Messages",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/messages.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/messages",permalink:"/developer/framework/engineering/messages",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/messages.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Messages",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Files",permalink:"/developer/framework/engineering/files"},next:{title:"Models",permalink:"/developer/framework/engineering/models"}},l={},d=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"message.jsonl",id:"messagejsonl",level:2},{value:"Examples",id:"examples",level:3},{value:"API Reference",id:"api-reference",level:2}];function c(e){const s={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(s.admonition,{type:"caution",children:(0,a.jsx)(s.p,{children:"This is currently under development."})}),"\n",(0,a.jsx)(s.h2,{id:"overview",children:"Overview"}),"\n",(0,a.jsxs)(s.p,{children:[(0,a.jsx)(s.code,{children:"Messages"})," capture a conversation's content. This can include the content from LLM responses and other metadata from ",(0,a.jsx)(s.a,{href:"/specs/chats",children:"chat completions"}),"."]}),"\n",(0,a.jsxs)(s.ul,{children:["\n",(0,a.jsx)(s.li,{children:"Users and assistants can send multimedia messages."}),"\n",(0,a.jsxs)(s.li,{children:["An ",(0,a.jsx)(s.a,{href:"https://platform.openai.com/docs/api-reference/messages",children:"OpenAI Message API"})," compatible endpoint at ",(0,a.jsx)(s.code,{children:"localhost:1337/v1/messages"}),"."]}),"\n"]}),"\n",(0,a.jsx)(s.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,a.jsxs)(s.p,{children:["Messages are saved in the ",(0,a.jsx)(s.code,{children:"/threads/{thread_id}"})," folder in ",(0,a.jsx)(s.code,{children:"messages.jsonl"})," files"]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-yaml",children:"jan/\n threads/\n assistant_name_unix_timestamp/\n thread.json # Thread metadata\n messages.jsonl # Messages are stored in jsonl format\n"})}),"\n",(0,a.jsx)(s.h2,{id:"messagejsonl",children:(0,a.jsx)(s.code,{children:"message.jsonl"})}),"\n",(0,a.jsxs)(s.p,{children:["Individual messages are saved in ",(0,a.jsx)(s.code,{children:"jsonl"})," format for indexing purposes."]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-js",children:"{...message_2}\n{...message_1}\n{...message_0}\n"})}),"\n",(0,a.jsx)(s.h3,{id:"examples",children:"Examples"}),"\n",(0,a.jsxs)(s.p,{children:["Here's a standard example ",(0,a.jsx)(s.code,{children:"message"})," sent from a user."]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-js",children:'"id": "0", // Sequential or UUID\n"object": "thread.message", // Defaults to "thread.message"\n"created_at": 1698983503,\n"thread_id": "thread_asdf", // Defaults to parent thread\n"assistant_id": "jan", // Defaults to parent thread\n"role": "user", // From either "user" or "assistant"\n"content": [\n {\n "type": "text",\n "text": {\n "value": "Hi!?",\n "annotations": []\n }\n }\n],\n"metadata": {}, // Defaults to {}\n'})}),"\n",(0,a.jsxs)(s.p,{children:["Here's an example ",(0,a.jsx)(s.code,{children:"message"})," response from an assistant."]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-js",children:'"id": "0", // Sequential or UUID\n"object": "thread.message", // Defaults to "thread.message"\n"created_at": 1698983503,\n"thread_id": "thread_asdf", // Defaults to parent thread\n"assistant_id": "jan", // Defaults to parent thread\n"role": "assistant", // From either "user" or "assistant"\n"content": [ // Usually from Chat Completion obj\n {\n "type": "text",\n "text": {\n "value": "Hi! How can I help you today?",\n "annotations": []\n }\n }\n],\n"metadata": {}, // Defaults to {}\n"usage": {} // Save chat completion properties https://platform.openai.com/docs/api-reference/chat/object\n'})}),"\n",(0,a.jsx)(s.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,a.jsxs)(s.p,{children:["Jan's ",(0,a.jsx)(s.code,{children:"messages"})," API is compatible with ",(0,a.jsx)(s.a,{href:"https://platform.openai.com/docs/api-reference/messages",children:"OpenAI's Messages API"}),", with additional methods for managing messages locally."]}),"\n",(0,a.jsxs)(s.p,{children:["See ",(0,a.jsx)(s.a,{href:"https://jan.ai/api-reference#tag/Messages",children:"Jan Messages API"}),"."]})]})}function h(e={}){const{wrapper:s}={...(0,t.R)(),...e.components};return s?(0,a.jsx)(s,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,s,n)=>{n.d(s,{R:()=>o,x:()=>i});var a=n(96540);const t={},r=a.createContext(t);function o(e){const s=a.useContext(r);return a.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function i(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),a.createElement(r.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e0f6d58a.fd0be044.js b/assets/js/e0f6d58a.fd0be044.js new file mode 100644 index 00000000..9f0f80e9 --- /dev/null +++ b/assets/js/e0f6d58a.fd0be044.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[252],{12050:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>l,contentTitle:()=>o,default:()=>p,frontMatter:()=>r,metadata:()=>i,toc:()=>d});var a=n(74848),t=n(28453);const r={title:"Messages",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,i={id:"developer/framework/engineering/messages",title:"Messages",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/messages.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/messages",permalink:"/developer/framework/engineering/messages",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/messages.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Messages",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Files",permalink:"/developer/framework/engineering/files"},next:{title:"Models",permalink:"/developer/framework/engineering/models"}},l={},d=[{value:"Overview",id:"overview",level:2},{value:"Folder Structure",id:"folder-structure",level:2},{value:"message.jsonl",id:"messagejsonl",level:2},{value:"Examples",id:"examples",level:3},{value:"API Reference",id:"api-reference",level:2}];function c(e){const s={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(s.admonition,{type:"caution",children:(0,a.jsx)(s.p,{children:"This is currently under development."})}),"\n",(0,a.jsx)(s.h2,{id:"overview",children:"Overview"}),"\n",(0,a.jsxs)(s.p,{children:[(0,a.jsx)(s.code,{children:"Messages"})," capture a conversation's content. This can include the content from LLM responses and other metadata from ",(0,a.jsx)(s.a,{href:"/specs/chats",children:"chat completions"}),"."]}),"\n",(0,a.jsxs)(s.ul,{children:["\n",(0,a.jsx)(s.li,{children:"Users and assistants can send multimedia messages."}),"\n",(0,a.jsxs)(s.li,{children:["An ",(0,a.jsx)(s.a,{href:"https://platform.openai.com/docs/api-reference/messages",children:"OpenAI Message API"})," compatible endpoint at ",(0,a.jsx)(s.code,{children:"localhost:1337/v1/messages"}),"."]}),"\n"]}),"\n",(0,a.jsx)(s.h2,{id:"folder-structure",children:"Folder Structure"}),"\n",(0,a.jsxs)(s.p,{children:["Messages are saved in the ",(0,a.jsx)(s.code,{children:"/threads/{thread_id}"})," folder in ",(0,a.jsx)(s.code,{children:"messages.jsonl"})," files"]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-yaml",children:"jan/\n threads/\n assistant_name_unix_timestamp/\n thread.json # Thread metadata\n messages.jsonl # Messages are stored in jsonl format\n"})}),"\n",(0,a.jsx)(s.h2,{id:"messagejsonl",children:(0,a.jsx)(s.code,{children:"message.jsonl"})}),"\n",(0,a.jsxs)(s.p,{children:["Individual messages are saved in ",(0,a.jsx)(s.code,{children:"jsonl"})," format for indexing purposes."]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-js",children:"{...message_2}\n{...message_1}\n{...message_0}\n"})}),"\n",(0,a.jsx)(s.h3,{id:"examples",children:"Examples"}),"\n",(0,a.jsxs)(s.p,{children:["Here's a standard example ",(0,a.jsx)(s.code,{children:"message"})," sent from a user."]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-js",children:'"id": "0", // Sequential or UUID\n"object": "thread.message", // Defaults to "thread.message"\n"created_at": 1698983503,\n"thread_id": "thread_asdf", // Defaults to parent thread\n"assistant_id": "jan", // Defaults to parent thread\n"role": "user", // From either "user" or "assistant"\n"content": [\n {\n "type": "text",\n "text": {\n "value": "Hi!?",\n "annotations": []\n }\n }\n],\n"metadata": {}, // Defaults to {}\n'})}),"\n",(0,a.jsxs)(s.p,{children:["Here's an example ",(0,a.jsx)(s.code,{children:"message"})," response from an assistant."]}),"\n",(0,a.jsx)(s.pre,{children:(0,a.jsx)(s.code,{className:"language-js",children:'"id": "0", // Sequential or UUID\n"object": "thread.message", // Defaults to "thread.message"\n"created_at": 1698983503,\n"thread_id": "thread_asdf", // Defaults to parent thread\n"assistant_id": "jan", // Defaults to parent thread\n"role": "assistant", // From either "user" or "assistant"\n"content": [ // Usually from Chat Completion obj\n {\n "type": "text",\n "text": {\n "value": "Hi! How can I help you today?",\n "annotations": []\n }\n }\n],\n"metadata": {}, // Defaults to {}\n"usage": {} // Save chat completion properties https://platform.openai.com/docs/api-reference/chat/object\n'})}),"\n",(0,a.jsx)(s.h2,{id:"api-reference",children:"API Reference"}),"\n",(0,a.jsxs)(s.p,{children:["Jan's ",(0,a.jsx)(s.code,{children:"messages"})," API is compatible with ",(0,a.jsx)(s.a,{href:"https://platform.openai.com/docs/api-reference/messages",children:"OpenAI's Messages API"}),", with additional methods for managing messages locally."]}),"\n",(0,a.jsxs)(s.p,{children:["See ",(0,a.jsx)(s.a,{href:"https://jan.ai/api-reference#tag/Messages",children:"Jan Messages API"}),"."]})]})}function p(e={}){const{wrapper:s}={...(0,t.R)(),...e.components};return s?(0,a.jsx)(s,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,s,n)=>{n.d(s,{R:()=>o,x:()=>i});var a=n(96540);const t={},r=a.createContext(t);function o(e){const s=a.useContext(r);return a.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function i(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:o(e.components),a.createElement(r.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e268956d.c0365603.js b/assets/js/e268956d.c0365603.js new file mode 100644 index 00000000..53f81fbf --- /dev/null +++ b/assets/js/e268956d.c0365603.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8792],{55571:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>a,default:()=>h,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var i=s(74848),t=s(28453);const r={title:"Project Management",slug:"/how-we-work/project-management",description:"Project management at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","project management"]},a=void 0,o={id:"how-we-work/project-management/project-management",title:"Project Management",description:"Project management at Jan",source:"@site/docs/how-we-work/project-management/project-management.md",sourceDirName:"how-we-work/project-management",slug:"/how-we-work/project-management",permalink:"/how-we-work/project-management",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/project-management/project-management.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Project Management",slug:"/how-we-work/project-management",description:"Project management at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","project management"]},sidebar:"aboutSidebar",previous:{title:"Strategy",permalink:"/how-we-work/strategy/"},next:{title:"Engineering",permalink:"/engineering"}},l={},c=[{value:"Quicklinks",id:"quicklinks",level:2},{value:"Organization",id:"organization",level:2},{value:"Kanban",id:"kanban",level:2},{value:"Triage SOP",id:"triage-sop",level:2},{value:"Request for help",id:"request-for-help",level:4}];function d(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h4:"h4",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsxs)(n.p,{children:["We use the ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5",children:"Jan Monorepo Project"})," in Github to manage our roadmap and sprint Kanbans."]}),"\n",(0,i.jsxs)(n.p,{children:["As much as possible, everyone owns their respective ",(0,i.jsx)(n.code,{children:"epics"})," and ",(0,i.jsx)(n.code,{children:"tasks"}),"."]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsxs)(n.p,{children:["We aim for a ",(0,i.jsx)(n.code,{children:"loosely coupled, but tightly aligned"})," autonomous culture."]})}),"\n",(0,i.jsx)(n.h2,{id:"quicklinks",children:"Quicklinks"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/16",children:"High-level roadmap"}),": view used at at strategic level, for team wide alignment. Start & end dates reflect engineering implementation cycles. Typically product & design work preceeds these timelines."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/25",children:"Standup Kanban"}),": view used during daily standup. Sprints should be up to date."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"organization",children:"Organization"}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/labels?q=roadmap",children:(0,i.jsx)(n.code,{children:"Roadmap Labels"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Roadmap Labels"})," tag large, long-term, & strategic projects that can span multiple teams and multiple sprints"]}),"\n",(0,i.jsxs)(n.li,{children:["Example label: ",(0,i.jsx)(n.code,{children:"roadmap: Jan has Mobile"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Roadmaps"})," contain ",(0,i.jsx)(n.code,{children:"epics"})]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues?q=is%3Aissue+is%3Aopen+label%3A%22type%3A+epic%22",children:(0,i.jsx)(n.code,{children:"Epics"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Epics"})," track large stories that span 1-2 weeks, and it outlines specs, architecture decisions, designs"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Epics"})," contain ",(0,i.jsx)(n.code,{children:"tasks"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Epics"})," should always have 1 owner"]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/milestones",children:(0,i.jsx)(n.code,{children:"Milestones"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Milestones"})," track release versions. We use ",(0,i.jsx)(n.a,{href:"https://semver.org/",children:"semantic versioning"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Milestones"})," span ~2 weeks and have deadlines"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Milestones"})," usually fit within 2-week sprint cycles"]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues",children:(0,i.jsx)(n.code,{children:"Tasks"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Tasks are individual issues (feats, bugs, chores) that can be completed within a few days"}),"\n",(0,i.jsxs)(n.li,{children:["Tasks, except for critical bugs, should always belong to an ",(0,i.jsx)(n.code,{children:"epic"})," (and thus fit into our roadmap)"]}),"\n",(0,i.jsxs)(n.li,{children:["Tasks are usually named per ",(0,i.jsx)(n.a,{href:"https://www.conventionalcommits.org/en/v1.0.0/#summary",children:"Conventional Commits"})]}),"\n",(0,i.jsx)(n.li,{children:"Tasks should always have 1 owner"}),"\n"]}),"\n",(0,i.jsxs)(n.p,{children:["We aim to always sprint on ",(0,i.jsx)(n.code,{children:"tasks"})," that are a part of the ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/16",children:"current roadmap"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"kanban",children:"Kanban"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"no status"}),": issues that need to be triaged (needs an owner, ETA)"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"icebox"}),": issues you don't plan to tackle yet"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"planned"}),": issues you plan to tackle this week"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"in-progress"}),": in progress"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"in-review"}),": pending PR or blocked by something"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"done"}),": done"]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"triage-sop",children:"Triage SOP"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Urgent bugs"}),": assign to an owner (or @engineers if you are not sure) && tag the current ",(0,i.jsx)(n.code,{children:"sprint"})," & ",(0,i.jsx)(n.code,{children:"milestone"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"All else"}),": assign the correct roadmap ",(0,i.jsx)(n.code,{children:"label(s)"})," and owner (if any)"]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"request-for-help",children:"Request for help"}),"\n",(0,i.jsx)(n.p,{children:"As a result, our feature prioritization can feel a bit black box at times."}),"\n",(0,i.jsxs)(n.p,{children:["We'd appreciate high quality insights and volunteers for user interviews through ",(0,i.jsx)(n.a,{href:"https://discord.gg/af6SaTdzpx",children:"Discord"})," and ",(0,i.jsx)(n.a,{href:"https://github.com/janhq",children:"Github"}),"."]})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(d,{...e})}):d(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>a,x:()=>o});var i=s(96540);const t={},r=i.createContext(t);function a(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:a(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e268956d.e7328f5a.js b/assets/js/e268956d.e7328f5a.js deleted file mode 100644 index 4e650c37..00000000 --- a/assets/js/e268956d.e7328f5a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8792],{55571:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>a,default:()=>h,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var i=s(74848),t=s(28453);const r={title:"Project Management",slug:"/how-we-work/project-management",description:"Project management at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","project management"]},a=void 0,o={id:"how-we-work/project-management/project-management",title:"Project Management",description:"Project management at Jan",source:"@site/docs/how-we-work/project-management/project-management.md",sourceDirName:"how-we-work/project-management",slug:"/how-we-work/project-management",permalink:"/how-we-work/project-management",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/project-management/project-management.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Project Management",slug:"/how-we-work/project-management",description:"Project management at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","project management"]},sidebar:"aboutSidebar",previous:{title:"Strategy",permalink:"/how-we-work/strategy/"},next:{title:"Engineering",permalink:"/engineering"}},l={},c=[{value:"Quicklinks",id:"quicklinks",level:2},{value:"Organization",id:"organization",level:2},{value:"Kanban",id:"kanban",level:2},{value:"Triage SOP",id:"triage-sop",level:2},{value:"Request for help",id:"request-for-help",level:4}];function d(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h4:"h4",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsxs)(n.p,{children:["We use the ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5",children:"Jan Monorepo Project"})," in Github to manage our roadmap and sprint Kanbans."]}),"\n",(0,i.jsxs)(n.p,{children:["As much as possible, everyone owns their respective ",(0,i.jsx)(n.code,{children:"epics"})," and ",(0,i.jsx)(n.code,{children:"tasks"}),"."]}),"\n",(0,i.jsx)(n.admonition,{type:"tip",children:(0,i.jsxs)(n.p,{children:["We aim for a ",(0,i.jsx)(n.code,{children:"loosely coupled, but tightly aligned"})," autonomous culture."]})}),"\n",(0,i.jsx)(n.h2,{id:"quicklinks",children:"Quicklinks"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/16",children:"High-level roadmap"}),": view used at at strategic level, for team wide alignment. Start & end dates reflect engineering implementation cycles. Typically product & design work preceeds these timelines."]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/25",children:"Standup Kanban"}),": view used during daily standup. Sprints should be up to date."]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"organization",children:"Organization"}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/labels?q=roadmap",children:(0,i.jsx)(n.code,{children:"Roadmap Labels"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Roadmap Labels"})," tag large, long-term, & strategic projects that can span multiple teams and multiple sprints"]}),"\n",(0,i.jsxs)(n.li,{children:["Example label: ",(0,i.jsx)(n.code,{children:"roadmap: Jan has Mobile"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Roadmaps"})," contain ",(0,i.jsx)(n.code,{children:"epics"})]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues?q=is%3Aissue+is%3Aopen+label%3A%22type%3A+epic%22",children:(0,i.jsx)(n.code,{children:"Epics"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Epics"})," track large stories that span 1-2 weeks, and it outlines specs, architecture decisions, designs"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Epics"})," contain ",(0,i.jsx)(n.code,{children:"tasks"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Epics"})," should always have 1 owner"]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/milestones",children:(0,i.jsx)(n.code,{children:"Milestones"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Milestones"})," track release versions. We use ",(0,i.jsx)(n.a,{href:"https://semver.org/",children:"semantic versioning"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Milestones"})," span ~2 weeks and have deadlines"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Milestones"})," usually fit within 2-week sprint cycles"]}),"\n"]}),"\n",(0,i.jsx)(n.p,{children:(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan/issues",children:(0,i.jsx)(n.code,{children:"Tasks"})})}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Tasks are individual issues (feats, bugs, chores) that can be completed within a few days"}),"\n",(0,i.jsxs)(n.li,{children:["Tasks, except for critical bugs, should always belong to an ",(0,i.jsx)(n.code,{children:"epic"})," (and thus fit into our roadmap)"]}),"\n",(0,i.jsxs)(n.li,{children:["Tasks are usually named per ",(0,i.jsx)(n.a,{href:"https://www.conventionalcommits.org/en/v1.0.0/#summary",children:"Conventional Commits"})]}),"\n",(0,i.jsx)(n.li,{children:"Tasks should always have 1 owner"}),"\n"]}),"\n",(0,i.jsxs)(n.p,{children:["We aim to always sprint on ",(0,i.jsx)(n.code,{children:"tasks"})," that are a part of the ",(0,i.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/16",children:"current roadmap"}),"."]}),"\n",(0,i.jsx)(n.h2,{id:"kanban",children:"Kanban"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"no status"}),": issues that need to be triaged (needs an owner, ETA)"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"icebox"}),": issues you don't plan to tackle yet"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"planned"}),": issues you plan to tackle this week"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"in-progress"}),": in progress"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"in-review"}),": pending PR or blocked by something"]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"done"}),": done"]}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"triage-sop",children:"Triage SOP"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"Urgent bugs"}),": assign to an owner (or @engineers if you are not sure) && tag the current ",(0,i.jsx)(n.code,{children:"sprint"})," & ",(0,i.jsx)(n.code,{children:"milestone"})]}),"\n",(0,i.jsxs)(n.li,{children:[(0,i.jsx)(n.code,{children:"All else"}),": assign the correct roadmap ",(0,i.jsx)(n.code,{children:"label(s)"})," and owner (if any)"]}),"\n"]}),"\n",(0,i.jsx)(n.h4,{id:"request-for-help",children:"Request for help"}),"\n",(0,i.jsx)(n.p,{children:"As a result, our feature prioritization can feel a bit black box at times."}),"\n",(0,i.jsxs)(n.p,{children:["We'd appreciate high quality insights and volunteers for user interviews through ",(0,i.jsx)(n.a,{href:"https://discord.gg/af6SaTdzpx",children:"Discord"})," and ",(0,i.jsx)(n.a,{href:"https://github.com/janhq",children:"Github"}),"."]})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(d,{...e})}):d(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>a,x:()=>o});var i=s(96540);const t={},r=i.createContext(t);function a(e){const n=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:a(e.components),i.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e42e4cd9.de4ad4de.js b/assets/js/e42e4cd9.de4ad4de.js new file mode 100644 index 00000000..597e446d --- /dev/null +++ b/assets/js/e42e4cd9.de4ad4de.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3221],{66129:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>u,frontMatter:()=>a,metadata:()=>i,toc:()=>c});var o=n(74848),s=n(28453);const a={title:"Jan (The Default Assistant)",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,i={id:"developer/framework/product/jan",title:"Jan (The Default Assistant)",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/jan.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/jan",permalink:"/developer/framework/product/jan",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/jan.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Jan (The Default Assistant)",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Hub",permalink:"/developer/framework/product/hub"},next:{title:"Settings",permalink:"/developer/framework/product/settings"}},l={},c=[];function d(e){const t={code:"code",li:"li",p:"p",ul:"ul",...(0,s.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(t.p,{children:'Jan ships with a default assistant "Jan" that lets users chat with any open source model out-of-the-box.'}),"\n",(0,o.jsxs)(t.p,{children:["This assistant is defined in ",(0,o.jsx)(t.code,{children:"/jan"}),". It is a generic assistant to illustrate power of Jan. In the future, it will support additional features e.g. multi-assistant conversations"]}),"\n",(0,o.jsxs)(t.ul,{children:["\n",(0,o.jsx)(t.li,{children:'Your Assistant "Jan" lets you pick any model that is in the root /models folder'}),"\n",(0,o.jsx)(t.li,{children:"Right panel: pick LLM model and set model parameters"}),"\n",(0,o.jsx)(t.li,{children:"Jan\u2019s threads will be at root level"}),"\n",(0,o.jsxs)(t.li,{children:[(0,o.jsx)(t.code,{children:"model.json"})," will reflect model chosen for that session"]}),"\n",(0,o.jsx)(t.li,{children:"Be able to \u201cadd\u201d other assistants in the future"}),"\n",(0,o.jsx)(t.li,{children:"Jan\u2019s files will be at thread level"}),"\n",(0,o.jsx)(t.li,{children:"Jan is not a persistent memory assistant"}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>i});var o=n(96540);const s={},a=o.createContext(s);function r(e){const t=o.useContext(a);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),o.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e42e4cd9.eca6b079.js b/assets/js/e42e4cd9.eca6b079.js deleted file mode 100644 index 0b50cc4c..00000000 --- a/assets/js/e42e4cd9.eca6b079.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3221],{66129:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>u,frontMatter:()=>s,metadata:()=>i,toc:()=>c});var o=n(74848),a=n(28453);const s={title:"Jan (The Default Assistant)",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,i={id:"developer/framework/product/jan",title:"Jan (The Default Assistant)",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/jan.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/jan",permalink:"/developer/framework/product/jan",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/jan.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Jan (The Default Assistant)",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Hub",permalink:"/developer/framework/product/hub"},next:{title:"Settings",permalink:"/developer/framework/product/settings"}},l={},c=[];function d(e){const t={code:"code",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(t.p,{children:'Jan ships with a default assistant "Jan" that lets users chat with any open source model out-of-the-box.'}),"\n",(0,o.jsxs)(t.p,{children:["This assistant is defined in ",(0,o.jsx)(t.code,{children:"/jan"}),". It is a generic assistant to illustrate power of Jan. In the future, it will support additional features e.g. multi-assistant conversations"]}),"\n",(0,o.jsxs)(t.ul,{children:["\n",(0,o.jsx)(t.li,{children:'Your Assistant "Jan" lets you pick any model that is in the root /models folder'}),"\n",(0,o.jsx)(t.li,{children:"Right panel: pick LLM model and set model parameters"}),"\n",(0,o.jsx)(t.li,{children:"Jan\u2019s threads will be at root level"}),"\n",(0,o.jsxs)(t.li,{children:[(0,o.jsx)(t.code,{children:"model.json"})," will reflect model chosen for that session"]}),"\n",(0,o.jsx)(t.li,{children:"Be able to \u201cadd\u201d other assistants in the future"}),"\n",(0,o.jsx)(t.li,{children:"Jan\u2019s files will be at thread level"}),"\n",(0,o.jsx)(t.li,{children:"Jan is not a persistent memory assistant"}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,a.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(d,{...e})}):d(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>r,x:()=>i});var o=n(96540);const a={},s=o.createContext(a);function r(e){const t=o.useContext(s);return o.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:r(e.components),o.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e6eb8051.18fe391e.js b/assets/js/e6eb8051.18fe391e.js new file mode 100644 index 00000000..87541740 --- /dev/null +++ b/assets/js/e6eb8051.18fe391e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4873],{12612:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>s,default:()=>d,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var i=n(74848),a=n(28453);const r={title:"llama.cpp"},s=void 0,o={id:"integrations/llamacpp",title:"llama.cpp",description:"Quicklinks",source:"@site/docs/integrations/llamacpp.md",sourceDirName:"integrations",slug:"/integrations/llamacpp",permalink:"/integrations/llamacpp",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/llamacpp.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"llama.cpp"},sidebar:"ecosystemSidebar",previous:{title:"Langchain",permalink:"/integrations/langchain"},next:{title:"Ollama",permalink:"/integrations/ollama"}},l={},c=[{value:"Quicklinks",id:"quicklinks",level:2}];function p(t){const e={a:"a",h2:"h2",li:"li",ul:"ul",...(0,a.R)(),...t.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(e.h2,{id:"quicklinks",children:"Quicklinks"}),"\n",(0,i.jsxs)(e.ul,{children:["\n",(0,i.jsxs)(e.li,{children:["Jan Framework ",(0,i.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/main/extensions/inference-nitro-extension",children:"Extension Code"})]}),"\n",(0,i.jsxs)(e.li,{children:["ggerganov/llama.pp ",(0,i.jsx)(e.a,{href:"https://github.com/ggerganov/llama.cpp",children:"Source URL"})]}),"\n",(0,i.jsxs)(e.li,{children:[(0,i.jsx)(e.a,{href:"https://nitro.jan.ai/",children:"Productized Wrapper"}),": a bit lower effort to use out of the box"]}),"\n"]})]})}function d(t={}){const{wrapper:e}={...(0,a.R)(),...t.components};return e?(0,i.jsx)(e,{...t,children:(0,i.jsx)(p,{...t})}):p(t)}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>o});var i=n(96540);const a={},r=i.createContext(a);function s(t){const e=i.useContext(r);return i.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function o(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(a):t.components||a:s(t.components),i.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e6eb8051.3db02976.js b/assets/js/e6eb8051.3db02976.js deleted file mode 100644 index 88b4fb4b..00000000 --- a/assets/js/e6eb8051.3db02976.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4873],{12612:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>s,default:()=>d,frontMatter:()=>r,metadata:()=>o,toc:()=>c});var i=n(74848),a=n(28453);const r={title:"llama.cpp"},s=void 0,o={id:"integrations/llamacpp",title:"llama.cpp",description:"Quicklinks",source:"@site/docs/integrations/llamacpp.md",sourceDirName:"integrations",slug:"/integrations/llamacpp",permalink:"/integrations/llamacpp",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations/llamacpp.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"llama.cpp"},sidebar:"ecosystemSidebar",previous:{title:"Langchain",permalink:"/integrations/langchain"},next:{title:"Ollama",permalink:"/integrations/ollama"}},l={},c=[{value:"Quicklinks",id:"quicklinks",level:2}];function p(t){const e={a:"a",h2:"h2",li:"li",ul:"ul",...(0,a.R)(),...t.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(e.h2,{id:"quicklinks",children:"Quicklinks"}),"\n",(0,i.jsxs)(e.ul,{children:["\n",(0,i.jsxs)(e.li,{children:["Jan Framework ",(0,i.jsx)(e.a,{href:"https://github.com/janhq/jan/tree/main/extensions/inference-nitro-extension",children:"Extension Code"})]}),"\n",(0,i.jsxs)(e.li,{children:["ggerganov/llama.pp ",(0,i.jsx)(e.a,{href:"https://github.com/ggerganov/llama.cpp",children:"Source URL"})]}),"\n",(0,i.jsxs)(e.li,{children:[(0,i.jsx)(e.a,{href:"https://nitro.jan.ai/",children:"Productized Wrapper"}),": a bit lower effort to use out of the box"]}),"\n"]})]})}function d(t={}){const{wrapper:e}={...(0,a.R)(),...t.components};return e?(0,i.jsx)(e,{...t,children:(0,i.jsx)(p,{...t})}):p(t)}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>o});var i=n(96540);const a={},r=i.createContext(a);function s(t){const e=i.useContext(r);return i.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function o(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(a):t.components||a:s(t.components),i.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e729be38.a60d6c01.js b/assets/js/e729be38.a60d6c01.js deleted file mode 100644 index 8a7ba488..00000000 --- a/assets/js/e729be38.a60d6c01.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2346],{70084:(t,e,o)=>{o.r(e),o.d(e,{assets:()=>d,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>c,toc:()=>i});var r=o(74848),n=o(28453);const s={title:"Motherboard"},a=void 0,c={id:"hardware/concepts/motherboard",title:"Motherboard",description:"- PCIe lanes that go to the processor (not Chipset)",source:"@site/docs/hardware/concepts/motherboard.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/motherboard",permalink:"/hardware/concepts/motherboard",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/motherboard.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Motherboard"}},d={},i=[];function h(t){const e={li:"li",ul:"ul",...(0,n.R)(),...t.components};return(0,r.jsxs)(e.ul,{children:["\n",(0,r.jsx)(e.li,{children:"PCIe lanes that go to the processor (not Chipset)"}),"\n"]})}function l(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,r.jsx)(e,{...t,children:(0,r.jsx)(h,{...t})}):h(t)}},28453:(t,e,o)=>{o.d(e,{R:()=>a,x:()=>c});var r=o(96540);const n={},s=r.createContext(n);function a(t){const e=r.useContext(s);return r.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:a(t.components),r.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e729be38.d036e988.js b/assets/js/e729be38.d036e988.js new file mode 100644 index 00000000..d50fb09b --- /dev/null +++ b/assets/js/e729be38.d036e988.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2346],{70084:(t,e,o)=>{o.r(e),o.d(e,{assets:()=>d,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>c,toc:()=>i});var r=o(74848),n=o(28453);const s={title:"Motherboard"},a=void 0,c={id:"hardware/concepts/motherboard",title:"Motherboard",description:"- PCIe lanes that go to the processor (not Chipset)",source:"@site/docs/hardware/concepts/motherboard.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts/motherboard",permalink:"/hardware/concepts/motherboard",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/motherboard.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Motherboard"}},d={},i=[];function h(t){const e={li:"li",ul:"ul",...(0,n.R)(),...t.components};return(0,r.jsxs)(e.ul,{children:["\n",(0,r.jsx)(e.li,{children:"PCIe lanes that go to the processor (not Chipset)"}),"\n"]})}function l(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,r.jsx)(e,{...t,children:(0,r.jsx)(h,{...t})}):h(t)}},28453:(t,e,o)=>{o.d(e,{R:()=>a,x:()=>c});var r=o(96540);const n={},s=r.createContext(n);function a(t){const e=r.useContext(s);return r.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:a(t.components),r.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e741274a.561b5844.js b/assets/js/e741274a.561b5844.js new file mode 100644 index 00000000..6922ecee --- /dev/null +++ b/assets/js/e741274a.561b5844.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2862],{1779:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>d});var s=n(74848),r=n(28453);const o={title:"Settings",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,a={id:"developer/framework/product/settings",title:"Settings",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/settings.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/settings",permalink:"/developer/framework/product/settings",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/settings.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Settings",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Jan (The Default Assistant)",permalink:"/developer/framework/product/jan"},next:{title:"System Monitor",permalink:"/developer/framework/product/system-monitor"}},l={},d=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2},{value:"General Settings",id:"general-settings",level:3},{value:"Extensions Settings",id:"extensions-settings",level:3},{value:"Model Settings",id:"model-settings",level:3},{value:"Appearance",id:"appearance",level:3}];function c(e){const t={code:"code",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.h2,{id:"overview",children:"Overview"}),"\n",(0,s.jsx)(t.p,{children:"A settings page for users to add extensions, configure model settings, change app appearance, add keyboard shortcuts, and a plethora of other personalizations."}),"\n",(0,s.jsx)(t.p,{children:(0,s.jsx)(t.img,{alt:"alt text",src:n(67138).A+"",width:"1440",height:"816"})}),"\n",(0,s.jsx)(t.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,s.jsx)(t.h3,{id:"general-settings",children:"General Settings"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsxs)(t.li,{children:["Users can customize ",(0,s.jsx)(t.code,{children:"port"})," number"]}),"\n",(0,s.jsxs)(t.li,{children:["Users can customize ",(0,s.jsx)(t.code,{children:"janroot"})," folder location"]}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"extensions-settings",children:"Extensions Settings"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Users can add, delete, and configure extensions"}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"model-settings",children:"Model Settings"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Users can configure default model parameters and settings"}),"\n",(0,s.jsx)(t.li,{children:"Users can delete models"}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"appearance",children:"Appearance"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Users can set color themes and dark/light modes"}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},67138:(e,t,n)=>{n.d(t,{A:()=>s});const s=n.p+"assets/images/settings-screen-e19723595bd3381d86fee44803d5e7d5.png"},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>a});var s=n(96540);const r={},o=s.createContext(r);function i(e){const t=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),s.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e741274a.9ce04719.js b/assets/js/e741274a.9ce04719.js deleted file mode 100644 index d04b5318..00000000 --- a/assets/js/e741274a.9ce04719.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2862],{1779:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>d});var s=n(74848),r=n(28453);const o={title:"Settings",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},i=void 0,a={id:"developer/framework/product/settings",title:"Settings",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-product/settings.md",sourceDirName:"developer/05-framework/03-product",slug:"/developer/framework/product/settings",permalink:"/developer/framework/product/settings",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-product/settings.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Settings",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Jan (The Default Assistant)",permalink:"/developer/framework/product/jan"},next:{title:"System Monitor",permalink:"/developer/framework/product/system-monitor"}},l={},d=[{value:"Overview",id:"overview",level:2},{value:"User Stories",id:"user-stories",level:2},{value:"General Settings",id:"general-settings",level:3},{value:"Extensions Settings",id:"extensions-settings",level:3},{value:"Model Settings",id:"model-settings",level:3},{value:"Appearance",id:"appearance",level:3}];function c(e){const t={code:"code",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.h2,{id:"overview",children:"Overview"}),"\n",(0,s.jsx)(t.p,{children:"A settings page for users to add extensions, configure model settings, change app appearance, add keyboard shortcuts, and a plethora of other personalizations."}),"\n",(0,s.jsx)(t.p,{children:(0,s.jsx)(t.img,{alt:"alt text",src:n(67138).A+"",width:"1440",height:"816"})}),"\n",(0,s.jsx)(t.h2,{id:"user-stories",children:"User Stories"}),"\n",(0,s.jsx)(t.h3,{id:"general-settings",children:"General Settings"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsxs)(t.li,{children:["Users can customize ",(0,s.jsx)(t.code,{children:"port"})," number"]}),"\n",(0,s.jsxs)(t.li,{children:["Users can customize ",(0,s.jsx)(t.code,{children:"janroot"})," folder location"]}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"extensions-settings",children:"Extensions Settings"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Users can add, delete, and configure extensions"}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"model-settings",children:"Model Settings"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Users can configure default model parameters and settings"}),"\n",(0,s.jsx)(t.li,{children:"Users can delete models"}),"\n"]}),"\n",(0,s.jsx)(t.h3,{id:"appearance",children:"Appearance"}),"\n",(0,s.jsxs)(t.ul,{children:["\n",(0,s.jsx)(t.li,{children:"Users can set color themes and dark/light modes"}),"\n"]})]})}function u(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},67138:(e,t,n)=>{n.d(t,{A:()=>s});const s=n.p+"assets/images/settings-screen-e19723595bd3381d86fee44803d5e7d5.png"},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>a});var s=n(96540);const r={},o=s.createContext(r);function i(e){const t=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function a(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),s.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e7a8e166.f380b973.js b/assets/js/e7a8e166.83c353d3.js similarity index 50% rename from assets/js/e7a8e166.f380b973.js rename to assets/js/e7a8e166.83c353d3.js index a8675115..cfc76ab1 100644 --- a/assets/js/e7a8e166.f380b973.js +++ b/assets/js/e7a8e166.83c353d3.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9086],{48335:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>l,frontMatter:()=>o,metadata:()=>i,toc:()=>c});var r=a(74848),n=a(28453);const o={title:"Hardware Setup",slug:"/guides/hardware",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:3,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","hardware requirements","Nvidia","AMD","CPU","GPU"]},s=void 0,i={id:"guides/get-started/hardware-setup",title:"Hardware Setup",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/get-started/hardware-setup.mdx",sourceDirName:"guides/get-started",slug:"/guides/hardware",permalink:"/guides/hardware",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/hardware-setup.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:3,frontMatter:{title:"Hardware Setup",slug:"/guides/hardware",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:3,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","hardware requirements","Nvidia","AMD","CPU","GPU"]}},d={},c=[];function u(e){const t={p:"p",...(0,n.R)(),...e.components};return(0,r.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},28453:(e,t,a)=>{a.d(t,{R:()=>s,x:()=>i});var r=a(96540);const n={},o=r.createContext(n);function s(e){const t=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:s(e.components),r.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9086],{48335:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>l,frontMatter:()=>o,metadata:()=>i,toc:()=>c});var r=a(74848),n=a(28453);const o={title:"Hardware Setup",slug:"/guides/hardware",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:3,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","hardware requirements","Nvidia","AMD","CPU","GPU"]},s=void 0,i={id:"guides/get-started/hardware-setup",title:"Hardware Setup",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/get-started/hardware-setup.mdx",sourceDirName:"guides/get-started",slug:"/guides/hardware",permalink:"/guides/hardware",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/hardware-setup.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:3,frontMatter:{title:"Hardware Setup",slug:"/guides/hardware",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:3,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","hardware requirements","Nvidia","AMD","CPU","GPU"]}},d={},c=[];function u(e){const t={p:"p",...(0,n.R)(),...e.components};return(0,r.jsx)(t.p,{children:"Coming Soon"})}function l(e={}){const{wrapper:t}={...(0,n.R)(),...e.components};return t?(0,r.jsx)(t,{...e,children:(0,r.jsx)(u,{...e})}):u(e)}},28453:(e,t,a)=>{a.d(t,{R:()=>s,x:()=>i});var r=a(96540);const n={},o=r.createContext(n);function s(e){const t=r.useContext(o);return r.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:s(e.components),r.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e7e7ea54.b4d5b5a2.js b/assets/js/e7e7ea54.b4d5b5a2.js new file mode 100644 index 00000000..457b79cd --- /dev/null +++ b/assets/js/e7e7ea54.b4d5b5a2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[294],{10570:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>c,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>s,toc:()=>u});var o=r(74848),n=r(28453);const a={title:"Contributor Program"},i=void 0,s={id:"team/contributor-program",title:"Contributor Program",description:"",source:"@site/docs/team/contributor-program.md",sourceDirName:"team",slug:"/team/contributor-program",permalink:"/team/contributor-program",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/team/contributor-program.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Contributor Program"},sidebar:"aboutSidebar",previous:{title:"Join us",permalink:"/team/join-us"},next:{title:"Wall of Love \u2764\ufe0f",permalink:"/wall-of-love"}},c={},u=[];function m(t){return(0,o.jsx)(o.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(m,{...t})}):m()}},28453:(t,e,r)=>{r.d(e,{R:()=>i,x:()=>s});var o=r(96540);const n={},a=o.createContext(n);function i(t){const e=o.useContext(a);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function s(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:i(t.components),o.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e7e7ea54.c7cdfe36.js b/assets/js/e7e7ea54.c7cdfe36.js deleted file mode 100644 index 3c419616..00000000 --- a/assets/js/e7e7ea54.c7cdfe36.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[294],{10570:(t,e,r)=>{r.r(e),r.d(e,{assets:()=>c,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>s,toc:()=>u});var o=r(74848),n=r(28453);const a={title:"Contributor Program"},i=void 0,s={id:"team/contributor-program",title:"Contributor Program",description:"",source:"@site/docs/team/contributor-program.md",sourceDirName:"team",slug:"/team/contributor-program",permalink:"/team/contributor-program",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/team/contributor-program.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Contributor Program"},sidebar:"aboutSidebar",previous:{title:"Join us",permalink:"/team/join-us"},next:{title:"Wall of Love \u2764\ufe0f",permalink:"/wall-of-love"}},c={},u=[];function m(t){return(0,o.jsx)(o.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,n.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(m,{...t})}):m()}},28453:(t,e,r)=>{r.d(e,{R:()=>i,x:()=>s});var o=r(96540);const n={},a=o.createContext(n);function i(t){const e=o.useContext(a);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function s(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(n):t.components||n:i(t.components),o.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e8493339.a0d0a3dc.js b/assets/js/e8493339.a0d0a3dc.js deleted file mode 100644 index 7c7d019f..00000000 --- a/assets/js/e8493339.a0d0a3dc.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[411],{21555:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>u,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var t=o(74848),r=o(28453);const i={title:"How We Work",slug:"/how-we-work",description:"How we work at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build in public","remote team","how we work"]},s=void 0,a={id:"how-we-work",title:"How We Work",description:"How we work at Jan",source:"@site/docs/how-we-work.md",sourceDirName:".",slug:"/how-we-work",permalink:"/how-we-work",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"How We Work",slug:"/how-we-work",description:"How we work at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build in public","remote team","how we work"]},sidebar:"aboutSidebar",previous:{title:"Wall of Love \u2764\ufe0f",permalink:"/wall-of-love"},next:{title:"Strategy",permalink:"/how-we-work/strategy/"}},l={},c=[{value:"Open Source",id:"open-source",level:3},{value:"Build in Public",id:"build-in-public",level:3},{value:"Remote Team",id:"remote-team",level:3}];function d(e){const n={a:"a",code:"code",h3:"h3",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h3,{id:"open-source",children:"Open Source"}),"\n",(0,t.jsx)(n.p,{children:"Jan is a startup with an open source business model. We believe in the need for an open source AI ecosystem, and are committed to building it."}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Jan Framework"})," (AGPLv3)"]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://jan.ai",children:"Jan Desktop Client & Local server"})," (AGPLv3, built on Jan Framework)"]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"Nitro: run Local AI"})," (AGPLv3)"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"build-in-public",children:"Build in Public"}),"\n",(0,t.jsx)(n.p,{children:"We use GitHub to build in public and welcome anyone to join in."}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:(0,t.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5",children:"Jan's Kanban"})}),"\n",(0,t.jsx)(n.li,{children:(0,t.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/29",children:"Jan's Roadmap"})}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"coming soon"})," ",(0,t.jsx)(n.a,{href:"https://newsletter.jan.ai",children:"Jan's Newsletter"})]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"remote-team",children:"Remote Team"}),"\n",(0,t.jsxs)(n.p,{children:["Jan has a fully-remote team. We are mainly based in the APAC timezone. We use ",(0,t.jsx)(n.a,{href:"https://discord.gg/af6SaTdzpx",children:"Discord"})," and ",(0,t.jsx)(n.a,{href:"https://github.com/janhq",children:"Github"})," to work."]})]})}function u(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(d,{...e})}):d(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>s,x:()=>a});var t=o(96540);const r={},i=t.createContext(r);function s(e){const n=t.useContext(i);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:s(e.components),t.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e8493339.af78b482.js b/assets/js/e8493339.af78b482.js new file mode 100644 index 00000000..dd206616 --- /dev/null +++ b/assets/js/e8493339.af78b482.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[411],{21555:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>u,frontMatter:()=>i,metadata:()=>a,toc:()=>c});var t=o(74848),r=o(28453);const i={title:"How We Work",slug:"/how-we-work",description:"How we work at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build in public","remote team","how we work"]},s=void 0,a={id:"how-we-work",title:"How We Work",description:"How we work at Jan",source:"@site/docs/how-we-work.md",sourceDirName:".",slug:"/how-we-work",permalink:"/how-we-work",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"How We Work",slug:"/how-we-work",description:"How we work at Jan",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","build in public","remote team","how we work"]},sidebar:"aboutSidebar",previous:{title:"Wall of Love \u2764\ufe0f",permalink:"/wall-of-love"},next:{title:"Strategy",permalink:"/how-we-work/strategy/"}},l={},c=[{value:"Open Source",id:"open-source",level:3},{value:"Build in Public",id:"build-in-public",level:3},{value:"Remote Team",id:"remote-team",level:3}];function d(e){const n={a:"a",code:"code",h3:"h3",li:"li",p:"p",ul:"ul",...(0,r.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h3,{id:"open-source",children:"Open Source"}),"\n",(0,t.jsx)(n.p,{children:"Jan is a startup with an open source business model. We believe in the need for an open source AI ecosystem, and are committed to building it."}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"Jan Framework"})," (AGPLv3)"]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://jan.ai",children:"Jan Desktop Client & Local server"})," (AGPLv3, built on Jan Framework)"]}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.a,{href:"https://github.com/janhq/nitro",children:"Nitro: run Local AI"})," (AGPLv3)"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"build-in-public",children:"Build in Public"}),"\n",(0,t.jsx)(n.p,{children:"We use GitHub to build in public and welcome anyone to join in."}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:(0,t.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5",children:"Jan's Kanban"})}),"\n",(0,t.jsx)(n.li,{children:(0,t.jsx)(n.a,{href:"https://github.com/orgs/janhq/projects/5/views/29",children:"Jan's Roadmap"})}),"\n",(0,t.jsxs)(n.li,{children:[(0,t.jsx)(n.code,{children:"coming soon"})," ",(0,t.jsx)(n.a,{href:"https://newsletter.jan.ai",children:"Jan's Newsletter"})]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"remote-team",children:"Remote Team"}),"\n",(0,t.jsxs)(n.p,{children:["Jan has a fully-remote team. We are mainly based in the APAC timezone. We use ",(0,t.jsx)(n.a,{href:"https://discord.gg/af6SaTdzpx",children:"Discord"})," and ",(0,t.jsx)(n.a,{href:"https://github.com/janhq",children:"Github"})," to work."]})]})}function u(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(d,{...e})}):d(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>s,x:()=>a});var t=o(96540);const r={},i=t.createContext(r);function s(e){const n=t.useContext(i);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:s(e.components),t.createElement(i.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e866b055.35b2e6de.js b/assets/js/e866b055.35b2e6de.js deleted file mode 100644 index b1fde8d5..00000000 --- a/assets/js/e866b055.35b2e6de.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[700],{86553:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>c,contentTitle:()=>i,default:()=>u,frontMatter:()=>s,metadata:()=>d,toc:()=>a});var t=o(74848),r=o(28453);const s={title:"Product & Design",slug:"/how-we-work/product-design",description:"How we work on product design",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","product design"]},i=void 0,d={id:"how-we-work/product-design/product-design",title:"Product & Design",description:"How we work on product design",source:"@site/docs/how-we-work/product-design/product-design.md",sourceDirName:"how-we-work/product-design",slug:"/how-we-work/product-design",permalink:"/how-we-work/product-design",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/product-design/product-design.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Product & Design",slug:"/how-we-work/product-design",description:"How we work on product design",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","product design"]},sidebar:"aboutSidebar",previous:{title:"QA",permalink:"/engineering/qa"},next:{title:"Analytics",permalink:"/how-we-work/analytics"}},c={},a=[{value:"Roadmap",id:"roadmap",level:2}];function l(e){const n={h2:"h2",li:"li",ul:"ul",...(0,r.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"roadmap",children:"Roadmap"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Conversations over Tickets","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"Discord's #roadmap channel"}),"\n",(0,t.jsx)(n.li,{children:"Work with the community to turn conversations into Product Specs"}),"\n"]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["Future System?","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"Use Canny?"}),"\n"]}),"\n"]}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(l,{...e})}):l(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>i,x:()=>d});var t=o(96540);const r={},s=t.createContext(r);function i(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e866b055.d1103a1f.js b/assets/js/e866b055.d1103a1f.js new file mode 100644 index 00000000..6f65b1a6 --- /dev/null +++ b/assets/js/e866b055.d1103a1f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[700],{86553:(e,n,o)=>{o.r(n),o.d(n,{assets:()=>c,contentTitle:()=>i,default:()=>u,frontMatter:()=>s,metadata:()=>d,toc:()=>a});var t=o(74848),r=o(28453);const s={title:"Product & Design",slug:"/how-we-work/product-design",description:"How we work on product design",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","product design"]},i=void 0,d={id:"how-we-work/product-design/product-design",title:"Product & Design",description:"How we work on product design",source:"@site/docs/how-we-work/product-design/product-design.md",sourceDirName:"how-we-work/product-design",slug:"/how-we-work/product-design",permalink:"/how-we-work/product-design",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/how-we-work/product-design/product-design.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Product & Design",slug:"/how-we-work/product-design",description:"How we work on product design",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","product design"]},sidebar:"aboutSidebar",previous:{title:"QA",permalink:"/engineering/qa"},next:{title:"Analytics",permalink:"/how-we-work/analytics"}},c={},a=[{value:"Roadmap",id:"roadmap",level:2}];function l(e){const n={h2:"h2",li:"li",ul:"ul",...(0,r.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"roadmap",children:"Roadmap"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Conversations over Tickets","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"Discord's #roadmap channel"}),"\n",(0,t.jsx)(n.li,{children:"Work with the community to turn conversations into Product Specs"}),"\n"]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["Future System?","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"Use Canny?"}),"\n"]}),"\n"]}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,r.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(l,{...e})}):l(e)}},28453:(e,n,o)=>{o.d(n,{R:()=>i,x:()=>d});var t=o(96540);const r={},s=t.createContext(r);function i(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e90db391.7552ff5e.js b/assets/js/e90db391.7552ff5e.js new file mode 100644 index 00000000..f398f377 --- /dev/null +++ b/assets/js/e90db391.7552ff5e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9982],{74643:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>l,default:()=>h,frontMatter:()=>o,metadata:()=>i,toc:()=>d});var s=n(74848),r=n(28453);const o={title:"Local API Server",slug:"/guides/local-api",description:"A step-by-step guide to start Jan Local Server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","local server","start server","api endpoint"]},l=void 0,i={id:"guides/user-guides/local-server",title:"Local API Server",description:"A step-by-step guide to start Jan Local Server.",source:"@site/docs/guides/user-guides/local-server.mdx",sourceDirName:"guides/user-guides",slug:"/guides/local-api",permalink:"/guides/local-api",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/local-server.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Local API Server",slug:"/guides/local-api",description:"A step-by-step guide to start Jan Local Server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","local server","start server","api endpoint"]},sidebar:"guidesSidebar",previous:{title:"Use Tools",permalink:"/guides/tools"},next:{title:"Advanced Settings",permalink:"/guides/advanced"}},a={},d=[{value:"Step 1: Set the Local Server",id:"step-1-set-the-local-server",level:2},{value:"Step 2: Start and Use the Built-in API Server",id:"step-2-start-and-use-the-built-in-api-server",level:2}];function c(e){const t={admonition:"admonition",code:"code",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:"Jan provides a built-in API server that can be used as a drop-in for OpenAI's API local replacement. This guide will walk you through on how to start the local server and use it to make request to the local server."}),"\n",(0,s.jsx)(t.h2,{id:"step-1-set-the-local-server",children:"Step 1: Set the Local Server"}),"\n",(0,s.jsx)(t.p,{children:"To start the local server, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Jan main menu dashboard."}),"\n",(0,s.jsx)(t.li,{children:"Click the corresponding icon on the bottom left side of your screen."}),"\n",(0,s.jsx)(t.li,{children:"Select the model you want to use under the Model Settings screen to set the LLM for your local server."}),"\n",(0,s.jsx)(t.li,{children:"Configure the server settings as follows:"}),"\n"]}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:"Feature"}),(0,s.jsx)(t.th,{children:"Description"}),(0,s.jsx)(t.th,{children:"Default Setting"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Local Server Address"}),(0,s.jsx)(t.td,{children:"By default, Jan is only accessible on the same computer it's running on, using the address 127.0.0.1. You can change this to 0.0.0.0 to let other devices on your local network access it. However, this is less secure than just allowing access from the same computer."}),(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"localhost (127.0.0.1)"})})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Port"}),(0,s.jsx)(t.td,{children:"Jan runs on port 1337 by default. The port can be changed to any other port number as needed."}),(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"1337"})})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Cross-Origin Resource Sharing (CORS)"}),(0,s.jsx)(t.td,{children:"Manages resource access from external domains. Enabled for security by default but can be disabled if needed."}),(0,s.jsx)(t.td,{children:"Enabled"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Verbose Server Logs"}),(0,s.jsx)(t.td,{children:"Provides extensive details about server activities as the local server runs, displayed at the center of the screen."}),(0,s.jsx)(t.td,{children:"Not specified (implied enabled)"})]})]})]}),"\n",(0,s.jsx)(t.h2,{id:"step-2-start-and-use-the-built-in-api-server",children:"Step 2: Start and Use the Built-in API Server"}),"\n",(0,s.jsx)(t.p,{children:"Once you have set the server settings, you can start the server by following the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsxs)(t.li,{children:["Click the ",(0,s.jsx)(t.strong,{children:"Start Server"})," button on the top left of your screen."]}),"\n"]}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsxs)(t.p,{children:["When the server starts, you'll see a message like ",(0,s.jsx)(t.code,{children:"Server listening at http://127.0.0.1:1337"}),", and the ",(0,s.jsx)(t.strong,{children:"Start Server"})," button will turn into a red ",(0,s.jsx)(t.strong,{children:"Stop Server"})," button."]})}),"\n",(0,s.jsxs)(t.ol,{start:"2",children:["\n",(0,s.jsx)(t.li,{children:"You will be redirected to the API reference server in your browser."}),"\n",(0,s.jsx)(t.li,{children:"Select the available endpoints and try them out by executing the example request."}),"\n",(0,s.jsxs)(t.li,{children:["In this example, we will show you how it works using the ",(0,s.jsx)(t.code,{children:"Chat"})," endpoint."]}),"\n",(0,s.jsxs)(t.li,{children:["Click the ",(0,s.jsx)(t.strong,{children:"Try it out"})," button."]}),"\n",(0,s.jsxs)(t.li,{children:["The Chat endpoint has the following ",(0,s.jsx)(t.code,{children:"cURL request example"})," when running using a ",(0,s.jsx)(t.code,{children:"tinyllama-1.1b"})," model local server:"]}),"\n"]}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-json",children:'{\n "messages": [\n {\n "content": "You are a helpful assistant.",\n "role": "system"\n },\n {\n "content": "Hello!",\n "role": "user"\n }\n ],\n "model": "tinyllama-1.1b",\n "stream": true,\n "max_tokens": 2048,\n "stop": [\n "hello"\n ],\n "frequency_penalty": 0,\n "presence_penalty": 0,\n "temperature": 0.7,\n "top_p": 0.95\n}\n\'\n'})}),"\n",(0,s.jsxs)(t.ol,{start:"7",children:["\n",(0,s.jsxs)(t.li,{children:["The endpoint returns the following ",(0,s.jsx)(t.code,{children:"JSON response body"}),":"]}),"\n"]}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-json",children:'{\n "choices": [\n {\n "finish_reason": null,\n "index": 0,\n "message": {\n "content": "Hello user. What can I help you with?",\n "role": "assistant"\n }\n }\n ],\n "created": 1700193928,\n "id": "ebwd2niJvJB1Q2Whyvkz",\n "model": "_",\n "object": "chat.completion",\n "system_fingerprint": "_",\n "usage": {\n "completion_tokens": 500,\n "prompt_tokens": 33,\n "total_tokens": 533\n }\n}\n'})})]})}function h(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>l,x:()=>i});var s=n(96540);const r={},o=s.createContext(r);function l(e){const t=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:l(e.components),s.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e90db391.dbe806de.js b/assets/js/e90db391.dbe806de.js deleted file mode 100644 index 950d57a7..00000000 --- a/assets/js/e90db391.dbe806de.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9982],{74643:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>i,default:()=>h,frontMatter:()=>o,metadata:()=>l,toc:()=>d});var s=n(74848),r=n(28453);const o={title:"Local API Server",slug:"/guides/local-api",description:"A step-by-step guide to start Jan Local Server.",sidebar_position:10,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","local server","start server","api endpoint"]},i=void 0,l={id:"guides/user-guides/local-server",title:"Local API Server",description:"A step-by-step guide to start Jan Local Server.",source:"@site/docs/guides/user-guides/local-server.mdx",sourceDirName:"guides/user-guides",slug:"/guides/local-api",permalink:"/guides/local-api",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/user-guides/local-server.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:10,frontMatter:{title:"Local API Server",slug:"/guides/local-api",description:"A step-by-step guide to start Jan Local Server.",sidebar_position:10,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","local server","start server","api endpoint"]},sidebar:"guidesSidebar",previous:{title:"Manage Threads",permalink:"/guides/threads"},next:{title:"Advanced Settings",permalink:"/guides/advanced"}},a={},d=[{value:"Step 1: Set the Local Server",id:"step-1-set-the-local-server",level:2},{value:"Step 2: Start and Use the Built-in API Server",id:"step-2-start-and-use-the-built-in-api-server",level:2}];function c(e){const t={admonition:"admonition",code:"code",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,r.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(t.p,{children:"Jan provides a built-in API server that can be used as a drop-in for OpenAI's API local replacement. This guide will walk you through on how to start the local server and use it to make request to the local server."}),"\n",(0,s.jsx)(t.h2,{id:"step-1-set-the-local-server",children:"Step 1: Set the Local Server"}),"\n",(0,s.jsx)(t.p,{children:"To start the local server, follow the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsx)(t.li,{children:"Navigate to the Jan main menu dashboard."}),"\n",(0,s.jsx)(t.li,{children:"Click the corresponding icon on the bottom left side of your screen."}),"\n",(0,s.jsx)(t.li,{children:"Select the model you want to use under the Model Settings screen to set the LLM for your local server."}),"\n",(0,s.jsx)(t.li,{children:"Configure the server settings as follows:"}),"\n"]}),"\n",(0,s.jsxs)(t.table,{children:[(0,s.jsx)(t.thead,{children:(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.th,{children:"Feature"}),(0,s.jsx)(t.th,{children:"Description"}),(0,s.jsx)(t.th,{children:"Default Setting"})]})}),(0,s.jsxs)(t.tbody,{children:[(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Local Server Address"}),(0,s.jsx)(t.td,{children:"By default, Jan is only accessible on the same computer it's running on, using the address 127.0.0.1. You can change this to 0.0.0.0 to let other devices on your local network access it. However, this is less secure than just allowing access from the same computer."}),(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"localhost (127.0.0.1)"})})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Port"}),(0,s.jsx)(t.td,{children:"Jan runs on port 1337 by default. The port can be changed to any other port number as needed."}),(0,s.jsx)(t.td,{children:(0,s.jsx)(t.code,{children:"1337"})})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Cross-Origin Resource Sharing (CORS)"}),(0,s.jsx)(t.td,{children:"Manages resource access from external domains. Enabled for security by default but can be disabled if needed."}),(0,s.jsx)(t.td,{children:"Enabled"})]}),(0,s.jsxs)(t.tr,{children:[(0,s.jsx)(t.td,{children:"Verbose Server Logs"}),(0,s.jsx)(t.td,{children:"Provides extensive details about server activities as the local server runs, displayed at the center of the screen."}),(0,s.jsx)(t.td,{children:"Not specified (implied enabled)"})]})]})]}),"\n",(0,s.jsx)(t.h2,{id:"step-2-start-and-use-the-built-in-api-server",children:"Step 2: Start and Use the Built-in API Server"}),"\n",(0,s.jsx)(t.p,{children:"Once you have set the server settings, you can start the server by following the steps below:"}),"\n",(0,s.jsxs)(t.ol,{children:["\n",(0,s.jsxs)(t.li,{children:["Click the ",(0,s.jsx)(t.strong,{children:"Start Server"})," button on the top left of your screen."]}),"\n"]}),"\n",(0,s.jsx)(t.admonition,{type:"note",children:(0,s.jsxs)(t.p,{children:["When the server starts, you'll see a message like ",(0,s.jsx)(t.code,{children:"Server listening at http://127.0.0.1:1337"}),", and the ",(0,s.jsx)(t.strong,{children:"Start Server"})," button will turn into a red ",(0,s.jsx)(t.strong,{children:"Stop Server"})," button."]})}),"\n",(0,s.jsxs)(t.ol,{start:"2",children:["\n",(0,s.jsx)(t.li,{children:"You will be redirected to the API reference server in your browser."}),"\n",(0,s.jsx)(t.li,{children:"Select the available endpoints and try them out by executing the example request."}),"\n",(0,s.jsxs)(t.li,{children:["In this example, we will show you how it works using the ",(0,s.jsx)(t.code,{children:"Chat"})," endpoint."]}),"\n",(0,s.jsxs)(t.li,{children:["Click the ",(0,s.jsx)(t.strong,{children:"Try it out"})," button."]}),"\n",(0,s.jsxs)(t.li,{children:["The Chat endpoint has the following ",(0,s.jsx)(t.code,{children:"cURL request example"})," when running using a ",(0,s.jsx)(t.code,{children:"tinyllama-1.1b"})," model local server:"]}),"\n"]}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-json",children:'{\n "messages": [\n {\n "content": "You are a helpful assistant.",\n "role": "system"\n },\n {\n "content": "Hello!",\n "role": "user"\n }\n ],\n "model": "tinyllama-1.1b",\n "stream": true,\n "max_tokens": 2048,\n "stop": [\n "hello"\n ],\n "frequency_penalty": 0,\n "presence_penalty": 0,\n "temperature": 0.7,\n "top_p": 0.95\n}\n\'\n'})}),"\n",(0,s.jsxs)(t.ol,{start:"7",children:["\n",(0,s.jsxs)(t.li,{children:["The endpoint returns the following ",(0,s.jsx)(t.code,{children:"JSON response body"}),":"]}),"\n"]}),"\n",(0,s.jsx)(t.pre,{children:(0,s.jsx)(t.code,{className:"language-json",children:'{\n "choices": [\n {\n "finish_reason": null,\n "index": 0,\n "message": {\n "content": "Hello user. What can I help you with?",\n "role": "assistant"\n }\n }\n ],\n "created": 1700193928,\n "id": "ebwd2niJvJB1Q2Whyvkz",\n "model": "_",\n "object": "chat.completion",\n "system_fingerprint": "_",\n "usage": {\n "completion_tokens": 500,\n "prompt_tokens": 33,\n "total_tokens": 533\n }\n}\n'})})]})}function h(e={}){const{wrapper:t}={...(0,r.R)(),...e.components};return t?(0,s.jsx)(t,{...e,children:(0,s.jsx)(c,{...e})}):c(e)}},28453:(e,t,n)=>{n.d(t,{R:()=>i,x:()=>l});var s=n(96540);const r={},o=s.createContext(r);function i(e){const t=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function l(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),s.createElement(o.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/e98001e4.c59f1b5c.js b/assets/js/e98001e4.c59f1b5c.js deleted file mode 100644 index 6f00c7df..00000000 --- a/assets/js/e98001e4.c59f1b5c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5299],{59938:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var o=n(74848),s=n(28453);const r={title:"Government",tags:["industries"]},i=void 0,a={id:"solutions/government",title:"Government",description:"",source:"@site/docs/solutions/government.md",sourceDirName:"solutions",slug:"/solutions/government",permalink:"/solutions/government",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/government.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Government",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Legal",permalink:"/solutions/legal"},next:{title:"Developers",permalink:"/solutions/developers"}},l={},u=[];function c(t){return(0,o.jsx)(o.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,s.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(c,{...t})}):c()}},28453:(t,e,n)=>{n.d(e,{R:()=>i,x:()=>a});var o=n(96540);const s={},r=o.createContext(s);function i(t){const e=o.useContext(r);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:i(t.components),o.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/e98001e4.f4004fd0.js b/assets/js/e98001e4.f4004fd0.js new file mode 100644 index 00000000..0af062b9 --- /dev/null +++ b/assets/js/e98001e4.f4004fd0.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5299],{59938:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var o=n(74848),s=n(28453);const r={title:"Government",tags:["industries"]},i=void 0,a={id:"solutions/government",title:"Government",description:"",source:"@site/docs/solutions/government.md",sourceDirName:"solutions",slug:"/solutions/government",permalink:"/solutions/government",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/government.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Government",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Legal",permalink:"/solutions/legal"},next:{title:"Developers",permalink:"/solutions/developers"}},l={},u=[];function c(t){return(0,o.jsx)(o.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,s.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(c,{...t})}):c()}},28453:(t,e,n)=>{n.d(e,{R:()=>i,x:()=>a});var o=n(96540);const s={},r=o.createContext(s);function i(t){const e=o.useContext(r);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function a(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(s):t.components||s:i(t.components),o.createElement(r.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/eae9547a.8d123d7c.js b/assets/js/eae9547a.8d123d7c.js deleted file mode 100644 index afaaabe6..00000000 --- a/assets/js/eae9547a.8d123d7c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3068],{50661:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>t,default:()=>h,frontMatter:()=>s,metadata:()=>r,toc:()=>d});var l=i(74848),a=i(28453);const s={sidebar_position:13,slug:"/changelog/changelog-v0.3.1"},t="v0.3.1",r={id:"releases/changelog/changelog-v0.3.1",title:"v0.3.1",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.1.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.1",permalink:"/changelog/changelog-v0.3.1",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.1.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:13,frontMatter:{sidebar_position:13,slug:"/changelog/changelog-v0.3.1"},sidebar:"releasesSidebar",previous:{title:"v0.3.2",permalink:"/changelog/changelog-v0.3.2"},next:{title:"v0.3.0",permalink:"/changelog/changelog-v0.3.0"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v031",children:"v0.3.1"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.1",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/580",children:"Issue #580: fix: preformatted text indents the first line strangely"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: preformatted text indents the first line strangely @louis-jan (#580)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to package app since core and uikit are not being built @louis-jan (#575)"}),"\n",(0,l.jsx)(n.li,{children:"cleanup: remove component folder and cleanup conversation screen @urmauur (#574)"}),"\n",(0,l.jsx)(n.li,{children:"bug: update convo state when user change model @urmauur (#571)"}),"\n",(0,l.jsx)(n.li,{children:"fix(#566): jan cannot retrieve the conversations @namchuai (#570)"}),"\n",(0,l.jsx)(n.li,{children:"bug: Toast messages shows [object object] @urmauur (#569)"}),"\n",(0,l.jsx)(n.li,{children:"ui: improve state of welcome screen @urmauur (#563)"}),"\n",(0,l.jsx)(n.li,{children:"chore: fixed an issue where app does not yield message result @louis-jan (#561)"}),"\n",(0,l.jsx)(n.li,{children:"Update readme @urmauur (#560)"}),"\n",(0,l.jsx)(n.li,{children:"ui: standalone UIKit and refactor @urmauur (#557)"}),"\n",(0,l.jsx)(n.li,{children:"Small description changes @dan-jan (#558)"}),"\n",(0,l.jsx)(n.li,{children:"add 'change download button based on OS' feature @Vikram-2004 (#551)"}),"\n",(0,l.jsx)(n.li,{children:"feat: revamp plugin architecture @louis-jan (#535)"}),"\n",(0,l.jsx)(n.li,{children:"Fix mobile padding @imtuyethan (#550)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update Readme @dan-jan (#549)"}),"\n",(0,l.jsx)(n.li,{children:"Update Homepage and README with 1-line pitch @dan-jan (#548)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Add About, Events, Blog @dan-jan (#546)"}),"\n",(0,l.jsx)(n.li,{children:"Ashley/update website content @imtuyethan (#545)"}),"\n",(0,l.jsx)(n.li,{children:"Add guides @hahuyhoang411 (#488)"}),"\n",(0,l.jsx)(n.li,{children:"Structure Docs @dan-jan (#536)"}),"\n",(0,l.jsx)(n.li,{children:"Update README.md @imtuyethan (#533)"}),"\n",(0,l.jsx)(n.li,{children:'Chore: Setup "Jan Improvements Proposal" workflow @dan-jan (#534)'}),"\n",(0,l.jsx)(n.li,{children:"Update website tag line @imtuyethan (#527)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #396 - allow user to cancel a model download @louis-jan (#530)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #479 - Toggle plugin is now experimental feature @louis-jan (#531)"}),"\n",(0,l.jsx)(n.li,{children:"chore: disable app update on test @louis-jan (#521)"}),"\n",(0,l.jsx)(n.li,{children:"bug: chat UI is not consistent @urmauur (#520)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: plugin manager and execution as ts @louis-jan (#504)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app toolbar is gone on windows @louis-jan (#503)"}),"\n",(0,l.jsx)(n.li,{children:"Chore: refactor code, hide plugin menu in web @ghost (#502)"}),"\n",(0,l.jsx)(n.li,{children:"fix: dest.end is not a function @louis-jan (#501)"}),"\n",(0,l.jsx)(n.li,{children:"#255: Jan cloud native @ghost (#320)"}),"\n",(0,l.jsx)(n.li,{children:"bug: download new version should show in status bar @urmauur (#500)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add New Conversation button on the conversation sidebar @urmauur (#499)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update plugin readme @louis-jan (#497)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update plugins license @louis-jan (#496)"}),"\n",(0,l.jsx)(n.li,{children:"#255: Read plugins manifest from CDN @ghost (#495)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update plugin sdk - add appDataPath @louis-jan (#492)"}),"\n",(0,l.jsx)(n.li,{children:"chore: enable back bot function for edge-release @louis-jan (#474)"}),"\n",(0,l.jsx)(n.li,{children:"chore: attempt to kill Nitro subprocesses @louis-jan (#484)"}),"\n",(0,l.jsx)(n.li,{children:"docs: new dev hub @0xSage (#450)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: Experimental Feature Toggle @louis-jan (#525)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Add rebuild leveldown for arm on mac intel @hiento09 (#487)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Bump nitro version from 0.1.4 to 0.1.6 @hiento09 (#581)"}),"\n",(0,l.jsx)(n.li,{children:"Add set yarn network timeout for uikit @hiento09 (#579)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error CI e2e run failed on windows @hiento09 (#578)"}),"\n",(0,l.jsx)(n.li,{children:"Fix build plugins macos codesiging error @hiento09 (#576)"}),"\n",(0,l.jsx)(n.li,{children:"Add install nitro mac intel inference plugin build locally @hiento09 (#542)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro version to 0.1.4 @hiento09 (#532)"}),"\n",(0,l.jsx)(n.li,{children:"Chore/update yarn dev script @hiento09 (#529)"}),"\n",(0,l.jsx)(n.li,{children:"Inference Plugin pull nitro binary from release @hiento09 (#524)"}),"\n",(0,l.jsx)(n.li,{children:"Correct version and license @hiento09 (#498)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @Vikram-2004, @dan-jan, @hahuyhoang411, @hiento09, @imtuyethan, @jan-service-account, @louis-jan, @namchuai, @tikikun, @urmauur, Han, James, John and nam-john-ho"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>t,x:()=>r});var l=i(96540);const a={},s=l.createContext(a);function t(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:t(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/eae9547a.aa97bd58.js b/assets/js/eae9547a.aa97bd58.js new file mode 100644 index 00000000..bbd0790b --- /dev/null +++ b/assets/js/eae9547a.aa97bd58.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3068],{50661:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>t,default:()=>h,frontMatter:()=>s,metadata:()=>r,toc:()=>d});var l=i(74848),a=i(28453);const s={sidebar_position:13,slug:"/changelog/changelog-v0.3.1"},t="v0.3.1",r={id:"releases/changelog/changelog-v0.3.1",title:"v0.3.1",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.1.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.1",permalink:"/changelog/changelog-v0.3.1",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.1.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:13,frontMatter:{sidebar_position:13,slug:"/changelog/changelog-v0.3.1"},sidebar:"releasesSidebar",previous:{title:"v0.3.2",permalink:"/changelog/changelog-v0.3.2"},next:{title:"v0.3.0",permalink:"/changelog/changelog-v0.3.0"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v031",children:"v0.3.1"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.1",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/580",children:"Issue #580: fix: preformatted text indents the first line strangely"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: preformatted text indents the first line strangely @louis-jan (#580)"}),"\n",(0,l.jsx)(n.li,{children:"fix: failed to package app since core and uikit are not being built @louis-jan (#575)"}),"\n",(0,l.jsx)(n.li,{children:"cleanup: remove component folder and cleanup conversation screen @urmauur (#574)"}),"\n",(0,l.jsx)(n.li,{children:"bug: update convo state when user change model @urmauur (#571)"}),"\n",(0,l.jsx)(n.li,{children:"fix(#566): jan cannot retrieve the conversations @namchuai (#570)"}),"\n",(0,l.jsx)(n.li,{children:"bug: Toast messages shows [object object] @urmauur (#569)"}),"\n",(0,l.jsx)(n.li,{children:"ui: improve state of welcome screen @urmauur (#563)"}),"\n",(0,l.jsx)(n.li,{children:"chore: fixed an issue where app does not yield message result @louis-jan (#561)"}),"\n",(0,l.jsx)(n.li,{children:"Update readme @urmauur (#560)"}),"\n",(0,l.jsx)(n.li,{children:"ui: standalone UIKit and refactor @urmauur (#557)"}),"\n",(0,l.jsx)(n.li,{children:"Small description changes @dan-jan (#558)"}),"\n",(0,l.jsx)(n.li,{children:"add 'change download button based on OS' feature @Vikram-2004 (#551)"}),"\n",(0,l.jsx)(n.li,{children:"feat: revamp plugin architecture @louis-jan (#535)"}),"\n",(0,l.jsx)(n.li,{children:"Fix mobile padding @imtuyethan (#550)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Update Readme @dan-jan (#549)"}),"\n",(0,l.jsx)(n.li,{children:"Update Homepage and README with 1-line pitch @dan-jan (#548)"}),"\n",(0,l.jsx)(n.li,{children:"docs: Add About, Events, Blog @dan-jan (#546)"}),"\n",(0,l.jsx)(n.li,{children:"Ashley/update website content @imtuyethan (#545)"}),"\n",(0,l.jsx)(n.li,{children:"Add guides @hahuyhoang411 (#488)"}),"\n",(0,l.jsx)(n.li,{children:"Structure Docs @dan-jan (#536)"}),"\n",(0,l.jsx)(n.li,{children:"Update README.md @imtuyethan (#533)"}),"\n",(0,l.jsx)(n.li,{children:'Chore: Setup "Jan Improvements Proposal" workflow @dan-jan (#534)'}),"\n",(0,l.jsx)(n.li,{children:"Update website tag line @imtuyethan (#527)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #396 - allow user to cancel a model download @louis-jan (#530)"}),"\n",(0,l.jsx)(n.li,{children:"fix: #479 - Toggle plugin is now experimental feature @louis-jan (#531)"}),"\n",(0,l.jsx)(n.li,{children:"chore: disable app update on test @louis-jan (#521)"}),"\n",(0,l.jsx)(n.li,{children:"bug: chat UI is not consistent @urmauur (#520)"}),"\n",(0,l.jsx)(n.li,{children:"refactor: plugin manager and execution as ts @louis-jan (#504)"}),"\n",(0,l.jsx)(n.li,{children:"fix: app toolbar is gone on windows @louis-jan (#503)"}),"\n",(0,l.jsx)(n.li,{children:"Chore: refactor code, hide plugin menu in web @ghost (#502)"}),"\n",(0,l.jsx)(n.li,{children:"fix: dest.end is not a function @louis-jan (#501)"}),"\n",(0,l.jsx)(n.li,{children:"#255: Jan cloud native @ghost (#320)"}),"\n",(0,l.jsx)(n.li,{children:"bug: download new version should show in status bar @urmauur (#500)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add New Conversation button on the conversation sidebar @urmauur (#499)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update plugin readme @louis-jan (#497)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update plugins license @louis-jan (#496)"}),"\n",(0,l.jsx)(n.li,{children:"#255: Read plugins manifest from CDN @ghost (#495)"}),"\n",(0,l.jsx)(n.li,{children:"chore: update plugin sdk - add appDataPath @louis-jan (#492)"}),"\n",(0,l.jsx)(n.li,{children:"chore: enable back bot function for edge-release @louis-jan (#474)"}),"\n",(0,l.jsx)(n.li,{children:"chore: attempt to kill Nitro subprocesses @louis-jan (#484)"}),"\n",(0,l.jsx)(n.li,{children:"docs: new dev hub @0xSage (#450)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: Experimental Feature Toggle @louis-jan (#525)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Add rebuild leveldown for arm on mac intel @hiento09 (#487)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Bump nitro version from 0.1.4 to 0.1.6 @hiento09 (#581)"}),"\n",(0,l.jsx)(n.li,{children:"Add set yarn network timeout for uikit @hiento09 (#579)"}),"\n",(0,l.jsx)(n.li,{children:"Fix error CI e2e run failed on windows @hiento09 (#578)"}),"\n",(0,l.jsx)(n.li,{children:"Fix build plugins macos codesiging error @hiento09 (#576)"}),"\n",(0,l.jsx)(n.li,{children:"Add install nitro mac intel inference plugin build locally @hiento09 (#542)"}),"\n",(0,l.jsx)(n.li,{children:"Bump nitro version to 0.1.4 @hiento09 (#532)"}),"\n",(0,l.jsx)(n.li,{children:"Chore/update yarn dev script @hiento09 (#529)"}),"\n",(0,l.jsx)(n.li,{children:"Inference Plugin pull nitro binary from release @hiento09 (#524)"}),"\n",(0,l.jsx)(n.li,{children:"Correct version and license @hiento09 (#498)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@0xSage, @Vikram-2004, @dan-jan, @hahuyhoang411, @hiento09, @imtuyethan, @jan-service-account, @louis-jan, @namchuai, @tikikun, @urmauur, Han, James, John and nam-john-ho"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>t,x:()=>r});var l=i(96540);const a={},s=l.createContext(a);function t(e){const n=l.useContext(s);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:t(e.components),l.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/eaf63638.d618342a.js b/assets/js/eaf63638.d618342a.js new file mode 100644 index 00000000..02952fcd --- /dev/null +++ b/assets/js/eaf63638.d618342a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7883],{72405:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>f,frontMatter:()=>a,metadata:()=>i,toc:()=>u});var n=r(74848),s=r(28453);const a={title:"Agents Framework"},o=void 0,i={id:"features/agents-framework",title:"Agents Framework",description:"",source:"@site/docs/features/agents-framework.md",sourceDirName:"features",slug:"/features/agents-framework",permalink:"/features/agents-framework",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/agents-framework.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Agents Framework"},sidebar:"productSidebar",previous:{title:"Extensions Framework",permalink:"/features/extensions-framework"},next:{title:"Data Security",permalink:"/features/data-security"}},c={},u=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function f(e={}){const{wrapper:t}={...(0,s.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>o,x:()=>i});var n=r(96540);const s={},a=n.createContext(s);function o(e){const t=n.useContext(a);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:o(e.components),n.createElement(a.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/eaf63638.efe6f07f.js b/assets/js/eaf63638.efe6f07f.js deleted file mode 100644 index 57bf0f92..00000000 --- a/assets/js/eaf63638.efe6f07f.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7883],{72405:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>f,frontMatter:()=>s,metadata:()=>i,toc:()=>u});var n=r(74848),a=r(28453);const s={title:"Agents Framework"},o=void 0,i={id:"features/agents-framework",title:"Agents Framework",description:"",source:"@site/docs/features/agents-framework.md",sourceDirName:"features",slug:"/features/agents-framework",permalink:"/features/agents-framework",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/features/agents-framework.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Agents Framework"},sidebar:"productSidebar",previous:{title:"Extensions Framework",permalink:"/features/extensions-framework"},next:{title:"Data Security",permalink:"/features/data-security"}},c={},u=[];function d(e){return(0,n.jsx)(n.Fragment,{})}function f(e={}){const{wrapper:t}={...(0,a.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(d,{...e})}):d()}},28453:(e,t,r)=>{r.d(t,{R:()=>o,x:()=>i});var n=r(96540);const a={},s=n.createContext(a);function o(e){const t=n.useContext(s);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function i(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),n.createElement(s.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/eb428099.beeff65d.js b/assets/js/eb428099.beeff65d.js new file mode 100644 index 00000000..7f5fbd98 --- /dev/null +++ b/assets/js/eb428099.beeff65d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6206],{98492:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>r,frontMatter:()=>i,metadata:()=>C,toc:()=>h});var g=e(74848),s=e(28453),t=e(64023);const i={title:"Changelog",sidebar_position:1,slug:"/changelog",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","changelog"]},d=void 0,C={id:"releases/changelog/README",title:"Changelog",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/releases/changelog/README.mdx",sourceDirName:"releases/changelog",slug:"/changelog",permalink:"/changelog",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Changelog",sidebar_position:1,slug:"/changelog",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","changelog"]},sidebar:"releasesSidebar",next:{title:"v0.4.9",permalink:"/changelog/changelog-v0.4.9"}},l={},h=[];function F(A){return(0,g.jsx)(t.A,{})}function r(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,g.jsx)(a,{...A,children:(0,g.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var g=e(18215),s=e(84142),t=e(20053),i=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},h="",F="",r="",n="",o="",u="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",U="",v="",W="",K="",N="",b="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,t.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:g,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,t.A)("text--truncate",l.cardTitle),title:g,children:[e," ",g]}),s&&(0,L.jsx)("p",{className:(0,t.A)(l.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",g=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??g?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const t=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,g.A)("row",e),children:t.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var g=e(96540);const s={},t=g.createContext(s);function i(A){const a=g.useContext(t);return g.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:i(A.components),g.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/eb428099.f70b4a44.js b/assets/js/eb428099.f70b4a44.js deleted file mode 100644 index fb8da7d0..00000000 --- a/assets/js/eb428099.f70b4a44.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6206],{98492:(A,a,e)=>{e.r(a),e.d(a,{assets:()=>l,contentTitle:()=>d,default:()=>r,frontMatter:()=>i,metadata:()=>C,toc:()=>h});var g=e(74848),s=e(28453),t=e(64023);const i={title:"Changelog",sidebar_position:1,slug:"/changelog",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","changelog"]},d=void 0,C={id:"releases/changelog/README",title:"Changelog",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/releases/changelog/README.mdx",sourceDirName:"releases/changelog",slug:"/changelog",permalink:"/changelog",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/README.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Changelog",sidebar_position:1,slug:"/changelog",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","changelog"]},sidebar:"releasesSidebar",next:{title:"v0.4.9",permalink:"/changelog/changelog-v0.4.9"}},l={},h=[];function F(A){return(0,g.jsx)(t.A,{})}function r(A={}){const{wrapper:a}={...(0,s.R)(),...A.components};return a?(0,g.jsx)(a,{...A,children:(0,g.jsx)(F,{...A})}):F()}},64023:(A,a,e)=>{e.d(a,{A:()=>y});e(96540);var g=e(18215),s=e(84142),t=e(20053),i=e(28774),d=e(21312),C=e(51107);const l={cardContainer:"cardContainer_S8oU",cardTitle:"cardTitle_HoSo",cardDescription:"cardDescription_c27F"},h="",F="",r="",n="",o="",u="",c="",E="",B="",p="",Y="",w="",V="",R="",I="",U="",v="",W="",K="",N="",b="",Q="",O="",m="",M="",G="",x="",Z="",X="";var L=e(74848);function j(A){let{href:a,children:e}=A;return(0,L.jsx)(i.A,{href:a,className:(0,t.A)("card padding--lg",l.cardContainer),children:e})}function S(A){let{href:a,icon:e,title:g,description:s}=A;return(0,L.jsxs)(j,{href:a,children:[(0,L.jsxs)(C.A,{as:"h2",className:(0,t.A)("text--truncate",l.cardTitle),title:g,children:[e," ",g]}),s&&(0,L.jsx)("p",{className:(0,t.A)(l.cardDescription),title:s,children:s})]})}function q(A){let{item:a}=A;const e=(0,s.Nr)(a);return e?(0,L.jsx)(S,{href:e,icon:"\ud83d\uddc3\ufe0f",title:a.label,description:a.description??(0,d.T)({message:"{count} items",id:"theme.docs.DocCard.categoryDescription",description:"The default description for a category card in the generated index about how many items this category includes"},{count:a.items.length})}):null}function k(A){let{item:a}=A;const e="Customize Engine Settings"===a.label?(0,L.jsx)("img",{src:h,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Remote Server Integration"===a.label?(0,L.jsx)("img",{src:F,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Manual Import"===a.label?(0,L.jsx)("img",{src:r,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.7"===a.label||"v0.4.6"===a.label||"v0.4.5"===a.label||"v0.4.4"===a.label||"v0.4.3"===a.label||"v0.4.2"===a.label||"v0.4.1"===a.label||"v0.4.0"===a.label||"v0.3.3"===a.label||"v0.3.2"===a.label||"v0.3.1"===a.label||"v0.3.0"===a.label||"v0.2.3"===a.label||"v0.2.2"===a.label||"v0.2.1"===a.label||"v0.2.0"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Extension Setup"===a.label?(0,L.jsx)("img",{src:o,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Import Extensions"===a.label?(0,L.jsx)("img",{src:u,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Continue Integration"===a.label?(0,L.jsx)("img",{src:c,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"OpenRouter"===a.label?(0,L.jsx)("img",{src:w,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Azure OpenAI"===a.label?(0,L.jsx)("img",{src:p,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Raycast"===a.label?(0,L.jsx)("img",{src:B,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Discord"===a.label?(0,L.jsx)("img",{src:E,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Open Interpreter"===a.label?(0,L.jsx)("img",{src:Y,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Permission Denied"===a.label?(0,L.jsx)("img",{src:V,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Unexpected Token"===a.label?(0,L.jsx)("img",{src:R,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Undefined Issue"===a.label?(0,L.jsx)("img",{src:I,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Something's Amiss"===a.label?(0,L.jsx)("img",{src:U,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Broken Build"===a.label?(0,L.jsx)("img",{src:v,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Jan not using GPU"===a.label?(0,L.jsx)("img",{src:W,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Mistral AI"===a.label?(0,L.jsx)("img",{src:K,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LM Studio"===a.label?(0,L.jsx)("img",{src:N,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Ollama"===a.label?(0,L.jsx)("img",{src:b,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"v0.4.8"===a.label||"v0.4.9"===a.label||"v0.4.10"===a.label?(0,L.jsx)("img",{src:n,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install with Docker"===a.label?(0,L.jsx)("img",{src:x,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Linux"===a.label?(0,L.jsx)("img",{src:M,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Mac"===a.label?(0,L.jsx)("img",{src:m,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Install on Windows"===a.label?(0,L.jsx)("img",{src:O,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Claude"===a.label?(0,L.jsx)("img",{src:Q,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"LlamaCPP Extension"===a.label?(0,L.jsx)("img",{src:G,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"TensorRT-LLM Extension"===a.label?(0,L.jsx)("img",{src:Z,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"Groq"===a.label?(0,L.jsx)("img",{src:X,alt:"Logo",width:"20px",height:"20px",style:{marginRight:"5px"}}):"\ud83d\udcc4\ufe0f",g=(0,s.cC)(a.docId??void 0);return(0,L.jsx)(S,{href:a.href,icon:e,title:a.label,description:a.description??g?.description})}function z(A){let{item:a}=A;switch(a.type){case"link":return(0,L.jsx)(k,{item:a});case"category":return(0,L.jsx)(q,{item:a});default:throw new Error(`unknown item type ${JSON.stringify(a)}`)}}function T(A){let{className:a}=A;const e=(0,s.$S)();return(0,L.jsx)(y,{items:e.items,className:a})}function y(A){const{items:a,className:e}=A;if(!a)return(0,L.jsx)(T,{...A});const t=(0,s.d1)(a);return(0,L.jsx)("section",{className:(0,g.A)("row",e),children:t.map(((A,a)=>(0,L.jsx)("article",{className:"col col--6 margin-bottom--lg",children:(0,L.jsx)(z,{item:A})},a)))})}},28453:(A,a,e)=>{e.d(a,{R:()=>i,x:()=>d});var g=e(96540);const s={},t=g.createContext(s);function i(A){const a=g.useContext(t);return g.useMemo((function(){return"function"==typeof A?A(a):{...a,...A}}),[a,A])}function d(A){let a;return a=A.disableParentContext?"function"==typeof A.components?A.components(s):A.components||s:i(A.components),g.createElement(t.Provider,{value:a},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/ef786345.34435d98.js b/assets/js/ef786345.34435d98.js new file mode 100644 index 00000000..8914e98f --- /dev/null +++ b/assets/js/ef786345.34435d98.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1315],{41158:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>p,contentTitle:()=>h,default:()=>m,frontMatter:()=>c,metadata:()=>u,toc:()=>g});var i=t(74848),s=t(28453),l=t(11470),r=t(19365);const a=t.p+"assets/images/download-825b1ad44749f938f6384742de782d05.gif",o=t.p+"assets/images/gpt-00460b6f9b2a98cd088c343c64b7ad46.gif",d=t.p+"assets/images/model-498b9da87c7167cc3911889a8716b9e1.gif",c={title:"Quickstart",slug:"/guides/quickstart",description:"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.",sidebar_position:2,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","quickstart","getting started","using AI model","installation"]},h=void 0,u={id:"guides/get-started/quickstart",title:"Quickstart",description:"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.",source:"@site/docs/guides/get-started/quickstart.mdx",sourceDirName:"guides/get-started",slug:"/guides/quickstart",permalink:"/guides/quickstart",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/quickstart.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"Quickstart",slug:"/guides/quickstart",description:"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.",sidebar_position:2,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","quickstart","getting started","using AI model","installation"]},sidebar:"guidesSidebar",previous:{title:"Overview",permalink:"/guides"},next:{title:"Manage Models",permalink:"/guides/models"}},p={},g=[{value:"Step 1: Install Jan Desktop",id:"step-1-install-jan-desktop",level:2},{value:"Pre-requisites",id:"pre-requisites",level:4},{value:"Stable Releases",id:"stable-releases",level:4},{value:"Nightly Releases",id:"nightly-releases",level:4},{value:"Experimental Model",id:"experimental-model",level:4},{value:"Install with Homebrew",id:"install-with-homebrew",level:4},{value:"Pre-requisites",id:"pre-requisites-1",level:4},{value:"Stable Releases",id:"stable-releases-1",level:4},{value:"Nightly Releases",id:"nightly-releases-1",level:4},{value:"Experimental Model",id:"experimental-model-1",level:4},{value:"Default Installation Directory",id:"default-installation-directory",level:4},{value:"Pre-requisites",id:"pre-requisites-2",level:4},{value:"Stable Releases",id:"stable-releases-2",level:4},{value:"Nightly Releases",id:"nightly-releases-2",level:4},{value:"Experimental Model",id:"experimental-model-2",level:4},{value:"Pre-requisites",id:"pre-requisites-3",level:3},{value:"Install Jan Development Build",id:"install-jan-development-build",level:3},{value:"Install Jan Production Build",id:"install-jan-production-build",level:3},{value:"Step 2: Download a Model",id:"step-2-download-a-model",level:2},{value:"Step 3: Connect to ChatGPT (Optional)",id:"step-3-connect-to-chatgpt-optional",level:2},{value:"Step 4: Chat with Models",id:"step-4-chat-with-models",level:2},{value:"Best Practices",id:"best-practices",level:2},{value:"Follow the Quickstart Guide",id:"follow-the-quickstart-guide",level:3},{value:"Select the Right Models",id:"select-the-right-models",level:3},{value:"Setting up Jan",id:"setting-up-jan",level:3},{value:"Integrations",id:"integrations",level:3},{value:"Mastering the Prompt Engineering",id:"mastering-the-prompt-engineering",level:3},{value:"Pre-configured Models",id:"pre-configured-models",level:2}];function x(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"step-1-install-jan-desktop",children:"Step 1: Install Jan Desktop"}),"\n",(0,i.jsxs)(l.A,{children:[(0,i.jsxs)(r.A,{value:"mac",label:"Mac",default:!0,children:[(0,i.jsx)(n.h4,{id:"pre-requisites",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Before installing Jan, ensure :"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"You have a Mac with an Apple Silicon Processor."}),"\n",(0,i.jsx)(n.li,{children:"Homebrew and its dependencies are installed for installing Jan with Homebrew package."}),"\n",(0,i.jsx)(n.li,{children:"Your macOS version is 10.15 or higher."}),"\n"]}),(0,i.jsx)(n.h4,{id:"stable-releases",children:"Stable Releases"}),(0,i.jsxs)(n.p,{children:["To download stable releases, go to ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"})," > select ",(0,i.jsx)(n.strong,{children:"Download for Mac"}),"."]}),(0,i.jsxs)(n.p,{children:["The download should be available as a ",(0,i.jsx)(n.code,{children:".dmg"}),"."]}),(0,i.jsx)(n.h4,{id:"nightly-releases",children:"Nightly Releases"}),(0,i.jsx)(n.p,{children:"We provide the Nightly Release so that you can test new features and see what might be coming in a future stable release. Please be aware that there might be bugs!"}),(0,i.jsxs)(n.p,{children:["You can download it from ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Jan's Discord"})," in the ",(0,i.jsx)(n.a,{href:"https://discord.gg/q8szebnxZ7",children:(0,i.jsx)(n.code,{children:"#nightly-builds"})})," channel."]}),(0,i.jsx)(n.h4,{id:"experimental-model",children:"Experimental Model"}),(0,i.jsxs)(n.p,{children:["To enable the experimental mode, go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Advanced Settings"})," and toggle the ",(0,i.jsx)(n.strong,{children:"Experimental Mode"})]}),(0,i.jsx)(n.h4,{id:"install-with-homebrew",children:"Install with Homebrew"}),(0,i.jsx)(n.p,{children:"Install Jan with the following Homebrew command:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-brew",children:"brew install --cask jan\n"})}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["Homebrew package installation is currently limited to ",(0,i.jsx)(n.strong,{children:"Apple Silicon Macs"}),", with upcoming support for Windows and Linux."]})})]}),(0,i.jsxs)(r.A,{value:"windows",label:"Windows",children:[(0,i.jsx)(n.h4,{id:"pre-requisites-1",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Ensure that your system meets the following requirements:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Windows 10 or higher is required to run Jan."}),"\n"]}),(0,i.jsx)(n.p,{children:"To enable GPU support, you will need:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"NVIDIA GPU with CUDA Toolkit 11.7 or higher"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver 470.63.01 or higher"}),"\n"]}),(0,i.jsx)(n.h4,{id:"stable-releases-1",children:"Stable Releases"}),(0,i.jsxs)(n.p,{children:["To download stable releases, go to ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"})," > select ",(0,i.jsx)(n.strong,{children:"Download for Windows"}),"."]}),(0,i.jsxs)(n.p,{children:["The download should be available as a ",(0,i.jsx)(n.code,{children:".exe"})," file."]}),(0,i.jsx)(n.h4,{id:"nightly-releases-1",children:"Nightly Releases"}),(0,i.jsx)(n.p,{children:"We provide the Nightly Release so that you can test new features and see what might be coming in a future stable release. Please be aware that there might be bugs!"}),(0,i.jsxs)(n.p,{children:["You can download it from ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Jan's Discord"})," in the ",(0,i.jsx)(n.a,{href:"https://discord.gg/q8szebnxZ7",children:(0,i.jsx)(n.code,{children:"#nightly-builds"})})," channel."]}),(0,i.jsx)(n.h4,{id:"experimental-model-1",children:"Experimental Model"}),(0,i.jsxs)(n.p,{children:["To enable the experimental mode, go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Advanced Settings"})," and toggle the ",(0,i.jsx)(n.strong,{children:"Experimental Mode"})]}),(0,i.jsx)(n.h4,{id:"default-installation-directory",children:"Default Installation Directory"}),(0,i.jsx)(n.p,{children:"By default, Jan is installed in the following directory:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Default installation directory\nC:\\Users\\{username}\\AppData\\Local\\Programs\\Jan\n"})}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]}),(0,i.jsxs)(r.A,{value:"linux",label:"Linux",children:[(0,i.jsx)(n.h4,{id:"pre-requisites-2",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Ensure that your system meets the following requirements:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["glibc 2.27 or higher (check with ",(0,i.jsx)(n.code,{children:"ldd --version"}),")"]}),"\n",(0,i.jsx)(n.li,{children:"gcc 11, g++ 11, cpp 11, or higher, refer to this link for more information."}),"\n"]}),(0,i.jsx)(n.p,{children:"To enable GPU support, you will need:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"NVIDIA GPU with CUDA Toolkit 11.7 or higher"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver 470.63.01 or higher"}),"\n"]}),(0,i.jsx)(n.h4,{id:"stable-releases-2",children:"Stable Releases"}),(0,i.jsxs)(n.p,{children:["To download stable releases, go to ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"})," > select ",(0,i.jsx)(n.strong,{children:"Download for Linux"}),"."]}),(0,i.jsxs)(n.p,{children:["The download should be available as a ",(0,i.jsx)(n.code,{children:".AppImage"})," file or a ",(0,i.jsx)(n.code,{children:".deb"})," file."]}),(0,i.jsx)(n.h4,{id:"nightly-releases-2",children:"Nightly Releases"}),(0,i.jsx)(n.p,{children:"We provide the Nightly Release so that you can test new features and see what might be coming in a future stable release. Please be aware that there might be bugs!"}),(0,i.jsxs)(n.p,{children:["You can download it from ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Jan's Discord"})," in the ",(0,i.jsx)(n.a,{href:"https://discord.gg/q8szebnxZ7",children:(0,i.jsx)(n.code,{children:"#nightly-builds"})})," channel."]}),(0,i.jsx)(n.h4,{id:"experimental-model-2",children:"Experimental Model"}),(0,i.jsxs)(n.p,{children:["To enable the experimental mode, go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Advanced Settings"})," and toggle the ",(0,i.jsx)(n.strong,{children:"Experimental Mode"})]}),(0,i.jsxs)(l.A,{groupId:"linux_type",children:[(0,i.jsx)(r.A,{value:"linux_main",label:"Linux",children:(0,i.jsxs)(n.p,{children:["To install Jan, you should use your package manager's install or ",(0,i.jsx)(n.code,{children:"dpkg"}),"."]})}),(0,i.jsxs)(r.A,{value:"deb_ub",label:"Debian / Ubuntu",children:[(0,i.jsx)(n.p,{children:"To install Jan, run the following command:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Install Jan using dpkg\nsudo dpkg -i jan-linux-amd64-{version}.deb\n\n# Install Jan using apt-get\nsudo apt-get install ./jan-linux-amd64-{version}.deb\n# where jan-linux-amd64-{version}.deb is path to the Jan package\n"})})]}),(0,i.jsxs)(r.A,{value:"other",label:"Others",children:[(0,i.jsx)(n.p,{children:"To install Jan, run the following commands:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Install Jan using AppImage\nchmod +x jan-linux-x86_64-{version}.AppImage\n./jan-linux-x86_64-{version}.AppImage\n# where jan-linux-x86_64-{version}.AppImage is path to the Jan package\n"})})]})]}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]}),(0,i.jsxs)(r.A,{value:"server",label:"Server-Side",children:[(0,i.jsx)(n.p,{children:"To install Jan from source, follow the steps below:"}),(0,i.jsx)(n.h3,{id:"pre-requisites-3",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Before proceeding with the installation of Jan from source, ensure that the following software versions are installed on your system:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Node.js version 20.0.0 or higher"}),"\n",(0,i.jsx)(n.li,{children:"Yarn version 1.22.0 or higher"}),"\n"]}),(0,i.jsx)(n.h3,{id:"install-jan-development-build",children:"Install Jan Development Build"}),(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ngit checkout DESIRED_BRANCH\ncd jan\n"})}),(0,i.jsxs)(n.ol,{start:"2",children:["\n",(0,i.jsx)(n.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),(0,i.jsxs)(n.ol,{start:"3",children:["\n",(0,i.jsx)(n.li,{children:"Run the development server."}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn dev\n"})}),(0,i.jsxs)(n.p,{children:["This will start the development server and open the desktop app. During this step, you may encounter notifications about installing base plugins. Simply click ",(0,i.jsx)(n.strong,{children:"OK"})," and ",(0,i.jsx)(n.strong,{children:"Next"})," to continue."]}),(0,i.jsx)(n.h3,{id:"install-jan-production-build",children:"Install Jan Production Build"}),(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ncd jan\n"})}),(0,i.jsxs)(n.ol,{start:"2",children:["\n",(0,i.jsx)(n.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),(0,i.jsxs)(n.ol,{start:"3",children:["\n",(0,i.jsx)(n.li,{children:"Run the production server."}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn\n"})}),(0,i.jsx)(n.p,{children:"This completes the installation process for Jan from source. The production-ready app for macOS can be found in the dist folder."}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]})]}),"\n",(0,i.jsx)(n.h2,{id:"step-2-download-a-model",children:"Step 2: Download a Model"}),"\n",(0,i.jsx)(n.p,{children:"Jan provides a variety of local AI models tailored to different needs, ready for download. These models are installed and run directly on the user's device."}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to the ",(0,i.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Select the models that you would like to install, to see a model details click the dropdown button."}),"\n",(0,i.jsxs)(n.li,{children:["Click the ",(0,i.jsx)(n.strong,{children:"Download"})," button."]}),"\n"]}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center"},children:(0,i.jsx)("img",{src:a,alt:"Download a Model"})}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"Ensure you select the appropriate model size by balancing performance, cost, and resource considerations in line with your task's specific requirements and hardware specifications."})}),"\n",(0,i.jsx)(n.h2,{id:"step-3-connect-to-chatgpt-optional",children:"Step 3: Connect to ChatGPT (Optional)"}),"\n",(0,i.jsx)(n.p,{children:"Jan also provides access to remote models hosted on external servers, requiring an API key for connectivity. For example, to use the ChatGPT model with Jan, you must input your API key by following these steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to the ",(0,i.jsx)(n.strong,{children:"Thread"})," tab."]}),"\n",(0,i.jsx)(n.li,{children:"Under the Model dropdown menu, select the ChatGPT model."}),"\n",(0,i.jsxs)(n.li,{children:["Fill in your ChatGPT API Key that you can get in your ",(0,i.jsx)(n.a,{href:"https://platform.openai.com/account/api-keys",children:"OpenAI platform"}),"."]}),"\n"]}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center"},children:(0,i.jsx)("img",{src:o,alt:"Connect to ChatGPT"})}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)(n.h2,{id:"step-4-chat-with-models",children:"Step 4: Chat with Models"}),"\n",(0,i.jsxs)(n.p,{children:["After downloading and configuring your model, you can immediately use it in the ",(0,i.jsx)(n.strong,{children:"Thread"})," tab."]}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center"},children:(0,i.jsx)("img",{src:d,alt:"Chat with a model"})}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)(n.h2,{id:"best-practices",children:"Best Practices"}),"\n",(0,i.jsx)(n.p,{children:"This section outlines best practices for developers, analysts, and AI enthusiasts to enhance their experience with Jan when adding AI locally to their computers. Implementing these practices will optimize the performance of AI models."}),"\n",(0,i.jsx)(n.h3,{id:"follow-the-quickstart-guide",children:"Follow the Quickstart Guide"}),"\n",(0,i.jsx)(n.p,{children:"The quickstart guide above is designed to facilitate a quick setup process. It provides a clear instruction and simple steps to get you up and running with Jan quickly. Even, if you are inexperienced in AI."}),"\n",(0,i.jsx)(n.h3,{id:"select-the-right-models",children:"Select the Right Models"}),"\n",(0,i.jsx)(n.p,{children:"Jan offers a range of pre-configured AI models that are suited for different purposes. You should identify which on that aligns with your objectives. There are factors to be considered:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Capabilities"}),"\n",(0,i.jsx)(n.li,{children:"Accuracy"}),"\n",(0,i.jsx)(n.li,{children:"Processing Speed"}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Some of these factors also depend on your hardware, please see Hardware Requirement."}),"\n",(0,i.jsx)(n.li,{children:"Choosing the right model is important to achieve the best performance."}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"setting-up-jan",children:"Setting up Jan"}),"\n",(0,i.jsxs)(n.p,{children:["Ensure that you familiarize yourself with the Jan application. Jan offers advanced settings that you can adjust. These settings may influence how your AI behaves locally. Please see the ",(0,i.jsx)(n.a,{href:"/guides/advanced",children:"Advanced Settings"})," article for a complete list of Jan's configurations and instructions on how to configure them."]}),"\n",(0,i.jsx)(n.h3,{id:"integrations",children:"Integrations"}),"\n",(0,i.jsx)(n.p,{children:"Jan can work with many different systems and tools. Whether you are incorporating Jan with any open-source LLM provider or other tools, it is important to understand the integration capabilities and limitations."}),"\n",(0,i.jsx)(n.h3,{id:"mastering-the-prompt-engineering",children:"Mastering the Prompt Engineering"}),"\n",(0,i.jsx)(n.p,{children:"Prompt engineering is an important aspect when dealing with AI models to generate the desired outputs. Mastering this skill can significantly enhance the performance and the responses of the AI. Below are some tips that you can do for prompt engineering:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Ask the model to adopt a persona"}),"\n",(0,i.jsx)(n.li,{children:"Be specific and details get a more specific answers"}),"\n",(0,i.jsx)(n.li,{children:"Provide examples or preference text or context at the beginning"}),"\n",(0,i.jsx)(n.li,{children:"Use a clear and concise language"}),"\n",(0,i.jsx)(n.li,{children:"Use certain keywords and phrases"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"pre-configured-models",children:"Pre-configured Models"}),"\n",(0,i.jsxs)(n.p,{children:["To see the full list of Jan's pre-configured models, please see our official GitHub ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"here"}),"."]})]})}function m(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(x,{...e})}):x(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>r});t(96540);var i=t(18215);const s={tabItem:"tabItem_Ymn6"};var l=t(74848);function r(e){let{children:n,hidden:t,className:r}=e;return(0,l.jsx)("div",{role:"tabpanel",className:(0,i.A)(s.tabItem,r),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>w});var i=t(96540),s=t(18215),l=t(23104),r=t(56347),a=t(205),o=t(57485),d=t(31682),c=t(89466);function h(e){return i.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,i.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function u(e){const{values:n,children:t}=e;return(0,i.useMemo)((()=>{const e=n??function(e){return h(e).map((e=>{let{props:{value:n,label:t,attributes:i,default:s}}=e;return{value:n,label:t,attributes:i,default:s}}))}(t);return function(e){const n=(0,d.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function g(e){let{queryString:n=!1,groupId:t}=e;const s=(0,r.W6)(),l=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,o.aZ)(l),(0,i.useCallback)((e=>{if(!l)return;const n=new URLSearchParams(s.location.search);n.set(l,e),s.replace({...s.location,search:n.toString()})}),[l,s])]}function x(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,l=u(e),[r,o]=(0,i.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const i=t.find((e=>e.default))??t[0];if(!i)throw new Error("Unexpected error: 0 tabValues");return i.value}({defaultValue:n,tabValues:l}))),[d,h]=g({queryString:t,groupId:s}),[x,m]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,l]=(0,c.Dv)(t);return[s,(0,i.useCallback)((e=>{t&&l.set(e)}),[t,l])]}({groupId:s}),j=(()=>{const e=d??x;return p({value:e,tabValues:l})?e:null})();(0,a.A)((()=>{j&&o(j)}),[j]);return{selectedValue:r,selectValue:(0,i.useCallback)((e=>{if(!p({value:e,tabValues:l}))throw new Error(`Can't select invalid tab value=${e}`);o(e),h(e),m(e)}),[h,m,l]),tabValues:l}}var m=t(92303);const j={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var f=t(74848);function b(e){let{className:n,block:t,selectedValue:i,selectValue:r,tabValues:a}=e;const o=[],{blockElementScrollPositionUntilNextRender:d}=(0,l.a_)(),c=e=>{const n=e.currentTarget,t=o.indexOf(n),s=a[t].value;s!==i&&(d(n),r(s))},h=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const t=o.indexOf(e.currentTarget)+1;n=o[t]??o[0];break}case"ArrowLeft":{const t=o.indexOf(e.currentTarget)-1;n=o[t]??o[o.length-1];break}}n?.focus()};return(0,f.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:a.map((e=>{let{value:n,label:t,attributes:l}=e;return(0,f.jsx)("li",{role:"tab",tabIndex:i===n?0:-1,"aria-selected":i===n,ref:e=>o.push(e),onKeyDown:h,onClick:c,...l,className:(0,s.A)("tabs__item",j.tabItem,l?.className,{"tabs__item--active":i===n}),children:t??n},n)}))})}function v(e){let{lazy:n,children:t,selectedValue:s}=e;const l=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=l.find((e=>e.props.value===s));return e?(0,i.cloneElement)(e,{className:"margin-top--md"}):null}return(0,f.jsx)("div",{className:"margin-top--md",children:l.map(((e,n)=>(0,i.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function y(e){const n=x(e);return(0,f.jsxs)("div",{className:(0,s.A)("tabs-container",j.tabList),children:[(0,f.jsx)(b,{...e,...n}),(0,f.jsx)(v,{...e,...n})]})}function w(e){const n=(0,m.A)();return(0,f.jsx)(y,{...e,children:h(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>a});var i=t(96540);const s={},l=i.createContext(s);function r(e){const n=i.useContext(l);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),i.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ef786345.9e2db065.js b/assets/js/ef786345.9e2db065.js deleted file mode 100644 index 3b9c4079..00000000 --- a/assets/js/ef786345.9e2db065.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1315],{41158:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>p,contentTitle:()=>h,default:()=>m,frontMatter:()=>c,metadata:()=>u,toc:()=>g});var i=t(74848),s=t(28453),l=t(11470),r=t(19365);const a=t.p+"assets/images/download-825b1ad44749f938f6384742de782d05.gif",o=t.p+"assets/images/gpt-00460b6f9b2a98cd088c343c64b7ad46.gif",d=t.p+"assets/images/model-498b9da87c7167cc3911889a8716b9e1.gif",c={title:"Quickstart",slug:"/guides/quickstart",description:"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.",sidebar_position:2,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","quickstart","getting started","using AI model","installation"]},h=void 0,u={id:"guides/get-started/quickstart",title:"Quickstart",description:"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.",source:"@site/docs/guides/get-started/quickstart.mdx",sourceDirName:"guides/get-started",slug:"/guides/quickstart",permalink:"/guides/quickstart",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/quickstart.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"Quickstart",slug:"/guides/quickstart",description:"Get started quickly with Jan, a ChatGPT-alternative that runs on your own computer, with a local API server. Learn how to install Jan and select an AI model to start chatting.",sidebar_position:2,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","quickstart","getting started","using AI model","installation"]},sidebar:"guidesSidebar",previous:{title:"Overview",permalink:"/guides"},next:{title:"Manage Models",permalink:"/guides/models"}},p={},g=[{value:"Step 1: Install Jan Desktop",id:"step-1-install-jan-desktop",level:2},{value:"Pre-requisites",id:"pre-requisites",level:4},{value:"Stable Releases",id:"stable-releases",level:4},{value:"Nightly Releases",id:"nightly-releases",level:4},{value:"Experimental Model",id:"experimental-model",level:4},{value:"Install with Homebrew",id:"install-with-homebrew",level:4},{value:"Pre-requisites",id:"pre-requisites-1",level:4},{value:"Stable Releases",id:"stable-releases-1",level:4},{value:"Nightly Releases",id:"nightly-releases-1",level:4},{value:"Experimental Model",id:"experimental-model-1",level:4},{value:"Default Installation Directory",id:"default-installation-directory",level:4},{value:"Pre-requisites",id:"pre-requisites-2",level:4},{value:"Stable Releases",id:"stable-releases-2",level:4},{value:"Nightly Releases",id:"nightly-releases-2",level:4},{value:"Experimental Model",id:"experimental-model-2",level:4},{value:"Pre-requisites",id:"pre-requisites-3",level:3},{value:"Install Jan Development Build",id:"install-jan-development-build",level:3},{value:"Install Jan Production Build",id:"install-jan-production-build",level:3},{value:"Step 2: Download a Model",id:"step-2-download-a-model",level:2},{value:"Step 3: Connect to ChatGPT (Optional)",id:"step-3-connect-to-chatgpt-optional",level:2},{value:"Step 4: Chat with Models",id:"step-4-chat-with-models",level:2},{value:"Best Practices",id:"best-practices",level:2},{value:"Follow the Quickstart Guide",id:"follow-the-quickstart-guide",level:3},{value:"Select the Right Models",id:"select-the-right-models",level:3},{value:"Setting up Jan",id:"setting-up-jan",level:3},{value:"Integrations",id:"integrations",level:3},{value:"Mastering the Prompt Engineering",id:"mastering-the-prompt-engineering",level:3},{value:"Pre-configured Models",id:"pre-configured-models",level:2}];function x(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,s.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"step-1-install-jan-desktop",children:"Step 1: Install Jan Desktop"}),"\n",(0,i.jsxs)(l.A,{children:[(0,i.jsxs)(r.A,{value:"mac",label:"Mac",default:!0,children:[(0,i.jsx)(n.h4,{id:"pre-requisites",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Before installing Jan, ensure :"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"You have a Mac with an Apple Silicon Processor."}),"\n",(0,i.jsx)(n.li,{children:"Homebrew and its dependencies are installed for installing Jan with Homebrew package."}),"\n",(0,i.jsx)(n.li,{children:"Your macOS version is 10.15 or higher."}),"\n"]}),(0,i.jsx)(n.h4,{id:"stable-releases",children:"Stable Releases"}),(0,i.jsxs)(n.p,{children:["To download stable releases, go to ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"})," > select ",(0,i.jsx)(n.strong,{children:"Download for Mac"}),"."]}),(0,i.jsxs)(n.p,{children:["The download should be available as a ",(0,i.jsx)(n.code,{children:".dmg"}),"."]}),(0,i.jsx)(n.h4,{id:"nightly-releases",children:"Nightly Releases"}),(0,i.jsx)(n.p,{children:"We provide the Nightly Release so that you can test new features and see what might be coming in a future stable release. Please be aware that there might be bugs!"}),(0,i.jsxs)(n.p,{children:["You can download it from ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Jan's Discord"})," in the ",(0,i.jsx)(n.a,{href:"https://discord.gg/q8szebnxZ7",children:(0,i.jsx)(n.code,{children:"#nightly-builds"})})," channel."]}),(0,i.jsx)(n.h4,{id:"experimental-model",children:"Experimental Model"}),(0,i.jsxs)(n.p,{children:["To enable the experimental mode, go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Advanced Settings"})," and toggle the ",(0,i.jsx)(n.strong,{children:"Experimental Mode"})]}),(0,i.jsx)(n.h4,{id:"install-with-homebrew",children:"Install with Homebrew"}),(0,i.jsx)(n.p,{children:"Install Jan with the following Homebrew command:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-brew",children:"brew install --cask jan\n"})}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["Homebrew package installation is currently limited to ",(0,i.jsx)(n.strong,{children:"Apple Silicon Macs"}),", with upcoming support for Windows and Linux."]})})]}),(0,i.jsxs)(r.A,{value:"windows",label:"Windows",children:[(0,i.jsx)(n.h4,{id:"pre-requisites-1",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Ensure that your system meets the following requirements:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Windows 10 or higher is required to run Jan."}),"\n"]}),(0,i.jsx)(n.p,{children:"To enable GPU support, you will need:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"NVIDIA GPU with CUDA Toolkit 11.7 or higher"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver 470.63.01 or higher"}),"\n"]}),(0,i.jsx)(n.h4,{id:"stable-releases-1",children:"Stable Releases"}),(0,i.jsxs)(n.p,{children:["To download stable releases, go to ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"})," > select ",(0,i.jsx)(n.strong,{children:"Download for Windows"}),"."]}),(0,i.jsxs)(n.p,{children:["The download should be available as a ",(0,i.jsx)(n.code,{children:".exe"})," file."]}),(0,i.jsx)(n.h4,{id:"nightly-releases-1",children:"Nightly Releases"}),(0,i.jsx)(n.p,{children:"We provide the Nightly Release so that you can test new features and see what might be coming in a future stable release. Please be aware that there might be bugs!"}),(0,i.jsxs)(n.p,{children:["You can download it from ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Jan's Discord"})," in the ",(0,i.jsx)(n.a,{href:"https://discord.gg/q8szebnxZ7",children:(0,i.jsx)(n.code,{children:"#nightly-builds"})})," channel."]}),(0,i.jsx)(n.h4,{id:"experimental-model-1",children:"Experimental Model"}),(0,i.jsxs)(n.p,{children:["To enable the experimental mode, go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Advanced Settings"})," and toggle the ",(0,i.jsx)(n.strong,{children:"Experimental Mode"})]}),(0,i.jsx)(n.h4,{id:"default-installation-directory",children:"Default Installation Directory"}),(0,i.jsx)(n.p,{children:"By default, Jan is installed in the following directory:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Default installation directory\nC:\\Users\\{username}\\AppData\\Local\\Programs\\Jan\n"})}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]}),(0,i.jsxs)(r.A,{value:"linux",label:"Linux",children:[(0,i.jsx)(n.h4,{id:"pre-requisites-2",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Ensure that your system meets the following requirements:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsxs)(n.li,{children:["glibc 2.27 or higher (check with ",(0,i.jsx)(n.code,{children:"ldd --version"}),")"]}),"\n",(0,i.jsx)(n.li,{children:"gcc 11, g++ 11, cpp 11, or higher, refer to this link for more information."}),"\n"]}),(0,i.jsx)(n.p,{children:"To enable GPU support, you will need:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"NVIDIA GPU with CUDA Toolkit 11.7 or higher"}),"\n",(0,i.jsx)(n.li,{children:"NVIDIA driver 470.63.01 or higher"}),"\n"]}),(0,i.jsx)(n.h4,{id:"stable-releases-2",children:"Stable Releases"}),(0,i.jsxs)(n.p,{children:["To download stable releases, go to ",(0,i.jsx)(n.a,{href:"https://jan.ai/",children:"Jan"})," > select ",(0,i.jsx)(n.strong,{children:"Download for Linux"}),"."]}),(0,i.jsxs)(n.p,{children:["The download should be available as a ",(0,i.jsx)(n.code,{children:".AppImage"})," file or a ",(0,i.jsx)(n.code,{children:".deb"})," file."]}),(0,i.jsx)(n.h4,{id:"nightly-releases-2",children:"Nightly Releases"}),(0,i.jsx)(n.p,{children:"We provide the Nightly Release so that you can test new features and see what might be coming in a future stable release. Please be aware that there might be bugs!"}),(0,i.jsxs)(n.p,{children:["You can download it from ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Jan's Discord"})," in the ",(0,i.jsx)(n.a,{href:"https://discord.gg/q8szebnxZ7",children:(0,i.jsx)(n.code,{children:"#nightly-builds"})})," channel."]}),(0,i.jsx)(n.h4,{id:"experimental-model-2",children:"Experimental Model"}),(0,i.jsxs)(n.p,{children:["To enable the experimental mode, go to ",(0,i.jsx)(n.strong,{children:"Settings"})," > ",(0,i.jsx)(n.strong,{children:"Advanced Settings"})," and toggle the ",(0,i.jsx)(n.strong,{children:"Experimental Mode"})]}),(0,i.jsxs)(l.A,{groupId:"linux_type",children:[(0,i.jsx)(r.A,{value:"linux_main",label:"Linux",children:(0,i.jsxs)(n.p,{children:["To install Jan, you should use your package manager's install or ",(0,i.jsx)(n.code,{children:"dpkg"}),"."]})}),(0,i.jsxs)(r.A,{value:"deb_ub",label:"Debian / Ubuntu",children:[(0,i.jsx)(n.p,{children:"To install Jan, run the following command:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Install Jan using dpkg\nsudo dpkg -i jan-linux-amd64-{version}.deb\n\n# Install Jan using apt-get\nsudo apt-get install ./jan-linux-amd64-{version}.deb\n# where jan-linux-amd64-{version}.deb is path to the Jan package\n"})})]}),(0,i.jsxs)(r.A,{value:"other",label:"Others",children:[(0,i.jsx)(n.p,{children:"To install Jan, run the following commands:"}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-sh",children:"# Install Jan using AppImage\nchmod +x jan-linux-x86_64-{version}.AppImage\n./jan-linux-x86_64-{version}.AppImage\n# where jan-linux-x86_64-{version}.AppImage is path to the Jan package\n"})})]})]}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]}),(0,i.jsxs)(r.A,{value:"server",label:"Server-Side",children:[(0,i.jsx)(n.p,{children:"To install Jan from source, follow the steps below:"}),(0,i.jsx)(n.h3,{id:"pre-requisites-3",children:"Pre-requisites"}),(0,i.jsx)(n.p,{children:"Before proceeding with the installation of Jan from source, ensure that the following software versions are installed on your system:"}),(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Node.js version 20.0.0 or higher"}),"\n",(0,i.jsx)(n.li,{children:"Yarn version 1.22.0 or higher"}),"\n"]}),(0,i.jsx)(n.h3,{id:"install-jan-development-build",children:"Install Jan Development Build"}),(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ngit checkout DESIRED_BRANCH\ncd jan\n"})}),(0,i.jsxs)(n.ol,{start:"2",children:["\n",(0,i.jsx)(n.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),(0,i.jsxs)(n.ol,{start:"3",children:["\n",(0,i.jsx)(n.li,{children:"Run the development server."}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn dev\n"})}),(0,i.jsxs)(n.p,{children:["This will start the development server and open the desktop app. During this step, you may encounter notifications about installing base plugins. Simply click ",(0,i.jsx)(n.strong,{children:"OK"})," and ",(0,i.jsx)(n.strong,{children:"Next"})," to continue."]}),(0,i.jsx)(n.h3,{id:"install-jan-production-build",children:"Install Jan Production Build"}),(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsx)(n.li,{children:"Clone the Jan repository from GitHub by using the following command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"git clone https://github.com/janhq/jan\ncd jan\n"})}),(0,i.jsxs)(n.ol,{start:"2",children:["\n",(0,i.jsx)(n.li,{children:"Install the required dependencies by using the following Yarn command:"}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn install\n\n# Build core module\nyarn build:core\n\n# Packing base plugins\nyarn build:plugins\n\n# Packing uikit\nyarn build:uikit\n"})}),(0,i.jsxs)(n.ol,{start:"3",children:["\n",(0,i.jsx)(n.li,{children:"Run the production server."}),"\n"]}),(0,i.jsx)(n.pre,{children:(0,i.jsx)(n.code,{className:"language-bash",children:"yarn\n"})}),(0,i.jsx)(n.p,{children:"This completes the installation process for Jan from source. The production-ready app for macOS can be found in the dist folder."}),(0,i.jsx)(n.admonition,{type:"warning",children:(0,i.jsxs)(n.p,{children:["If you are stuck in a broken build, go to the ",(0,i.jsx)(n.a,{href:"/troubleshooting/#broken-build",children:"Broken Build"})," section of Common Errors."]})})]})]}),"\n",(0,i.jsx)(n.h2,{id:"step-2-download-a-model",children:"Step 2: Download a Model"}),"\n",(0,i.jsx)(n.p,{children:"Jan provides a variety of local AI models tailored to different needs, ready for download. These models are installed and run directly on the user's device."}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to the ",(0,i.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Select the models that you would like to install, to see a model details click the dropdown button."}),"\n",(0,i.jsxs)(n.li,{children:["Click the ",(0,i.jsx)(n.strong,{children:"Download"})," button."]}),"\n"]}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center"},children:(0,i.jsx)("img",{src:a,alt:"Download a Model"})}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsx)(n.p,{children:"Ensure you select the appropriate model size by balancing performance, cost, and resource considerations in line with your task's specific requirements and hardware specifications."})}),"\n",(0,i.jsx)(n.h2,{id:"step-3-connect-to-chatgpt-optional",children:"Step 3: Connect to ChatGPT (Optional)"}),"\n",(0,i.jsx)(n.p,{children:"Jan also provides access to remote models hosted on external servers, requiring an API key for connectivity. For example, to use the ChatGPT model with Jan, you must input your API key by following these steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Go to the ",(0,i.jsx)(n.strong,{children:"Thread"})," tab."]}),"\n",(0,i.jsx)(n.li,{children:"Under the Model dropdown menu, select the ChatGPT model."}),"\n",(0,i.jsxs)(n.li,{children:["Fill in your ChatGPT API Key that you can get in your ",(0,i.jsx)(n.a,{href:"https://platform.openai.com/account/api-keys",children:"OpenAI platform"}),"."]}),"\n"]}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center"},children:(0,i.jsx)("img",{src:o,alt:"Connect to ChatGPT"})}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)(n.h2,{id:"step-4-chat-with-models",children:"Step 4: Chat with Models"}),"\n",(0,i.jsxs)(n.p,{children:["After downloading and configuring your model, you can immediately use it in the ",(0,i.jsx)(n.strong,{children:"Thread"})," tab."]}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center"},children:(0,i.jsx)("img",{src:d,alt:"Chat with a model"})}),"\n",(0,i.jsx)("br",{}),"\n",(0,i.jsx)(n.h2,{id:"best-practices",children:"Best Practices"}),"\n",(0,i.jsx)(n.p,{children:"This section outlines best practices for developers, analysts, and AI enthusiasts to enhance their experience with Jan when adding AI locally to their computers. Implementing these practices will optimize the performance of AI models."}),"\n",(0,i.jsx)(n.h3,{id:"follow-the-quickstart-guide",children:"Follow the Quickstart Guide"}),"\n",(0,i.jsx)(n.p,{children:"The quickstart guide above is designed to facilitate a quick setup process. It provides a clear instruction and simple steps to get you up and running with Jan quickly. Even, if you are inexperienced in AI."}),"\n",(0,i.jsx)(n.h3,{id:"select-the-right-models",children:"Select the Right Models"}),"\n",(0,i.jsx)(n.p,{children:"Jan offers a range of pre-configured AI models that are suited for different purposes. You should identify which on that aligns with your objectives. There are factors to be considered:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Capabilities"}),"\n",(0,i.jsx)(n.li,{children:"Accuracy"}),"\n",(0,i.jsx)(n.li,{children:"Processing Speed"}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Some of these factors also depend on your hardware, please see Hardware Requirement."}),"\n",(0,i.jsx)(n.li,{children:"Choosing the right model is important to achieve the best performance."}),"\n"]})}),"\n",(0,i.jsx)(n.h3,{id:"setting-up-jan",children:"Setting up Jan"}),"\n",(0,i.jsxs)(n.p,{children:["Ensure that you familiarize yourself with the Jan application. Jan offers advanced settings that you can adjust. These settings may influence how your AI behaves locally. Please see the ",(0,i.jsx)(n.a,{href:"/guides/advanced",children:"Advanced Settings"})," article for a complete list of Jan's configurations and instructions on how to configure them."]}),"\n",(0,i.jsx)(n.h3,{id:"integrations",children:"Integrations"}),"\n",(0,i.jsx)(n.p,{children:"Jan can work with many different systems and tools. Whether you are incorporating Jan with any open-source LLM provider or other tools, it is important to understand the integration capabilities and limitations."}),"\n",(0,i.jsx)(n.h3,{id:"mastering-the-prompt-engineering",children:"Mastering the Prompt Engineering"}),"\n",(0,i.jsx)(n.p,{children:"Prompt engineering is an important aspect when dealing with AI models to generate the desired outputs. Mastering this skill can significantly enhance the performance and the responses of the AI. Below are some tips that you can do for prompt engineering:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Ask the model to adopt a persona"}),"\n",(0,i.jsx)(n.li,{children:"Be specific and details get a more specific answers"}),"\n",(0,i.jsx)(n.li,{children:"Provide examples or preference text or context at the beginning"}),"\n",(0,i.jsx)(n.li,{children:"Use a clear and concise language"}),"\n",(0,i.jsx)(n.li,{children:"Use certain keywords and phrases"}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"pre-configured-models",children:"Pre-configured Models"}),"\n",(0,i.jsxs)(n.p,{children:["To see the full list of Jan's pre-configured models, please see our official GitHub ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"here"}),"."]})]})}function m(e={}){const{wrapper:n}={...(0,s.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(x,{...e})}):x(e)}},19365:(e,n,t)=>{t.d(n,{A:()=>r});t(96540);var i=t(18215);const s={tabItem:"tabItem_Ymn6"};var l=t(74848);function r(e){let{children:n,hidden:t,className:r}=e;return(0,l.jsx)("div",{role:"tabpanel",className:(0,i.A)(s.tabItem,r),hidden:t,children:n})}},11470:(e,n,t)=>{t.d(n,{A:()=>w});var i=t(96540),s=t(18215),l=t(23104),r=t(56347),a=t(205),o=t(57485),d=t(31682),c=t(89466);function h(e){return i.Children.toArray(e).filter((e=>"\n"!==e)).map((e=>{if(!e||(0,i.isValidElement)(e)&&function(e){const{props:n}=e;return!!n&&"object"==typeof n&&"value"in n}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}function u(e){const{values:n,children:t}=e;return(0,i.useMemo)((()=>{const e=n??function(e){return h(e).map((e=>{let{props:{value:n,label:t,attributes:i,default:s}}=e;return{value:n,label:t,attributes:i,default:s}}))}(t);return function(e){const n=(0,d.X)(e,((e,n)=>e.value===n.value));if(n.length>0)throw new Error(`Docusaurus error: Duplicate values "${n.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[n,t])}function p(e){let{value:n,tabValues:t}=e;return t.some((e=>e.value===n))}function g(e){let{queryString:n=!1,groupId:t}=e;const s=(0,r.W6)(),l=function(e){let{queryString:n=!1,groupId:t}=e;if("string"==typeof n)return n;if(!1===n)return null;if(!0===n&&!t)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return t??null}({queryString:n,groupId:t});return[(0,o.aZ)(l),(0,i.useCallback)((e=>{if(!l)return;const n=new URLSearchParams(s.location.search);n.set(l,e),s.replace({...s.location,search:n.toString()})}),[l,s])]}function x(e){const{defaultValue:n,queryString:t=!1,groupId:s}=e,l=u(e),[r,o]=(0,i.useState)((()=>function(e){let{defaultValue:n,tabValues:t}=e;if(0===t.length)throw new Error("Docusaurus error: the component requires at least one children component");if(n){if(!p({value:n,tabValues:t}))throw new Error(`Docusaurus error: The has a defaultValue "${n}" but none of its children has the corresponding value. Available values are: ${t.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return n}const i=t.find((e=>e.default))??t[0];if(!i)throw new Error("Unexpected error: 0 tabValues");return i.value}({defaultValue:n,tabValues:l}))),[d,h]=g({queryString:t,groupId:s}),[x,m]=function(e){let{groupId:n}=e;const t=function(e){return e?`docusaurus.tab.${e}`:null}(n),[s,l]=(0,c.Dv)(t);return[s,(0,i.useCallback)((e=>{t&&l.set(e)}),[t,l])]}({groupId:s}),j=(()=>{const e=d??x;return p({value:e,tabValues:l})?e:null})();(0,a.A)((()=>{j&&o(j)}),[j]);return{selectedValue:r,selectValue:(0,i.useCallback)((e=>{if(!p({value:e,tabValues:l}))throw new Error(`Can't select invalid tab value=${e}`);o(e),h(e),m(e)}),[h,m,l]),tabValues:l}}var m=t(92303);const j={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};var f=t(74848);function b(e){let{className:n,block:t,selectedValue:i,selectValue:r,tabValues:a}=e;const o=[],{blockElementScrollPositionUntilNextRender:d}=(0,l.a_)(),c=e=>{const n=e.currentTarget,t=o.indexOf(n),s=a[t].value;s!==i&&(d(n),r(s))},h=e=>{let n=null;switch(e.key){case"Enter":c(e);break;case"ArrowRight":{const t=o.indexOf(e.currentTarget)+1;n=o[t]??o[0];break}case"ArrowLeft":{const t=o.indexOf(e.currentTarget)-1;n=o[t]??o[o.length-1];break}}n?.focus()};return(0,f.jsx)("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,s.A)("tabs",{"tabs--block":t},n),children:a.map((e=>{let{value:n,label:t,attributes:l}=e;return(0,f.jsx)("li",{role:"tab",tabIndex:i===n?0:-1,"aria-selected":i===n,ref:e=>o.push(e),onKeyDown:h,onClick:c,...l,className:(0,s.A)("tabs__item",j.tabItem,l?.className,{"tabs__item--active":i===n}),children:t??n},n)}))})}function v(e){let{lazy:n,children:t,selectedValue:s}=e;const l=(Array.isArray(t)?t:[t]).filter(Boolean);if(n){const e=l.find((e=>e.props.value===s));return e?(0,i.cloneElement)(e,{className:"margin-top--md"}):null}return(0,f.jsx)("div",{className:"margin-top--md",children:l.map(((e,n)=>(0,i.cloneElement)(e,{key:n,hidden:e.props.value!==s})))})}function y(e){const n=x(e);return(0,f.jsxs)("div",{className:(0,s.A)("tabs-container",j.tabList),children:[(0,f.jsx)(b,{...e,...n}),(0,f.jsx)(v,{...e,...n})]})}function w(e){const n=(0,m.A)();return(0,f.jsx)(y,{...e,children:h(e.children)},String(n))}},28453:(e,n,t)=>{t.d(n,{R:()=>r,x:()=>a});var i=t(96540);const s={},l=i.createContext(s);function r(e){const n=i.useContext(l);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:r(e.components),i.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f078801c.15f00ca3.js b/assets/js/f078801c.15f00ca3.js new file mode 100644 index 00000000..37567f34 --- /dev/null +++ b/assets/js/f078801c.15f00ca3.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8740],{25526:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>s,metadata:()=>d,toc:()=>a});var t=i(74848),o=i(28453);const s={title:"OpenAI API",sidebar_position:2,slug:"/guides/engines/openai",description:"A step-by-step guide on how to integrate Jan with Azure OpenAI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","integration","Azure OpenAI Service"]},r=void 0,d={id:"guides/remote-providers/openai",title:"OpenAI API",description:"A step-by-step guide on how to integrate Jan with Azure OpenAI.",source:"@site/docs/guides/remote-providers/openai.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/openai",permalink:"/guides/engines/openai",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/openai.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"OpenAI API",sidebar_position:2,slug:"/guides/engines/openai",description:"A step-by-step guide on how to integrate Jan with Azure OpenAI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","integration","Azure OpenAI Service"]},sidebar:"guidesSidebar",previous:{title:"Mistral API",permalink:"/guides/engines/mistral"},next:{title:"Any OAI Compatible Server",permalink:"/guides/engines/remote-server"}},l={},a=[{value:"OpenAI Platform",id:"openai-platform",level:2},{value:"1. Create a Model JSON",id:"1-create-a-model-json",level:3},{value:"model.json",id:"modeljson",level:3},{value:"Settings",id:"settings",level:4},{value:"Parameters",id:"parameters",level:4},{value:"2. Configure OpenAI API Keys",id:"2-configure-openai-api-keys",level:3},{value:"3. Start the Model",id:"3-start-the-model",level:3},{value:"Azure OpenAI",id:"azure-openai",level:2},{value:"Step 1: Configure Azure OpenAI Service API Key",id:"step-1-configure-azure-openai-service-api-key",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Start the Model",id:"step-3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,o.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"openai-platform",children:"OpenAI Platform"}),"\n",(0,t.jsx)(n.h3,{id:"1-create-a-model-json",children:"1. Create a Model JSON"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In ",(0,t.jsx)(n.code,{children:"~/jan/models"}),", create a folder named ",(0,t.jsx)(n.code,{children:"gpt-3.5-turbo-16k"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In this folder, add a ",(0,t.jsx)(n.code,{children:"model.json"})," file with Filename as ",(0,t.jsx)(n.code,{children:"model.json"}),", ",(0,t.jsx)(n.code,{children:"id"})," matching folder name, ",(0,t.jsx)(n.code,{children:"Format"})," as ",(0,t.jsx)(n.code,{children:"api"}),", ",(0,t.jsx)(n.code,{children:"Engine"})," as ",(0,t.jsx)(n.code,{children:"openai"}),", and ",(0,t.jsx)(n.code,{children:"State"})," as ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/gpt-3.5-turbo-16k/model.json"',children:'{\n "sources": [\n {\n "filename": "openai",\n "url": "https://openai.com"\n }\n ],\n "id": "gpt-3.5-turbo-16k",\n "object": "model",\n "name": "OpenAI GPT 3.5 Turbo 16k",\n "version": "1.0",\n "description": "OpenAI GPT 3.5 Turbo 16k model is extremely good",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "OpenAI",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"modeljson",children:(0,t.jsx)(n.code,{children:"model.json"})}),"\n",(0,t.jsxs)(n.p,{children:["The ",(0,t.jsx)(n.code,{children:"model.json"})," file is used to set up your local models."]}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["If you've set up your model's configuration in ",(0,t.jsx)(n.code,{children:"nitro.json"}),", please note that ",(0,t.jsx)(n.code,{children:"model.json"})," can overwrite the settings."]}),"\n",(0,t.jsxs)(n.li,{children:["When using OpenAI models like GPT-3.5 and GPT-4, you can use the default settings in ",(0,t.jsx)(n.code,{children:"model.json"})," file."]}),"\n"]})}),"\n",(0,t.jsx)(n.p,{children:"There are two important fields in model.json that you need to setup:"}),"\n",(0,t.jsx)(n.h4,{id:"settings",children:"Settings"}),"\n",(0,t.jsx)(n.p,{children:"This is the field where to set your engine configurations, there are two imporant field that you need to define for your local models:"}),"\n",(0,t.jsxs)(n.table,{children:[(0,t.jsx)(n.thead,{children:(0,t.jsxs)(n.tr,{children:[(0,t.jsx)(n.th,{children:"Term"}),(0,t.jsx)(n.th,{children:"Description"})]})}),(0,t.jsxs)(n.tbody,{children:[(0,t.jsxs)(n.tr,{children:[(0,t.jsx)(n.td,{children:(0,t.jsx)(n.code,{children:"ctx_len"})}),(0,t.jsx)(n.td,{children:"Defined based on the model's context size."})]}),(0,t.jsxs)(n.tr,{children:[(0,t.jsx)(n.td,{children:(0,t.jsx)(n.code,{children:"prompt_template"})}),(0,t.jsx)(n.td,{children:"Defined based on the model's trained template (e.g., ChatML, Alpaca)."})]})]})]}),"\n",(0,t.jsxs)(n.p,{children:["To set up the ",(0,t.jsx)(n.code,{children:"prompt_template"})," based on your model, follow the steps below: 1. Visit ",(0,t.jsx)(n.a,{href:"https://huggingface.co/",children:"Hugging Face"}),", an open-source machine learning platform. 2. Find the current model that you're using (e.g., ",(0,t.jsx)(n.a,{href:"https://huggingface.co/google/gemma-7b-it",children:"Gemma 7b it"}),"). 3. Review the text and identify the template."]}),"\n",(0,t.jsx)(n.h4,{id:"parameters",children:"Parameters"}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.code,{children:"parameters"})," is the adjustable settings that affect how your model operates or processes the data.\nThe fields in ",(0,t.jsx)(n.code,{children:"parameters"})," are typically general and can be the same across models. An example is provided below:"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",children:'"parameters":{\n "temperature": 0.7,\n "top_p": 0.95,\n "stream": true,\n "max_tokens": 4096,\n "frequency_penalty": 0,\n "presence_penalty": 0\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"tip",children:(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["You can find the list of available models in the ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/docs/models/overview",children:"OpenAI Platform"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["The ",(0,t.jsx)(n.code,{children:"id"})," property needs to match the model name in the list.","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["For example, if you want to use the ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/docs/models/gpt-4-and-gpt-4-turbo",children:"GPT-4 Turbo"}),", you must set the ",(0,t.jsx)(n.code,{children:"id"})," property to ",(0,t.jsx)(n.code,{children:"gpt-4-1106-preview"}),"."]}),"\n"]}),"\n"]}),"\n"]})}),"\n",(0,t.jsx)(n.h3,{id:"2-configure-openai-api-keys",children:"2. Configure OpenAI API Keys"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Find your API keys in the ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/api-keys",children:"OpenAI Platform"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the OpenAI API keys in ",(0,t.jsx)(n.code,{children:"~/jan/engines/openai.json"})," file."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "https://api.openai.com/v1/chat/completions",\n "api_key": "sk-"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"3-start-the-model",children:"3. Start the Model"}),"\n",(0,t.jsx)(n.p,{children:"Restart Jan and navigate to the Hub. Then, select your configured model and start the model."}),"\n",(0,t.jsx)(n.h2,{id:"azure-openai",children:"Azure OpenAI"}),"\n",(0,t.jsxs)(n.p,{children:["The ",(0,t.jsx)(n.a,{href:"https://learn.microsoft.com/en-us/azure/ai-services/openai/overview?source=docs",children:"Azure OpenAI Service"})," offers robust APIs, making it simple for you to incorporate OpenAI's language models into your applications. You can integrate Azure OpenAI with Jan by following the steps below:"]}),"\n",(0,t.jsx)(n.h3,{id:"step-1-configure-azure-openai-service-api-key",children:"Step 1: Configure Azure OpenAI Service API Key"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"Set up and deploy the Azure OpenAI Service."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Once you've set up and deployed Azure OpenAI Service, you can find the endpoint and API key in ",(0,t.jsx)(n.a,{href:"https://oai.azure.com/",children:"Azure OpenAI Studio"})," under ",(0,t.jsx)(n.code,{children:"Chat"})," > ",(0,t.jsx)(n.code,{children:"View code"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Set up the endpoint and API key for Azure OpenAI Service in the ",(0,t.jsx)(n.code,{children:"~/jan/engines/openai.json"})," file."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n // https://hieujan.openai.azure.com/openai/deployments/gpt-35-hieu-jan/chat/completions?api-version=2023-07-01-preview\n "full_url": "https://.openai.azure.com/openai/deployments//chat/completions?api-version=",\n "api_key": ""\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Go to the ",(0,t.jsx)(n.code,{children:"~/jan/models"})," directory."]}),"\n",(0,t.jsxs)(n.li,{children:["Make a new folder called ",(0,t.jsx)(n.code,{children:"(your-deployment-name)"}),", for example ",(0,t.jsx)(n.code,{children:"gpt-35-hieu-jan"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a ",(0,t.jsx)(n.code,{children:"model.json"})," file inside the folder with the specified configurations:"]}),"\n"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Match the ",(0,t.jsx)(n.code,{children:"id"})," property with both the folder name and your deployment name."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"format"})," property as ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Choose ",(0,t.jsx)(n.code,{children:"openai"})," for the ",(0,t.jsx)(n.code,{children:"engine"})," property."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"state"})," property as ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/gpt-35-hieu-jan/model.json"',children:'{\n "sources": [\n {\n "filename": "azure_openai",\n "url": "https://hieujan.openai.azure.com"\n }\n ],\n "id": "gpt-35-hieu-jan",\n "object": "model",\n "name": "Azure OpenAI GPT 3.5",\n "version": "1.0",\n "description": "Azure Open AI GPT 3.5 model is extremely good",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "OpenAI",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["For more details regarding the ",(0,t.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,t.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-start-the-model",children:"Step 3: Start the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Restart Jan and go to the Hub."}),"\n",(0,t.jsx)(n.li,{children:"Find your model in Jan application and click on the Use button."}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>d});var t=i(96540);const o={},s=t.createContext(o);function r(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f078801c.ce837ed1.js b/assets/js/f078801c.ce837ed1.js deleted file mode 100644 index a1f8a06f..00000000 --- a/assets/js/f078801c.ce837ed1.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8740],{25526:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>s,metadata:()=>d,toc:()=>a});var t=i(74848),o=i(28453);const s={title:"OpenAI API",sidebar_position:2,slug:"/guides/engines/openai",description:"A step-by-step guide on how to integrate Jan with Azure OpenAI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","integration","Azure OpenAI Service"]},r=void 0,d={id:"guides/remote-providers/openai",title:"OpenAI API",description:"A step-by-step guide on how to integrate Jan with Azure OpenAI.",source:"@site/docs/guides/remote-providers/openai.mdx",sourceDirName:"guides/remote-providers",slug:"/guides/engines/openai",permalink:"/guides/engines/openai",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/remote-providers/openai.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"OpenAI API",sidebar_position:2,slug:"/guides/engines/openai",description:"A step-by-step guide on how to integrate Jan with Azure OpenAI.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","integration","Azure OpenAI Service"]},sidebar:"guidesSidebar",previous:{title:"Mistral API",permalink:"/guides/engines/mistral"},next:{title:"Any OAI Compatible Server",permalink:"/guides/engines/remote-server"}},l={},a=[{value:"OpenAI Platform",id:"openai-platform",level:2},{value:"1. Create a Model JSON",id:"1-create-a-model-json",level:3},{value:"model.json",id:"modeljson",level:3},{value:"Settings",id:"settings",level:4},{value:"Parameters",id:"parameters",level:4},{value:"2. Configure OpenAI API Keys",id:"2-configure-openai-api-keys",level:3},{value:"3. Start the Model",id:"3-start-the-model",level:3},{value:"Azure OpenAI",id:"azure-openai",level:2},{value:"Step 1: Configure Azure OpenAI Service API Key",id:"step-1-configure-azure-openai-service-api-key",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3: Start the Model",id:"step-3-start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,o.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"openai-platform",children:"OpenAI Platform"}),"\n",(0,t.jsx)(n.h3,{id:"1-create-a-model-json",children:"1. Create a Model JSON"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In ",(0,t.jsx)(n.code,{children:"~/jan/models"}),", create a folder named ",(0,t.jsx)(n.code,{children:"gpt-3.5-turbo-16k"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["In this folder, add a ",(0,t.jsx)(n.code,{children:"model.json"})," file with Filename as ",(0,t.jsx)(n.code,{children:"model.json"}),", ",(0,t.jsx)(n.code,{children:"id"})," matching folder name, ",(0,t.jsx)(n.code,{children:"Format"})," as ",(0,t.jsx)(n.code,{children:"api"}),", ",(0,t.jsx)(n.code,{children:"Engine"})," as ",(0,t.jsx)(n.code,{children:"openai"}),", and ",(0,t.jsx)(n.code,{children:"State"})," as ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/gpt-3.5-turbo-16k/model.json"',children:'{\n "sources": [\n {\n "filename": "openai",\n "url": "https://openai.com"\n }\n ],\n "id": "gpt-3.5-turbo-16k",\n "object": "model",\n "name": "OpenAI GPT 3.5 Turbo 16k",\n "version": "1.0",\n "description": "OpenAI GPT 3.5 Turbo 16k model is extremely good",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "OpenAI",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"modeljson",children:(0,t.jsx)(n.code,{children:"model.json"})}),"\n",(0,t.jsxs)(n.p,{children:["The ",(0,t.jsx)(n.code,{children:"model.json"})," file is used to set up your local models."]}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["If you've set up your model's configuration in ",(0,t.jsx)(n.code,{children:"nitro.json"}),", please note that ",(0,t.jsx)(n.code,{children:"model.json"})," can overwrite the settings."]}),"\n",(0,t.jsxs)(n.li,{children:["When using OpenAI models like GPT-3.5 and GPT-4, you can use the default settings in ",(0,t.jsx)(n.code,{children:"model.json"})," file."]}),"\n"]})}),"\n",(0,t.jsx)(n.p,{children:"There are two important fields in model.json that you need to setup:"}),"\n",(0,t.jsx)(n.h4,{id:"settings",children:"Settings"}),"\n",(0,t.jsx)(n.p,{children:"This is the field where to set your engine configurations, there are two imporant field that you need to define for your local models:"}),"\n",(0,t.jsxs)(n.table,{children:[(0,t.jsx)(n.thead,{children:(0,t.jsxs)(n.tr,{children:[(0,t.jsx)(n.th,{children:"Term"}),(0,t.jsx)(n.th,{children:"Description"})]})}),(0,t.jsxs)(n.tbody,{children:[(0,t.jsxs)(n.tr,{children:[(0,t.jsx)(n.td,{children:(0,t.jsx)(n.code,{children:"ctx_len"})}),(0,t.jsx)(n.td,{children:"Defined based on the model's context size."})]}),(0,t.jsxs)(n.tr,{children:[(0,t.jsx)(n.td,{children:(0,t.jsx)(n.code,{children:"prompt_template"})}),(0,t.jsx)(n.td,{children:"Defined based on the model's trained template (e.g., ChatML, Alpaca)."})]})]})]}),"\n",(0,t.jsxs)(n.p,{children:["To set up the ",(0,t.jsx)(n.code,{children:"prompt_template"})," based on your model, follow the steps below: 1. Visit ",(0,t.jsx)(n.a,{href:"https://huggingface.co/",children:"Hugging Face"}),", an open-source machine learning platform. 2. Find the current model that you're using (e.g., ",(0,t.jsx)(n.a,{href:"https://huggingface.co/google/gemma-7b-it",children:"Gemma 7b it"}),"). 3. Review the text and identify the template."]}),"\n",(0,t.jsx)(n.h4,{id:"parameters",children:"Parameters"}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.code,{children:"parameters"})," is the adjustable settings that affect how your model operates or processes the data.\nThe fields in ",(0,t.jsx)(n.code,{children:"parameters"})," are typically general and can be the same across models. An example is provided below:"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",children:'"parameters":{\n "temperature": 0.7,\n "top_p": 0.95,\n "stream": true,\n "max_tokens": 4096,\n "frequency_penalty": 0,\n "presence_penalty": 0\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"tip",children:(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["You can find the list of available models in the ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/docs/models/overview",children:"OpenAI Platform"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["The ",(0,t.jsx)(n.code,{children:"id"})," property needs to match the model name in the list.","\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["For example, if you want to use the ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/docs/models/gpt-4-and-gpt-4-turbo",children:"GPT-4 Turbo"}),", you must set the ",(0,t.jsx)(n.code,{children:"id"})," property to ",(0,t.jsx)(n.code,{children:"gpt-4-1106-preview"}),"."]}),"\n"]}),"\n"]}),"\n"]})}),"\n",(0,t.jsx)(n.h3,{id:"2-configure-openai-api-keys",children:"2. Configure OpenAI API Keys"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Find your API keys in the ",(0,t.jsx)(n.a,{href:"https://platform.openai.com/api-keys",children:"OpenAI Platform"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the OpenAI API keys in ",(0,t.jsx)(n.code,{children:"~/jan/engines/openai.json"})," file."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n "full_url": "https://api.openai.com/v1/chat/completions",\n "api_key": "sk-"\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"3-start-the-model",children:"3. Start the Model"}),"\n",(0,t.jsx)(n.p,{children:"Restart Jan and navigate to the Hub. Then, select your configured model and start the model."}),"\n",(0,t.jsx)(n.h2,{id:"azure-openai",children:"Azure OpenAI"}),"\n",(0,t.jsxs)(n.p,{children:["The ",(0,t.jsx)(n.a,{href:"https://learn.microsoft.com/en-us/azure/ai-services/openai/overview?source=docs",children:"Azure OpenAI Service"})," offers robust APIs, making it simple for you to incorporate OpenAI's language models into your applications. You can integrate Azure OpenAI with Jan by following the steps below:"]}),"\n",(0,t.jsx)(n.h3,{id:"step-1-configure-azure-openai-service-api-key",children:"Step 1: Configure Azure OpenAI Service API Key"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsx)(n.p,{children:"Set up and deploy the Azure OpenAI Service."}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Once you've set up and deployed Azure OpenAI Service, you can find the endpoint and API key in ",(0,t.jsx)(n.a,{href:"https://oai.azure.com/",children:"Azure OpenAI Studio"})," under ",(0,t.jsx)(n.code,{children:"Chat"})," > ",(0,t.jsx)(n.code,{children:"View code"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Set up the endpoint and API key for Azure OpenAI Service in the ",(0,t.jsx)(n.code,{children:"~/jan/engines/openai.json"})," file."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/engines/openai.json"',children:'{\n // https://hieujan.openai.azure.com/openai/deployments/gpt-35-hieu-jan/chat/completions?api-version=2023-07-01-preview\n "full_url": "https://.openai.azure.com/openai/deployments//chat/completions?api-version=",\n "api_key": ""\n}\n'})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["Go to the ",(0,t.jsx)(n.code,{children:"~/jan/models"})," directory."]}),"\n",(0,t.jsxs)(n.li,{children:["Make a new folder called ",(0,t.jsx)(n.code,{children:"(your-deployment-name)"}),", for example ",(0,t.jsx)(n.code,{children:"gpt-35-hieu-jan"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Create a ",(0,t.jsx)(n.code,{children:"model.json"})," file inside the folder with the specified configurations:"]}),"\n"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["Match the ",(0,t.jsx)(n.code,{children:"id"})," property with both the folder name and your deployment name."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"format"})," property as ",(0,t.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,t.jsxs)(n.li,{children:["Choose ",(0,t.jsx)(n.code,{children:"openai"})," for the ",(0,t.jsx)(n.code,{children:"engine"})," property."]}),"\n",(0,t.jsxs)(n.li,{children:["Set the ",(0,t.jsx)(n.code,{children:"state"})," property as ",(0,t.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/gpt-35-hieu-jan/model.json"',children:'{\n "sources": [\n {\n "filename": "azure_openai",\n "url": "https://hieujan.openai.azure.com"\n }\n ],\n "id": "gpt-35-hieu-jan",\n "object": "model",\n "name": "Azure OpenAI GPT 3.5",\n "version": "1.0",\n "description": "Azure Open AI GPT 3.5 model is extremely good",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "author": "OpenAI",\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,t.jsx)(n.admonition,{type:"note",children:(0,t.jsxs)(n.p,{children:["For more details regarding the ",(0,t.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,t.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,t.jsx)(n.h3,{id:"step-3-start-the-model",children:"Step 3: Start the Model"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Restart Jan and go to the Hub."}),"\n",(0,t.jsx)(n.li,{children:"Find your model in Jan application and click on the Use button."}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>d});var t=i(96540);const o={},s=t.createContext(o);function r(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:r(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f0ba8d54.34967b52.js b/assets/js/f0ba8d54.34967b52.js new file mode 100644 index 00000000..1c7a76ab --- /dev/null +++ b/assets/js/f0ba8d54.34967b52.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[825],{40516:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>p,frontMatter:()=>o,metadata:()=>i,toc:()=>d});var a=s(74848),t=s(28453);const o={title:"File-based Approach",slug:"/developer/file-based",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","file based approach"]},r=void 0,i={id:"developer/overview/file-based",title:"File-based Approach",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/02-file-based.md",sourceDirName:"developer/01-overview",slug:"/developer/file-based",permalink:"/developer/file-based",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/02-file-based.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"File-based Approach",slug:"/developer/file-based",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","file based approach"]},sidebar:"developerSidebar",previous:{title:"Architecture",permalink:"/developer/architecture"},next:{title:"User Interface",permalink:"/developer/ui"}},l={},d=[{value:"Data Dependencies",id:"data-dependencies",level:2}];function c(e){const n={admonition:"admonition",code:"code",h2:"h2",li:"li",mermaid:"mermaid",p:"p",pre:"pre",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.admonition,{type:"warning",children:(0,a.jsx)(n.p,{children:"This page is still under construction, and should be read as a scratchpad"})}),"\n",(0,a.jsx)(n.p,{children:"Jan use the local filesystem for data persistence, similar to VSCode. This allows for composability and tinkerability."}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-yaml",children:"janroot/ # Jan's root folder (e.g. ~/jan)\n models/ # For raw AI models\n threads/ # For conversation history\n assistants/ # For AI assistants' configs, knowledge, etc.\n"})}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-yaml",children:"/models\n /modelA\n model.json # Default model settings\n llama-7b-q4.gguf # Model binaries\n/threads\n /jan-unixstamp\n thread.json # thread metadata (e.g. subject)\n messages.jsonl # messages\n files/ # RAG\n/assistants\n /jan # A default assistant that can use all models\n assistant.json # Assistant configs (see below)\n package.json # Import npm modules, e.g. Langchain, Llamaindex\n /src # For custom code\n index.js # Entrypoint\n # `/threads` at root level\n # `/models` at root level\n /shakespeare # Example of a custom assistant\n assistant.json\n package.json\n /threads # Assistants remember conversations in the future\n /models # Users can upload custom models\n"})}),"\n",(0,a.jsx)(n.h2,{id:"data-dependencies",children:"Data Dependencies"}),"\n",(0,a.jsx)(n.mermaid,{value:'graph LR\n A1[("A User Integrators")] --\x3e|uses| B1[assistant]\n B1 --\x3e|persist conversational history| C1[("thread A")]\n B1 --\x3e|executes| D1[("built-in tools as module")]\n B1 -.->|uses| E1[model]\n E1 -.->|model.json| D1\n D1 --\x3e F1[retrieval]\n F1 --\x3e|belongs to| G1[("web browsing")]\n G1 --\x3e H1[Google]\n G1 --\x3e H2[Duckduckgo]\n F1 --\x3e|belongs to| I1[("API calling")]\n F1 --\x3e J1[("knowledge files")]'}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"User/ Integrator"}),"\n",(0,a.jsx)(n.li,{children:"Assistant object"}),"\n",(0,a.jsx)(n.li,{children:"Model object"}),"\n",(0,a.jsx)(n.li,{children:"Thread object"}),"\n",(0,a.jsx)(n.li,{children:"Built-in tool object"}),"\n"]})]})}function p(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>r,x:()=>i});var a=s(96540);const t={},o=a.createContext(t);function r(e){const n=a.useContext(o);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function i(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:r(e.components),a.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f0ba8d54.40fc96e2.js b/assets/js/f0ba8d54.40fc96e2.js deleted file mode 100644 index dfd63993..00000000 --- a/assets/js/f0ba8d54.40fc96e2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[825],{40516:(e,n,s)=>{s.r(n),s.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>p,frontMatter:()=>o,metadata:()=>i,toc:()=>d});var a=s(74848),t=s(28453);const o={title:"File-based Approach",slug:"/developer/file-based",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","file based approach"]},r=void 0,i={id:"developer/overview/file-based",title:"File-based Approach",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/01-overview/02-file-based.md",sourceDirName:"developer/01-overview",slug:"/developer/file-based",permalink:"/developer/file-based",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/01-overview/02-file-based.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"File-based Approach",slug:"/developer/file-based",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","file based approach"]},sidebar:"developerSidebar",previous:{title:"Architecture",permalink:"/developer/architecture"},next:{title:"User Interface",permalink:"/developer/ui"}},l={},d=[{value:"Data Dependencies",id:"data-dependencies",level:2}];function c(e){const n={admonition:"admonition",code:"code",h2:"h2",li:"li",mermaid:"mermaid",p:"p",pre:"pre",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.admonition,{type:"warning",children:(0,a.jsx)(n.p,{children:"This page is still under construction, and should be read as a scratchpad"})}),"\n",(0,a.jsx)(n.p,{children:"Jan use the local filesystem for data persistence, similar to VSCode. This allows for composability and tinkerability."}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-yaml",children:"janroot/ # Jan's root folder (e.g. ~/jan)\n models/ # For raw AI models\n threads/ # For conversation history\n assistants/ # For AI assistants' configs, knowledge, etc.\n"})}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-yaml",children:"/models\n /modelA\n model.json # Default model settings\n llama-7b-q4.gguf # Model binaries\n/threads\n /jan-unixstamp\n thread.json # thread metadata (e.g. subject)\n messages.jsonl # messages\n files/ # RAG\n/assistants\n /jan # A default assistant that can use all models\n assistant.json # Assistant configs (see below)\n package.json # Import npm modules, e.g. Langchain, Llamaindex\n /src # For custom code\n index.js # Entrypoint\n # `/threads` at root level\n # `/models` at root level\n /shakespeare # Example of a custom assistant\n assistant.json\n package.json\n /threads # Assistants remember conversations in the future\n /models # Users can upload custom models\n"})}),"\n",(0,a.jsx)(n.h2,{id:"data-dependencies",children:"Data Dependencies"}),"\n",(0,a.jsx)(n.mermaid,{value:'graph LR\n A1[("A User Integrators")] --\x3e|uses| B1[assistant]\n B1 --\x3e|persist conversational history| C1[("thread A")]\n B1 --\x3e|executes| D1[("built-in tools as module")]\n B1 -.->|uses| E1[model]\n E1 -.->|model.json| D1\n D1 --\x3e F1[retrieval]\n F1 --\x3e|belongs to| G1[("web browsing")]\n G1 --\x3e H1[Google]\n G1 --\x3e H2[Duckduckgo]\n F1 --\x3e|belongs to| I1[("API calling")]\n F1 --\x3e J1[("knowledge files")]'}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"User/ Integrator"}),"\n",(0,a.jsx)(n.li,{children:"Assistant object"}),"\n",(0,a.jsx)(n.li,{children:"Model object"}),"\n",(0,a.jsx)(n.li,{children:"Thread object"}),"\n",(0,a.jsx)(n.li,{children:"Built-in tool object"}),"\n"]})]})}function p(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,s)=>{s.d(n,{R:()=>r,x:()=>i});var a=s(96540);const t={},o=a.createContext(t);function r(e){const n=a.useContext(o);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function i(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:r(e.components),a.createElement(o.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f0fd40ad.1f04ffd2.js b/assets/js/f0fd40ad.1f04ffd2.js deleted file mode 100644 index c2ef7ee9..00000000 --- a/assets/js/f0fd40ad.1f04ffd2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[776],{58890:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>c});var s=n(74848),o=n(28453);const a={title:"Healthcare",tags:["industries"]},r=void 0,i={id:"solutions/healthcare",title:"Healthcare",description:"",source:"@site/docs/solutions/healthcare.md",sourceDirName:"solutions",slug:"/solutions/healthcare",permalink:"/solutions/healthcare",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/healthcare.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Healthcare",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Finance",permalink:"/solutions/finance"},next:{title:"Legal",permalink:"/solutions/legal"}},l={},c=[];function u(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>r,x:()=>i});var s=n(96540);const o={},a=s.createContext(o);function r(t){const e=s.useContext(a);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),s.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/f0fd40ad.d44734ec.js b/assets/js/f0fd40ad.d44734ec.js new file mode 100644 index 00000000..cbf15787 --- /dev/null +++ b/assets/js/f0fd40ad.d44734ec.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[776],{58890:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>a,metadata:()=>i,toc:()=>c});var s=n(74848),o=n(28453);const a={title:"Healthcare",tags:["industries"]},r=void 0,i={id:"solutions/healthcare",title:"Healthcare",description:"",source:"@site/docs/solutions/healthcare.md",sourceDirName:"solutions",slug:"/solutions/healthcare",permalink:"/solutions/healthcare",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/solutions/healthcare.md",tags:[{label:"industries",permalink:"/tags/industries"}],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Healthcare",tags:["industries"]},sidebar:"solutionSidebar",previous:{title:"Finance",permalink:"/solutions/finance"},next:{title:"Legal",permalink:"/solutions/legal"}},l={},c=[];function u(t){return(0,s.jsx)(s.Fragment,{})}function d(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,s.jsx)(e,{...t,children:(0,s.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>r,x:()=>i});var s=n(96540);const o={},a=s.createContext(o);function r(t){const e=s.useContext(a);return s.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:r(t.components),s.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/f1cabb85.534d6f17.js b/assets/js/f1cabb85.534d6f17.js deleted file mode 100644 index 44af1188..00000000 --- a/assets/js/f1cabb85.534d6f17.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6369],{94575:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>a,contentTitle:()=>r,default:()=>f,frontMatter:()=>t,metadata:()=>o,toc:()=>c});var s=i(74848),l=i(28453);const t={title:"Files",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,o={id:"developer/framework/engineering/files",title:"Files",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/files.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/files",permalink:"/developer/framework/engineering/files",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/files.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Files",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Engine",permalink:"/developer/framework/engineering/engine"},next:{title:"Messages",permalink:"/developer/framework/engineering/messages"}},a={},c=[{value:"Files Object",id:"files-object",level:2},{value:"File API",id:"file-api",level:2},{value:"List Files",id:"list-files",level:3},{value:"Upload file",id:"upload-file",level:3},{value:"Delete file",id:"delete-file",level:3},{value:"Retrieve file",id:"retrieve-file",level:3},{value:"Retrieve file content",id:"retrieve-file-content",level:3},{value:"Files Filesystem",id:"files-filesystem",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,l.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.admonition,{type:"warning",children:(0,s.jsx)(n.p,{children:"Draft Specification: functionality has not been implemented yet."})}),"\n",(0,s.jsxs)(n.p,{children:["Files can be used by ",(0,s.jsx)(n.code,{children:"threads"}),", ",(0,s.jsx)(n.code,{children:"assistants"})," and ",(0,s.jsx)(n.code,{children:"fine-tuning"})]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["Equivalent to: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files",children:"https://platform.openai.com/docs/api-reference/files"})]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"files-object",children:"Files Object"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Equivalent to: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files",children:"https://platform.openai.com/docs/api-reference/files"})]}),"\n",(0,s.jsx)(n.li,{children:"Note: OAI's struct doesn't seem very well designed"}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.code,{children:"files.json"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-js",children:'{\n // Public properties (OpenAI Compatible: https://platform.openai.com/docs/api-reference/files/object)\n "id": "file-BK7bzQj3FfZFXr7DbL6xJwfo",\n "object": "file",\n "bytes": 120000,\n "created_at": 1677610602,\n "filename": "salesOverview.pdf",\n "purpose": "assistants"\n}\n'})}),"\n",(0,s.jsx)(n.h2,{id:"file-api",children:"File API"}),"\n",(0,s.jsx)(n.h3,{id:"list-files",children:"List Files"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/list",children:"https://platform.openai.com/docs/api-reference/files/list"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"upload-file",children:"Upload file"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/create",children:"https://platform.openai.com/docs/api-reference/files/create"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"delete-file",children:"Delete file"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/delete",children:"https://platform.openai.com/docs/api-reference/files/delete"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"retrieve-file",children:"Retrieve file"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/retrieve",children:"https://platform.openai.com/docs/api-reference/files/retrieve"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"retrieve-file-content",children:"Retrieve file content"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/retrieve-contents",children:"https://platform.openai.com/docs/api-reference/files/retrieve-contents"})]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"files-filesystem",children:"Files Filesystem"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Files can exist in several parts of Jan's filesystem"}),"\n",(0,s.jsxs)(n.li,{children:["TODO: are files hard copied into these folders? Or do we define a ",(0,s.jsx)(n.code,{children:"files.json"})," and only record the relative filepath?"]}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-sh",children:"/files # root `/files` for finetuning, etc\n/assistants\n /jan\n /files # assistant-specific files\n/threads\n /jan-12938912\n /files # thread-specific files\n"})})]})}function f(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>o});var s=i(96540);const l={},t=s.createContext(l);function r(e){const n=s.useContext(t);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:r(e.components),s.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f1cabb85.6499f82a.js b/assets/js/f1cabb85.6499f82a.js new file mode 100644 index 00000000..ea4254f5 --- /dev/null +++ b/assets/js/f1cabb85.6499f82a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6369],{94575:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>a,contentTitle:()=>r,default:()=>f,frontMatter:()=>t,metadata:()=>o,toc:()=>c});var s=i(74848),l=i(28453);const t={title:"Files",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},r=void 0,o={id:"developer/framework/engineering/files",title:"Files",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/developer/05-framework/03-engineering/files.md",sourceDirName:"developer/05-framework/03-engineering",slug:"/developer/framework/engineering/files",permalink:"/developer/framework/engineering/files",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/developer/05-framework/03-engineering/files.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Files",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},sidebar:"developerSidebar",previous:{title:"Engine",permalink:"/developer/framework/engineering/engine"},next:{title:"Messages",permalink:"/developer/framework/engineering/messages"}},a={},c=[{value:"Files Object",id:"files-object",level:2},{value:"File API",id:"file-api",level:2},{value:"List Files",id:"list-files",level:3},{value:"Upload file",id:"upload-file",level:3},{value:"Delete file",id:"delete-file",level:3},{value:"Retrieve file",id:"retrieve-file",level:3},{value:"Retrieve file content",id:"retrieve-file-content",level:3},{value:"Files Filesystem",id:"files-filesystem",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,l.R)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.admonition,{type:"warning",children:(0,s.jsx)(n.p,{children:"Draft Specification: functionality has not been implemented yet."})}),"\n",(0,s.jsxs)(n.p,{children:["Files can be used by ",(0,s.jsx)(n.code,{children:"threads"}),", ",(0,s.jsx)(n.code,{children:"assistants"})," and ",(0,s.jsx)(n.code,{children:"fine-tuning"})]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["Equivalent to: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files",children:"https://platform.openai.com/docs/api-reference/files"})]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"files-object",children:"Files Object"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:["Equivalent to: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files",children:"https://platform.openai.com/docs/api-reference/files"})]}),"\n",(0,s.jsx)(n.li,{children:"Note: OAI's struct doesn't seem very well designed"}),"\n",(0,s.jsx)(n.li,{children:(0,s.jsx)(n.code,{children:"files.json"})}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-js",children:'{\n // Public properties (OpenAI Compatible: https://platform.openai.com/docs/api-reference/files/object)\n "id": "file-BK7bzQj3FfZFXr7DbL6xJwfo",\n "object": "file",\n "bytes": 120000,\n "created_at": 1677610602,\n "filename": "salesOverview.pdf",\n "purpose": "assistants"\n}\n'})}),"\n",(0,s.jsx)(n.h2,{id:"file-api",children:"File API"}),"\n",(0,s.jsx)(n.h3,{id:"list-files",children:"List Files"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/list",children:"https://platform.openai.com/docs/api-reference/files/list"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"upload-file",children:"Upload file"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/create",children:"https://platform.openai.com/docs/api-reference/files/create"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"delete-file",children:"Delete file"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/delete",children:"https://platform.openai.com/docs/api-reference/files/delete"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"retrieve-file",children:"Retrieve file"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/retrieve",children:"https://platform.openai.com/docs/api-reference/files/retrieve"})]}),"\n"]}),"\n",(0,s.jsx)(n.h3,{id:"retrieve-file-content",children:"Retrieve file content"}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.p,{children:["OpenAI Equivalent: ",(0,s.jsx)(n.a,{href:"https://platform.openai.com/docs/api-reference/files/retrieve-contents",children:"https://platform.openai.com/docs/api-reference/files/retrieve-contents"})]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"files-filesystem",children:"Files Filesystem"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:"Files can exist in several parts of Jan's filesystem"}),"\n",(0,s.jsxs)(n.li,{children:["TODO: are files hard copied into these folders? Or do we define a ",(0,s.jsx)(n.code,{children:"files.json"})," and only record the relative filepath?"]}),"\n"]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-sh",children:"/files # root `/files` for finetuning, etc\n/assistants\n /jan\n /files # assistant-specific files\n/threads\n /jan-12938912\n /files # thread-specific files\n"})})]})}function f(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>o});var s=i(96540);const l={},t=s.createContext(l);function r(e){const n=s.useContext(t);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:r(e.components),s.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f25ab7b5.612aa647.js b/assets/js/f25ab7b5.612aa647.js deleted file mode 100644 index ad59abc1..00000000 --- a/assets/js/f25ab7b5.612aa647.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6915],{63785:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>t,toc:()=>d});var a=i(74848),l=i(28453);const r={sidebar_position:4,slug:"/changelog/changelog-v0.4.6"},s="v0.4.6",t={id:"releases/changelog/changelog-v0.4.6",title:"v0.4.6",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.6.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.6",permalink:"/changelog/changelog-v0.4.6",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.6.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:4,frontMatter:{sidebar_position:4,slug:"/changelog/changelog-v0.4.6"},sidebar:"releasesSidebar",previous:{title:"v0.4.7",permalink:"/changelog/changelog-v0.4.7"},next:{title:"v0.4.5",permalink:"/changelog/changelog-v0.4.5"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,l.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v046",children:"v0.4.6"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.6",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1918",children:"Issue #1918: Regression fix assistant extension codesign"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Regression fix assitant extension codesign @hiento09 (#1918)"}),"\n",(0,a.jsx)(n.li,{children:"Release cut 0.4.6 @louis-jan (#1888)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add factory reset feature @namchuai (#1750)"}),"\n",(0,a.jsx)(n.li,{children:"chore: add react developer tools to electron @Helloyunho (#1858)"}),"\n",(0,a.jsx)(n.li,{children:"Sync Release 0.4.5 to dev @louis-jan (#1830)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: integrate umami @hieu-jan (#1809)"}),"\n",(0,a.jsx)(n.li,{children:"feat: Add default value for ngl @hiro-v (#1886)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add start/stop model via http api @namchuai (#1862)"}),"\n",(0,a.jsx)(n.li,{children:"feat: add snackbar component and update style side banner @urmauur (#1874)"}),"\n",(0,a.jsx)(n.li,{children:"feat: move open app directory into icon folder @urmauur (#1879)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Bump nitro to 0.3.3 @hiro-v (#1877)"}),"\n",(0,a.jsx)(n.li,{children:"feat: put timestamp under thread name in left panel @urmauur (#1820)"}),"\n",(0,a.jsx)(n.li,{children:"perf: remove unnecessary rerender when user typing input @namchuai (#1818)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: umami analytics send app loaded event @louis-jan (#1928)"}),"\n",(0,a.jsx)(n.li,{children:"fix: migration loading indicator @louis-jan (#1913)"}),"\n",(0,a.jsx)(n.li,{children:"fix: broken manual import model with NA fields @louis-jan (#1912)"}),"\n",(0,a.jsx)(n.li,{children:"fix: openAIEmbedding now requires top level API Key configuration @louis-jan (#1902)"}),"\n",(0,a.jsx)(n.li,{children:"fix: load model fail overlays thread message error @louis-jan (#1901)"}),"\n",(0,a.jsx)(n.li,{children:"fix: show generate response on message send @louis-jan (#1895)"}),"\n",(0,a.jsx)(n.li,{children:"fix: display error message on model load fail @louis-jan (#1894)"}),"\n",(0,a.jsx)(n.li,{children:"fix: the selected model auto revert back to previous used model with setting mismatch @louis-jan (#1883)"}),"\n",(0,a.jsx)(n.li,{children:"fix: add dialog confirm when move folder and next dest isn't empty @urmauur (#1880)"}),"\n",(0,a.jsx)(n.li,{children:"Increase timeout for explore.e2e.spec test @hiento09 (#1844)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Bump nitro to 0.3.3 @hiro-v (#1877)"}),"\n",(0,a.jsx)(n.li,{children:"fix: auto collapse retrieval setting while update config @urmauur (#1866)"}),"\n",(0,a.jsx)(n.li,{children:"fix: loader show while error global when change folder @urmauur (#1870)"}),"\n",(0,a.jsx)(n.li,{children:"fix: retrieval always ask for api key @louis-jan (#1856)"}),"\n",(0,a.jsx)(n.li,{children:"fix: all input text box are disabled @namchuai (#1855)"}),"\n",(0,a.jsx)(n.li,{children:"fix: add loader when user change folder @urmauur (#1850)"}),"\n",(0,a.jsx)(n.li,{children:"Add code sign step for darwin assistant extension @hiento09 (#1841)"}),"\n",(0,a.jsx)(n.li,{children:"fix: preserve focused thread when navigating in jan app @namchuai (#1814)"}),"\n",(0,a.jsx)(n.li,{children:"fix: highlight menu dropdown server options @urmauur (#1831)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"chore: mark RAG as experimental feature @louis-jan (#1882)"}),"\n",(0,a.jsx)(n.li,{children:"Increase timeout for explore.e2e.spec test @hiento09 (#1844)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Bump nitro to 0.3.3 @hiro-v (#1877)"}),"\n",(0,a.jsx)(n.li,{children:"chore: Jan Data Folder setting is no longer an experimental feature @louis-jan (#1847)"}),"\n",(0,a.jsx)(n.li,{children:"chore: resolve main conflict @louis-jan (#1833)"}),"\n",(0,a.jsx)(n.li,{children:"Update release url on README to default branch instead of main branch @hiento09 (#1832)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@Helloyunho, @hiento09, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @namchuai, @urmauur and James"})]})}function h(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>t});var a=i(96540);const l={},r=a.createContext(l);function s(e){const n=a.useContext(r);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:s(e.components),a.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f25ab7b5.d295f10f.js b/assets/js/f25ab7b5.d295f10f.js new file mode 100644 index 00000000..4a642540 --- /dev/null +++ b/assets/js/f25ab7b5.d295f10f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6915],{63785:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>s,default:()=>h,frontMatter:()=>r,metadata:()=>t,toc:()=>d});var l=i(74848),a=i(28453);const r={sidebar_position:4,slug:"/changelog/changelog-v0.4.6"},s="v0.4.6",t={id:"releases/changelog/changelog-v0.4.6",title:"v0.4.6",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.6.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.6",permalink:"/changelog/changelog-v0.4.6",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.6.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:4,frontMatter:{sidebar_position:4,slug:"/changelog/changelog-v0.4.6"},sidebar:"releasesSidebar",previous:{title:"v0.4.7",permalink:"/changelog/changelog-v0.4.7"},next:{title:"v0.4.5",permalink:"/changelog/changelog-v0.4.5"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,a.R)(),...e.components};return(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(n.h1,{id:"v046",children:"v0.4.6"}),"\n",(0,l.jsxs)(n.p,{children:["For more details, ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.6",children:"GitHub Issues"})]}),"\n",(0,l.jsxs)(n.p,{children:["Highlighted Issue: ",(0,l.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1918",children:"Issue #1918: Regression fix assistant extension codesign"})]}),"\n",(0,l.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"Regression fix assitant extension codesign @hiento09 (#1918)"}),"\n",(0,l.jsx)(n.li,{children:"Release cut 0.4.6 @louis-jan (#1888)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add factory reset feature @namchuai (#1750)"}),"\n",(0,l.jsx)(n.li,{children:"chore: add react developer tools to electron @Helloyunho (#1858)"}),"\n",(0,l.jsx)(n.li,{children:"Sync Release 0.4.5 to dev @louis-jan (#1830)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"feat: integrate umami @hieu-jan (#1809)"}),"\n",(0,l.jsx)(n.li,{children:"feat: Add default value for ngl @hiro-v (#1886)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add start/stop model via http api @namchuai (#1862)"}),"\n",(0,l.jsx)(n.li,{children:"feat: add snackbar component and update style side banner @urmauur (#1874)"}),"\n",(0,l.jsx)(n.li,{children:"feat: move open app directory into icon folder @urmauur (#1879)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump nitro to 0.3.3 @hiro-v (#1877)"}),"\n",(0,l.jsx)(n.li,{children:"feat: put timestamp under thread name in left panel @urmauur (#1820)"}),"\n",(0,l.jsx)(n.li,{children:"perf: remove unnecessary rerender when user typing input @namchuai (#1818)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"fix: umami analytics send app loaded event @louis-jan (#1928)"}),"\n",(0,l.jsx)(n.li,{children:"fix: migration loading indicator @louis-jan (#1913)"}),"\n",(0,l.jsx)(n.li,{children:"fix: broken manual import model with NA fields @louis-jan (#1912)"}),"\n",(0,l.jsx)(n.li,{children:"fix: openAIEmbedding now requires top level API Key configuration @louis-jan (#1902)"}),"\n",(0,l.jsx)(n.li,{children:"fix: load model fail overlays thread message error @louis-jan (#1901)"}),"\n",(0,l.jsx)(n.li,{children:"fix: show generate response on message send @louis-jan (#1895)"}),"\n",(0,l.jsx)(n.li,{children:"fix: display error message on model load fail @louis-jan (#1894)"}),"\n",(0,l.jsx)(n.li,{children:"fix: the selected model auto revert back to previous used model with setting mismatch @louis-jan (#1883)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add dialog confirm when move folder and next dest isn't empty @urmauur (#1880)"}),"\n",(0,l.jsx)(n.li,{children:"Increase timeout for explore.e2e.spec test @hiento09 (#1844)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump nitro to 0.3.3 @hiro-v (#1877)"}),"\n",(0,l.jsx)(n.li,{children:"fix: auto collapse retrieval setting while update config @urmauur (#1866)"}),"\n",(0,l.jsx)(n.li,{children:"fix: loader show while error global when change folder @urmauur (#1870)"}),"\n",(0,l.jsx)(n.li,{children:"fix: retrieval always ask for api key @louis-jan (#1856)"}),"\n",(0,l.jsx)(n.li,{children:"fix: all input text box are disabled @namchuai (#1855)"}),"\n",(0,l.jsx)(n.li,{children:"fix: add loader when user change folder @urmauur (#1850)"}),"\n",(0,l.jsx)(n.li,{children:"Add code sign step for darwin assistant extension @hiento09 (#1841)"}),"\n",(0,l.jsx)(n.li,{children:"fix: preserve focused thread when navigating in jan app @namchuai (#1814)"}),"\n",(0,l.jsx)(n.li,{children:"fix: highlight menu dropdown server options @urmauur (#1831)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,l.jsxs)(n.ul,{children:["\n",(0,l.jsx)(n.li,{children:"chore: mark RAG as experimental feature @louis-jan (#1882)"}),"\n",(0,l.jsx)(n.li,{children:"Increase timeout for explore.e2e.spec test @hiento09 (#1844)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Bump nitro to 0.3.3 @hiro-v (#1877)"}),"\n",(0,l.jsx)(n.li,{children:"chore: Jan Data Folder setting is no longer an experimental feature @louis-jan (#1847)"}),"\n",(0,l.jsx)(n.li,{children:"chore: resolve main conflict @louis-jan (#1833)"}),"\n",(0,l.jsx)(n.li,{children:"Update release url on README to default branch instead of main branch @hiento09 (#1832)"}),"\n"]}),"\n",(0,l.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,l.jsx)(n.p,{children:"@Helloyunho, @hiento09, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @namchuai, @urmauur and James"})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,l.jsx)(n,{...e,children:(0,l.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>s,x:()=>t});var l=i(96540);const a={},r=l.createContext(a);function s(e){const n=l.useContext(r);return l.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function t(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:s(e.components),l.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f274275e.20c2b028.js b/assets/js/f274275e.20c2b028.js deleted file mode 100644 index 467aec76..00000000 --- a/assets/js/f274275e.20c2b028.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1965],{2295:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>s,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var o=t(74848),i=t(28453);const r={title:"Overview",slug:"/guides/engines",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:12,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,a={id:"guides/inference/overview-inference",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/inference/overview-inference.mdx",sourceDirName:"guides/inference",slug:"/guides/engines",permalink:"/guides/engines",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/inference/overview-inference.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:12,frontMatter:{title:"Overview",slug:"/guides/engines",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:12,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},c={},u=[];function l(e){const n={p:"p",...(0,i.R)(),...e.components};return(0,o.jsx)(n.p,{children:"Coming Soon"})}function d(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(l,{...e})}):l(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var o=t(96540);const i={},r=o.createContext(i);function s(e){const n=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),o.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f274275e.375f8ba6.js b/assets/js/f274275e.375f8ba6.js new file mode 100644 index 00000000..cceb7d21 --- /dev/null +++ b/assets/js/f274275e.375f8ba6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1965],{2295:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>s,default:()=>d,frontMatter:()=>r,metadata:()=>a,toc:()=>u});var o=t(74848),i=t(28453);const r={title:"Overview",slug:"/guides/engines",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:12,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},s=void 0,a={id:"guides/inference/overview-inference",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/inference/overview-inference.mdx",sourceDirName:"guides/inference",slug:"/guides/engines",permalink:"/guides/engines",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/inference/overview-inference.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:12,frontMatter:{title:"Overview",slug:"/guides/engines",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:12,keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},c={},u=[];function l(e){const n={p:"p",...(0,i.R)(),...e.components};return(0,o.jsx)(n.p,{children:"Coming Soon"})}function d(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(l,{...e})}):l(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var o=t(96540);const i={},r=o.createContext(i);function s(e){const n=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),o.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f4e1c670.c9797c12.js b/assets/js/f4e1c670.c9797c12.js new file mode 100644 index 00000000..ffd7d09a --- /dev/null +++ b/assets/js/f4e1c670.c9797c12.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9625],{18321:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>l,default:()=>h,frontMatter:()=>s,metadata:()=>o,toc:()=>c});var a=i(74848),t=i(28453);const s={sidebar_position:18,slug:"/changelog/changelog-v0.2.0"},l="v0.2.0",o={id:"releases/changelog/changelog-v0.2.0",title:"v0.2.0",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.0.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.0",permalink:"/changelog/changelog-v0.2.0",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.0.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:18,frontMatter:{sidebar_position:18,slug:"/changelog/changelog-v0.2.0"},sidebar:"releasesSidebar",previous:{title:"v0.2.1",permalink:"/changelog/changelog-v0.2.1"}},r={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"\ud83d\udcd6 Documentaion",id:"-documentaion",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v020",children:"v0.2.0"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.0",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/342",children:"Issue #342: feat: Add Jan Hacker House event page to Docs"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: Add Jan Hacker House event page to Docs @dan-jan (#342)"}),"\n",(0,a.jsx)(n.li,{children:"feat: Hide incomplete Hardware section from Docs site @dan-jan (#341)"}),"\n",(0,a.jsx)(n.li,{children:"style: better chatbox ui @0xSage (#338)"}),"\n",(0,a.jsx)(n.li,{children:"feat: allowing user to fetch models from github @namchuai (#319)"}),"\n",(0,a.jsx)(n.li,{children:"fixes: #247 - inference plugin should check nitro service available @louis-jan (#313)"}),"\n",(0,a.jsx)(n.li,{children:"Fix icon error for linux app @hiento09 (#316)"}),"\n",(0,a.jsx)(n.li,{children:"docs: initial hardware content @Its-Alamin-H (#240)"}),"\n",(0,a.jsx)(n.li,{children:"fixes #277 - bug: memory utilization always at 99% @louis-jan (#309)"}),"\n",(0,a.jsx)(n.li,{children:"Docusaurus parser string from githubapi to get latest release @hiento09 (#312)"}),"\n",(0,a.jsx)(n.li,{children:"Footer background, CTA & Highlight colors @drakehere (#288)"}),"\n",(0,a.jsx)(n.li,{children:"Fix CI Test run failed on ubuntu and change release file app name @hiento09 (#307)"}),"\n",(0,a.jsx)(n.li,{children:"Add docusaurus test build pipeline @hiento09 (#302)"}),"\n",(0,a.jsx)(n.li,{children:"fix: #271 Cannot read properties of undefined (reading 'map') @louis-jan (#300)"}),"\n",(0,a.jsx)(n.li,{children:"Fix Docusaurus server side render error @hiento09 (#301)"}),"\n",(0,a.jsx)(n.li,{children:"fix #283: small ui fixes @namchuai (#299)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Fix #290: Add description in package.json and rename to jan @hiento09 (#333)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Add Documentation category to release note template @hiento09 (#332)"}),"\n",(0,a.jsx)(n.li,{children:"Chore/release note template @hiento09 (#323)"}),"\n",(0,a.jsx)(n.li,{children:"Add release note template @hiento09 (#322)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-documentaion",children:"\ud83d\udcd6 Documentaion"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Add auto update app download url on jan.ai @hiento09 (#311)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update per v0.1.3 @0xSage (#280)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @Its-Alamin-H, @dan-jan, @drakehere, @hiento09, @hientominh, @louis-jan, @namchuai, Hien To and James"})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>l,x:()=>o});var a=i(96540);const t={},s=a.createContext(t);function l(e){const n=a.useContext(s);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:l(e.components),a.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f4e1c670.d73e5da1.js b/assets/js/f4e1c670.d73e5da1.js deleted file mode 100644 index 7a4e3563..00000000 --- a/assets/js/f4e1c670.d73e5da1.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9625],{18321:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>r,contentTitle:()=>l,default:()=>h,frontMatter:()=>s,metadata:()=>o,toc:()=>c});var a=i(74848),t=i(28453);const s={sidebar_position:18,slug:"/changelog/changelog-v0.2.0"},l="v0.2.0",o={id:"releases/changelog/changelog-v0.2.0",title:"v0.2.0",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.2.0.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.2.0",permalink:"/changelog/changelog-v0.2.0",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.2.0.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:18,frontMatter:{sidebar_position:18,slug:"/changelog/changelog-v0.2.0"},sidebar:"releasesSidebar",previous:{title:"v0.2.1",permalink:"/changelog/changelog-v0.2.1"}},r={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"\ud83d\udcd6 Documentaion",id:"-documentaion",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v020",children:"v0.2.0"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.2.0",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/342",children:"Issue #342: feat: Add Jan Hacker House event page to Docs"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: Add Jan Hacker House event page to Docs @dan-jan (#342)"}),"\n",(0,a.jsx)(n.li,{children:"feat: Hide incomplete Hardware section from Docs site @dan-jan (#341)"}),"\n",(0,a.jsx)(n.li,{children:"style: better chatbox ui @0xSage (#338)"}),"\n",(0,a.jsx)(n.li,{children:"feat: allowing user to fetch models from github @namchuai (#319)"}),"\n",(0,a.jsx)(n.li,{children:"fixes: #247 - inference plugin should check nitro service available @louis-jan (#313)"}),"\n",(0,a.jsx)(n.li,{children:"Fix icon error for linux app @hiento09 (#316)"}),"\n",(0,a.jsx)(n.li,{children:"docs: initial hardware content @Its-Alamin-H (#240)"}),"\n",(0,a.jsx)(n.li,{children:"fixes #277 - bug: memory utilization always at 99% @louis-jan (#309)"}),"\n",(0,a.jsx)(n.li,{children:"Docusaurus parser string from githubapi to get latest release @hiento09 (#312)"}),"\n",(0,a.jsx)(n.li,{children:"Footer background, CTA & Highlight colors @drakehere (#288)"}),"\n",(0,a.jsx)(n.li,{children:"Fix CI Test run failed on ubuntu and change release file app name @hiento09 (#307)"}),"\n",(0,a.jsx)(n.li,{children:"Add docusaurus test build pipeline @hiento09 (#302)"}),"\n",(0,a.jsx)(n.li,{children:"fix: #271 Cannot read properties of undefined (reading 'map') @louis-jan (#300)"}),"\n",(0,a.jsx)(n.li,{children:"Fix Docusaurus server side render error @hiento09 (#301)"}),"\n",(0,a.jsx)(n.li,{children:"fix #283: small ui fixes @namchuai (#299)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Fix #290: Add description in package.json and rename to jan @hiento09 (#333)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Add Documentation category to release note template @hiento09 (#332)"}),"\n",(0,a.jsx)(n.li,{children:"Chore/release note template @hiento09 (#323)"}),"\n",(0,a.jsx)(n.li,{children:"Add release note template @hiento09 (#322)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-documentaion",children:"\ud83d\udcd6 Documentaion"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Add auto update app download url on jan.ai @hiento09 (#311)"}),"\n",(0,a.jsx)(n.li,{children:"docs: update per v0.1.3 @0xSage (#280)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @Its-Alamin-H, @dan-jan, @drakehere, @hiento09, @hientominh, @louis-jan, @namchuai, Hien To and James"})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>l,x:()=>o});var a=i(96540);const t={},s=a.createContext(t);function l(e){const n=a.useContext(s);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function o(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:l(e.components),a.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f5765423.318bb309.js b/assets/js/f5765423.318bb309.js new file mode 100644 index 00000000..143642b2 --- /dev/null +++ b/assets/js/f5765423.318bb309.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5689],{14936:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>a,contentTitle:()=>i,default:()=>l,frontMatter:()=>s,metadata:()=>c,toc:()=>u});var o=n(74848),r=n(28453);const s={title:"Audit & Compliance"},i=void 0,c={id:"server-suite/audit-compliance",title:"Audit & Compliance",description:"",source:"@site/docs/server-suite/audit-compliance.md",sourceDirName:"server-suite",slug:"/server-suite/audit-compliance",permalink:"/server-suite/audit-compliance",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/audit-compliance.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Audit & Compliance"}},a={},u=[];function d(t){return(0,o.jsx)(o.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(d,{...t})}):d()}},28453:(t,e,n)=>{n.d(e,{R:()=>i,x:()=>c});var o=n(96540);const r={},s=o.createContext(r);function i(t){const e=o.useContext(s);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:i(t.components),o.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/f5765423.a50a167b.js b/assets/js/f5765423.a50a167b.js deleted file mode 100644 index a69edc88..00000000 --- a/assets/js/f5765423.a50a167b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5689],{14936:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>a,contentTitle:()=>i,default:()=>l,frontMatter:()=>s,metadata:()=>c,toc:()=>u});var o=n(74848),r=n(28453);const s={title:"Audit & Compliance"},i=void 0,c={id:"server-suite/audit-compliance",title:"Audit & Compliance",description:"",source:"@site/docs/server-suite/audit-compliance.md",sourceDirName:"server-suite",slug:"/server-suite/audit-compliance",permalink:"/server-suite/audit-compliance",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/server-suite/audit-compliance.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Audit & Compliance"}},a={},u=[];function d(t){return(0,o.jsx)(o.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,r.R)(),...t.components};return e?(0,o.jsx)(e,{...t,children:(0,o.jsx)(d,{...t})}):d()}},28453:(t,e,n)=>{n.d(e,{R:()=>i,x:()=>c});var o=n(96540);const r={},s=o.createContext(r);function i(t){const e=o.useContext(s);return o.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function c(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(r):t.components||r:i(t.components),o.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/f6d5df20.8ee55645.js b/assets/js/f6d5df20.8ee55645.js new file mode 100644 index 00000000..5e3a5f8c --- /dev/null +++ b/assets/js/f6d5df20.8ee55645.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5106],{442:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>r,metadata:()=>l,toc:()=>d});var a=t(74848),i=t(28453);const r={title:"Hardware Examples",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,l={id:"hardware/community",title:"Hardware Examples",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/hardware/community.md",sourceDirName:"hardware",slug:"/hardware/community",permalink:"/hardware/community",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/community.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Hardware Examples",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},s={},d=[{value:"Add your own example",id:"add-your-own-example",level:2},{value:"File and Title Convention",id:"file-and-title-convention",level:3},{value:"Content",id:"content",level:3},{value:"Affiliate Links",id:"affiliate-links",level:2},{value:"Longer-Term",id:"longer-term",level:2}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,i.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h2,{id:"add-your-own-example",children:"Add your own example"}),"\n",(0,a.jsxs)(n.p,{children:["Add your own examples to this page by creating a new file in the ",(0,a.jsx)(n.code,{children:"docs/docs/hardware/examples"})," directory."]}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-shell",children:"docs\n\u2514\u2500\u2500 docs\n \u2514\u2500\u2500 hardware\n \u2514\u2500\u2500 examples\n \u2514\u2500\u2500 3090x1-%40dan-jan.md\n \u2514\u2500\u2500 3090x1-%40dan-jan.md\n // highlight-next-line\n \u2514\u2500\u2500 .md\n"})}),"\n",(0,a.jsx)(n.h3,{id:"file-and-title-convention",children:"File and Title Convention"}),"\n",(0,a.jsx)(n.p,{children:"We use a specific naming convention for the file name."}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-shell",children:"# Filename\n-.md\n3090x1-@dan-jan.md # Example\n\n# Title\n---\ntitle: <@github_username>: \ntitle: @dan-jan: 3090 Desktop # Example\n---\n"})}),"\n",(0,a.jsx)(n.h3,{id:"content",children:"Content"}),"\n",(0,a.jsx)(n.p,{children:"We highly recommend you include:"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Photos of your build"}),"\n",(0,a.jsxs)(n.li,{children:["List of the components (e.g. ",(0,a.jsx)(n.a,{href:"https://pcpartpicker.com",children:"PCPartPicker"}),")"]}),"\n",(0,a.jsx)(n.li,{children:"Dimensions"}),"\n",(0,a.jsx)(n.li,{children:"Power consumption"}),"\n",(0,a.jsx)(n.li,{children:"Noise level"}),"\n",(0,a.jsx)(n.li,{children:"Any stats on token generation speeds"}),"\n",(0,a.jsx)(n.li,{children:"List of models you have run successfully on the build"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"affiliate-links",children:"Affiliate Links"}),"\n",(0,a.jsx)(n.p,{children:"You are allowed to include affiliate links in your example."}),"\n",(0,a.jsx)(n.h2,{id:"longer-term",children:"Longer-Term"}),"\n",(0,a.jsx)(n.p,{children:"We will likely build a simple web app to make it easier to add your own examples, sort and retrieve."})]})}function u(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>l});var a=t(96540);const i={},r=a.createContext(i);function o(e){const n=a.useContext(r);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),a.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f6d5df20.ec49d76e.js b/assets/js/f6d5df20.ec49d76e.js deleted file mode 100644 index a7e94977..00000000 --- a/assets/js/f6d5df20.ec49d76e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5106],{442:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>r,metadata:()=>l,toc:()=>d});var a=t(74848),i=t(28453);const r={title:"Hardware Examples",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]},o=void 0,l={id:"hardware/community",title:"Hardware Examples",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/hardware/community.md",sourceDirName:"hardware",slug:"/hardware/community",permalink:"/hardware/community",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/community.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Hardware Examples",description:"Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models"]}},s={},d=[{value:"Add your own example",id:"add-your-own-example",level:2},{value:"File and Title Convention",id:"file-and-title-convention",level:3},{value:"Content",id:"content",level:3},{value:"Affiliate Links",id:"affiliate-links",level:2},{value:"Longer-Term",id:"longer-term",level:2}];function c(e){const n={a:"a",code:"code",h2:"h2",h3:"h3",li:"li",p:"p",pre:"pre",ul:"ul",...(0,i.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h2,{id:"add-your-own-example",children:"Add your own example"}),"\n",(0,a.jsxs)(n.p,{children:["Add your own examples to this page by creating a new file in the ",(0,a.jsx)(n.code,{children:"docs/docs/hardware/examples"})," directory."]}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-shell",children:"docs\n\u2514\u2500\u2500 docs\n \u2514\u2500\u2500 hardware\n \u2514\u2500\u2500 examples\n \u2514\u2500\u2500 3090x1-%40dan-jan.md\n \u2514\u2500\u2500 3090x1-%40dan-jan.md\n // highlight-next-line\n \u2514\u2500\u2500 .md\n"})}),"\n",(0,a.jsx)(n.h3,{id:"file-and-title-convention",children:"File and Title Convention"}),"\n",(0,a.jsx)(n.p,{children:"We use a specific naming convention for the file name."}),"\n",(0,a.jsx)(n.pre,{children:(0,a.jsx)(n.code,{className:"language-shell",children:"# Filename\n-.md\n3090x1-@dan-jan.md # Example\n\n# Title\n---\ntitle: <@github_username>: \ntitle: @dan-jan: 3090 Desktop # Example\n---\n"})}),"\n",(0,a.jsx)(n.h3,{id:"content",children:"Content"}),"\n",(0,a.jsx)(n.p,{children:"We highly recommend you include:"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Photos of your build"}),"\n",(0,a.jsxs)(n.li,{children:["List of the components (e.g. ",(0,a.jsx)(n.a,{href:"https://pcpartpicker.com",children:"PCPartPicker"}),")"]}),"\n",(0,a.jsx)(n.li,{children:"Dimensions"}),"\n",(0,a.jsx)(n.li,{children:"Power consumption"}),"\n",(0,a.jsx)(n.li,{children:"Noise level"}),"\n",(0,a.jsx)(n.li,{children:"Any stats on token generation speeds"}),"\n",(0,a.jsx)(n.li,{children:"List of models you have run successfully on the build"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"affiliate-links",children:"Affiliate Links"}),"\n",(0,a.jsx)(n.p,{children:"You are allowed to include affiliate links in your example."}),"\n",(0,a.jsx)(n.h2,{id:"longer-term",children:"Longer-Term"}),"\n",(0,a.jsx)(n.p,{children:"We will likely build a simple web app to make it easier to add your own examples, sort and retrieve."})]})}function u(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>l});var a=t(96540);const i={},r=a.createContext(i);function o(e){const n=a.useContext(r);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),a.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f75920de.2868a81c.js b/assets/js/f75920de.2868a81c.js deleted file mode 100644 index 77b03faf..00000000 --- a/assets/js/f75920de.2868a81c.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4803],{63232:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>r,default:()=>h,frontMatter:()=>l,metadata:()=>s,toc:()=>d});var a=i(74848),t=i(28453);const l={sidebar_position:7,slug:"/changelog/changelog-v0.4.3"},r="v0.4.3",s={id:"releases/changelog/changelog-v0.4.3",title:"v0.4.3",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.3.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.3",permalink:"/changelog/changelog-v0.4.3",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.3.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:7,frontMatter:{sidebar_position:7,slug:"/changelog/changelog-v0.4.3"},sidebar:"releasesSidebar",previous:{title:"v0.4.4",permalink:"/changelog/changelog-v0.4.4"},next:{title:"v0.4.2",permalink:"/changelog/changelog-v0.4.2"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v043",children:"v0.4.3"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.3",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1159",children:"Issue #1159: Hotfix Prompt template for models on the Hub"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Hotfix Prompt template for models on the Hub @hahuyhoang411 (#1159)"}),"\n",(0,a.jsx)(n.li,{children:"Update model list for new release @hahuyhoang411 (#1143)"}),"\n",(0,a.jsx)(n.li,{children:"fix(Thread): #1119 focus on the first thread to prevent blank chat screen @namchuai (#1127)"}),"\n",(0,a.jsx)(n.li,{children:"fix(Thread): #1064 message being added to wrong thread if switching thread @namchuai (#1108)"}),"\n",(0,a.jsx)(n.li,{children:"fix(Thread): #1042 allow create new thread by clicking Use in Jan Hub @namchuai (#1103)"}),"\n",(0,a.jsx)(n.li,{children:"feat(ModelSetting): #1065 update state of model setting between threads @namchuai (#1090)"}),"\n",(0,a.jsx)(n.li,{children:"Update model version @hahuyhoang411 (#1086)"}),"\n",(0,a.jsx)(n.li,{children:"fix: cache hallucinations and failed to load model due to race condition @louis-jan (#1071)"}),"\n",(0,a.jsx)(n.li,{children:"fix(thread): #1043 default model to prefer active model @namchuai (#1070)"}),"\n",(0,a.jsx)(n.li,{children:"Update issue templates @0xSage (#1058)"}),"\n",(0,a.jsx)(n.li,{children:"Update ctx_len and max_tokens @hahuyhoang411 (#1035)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: Add codeQL analysis for push main and pr main @hiro-v (#1128)"}),"\n",(0,a.jsx)(n.li,{children:"Feature autoupdater for nightly build @hiento09 (#1068)"}),"\n",(0,a.jsx)(n.li,{children:"feat: copy button for code block @urmauur (#1062)"}),"\n",(0,a.jsx)(n.li,{children:"Enhancements to Dependency Installation and App Testing @hiento09 (#965)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: error road map url @hieu-jan (#1153)"}),"\n",(0,a.jsx)(n.li,{children:"Fix token speed slow in machine has multi gpus @hiento09 (#1157)"}),"\n",(0,a.jsx)(n.li,{children:"fix: added dialog confirmation clean thread @urmauur (#1142)"}),"\n",(0,a.jsx)(n.li,{children:"fix: remove remote model from shortcut models dialog @urmauur (#1124)"}),"\n",(0,a.jsx)(n.li,{children:"fix: ui issue - all models are activated @louis-jan (#1120)"}),"\n",(0,a.jsx)(n.li,{children:"fix: should not hide empty message away @louis-jan (#1116)"}),"\n",(0,a.jsx)(n.li,{children:"fix: added tooltip for user cannot change model after starting thread @urmauur (#1115)"}),"\n",(0,a.jsx)(n.li,{children:"fix: remote model always active badges @urmauur (#1113)"}),"\n",(0,a.jsx)(n.li,{children:"fix: handle chat completion state with enter button @louis-jan (#1114)"}),"\n",(0,a.jsx)(n.li,{children:"fix: model active indicator only show when model activated @urmauur (#1110)"}),"\n",(0,a.jsx)(n.li,{children:"fix: #1096 yield error message upon thread switching @louis-jan (#1109)"}),"\n",(0,a.jsx)(n.li,{children:"fix: toaster success deleted thread showing id instead of active model @urmauur (#1111)"}),"\n",(0,a.jsx)(n.li,{children:"fix: update copy setting page @urmauur (#1105)"}),"\n",(0,a.jsx)(n.li,{children:"fix: search recommended model @urmauur (#1106)"}),"\n",(0,a.jsx)(n.li,{children:"fix: #1097 streaming response is replaced by error message @louis-jan (#1099)"}),"\n",(0,a.jsx)(n.li,{children:"Fix auto update windows Bug @hiento09 (#1102)"}),"\n",(0,a.jsx)(n.li,{children:"fix: added dialog confirmation when delete thread @urmauur (#1093)"}),"\n",(0,a.jsx)(n.li,{children:"fix: system monitor broken layout when responsive @urmauur (#1085)"}),"\n",(0,a.jsx)(n.li,{children:"bug: chatbox doesn't resize back down @urmauur (#1084)"}),"\n",(0,a.jsx)(n.li,{children:"fix: thread is broken after deleted first generated message @louis-jan (#1061)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: Add codeQL analysis for push main and pr main @hiro-v (#1128)"}),"\n",(0,a.jsx)(n.li,{children:"docs: refactor dev docs, guides and specs @0xSage (#1092)"}),"\n",(0,a.jsx)(n.li,{children:"Correct jq command cause ci nightly build run failed @hiento09 (#1104)"}),"\n",(0,a.jsx)(n.li,{children:"Fix nightly build autoupdater @hiento09 (#1073)"}),"\n",(0,a.jsx)(n.li,{children:"Feature autoupdater for nightly build @hiento09 (#1068)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update product.md @0xSage (#1066)"}),"\n",(0,a.jsx)(n.li,{children:"Posthog disable click event and increase timeout for nitro load model\u2026 @hiento09 (#1060)"}),"\n",(0,a.jsx)(n.li,{children:"docs: improve quickstart docs @0xSage (#1047)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>s});var a=i(96540);const t={},l=a.createContext(t);function r(e){const n=a.useContext(l);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:r(e.components),a.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f75920de.d4a290a1.js b/assets/js/f75920de.d4a290a1.js new file mode 100644 index 00000000..f8ddef77 --- /dev/null +++ b/assets/js/f75920de.d4a290a1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4803],{63232:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>r,default:()=>h,frontMatter:()=>l,metadata:()=>s,toc:()=>d});var a=i(74848),t=i(28453);const l={sidebar_position:7,slug:"/changelog/changelog-v0.4.3"},r="v0.4.3",s={id:"releases/changelog/changelog-v0.4.3",title:"v0.4.3",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.3.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.3",permalink:"/changelog/changelog-v0.4.3",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.3.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:7,frontMatter:{sidebar_position:7,slug:"/changelog/changelog-v0.4.3"},sidebar:"releasesSidebar",previous:{title:"v0.4.4",permalink:"/changelog/changelog-v0.4.4"},next:{title:"v0.4.2",permalink:"/changelog/changelog-v0.4.2"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v043",children:"v0.4.3"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.3",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/1159",children:"Issue #1159: Hotfix Prompt template for models on the Hub"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Hotfix Prompt template for models on the Hub @hahuyhoang411 (#1159)"}),"\n",(0,a.jsx)(n.li,{children:"Update model list for new release @hahuyhoang411 (#1143)"}),"\n",(0,a.jsx)(n.li,{children:"fix(Thread): #1119 focus on the first thread to prevent blank chat screen @namchuai (#1127)"}),"\n",(0,a.jsx)(n.li,{children:"fix(Thread): #1064 message being added to wrong thread if switching thread @namchuai (#1108)"}),"\n",(0,a.jsx)(n.li,{children:"fix(Thread): #1042 allow create new thread by clicking Use in Jan Hub @namchuai (#1103)"}),"\n",(0,a.jsx)(n.li,{children:"feat(ModelSetting): #1065 update state of model setting between threads @namchuai (#1090)"}),"\n",(0,a.jsx)(n.li,{children:"Update model version @hahuyhoang411 (#1086)"}),"\n",(0,a.jsx)(n.li,{children:"fix: cache hallucinations and failed to load model due to race condition @louis-jan (#1071)"}),"\n",(0,a.jsx)(n.li,{children:"fix(thread): #1043 default model to prefer active model @namchuai (#1070)"}),"\n",(0,a.jsx)(n.li,{children:"Update issue templates @0xSage (#1058)"}),"\n",(0,a.jsx)(n.li,{children:"Update ctx_len and max_tokens @hahuyhoang411 (#1035)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: Add codeQL analysis for push main and pr main @hiro-v (#1128)"}),"\n",(0,a.jsx)(n.li,{children:"Feature autoupdater for nightly build @hiento09 (#1068)"}),"\n",(0,a.jsx)(n.li,{children:"feat: copy button for code block @urmauur (#1062)"}),"\n",(0,a.jsx)(n.li,{children:"Enhancements to Dependency Installation and App Testing @hiento09 (#965)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: error road map url @hieu-jan (#1153)"}),"\n",(0,a.jsx)(n.li,{children:"Fix token speed slow in machine has multi gpus @hiento09 (#1157)"}),"\n",(0,a.jsx)(n.li,{children:"fix: added dialog confirmation clean thread @urmauur (#1142)"}),"\n",(0,a.jsx)(n.li,{children:"fix: remove remote model from shortcut models dialog @urmauur (#1124)"}),"\n",(0,a.jsx)(n.li,{children:"fix: ui issue - all models are activated @louis-jan (#1120)"}),"\n",(0,a.jsx)(n.li,{children:"fix: should not hide empty message away @louis-jan (#1116)"}),"\n",(0,a.jsx)(n.li,{children:"fix: added tooltip for user cannot change model after starting thread @urmauur (#1115)"}),"\n",(0,a.jsx)(n.li,{children:"fix: remote model always active badges @urmauur (#1113)"}),"\n",(0,a.jsx)(n.li,{children:"fix: handle chat completion state with enter button @louis-jan (#1114)"}),"\n",(0,a.jsx)(n.li,{children:"fix: model active indicator only show when model activated @urmauur (#1110)"}),"\n",(0,a.jsx)(n.li,{children:"fix: #1096 yield error message upon thread switching @louis-jan (#1109)"}),"\n",(0,a.jsx)(n.li,{children:"fix: toaster success deleted thread showing id instead of active model @urmauur (#1111)"}),"\n",(0,a.jsx)(n.li,{children:"fix: update copy setting page @urmauur (#1105)"}),"\n",(0,a.jsx)(n.li,{children:"fix: search recommended model @urmauur (#1106)"}),"\n",(0,a.jsx)(n.li,{children:"fix: #1097 streaming response is replaced by error message @louis-jan (#1099)"}),"\n",(0,a.jsx)(n.li,{children:"Fix auto update windows Bug @hiento09 (#1102)"}),"\n",(0,a.jsx)(n.li,{children:"fix: added dialog confirmation when delete thread @urmauur (#1093)"}),"\n",(0,a.jsx)(n.li,{children:"fix: system monitor broken layout when responsive @urmauur (#1085)"}),"\n",(0,a.jsx)(n.li,{children:"bug: chatbox doesn't resize back down @urmauur (#1084)"}),"\n",(0,a.jsx)(n.li,{children:"fix: thread is broken after deleted first generated message @louis-jan (#1061)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"feat: Add codeQL analysis for push main and pr main @hiro-v (#1128)"}),"\n",(0,a.jsx)(n.li,{children:"docs: refactor dev docs, guides and specs @0xSage (#1092)"}),"\n",(0,a.jsx)(n.li,{children:"Correct jq command cause ci nightly build run failed @hiento09 (#1104)"}),"\n",(0,a.jsx)(n.li,{children:"Fix nightly build autoupdater @hiento09 (#1073)"}),"\n",(0,a.jsx)(n.li,{children:"Feature autoupdater for nightly build @hiento09 (#1068)"}),"\n",(0,a.jsx)(n.li,{children:"docs: Update product.md @0xSage (#1066)"}),"\n",(0,a.jsx)(n.li,{children:"Posthog disable click event and increase timeout for nitro load model\u2026 @hiento09 (#1060)"}),"\n",(0,a.jsx)(n.li,{children:"docs: improve quickstart docs @0xSage (#1047)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @hieu-jan, @hiro-v, @jan-service-account, @louis-jan, @namchuai and @urmauur"})]})}function h(e={}){const{wrapper:n}={...(0,t.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(c,{...e})}):c(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>s});var a=i(96540);const t={},l=a.createContext(t);function r(e){const n=a.useContext(l);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:r(e.components),a.createElement(l.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f7b6804f.3f171248.js b/assets/js/f7b6804f.3f171248.js new file mode 100644 index 00000000..54e866ca --- /dev/null +++ b/assets/js/f7b6804f.3f171248.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1908],{40417:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>p,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var o=t(74848),i=t(28453);const r={title:"OpenRouter",slug:"/integrations/openrouter",sidebar_position:2,description:"A step-by-step guide on how to integrate Jan with OpenRouter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","OpenRouter integration","OpenRouter"]},s=void 0,a={id:"guides/integrations/router",title:"OpenRouter",description:"A step-by-step guide on how to integrate Jan with OpenRouter.",source:"@site/docs/guides/integrations/router.mdx",sourceDirName:"guides/integrations",slug:"/integrations/openrouter",permalink:"/integrations/openrouter",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/router.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:2,frontMatter:{title:"OpenRouter",slug:"/integrations/openrouter",sidebar_position:2,description:"A step-by-step guide on how to integrate Jan with OpenRouter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","OpenRouter integration","OpenRouter"]},sidebar:"guidesSidebar",previous:{title:"Raycast",permalink:"/integrations/raycast"},next:{title:"Continue Integration",permalink:"/integrations/continue"}},l={},d=[{value:"Integrate OpenRouter with Jan",id:"integrate-openrouter-with-jan",level:2},{value:"Step 1: Configure OpenRouter API key",id:"step-1-configure-openrouter-api-key",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3 : Start the Model",id:"step-3--start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.h2,{id:"integrate-openrouter-with-jan",children:"Integrate OpenRouter with Jan"}),"\n",(0,o.jsxs)(n.p,{children:[(0,o.jsx)(n.a,{href:"https://openrouter.ai/docs#quick-start",children:"OpenRouter"})," is a tool that gathers AI models. Developers can utilize its API to engage with diverse large language models, generative image models, and generative 3D object models."]}),"\n",(0,o.jsx)(n.p,{children:"To connect Jan with OpenRouter for accessing remote Large Language Models (LLMs) through OpenRouter, you can follow the steps below:"}),"\n",(0,o.jsx)(n.h3,{id:"step-1-configure-openrouter-api-key",children:"Step 1: Configure OpenRouter API key"}),"\n",(0,o.jsxs)(n.ol,{children:["\n",(0,o.jsxs)(n.li,{children:["Find your API keys in the ",(0,o.jsx)(n.a,{href:"https://openrouter.ai/keys",children:"OpenRouter API Key"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Set the OpenRouter API key in ",(0,o.jsx)(n.code,{children:"~/jan/engines/openai.json"})," file."]}),"\n"]}),"\n",(0,o.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,o.jsxs)(n.ol,{children:["\n",(0,o.jsxs)(n.li,{children:["Go to the directory ",(0,o.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Make a new folder called ",(0,o.jsx)(n.code,{children:"openrouter-(modelname)"}),", like ",(0,o.jsx)(n.code,{children:"openrouter-dolphin-mixtral-8x7b"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Inside the folder, create a ",(0,o.jsx)(n.code,{children:"model.json"})," file with the following settings:"]}),"\n"]}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsxs)(n.li,{children:["Set the ",(0,o.jsx)(n.code,{children:"id"})," property to the model id obtained from OpenRouter."]}),"\n",(0,o.jsxs)(n.li,{children:["Set the ",(0,o.jsx)(n.code,{children:"format"})," property to ",(0,o.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Set the ",(0,o.jsx)(n.code,{children:"engine"})," property to ",(0,o.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Ensure the ",(0,o.jsx)(n.code,{children:"state"})," property is set to ",(0,o.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,o.jsx)(n.pre,{children:(0,o.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/openrouter-dolphin-mixtral-8x7b/model.json"',children:'{\n "sources": [\n {\n "filename": "openrouter",\n "url": "https://openrouter.ai/"\n }\n ],\n "id": "cognitivecomputations/dolphin-mixtral-8x7b",\n "object": "model",\n "name": "Dolphin 2.6 Mixtral 8x7B",\n "version": "1.0",\n "description": "This is a 16k context fine-tune of Mixtral-8x7b. It excels in coding tasks due to extensive training with coding data and is known for its obedience, although it lacks DPO tuning. The model is uncensored and is stripped of alignment and bias. It requires an external alignment layer for ethical use. Users are cautioned to use this highly compliant model responsibly, as detailed in a blog post about uncensored models at erichartford.com/uncensored-models.",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,o.jsx)(n.admonition,{type:"note",children:(0,o.jsxs)(n.p,{children:["For more details regarding the ",(0,o.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,o.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,o.jsx)(n.h3,{id:"step-3--start-the-model",children:"Step 3 : Start the Model"}),"\n",(0,o.jsxs)(n.ol,{children:["\n",(0,o.jsxs)(n.li,{children:["Restart Jan and go to the ",(0,o.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Find your model and click on the ",(0,o.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]})]})}function p(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var o=t(96540);const i={},r=o.createContext(i);function s(e){const n=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),o.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f7b6804f.f950993e.js b/assets/js/f7b6804f.f950993e.js deleted file mode 100644 index 991b9918..00000000 --- a/assets/js/f7b6804f.f950993e.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1908],{40417:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>s,default:()=>u,frontMatter:()=>r,metadata:()=>a,toc:()=>d});var o=t(74848),i=t(28453);const r={title:"OpenRouter",slug:"/integrations/openrouter",sidebar_position:2,description:"A step-by-step guide on how to integrate Jan with OpenRouter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","OpenRouter integration","OpenRouter"]},s=void 0,a={id:"guides/integrations/router",title:"OpenRouter",description:"A step-by-step guide on how to integrate Jan with OpenRouter.",source:"@site/docs/guides/integrations/router.mdx",sourceDirName:"guides/integrations",slug:"/integrations/openrouter",permalink:"/integrations/openrouter",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/router.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:2,frontMatter:{title:"OpenRouter",slug:"/integrations/openrouter",sidebar_position:2,description:"A step-by-step guide on how to integrate Jan with OpenRouter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","OpenRouter integration","OpenRouter"]},sidebar:"guidesSidebar",previous:{title:"Raycast",permalink:"/integrations/raycast"},next:{title:"Continue Integration",permalink:"/integrations/continue"}},l={},d=[{value:"Integrate OpenRouter with Jan",id:"integrate-openrouter-with-jan",level:2},{value:"Step 1: Configure OpenRouter API key",id:"step-1-configure-openrouter-api-key",level:3},{value:"Step 2: Model Configuration",id:"step-2-model-configuration",level:3},{value:"Step 3 : Start the Model",id:"step-3--start-the-model",level:3}];function c(e){const n={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(n.h2,{id:"integrate-openrouter-with-jan",children:"Integrate OpenRouter with Jan"}),"\n",(0,o.jsxs)(n.p,{children:[(0,o.jsx)(n.a,{href:"https://openrouter.ai/docs#quick-start",children:"OpenRouter"})," is a tool that gathers AI models. Developers can utilize its API to engage with diverse large language models, generative image models, and generative 3D object models."]}),"\n",(0,o.jsx)(n.p,{children:"To connect Jan with OpenRouter for accessing remote Large Language Models (LLMs) through OpenRouter, you can follow the steps below:"}),"\n",(0,o.jsx)(n.h3,{id:"step-1-configure-openrouter-api-key",children:"Step 1: Configure OpenRouter API key"}),"\n",(0,o.jsxs)(n.ol,{children:["\n",(0,o.jsxs)(n.li,{children:["Find your API keys in the ",(0,o.jsx)(n.a,{href:"https://openrouter.ai/keys",children:"OpenRouter API Key"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Set the OpenRouter API key in ",(0,o.jsx)(n.code,{children:"~/jan/engines/openai.json"})," file."]}),"\n"]}),"\n",(0,o.jsx)(n.h3,{id:"step-2-model-configuration",children:"Step 2: Model Configuration"}),"\n",(0,o.jsxs)(n.ol,{children:["\n",(0,o.jsxs)(n.li,{children:["Go to the directory ",(0,o.jsx)(n.code,{children:"~/jan/models"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Make a new folder called ",(0,o.jsx)(n.code,{children:"openrouter-(modelname)"}),", like ",(0,o.jsx)(n.code,{children:"openrouter-dolphin-mixtral-8x7b"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Inside the folder, create a ",(0,o.jsx)(n.code,{children:"model.json"})," file with the following settings:"]}),"\n"]}),"\n",(0,o.jsxs)(n.ul,{children:["\n",(0,o.jsxs)(n.li,{children:["Set the ",(0,o.jsx)(n.code,{children:"id"})," property to the model id obtained from OpenRouter."]}),"\n",(0,o.jsxs)(n.li,{children:["Set the ",(0,o.jsx)(n.code,{children:"format"})," property to ",(0,o.jsx)(n.code,{children:"api"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Set the ",(0,o.jsx)(n.code,{children:"engine"})," property to ",(0,o.jsx)(n.code,{children:"openai"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Ensure the ",(0,o.jsx)(n.code,{children:"state"})," property is set to ",(0,o.jsx)(n.code,{children:"ready"}),"."]}),"\n"]}),"\n",(0,o.jsx)(n.pre,{children:(0,o.jsx)(n.code,{className:"language-json",metastring:'title="~/jan/models/openrouter-dolphin-mixtral-8x7b/model.json"',children:'{\n "sources": [\n {\n "filename": "openrouter",\n "url": "https://openrouter.ai/"\n }\n ],\n "id": "cognitivecomputations/dolphin-mixtral-8x7b",\n "object": "model",\n "name": "Dolphin 2.6 Mixtral 8x7B",\n "version": "1.0",\n "description": "This is a 16k context fine-tune of Mixtral-8x7b. It excels in coding tasks due to extensive training with coding data and is known for its obedience, although it lacks DPO tuning. The model is uncensored and is stripped of alignment and bias. It requires an external alignment layer for ethical use. Users are cautioned to use this highly compliant model responsibly, as detailed in a blog post about uncensored models at erichartford.com/uncensored-models.",\n "format": "api",\n "settings": {},\n "parameters": {},\n "metadata": {\n "tags": ["General", "Big Context Length"]\n },\n "engine": "openai"\n}\n'})}),"\n",(0,o.jsx)(n.admonition,{type:"note",children:(0,o.jsxs)(n.p,{children:["For more details regarding the ",(0,o.jsx)(n.code,{children:"model.json"})," settings and parameters fields, please see ",(0,o.jsx)(n.a,{href:"/guides/engines/remote-server/#modeljson",children:"here"}),"."]})}),"\n",(0,o.jsx)(n.h3,{id:"step-3--start-the-model",children:"Step 3 : Start the Model"}),"\n",(0,o.jsxs)(n.ol,{children:["\n",(0,o.jsxs)(n.li,{children:["Restart Jan and go to the ",(0,o.jsx)(n.strong,{children:"Hub"}),"."]}),"\n",(0,o.jsxs)(n.li,{children:["Find your model and click on the ",(0,o.jsx)(n.strong,{children:"Use"})," button."]}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,o.jsx)(n,{...e,children:(0,o.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>s,x:()=>a});var o=t(96540);const i={},r=o.createContext(i);function s(e){const n=o.useContext(r);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function a(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),o.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f7cb2fe9.c149374b.js b/assets/js/f7cb2fe9.c149374b.js deleted file mode 100644 index c232f7f8..00000000 --- a/assets/js/f7cb2fe9.c149374b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4951],{49946:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>r,toc:()=>d});var i=t(74848),a=t(28453);const s={title:"Overview",slug:"/guides",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model"]},o=void 0,r={id:"guides/get-started/overview",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/get-started/overview.mdx",sourceDirName:"guides/get-started",slug:"/guides",permalink:"/guides",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/overview.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:1,frontMatter:{title:"Overview",slug:"/guides",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model"]},sidebar:"guidesSidebar",next:{title:"Quickstart",permalink:"/guides/quickstart"}},l={},d=[{value:"What is Jan Application",id:"what-is-jan-application",level:2},{value:"How to Use Jan",id:"how-to-use-jan",level:2},{value:"Jan Extensions",id:"jan-extensions",level:2},{value:"Jan Supported Integrations",id:"jan-supported-integrations",level:2}];function c(e){const n={a:"a",admonition:"admonition",h2:"h2",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"what-is-jan-application",children:"What is Jan Application"}),"\n",(0,i.jsx)(n.p,{children:"Jan application is an open-source platform designed to run AI on your computer locally. It is highly customizable and uses open-source AI models, allowing you to do the following:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Run open-source Large Language Models (LLMs) locally."}),"\n",(0,i.jsx)(n.li,{children:"Connect to cloud AIs like ChatGPT or Google."}),"\n",(0,i.jsx)(n.li,{children:"Customize AI with a specific knowledge."}),"\n",(0,i.jsx)(n.li,{children:"Integrate the AI with everyday tools."}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"how-to-use-jan",children:"How to Use Jan"}),"\n",(0,i.jsx)(n.p,{children:"You can install and start Jan in less than 5 minutes by following these simple steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Download Jan from our ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Discord"})," or ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"GitHub repo"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Install Jan."}),"\n",(0,i.jsxs)(n.li,{children:["Open Jan application, select a model in the ",(0,i.jsx)(n.strong,{children:"Hub"})," tab."]}),"\n",(0,i.jsx)(n.li,{children:"Download the model."}),"\n",(0,i.jsxs)(n.li,{children:["Navigate to the ",(0,i.jsx)(n.strong,{children:"Thread"})," tab."]}),"\n",(0,i.jsx)(n.li,{children:"Configure the model."}),"\n",(0,i.jsx)(n.li,{children:"Start chatting with the model."}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["For more detailed quickstart guide, please see ",(0,i.jsx)(n.a,{href:"/guides/quickstart",children:"here"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"jan-extensions",children:"Jan Extensions"}),"\n",(0,i.jsx)(n.p,{children:"Extensions serve as plugins or add-ons that augment the capabilities of the Jan application. These extensions offer a range of enhancements, including adding new functionalities, better integration with external tools, and customizable options for the models within Jan. Jan application currently includes 9 built-in extensions to improve the user experience. Additionally, users can create and add extensions from third parties."}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["For more information regarding the extensions, please see ",(0,i.jsx)(n.a,{href:"/extensions/",children:"here"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"jan-supported-integrations",children:"Jan Supported Integrations"}),"\n",(0,i.jsx)(n.p,{children:"Jan is a versatile tool that supports a wide range of integrations, enhancing its utility for users. Its unique capability to operate fully offline, along with seamless connectivity with daily tools and platforms, facilitates direct interactions with databases, web services, and various software applications from within Jan. Currently, Jan compatible with 7 integration systems, with plans to expand and update these integrations over time, ensuring continuous improvement and adaptability to user needs."}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["For more information regarding the integration, please see ",(0,i.jsx)(n.a,{href:"/integrations/",children:"here"}),"."]})})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>r});var i=t(96540);const a={},s=i.createContext(a);function o(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f7cb2fe9.f5b61cca.js b/assets/js/f7cb2fe9.f5b61cca.js new file mode 100644 index 00000000..1f3033bb --- /dev/null +++ b/assets/js/f7cb2fe9.f5b61cca.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4951],{49946:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>r,toc:()=>d});var i=t(74848),a=t(28453);const s={title:"Overview",slug:"/guides",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model"]},o=void 0,r={id:"guides/get-started/overview",title:"Overview",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",source:"@site/docs/guides/get-started/overview.mdx",sourceDirName:"guides/get-started",slug:"/guides",permalink:"/guides",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/get-started/overview.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:1,frontMatter:{title:"Overview",slug:"/guides",description:"Jan Docs | Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.",sidebar_position:1,keywords:["Jan AI","Jan","ChatGPT alternative","local AI","private AI","conversational AI","no-subscription fee","large language model"]},sidebar:"guidesSidebar",next:{title:"Quickstart",permalink:"/guides/quickstart"}},l={},d=[{value:"What is Jan Application",id:"what-is-jan-application",level:2},{value:"How to Use Jan",id:"how-to-use-jan",level:2},{value:"Jan Extensions",id:"jan-extensions",level:2},{value:"Jan Supported Integrations",id:"jan-supported-integrations",level:2}];function c(e){const n={a:"a",admonition:"admonition",h2:"h2",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,a.R)(),...e.components};return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)(n.h2,{id:"what-is-jan-application",children:"What is Jan Application"}),"\n",(0,i.jsx)(n.p,{children:"Jan application is an open-source platform designed to run AI on your computer locally. It is highly customizable and uses open-source AI models, allowing you to do the following:"}),"\n",(0,i.jsxs)(n.ul,{children:["\n",(0,i.jsx)(n.li,{children:"Run open-source Large Language Models (LLMs) locally."}),"\n",(0,i.jsx)(n.li,{children:"Connect to cloud AIs like ChatGPT or Google."}),"\n",(0,i.jsx)(n.li,{children:"Customize AI with a specific knowledge."}),"\n",(0,i.jsx)(n.li,{children:"Integrate the AI with everyday tools."}),"\n"]}),"\n",(0,i.jsx)(n.h2,{id:"how-to-use-jan",children:"How to Use Jan"}),"\n",(0,i.jsx)(n.p,{children:"You can install and start Jan in less than 5 minutes by following these simple steps:"}),"\n",(0,i.jsxs)(n.ol,{children:["\n",(0,i.jsxs)(n.li,{children:["Download Jan from our ",(0,i.jsx)(n.a,{href:"https://discord.gg/FTk2MvZwJH",children:"Discord"})," or ",(0,i.jsx)(n.a,{href:"https://github.com/janhq/jan",children:"GitHub repo"}),"."]}),"\n",(0,i.jsx)(n.li,{children:"Install Jan."}),"\n",(0,i.jsxs)(n.li,{children:["Open Jan application, select a model in the ",(0,i.jsx)(n.strong,{children:"Hub"})," tab."]}),"\n",(0,i.jsx)(n.li,{children:"Download the model."}),"\n",(0,i.jsxs)(n.li,{children:["Navigate to the ",(0,i.jsx)(n.strong,{children:"Thread"})," tab."]}),"\n",(0,i.jsx)(n.li,{children:"Configure the model."}),"\n",(0,i.jsx)(n.li,{children:"Start chatting with the model."}),"\n"]}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["For more detailed quickstart guide, please see ",(0,i.jsx)(n.a,{href:"/guides/quickstart",children:"here"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"jan-extensions",children:"Jan Extensions"}),"\n",(0,i.jsx)(n.p,{children:"Extensions serve as plugins or add-ons that augment the capabilities of the Jan application. These extensions offer a range of enhancements, including adding new functionalities, better integration with external tools, and customizable options for the models within Jan. Jan application currently includes 9 built-in extensions to improve the user experience. Additionally, users can create and add extensions from third parties."}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["For more information regarding the extensions, please see ",(0,i.jsx)(n.a,{href:"/extensions/",children:"here"}),"."]})}),"\n",(0,i.jsx)(n.h2,{id:"jan-supported-integrations",children:"Jan Supported Integrations"}),"\n",(0,i.jsx)(n.p,{children:"Jan is a versatile tool that supports a wide range of integrations, enhancing its utility for users. Its unique capability to operate fully offline, along with seamless connectivity with daily tools and platforms, facilitates direct interactions with databases, web services, and various software applications from within Jan. Currently, Jan compatible with 7 integration systems, with plans to expand and update these integrations over time, ensuring continuous improvement and adaptability to user needs."}),"\n",(0,i.jsx)(n.admonition,{type:"note",children:(0,i.jsxs)(n.p,{children:["For more information regarding the integration, please see ",(0,i.jsx)(n.a,{href:"/integrations/",children:"here"}),"."]})})]})}function h(e={}){const{wrapper:n}={...(0,a.R)(),...e.components};return n?(0,i.jsx)(n,{...e,children:(0,i.jsx)(c,{...e})}):c(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>o,x:()=>r});var i=t(96540);const a={},s=i.createContext(a);function o(e){const n=i.useContext(s);return i.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(a):e.components||a:o(e.components),i.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f81759f7.0a3270ab.js b/assets/js/f81759f7.0a3270ab.js new file mode 100644 index 00000000..0dacc2c5 --- /dev/null +++ b/assets/js/f81759f7.0a3270ab.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2725],{70042:(n,e,i)=>{i.r(e),i.d(e,{assets:()=>o,contentTitle:()=>r,default:()=>h,frontMatter:()=>l,metadata:()=>s,toc:()=>d});var a=i(74848),t=i(28453);const l={sidebar_position:9,slug:"/changelog/changelog-v0.4.1"},r="v0.4.1",s={id:"releases/changelog/changelog-v0.4.1",title:"v0.4.1",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.1.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.1",permalink:"/changelog/changelog-v0.4.1",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.1.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:9,frontMatter:{sidebar_position:9,slug:"/changelog/changelog-v0.4.1"},sidebar:"releasesSidebar",previous:{title:"v0.4.2",permalink:"/changelog/changelog-v0.4.2"},next:{title:"v0.4.0",permalink:"/changelog/changelog-v0.4.0"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(n){const e={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...n.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(e.h1,{id:"v041",children:"v0.4.1"}),"\n",(0,a.jsxs)(e.p,{children:["For more details, ",(0,a.jsx)(e.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.1",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(e.p,{children:["Highlighted Issue: ",(0,a.jsx)(e.a,{href:"https://github.com/janhq/jan/pull/903",children:"Issue #903: Update README.md"})]}),"\n",(0,a.jsx)(e.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"Update README.md @imtuyethan (#903)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"feat: Kill nitro process with API - nitro 0.1.27 @vuonghoainam (#975)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Inference Nitro with Prompt Template @hahuyhoang411 (#952)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Add NVIDIA triton trt-llm extension @vuonghoainam (#888)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Hotfit for Nitro loading on CPU with hyper-threading support @vuonghoainam (#931)"}),"\n",(0,a.jsx)(e.li,{children:"feat: adding model params @namchuai (#886)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Multiple inference engines for nitro and openai @vuonghoainam (#814)"}),"\n",(0,a.jsx)(e.li,{children:"docs: add json schema for engine and model parameters @tikikun (#840)"}),"\n",(0,a.jsx)(e.li,{children:"feat: improve SEO keywords @hieu-jan (#894)"}),"\n",(0,a.jsx)(e.li,{children:"enhancement: fix spacing landing page responsive @urmauur (#891)"}),"\n",(0,a.jsx)(e.li,{children:"bug: added label coming soon for windows and linux @urmauur (#881)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"fix: 963 can not run openai models on windows @louis-jan (#974)"}),"\n",(0,a.jsx)(e.li,{children:"fix: Inference engine Nitro with Windows with/ without CUDA @vuonghoainam (#950)"}),"\n",(0,a.jsx)(e.li,{children:"Fix error Jan app linux crash @hiento09 (#958)"}),"\n",(0,a.jsx)(e.li,{children:"fix: windows bug - control buttons close,max,min hidden @linhtran174 (#949)"}),"\n",(0,a.jsx)(e.li,{children:"bug: fix ui landing page @urmauur (#937)"}),"\n",(0,a.jsx)(e.li,{children:"fix: model parameters for inference extensions @vuonghoainam (#935)"}),"\n",(0,a.jsx)(e.li,{children:"[bug] Fix floating border outside card right panel @urmauur (#934)"}),"\n",(0,a.jsx)(e.li,{children:"fix: import_typescript.default.isTokenKind is not a function @louis-jan (#923)"}),"\n",(0,a.jsx)(e.li,{children:"bug: fix syntax formatting @urmauur (#899)"}),"\n",(0,a.jsx)(e.li,{children:"bug: update metadata title and desc @urmauur (#884)"}),"\n",(0,a.jsx)(e.li,{children:"fix: download button text color is blending into the background @louis-jan (#883)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"chore: add desktop app analytics @louis-jan (#978)"}),"\n",(0,a.jsx)(e.li,{children:"refactor: clean types and interfaces @0xSage (#966)"}),"\n",(0,a.jsx)(e.li,{children:"docs: scaffold dev docs @0xSage (#856)"}),"\n",(0,a.jsx)(e.li,{children:"chore: Bump nitro to 0.1.26 @vuonghoainam (#960)"}),"\n",(0,a.jsx)(e.li,{children:"Update update-release-url.yml @hiento09 (#951)"}),"\n",(0,a.jsx)(e.li,{children:"Fix update release url pipeline run failed @hiento09 (#947)"}),"\n",(0,a.jsx)(e.li,{children:"chore: Bumpt nitro bin version to version 0.1.23 @vuonghoainam (#942)"}),"\n",(0,a.jsx)(e.li,{children:"Fix update release url pipeline @hiento09 (#941)"}),"\n",(0,a.jsx)(e.li,{children:"CI automatically update Update README with Nightly Build Information and stable download URL @hiento09 (#940)"}),"\n",(0,a.jsx)(e.li,{children:"refactor: deprecate invokers - auto proxying apis - strict types @louis-jan (#924)"}),"\n",(0,a.jsx)(e.li,{children:"docs: standardize yaml files @hieu-jan (#933)"}),"\n",(0,a.jsx)(e.li,{children:"chore: universal module definition @louis-jan (#902)"}),"\n",(0,a.jsx)(e.li,{children:"docs: add assistants api reference @hieu-jan (#801)"}),"\n",(0,a.jsx)(e.li,{children:"docs: add json schema for engine and model parameters @tikikun (#840)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(e.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @hieu-jan, @imtuyethan, @jan-service-account, @linhtran174, @louis-jan, @namchuai, @tikikun, @urmauur and @vuonghoainam"})]})}function h(n={}){const{wrapper:e}={...(0,t.R)(),...n.components};return e?(0,a.jsx)(e,{...n,children:(0,a.jsx)(c,{...n})}):c(n)}},28453:(n,e,i)=>{i.d(e,{R:()=>r,x:()=>s});var a=i(96540);const t={},l=a.createContext(t);function r(n){const e=a.useContext(l);return a.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function s(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(t):n.components||t:r(n.components),a.createElement(l.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/f81759f7.23e790cf.js b/assets/js/f81759f7.23e790cf.js deleted file mode 100644 index f1b699d9..00000000 --- a/assets/js/f81759f7.23e790cf.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2725],{70042:(n,e,i)=>{i.r(e),i.d(e,{assets:()=>o,contentTitle:()=>r,default:()=>h,frontMatter:()=>l,metadata:()=>s,toc:()=>d});var a=i(74848),t=i(28453);const l={sidebar_position:9,slug:"/changelog/changelog-v0.4.1"},r="v0.4.1",s={id:"releases/changelog/changelog-v0.4.1",title:"v0.4.1",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.4.1.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.4.1",permalink:"/changelog/changelog-v0.4.1",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.4.1.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:9,frontMatter:{sidebar_position:9,slug:"/changelog/changelog-v0.4.1"},sidebar:"releasesSidebar",previous:{title:"v0.4.2",permalink:"/changelog/changelog-v0.4.2"},next:{title:"v0.4.0",permalink:"/changelog/changelog-v0.4.0"}},o={},d=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Fixes",id:"-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function c(n){const e={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,t.R)(),...n.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(e.h1,{id:"v041",children:"v0.4.1"}),"\n",(0,a.jsxs)(e.p,{children:["For more details, ",(0,a.jsx)(e.a,{href:"https://github.com/janhq/jan/releases/tag/v0.4.1",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(e.p,{children:["Highlighted Issue: ",(0,a.jsx)(e.a,{href:"https://github.com/janhq/jan/pull/903",children:"Issue #903: Update README.md"})]}),"\n",(0,a.jsx)(e.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"Update README.md @imtuyethan (#903)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"feat: Kill nitro process with API - nitro 0.1.27 @vuonghoainam (#975)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Inference Nitro with Prompt Template @hahuyhoang411 (#952)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Add NVIDIA triton trt-llm extension @vuonghoainam (#888)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Hotfit for Nitro loading on CPU with hyper-threading support @vuonghoainam (#931)"}),"\n",(0,a.jsx)(e.li,{children:"feat: adding model params @namchuai (#886)"}),"\n",(0,a.jsx)(e.li,{children:"feat: Multiple inference engines for nitro and openai @vuonghoainam (#814)"}),"\n",(0,a.jsx)(e.li,{children:"docs: add json schema for engine and model parameters @tikikun (#840)"}),"\n",(0,a.jsx)(e.li,{children:"feat: improve SEO keywords @hieu-jan (#894)"}),"\n",(0,a.jsx)(e.li,{children:"enhancement: fix spacing landing page responsive @urmauur (#891)"}),"\n",(0,a.jsx)(e.li,{children:"bug: added label coming soon for windows and linux @urmauur (#881)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"-fixes",children:"\ud83d\udc1b Fixes"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"fix: 963 can not run openai models on windows @louis-jan (#974)"}),"\n",(0,a.jsx)(e.li,{children:"fix: Inference engine Nitro with Windows with/ without CUDA @vuonghoainam (#950)"}),"\n",(0,a.jsx)(e.li,{children:"Fix error Jan app linux crash @hiento09 (#958)"}),"\n",(0,a.jsx)(e.li,{children:"fix: windows bug - control buttons close,max,min hidden @linhtran174 (#949)"}),"\n",(0,a.jsx)(e.li,{children:"bug: fix ui landing page @urmauur (#937)"}),"\n",(0,a.jsx)(e.li,{children:"fix: model parameters for inference extensions @vuonghoainam (#935)"}),"\n",(0,a.jsx)(e.li,{children:"[bug] Fix floating border outside card right panel @urmauur (#934)"}),"\n",(0,a.jsx)(e.li,{children:"fix: import_typescript.default.isTokenKind is not a function @louis-jan (#923)"}),"\n",(0,a.jsx)(e.li,{children:"bug: fix syntax formatting @urmauur (#899)"}),"\n",(0,a.jsx)(e.li,{children:"bug: update metadata title and desc @urmauur (#884)"}),"\n",(0,a.jsx)(e.li,{children:"fix: download button text color is blending into the background @louis-jan (#883)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(e.ul,{children:["\n",(0,a.jsx)(e.li,{children:"chore: add desktop app analytics @louis-jan (#978)"}),"\n",(0,a.jsx)(e.li,{children:"refactor: clean types and interfaces @0xSage (#966)"}),"\n",(0,a.jsx)(e.li,{children:"docs: scaffold dev docs @0xSage (#856)"}),"\n",(0,a.jsx)(e.li,{children:"chore: Bump nitro to 0.1.26 @vuonghoainam (#960)"}),"\n",(0,a.jsx)(e.li,{children:"Update update-release-url.yml @hiento09 (#951)"}),"\n",(0,a.jsx)(e.li,{children:"Fix update release url pipeline run failed @hiento09 (#947)"}),"\n",(0,a.jsx)(e.li,{children:"chore: Bumpt nitro bin version to version 0.1.23 @vuonghoainam (#942)"}),"\n",(0,a.jsx)(e.li,{children:"Fix update release url pipeline @hiento09 (#941)"}),"\n",(0,a.jsx)(e.li,{children:"CI automatically update Update README with Nightly Build Information and stable download URL @hiento09 (#940)"}),"\n",(0,a.jsx)(e.li,{children:"refactor: deprecate invokers - auto proxying apis - strict types @louis-jan (#924)"}),"\n",(0,a.jsx)(e.li,{children:"docs: standardize yaml files @hieu-jan (#933)"}),"\n",(0,a.jsx)(e.li,{children:"chore: universal module definition @louis-jan (#902)"}),"\n",(0,a.jsx)(e.li,{children:"docs: add assistants api reference @hieu-jan (#801)"}),"\n",(0,a.jsx)(e.li,{children:"docs: add json schema for engine and model parameters @tikikun (#840)"}),"\n"]}),"\n",(0,a.jsx)(e.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(e.p,{children:"@0xSage, @hahuyhoang411, @hiento09, @hieu-jan, @imtuyethan, @jan-service-account, @linhtran174, @louis-jan, @namchuai, @tikikun, @urmauur and @vuonghoainam"})]})}function h(n={}){const{wrapper:e}={...(0,t.R)(),...n.components};return e?(0,a.jsx)(e,{...n,children:(0,a.jsx)(c,{...n})}):c(n)}},28453:(n,e,i)=>{i.d(e,{R:()=>r,x:()=>s});var a=i(96540);const t={},l=a.createContext(t);function r(n){const e=a.useContext(l);return a.useMemo((function(){return"function"==typeof n?n(e):{...e,...n}}),[e,n])}function s(n){let e;return e=n.disableParentContext?"function"==typeof n.components?n.components(t):n.components||t:r(n.components),a.createElement(l.Provider,{value:e},n.children)}}}]); \ No newline at end of file diff --git a/assets/js/f8bfd07c.55b6af87.js b/assets/js/f8bfd07c.55b6af87.js deleted file mode 100644 index 5c9a9e49..00000000 --- a/assets/js/f8bfd07c.55b6af87.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[231],{60192:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>i,contentTitle:()=>a,default:()=>p,frontMatter:()=>r,metadata:()=>s,toc:()=>d});var c=t(74848),o=t(28453);const r={title:"Anatomy of a Thinking Machine",slug:"/hardware/concepts"},a=void 0,s={id:"hardware/concepts/concepts",title:"Anatomy of a Thinking Machine",description:"- Cover the difference between CPU/RAM and GPU/VRAM",source:"@site/docs/hardware/concepts/concepts.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts",permalink:"/hardware/concepts",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/concepts.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Anatomy of a Thinking Machine",slug:"/hardware/concepts"}},i={},d=[];function l(e){const n={li:"li",ul:"ul",...(0,o.R)(),...e.components};return(0,c.jsxs)(n.ul,{children:["\n",(0,c.jsx)(n.li,{children:"Cover the difference between CPU/RAM and GPU/VRAM"}),"\n",(0,c.jsx)(n.li,{children:"AI can now run on CPU/RAM (llama.cpp)"}),"\n",(0,c.jsx)(n.li,{children:"AI that runs on Apple Silicon"}),"\n"]})}function p(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,c.jsx)(n,{...e,children:(0,c.jsx)(l,{...e})}):l(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>s});var c=t(96540);const o={},r=c.createContext(o);function a(e){const n=c.useContext(r);return c.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),c.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f8bfd07c.fa55446a.js b/assets/js/f8bfd07c.fa55446a.js new file mode 100644 index 00000000..5ce38c21 --- /dev/null +++ b/assets/js/f8bfd07c.fa55446a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[231],{60192:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>i,contentTitle:()=>a,default:()=>p,frontMatter:()=>r,metadata:()=>s,toc:()=>d});var c=t(74848),o=t(28453);const r={title:"Anatomy of a Thinking Machine",slug:"/hardware/concepts"},a=void 0,s={id:"hardware/concepts/concepts",title:"Anatomy of a Thinking Machine",description:"- Cover the difference between CPU/RAM and GPU/VRAM",source:"@site/docs/hardware/concepts/concepts.md",sourceDirName:"hardware/concepts",slug:"/hardware/concepts",permalink:"/hardware/concepts",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/hardware/concepts/concepts.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Anatomy of a Thinking Machine",slug:"/hardware/concepts"}},i={},d=[];function l(e){const n={li:"li",ul:"ul",...(0,o.R)(),...e.components};return(0,c.jsxs)(n.ul,{children:["\n",(0,c.jsx)(n.li,{children:"Cover the difference between CPU/RAM and GPU/VRAM"}),"\n",(0,c.jsx)(n.li,{children:"AI can now run on CPU/RAM (llama.cpp)"}),"\n",(0,c.jsx)(n.li,{children:"AI that runs on Apple Silicon"}),"\n"]})}function p(e={}){const{wrapper:n}={...(0,o.R)(),...e.components};return n?(0,c.jsx)(n,{...e,children:(0,c.jsx)(l,{...e})}):l(e)}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>s});var c=t(96540);const o={},r=c.createContext(o);function a(e){const n=c.useContext(r);return c.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:a(e.components),c.createElement(r.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f9a6fee3.22eabd3e.js b/assets/js/f9a6fee3.22eabd3e.js new file mode 100644 index 00000000..39ea0b7c --- /dev/null +++ b/assets/js/f9a6fee3.22eabd3e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6222],{97546:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>r,default:()=>u,frontMatter:()=>t,metadata:()=>s,toc:()=>c});var a=i(74848),l=i(28453);const t={sidebar_position:12,slug:"/changelog/changelog-v0.3.2"},r="v0.3.2",s={id:"releases/changelog/changelog-v0.3.2",title:"v0.3.2",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.2.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.2",permalink:"/changelog/changelog-v0.3.2",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.2.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:12,frontMatter:{sidebar_position:12,slug:"/changelog/changelog-v0.3.2"},sidebar:"releasesSidebar",previous:{title:"v0.3.3",permalink:"/changelog/changelog-v0.3.3"},next:{title:"v0.3.1",permalink:"/changelog/changelog-v0.3.1"}},o={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,l.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v032",children:"v0.3.2"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.2",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/612",children:"Issue #612: fix: disabled required env"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: disabled required env @urmauur (#612)"}),"\n",(0,a.jsx)(n.li,{children:"Install Posthog snippet @imtuyethan (#573)"}),"\n",(0,a.jsx)(n.li,{children:"web: google tag manager @urmauur (#562)"}),"\n",(0,a.jsx)(n.li,{children:"docs: fix syntax highlighting @0xSage (#602)"}),"\n",(0,a.jsx)(n.li,{children:"chore: remove past event @0xSage (#600)"}),"\n",(0,a.jsx)(n.li,{children:"docs: new docs @0xSage (#599)"}),"\n",(0,a.jsx)(n.li,{children:"[chore]: Update docs @dan-jan (#597)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"refactor: main electron with managers and handlers @louis-jan (#610)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Fix: Failed to load model - unload model nitro @louis-jan (#616)"}),"\n",(0,a.jsx)(n.li,{children:"Restore cpx nitro step in yarn script @hiento09 (#617)"}),"\n",(0,a.jsx)(n.li,{children:"fix(#591): prevent duplicate message id issue @namchuai (#595)"}),"\n",(0,a.jsx)(n.li,{children:"bug: cancelling a model download should be delete the model file on user data @urmauur (#613)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix weird padding vertical snippet code @urmauur (#608)"}),"\n",(0,a.jsx)(n.li,{children:"bug: Fix button download detect intel or apple silicon @urmauur (#609)"}),"\n",(0,a.jsx)(n.li,{children:"bug: enable delete conversation after deleted model @urmauur (#594)"}),"\n",(0,a.jsx)(n.li,{children:"bug: download modal should truncate model name @urmauur (#592)"}),"\n",(0,a.jsx)(n.li,{children:"bug: support multiple line input chat using Textarea instead @urmauur (#593)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"refactor: main electron with managers and handlers @louis-jan (#610)"}),"\n",(0,a.jsx)(n.li,{children:"Chore/refactor yarn script @hiento09 (#615)"}),"\n",(0,a.jsx)(n.li,{children:"fix: line height and update typography component @urmauur (#611)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @dan-jan, @hiento09, @imtuyethan, @jan-service-account, @louis-jan, @namchuai and @urmauur"})]})}function u(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>s});var a=i(96540);const l={},t=a.createContext(l);function r(e){const n=a.useContext(t);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:r(e.components),a.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/f9a6fee3.f2a75886.js b/assets/js/f9a6fee3.f2a75886.js deleted file mode 100644 index d7d7de15..00000000 --- a/assets/js/f9a6fee3.f2a75886.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6222],{97546:(e,n,i)=>{i.r(n),i.d(n,{assets:()=>o,contentTitle:()=>r,default:()=>u,frontMatter:()=>t,metadata:()=>s,toc:()=>c});var a=i(74848),l=i(28453);const t={sidebar_position:12,slug:"/changelog/changelog-v0.3.2"},r="v0.3.2",s={id:"releases/changelog/changelog-v0.3.2",title:"v0.3.2",description:"For more details, GitHub Issues",source:"@site/docs/releases/changelog/changelog-v0.3.2.mdx",sourceDirName:"releases/changelog",slug:"/changelog/changelog-v0.3.2",permalink:"/changelog/changelog-v0.3.2",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/releases/changelog/changelog-v0.3.2.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:12,frontMatter:{sidebar_position:12,slug:"/changelog/changelog-v0.3.2"},sidebar:"releasesSidebar",previous:{title:"v0.3.3",permalink:"/changelog/changelog-v0.3.3"},next:{title:"v0.3.1",permalink:"/changelog/changelog-v0.3.1"}},o={},c=[{value:"Changes",id:"changes",level:2},{value:"\ud83d\ude80 Features",id:"-features",level:2},{value:"\ud83d\udc1b Bug Fixes",id:"-bug-fixes",level:2},{value:"\ud83e\uddf0 Maintenance",id:"-maintenance",level:2},{value:"Contributor",id:"contributor",level:2}];function d(e){const n={a:"a",h1:"h1",h2:"h2",li:"li",p:"p",ul:"ul",...(0,l.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.h1,{id:"v032",children:"v0.3.2"}),"\n",(0,a.jsxs)(n.p,{children:["For more details, ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/releases/tag/v0.3.2",children:"GitHub Issues"})]}),"\n",(0,a.jsxs)(n.p,{children:["Highlighted Issue: ",(0,a.jsx)(n.a,{href:"https://github.com/janhq/jan/pull/612",children:"Issue #612: fix: disabled required env"})]}),"\n",(0,a.jsx)(n.h2,{id:"changes",children:"Changes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"fix: disabled required env @urmauur (#612)"}),"\n",(0,a.jsx)(n.li,{children:"Install Posthog snippet @imtuyethan (#573)"}),"\n",(0,a.jsx)(n.li,{children:"web: google tag manager @urmauur (#562)"}),"\n",(0,a.jsx)(n.li,{children:"docs: fix syntax highlighting @0xSage (#602)"}),"\n",(0,a.jsx)(n.li,{children:"chore: remove past event @0xSage (#600)"}),"\n",(0,a.jsx)(n.li,{children:"docs: new docs @0xSage (#599)"}),"\n",(0,a.jsx)(n.li,{children:"[chore]: Update docs @dan-jan (#597)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-features",children:"\ud83d\ude80 Features"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"refactor: main electron with managers and handlers @louis-jan (#610)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-bug-fixes",children:"\ud83d\udc1b Bug Fixes"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"Fix: Failed to load model - unload model nitro @louis-jan (#616)"}),"\n",(0,a.jsx)(n.li,{children:"Restore cpx nitro step in yarn script @hiento09 (#617)"}),"\n",(0,a.jsx)(n.li,{children:"fix(#591): prevent duplicate message id issue @namchuai (#595)"}),"\n",(0,a.jsx)(n.li,{children:"bug: cancelling a model download should be delete the model file on user data @urmauur (#613)"}),"\n",(0,a.jsx)(n.li,{children:"bug: fix weird padding vertical snippet code @urmauur (#608)"}),"\n",(0,a.jsx)(n.li,{children:"bug: Fix button download detect intel or apple silicon @urmauur (#609)"}),"\n",(0,a.jsx)(n.li,{children:"bug: enable delete conversation after deleted model @urmauur (#594)"}),"\n",(0,a.jsx)(n.li,{children:"bug: download modal should truncate model name @urmauur (#592)"}),"\n",(0,a.jsx)(n.li,{children:"bug: support multiple line input chat using Textarea instead @urmauur (#593)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"-maintenance",children:"\ud83e\uddf0 Maintenance"}),"\n",(0,a.jsxs)(n.ul,{children:["\n",(0,a.jsx)(n.li,{children:"refactor: main electron with managers and handlers @louis-jan (#610)"}),"\n",(0,a.jsx)(n.li,{children:"Chore/refactor yarn script @hiento09 (#615)"}),"\n",(0,a.jsx)(n.li,{children:"fix: line height and update typography component @urmauur (#611)"}),"\n"]}),"\n",(0,a.jsx)(n.h2,{id:"contributor",children:"Contributor"}),"\n",(0,a.jsx)(n.p,{children:"@0xSage, @dan-jan, @hiento09, @imtuyethan, @jan-service-account, @louis-jan, @namchuai and @urmauur"})]})}function u(e={}){const{wrapper:n}={...(0,l.R)(),...e.components};return n?(0,a.jsx)(n,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},28453:(e,n,i)=>{i.d(n,{R:()=>r,x:()=>s});var a=i(96540);const l={},t=a.createContext(l);function r(e){const n=a.useContext(t);return a.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function s(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:r(e.components),a.createElement(t.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/fece9508.c5f6eafa.js b/assets/js/fece9508.c5f6eafa.js deleted file mode 100644 index 48a9fae3..00000000 --- a/assets/js/fece9508.c5f6eafa.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5094],{16891:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>s,default:()=>l,frontMatter:()=>a,metadata:()=>i,toc:()=>d});var r=n(74848),o=n(28453);const a={title:"Integrations"},s=void 0,i={id:"integrations",title:"Integrations",description:"",source:"@site/docs/integrations.md",sourceDirName:".",slug:"/integrations",permalink:"/integrations",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",frontMatter:{title:"Integrations"},sidebar:"ecosystemSidebar",previous:{title:"Become a Partner",permalink:"/partners/become-a-partner"},next:{title:"Langchain",permalink:"/integrations/langchain"}},c={},d=[];function u(t){return(0,r.jsx)(r.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,r.jsx)(e,{...t,children:(0,r.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>s,x:()=>i});var r=n(96540);const o={},a=r.createContext(o);function s(t){const e=r.useContext(a);return r.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:s(t.components),r.createElement(a.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/fece9508.ceabf536.js b/assets/js/fece9508.ceabf536.js new file mode 100644 index 00000000..2f487e65 --- /dev/null +++ b/assets/js/fece9508.ceabf536.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5094],{16891:(t,e,n)=>{n.r(e),n.d(e,{assets:()=>c,contentTitle:()=>a,default:()=>l,frontMatter:()=>s,metadata:()=>i,toc:()=>d});var r=n(74848),o=n(28453);const s={title:"Integrations"},a=void 0,i={id:"integrations",title:"Integrations",description:"",source:"@site/docs/integrations.md",sourceDirName:".",slug:"/integrations",permalink:"/integrations",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/integrations.md",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",frontMatter:{title:"Integrations"},sidebar:"ecosystemSidebar",previous:{title:"Become a Partner",permalink:"/partners/become-a-partner"},next:{title:"Langchain",permalink:"/integrations/langchain"}},c={},d=[];function u(t){return(0,r.jsx)(r.Fragment,{})}function l(t={}){const{wrapper:e}={...(0,o.R)(),...t.components};return e?(0,r.jsx)(e,{...t,children:(0,r.jsx)(u,{...t})}):u()}},28453:(t,e,n)=>{n.d(e,{R:()=>a,x:()=>i});var r=n(96540);const o={},s=r.createContext(o);function a(t){const e=r.useContext(s);return r.useMemo((function(){return"function"==typeof t?t(e):{...e,...t}}),[e,t])}function i(t){let e;return e=t.disableParentContext?"function"==typeof t.components?t.components(o):t.components||o:a(t.components),r.createElement(s.Provider,{value:e},t.children)}}}]); \ No newline at end of file diff --git a/assets/js/ff5e07c6.0c8ff949.js b/assets/js/ff5e07c6.0c8ff949.js new file mode 100644 index 00000000..eefa3ab6 --- /dev/null +++ b/assets/js/ff5e07c6.0c8ff949.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5697],{43018:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>a,contentTitle:()=>o,default:()=>d,frontMatter:()=>s,metadata:()=>l,toc:()=>p});var t=r(74848),i=r(28453);const s={title:"Open Interpreter",slug:"/integrations/interpreter",sidebar_position:6,description:"A step-by-step guide on how to integrate Jan with Open Interpreter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Open Interpreter integration","Open Interpreter"]},o=void 0,l={id:"guides/integrations/interpreter",title:"Open Interpreter",description:"A step-by-step guide on how to integrate Jan with Open Interpreter.",source:"@site/docs/guides/integrations/interpreter.mdx",sourceDirName:"guides/integrations",slug:"/integrations/interpreter",permalink:"/integrations/interpreter",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/interpreter.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1712027706,formattedLastUpdatedAt:"Apr 2, 2024",sidebarPosition:6,frontMatter:{title:"Open Interpreter",slug:"/integrations/interpreter",sidebar_position:6,description:"A step-by-step guide on how to integrate Jan with Open Interpreter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Open Interpreter integration","Open Interpreter"]},sidebar:"guidesSidebar",previous:{title:"Discord",permalink:"/integrations/discord"},next:{title:"Raycast",permalink:"/integrations/raycast"}},a={},p=[{value:"Integrate Open Interpreter with Jan",id:"integrate-open-interpreter-with-jan",level:2},{value:"Step 1: Install Open Interpreter",id:"step-1-install-open-interpreter",level:3},{value:"Step 2: Configure Jan's Local API Server",id:"step-2-configure-jans-local-api-server",level:3},{value:"Enabling Jan API Server",id:"enabling-jan-api-server",level:4},{value:"Step 3: Set the Open Interpreter Environment",id:"step-3-set-the-open-interpreter-environment",level:3}];function c(e){const n={a:"a",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"integrate-open-interpreter-with-jan",children:"Integrate Open Interpreter with Jan"}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.a,{href:"https://github.com/KillianLucas/open-interpreter/",children:"Open Interpreter"})," lets LLMs run code (Python, Javascript, Shell, and more) locally. You can chat with Open Interpreter through a ChatGPT-like interface in your terminal by running ",(0,t.jsx)(n.code,{children:"interpreter"})," after installing. To integrate Open Interpreter with Jan, follow the steps below:"]}),"\n",(0,t.jsx)(n.h3,{id:"step-1-install-open-interpreter",children:"Step 1: Install Open Interpreter"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Install Open Interpreter by running:"}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-sh",children:"pip install open-interpreter\n"})}),"\n",(0,t.jsxs)(n.ol,{start:"2",children:["\n",(0,t.jsxs)(n.li,{children:["A Rust compiler is required to install Open Interpreter. If not already installed, run the following command or go to ",(0,t.jsx)(n.a,{href:"https://rustup.rs/",children:"this page"})," if you are running on windows:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-zsh",children:"sudo apt install rustc\n"})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-configure-jans-local-api-server",children:"Step 2: Configure Jan's Local API Server"}),"\n",(0,t.jsxs)(n.p,{children:["Before using Open Interpreter, configure the model in ",(0,t.jsx)(n.code,{children:"Settings"})," > ",(0,t.jsx)(n.code,{children:"My Model"})," for Jan and activate its local API server."]}),"\n",(0,t.jsx)(n.h4,{id:"enabling-jan-api-server",children:"Enabling Jan API Server"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Click the ",(0,t.jsx)(n.code,{children:"<>"})," button to access the ",(0,t.jsx)(n.strong,{children:"Local API Server"})," section in Jan."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Configure the server settings, including ",(0,t.jsx)(n.strong,{children:"IP Port"}),", ",(0,t.jsx)(n.strong,{children:"Cross-Origin-Resource-Sharing (CORS)"}),", and ",(0,t.jsx)(n.strong,{children:"Verbose Server Logs"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Click ",(0,t.jsx)(n.strong,{children:"Start Server"}),"."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"step-3-set-the-open-interpreter-environment",children:"Step 3: Set the Open Interpreter Environment"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["For integration, provide the API Base (",(0,t.jsx)(n.code,{children:"http://localhost:1337/v1"}),") and the model ID (e.g., ",(0,t.jsx)(n.code,{children:"mistral-ins-7b-q4"}),") when running Open Interpreter. For example see the code below:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-zsh",children:"interpreter --api_base http://localhost:1337/v1 --model mistral-ins-7b-q4\n"})}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.strong,{children:"Open Interpreter is now ready for use!"})}),"\n"]})]})}function d(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>l});var t=r(96540);const i={},s=t.createContext(i);function o(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/ff5e07c6.b7272128.js b/assets/js/ff5e07c6.b7272128.js deleted file mode 100644 index 1f86560c..00000000 --- a/assets/js/ff5e07c6.b7272128.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5697],{43018:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>a,contentTitle:()=>o,default:()=>d,frontMatter:()=>s,metadata:()=>l,toc:()=>p});var t=r(74848),i=r(28453);const s={title:"Open Interpreter",slug:"/integrations/interpreter",sidebar_position:6,description:"A step-by-step guide on how to integrate Jan with Open Interpreter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Open Interpreter integration","Open Interpreter"]},o=void 0,l={id:"guides/integrations/interpreter",title:"Open Interpreter",description:"A step-by-step guide on how to integrate Jan with Open Interpreter.",source:"@site/docs/guides/integrations/interpreter.mdx",sourceDirName:"guides/integrations",slug:"/integrations/interpreter",permalink:"/integrations/interpreter",draft:!1,unlisted:!1,editUrl:"https://github.com/janhq/docs/tree/main/docs/guides/integrations/interpreter.mdx",tags:[],version:"current",lastUpdatedBy:"Nicole Zhu",lastUpdatedAt:1711818688,formattedLastUpdatedAt:"Mar 30, 2024",sidebarPosition:6,frontMatter:{title:"Open Interpreter",slug:"/integrations/interpreter",sidebar_position:6,description:"A step-by-step guide on how to integrate Jan with Open Interpreter.",keywords:["Jan","Customizable Intelligence","LLM","local AI","privacy focus","free and open source","private and offline","conversational AI","no-subscription fee","large language models","Open Interpreter integration","Open Interpreter"]},sidebar:"guidesSidebar",previous:{title:"Discord",permalink:"/integrations/discord"},next:{title:"Raycast",permalink:"/integrations/raycast"}},a={},p=[{value:"Integrate Open Interpreter with Jan",id:"integrate-open-interpreter-with-jan",level:2},{value:"Step 1: Install Open Interpreter",id:"step-1-install-open-interpreter",level:3},{value:"Step 2: Configure Jan's Local API Server",id:"step-2-configure-jans-local-api-server",level:3},{value:"Enabling Jan API Server",id:"enabling-jan-api-server",level:4},{value:"Step 3: Set the Open Interpreter Environment",id:"step-3-set-the-open-interpreter-environment",level:3}];function c(e){const n={a:"a",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",h4:"h4",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",...(0,i.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.h2,{id:"integrate-open-interpreter-with-jan",children:"Integrate Open Interpreter with Jan"}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.a,{href:"https://github.com/KillianLucas/open-interpreter/",children:"Open Interpreter"})," lets LLMs run code (Python, Javascript, Shell, and more) locally. You can chat with Open Interpreter through a ChatGPT-like interface in your terminal by running ",(0,t.jsx)(n.code,{children:"interpreter"})," after installing. To integrate Open Interpreter with Jan, follow the steps below:"]}),"\n",(0,t.jsx)(n.h3,{id:"step-1-install-open-interpreter",children:"Step 1: Install Open Interpreter"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsx)(n.li,{children:"Install Open Interpreter by running:"}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-sh",children:"pip install open-interpreter\n"})}),"\n",(0,t.jsxs)(n.ol,{start:"2",children:["\n",(0,t.jsxs)(n.li,{children:["A Rust compiler is required to install Open Interpreter. If not already installed, run the following command or go to ",(0,t.jsx)(n.a,{href:"https://rustup.rs/",children:"this page"})," if you are running on windows:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-zsh",children:"sudo apt install rustc\n"})}),"\n",(0,t.jsx)(n.h3,{id:"step-2-configure-jans-local-api-server",children:"Step 2: Configure Jan's Local API Server"}),"\n",(0,t.jsxs)(n.p,{children:["Before using Open Interpreter, configure the model in ",(0,t.jsx)(n.code,{children:"Settings"})," > ",(0,t.jsx)(n.code,{children:"My Model"})," for Jan and activate its local API server."]}),"\n",(0,t.jsx)(n.h4,{id:"enabling-jan-api-server",children:"Enabling Jan API Server"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Click the ",(0,t.jsx)(n.code,{children:"<>"})," button to access the ",(0,t.jsx)(n.strong,{children:"Local API Server"})," section in Jan."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Configure the server settings, including ",(0,t.jsx)(n.strong,{children:"IP Port"}),", ",(0,t.jsx)(n.strong,{children:"Cross-Origin-Resource-Sharing (CORS)"}),", and ",(0,t.jsx)(n.strong,{children:"Verbose Server Logs"}),"."]}),"\n"]}),"\n",(0,t.jsxs)(n.li,{children:["\n",(0,t.jsxs)(n.p,{children:["Click ",(0,t.jsx)(n.strong,{children:"Start Server"}),"."]}),"\n"]}),"\n"]}),"\n",(0,t.jsx)(n.h3,{id:"step-3-set-the-open-interpreter-environment",children:"Step 3: Set the Open Interpreter Environment"}),"\n",(0,t.jsxs)(n.ol,{children:["\n",(0,t.jsxs)(n.li,{children:["For integration, provide the API Base (",(0,t.jsx)(n.code,{children:"http://localhost:1337/v1"}),") and the model ID (e.g., ",(0,t.jsx)(n.code,{children:"mistral-ins-7b-q4"}),") when running Open Interpreter. For example see the code below:"]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-zsh",children:"interpreter --api_base http://localhost:1337/v1 --model mistral-ins-7b-q4\n"})}),"\n",(0,t.jsxs)(n.blockquote,{children:["\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.strong,{children:"Open Interpreter is now ready for use!"})}),"\n"]})]})}function d(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},28453:(e,n,r)=>{r.d(n,{R:()=>o,x:()=>l});var t=r(96540);const i={},s=t.createContext(i);function o(e){const n=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function l(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:o(e.components),t.createElement(s.Provider,{value:n},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/main.27ee85bf.js b/assets/js/main.27ee85bf.js deleted file mode 100644 index f2a1c400..00000000 --- a/assets/js/main.27ee85bf.js +++ /dev/null @@ -1,2 +0,0 @@ -/*! For license information please see main.27ee85bf.js.LICENSE.txt */ -(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6411],{17785:(e,t,n)=>{"use strict";n.d(t,{B:()=>p});var r=n(96540);function a(){return r.createElement("svg",{width:"15",height:"15",className:"DocSearch-Control-Key-Icon"},r.createElement("path",{d:"M4.505 4.496h2M5.505 5.496v5M8.216 4.496l.055 5.993M10 7.5c.333.333.5.667.5 1v2M12.326 4.5v5.996M8.384 4.496c1.674 0 2.116 0 2.116 1.5s-.442 1.5-2.116 1.5M3.205 9.303c-.09.448-.277 1.21-1.241 1.203C1 10.5.5 9.513.5 8V7c0-1.57.5-2.5 1.464-2.494.964.006 1.134.598 1.24 1.342M12.553 10.5h1.953",strokeWidth:"1.2",stroke:"currentColor",fill:"none",strokeLinecap:"square"}))}var o=n(89188),s=["translations"];function i(){return i=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var n=0,r=new Array(t);n=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var d="Ctrl";var p=r.forwardRef((function(e,t){var n=e.translations,c=void 0===n?{}:n,p=u(e,s),m=c.buttonText,h=void 0===m?"Search":m,g=c.buttonAriaLabel,b=void 0===g?"Search":g,y=l((0,r.useState)(null),2),v=y[0],w=y[1];return(0,r.useEffect)((function(){"undefined"!=typeof navigator&&(/(Mac|iPhone|iPod|iPad)/i.test(navigator.platform)?w("\u2318"):w(d))}),[]),r.createElement("button",i({type:"button",className:"DocSearch DocSearch-Button","aria-label":b},p,{ref:t}),r.createElement("span",{className:"DocSearch-Button-Container"},r.createElement(o.W,null),r.createElement("span",{className:"DocSearch-Button-Placeholder"},h)),r.createElement("span",{className:"DocSearch-Button-Keys"},null!==v&&r.createElement(r.Fragment,null,r.createElement(f,{reactsToKey:v===d?d:"Meta"},v===d?r.createElement(a,null):v),r.createElement(f,{reactsToKey:"k"},"K"))))}));function f(e){var t=e.reactsToKey,n=e.children,a=l((0,r.useState)(!1),2),o=a[0],s=a[1];return(0,r.useEffect)((function(){if(t)return window.addEventListener("keydown",e),window.addEventListener("keyup",n),function(){window.removeEventListener("keydown",e),window.removeEventListener("keyup",n)};function e(e){e.key===t&&s(!0)}function n(e){e.key!==t&&"Meta"!==e.key||s(!1)}}),[t]),r.createElement("kbd",{className:o?"DocSearch-Button-Key DocSearch-Button-Key--pressed":"DocSearch-Button-Key"},n)}},89188:(e,t,n)=>{"use strict";n.d(t,{W:()=>a});var r=n(96540);function a(){return r.createElement("svg",{width:"20",height:"20",className:"DocSearch-Search-Icon",viewBox:"0 0 20 20","aria-hidden":"true"},r.createElement("path",{d:"M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z",stroke:"currentColor",fill:"none",fillRule:"evenodd",strokeLinecap:"round",strokeLinejoin:"round"}))}},22525:(e,t,n)=>{"use strict";n.d(t,{E:()=>a});var r=n(96540);function a(e){var t=e.isOpen,n=e.onOpen,a=e.onClose,o=e.onInput,s=e.searchButtonRef;r.useEffect((function(){function e(e){var r;(27===e.keyCode&&t||"k"===(null===(r=e.key)||void 0===r?void 0:r.toLowerCase())&&(e.metaKey||e.ctrlKey)||!function(e){var t=e.target,n=t.tagName;return t.isContentEditable||"INPUT"===n||"SELECT"===n||"TEXTAREA"===n}(e)&&"/"===e.key&&!t)&&(e.preventDefault(),t?a():document.body.classList.contains("DocSearch--active")||document.body.classList.contains("DocSearch--active")||n()),s&&s.current===document.activeElement&&o&&/[a-zA-Z0-9]/.test(String.fromCharCode(e.keyCode))&&o(e)}return window.addEventListener("keydown",e),function(){window.removeEventListener("keydown",e)}}),[t,n,a,o,s])}},35947:(e,t,n)=>{"use strict";n.d(t,{A:()=>p});n(96540);var r=n(53259),a=n.n(r),o=n(84054);const s={"008541a4":[()=>n.e(3152).then(n.bind(n,77200)),"@site/docs/releases/changelog/changelog-v0.3.0.mdx",77200],"00863b7a":[()=>n.e(8282).then(n.bind(n,71254)),"@site/docs/guides/integrations/overview-integration.mdx",71254],"01a85c17":[()=>Promise.all([n.e(1869),n.e(8209)]).then(n.bind(n,29140)),"@theme/BlogTagsListPage",29140],"024311fd":[()=>Promise.all([n.e(1869),n.e(9666)]).then(n.bind(n,28952)),"@site/docs/guides/troubleshooting.mdx",28952],"05bed8b8":[()=>n.e(127).then(n.bind(n,1886)),"@site/docs/releases/changelog/changelog-v0.4.5.mdx",1886],"05e26e91":[()=>n.e(6770).then(n.bind(n,45549)),"@site/docs/foundry/foundry.md",45549],"07d35b44":[()=>n.e(8946).then(n.bind(n,31609)),"@site/docs/team/join-us.md",31609],"08b75426":[()=>n.e(257).then(n.bind(n,82010)),"@site/docs/guides/remote-providers/claude.mdx",82010],"09d23ef9":[()=>n.e(9975).then(n.bind(n,14643)),"@site/docs/how-we-work/engineering/engineering.md",14643],"0a199304":[()=>n.e(7028).then(n.bind(n,90282)),"@site/docs/partners/become-a-partner.md",90282],"0b3bb891":[()=>n.e(9754).then(n.bind(n,87062)),"@site/docs/guides/local-providers/tensorrt.mdx",87062],"106736fc":[()=>n.e(8663).then(n.bind(n,92790)),"@site/docs/solutions/developers.md",92790],"119e46ed":[()=>Promise.all([n.e(1869),n.e(7570)]).then(n.bind(n,92617)),"@site/docs/guides/installation/docker.mdx",92617],"11c8e996":[()=>n.e(2563).then(n.bind(n,11318)),"@site/docs/guides/providers/tensorrt-llm.md",11318],"13238e48":[()=>n.e(2727).then(n.bind(n,28348)),"@site/docs/hardware/concepts/storage.md",28348],"1496a874":[()=>n.e(1919).then(n.bind(n,65284)),"@site/docs/how-we-work/engineering/qa.mdx",65284],"15d51a08":[()=>n.e(6034).then(n.bind(n,15373)),"@site/docs/guides/extensions/extensions.mdx",15373],"16993ecd":[()=>Promise.all([n.e(1869),n.e(4597)]).then(n.bind(n,46193)),"@site/docs/guides/local-providers/README.mdx",46193],"1736cbe2":[()=>n.e(4606).then(n.bind(n,45017)),"@site/docs/integrations/langchain.md",45017],17896441:[()=>Promise.all([n.e(1869),n.e(3224),n.e(8401)]).then(n.bind(n,25022)),"@theme/DocItem",25022],"181ad04a":[()=>n.e(4479).then(n.t.bind(n,66799,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-plugin-redoc/plugin-redoc-0/redocApiSpecV1.2-plugin-redoc-0.json",66799],"188f62ae":[()=>Promise.all([n.e(1869),n.e(2616)]).then(n.bind(n,23124)),"@site/docs/developer/05-framework/03-engineering/README.mdx",23124],"1a4e3797":[()=>Promise.all([n.e(1869),n.e(2138)]).then(n.bind(n,10673)),"@theme/SearchPage",10673],"1c091541":[()=>n.e(1153).then(n.t.bind(n,52945,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-plugin-content-blog/default/plugin-route-context-module-100.json",52945],"1ca75787":[()=>n.e(9876).then(n.bind(n,44074)),"@site/docs/server-suite/admin-console.md",44074],"1f2d4838":[()=>n.e(4573).then(n.t.bind(n,10899,19)),"~docs/default/tag-tags-finetune-llm-cb8.json",10899],"206c1ee3":[()=>n.e(3454).then(n.t.bind(n,75120,19)),"~docs/default/tag-tags-fine-tuning-tutorial-ac1.json",75120],"22f0f67d":[()=>Promise.all([n.e(1869),n.e(5032)]).then(n.bind(n,70116)),"@site/docs/guides/integrations/README.mdx",70116],"2460799d":[()=>n.e(7152).then(n.bind(n,70117)),"@site/docs/hardware/concepts/chassis.md",70117],"247783bb":[()=>n.e(5548).then(n.t.bind(n,61966,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-plugin-content-docs/default/plugin-route-context-module-100.json",61966],"25b7c3f2":[()=>Promise.all([n.e(1869),n.e(6513),n.e(9847)]).then(n.bind(n,1494)),"@site/src/pages/docs.js",1494],26408708:[()=>n.e(4888).then(n.t.bind(n,97739,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-plugin-redoc/plugin-redoc-0/plugin-route-context-module-100.json",97739],"266350b9":[()=>n.e(166).then(n.bind(n,980)),"@site/docs/releases/changelog/changelog-v0.4.7.mdx",980],"26c8ba65":[()=>n.e(1178).then(n.bind(n,20963)),"@site/docs/guides/installation/linux.mdx",20963],"286abf9a":[()=>n.e(1860).then(n.bind(n,62935)),"@site/docs/developer/05-framework/03-product/hub.md",62935],"29484a29":[()=>n.e(2222).then(n.bind(n,22379)),"@site/docs/guides/integrations/crewai.mdx",22379],"2a036e2a":[()=>n.e(9307).then(n.bind(n,49932)),"@site/docs/integrations/openai.md",49932],"2a4d3a22":[()=>n.e(6312).then(n.bind(n,12093)),"@site/docs/events/hcmc-oct23.md",12093],"2c3f1425":[()=>n.e(8965).then(n.bind(n,475)),"@site/docs/releases/changelog/changelog-v0.4.4.mdx",475],"2c9d0a4b":[()=>n.e(6258).then(n.bind(n,83986)),"@site/docs/about/vision.md",83986],"2f9d99a9":[()=>n.e(3088).then(n.bind(n,10320)),"@site/docs/hardware/recommendations/by-hardware.md",10320],"30c31013":[()=>n.e(6511).then(n.bind(n,15264)),"@site/docs/guides/local-providers/lmstudio.mdx",15264],32016656:[()=>n.e(5404).then(n.bind(n,17503)),"@site/docs/how-we-work/analytics/analytics.md",17503],"3214d410":[()=>n.e(9068).then(n.t.bind(n,10490,19)),"~docs/default/tag-tags-use-cases-b94.json",10490],"333fadac":[()=>n.e(1641).then(n.bind(n,8552)),"@site/docs/developer/05-framework/03-engineering/engine.md",8552],"33b2879d":[()=>n.e(7037).then(n.t.bind(n,59749,19)),"~docs/default/tag-tags-retrieval-augmented-generation-357.json",59749],"34f95ac5":[()=>n.e(8151).then(n.bind(n,96287)),"@site/blog/2024-03-19-TensorRT-LLM.md?truncated=true",96287],"363dfc80":[()=>n.e(7388).then(n.t.bind(n,46644,19)),"~blog/default/blog-tags-postmortem-9e0-list.json",46644],"3720c009":[()=>Promise.all([n.e(1869),n.e(4787)]).then(n.bind(n,12194)),"@theme/DocTagsListPage",12194],"3acd41e5":[()=>Promise.all([n.e(1869),n.e(853)]).then(n.t.bind(n,1914,23)),"/home/runner/work/docs/docs/node_modules/@scalar/docusaurus/dist/ScalarDocusaurus",1914],"3adc484d":[()=>n.e(168).then(n.bind(n,3657)),"@site/docs/features/extensions-framework.md",3657],"3afe9044":[()=>n.e(9419).then(n.bind(n,23603)),"@site/docs/developer/01-overview/README.md",23603],"3b8fdfae":[()=>n.e(7226).then(n.bind(n,28430)),"@site/docs/hardware/overview/cpu-vs-gpu.md",28430],"3c009e50":[()=>n.e(996).then(n.bind(n,79791)),"@site/docs/releases/changelog/changelog-v0.4.8.mdx",79791],"3c380bbe":[()=>Promise.all([n.e(1869),n.e(5033)]).then(n.bind(n,81972)),"@site/docs/guides/integrations/vscode.mdx",81972],"3cca42cf":[()=>n.e(2244).then(n.bind(n,53955)),"@site/docs/guides/integrations/unsloth.mdx",53955],"3de37af1":[()=>n.e(8509).then(n.t.bind(n,88089,19)),"~docs/default/tag-tags-open-source-chat-gpt-alternatives-dd3.json",88089],"3f026702":[()=>n.e(6505).then(n.bind(n,93672)),"@site/docs/about/2035.mdx",93672],"43e2ca0d":[()=>n.e(3929).then(n.bind(n,7383)),"@site/docs/integrations/openrouter.md",7383],"44215aaa":[()=>n.e(4940).then(n.bind(n,73688)),"@site/docs/server-suite/identity-access-management.md",73688],"47cd42b6":[()=>n.e(7523).then(n.bind(n,30364)),"@site/docs/developer/01-overview/01-architecture.md",30364],"4a916acb":[()=>n.e(4368).then(n.bind(n,89734)),"@site/docs/hardware/concepts/gpu-and-vram.md",89734],"4ed5f22c":[()=>n.e(6330).then(n.bind(n,25751)),"@site/docs/hardware/hardware.md",25751],"50318dff":[()=>n.e(9816).then(n.bind(n,22484)),"@site/docs/developer/05-framework/03-product/system-monitor.md",22484],"516c1eaf":[()=>n.e(2691).then(n.bind(n,64396)),"@site/docs/features/remote.md",64396],"538c54c2":[()=>n.e(7460).then(n.t.bind(n,74632,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-plugin-redoc/plugin-redoc-0/redocApiLayoutV1-plugin-redoc-0.json",74632],"5578256f":[()=>n.e(8611).then(n.bind(n,68051)),"@site/docs/developer/05-framework/03-engineering/assistants.md",68051],"55960ee5":[()=>n.e(5151).then(n.t.bind(n,30350,19)),"~docs/default/tags-list-current-prop-15a.json",30350],"5682c91a":[()=>n.e(670).then(n.bind(n,84147)),"@site/docs/studio/studio.md",84147],57902419:[()=>n.e(7176).then(n.bind(n,34764)),"@site/docs/about/roadmap.md",34764],"58a762cd":[()=>n.e(2689).then(n.bind(n,31477)),"@site/docs/team/team.md",31477],"58dab583":[()=>n.e(8545).then(n.bind(n,45473)),"@site/docs/solutions/enterprises.md",45473],"59b068d1":[()=>n.e(8968).then(n.t.bind(n,57757,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-theme-search-algolia/default/plugin-route-context-module-100.json",57757],"5b978d55":[()=>n.e(672).then(n.t.bind(n,7616,19)),"~docs/default/tag-tags-industries-6c1.json",7616],"5b9b123e":[()=>Promise.all([n.e(1869),n.e(7785)]).then(n.bind(n,60365)),"@site/docs/guides/local-providers/llamacpp.mdx",60365],"5d1d7bd5":[()=>n.e(2873).then(n.bind(n,49205)),"@site/docs/releases/changelog/changelog-v0.4.2.mdx",49205],"5d642b69":[()=>n.e(4509).then(n.t.bind(n,7048,19)),"~blog/default/blog-tags-4090-eb4-list.json",7048],"5e95c892":[()=>n.e(9647).then(n.bind(n,7121)),"@theme/DocsRoot",7121],"5e9f5e1a":[()=>Promise.resolve().then(n.bind(n,4784)),"@generated/docusaurus.config",4784],"623a8400":[()=>n.e(9651).then(n.bind(n,89916)),"@site/docs/how-we-work/engineering/ci-cd.md",89916],"637ab85d":[()=>n.e(4207).then(n.bind(n,95199)),"@site/docs/guides/user-guides/overview-guides.mdx",95199],"63f5f85b":[()=>n.e(4558).then(n.bind(n,20820)),"@site/docs/server-suite/observability.md",20820],"6477de9f":[()=>n.e(3919).then(n.bind(n,20582)),"@site/docs/hardware/examples/4090x2-@dan-jan.md",20582],"667ed12c":[()=>n.e(259).then(n.bind(n,30749)),"@site/docs/guides/remote-providers/remote-server-integration.mdx",30749],"6875c492":[()=>Promise.all([n.e(1869),n.e(3224),n.e(8544),n.e(4813)]).then(n.bind(n,33069)),"@theme/BlogTagsPostsPage",33069],"6e9fbade":[()=>n.e(5483).then(n.bind(n,10394)),"@site/docs/developer/05-framework/README.md",10394],"71718d6b":[()=>n.e(4103).then(n.bind(n,12017)),"@site/docs/guides/integrations/raycast.mdx",12017],"723a3dd1":[()=>n.e(6292).then(n.bind(n,18157)),"@site/docs/hardware/recommendations/by-usecase.md",18157],"72d4c782":[()=>n.e(4536).then(n.bind(n,36520)),"@site/docs/solutions/chatgpt-alternative.md",36520],"75e6dc85":[()=>n.e(352).then(n.bind(n,9289)),"@site/docs/wall-of-love.md",9289],"7706d644":[()=>Promise.all([n.e(1869),n.e(1893)]).then(n.bind(n,22555)),"@site/docs/guides/installation/README.mdx",22555],"788574c2":[()=>n.e(9201).then(n.t.bind(n,46831,19)),"~blog/default/blog-tags-3090-8c0-list.json",46831],"78f51efd":[()=>n.e(9505).then(n.t.bind(n,92409,19)),"~blog/default/blog-tags-4090-eb4.json",92409],"7918b82f":[()=>n.e(8402).then(n.bind(n,60709)),"@site/docs/privacy/privacy.md",60709],"7f23cee5":[()=>n.e(2591).then(n.bind(n,75491)),"@site/docs/community/community.mdx",75491],"7fa78872":[()=>n.e(4571).then(n.bind(n,18222)),"@site/docs/guides/user-guides/manage-models.mdx",18222],"814f3328":[()=>n.e(7472).then(n.t.bind(n,55513,19)),"~blog/default/blog-post-list-prop-default.json",55513],"83b8bbb8":[()=>n.e(4240).then(n.t.bind(n,48132,19)),"~blog/default/blog-tags-llama-cpp-ebc-list.json",48132],"849af23d":[()=>n.e(8152).then(n.bind(n,82657)),"@site/docs/ecosystem/ecosystem.md",82657],"84ee6c7c":[()=>n.e(202).then(n.bind(n,46149)),"@site/docs/hardware/recommendations/by-budget.md",46149],"85c092f0":[()=>n.e(3940).then(n.bind(n,78379)),"@site/docs/hardware/concepts/network.md",78379],"85edfec6":[()=>n.e(1837).then(n.bind(n,73365)),"@site/docs/guides/local-providers/ollama.mdx",73365],"89a159d2":[()=>n.e(4704).then(n.bind(n,71506)),"@site/docs/server-suite/enterprise.md",71506],"8abcec24":[()=>n.e(2969).then(n.bind(n,89352)),"@site/docs/about/faq.md",89352],"8af60830":[()=>n.e(7719).then(n.bind(n,60865)),"@site/docs/platforms/desktop.md",60865],"8c922572":[()=>n.e(1345).then(n.bind(n,8797)),"@site/docs/features/data-security.md",8797],"8d91959a":[()=>n.e(6977).then(n.bind(n,92980)),"@site/docs/hardware/concepts/power.md",92980],"8edd84da":[()=>n.e(5971).then(n.bind(n,73972)),"@site/docs/guides/integrations/discord.mdx",73972],"8fc2f59a":[()=>n.e(9627).then(n.t.bind(n,56890,19)),"~docs/default/tag-tags-outperform-chat-gpt-d0f.json",56890],"935f2afb":[()=>n.e(8581).then(n.t.bind(n,35610,19)),"~docs/default/version-current-metadata-prop-751.json",35610],"9456c9fc":[()=>n.e(8236).then(n.bind(n,80384)),"@site/docs/developer/05-framework/03-product/chat.md",80384],"96809c51":[()=>n.e(9364).then(n.bind(n,34945)),"@site/docs/guides/user-guides/manage-threads.mdx",34945],"9913ef57":[()=>n.e(7212).then(n.t.bind(n,64656,19)),"~blog/default/blog-tags-inference-engine-9a1.json",64656],"9a70be8c":[()=>n.e(2712).then(n.bind(n,99942)),"@site/docs/features/api-server.md",99942],"9b2fae64":[()=>n.e(9602).then(n.bind(n,89455)),"@site/docs/solutions/finance.md",89455],"9b95d7dc":[()=>n.e(1032).then(n.bind(n,90054)),"@site/docs/hardware/concepts/cpu-and-ram.md",90054],"9c214a64":[()=>n.e(379).then(n.bind(n,96513)),"@site/docs/partners/partners.md",96513],"9d26486f":[()=>n.e(9208).then(n.bind(n,84457)),"@site/docs/guides/get-started/settingup-gpu.mdx",84457],"9d84b429":[()=>n.e(2145).then(n.t.bind(n,4993,19)),"~docs/default/tag-tags-personal-dataset-2c3.json",4993],"9e4087bc":[()=>n.e(2711).then(n.bind(n,89331)),"@theme/BlogArchivePage",89331],"9f16b3a4":[()=>n.e(2313).then(n.t.bind(n,52839,19)),"/home/runner/work/docs/docs/.docusaurus/@scalar/docusaurus/default/plugin-route-context-module-100.json",52839],"9ffacb83":[()=>n.e(8321).then(n.bind(n,82592)),"@site/docs/guides/installation/mac.mdx",82592],a070662e:[()=>n.e(2614).then(n.bind(n,3697)),"@site/docs/developer/01-overview/04-install-and-prerequisites.md",3697],a0b2d528:[()=>n.e(9323).then(n.bind(n,78039)),"@site/docs/guides/user-guides/jan-data-folder.mdx",78039],a0b5e9d3:[()=>n.e(6718).then(n.bind(n,2751)),"@site/docs/solutions/startups.md",2751],a422893d:[()=>n.e(9704).then(n.bind(n,40981)),"@site/docs/template/QA_script.md",40981],a4e65e27:[()=>n.e(4306).then(n.bind(n,7058)),"@site/docs/guides/installation/windows.mdx",7058],a6117a95:[()=>n.e(2294).then(n.bind(n,43159)),"@site/docs/how-we-work/website-docs/website-docs.md",43159],a6aa9e1f:[()=>Promise.all([n.e(1869),n.e(3224),n.e(8544),n.e(7643)]).then(n.bind(n,77785)),"@theme/BlogListPage",77785],a7023ddc:[()=>n.e(9267).then(n.t.bind(n,28289,19)),"~blog/default/blog-tags-tags-4c2.json",28289],a7434565:[()=>n.e(1678).then(n.t.bind(n,4061,19)),"/home/runner/work/docs/docs/.docusaurus/docusaurus-plugin-content-pages/default/plugin-route-context-module-100.json",4061],a7bd4aaa:[()=>n.e(7098).then(n.bind(n,74532)),"@theme/DocVersionRoot",74532],a8144d1b:[()=>n.e(7130).then(n.bind(n,65370)),"@site/docs/guides/remote-providers/mistral.mdx",65370],a89e83c1:[()=>n.e(409).then(n.t.bind(n,22048,19)),"~blog/default/blog-tags-llama-cpp-ebc.json",22048],a94703ab:[()=>Promise.all([n.e(1869),n.e(9048)]).then(n.bind(n,92559)),"@theme/DocRoot",92559],ab3966b2:[()=>n.e(7778).then(n.bind(n,81483)),"@site/docs/hardware/recommendations/by-model.md",81483],ab40e686:[()=>Promise.all([n.e(1869),n.e(2377)]).then(n.bind(n,85580)),"@site/docs/developer/05-framework/03-product/README.mdx",85580],ac19ad34:[()=>n.e(8767).then(n.t.bind(n,79992,19)),"~blog/default/blog-tags-3090-8c0.json",79992],ac215511:[()=>n.e(9368).then(n.bind(n,85068)),"@site/blog/2024-01-10-bitdefender-false-positive-flag.mdx?truncated=true",85068],ac2eaf96:[()=>n.e(2076).then(n.bind(n,89336)),"@site/docs/integrations/ollama.md",89336],acdc6a90:[()=>n.e(5160).then(n.t.bind(n,89360,19)),"~docs/default/tag-tags-audiences-f52.json",89360],ad24ee66:[()=>n.e(5624).then(n.t.bind(n,95392,19)),"~blog/default/blog-tags-nvidia-5cf.json",95392],af41fd2b:[()=>n.e(9773).then(n.bind(n,46865)),"@site/docs/developer/05-framework/03-engineering/threads.md",46865],b0b06257:[()=>n.e(5187).then(n.bind(n,71325)),"@site/blog/2024-03-19-TensorRT-LLM.md",71325],b0ff4131:[()=>n.e(9680).then(n.bind(n,73103)),"@site/docs/guides/user-guides/manage-assistants.mdx",73103],b2a763b0:[()=>n.e(2544).then(n.bind(n,77487)),"@site/docs/platforms/mobile.md",77487],b2b675dd:[()=>n.e(1991).then(n.t.bind(n,29775,19)),"~blog/default/blog-c06.json",29775],b2e8bd45:[()=>n.e(5347).then(n.bind(n,38800)),"@site/docs/solutions/legal.md",38800],b2f554cd:[()=>n.e(5894).then(n.t.bind(n,76042,19)),"~blog/default/blog-archive-80c.json",76042],b43004d9:[()=>n.e(2905).then(n.t.bind(n,48782,19)),"~blog/default/blog-tags-tensor-rt-llm-f4d-list.json",48782],b7c91fb8:[()=>n.e(1245).then(n.bind(n,27111)),"@site/docs/features/local.md",27111],b7da00f9:[()=>n.e(8600).then(n.bind(n,79539)),"@site/docs/how-we-work/strategy/strategy.md",79539],bdfdc86d:[()=>n.e(176).then(n.bind(n,3750)),"@site/docs/releases/changelog/changelog-v0.2.3.mdx",3750],be9dd107:[()=>n.e(1013).then(n.bind(n,21730)),"@site/docs/releases/changelog/changelog-v0.4.9.mdx",21730],bebfba98:[()=>n.e(3100).then(n.bind(n,46147)),"@site/docs/solutions/ai-employees.md",46147],bf442c43:[()=>n.e(2541).then(n.bind(n,34400)),"@site/blog/2024-01-10-bitdefender-false-positive-flag.mdx",34400],c1ad6153:[()=>n.e(6123).then(n.bind(n,29879)),"@site/docs/releases/changelog/changelog-v0.3.3.mdx",29879],c236f8c9:[()=>n.e(4057).then(n.bind(n,34059)),"@site/docs/guides/remote-providers/groq.mdx",34059],c469c680:[()=>n.e(2170).then(n.bind(n,82274)),"@site/docs/events/nvidia-llm-day-nov-23.md",82274],c494d087:[()=>n.e(1014).then(n.bind(n,1959)),"@site/docs/releases/changelog/changelog-v0.4.0.mdx",1959],c4f5d8e4:[()=>Promise.all([n.e(1869),n.e(9660),n.e(9924),n.e(2634)]).then(n.bind(n,55875)),"@site/src/pages/index.js",55875],c5483ccc:[()=>n.e(8911).then(n.bind(n,46812)),"@site/docs/hardware/overview/cloud-vs-self-hosting.md",46812],c582042f:[()=>n.e(9493).then(n.bind(n,69493)),"@site/docs/support/support.md",69493],c5e57f2d:[()=>n.e(3167).then(n.bind(n,98300)),"@site/docs/releases/changelog/changelog-v0.2.1.mdx",98300],c689f34a:[()=>n.e(3085).then(n.t.bind(n,33623,19)),"~blog/default/blog-tags-nvidia-5cf-list.json",33623],c9ded099:[()=>n.e(9504).then(n.t.bind(n,61685,19)),"~blog/default/blog-tags-postmortem-9e0.json",61685],ca7f0669:[()=>n.e(7401).then(n.bind(n,72797)),"@site/docs/pricing/pricing.md",72797],ccc49370:[()=>Promise.all([n.e(1869),n.e(3224),n.e(8544),n.e(3249)]).then(n.bind(n,84029)),"@theme/BlogPostPage",84029],ceb5ae55:[()=>n.e(2992).then(n.bind(n,74285)),"@site/docs/about/about.md",74285],d05ec3cd:[()=>n.e(8538).then(n.bind(n,77861)),"@site/docs/solutions/ai-pc.md",77861],d1a98e8c:[()=>n.e(5250).then(n.bind(n,71520)),"@site/docs/server-suite/home-server.md",71520],d63d6a03:[()=>n.e(7435).then(n.bind(n,81149)),"@site/docs/features/features.md",81149],d6d14160:[()=>Promise.all([n.e(1869),n.e(747)]).then(n.bind(n,38270)),"@site/docs/guides/user-guides/advanced-settings.mdx",38270],d8ca778a:[()=>n.e(5488).then(n.bind(n,69564)),"@site/docs/developer/05-framework/03-engineering/models.md",69564],da5da385:[()=>n.e(5460).then(n.bind(n,62913)),"@site/docs/acknowledgements.md",62913],dabe0364:[()=>n.e(7572).then(n.bind(n,62574)),"@site/docs/pending-content/blogpost/finetune-with-docs.mdx",62574],dae9d1a4:[()=>n.e(8246).then(n.bind(n,29231)),"@site/docs/solutions/consultants.md",29231],db6d369b:[()=>Promise.all([n.e(1869),n.e(4401)]).then(n.bind(n,83818)),"@site/docs/guides/remote-providers/README.mdx",83818],db7de07b:[()=>n.e(6100).then(n.bind(n,22787)),"@site/docs/releases/changelog/changelog-v0.2.2.mdx",22787],dbb31ac1:[()=>n.e(5406).then(n.bind(n,97804)),"@site/docs/developer/01-overview/03-user-interface.md",97804],dc051efd:[()=>n.e(8429).then(n.bind(n,21999)),"@site/docs/developer/05-framework/03-engineering/chats.md",21999],dc1725da:[()=>n.e(1722).then(n.bind(n,40446)),"@site/docs/platforms/hub.md",40446],dcb95049:[()=>n.e(789).then(n.t.bind(n,91839,19)),"~docs/default/tag-tags-customzied-dataset-73e.json",91839],df203c0f:[()=>Promise.all([n.e(1869),n.e(4279)]).then(n.bind(n,45921)),"@theme/DocTagDocListPage",45921],dfd62110:[()=>n.e(6895).then(n.bind(n,68868)),"@site/docs/pending-content/blogpost/02-surpassing-chatgpt-with-open-source-alternatives.mdx",68868],e0f6d58a:[()=>n.e(252).then(n.bind(n,12050)),"@site/docs/developer/05-framework/03-engineering/messages.md",12050],e268956d:[()=>n.e(8792).then(n.bind(n,55571)),"@site/docs/how-we-work/project-management/project-management.md",55571],e42e4cd9:[()=>n.e(3221).then(n.bind(n,66129)),"@site/docs/developer/05-framework/03-product/jan.md",66129],e5189f58:[()=>n.e(8052).then(n.t.bind(n,29575,19)),"~blog/default/blog-tags-inference-engine-9a1-list.json",29575],e6eb8051:[()=>n.e(4873).then(n.bind(n,12612)),"@site/docs/integrations/llamacpp.md",12612],e729be38:[()=>n.e(2346).then(n.bind(n,70084)),"@site/docs/hardware/concepts/motherboard.md",70084],e741274a:[()=>n.e(2862).then(n.bind(n,1779)),"@site/docs/developer/05-framework/03-product/settings.md",1779],e7a8e166:[()=>n.e(9086).then(n.bind(n,48335)),"@site/docs/guides/get-started/hardware-setup.mdx",48335],e7e7ea54:[()=>n.e(294).then(n.bind(n,10570)),"@site/docs/team/contributor-program.md",10570],e8493339:[()=>n.e(411).then(n.bind(n,21555)),"@site/docs/how-we-work.md",21555],e866b055:[()=>n.e(700).then(n.bind(n,86553)),"@site/docs/how-we-work/product-design/product-design.md",86553],e90db391:[()=>n.e(9982).then(n.bind(n,74643)),"@site/docs/guides/user-guides/local-server.mdx",74643],e98001e4:[()=>n.e(5299).then(n.bind(n,59938)),"@site/docs/solutions/government.md",59938],eae9547a:[()=>n.e(3068).then(n.bind(n,50661)),"@site/docs/releases/changelog/changelog-v0.3.1.mdx",50661],eaf63638:[()=>n.e(7883).then(n.bind(n,72405)),"@site/docs/features/agents-framework.md",72405],eb428099:[()=>Promise.all([n.e(1869),n.e(6206)]).then(n.bind(n,98492)),"@site/docs/releases/changelog/README.mdx",98492],ef786345:[()=>Promise.all([n.e(1869),n.e(1315)]).then(n.bind(n,41158)),"@site/docs/guides/get-started/quickstart.mdx",41158],f078801c:[()=>n.e(8740).then(n.bind(n,25526)),"@site/docs/guides/remote-providers/openai.mdx",25526],f08c2896:[()=>n.e(5625).then(n.t.bind(n,94062,19)),"~docs/default/tag-tags-large-language-models-feb.json",94062],f0ad3fbb:[()=>Promise.all([n.e(1869),n.e(9746),n.e(5869),n.e(5350)]).then(n.bind(n,55869)),"@theme/ApiDoc",55869],f0ba8d54:[()=>n.e(825).then(n.bind(n,40516)),"@site/docs/developer/01-overview/02-file-based.md",40516],f0fd40ad:[()=>n.e(776).then(n.bind(n,58890)),"@site/docs/solutions/healthcare.md",58890],f15f6e84:[()=>Promise.all([n.e(9660),n.e(7846)]).then(n.bind(n,380)),"@site/src/pages/download.js",380],f1cabb85:[()=>n.e(6369).then(n.bind(n,94575)),"@site/docs/developer/05-framework/03-engineering/files.md",94575],f25ab7b5:[()=>n.e(6915).then(n.bind(n,63785)),"@site/docs/releases/changelog/changelog-v0.4.6.mdx",63785],f274275e:[()=>n.e(1965).then(n.bind(n,2295)),"@site/docs/guides/inference/overview-inference.mdx",2295],f4e1c670:[()=>n.e(9625).then(n.bind(n,18321)),"@site/docs/releases/changelog/changelog-v0.2.0.mdx",18321],f5765423:[()=>n.e(5689).then(n.bind(n,14936)),"@site/docs/server-suite/audit-compliance.md",14936],f6a98bad:[()=>n.e(2784).then(n.t.bind(n,1279,19)),"~blog/default/blog-tags-tensor-rt-llm-f4d.json",1279],f6d5df20:[()=>n.e(5106).then(n.bind(n,442)),"@site/docs/hardware/community.md",442],f75920de:[()=>n.e(4803).then(n.bind(n,63232)),"@site/docs/releases/changelog/changelog-v0.4.3.mdx",63232],f7b6804f:[()=>n.e(1908).then(n.bind(n,40417)),"@site/docs/guides/integrations/router.mdx",40417],f7cb2fe9:[()=>n.e(4951).then(n.bind(n,49946)),"@site/docs/guides/get-started/overview.mdx",49946],f81759f7:[()=>n.e(2725).then(n.bind(n,70042)),"@site/docs/releases/changelog/changelog-v0.4.1.mdx",70042],f8bfd07c:[()=>n.e(231).then(n.bind(n,60192)),"@site/docs/hardware/concepts/concepts.md",60192],f9a6fee3:[()=>n.e(6222).then(n.bind(n,97546)),"@site/docs/releases/changelog/changelog-v0.3.2.mdx",97546],fece9508:[()=>n.e(5094).then(n.bind(n,16891)),"@site/docs/integrations.md",16891],ff5e07c6:[()=>n.e(5697).then(n.bind(n,43018)),"@site/docs/guides/integrations/interpreter.mdx",43018]};var i=n(74848);function l(e){let{error:t,retry:n,pastDelay:r}=e;return t?(0,i.jsxs)("div",{style:{textAlign:"center",color:"#fff",backgroundColor:"#fa383e",borderColor:"#fa383e",borderStyle:"solid",borderRadius:"0.25rem",borderWidth:"1px",boxSizing:"border-box",display:"block",padding:"1rem",flex:"0 0 50%",marginLeft:"25%",marginRight:"25%",marginTop:"5rem",maxWidth:"50%",width:"100%"},children:[(0,i.jsx)("p",{children:String(t)}),(0,i.jsx)("div",{children:(0,i.jsx)("button",{type:"button",onClick:n,children:"Retry"})})]}):r?(0,i.jsx)("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:(0,i.jsx)("svg",{id:"loader",style:{width:128,height:110,position:"absolute",top:"calc(100vh - 64%)"},viewBox:"0 0 45 45",xmlns:"http://www.w3.org/2000/svg",stroke:"#61dafb",children:(0,i.jsxs)("g",{fill:"none",fillRule:"evenodd",transform:"translate(1 1)",strokeWidth:"2",children:[(0,i.jsxs)("circle",{cx:"22",cy:"22",r:"6",strokeOpacity:"0",children:[(0,i.jsx)("animate",{attributeName:"r",begin:"1.5s",dur:"3s",values:"6;22",calcMode:"linear",repeatCount:"indefinite"}),(0,i.jsx)("animate",{attributeName:"stroke-opacity",begin:"1.5s",dur:"3s",values:"1;0",calcMode:"linear",repeatCount:"indefinite"}),(0,i.jsx)("animate",{attributeName:"stroke-width",begin:"1.5s",dur:"3s",values:"2;0",calcMode:"linear",repeatCount:"indefinite"})]}),(0,i.jsxs)("circle",{cx:"22",cy:"22",r:"6",strokeOpacity:"0",children:[(0,i.jsx)("animate",{attributeName:"r",begin:"3s",dur:"3s",values:"6;22",calcMode:"linear",repeatCount:"indefinite"}),(0,i.jsx)("animate",{attributeName:"stroke-opacity",begin:"3s",dur:"3s",values:"1;0",calcMode:"linear",repeatCount:"indefinite"}),(0,i.jsx)("animate",{attributeName:"stroke-width",begin:"3s",dur:"3s",values:"2;0",calcMode:"linear",repeatCount:"indefinite"})]}),(0,i.jsx)("circle",{cx:"22",cy:"22",r:"8",children:(0,i.jsx)("animate",{attributeName:"r",begin:"0s",dur:"1.5s",values:"6;1;2;3;4;5;6",calcMode:"linear",repeatCount:"indefinite"})})]})})}):null}var c=n(86921),u=n(53102);function d(e,t){if("*"===e)return a()({loading:l,loader:()=>n.e(2237).then(n.bind(n,82237)),modules:["@theme/NotFound"],webpack:()=>[82237],render(e,t){const n=e.default;return(0,i.jsx)(u.W,{value:{plugin:{name:"native",id:"default"}},children:(0,i.jsx)(n,{...t})})}});const r=o[`${e}-${t}`],d={},p=[],f=[],m=(0,c.A)(r);return Object.entries(m).forEach((e=>{let[t,n]=e;const r=s[n];r&&(d[t]=r[0],p.push(r[1]),f.push(r[2]))})),a().Map({loading:l,loader:d,modules:p,webpack:()=>f,render(t,n){const a=JSON.parse(JSON.stringify(r));Object.entries(t).forEach((t=>{let[n,r]=t;const o=r.default;if(!o)throw new Error(`The page component at ${e} doesn't have a default export. This makes it impossible to render anything. Consider default-exporting a React component.`);"object"!=typeof o&&"function"!=typeof o||Object.keys(r).filter((e=>"default"!==e)).forEach((e=>{o[e]=r[e]}));let s=a;const i=n.split(".");i.slice(0,-1).forEach((e=>{s=s[e]})),s[i[i.length-1]]=o}));const o=a.__comp;delete a.__comp;const s=a.__context;return delete a.__context,(0,i.jsx)(u.W,{value:s,children:(0,i.jsx)(o,{...a,...n})})}})}const p=[{path:"/api-reference-1.0/",component:d("/api-reference-1.0/","88a"),exact:!0},{path:"/api-reference/",component:d("/api-reference/","2a9"),exact:!0,configuration:{spec:{content:{openapi:"3.0.0",info:{title:"API Reference",description:"# Introduction\nJan API is compatible with the [OpenAI API](https://platform.openai.com/docs/api-reference).\n",version:"0.1.8",contact:{name:"Jan Discord",url:"https://discord.gg/7EcEz7MrvA"},license:{name:"AGPLv3",url:"https://github.com/janhq/nitro/blob/main/LICENSE"}},servers:[{url:"http://localhost:1337/v1"}],tags:[{name:"Models",description:"List and describe the various models available in the API."},{name:"Chat",description:"Given a list of messages comprising a conversation, the model will return a response.\n"},{name:"Messages",description:"Messages capture a conversation's content. This can include the content from LLM responses and other metadata from [chat completions](/specs/chats).\n"},{name:"Threads"},{name:"Assistants",description:"Configures and utilizes different AI assistants for varied tasks"}],"x-tagGroups":[{name:"Endpoints",tags:["Models","Chat"]},{name:"Chat",tags:["Assistants","Messages","Threads"]}],paths:{"/chat/completions":{post:{operationId:"createChatCompletion",tags:["Chat"],summary:"Create chat completion\n",description:'Creates a model response for the given chat conversation. Equivalent to OpenAI\'s create chat completion. \n',requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/ChatCompletionRequest"}}}},responses:{200:{description:"OK",content:{"application/json":{schema:{$ref:"#/components/schemas/ChatCompletionResponse"}}}}}}},"/models":{get:{operationId:"listModels",tags:["Models"],summary:"List models",description:'Lists the currently available models, and provides basic information about each one such as the owner and availability. Equivalent to OpenAI\'s list model. \n',responses:{200:{description:"OK",content:{"application/json":{schema:{$ref:"#/components/schemas/ListModelsResponse"}}}}}}},"/models/download/{model_id}":{get:{operationId:"downloadModel",tags:["Models"],summary:"Download a specific model.",description:"Download a model.\n",parameters:[{in:"path",name:"model_id",required:!0,schema:{type:"string",example:"mistral-ins-7b-q4"},description:"The ID of the model to use for this request.\n"}],responses:{200:{description:"OK",content:{"application/json":{schema:{$ref:"#/components/schemas/DownloadModelResponse"}}}}}}},"/models/{model_id}":{get:{operationId:"retrieveModel",tags:["Models"],summary:"Retrieve model",description:'Get a model instance, providing basic information about the model such as the owner and permissioning. Equivalent to OpenAI\'s retrieve model. \n',parameters:[{in:"path",name:"model_id",required:!0,schema:{type:"string",example:"mistral-ins-7b-q4"},description:"The ID of the model to use for this request.\n"}],responses:{200:{description:"OK",content:{"application/json":{schema:{$ref:"#/components/schemas/GetModelResponse"}}}}}},delete:{operationId:"deleteModel",tags:["Models"],summary:"Delete model",description:'Delete a model. Equivalent to OpenAI\'s delete model. \n',parameters:[{in:"path",name:"model_id",required:!0,schema:{type:"string",example:"mistral-ins-7b-q4"},description:"The model id to delete\n"}],responses:{200:{description:"OK",content:{"application/json":{schema:{$ref:"#/components/schemas/DeleteModelResponse"}}}}}}},"/threads":{post:{operationId:"createThread",tags:["Threads"],summary:"Create thread",description:'Create a thread. Equivalent to OpenAI\'s create thread. \n',requestBody:{required:!1,content:{"application/json":{schema:{$ref:"#/components/schemas/CreateThreadObject"}}}},responses:{200:{description:"Thread created successfully",content:{"application/json":{schema:{$ref:"#/components/schemas/CreateThreadResponse"}}}}}},get:{operationId:"listThreads",tags:["Threads"],summary:"List threads",description:"Retrieves a list of all threads available in the system.\n",responses:{200:{description:"List of threads retrieved successfully",content:{"application/json":{schema:{type:"array",items:{$ref:"#/components/schemas/ThreadObject"},example:[{id:"thread_abc123",object:"thread",created_at:1699014083,assistants:["assistant-001"],metadata:{},messages:[]},{id:"thread_abc456",object:"thread",created_at:1699014083,assistants:["assistant-002","assistant-003"],metadata:{}}]}}}}}}},"/threads/{thread_id}":{get:{operationId:"getThread",tags:["Threads"],summary:"Retrieve thread",description:'Retrieves detailed information about a specific thread using its thread_id. Equivalent to OpenAI\'s retrieve thread. \n',parameters:[{in:"path",name:"thread_id",required:!0,schema:{type:"string"},description:"The ID of the thread to retrieve.\n"}],responses:{200:{description:"Thread details retrieved successfully",content:{"application/json":{schema:{$ref:"#/components/schemas/GetThreadResponse"}}}}}},patch:{operationId:"modifyThread",tags:["Threads"],summary:"Modify thread",description:'Modifies a thread. Equivalent to OpenAI\'s modify thread. \n',parameters:[{in:"path",name:"thread_id",required:!0,schema:{type:"string"},description:"The ID of the thread to be modified.\n"}],requestBody:{required:!0,content:{"application/json":{schema:{type:"object",properties:{title:{type:"string",description:"Set the title of the thread",items:{$ref:"#/components/schemas/ThreadMessageObject"}}}}}}},responses:{200:{description:"Thread modified successfully",content:{"application/json":{schema:{$ref:"#/components/schemas/ModifyThreadResponse"}}}}}},delete:{operationId:"deleteThread",tags:["Threads"],summary:"Delete thread",description:'Delete a thread. Equivalent to OpenAI\'s delete thread. \n',parameters:[{in:"path",name:"thread_id",required:!0,schema:{type:"string"},description:"The ID of the thread to be deleted.\n"}],responses:{200:{description:"Thread deleted successfully",content:{"application/json":{schema:{$ref:"#/components/schemas/DeleteThreadResponse"}}}}}}},"/assistants":{get:{operationId:"listAssistants",tags:["Assistants"],summary:"List assistants",description:'Return a list of assistants. Equivalent to OpenAI\'s list assistants. \n',responses:{200:{description:"List of assistants retrieved successfully",content:{"application/json":{schema:{type:"array",items:{type:"object",properties:{id:{type:"string"},object:{type:"string"},version:{type:"integer"},created_at:{type:"integer"},name:{type:"string"},description:{type:"string"},avatar:{type:"string",format:"uri"},models:{type:"array",items:{type:"object",properties:{model_id:{type:"string"}}}},instructions:{type:"string"},events:{type:"object",properties:{in:{type:"array",items:{}},out:{type:"array",items:{}}}},metadata:{type:"object"},"x-codeSamples":{type:"object",properties:{cURL:{type:"object",properties:{lang:{type:"string",example:"cURL"},source:{type:"string",example:'curl http://localhost:1337/v1/assistants \\\n -H "Content-Type: application/json"\n'}}},JavaScript:{type:"object",properties:{lang:{type:"string",example:"JavaScript"},source:{type:"string",example:"fetch('http://localhost:1337/v1/assistants', {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json'\n }\n})\n"}}},"Node.js":{type:"object",properties:{lang:{type:"string",example:"Node.js"},source:{type:"string",example:"const fetch = require('node-fetch');\n\nfetch('http://localhost:1337/v1/assistants', {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json'\n }\n})\n"}}},Python:{type:"object",properties:{lang:{type:"string",example:"Python"},source:{type:"string",example:"import requests\n\nurl = 'http://localhost:1337/v1/assistants'\nheaders = {'Content-Type': 'application/json'}\n\nresponse = requests.get(url, headers=headers)\n"}}}}}}}}}}}}}},"/assistants/{assistant_id}":{get:{operationId:"getAssistant",tags:["Assistants"],summary:"Retrieve assistant",description:'Retrieves an assistant. Equivalent to OpenAI\'s retrieve assistants. \n',parameters:[{in:"path",name:"assistant_id",required:!0,schema:{type:"string",example:"jan"},description:"The ID of the assistant to retrieve.\n"}],responses:{200:{description:"string",content:{"application/json":{schema:{$ref:"#/components/schemas/RetrieveAssistantResponse"}}}}}}},"/threads/{thread_id}/messages":{get:{operationId:"listMessages",tags:["Messages"],summary:"List messages",description:'Retrieves all messages from the given thread. Equivalent to OpenAI\'s list messages. \n',parameters:[{in:"path",name:"thread_id",required:!0,schema:{type:"string"},description:"The ID of the thread from which to retrieve messages.\n"}],responses:{200:{description:"List of messages retrieved successfully",content:{"application/json":{schema:{$ref:"#/components/schemas/ListMessagesResponse"}}}}}},post:{operationId:"createMessage",tags:["Messages"],summary:"Create message",description:'Create a message. Equivalent to OpenAI\'s list messages. \n',parameters:[{in:"path",name:"thread_id",required:!0,schema:{type:"string"},description:"The ID of the thread to which the message will be posted.\n"}],requestBody:{required:!0,content:{"application/json":{schema:{type:"object",properties:{role:{type:"string",description:"Role of the sender, either 'user' or 'assistant'.\n",example:"user",enum:["user","assistant"]},content:{type:"string",description:"Text content of the message.\n",example:"How does AI work? Explain it in simple terms."}},required:["role","content"]}}}},responses:{200:{description:"Message created successfully",content:{"application/json":{schema:{$ref:"#/components/schemas/CreateMessageResponse"}}}}}}},"/threads/{thread_id}/messages/{message_id}":{get:{operationId:"retrieveMessage",tags:["Messages"],summary:"Retrieve message",description:'Retrieve a specific message from a thread using its thread_id and message_id. Equivalent to OpenAI\'s retrieve messages. \n',parameters:[{in:"path",name:"thread_id",required:!0,schema:{type:"string"},description:"The ID of the thread containing the message.\n"},{in:"path",name:"message_id",required:!0,schema:{type:"string"},description:"The ID of the message to retrieve.\n"}],responses:{200:{description:"OK",content:{"application/json":{schema:{$ref:"#/components/schemas/GetMessageResponse"}}}}}}}},"x-webhooks":{ModelObject:{post:{summary:"The model object",description:'Describe a model offering that can be used with the API. Equivalent to OpenAI\'s model object. \n',operationId:"ModelObject",tags:["Models"],requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/ModelObject"}}}}}},AssistantObject:{post:{summary:"The assistant object",description:'Build assistants that can call models and use tools to perform tasks. Equivalent to OpenAI\'s assistants object. \n',operationId:"AssistantObjects",tags:["Assistants"],requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/AssistantObject"}}}}}},MessageObject:{post:{summary:"The message object",description:'Information about a message in the thread. Equivalent to OpenAI\'s message object. \n',operationId:"MessageObject",tags:["Messages"],requestBody:{content:{"application/json":{schema:{$ref:null}}}}}},ThreadObject:{post:{summary:"The thread object",description:'Represents a thread that contains messages. Equivalent to OpenAI\'s thread object. ',operationId:"ThreadObject",tags:["Threads"],requestBody:{content:{"application/json":{schema:{$ref:null}}}}}}},components:{schemas:{ThreadObject:{type:"object",properties:{id:{type:"string",description:"The identifier of the thread, defaults to foldername.\n",example:"thread_...."},object:{type:"string",description:"Type of the object, defaults to thread.\n",example:"thread"},title:{type:"string",description:"A brief summary or description of the thread, defaults to an empty string.\n",example:"funny physics joke"},assistants:{type:"array",description:"",items:{properties:{assistant_id:{type:"string",description:'The identifier of assistant, defaults to "jan"\n',example:"jan"},model:{type:"object",properties:{id:{type:"string",description:"",example:"..."},settings:{type:"object",description:'Defaults to and overrides assistant.json\'s "settings" (and if none, then model.json "settings")\n'},parameters:{type:"object",description:'Defaults to and overrides assistant.json\'s "parameters" (and if none, then model.json "parameters")\n'}}}}}},created:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the thread, defaults to file creation time.\n",example:1231231},metadata:{type:"object",description:"Metadata associated with the thread, defaults to an empty object.\n",example:{}}}},GetThreadResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the thread.",example:"thread_abc123"},object:{type:"string",description:"Type of the object",example:"thread"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the thread.",example:1699014083},assistants:{type:"array",items:{type:"string"},description:"List of assistants involved in the thread.",example:["assistant-001"]},metadata:{type:"object",description:"Metadata associated with the thread.",example:{}},messages:{type:"array",items:{type:"string"},description:"List of messages within the thread.",example:[]}}},CreateThreadResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the newly created thread.",example:"thread_abc123"},object:{type:"string",description:"Type of the object, indicating it's a thread.",example:"thread"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the thread.",example:1699014083},metadata:{type:"object",description:"Metadata associated with the newly created thread.",example:{}}}},CreateThreadObject:{type:"object",properties:{object:{type:"string",description:"Type of the object, indicating it's a thread.",example:"thread"},title:{type:"string",description:"A brief summary or description of the thread, defaults to an empty string.\n",example:"funny physics joke"},assistants:{type:"array",description:"assistant involved in the thread",items:{properties:{assistant_id:{type:"string",description:'The identifier of assistant, defaults to "jan"\n',example:"jan"},assistant_name:{type:"string",description:'The name of assistant, defaults to "Jan"\n',example:"Jan"},instructions:{type:"string",description:'The instruction of assistant, defaults to "Be my grammar corrector"\n'},model:{type:"object",properties:{id:{type:"string",description:"Model id",example:"mistral-ins-7b-q4"},settings:{type:"object",description:'Defaults to and overrides assistant.json\'s "settings" (and if none, then model.json "settings")\n'},parameters:{type:"object",description:'Defaults to and overrides assistant.json\'s "parameters" (and if none, then model.json "parameters")\n'},engine:{type:"string",description:"Engine id",example:"nitro"}}}}}},metadata:{type:"object",description:"Metadata associated with the thread, defaults to an empty object.\n"}}},ThreadMessageObject:{type:"object",properties:{role:{type:"string",description:"\"Role of the sender, either 'user' or 'assistant'.\"\n",enum:["user","assistant"]},content:{type:"string",description:'"Text content of the message."\n'},file_ids:{type:"array",items:{type:"string"},description:'"Array of file IDs associated with the message, if any."\n'}}},ModifyThreadResponse:{type:"object",properties:{id:{type:"string",description:'"The identifier of the modified thread."\n',example:"thread_abc123"},object:{type:"string",description:"Type of the object, indicating it's a thread.",example:"thread"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the thread.",example:1699014083},metadata:{type:"object",description:"Metadata associated with the modified thread.",example:{}}}},DeleteThreadResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the deleted thread.",example:"thread_abc123"},object:{type:"string",description:"Type of the object, indicating the thread has been deleted.",example:"thread.deleted"},deleted:{type:"boolean",description:"Indicates whether the thread was successfully deleted.",example:!0}}},ListModelsResponse:{type:"object",properties:{object:{type:"string",enum:["list"]},data:{type:"array",items:{$ref:"#/components/schemas/Model"}}},required:["object","data"]},Model:{type:"object",properties:{source_url:{type:"string",format:"uri",description:"URL to the source of the model.",example:"https://huggingface.co/janhq/trinity-v1.2-GGUF/resolve/main/trinity-v1.2.Q4_K_M.gguf"},id:{type:"string",description:"Unique identifier used in chat-completions model_name, matches folder name.",example:"trinity-v1.2-7b"},object:{type:"string",example:"model"},name:{type:"string",description:"Name of the model.",example:"Trinity-v1.2 7B Q4"},version:{type:"string",default:"1.0",description:"The version number of the model."},description:{type:"string",description:"Description of the model.",example:"Trinity is an experimental model merge using the Slerp method. Recommended for daily assistance purposes."},format:{type:"string",description:"State format of the model, distinct from the engine.",example:"gguf"},settings:{type:"object",properties:{ctx_len:{type:"integer",description:"Context length.",example:4096},prompt_template:{type:"string",example:"<|im_start|>system\n{system_message}<|im_end|>\n<|im_start|>user\n{prompt}<|im_end|>\n<|im_start|>assistant"}},additionalProperties:!1},parameters:{type:"object",properties:{temperature:{example:.7},top_p:{example:.95},stream:{example:!0},max_tokens:{example:4096},stop:{example:[]},frequency_penalty:{example:0},presence_penalty:{example:0}},additionalProperties:!1},metadata:{type:"object",properties:{author:{type:"string",example:"Jan"},tags:{type:"array",items:{type:"string"},example:["7B","Merged","Featured"]},size:{type:"integer",example:437e7},cover:{type:"string",format:"uri",example:"https://raw.githubusercontent.com/janhq/jan/main/models/trinity-v1.2-7b/cover.png"}},additionalProperties:!1},engine:{example:"nitro"}}},ModelObject:{type:"object",properties:{id:{type:"string",description:"The identifier of the model.\n",example:"trinity-v1.2-7b"},object:{type:"string",description:"The type of the object, indicating it's a model.\n",default:"model"},created:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the model.\n",example:1253935178},owned_by:{type:"string",description:"The entity that owns the model.\n",example:"_"}}},GetModelResponse:{type:"object",properties:{source_url:{type:"string",format:"uri",description:"URL to the source of the model.",example:"https://huggingface.co/TheBloke/Mistral-7B-Instruct-v0.2-GGUF/resolve/main/mistral-7b-instruct-v0.2.Q4_K_M.gguf"},id:{type:"string",description:"Unique identifier used in chat-completions model_name, matches folder name.",example:"mistral-ins-7b-q4"},object:{type:"string",example:"model"},name:{type:"string",description:"Name of the model.",example:"Mistral Instruct 7B Q4"},version:{type:"string",default:"1.0",description:"The version number of the model."},description:{type:"string",description:"Description of the model.",example:"Trinity is an experimental model merge using the Slerp method. Recommended for daily assistance purposes."},format:{type:"string",description:"State format of the model, distinct from the engine.",example:"gguf"},settings:{type:"object",properties:{ctx_len:{type:"integer",description:"Context length.",example:4096},prompt_template:{type:"string",example:"[INST] {prompt} [/INST]"}},additionalProperties:!1},parameters:{type:"object",properties:{temperature:{example:.7},top_p:{example:.95},stream:{example:!0},max_tokens:{example:4096},stop:{example:[]},frequency_penalty:{example:0},presence_penalty:{example:0}},additionalProperties:!1},metadata:{type:"object",properties:{author:{type:"string",example:"MistralAI"},tags:{type:"array",items:{type:"string"},example:["7B","Featured","Foundation Model"]},size:{example:437e7,type:"integer"},cover:{example:"https://raw.githubusercontent.com/janhq/jan/main/models/mistral-ins-7b-q4/cover.png",type:"string"}},additionalProperties:!1},engine:{example:"nitro"}}},DeleteModelResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the model that was deleted.",example:"mistral-ins-7b-q4"},object:{type:"string",description:"Type of the object, indicating it's a model.",default:"model"},deleted:{type:"boolean",description:"Indicates whether the model was successfully deleted.",example:!0}}},StartModelResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the model that was started.",example:"model-zephyr-7B"},object:{type:"string",description:"Type of the object, indicating it's a model.",default:"model"},state:{type:"string",description:"The current state of the model after the start operation.",example:"running"}},required:["id","object","state"]},StopModelResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the model that was started.",example:"model-zephyr-7B"},object:{type:"string",description:"Type of the object, indicating it's a model.",default:"model"},state:{type:"string",description:"The current state of the model after the start operation.",example:"stopped"}},required:["id","object","state"]},DownloadModelResponse:{type:"object",properties:{message:{type:"string",description:"Message indicates Jan starting download corresponding model.",example:"Starting download mistral-ins-7b-q4"}}},MessageObject:{type:"object",properties:{id:{type:"string",description:"Sequential or UUID identifier of the message.\n",example:0},object:{type:"string",description:"Type of the object, defaults to 'thread.message'.\n",example:"thread.message"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the message.\n"},thread_id:{type:"string",description:"Identifier of the thread to which this message belongs. Defaults to parent thread.\n",example:"thread_asdf"},assistant_id:{type:"string",description:"Identifier of the assistant involved in the message. Defaults to parent thread.\n",example:"jan"},role:{type:"string",enum:["user","assistant"],description:"Role of the sender, either 'user' or 'assistant'.\n"},content:{type:"array",items:{type:"object",properties:{type:{type:"string",description:"Type of content, e.g., 'text'.\n"},text:{type:"object",properties:{value:{type:"string",description:"Text content of the message.\n",example:"Hi!?"},annotations:{type:"array",items:{type:"string"},description:"Annotations for the text content, if any.\n",example:[]}}}}}},metadata:{type:"object",description:"Metadata associated with the message, defaults to an empty object.\n",example:{}}}},GetMessageResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the message.",example:"msg_abc123"},object:{type:"string",description:"Type of the object, indicating it's a thread message.",default:"thread.message"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the message.",example:1699017614},thread_id:{type:"string",description:"Identifier of the thread to which this message belongs.",example:"thread_abc123"},role:{type:"string",description:"Role of the sender, either 'user' or 'assistant'.",example:"user"},content:{type:"array",items:{type:"object",properties:{type:{type:"string",description:"Type of content, e.g., 'text'.",example:"text"},text:{type:"object",properties:{value:{type:"string",description:"Text content of the message.",example:"How does AI work? Explain it in simple terms."},annotations:{type:"array",items:{type:"string"},description:"Annotations for the text content, if any.",example:[]}}}}}},file_ids:{type:"array",items:{type:"string"},description:"Array of file IDs associated with the message, if any.",example:[]},assistant_id:{type:"string",description:"Identifier of the assistant involved in the message, if applicable.",example:null},run_id:{type:"string",description:"Run ID associated with the message, if applicable.",example:null},metadata:{type:"object",description:"Metadata associated with the message.",example:{}}}},CreateMessageResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the created message.",example:"msg_abc123"},object:{type:"string",description:"Type of the object, indicating it's a thread message.",example:"thread.message"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the message.",example:1699017614},thread_id:{type:"string",description:"Identifier of the thread to which this message belongs.",example:"thread_abc123"},role:{type:"string",description:"Role of the sender, either 'user' or 'assistant'.",example:"user"},content:{type:"array",items:{type:"object",properties:{type:{type:"string",description:"Type of content, e.g., 'text'.",example:"text"},text:{type:"object",properties:{value:{type:"string",description:"Text content of the message.",example:"How does AI work? Explain it in simple terms."},annotations:{type:"array",items:{type:"string"},description:"Annotations for the text content, if any.",example:[]}}}}}},file_ids:{type:"array",items:{type:"string"},description:"Array of file IDs associated with the message, if any.",example:[]},assistant_id:{type:"string",description:"Identifier of the assistant involved in the message, if applicable.",example:null},run_id:{type:"string",description:"Run ID associated with the message, if applicable.",example:null},metadata:{type:"object",description:"Metadata associated with the message.",example:{}}}},ListMessagesResponse:{type:"object",properties:{object:{type:"string",description:"Type of the object, indicating it's a list.",default:"list"},data:{type:"array",items:{$ref:"#/components/schemas/ListMessageObject"}},first_id:{type:"string",description:"Identifier of the first message in the list.",example:"msg_abc123"},last_id:{type:"string",description:"Identifier of the last message in the list.",example:"msg_abc456"},has_more:{type:"boolean",description:"Indicates whether there are more messages to retrieve.",example:!1}}},ListMessageObject:{type:"object",properties:{id:{type:"string",description:"The identifier of the message.",example:"msg_abc123"},object:{type:"string",description:"Type of the object, indicating it's a thread message.",example:"thread.message"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the message.",example:1699017614},thread_id:{type:"string",description:"Identifier of the thread to which this message belongs.",example:"thread_abc123"},role:{type:"string",description:"Role of the sender, either 'user' or 'assistant'.",example:"user"},content:{type:"array",items:{type:"object",properties:{type:{type:"string",description:"Type of content, e.g., 'text'."},text:{type:"object",properties:{value:{type:"string",description:"Text content of the message.",example:"How does AI work? Explain it in simple terms."},annotations:{type:"array",items:{type:"string"},description:"Annotations for the text content, if any."}}}}}},file_ids:{type:"array",items:{type:"string"},description:"Array of file IDs associated with the message, if any.",example:[]},assistant_id:{type:"string",description:"Identifier of the assistant involved in the message, if applicable.",example:null},run_id:{type:"string",description:"Run ID associated with the message, if applicable.",example:null},metadata:{type:"object",description:"Metadata associated with the message.",example:{}}}},MessageFileObject:{type:"object",properties:{id:{type:"string",description:"The identifier of the file.",example:"file-abc123"},object:{type:"string",description:"Type of the object, indicating it's a thread message file.",example:"thread.message.file"},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the file.",example:1699061776},message_id:{type:"string",description:"Identifier of the message to which this file is associated.",example:"msg_abc123"}}},ListMessageFilesResponse:{type:"object",properties:{object:{type:"string",description:"Type of the object, indicating it's a list.",default:"list"},data:{type:"array",items:{$ref:"#/components/schemas/MessageFileObject"}}}},ChatObject:{type:"object",properties:{messages:{type:"array",description:"Contains input data or prompts for the model to process.\n",items:{type:"object",properties:{content:{type:"string"},role:{type:"string"}}},example:[{content:"Hello there :wave:",role:"assistant"},{content:"Can you write a long story",role:"user"}]},stream:{type:"boolean",default:!0,description:"Enables continuous output generation, allowing for streaming of model responses."},model:{type:"string",example:"gpt-3.5-turbo",description:"Specifies the model being used for inference or processing tasks."},max_tokens:{type:"number",default:2048,description:"The maximum number of tokens the model will generate in a single response."},stop:{type:"array",items:{type:"string"},description:"Defines specific tokens or phrases at which the model will stop generating further output.",example:["hello"]},frequency_penalty:{type:"number",default:0,description:"Adjusts the likelihood of the model repeating words or phrases in its output."},presence_penalty:{type:"number",default:0,description:"Influences the generation of new and varied concepts in the model's output."},temperature:{type:"number",default:.7,description:"Controls the randomness of the model's output."},top_p:{type:"number",default:.95,description:"Set probability threshold for more relevant outputs."},cache_prompt:{type:"boolean",default:!0,description:"Optimize performance in repeated or similar requests."}}},ChatCompletionRequest:{type:"object",properties:{messages:{type:"array",description:"Contains input data or prompts for the model to process.\n",items:{type:"object",properties:{content:{type:"string"},role:{type:"string"}}},example:[{content:"You are a helpful assistant.",role:"system"},{content:"Hello!",role:"user"}]},model:{type:"string",example:"tinyllama-1.1b",description:"Specifies the model being used for inference or processing tasks.\n"},stream:{type:"boolean",default:!0,description:"Enables continuous output generation, allowing for streaming of model responses.\n"},max_tokens:{type:"number",default:2048,description:"The maximum number of tokens the model will generate in a single response.\n"},stop:{type:"array",items:{type:"string"},description:"Defines specific tokens or phrases at which the model will stop generating further output.\n",example:["hello"]},frequency_penalty:{type:"number",default:0,description:"Adjusts the likelihood of the model repeating words or phrases in its output.\n"},presence_penalty:{type:"number",default:0,description:"Influences the generation of new and varied concepts in the model's output.\n"},temperature:{type:"number",default:.7,description:"Controls the randomness of the model's output.\n"},top_p:{type:"number",default:.95,description:"Set probability threshold for more relevant outputs.\n"}}},ChatCompletionResponse:{type:"object",description:"Description of the response structure",properties:{choices:{type:"array",description:"Array of choice objects",items:{type:"object",properties:{finish_reason:{type:"string",nullable:!0,example:null,description:"Reason for finishing the response, if applicable"},index:{type:"integer",example:0,description:"Index of the choice"},message:{type:"object",properties:{content:{type:"string",example:"Hello user. What can I help you with?",description:"Content of the message"},role:{type:"string",example:"assistant",description:"Role of the sender"}}}}}},created:{type:"integer",example:1700193928,description:"Timestamp of when the response was created"},id:{type:"string",example:"ebwd2niJvJB1Q2Whyvkz",description:"Unique identifier of the response"},model:{type:"string",nullable:!0,example:"_",description:"Model used for generating the response"},object:{type:"string",example:"chat.completion",description:"Type of the response object"},system_fingerprint:{type:"string",nullable:!0,example:"_",description:"System fingerprint"},usage:{type:"object",description:"Information about the usage of tokens",properties:{completion_tokens:{type:"integer",example:500,description:"Number of tokens used for completion"},prompt_tokens:{type:"integer",example:33,description:"Number of tokens used in the prompt"},total_tokens:{type:"integer",example:533,description:"Total number of tokens used"}}}}},AssistantObject:{type:"object",properties:{id:{type:"string",description:"The identifier of the assistant.",example:"asst_abc123"},object:{type:"string",description:"Type of the object, indicating it's an assistant.",default:"assistant"},version:{type:"integer",description:"Version number of the assistant.",example:1},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the assistant.",example:1698984975},name:{type:"string",description:"Name of the assistant.",example:"Math Tutor"},description:{type:"string",description:"Description of the assistant. Can be null.",example:null},avatar:{type:"string",description:"URL of the assistant's avatar. Jan-specific property.",example:"https://pic.png"},models:{type:"array",description:"List of models associated with the assistant. Jan-specific property.",items:{type:"object",properties:{model_id:{type:"string",example:"model_0"}}}},instructions:{type:"string",description:"A system prompt for the assistant.",example:"Be concise"},events:{type:"object",description:"Event subscription settings for the assistant.",properties:{in:{type:"array",items:{type:"string"}},out:{type:"array",items:{type:"string"}}}},metadata:{type:"object",description:"Metadata associated with the assistant."}}},ListAssistantsResponse:{type:"object"},CreateAssistantResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the assistant.",example:"asst_abc123"},object:{type:"string",description:"Type of the object, indicating it's an assistant.",default:"assistant"},version:{type:"integer",description:"Version number of the assistant.",example:1},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the assistant.",example:1698984975},name:{type:"string",description:"Name of the assistant.",example:"Math Tutor"},description:{type:"string",description:"Description of the assistant. Can be null.",example:null},avatar:{type:"string",description:"URL of the assistant's avatar. Jan-specific property.",example:"https://pic.png"},models:{type:"array",description:"List of models associated with the assistant. Jan-specific property.",items:{type:"object",properties:{model_id:{type:"string",example:"model_0"}}}},instructions:{type:"string",description:"A system prompt for the assistant.",example:"Be concise"},events:{type:"object",description:"Event subscription settings for the assistant.",properties:{in:{type:"array",items:{type:"string"}},out:{type:"array",items:{type:"string"}}}},metadata:{type:"object",description:"Metadata associated with the assistant."}}},RetrieveAssistantResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the assistant.",example:"asst_abc123"},object:{type:"string",description:"Type of the object, indicating it's an assistant.",default:"assistant"},version:{type:"integer",description:"Version number of the assistant.",example:1},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the assistant.",example:1698984975},name:{type:"string",description:"Name of the assistant.",example:"Math Tutor"},description:{type:"string",description:"Description of the assistant. Can be null.",example:null},avatar:{type:"string",description:"URL of the assistant's avatar. Jan-specific property.",example:"https://pic.png"},models:{type:"array",description:"List of models associated with the assistant. Jan-specific property.",items:{type:"object",properties:{model_id:{type:"string",example:"model_0"}}}},instructions:{type:"string",description:"A system prompt for the assistant.",example:"Be concise"},events:{type:"object",description:"Event subscription settings for the assistant.",properties:{in:{type:"array",items:{type:"string"}},out:{type:"array",items:{type:"string"}}}},metadata:{type:"object",description:"Metadata associated with the assistant."}}},ModifyAssistantObject:{type:"object",properties:{id:{type:"string",description:"The identifier of the assistant.",example:"asst_abc123"},object:{type:"string",description:"Type of the object, indicating it's an assistant.",default:"assistant"},version:{type:"integer",description:"Version number of the assistant.",example:1},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the assistant.",example:1698984975},name:{type:"string",description:"Name of the assistant.",example:"Math Tutor"},description:{type:"string",description:"Description of the assistant. Can be null.",example:null},avatar:{type:"string",description:"URL of the assistant's avatar. Jan-specific property.",example:"https://pic.png"},models:{type:"array",description:"List of models associated with the assistant. Jan-specific property.",items:{type:"object",properties:{model_id:{type:"string",example:"model_0"}}}},instructions:{type:"string",description:"A system prompt for the assistant.",example:"Be concise"},events:{type:"object",description:"Event subscription settings for the assistant.",properties:{in:{type:"array",items:{type:"string"}},out:{type:"array",items:{type:"string"}}}},metadata:{type:"object",description:"Metadata associated with the assistant."}}},ModifyAssistantResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the assistant.",example:"asst_abc123"},object:{type:"string",description:"Type of the object, indicating it's an assistant.",default:"assistant"},version:{type:"integer",description:"Version number of the assistant.",example:1},created_at:{type:"integer",format:"int64",description:"Unix timestamp representing the creation time of the assistant.",example:1698984975},name:{type:"string",description:"Name of the assistant.",example:"Physics Tutor"},description:{type:"string",description:"Description of the assistant. Can be null.",example:null},avatar:{type:"string",description:"URL of the assistant's avatar. Jan-specific property.",example:"https://pic.png"},models:{type:"array",description:"List of models associated with the assistant. Jan-specific property.",items:{type:"object",properties:{model_id:{type:"string",example:"model_0"}}}},instructions:{type:"string",description:"A system prompt for the assistant.",example:"Be concise!"},events:{type:"object",description:"Event subscription settings for the assistant.",properties:{in:{type:"array",items:{type:"string"}},out:{type:"array",items:{type:"string"}}}},metadata:{type:"object",description:"Metadata associated with the assistant."}}},DeleteAssistantResponse:{type:"object",properties:{id:{type:"string",description:"The identifier of the deleted assistant.",example:"asst_abc123"},object:{type:"string",description:"Type of the object, indicating the assistant has been deleted.",example:"assistant.deleted"},deleted:{type:"boolean",description:"Indicates whether the assistant was successfully deleted.",example:!0}}}}}}}}},{path:"/blog/",component:d("/blog/","57a"),exact:!0},{path:"/blog/2024/03/19/TensorRT-LLM/",component:d("/blog/2024/03/19/TensorRT-LLM/","aa4"),exact:!0},{path:"/blog/archive/",component:d("/blog/archive/","a0b"),exact:!0},{path:"/blog/postmortems/january-10-2024-bitdefender-false-positive-flag/",component:d("/blog/postmortems/january-10-2024-bitdefender-false-positive-flag/","42e"),exact:!0},{path:"/blog/tags/",component:d("/blog/tags/","676"),exact:!0},{path:"/blog/tags/3090/",component:d("/blog/tags/3090/","0cd"),exact:!0},{path:"/blog/tags/4090/",component:d("/blog/tags/4090/","ec1"),exact:!0},{path:"/blog/tags/inference-engine/",component:d("/blog/tags/inference-engine/","791"),exact:!0},{path:"/blog/tags/llama-cpp/",component:d("/blog/tags/llama-cpp/","e0e"),exact:!0},{path:"/blog/tags/nvidia/",component:d("/blog/tags/nvidia/","8f1"),exact:!0},{path:"/blog/tags/postmortem/",component:d("/blog/tags/postmortem/","3ef"),exact:!0},{path:"/blog/tags/tensor-rt-llm/",component:d("/blog/tags/tensor-rt-llm/","9e9"),exact:!0},{path:"/docs/",component:d("/docs/","e8e"),exact:!0},{path:"/download/",component:d("/download/","553"),exact:!0},{path:"/search/",component:d("/search/","db4"),exact:!0},{path:"/",component:d("/","fc2"),exact:!0},{path:"/",component:d("/","dbe"),routes:[{path:"/",component:d("/","3a1"),routes:[{path:"/tags/",component:d("/tags/","c6e"),exact:!0},{path:"/tags/audiences/",component:d("/tags/audiences/","72b"),exact:!0},{path:"/tags/customzied-dataset/",component:d("/tags/customzied-dataset/","759"),exact:!0},{path:"/tags/fine-tuning-tutorial/",component:d("/tags/fine-tuning-tutorial/","c58"),exact:!0},{path:"/tags/finetune-llm/",component:d("/tags/finetune-llm/","1e4"),exact:!0},{path:"/tags/industries/",component:d("/tags/industries/","0aa"),exact:!0},{path:"/tags/large-language-models/",component:d("/tags/large-language-models/","6f7"),exact:!0},{path:"/tags/open-source-chat-gpt-alternatives/",component:d("/tags/open-source-chat-gpt-alternatives/","ba9"),exact:!0},{path:"/tags/outperform-chat-gpt/",component:d("/tags/outperform-chat-gpt/","14d"),exact:!0},{path:"/tags/personal-dataset/",component:d("/tags/personal-dataset/","dc2"),exact:!0},{path:"/tags/retrieval-augmented-generation/",component:d("/tags/retrieval-augmented-generation/","3e5"),exact:!0},{path:"/tags/use-cases/",component:d("/tags/use-cases/","ff8"),exact:!0},{path:"/",component:d("/","69b"),routes:[{path:"/about/",component:d("/about/","d0f"),exact:!0,sidebar:"aboutSidebar"},{path:"/about/2035/",component:d("/about/2035/","c48"),exact:!0},{path:"/about/faq/",component:d("/about/faq/","027"),exact:!0,sidebar:"aboutSidebar"},{path:"/about/roadmap/",component:d("/about/roadmap/","afa"),exact:!0},{path:"/acknowledgements/",component:d("/acknowledgements/","c1d"),exact:!0,sidebar:"aboutSidebar"},{path:"/blog/surpassing-chatgpt-with-open-source-alternatives/",component:d("/blog/surpassing-chatgpt-with-open-source-alternatives/","efd"),exact:!0},{path:"/changelog/",component:d("/changelog/","ba7"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.2.0/",component:d("/changelog/changelog-v0.2.0/","3a7"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.2.1/",component:d("/changelog/changelog-v0.2.1/","f64"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.2.2/",component:d("/changelog/changelog-v0.2.2/","4e3"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.2.3/",component:d("/changelog/changelog-v0.2.3/","504"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.3.0/",component:d("/changelog/changelog-v0.3.0/","57e"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.3.1/",component:d("/changelog/changelog-v0.3.1/","e08"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.3.2/",component:d("/changelog/changelog-v0.3.2/","b79"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.3.3/",component:d("/changelog/changelog-v0.3.3/","e56"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.0/",component:d("/changelog/changelog-v0.4.0/","6f5"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.1/",component:d("/changelog/changelog-v0.4.1/","83c"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.2/",component:d("/changelog/changelog-v0.4.2/","53c"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.3/",component:d("/changelog/changelog-v0.4.3/","182"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.4/",component:d("/changelog/changelog-v0.4.4/","d53"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.5/",component:d("/changelog/changelog-v0.4.5/","65f"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.6/",component:d("/changelog/changelog-v0.4.6/","687"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.7/",component:d("/changelog/changelog-v0.4.7/","964"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.8/",component:d("/changelog/changelog-v0.4.8/","e1a"),exact:!0,sidebar:"releasesSidebar"},{path:"/changelog/changelog-v0.4.9/",component:d("/changelog/changelog-v0.4.9/","a67"),exact:!0,sidebar:"releasesSidebar"},{path:"/community/",component:d("/community/","f25"),exact:!0,sidebar:"aboutSidebar"},{path:"/desktop/",component:d("/desktop/","a4a"),exact:!0,sidebar:"productSidebar"},{path:"/developer/",component:d("/developer/","910"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/architecture/",component:d("/developer/architecture/","5f5"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/engineering/",component:d("/developer/engineering/","112"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/file-based/",component:d("/developer/file-based/","68e"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/",component:d("/developer/framework/","ac0"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/assistants/",component:d("/developer/framework/engineering/assistants/","689"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/chats/",component:d("/developer/framework/engineering/chats/","a54"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/engine/",component:d("/developer/framework/engineering/engine/","cff"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/files/",component:d("/developer/framework/engineering/files/","01b"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/messages/",component:d("/developer/framework/engineering/messages/","18b"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/models/",component:d("/developer/framework/engineering/models/","416"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/engineering/threads/",component:d("/developer/framework/engineering/threads/","20f"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/product/chat/",component:d("/developer/framework/product/chat/","edb"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/product/hub/",component:d("/developer/framework/product/hub/","31e"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/product/jan/",component:d("/developer/framework/product/jan/","434"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/product/settings/",component:d("/developer/framework/product/settings/","532"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/framework/product/system-monitor/",component:d("/developer/framework/product/system-monitor/","f86"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/prereq/",component:d("/developer/prereq/","9fd"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/product/",component:d("/developer/product/","793"),exact:!0,sidebar:"developerSidebar"},{path:"/developer/ui/",component:d("/developer/ui/","952"),exact:!0,sidebar:"developerSidebar"},{path:"/ecosystem/",component:d("/ecosystem/","63e"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/engineering/",component:d("/engineering/","2a8"),exact:!0,sidebar:"aboutSidebar"},{path:"/engineering/ci-cd/",component:d("/engineering/ci-cd/","0e0"),exact:!0,sidebar:"aboutSidebar"},{path:"/engineering/qa/",component:d("/engineering/qa/","5bd"),exact:!0,sidebar:"aboutSidebar"},{path:"/enterprise/",component:d("/enterprise/","614"),exact:!0},{path:"/events/hcmc-oct23/",component:d("/events/hcmc-oct23/","c08"),exact:!0},{path:"/events/nvidia-llm-day-nov-23/",component:d("/events/nvidia-llm-day-nov-23/","a0d"),exact:!0},{path:"/extensions/",component:d("/extensions/","2a4"),exact:!0,sidebar:"guidesSidebar"},{path:"/features/",component:d("/features/","dbf"),exact:!0,sidebar:"productSidebar"},{path:"/features/agents-framework/",component:d("/features/agents-framework/","c41"),exact:!0,sidebar:"productSidebar"},{path:"/features/api-server/",component:d("/features/api-server/","52b"),exact:!0,sidebar:"productSidebar"},{path:"/features/data-security/",component:d("/features/data-security/","c23"),exact:!0,sidebar:"productSidebar"},{path:"/features/extensions-framework/",component:d("/features/extensions-framework/","b0a"),exact:!0,sidebar:"productSidebar"},{path:"/features/local/",component:d("/features/local/","de7"),exact:!0,sidebar:"productSidebar"},{path:"/features/remote/",component:d("/features/remote/","737"),exact:!0,sidebar:"productSidebar"},{path:"/foundry/",component:d("/foundry/","9a7"),exact:!0},{path:"/guides/",component:d("/guides/","a12"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/advanced/",component:d("/guides/advanced/","b9d"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/assistants/",component:d("/guides/assistants/","11e"),exact:!0},{path:"/guides/data-folder/",component:d("/guides/data-folder/","df7"),exact:!0},{path:"/guides/engines/",component:d("/guides/engines/","402"),exact:!0},{path:"/guides/engines/claude/",component:d("/guides/engines/claude/","1ea"),exact:!0},{path:"/guides/engines/groq/",component:d("/guides/engines/groq/","387"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/llamacpp/",component:d("/guides/engines/llamacpp/","e82"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/lmstudio/",component:d("/guides/engines/lmstudio/","289"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/local/",component:d("/guides/engines/local/","d2f"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/mistral/",component:d("/guides/engines/mistral/","e34"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/ollama/",component:d("/guides/engines/ollama/","505"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/openai/",component:d("/guides/engines/openai/","655"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/remote-server/",component:d("/guides/engines/remote-server/","060"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/remote/",component:d("/guides/engines/remote/","e80"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/engines/tensorrt-llm/",component:d("/guides/engines/tensorrt-llm/","039"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/hardware/",component:d("/guides/hardware/","f88"),exact:!0},{path:"/guides/hardware/gpu/",component:d("/guides/hardware/gpu/","7ce"),exact:!0},{path:"/guides/install/",component:d("/guides/install/","295"),exact:!0},{path:"/guides/install/linux/",component:d("/guides/install/linux/","7f0"),exact:!0},{path:"/guides/install/mac/",component:d("/guides/install/mac/","156"),exact:!0},{path:"/guides/install/server/",component:d("/guides/install/server/","dbc"),exact:!0},{path:"/guides/install/windows/",component:d("/guides/install/windows/","045"),exact:!0},{path:"/guides/local-api/",component:d("/guides/local-api/","55f"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/models/",component:d("/guides/models/","00f"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/overview/",component:d("/guides/overview/","be1"),exact:!0},{path:"/guides/providers/tensorrt-llm/",component:d("/guides/providers/tensorrt-llm/","abc"),exact:!0},{path:"/guides/quickstart/",component:d("/guides/quickstart/","179"),exact:!0,sidebar:"guidesSidebar"},{path:"/guides/threads/",component:d("/guides/threads/","e0b"),exact:!0,sidebar:"guidesSidebar"},{path:"/hardware/",component:d("/hardware/","d35"),exact:!0},{path:"/hardware/community/",component:d("/hardware/community/","efa"),exact:!0},{path:"/hardware/concepts/",component:d("/hardware/concepts/","9b1"),exact:!0},{path:"/hardware/concepts/chassis/",component:d("/hardware/concepts/chassis/","455"),exact:!0},{path:"/hardware/concepts/cpu-and-ram/",component:d("/hardware/concepts/cpu-and-ram/","30e"),exact:!0},{path:"/hardware/concepts/gpu-and-vram/",component:d("/hardware/concepts/gpu-and-vram/","0e0"),exact:!0},{path:"/hardware/concepts/motherboard/",component:d("/hardware/concepts/motherboard/","460"),exact:!0},{path:"/hardware/concepts/network/",component:d("/hardware/concepts/network/","73d"),exact:!0},{path:"/hardware/concepts/power/",component:d("/hardware/concepts/power/","08b"),exact:!0},{path:"/hardware/concepts/storage/",component:d("/hardware/concepts/storage/","b0d"),exact:!0},{path:"/hardware/examples/4090x2-@dan-jan/",component:d("/hardware/examples/4090x2-@dan-jan/","672"),exact:!0},{path:"/hardware/overview/cloud-vs-self-hosting/",component:d("/hardware/overview/cloud-vs-self-hosting/","966"),exact:!0},{path:"/hardware/overview/cpu-vs-gpu/",component:d("/hardware/overview/cpu-vs-gpu/","8e0"),exact:!0},{path:"/hardware/recommendations/by-budget/",component:d("/hardware/recommendations/by-budget/","dde"),exact:!0},{path:"/hardware/recommendations/by-hardware/",component:d("/hardware/recommendations/by-hardware/","4fd"),exact:!0},{path:"/hardware/recommendations/by-model/",component:d("/hardware/recommendations/by-model/","8a2"),exact:!0},{path:"/hardware/recommendations/by-usecase/",component:d("/hardware/recommendations/by-usecase/","a71"),exact:!0},{path:"/home-server/",component:d("/home-server/","22e"),exact:!0,sidebar:"productSidebar"},{path:"/how-we-work/",component:d("/how-we-work/","c3c"),exact:!0,sidebar:"aboutSidebar"},{path:"/how-we-work/analytics/",component:d("/how-we-work/analytics/","84b"),exact:!0,sidebar:"aboutSidebar"},{path:"/how-we-work/product-design/",component:d("/how-we-work/product-design/","67e"),exact:!0,sidebar:"aboutSidebar"},{path:"/how-we-work/project-management/",component:d("/how-we-work/project-management/","57f"),exact:!0,sidebar:"aboutSidebar"},{path:"/how-we-work/strategy/",component:d("/how-we-work/strategy/","51d"),exact:!0,sidebar:"aboutSidebar"},{path:"/how-we-work/website-docs/",component:d("/how-we-work/website-docs/","7a4"),exact:!0,sidebar:"aboutSidebar"},{path:"/integrations/",component:d("/integrations/","b48"),exact:!0,sidebar:"guidesSidebar"},{path:"/integrations/",component:d("/integrations/","4dc"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/integrations/continue/",component:d("/integrations/continue/","f5e"),exact:!0,sidebar:"guidesSidebar"},{path:"/integrations/crewai/",component:d("/integrations/crewai/","80e"),exact:!0},{path:"/integrations/discord/",component:d("/integrations/discord/","583"),exact:!0,sidebar:"guidesSidebar"},{path:"/integrations/interpreter/",component:d("/integrations/interpreter/","c43"),exact:!0,sidebar:"guidesSidebar"},{path:"/integrations/langchain/",component:d("/integrations/langchain/","221"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/integrations/llamacpp/",component:d("/integrations/llamacpp/","112"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/integrations/ollama/",component:d("/integrations/ollama/","dfe"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/integrations/openai/",component:d("/integrations/openai/","4a9"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/integrations/openrouter/",component:d("/integrations/openrouter/","998"),exact:!0,sidebar:"guidesSidebar"},{path:"/integrations/openrouter/",component:d("/integrations/openrouter/","932"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/integrations/raycast/",component:d("/integrations/raycast/","477"),exact:!0,sidebar:"guidesSidebar"},{path:"/integrations/unsloth/",component:d("/integrations/unsloth/","b9e"),exact:!0},{path:"/integrationss/",component:d("/integrationss/","0c0"),exact:!0},{path:"/mobile/",component:d("/mobile/","ef3"),exact:!0},{path:"/partners/",component:d("/partners/","4f5"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/partners/become-a-partner/",component:d("/partners/become-a-partner/","60e"),exact:!0,sidebar:"ecosystemSidebar"},{path:"/platforms/hub/",component:d("/platforms/hub/","d13"),exact:!0},{path:"/pricing/",component:d("/pricing/","e2a"),exact:!0,sidebar:"pricingSidebar"},{path:"/privacy/",component:d("/privacy/","a62"),exact:!0},{path:"/server-suite/admin-console/",component:d("/server-suite/admin-console/","8bd"),exact:!0},{path:"/server-suite/audit-compliance/",component:d("/server-suite/audit-compliance/","3df"),exact:!0},{path:"/server-suite/identity-access-management/",component:d("/server-suite/identity-access-management/","2e4"),exact:!0},{path:"/server-suite/observability/",component:d("/server-suite/observability/","228"),exact:!0},{path:"/solutions/ai-employees/",component:d("/solutions/ai-employees/","0ad"),exact:!0},{path:"/solutions/ai-pc/",component:d("/solutions/ai-pc/","34a"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/chatgpt-alternative/",component:d("/solutions/chatgpt-alternative/","341"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/consultants/",component:d("/solutions/consultants/","50a"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/developers/",component:d("/solutions/developers/","809"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/enterprises/",component:d("/solutions/enterprises/","fbf"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/finance/",component:d("/solutions/finance/","e69"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/government/",component:d("/solutions/government/","0c9"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/healthcare/",component:d("/solutions/healthcare/","c0c"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/legal/",component:d("/solutions/legal/","e5f"),exact:!0,sidebar:"solutionSidebar"},{path:"/solutions/startups/",component:d("/solutions/startups/","0f0"),exact:!0,sidebar:"solutionSidebar"},{path:"/studio/",component:d("/studio/","c78"),exact:!0},{path:"/support/",component:d("/support/","39a"),exact:!0},{path:"/team/",component:d("/team/","466"),exact:!0,sidebar:"aboutSidebar"},{path:"/team/contributor-program/",component:d("/team/contributor-program/","4ca"),exact:!0,sidebar:"aboutSidebar"},{path:"/team/join-us/",component:d("/team/join-us/","555"),exact:!0,sidebar:"aboutSidebar"},{path:"/template/QA_script/",component:d("/template/QA_script/","8d8"),exact:!0},{path:"/troubleshooting/",component:d("/troubleshooting/","235"),exact:!0,sidebar:"guidesSidebar"},{path:"/tutorial/how-to-fine-tune-llms/",component:d("/tutorial/how-to-fine-tune-llms/","d4a"),exact:!0},{path:"/vision/",component:d("/vision/","d02"),exact:!0},{path:"/wall-of-love/",component:d("/wall-of-love/","486"),exact:!0,sidebar:"aboutSidebar"}]}]}]},{path:"*",component:d("*")}]},6125:(e,t,n)=>{"use strict";n.d(t,{o:()=>o,x:()=>s});var r=n(96540),a=n(74848);const o=r.createContext(!1);function s(e){let{children:t}=e;const[n,s]=(0,r.useState)(!1);return(0,r.useEffect)((()=>{s(!0)}),[]),(0,a.jsx)(o.Provider,{value:n,children:t})}},38536:(e,t,n)=>{"use strict";var r=n(96540),a=n(5338),o=n(54625),s=n(80545),i=n(38193);const l=[n(10119),n(26134),n(76294),n(73339),n(7767),n(23390),n(29530)];var c=n(35947),u=n(56347),d=n(22831),p=n(74848);function f(e){let{children:t}=e;return(0,p.jsx)(p.Fragment,{children:t})}var m=n(5260),h=n(44586),g=n(86025),b=n(6342),y=n(69024),v=n(32131),w=n(14090),x=n(2967),k=n(70440),_=n(41463);function S(){const{i18n:{currentLocale:e,defaultLocale:t,localeConfigs:n}}=(0,h.A)(),r=(0,v.o)(),a=n[e].htmlLang,o=e=>e.replace("-","_");return(0,p.jsxs)(m.A,{children:[Object.entries(n).map((e=>{let[t,{htmlLang:n}]=e;return(0,p.jsx)("link",{rel:"alternate",href:r.createUrl({locale:t,fullyQualified:!0}),hrefLang:n},t)})),(0,p.jsx)("link",{rel:"alternate",href:r.createUrl({locale:t,fullyQualified:!0}),hrefLang:"x-default"}),(0,p.jsx)("meta",{property:"og:locale",content:o(a)}),Object.values(n).filter((e=>a!==e.htmlLang)).map((e=>(0,p.jsx)("meta",{property:"og:locale:alternate",content:o(e.htmlLang)},`meta-og-${e.htmlLang}`)))]})}function E(e){let{permalink:t}=e;const{siteConfig:{url:n}}=(0,h.A)(),r=function(){const{siteConfig:{url:e,baseUrl:t,trailingSlash:n}}=(0,h.A)(),{pathname:r}=(0,u.zy)();return e+(0,k.applyTrailingSlash)((0,g.A)(r),{trailingSlash:n,baseUrl:t})}(),a=t?`${n}${t}`:r;return(0,p.jsxs)(m.A,{children:[(0,p.jsx)("meta",{property:"og:url",content:a}),(0,p.jsx)("link",{rel:"canonical",href:a})]})}function j(){const{i18n:{currentLocale:e}}=(0,h.A)(),{metadata:t,image:n}=(0,b.p)();return(0,p.jsxs)(p.Fragment,{children:[(0,p.jsxs)(m.A,{children:[(0,p.jsx)("meta",{name:"twitter:card",content:"summary_large_image"}),(0,p.jsx)("body",{className:w.w})]}),n&&(0,p.jsx)(y.be,{image:n}),(0,p.jsx)(E,{}),(0,p.jsx)(S,{}),(0,p.jsx)(_.A,{tag:x.Cy,locale:e}),(0,p.jsx)(m.A,{children:t.map(((e,t)=>(0,p.jsx)("meta",{...e},t)))})]})}const T=new Map;function A(e){if(T.has(e.pathname))return{...e,pathname:T.get(e.pathname)};if((0,d.u)(c.A,e.pathname).some((e=>{let{route:t}=e;return!0===t.exact})))return T.set(e.pathname,e.pathname),e;const t=e.pathname.trim().replace(/(?:\/index)?\.html$/,"")||"/";return T.set(e.pathname,t),{...e,pathname:t}}var C=n(6125),R=n(26988),I=n(205);function O(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),r=1;r{const r=t.default?.[e]??t[e];return r?.(...n)}));return()=>a.forEach((e=>e?.()))}const L=function(e){let{children:t,location:n,previousLocation:r}=e;return(0,I.A)((()=>{r!==n&&(!function(e){let{location:t,previousLocation:n}=e;if(!n)return;const r=t.pathname===n.pathname,a=t.hash===n.hash,o=t.search===n.search;if(r&&a&&!o)return;const{hash:s}=t;if(s){const e=decodeURIComponent(s.substring(1)),t=document.getElementById(e);t?.scrollIntoView()}else window.scrollTo(0,0)}({location:n,previousLocation:r}),O("onRouteDidUpdate",{previousLocation:r,location:n}))}),[r,n]),t};function N(e){const t=Array.from(new Set([e,decodeURI(e)])).map((e=>(0,d.u)(c.A,e))).flat();return Promise.all(t.map((e=>e.route.component.preload?.())))}class P extends r.Component{previousLocation;routeUpdateCleanupCb;constructor(e){super(e),this.previousLocation=null,this.routeUpdateCleanupCb=i.default.canUseDOM?O("onRouteUpdate",{previousLocation:null,location:this.props.location}):()=>{},this.state={nextRouteHasLoaded:!0}}shouldComponentUpdate(e,t){if(e.location===this.props.location)return t.nextRouteHasLoaded;const n=e.location;return this.previousLocation=this.props.location,this.setState({nextRouteHasLoaded:!1}),this.routeUpdateCleanupCb=O("onRouteUpdate",{previousLocation:this.previousLocation,location:n}),N(n.pathname).then((()=>{this.routeUpdateCleanupCb(),this.setState({nextRouteHasLoaded:!0})})).catch((e=>{console.warn(e),window.location.reload()})),!1}render(){const{children:e,location:t}=this.props;return(0,p.jsx)(L,{previousLocation:this.previousLocation,location:t,children:(0,p.jsx)(u.qh,{location:t,render:()=>e})})}}const M=P,D="__docusaurus-base-url-issue-banner-container",F="__docusaurus-base-url-issue-banner",B="__docusaurus-base-url-issue-banner-suggestion-container";function $(e){return`\ndocument.addEventListener('DOMContentLoaded', function maybeInsertBanner() {\n var shouldInsert = typeof window['docusaurus'] === 'undefined';\n shouldInsert && insertBanner();\n});\n\nfunction insertBanner() {\n var bannerContainer = document.createElement('div');\n bannerContainer.id = '${D}';\n var bannerHtml = ${JSON.stringify(function(e){return`\n
    \n

    Your Docusaurus site did not load properly.

    \n

    A very common reason is a wrong site baseUrl configuration.

    \n

    Current configured baseUrl = ${e} ${"/"===e?" (default value)":""}

    \n

    We suggest trying baseUrl =

    \n
    \n`}(e)).replace(/{if("undefined"==typeof document)return void n();const r=document.createElement("link");r.setAttribute("rel","prefetch"),r.setAttribute("href",e),r.onload=()=>t(),r.onerror=()=>n();const a=document.getElementsByTagName("head")[0]??document.getElementsByName("script")[0]?.parentNode;a?.appendChild(r)}))}:function(e){return new Promise(((t,n)=>{const r=new XMLHttpRequest;r.open("GET",e,!0),r.withCredentials=!0,r.onload=()=>{200===r.status?t():n()},r.send(null)}))};var Q=n(86921);const J=new Set,Z=new Set,X=()=>navigator.connection?.effectiveType.includes("2g")||navigator.connection?.saveData,ee={prefetch(e){if(!(e=>!X()&&!Z.has(e)&&!J.has(e))(e))return!1;J.add(e);const t=(0,d.u)(c.A,e).flatMap((e=>{return t=e.route.path,Object.entries(K).filter((e=>{let[n]=e;return n.replace(/-[^-]+$/,"")===t})).flatMap((e=>{let[,t]=e;return Object.values((0,Q.A)(t))}));var t}));return Promise.all(t.map((e=>{const t=n.gca(e);return t&&!t.includes("undefined")?Y(t).catch((()=>{})):Promise.resolve()})))},preload:e=>!!(e=>!X()&&!Z.has(e))(e)&&(Z.add(e),N(e))},te=Object.freeze(ee),ne=Boolean(!0);if(i.default.canUseDOM){window.docusaurus=te;const e=document.getElementById("__docusaurus"),t=(0,p.jsx)(s.vd,{children:(0,p.jsx)(o.Kd,{children:(0,p.jsx)(G,{})})}),n=(e,t)=>{console.error("Docusaurus React Root onRecoverableError:",e,t)},i=()=>{if(ne)r.startTransition((()=>{a.hydrateRoot(e,t,{onRecoverableError:n})}));else{const o=a.createRoot(e,{onRecoverableError:n});r.startTransition((()=>{o.render(t)}))}};N(window.location.pathname).then(i)}},26988:(e,t,n)=>{"use strict";n.d(t,{o:()=>d,l:()=>p});var r=n(96540),a=n(4784);const o=JSON.parse('{"docusaurus-plugin-redoc":{"plugin-redoc-0":{"url":"redocusaurus/plugin-redoc-0.yaml","themeId":"theme-redoc","isSpecFile":true,"spec":{"openapi":"3.0.0","info":{"title":"API Reference","description":"# Introduction\\nJan API is compatible with the [OpenAI API](https://platform.openai.com/docs/api-reference).\\n"},"version":"0.1.8","contact":{"name":"Jan Discord","url":"https://discord.gg/7EcEz7MrvA"},"license":{"name":"AGPLv3","url":"https://github.com/janhq/nitro/blob/main/LICENSE"},"servers":[{"url":"/v1"}],"tags":[{"name":"Models","description":"List and describe the various models available in the API."},{"name":"Chat","description":"Given a list of messages comprising a conversation, the model will return a response.\\n"},{"name":"Messages","description":"Messages capture a conversation\'s content. This can include the content from LLM responses and other metadata from [chat completions](/specs/chats).\\n"},{"name":"Threads"},{"name":"Assistants","description":"Configures and utilizes different AI assistants for varied tasks"}],"x-tagGroups":[{"name":"Endpoints","tags":["Models","Chat"]},{"name":"Chat","tags":["Assistants","Messages","Threads"]}],"paths":{"/chat/completions":{"post":{"operationId":"createChatCompletion","tags":["Chat"],"summary":"Create chat completion\\n","description":"Creates a model response for the given chat conversation. Equivalent to OpenAI\'s create chat completion. \\n","requestBody":{"content":{"application/json":{"schema":{"$ref":"#/components/schemas/ChatCompletionRequest"}}}},"responses":{"200":{"description":"OK","content":{"application/json":{"schema":{"$ref":"#/components/schemas/ChatCompletionResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X \'POST\' \\\\\\n \'http://localhost:1337/v1/chat/completions\' \\\\\\n -H \'accept: application/json\' \\\\\\n -H \'Content-Type: application/json\' \\\\\\n -d \'{\\n \\"messages\\": [\\n {\\n \\"content\\": \\"You are a helpful assistant.\\",\\n \\"role\\": \\"system\\"\\n },\\n {\\n \\"content\\": \\"Hello!\\",\\n \\"role\\": \\"user\\"\\n }\\n ],\\n \\"model\\": \\"tinyllama-1.1b\\",\\n \\"stream\\": true,\\n \\"max_tokens\\": 2048,\\n \\"stop\\": [\\n \\"hello\\"\\n ],\\n \\"frequency_penalty\\": 0,\\n \\"presence_penalty\\": 0,\\n \\"temperature\\": 0.7,\\n \\"top_p\\": 0.95\\n }\'\\n"},{"lang":"JavaScript","source":"const data = {\\n messages: [\\n {\\n content: \'You are a helpful assistant.\',\\n role: \'system\'\\n },\\n {\\n content: \'Hello!\',\\n role: \'user\'\\n }\\n ],\\n model: \'tinyllama-1.1b\',\\n stream: true,\\n max_tokens: 2048,\\n stop: [\'hello\'],\\n frequency_penalty: 0,\\n presence_penalty: 0,\\n temperature: 0.7,\\n top_p: 0.95\\n};\\n\\nfetch(\'http://localhost:1337/v1/chat/completions\', {\\n method: \'POST\',\\n headers: {\\n \'Content-Type\': \'application/json\',\\n \'Accept\': \'application/json\'\\n },\\n body: JSON.stringify(data)\\n})\\n .then(response => response.json())\\n .then(data => console.log(data));"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nconst data = {\\n messages: [\\n {\\n content: \'You are a helpful assistant.\',\\n role: \'system\'\\n },\\n {\\n content: \'Hello!\',\\n role: \'user\'\\n }\\n ],\\n model: \'tinyllama-1.1b\',\\n stream: true,\\n max_tokens: 2048,\\n stop: [\'hello\'],\\n frequency_penalty: 0,\\n presence_penalty: 0,\\n temperature: 0.7,\\n top_p: 0.95\\n};\\n\\nfetch(\'http://localhost:1337/v1/chat/completions\', {\\n method: \'POST\',\\n headers: {\\n \'Content-Type\': \'application/json\',\\n \'Accept\': \'application/json\'\\n },\\n body: JSON.stringify(data)\\n})\\n .then(response => response.json())\\n .then(data => console.log(data));"},{"lang":"Python","source":"import requests\\nimport json\\n\\ndata = {\\n \\"messages\\": [\\n {\\n \\"content\\": \\"You are a helpful assistant.\\",\\n \\"role\\": \\"system\\"\\n },\\n {\\n \\"content\\": \\"Hello!\\",\\n \\"role\\": \\"user\\"\\n }\\n ],\\n \\"model\\": \\"tinyllama-1.1b\\",\\n \\"stream\\": true,\\n \\"max_tokens\\": 2048,\\n \\"stop\\": [\\n \\"hello\\"\\n ],\\n \\"frequency_penalty\\": 0,\\n \\"presence_penalty\\": 0,\\n \\"temperature\\": 0.7,\\n \\"top_p\\": 0.95\\n}\\n\\nresponse = requests.post(\'http://localhost:1337/v1/chat/completions\', json=data)\\nprint(response.json())"}]}},"/models":{"get":{"operationId":"listModels","tags":["Models"],"summary":"List models","description":"Lists the currently available models, and provides basic information about each one such as the owner and availability. Equivalent to OpenAI\'s list model. \\n","responses":{"200":{"description":"OK","content":{"application/json":{"schema":{"$ref":"#/components/schemas/ListModelsResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X \'GET\' \\\\\\n \'http://localhost:1337/v1/models\' \\\\\\n -H \'accept: application/json\'"},{"lang":"JavaScript","source":"const response = await fetch(\'http://localhost:1337/v1/models\', {\\n method: \'GET\',\\n headers: {Accept: \'application/json\'}\\n});\\nconst data = await response.json();"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nconst url = \'http://localhost:1337/v1/models\';\\nconst options = {\\n method: \'GET\',\\n headers: { Accept: \'application/json\' }\\n};\\n\\nfetch(url, options)\\n .then(res => res.json())\\n .then(json => console.log(json));"},{"lang":"Python","source":"import requests\\n\\nurl = \'http://localhost:1337/v1/models\'\\nheaders = {\'Accept\': \'application/json\'}\\nresponse = requests.get(url, headers=headers)\\ndata = response.json()"}]}},"/models/download/{model_id}":{"get":{"operationId":"downloadModel","tags":["Models"],"summary":"Download a specific model.","description":"Download a model.\\n","parameters":[{"in":"path","name":"model_id","required":true,"schema":{"type":"string","example":"mistral-ins-7b-q4"},"description":"The ID of the model to use for this request.\\n"}],"responses":{"200":{"description":"OK","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DownloadModelResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X \'GET\' \\\\ \\n \'http://localhost:1337/v1/models/download/{model_id}\' \\\\ \\n -H \'accept: application/json\'"},{"lang":"JavaScript","source":"const response = await fetch(\'http://localhost:1337/v1/models/download/{model_id}\', {\\n method: \'GET\',\\n headers: {accept: \'application/json\'}\\n});\\n\\nconst data = await response.json();"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nfetch(\'http://localhost:1337/v1/models/download/{model_id}\', {\\n method: \'GET\',\\n headers: {accept: \'application/json\'}\\n})\\n.then(res => res.json())\\n.then(data => console.log(data));"},{"lang":"Python","source":"import requests\\n\\nresponse = requests.get(\'http://localhost:1337/v1/models/download/{model_id}\', headers={\'accept\': \'application/json\'})\\ndata = response.json()"}]}},"/models/{model_id}":{"get":{"operationId":"retrieveModel","tags":["Models"],"summary":"Retrieve model","description":"Get a model instance, providing basic information about the model such as the owner and permissioning. Equivalent to OpenAI\'s retrieve model. \\n","parameters":[{"in":"path","name":"model_id","required":true,"schema":{"type":"string","example":"mistral-ins-7b-q4"},"description":"The ID of the model to use for this request.\\n"}],"responses":{"200":{"description":"OK","content":{"application/json":{"schema":{"$ref":"#/components/schemas/GetModelResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X \'GET\' \\\\ \\n \'http://localhost:1337/v1/models/{model_id}\' \\\\ \\n -H \'accept: application/json\'"},{"lang":"JavaScript","source":"const fetch = require(\'node-fetch\');\\n\\nconst modelId = \'mistral-ins-7b-q4\';\\n\\nfetch(`http://localhost:1337/v1/models/${modelId}`, {\\n method: \'GET\',\\n headers: {\'accept\': \'application/json\'}\\n})\\n.then(res => res.json())\\n.then(json => console.log(json));"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nconst modelId = \'mistral-ins-7b-q4\';\\n\\nfetch(`http://localhost:1337/v1/models/${modelId}`, {\\n method: \'GET\',\\n headers: {\'accept\': \'application/json\'}\\n})\\n.then(res => res.json())\\n.then(json => console.log(json));"},{"lang":"Python","source":"import requests\\n\\nmodel_id = \'mistral-ins-7b-q4\'\\n\\nresponse = requests.get(f\'http://localhost:1337/v1/models/{model_id}\', headers={\'accept\': \'application/json\'})\\nprint(response.json())"}]},"delete":{"operationId":"deleteModel","tags":["Models"],"summary":"Delete model","description":"Delete a model. Equivalent to OpenAI\'s delete model. \\n","parameters":[{"in":"path","name":"model_id","required":true,"schema":{"type":"string","example":"mistral-ins-7b-q4"},"description":"The model id to delete\\n"}],"responses":{"200":{"description":"OK","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DeleteModelResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X \'DELETE\' \\\\\\n \'http://localhost:1337/v1/models/{model_id}\' \\\\\\n -H \'accept: application/json\'"},{"lang":"JavaScript","source":"const fetch = require(\'node-fetch\');\\n\\nconst modelId = \'mistral-ins-7b-q4\';\\n\\nfetch(`http://localhost:1337/v1/models/${modelId}`, {\\n method: \'DELETE\',\\n headers: { \'accept\': \'application/json\' }\\n})\\n .then(res => res.json())\\n .then(json => console.log(json));"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nconst modelId = \'mistral-ins-7b-q4\';\\n\\nfetch(`http://localhost:1337/v1/models/${modelId}`, {\\n method: \'DELETE\',\\n headers: { \'accept\': \'application/json\' }\\n})\\n .then(res => res.json())\\n .then(json => console.log(json));"},{"lang":"Python","source":"import requests\\n\\nmodel_id = \'mistral-ins-7b-q4\'\\n\\nresponse = requests.delete(f\'http://localhost:1337/v1/models/{model_id}\', headers={\'accept\': \'application/json\'})"}]}},"/threads":{"post":{"operationId":"createThread","tags":["Threads"],"summary":"Create thread","description":"Create a thread. Equivalent to OpenAI\'s create thread. \\n","requestBody":{"required":false,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/CreateThreadObject"}}}},"responses":{"200":{"description":"Thread created successfully","content":{"application/json":{"schema":{"$ref":"#/components/schemas/CreateThreadResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X POST http://localhost:1337/v1/threads \\\\ \\n -H \\"Content-Type: application/json\\" \\\\ \\n -d \'{\\n \\"messages\\": [{\\n \\"role\\": \\"user\\",\\n \\"content\\": \\"Hello, what is AI?\\",\\n \\"file_ids\\": [\\"file-abc123\\"]\\n }, {\\n \\"role\\": \\"user\\",\\n \\"content\\": \\"How does AI work? Explain it in simple terms.\\"\\n }]\\n }\'\\n"},{"lang":"JavaScript","source":"const fetch = require(\'node-fetch\');\\n\\nfetch(\'http://localhost:1337/v1/threads\', {\\n method: \'POST\',\\n headers: {\\n \'Content-Type\': \'application/json\'\\n },\\n body: JSON.stringify({\\n messages: [\\n {\\n role: \'user\',\\n content: \'Hello, what is AI?\',\\n file_ids: [\'file-abc123\']\\n },\\n {\\n role: \'user\',\\n content: \'How does AI work? Explain it in simple terms.\'\\n }\\n ]\\n })\\n});"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nfetch(\'http://localhost:1337/v1/threads\', {\\n method: \'POST\',\\n headers: {\\n \'Content-Type\': \'application/json\'\\n },\\n body: JSON.stringify({\\n messages: [\\n {\\n role: \'user\',\\n content: \'Hello, what is AI?\',\\n file_ids: [\'file-abc123\']\\n },\\n {\\n role: \'user\',\\n content: \'How does AI work? Explain it in simple terms.\'\\n }\\n ]\\n })\\n});"},{"lang":"Python","source":"import requests\\n\\nurl = \'http://localhost:1337/v1/threads\'\\npayload = {\\n \'messages\': [\\n {\\n \'role\': \'user\',\\n \'content\': \'Hello, what is AI?\',\\n \'file_ids\': [\'file-abc123\']\\n },\\n {\\n \'role\': \'user\',\\n \'content\': \'How does AI work? Explain it in simple terms.\'\\n }\\n ]\\n}\\n\\nresponse = requests.post(url, json=payload)\\nprint(response.text)"}]},"get":{"operationId":"listThreads","tags":["Threads"],"summary":"List threads","description":"Retrieves a list of all threads available in the system.\\n","responses":{"200":{"description":"List of threads retrieved successfully","content":{"application/json":{"schema":{"type":"array","items":{"$ref":"#/components/schemas/ThreadObject"},"example":[{"id":"thread_abc123","object":"thread","created_at":1699014083,"assistants":["assistant-001"],"metadata":{},"messages":[]},{"id":"thread_abc456","object":"thread","created_at":1699014083,"assistants":["assistant-002","assistant-003"],"metadata":{}}]}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl http://localhost:1337/v1/threads \\\\ \\n -H \\"Content-Type: application/json\\""},{"lang":"JavaScript","source":"const fetch = require(\'node-fetch\'); \\n\\nfetch(\'http://localhost:1337/v1/threads\', { \\n method: \'GET\', \\n headers: {\'Content-Type\': \'application/json\'} \\n}).then(res => res.json()) \\n.then(json => console.log(json));"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nfetch(\'http://localhost:1337/v1/threads\', {\\n method: \'GET\',\\n headers: {\'Content-Type\': \'application/json\'}\\n}).then(res => res.json())\\n.then(json => console.log(json));"},{"lang":"Python","source":"import requests\\n\\nurl = \'http://localhost:1337/v1/threads\'\\nheaders = {\'Content-Type\': \'application/json\'}\\n\\nresponse = requests.get(url, headers=headers)\\nprint(response.json())"}]}},"/threads/{thread_id}":{"get":{"operationId":"getThread","tags":["Threads"],"summary":"Retrieve thread","description":"Retrieves detailed information about a specific thread using its thread_id. Equivalent to OpenAI\'s retrieve thread. \\n","parameters":[{"in":"path","name":"thread_id","required":true,"schema":{"type":"string"},"description":"The ID of the thread to retrieve.\\n"}],"responses":{"200":{"description":"Thread details retrieved successfully","content":{"application/json":{"schema":{"$ref":"#/components/schemas/GetThreadResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl http://localhost:1337/v1/threads/{thread_id}\\n"}]},"patch":{"operationId":"modifyThread","tags":["Threads"],"summary":"Modify thread","description":"Modifies a thread. Equivalent to OpenAI\'s modify thread. \\n","parameters":[{"in":"path","name":"thread_id","required":true,"schema":{"type":"string"},"description":"The ID of the thread to be modified.\\n"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"type":"object","properties":{"title":{"type":"string","description":"Set the title of the thread","items":{"$ref":"#/components/schemas/ThreadMessageObject"}}}}}}},"responses":{"200":{"description":"Thread modified successfully","content":{"application/json":{"schema":{"$ref":"#/components/schemas/ModifyThreadResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X POST http://localhost:1337/v1/threads/{thread_id} \\\\\\n -H \\"Content-Type: application/json\\" \\\\\\n -d \'{\\n \\"messages\\": [{\\n \\"role\\": \\"user\\",\\n \\"content\\": \\"Hello, what is AI?\\",\\n \\"file_ids\\": [\\"file-abc123\\"]\\n }, {\\n \\"role\\": \\"user\\",\\n \\"content\\": \\"How does AI work? Explain it in simple terms.\\"\\n }]\\n }\'\\n"}]},"delete":{"operationId":"deleteThread","tags":["Threads"],"summary":"Delete thread","description":"Delete a thread. Equivalent to OpenAI\'s delete thread. \\n","parameters":[{"in":"path","name":"thread_id","required":true,"schema":{"type":"string"},"description":"The ID of the thread to be deleted.\\n"}],"responses":{"200":{"description":"Thread deleted successfully","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DeleteThreadResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X DELETE http://localhost:1337/v1/threads/{thread_id}\\n"}]}},"/assistants":{"get":{"operationId":"listAssistants","tags":["Assistants"],"summary":"List assistants","description":"Return a list of assistants. Equivalent to OpenAI\'s list assistants. \\n","responses":{"200":{"description":"List of assistants retrieved successfully","content":{"application/json":{"schema":{"type":"array","example":[{"id":"asst_abc123","object":"assistant","version":1,"created_at":1698984975,"name":"Math Tutor","description":null,"avatar":"https://pic.png","models":[{"model_id":"model_0"}],"instructions":"Be concise","events":{"in":[],"out":[]},"metadata":{}},{"id":"asst_abc456","object":"assistant","version":1,"created_at":1698984975,"name":"Physics Tutor","description":null,"avatar":"https://pic.png","models":[{"model_id":"model_1"}],"instructions":"Be concise!","events":{"in":[],"out":[]},"metadata":{}}]}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl http://localhost:1337/v1/assistants \\\\\\n -H \\"Content-Type: application/json\\""},{"lang":"JavaScript","source":"fetch(\'http://localhost:1337/v1/assistants\', {\\n method: \'GET\',\\n headers: {\\n \'Content-Type\': \'application/json\'\\n }\\n})"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nfetch(\'http://localhost:1337/v1/assistants\', {\\n method: \'GET\',\\n headers: {\\n \'Content-Type\': \'application/json\'\\n }\\n})"},{"lang":"Python","source":"import requests\\n\\nurl = \'http://localhost:1337/v1/assistants\'\\nheaders = {\'Content-Type\': \'application/json\'}\\n\\nresponse = requests.get(url, headers=headers)"}]}},"/assistants/{assistant_id}":{"get":{"operationId":"getAssistant","tags":["Assistants"],"summary":"Retrieve assistant","description":"Retrieves an assistant. Equivalent to OpenAI\'s retrieve assistants. \\n","parameters":[{"in":"path","name":"assistant_id","required":true,"schema":{"type":"string","example":"jan"},"description":"The ID of the assistant to retrieve.\\n"}],"responses":{"200":{"description":null,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/RetrieveAssistantResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl http://localhost:1337/v1/assistants/{assistant_id} \\\\\\n -H \\"Content-Type: application/json\\""},{"lang":"JavaScript","source":"const fetch = require(\'node-fetch\');\\n\\nlet assistantId = \'abc123\';\\n\\nfetch(`http://localhost:1337/v1/assistants/${assistantId}`, {\\n method: \'GET\',\\n headers: {\\n \'Content-Type\': \'application/json\'\\n }\\n})"},{"lang":"Node.js","source":"const fetch = require(\'node-fetch\');\\n\\nlet assistantId = \'abc123\';\\n\\nfetch(`http://localhost:1337/v1/assistants/${assistantId}`, {\\n method: \'GET\',\\n headers: {\\n \'Content-Type\': \'application/json\'\\n }\\n})"},{"lang":"Python","source":"import requests\\n\\nassistant_id = \'abc123\'\\n\\nresponse = requests.get(f\'http://localhost:1337/v1/assistants/{assistant_id}\', headers={\'Content-Type\': \'application/json\'})"}]}},"/threads/{thread_id}/messages":{"get":{"operationId":"listMessages","tags":["Messages"],"summary":"List messages","description":"Retrieves all messages from the given thread. Equivalent to OpenAI\'s list messages. \\n","parameters":[{"in":"path","name":"thread_id","required":true,"schema":{"type":"string"},"description":"The ID of the thread from which to retrieve messages.\\n"}],"responses":{"200":{"description":"List of messages retrieved successfully","content":{"application/json":{"schema":{"$ref":"#/components/schemas/ListMessagesResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl http://localhost:1337/v1/threads/{thread_id}/messages \\\\\\n -H \\"Content-Type: application/json\\"\\n"}]},"post":{"operationId":"createMessage","tags":["Messages"],"summary":"Create message","description":"Create a message. Equivalent to OpenAI\'s list messages. \\n","parameters":[{"in":"path","name":"thread_id","required":true,"schema":{"type":"string"},"description":"The ID of the thread to which the message will be posted.\\n"}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"type":"object","properties":{"role":{"type":"string","description":"Role of the sender, either \'user\' or \'assistant\'.\\n","example":"user","enum":["user","assistant"]},"content":{"type":"string","description":"Text content of the message.\\n","example":"How does AI work? Explain it in simple terms."}},"required":["role","content"]}}}},"responses":{"200":{"description":"Message created successfully","content":{"application/json":{"schema":{"$ref":"#/components/schemas/CreateMessageResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl -X POST http://localhost:1337/v1/threads/{thread_id}/messages \\\\\\n -H \\"Content-Type: application/json\\" \\\\\\n -d \'{\\n \\"role\\": \\"user\\",\\n \\"content\\": \\"How does AI work? Explain it in simple terms.\\"\\n }\'\\n"}]}},"/threads/{thread_id}/messages/{message_id}":{"get":{"operationId":"retrieveMessage","tags":["Messages"],"summary":"Retrieve message","description":"Retrieve a specific message from a thread using its thread_id and message_id. Equivalent to OpenAI\'s retrieve messages. \\n","parameters":[{"in":"path","name":"thread_id","required":true,"schema":{"type":"string"},"description":"The ID of the thread containing the message.\\n"},{"in":"path","name":"message_id","required":true,"schema":{"type":"string"},"description":"The ID of the message to retrieve.\\n"}],"responses":{"200":{"description":"OK","content":{"application/json":{"schema":{"$ref":"#/components/schemas/GetMessageResponse"}}}}},"x-codeSamples":[{"lang":"cURL","source":"curl http://localhost:1337/v1/threads/{thread_id}/messages/{message_id} \\\\\\n -H \\"Content-Type: application/json\\"\\n"}]}}},"x-webhooks":{"ModelObject":{"post":{"summary":"The model object","description":"Describe a model offering that can be used with the API. Equivalent to OpenAI\'s model object. \\n","operationId":"ModelObject","tags":["Models"],"requestBody":{"content":{"application/json":{"schema":{"$ref":"#/components/schemas/ModelObject"}}}}}},"AssistantObject":{"post":{"summary":"The assistant object","description":"Build assistants that can call models and use tools to perform tasks. Equivalent to OpenAI\'s assistants object. \\n","operationId":"AssistantObjects","tags":["Assistants"],"requestBody":{"content":{"application/json":{"schema":{"$ref":"#/components/schemas/AssistantObject"}}}}}},"MessageObject":{"post":{"summary":"The message object","description":"Information about a message in the thread. Equivalent to OpenAI\'s message object. \\n","operationId":"MessageObject","tags":["Messages"],"requestBody":{"content":{"application/json":{"schema":{"$ref":"#/components/schemas/MessageObject"}}}}}},"ThreadObject":{"post":{"summary":"The thread object","description":"Represents a thread that contains messages. Equivalent to OpenAI\'s thread object. ","operationId":"ThreadObject","tags":["Threads"],"requestBody":{"content":{"application/json":{"schema":{"$ref":"#/components/schemas/ThreadObject"}}}}}}},"components":{"schemas":{"ChatCompletionRequest":{"type":"object","properties":{"messages":{"type":"arrays","description":"Contains input data or prompts for the model to process.\\n","example":[{"content":"You are a helpful assistant.","role":"system"},{"content":"Hello!","role":"user"}]},"model":{"type":"string","example":"tinyllama-1.1b","description":"Specifies the model being used for inference or processing tasks.\\n"},"stream":{"type":"boolean","default":true,"description":"Enables continuous output generation, allowing for streaming of model responses.\\n"},"max_tokens":{"type":"number","default":2048,"description":"The maximum number of tokens the model will generate in a single response.\\n"},"stop":{"type":"arrays","example":["hello"],"description":"Defines specific tokens or phrases at which the model will stop generating further output.\\n"},"frequency_penalty":{"type":"number","default":0,"description":"Adjusts the likelihood of the model repeating words or phrases in its output.\\n"},"presence_penalty":{"type":"number","default":0,"description":"Influences the generation of new and varied concepts in the model\'s output.\\n"},"temperature":{"type":"number","default":0.7,"min":0,"max":1,"description":"Controls the randomness of the model\'s output.\\n"},"top_p":{"type":"number","default":0.95,"min":0,"max":1,"description":"Set probability threshold for more relevant outputs.\\n"}}},"ChatCompletionResponse":{"type":"object","description":"Description of the response structure","properties":{"choices":{"type":"array","description":"Array of choice objects","items":{"type":"object","properties":{"finish_reason":{"type":"string","nullable":true,"example":null,"description":"Reason for finishing the response, if applicable"},"index":{"type":"integer","example":0,"description":"Index of the choice"},"message":{"type":"object","properties":{"content":{"type":"string","example":"Hello user. What can I help you with?","description":"Content of the message"},"role":{"type":"string","example":"assistant","description":"Role of the sender"}}}}}},"created":{"type":"integer","example":1700193928,"description":"Timestamp of when the response was created"},"id":{"type":"string","example":"ebwd2niJvJB1Q2Whyvkz","description":"Unique identifier of the response"},"model":{"type":"string","nullable":true,"example":"_","description":"Model used for generating the response"},"object":{"type":"string","example":"chat.completion","description":"Type of the response object"},"system_fingerprint":{"type":"string","nullable":true,"example":"_","description":"System fingerprint"},"usage":{"type":"object","description":"Information about the usage of tokens","properties":{"completion_tokens":{"type":"integer","example":500,"description":"Number of tokens used for completion"},"prompt_tokens":{"type":"integer","example":33,"description":"Number of tokens used in the prompt"},"total_tokens":{"type":"integer","example":533,"description":"Total number of tokens used"}}}}},"Model":{"type":"object","properties":{"source_url":{"type":"string","format":"uri","description":"URL to the source of the model.","example":"https://huggingface.co/janhq/trinity-v1.2-GGUF/resolve/main/trinity-v1.2.Q4_K_M.gguf"},"id":{"type":"string","description":"Unique identifier used in chat-completions model_name, matches folder name.","example":"trinity-v1.2-7b"},"object":{"type":"string","example":"model"},"name":{"type":"string","description":"Name of the model.","example":"Trinity-v1.2 7B Q4"},"version":{"type":"string","default":"1.0","description":"The version number of the model."},"description":{"type":"string","description":"Description of the model.","example":"Trinity is an experimental model merge using the Slerp method. Recommended for daily assistance purposes."},"format":{"type":"string","description":"State format of the model, distinct from the engine.","example":"gguf"},"settings":{"type":"object","properties":{"ctx_len":{"type":"integer","description":"Context length.","example":4096},"prompt_template":{"type":"string","example":"<|im_start|>system\\n{system_message}<|im_end|>\\n<|im_start|>user\\n{prompt}<|im_end|>\\n<|im_start|>assistant"}},"additionalProperties":false},"parameters":{"type":"object","properties":{"temperature":{"example":0.7},"top_p":{"example":0.95},"stream":{"example":true},"max_tokens":{"example":4096},"stop":{"example":[]},"frequency_penalty":{"example":0},"presence_penalty":{"example":0}},"additionalProperties":false},"metadata":{"author":{"type":"string","example":"Jan"},"tags":{"example":["7B","Merged","Featured"]},"size":{"example":"4370000000,"},"cover":{"example":"https://raw.githubusercontent.com/janhq/jan/main/models/trinity-v1.2-7b/cover.png"}},"engine":{"example":"nitro"}}},"ListModelsResponse":{"type":"object","properties":{"object":{"type":"string","enum":["list"]},"data":{"type":"array","items":{"$ref":"#/components/schemas/Model"}}},"required":["object","data"]},"DownloadModelResponse":{"type":"object","properties":{"message":{"type":"string","description":"Message indicates Jan starting download corresponding model.","example":"Starting download mistral-ins-7b-q4"}}},"GetModelResponse":{"type":"object","properties":{"source_url":{"type":"string","format":"uri","description":"URL to the source of the model.","example":"https://huggingface.co/TheBloke/Mistral-7B-Instruct-v0.2-GGUF/resolve/main/mistral-7b-instruct-v0.2.Q4_K_M.gguf"},"id":{"type":"string","description":"Unique identifier used in chat-completions model_name, matches folder name.","example":"mistral-ins-7b-q4"},"object":{"type":"string","example":"model"},"name":{"type":"string","description":"Name of the model.","example":"Mistral Instruct 7B Q4"},"version":{"type":"string","default":"1.0","description":"The version number of the model."},"description":{"type":"string","description":"Description of the model.","example":"Trinity is an experimental model merge using the Slerp method. Recommended for daily assistance purposes."},"format":{"type":"string","description":"State format of the model, distinct from the engine.","example":"gguf"},"settings":{"type":"object","properties":{"ctx_len":{"type":"integer","description":"Context length.","example":4096},"prompt_template":{"type":"string","example":"[INST] {prompt} [/INST]"}},"additionalProperties":false},"parameters":{"type":"object","properties":{"temperature":{"example":0.7},"top_p":{"example":0.95},"stream":{"example":true},"max_tokens":{"example":4096},"stop":{"example":[]},"frequency_penalty":{"example":0},"presence_penalty":{"example":0}},"additionalProperties":false},"metadata":{"author":{"type":"string","example":"MistralAI"},"tags":{"example":["7B","Featured","Foundation Model"]},"size":{"example":"4370000000,"},"cover":{"example":"https://raw.githubusercontent.com/janhq/jan/main/models/mistral-ins-7b-q4/cover.png"}},"engine":{"example":"nitro"}}},"DeleteModelResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the model that was deleted.","example":"mistral-ins-7b-q4"},"object":{"type":"string","description":"Type of the object, indicating it\'s a model.","default":"model"},"deleted":{"type":"boolean","description":"Indicates whether the model was successfully deleted.","example":true}}},"ThreadObject":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the thread, defaults to foldername.\\n","example":"thread_...."},"object":{"type":"string","description":"Type of the object, defaults to thread.\\n","example":"thread"},"title":{"type":"string","description":"A brief summary or description of the thread, defaults to an empty string.\\n","example":"funny physics joke"},"assistants":{"type":"array","description":"","items":{"properties":{"assistant_id":{"type":"string","description":"The identifier of assistant, defaults to \\"jan\\"\\n","example":"jan"},"model":{"type":"object","properties":{"id":{"type":"string","description":"","example":"..."},"settings":{"type":"object","description":"Defaults to and overrides assistant.json\'s \\"settings\\" (and if none, then model.json \\"settings\\")\\n"},"parameters":{"type":"object","description":"Defaults to and overrides assistant.json\'s \\"parameters\\" (and if none, then model.json \\"parameters\\")\\n"}}}}}},"created":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the thread, defaults to file creation time.\\n","example":1231231},"metadata":{"type":"object","description":"Metadata associated with the thread, defaults to an empty object.\\n","example":{}}}},"CreateThreadObject":{"type":"object","properties":{"object":{"type":"string","description":"Type of the object, indicating it\'s a thread.","example":"thread"},"title":{"type":"string","description":"A brief summary or description of the thread, defaults to an empty string.\\n","example":"funny physics joke"},"assistants":{"type":"array","description":"assistant involved in the thread","items":{"properties":{"assistant_id":{"type":"string","description":"The identifier of assistant, defaults to \\"jan\\"\\n","example":"jan"},"assistant_name":{"type":"string","description":"The name of assistant, defaults to \\"Jan\\"\\n","example":"Jan"},"instructions":{"type":"string","description":"The instruction of assistant, defaults to \\"Be my grammar corrector\\"\\n"},"model":{"type":"object","properties":{"id":{"type":"string","description":"Model id","example":"mistral-ins-7b-q4"},"settings":{"type":"object","description":"Defaults to and overrides assistant.json\'s \\"settings\\" (and if none, then model.json \\"settings\\")\\n"},"parameters":{"type":"object","description":"Defaults to and overrides assistant.json\'s \\"parameters\\" (and if none, then model.json \\"parameters\\")\\n"},"engine":{"type":"string","description":"Engine id","example":"nitro"}}}}}},"metadata":{"type":"object","description":"Metadata associated with the thread, defaults to an empty object.\\n"}}},"CreateThreadResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the newly created thread.","example":"thread_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s a thread.","example":"thread"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the thread.","example":1699014083},"metadata":{"type":"object","description":"Metadata associated with the newly created thread.","example":{}}}},"GetThreadResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the thread.","example":"thread_abc123"},"object":{"type":"string","description":"Type of the object","example":"thread"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the thread.","example":1699014083},"assistants":{"type":"array","items":{"type":"string"},"description":"List of assistants involved in the thread.","example":["assistant-001"]},"metadata":{"type":"object","description":"Metadata associated with the thread.","example":{}},"messages":{"type":"array","items":{"type":"string"},"description":"List of messages within the thread.","example":[]}}},"DeleteThreadResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the deleted thread.","example":"thread_abc123"},"object":{"type":"string","description":"Type of the object, indicating the thread has been deleted.","example":"thread.deleted"},"deleted":{"type":"boolean","description":"Indicates whether the thread was successfully deleted.","example":true}}},"ThreadMessageObject":{"type":"object","properties":{"role":{"type":"string","description":"\\"Role of the sender, either \'user\' or \'assistant\'.\\"\\n","enum":["user","assistant"]},"content":{"type":"string","description":"\\"Text content of the message.\\"\\n"},"file_ids":{"type":"array","items":{"type":"string"},"description":"\\"Array of file IDs associated with the message, if any.\\"\\n"}}},"ModifyThreadResponse":{"type":"object","properties":{"id":{"type":"string","description":"\\"The identifier of the modified thread.\\"\\n","example":"thread_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s a thread.","example":"thread"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the thread.","example":1699014083},"metadata":{"type":"object","description":"Metadata associated with the modified thread.","example":{}}}},"RetrieveAssistantResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the assistant.","example":"asst_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s an assistant.","default":"assistant"},"version":{"type":"integer","description":"Version number of the assistant.","example":1},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the assistant.","example":1698984975},"name":{"type":"string","description":"Name of the assistant.","example":"Math Tutor"},"description":{"type":"string","description":"Description of the assistant. Can be null.","example":null},"avatar":{"type":"string","description":"URL of the assistant\'s avatar. Jan-specific property.","example":"https://pic.png"},"models":{"type":"array","description":"List of models associated with the assistant. Jan-specific property.","items":{"type":"object","properties":{"model_id":{"type":"string","example":"model_0"}}}},"instructions":{"type":"string","description":"A system prompt for the assistant.","example":"Be concise"},"events":{"type":"object","description":"Event subscription settings for the assistant.","properties":{"in":{"type":"array","items":{"type":"string"}},"out":{"type":"array","items":{"type":"string"}}}},"metadata":{"type":"object","description":"Metadata associated with the assistant."}}},"ListMessageObject":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the message.","example":"msg_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s a thread message.","example":"thread.message"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the message.","example":1699017614},"thread_id":{"type":"string","description":"Identifier of the thread to which this message belongs.","example":"thread_abc123"},"role":{"type":"string","description":"Role of the sender, either \'user\' or \'assistant\'.","example":"user"},"content":{"type":"array","items":{"type":"object","properties":{"type":{"type":"string","description":"Type of content, e.g., \'text\'."},"text":{"type":"object","properties":{"value":{"type":"string","description":"Text content of the message.","example":"How does AI work? Explain it in simple terms."},"annotations":{"type":"array","items":{"type":"string"},"description":"Annotations for the text content, if any."}}}}}},"file_ids":{"type":"array","items":{"type":"string"},"description":"Array of file IDs associated with the message, if any.","example":[]},"assistant_id":{"type":"string","description":"Identifier of the assistant involved in the message, if applicable.","example":null},"run_id":{"type":"string","description":"Run ID associated with the message, if applicable.","example":null},"metadata":{"type":"object","description":"Metadata associated with the message.","example":{}}}},"ListMessagesResponse":{"type":"object","properties":{"object":{"type":"string","description":"Type of the object, indicating it\'s a list.","default":"list"},"data":{"type":"array","items":{"$ref":"#/components/schemas/ListMessageObject"}},"first_id":{"type":"string","description":"Identifier of the first message in the list.","example":"msg_abc123"},"last_id":{"type":"string","description":"Identifier of the last message in the list.","example":"msg_abc456"},"has_more":{"type":"boolean","description":"Indicates whether there are more messages to retrieve.","example":false}}},"CreateMessageResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the created message.","example":"msg_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s a thread message.","example":"thread.message"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the message.","example":1699017614},"thread_id":{"type":"string","description":"Identifier of the thread to which this message belongs.","example":"thread_abc123"},"role":{"type":"string","description":"Role of the sender, either \'user\' or \'assistant\'.","example":"user"},"content":{"type":"array","items":{"type":"object","properties":{"type":{"type":"string","description":"Type of content, e.g., \'text\'.","example":"text"},"text":{"type":"object","properties":{"value":{"type":"string","description":"Text content of the message.","example":"How does AI work? Explain it in simple terms."},"annotations":{"type":"array","items":{"type":"string"},"description":"Annotations for the text content, if any.","example":[]}}}}}},"file_ids":{"type":"array","items":{"type":"string"},"description":"Array of file IDs associated with the message, if any.","example":[]},"assistant_id":{"type":"string","description":"Identifier of the assistant involved in the message, if applicable.","example":null},"run_id":{"type":"string","description":"Run ID associated with the message, if applicable.","example":null},"metadata":{"type":"object","description":"Metadata associated with the message.","example":{}}}},"GetMessageResponse":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the message.","example":"msg_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s a thread message.","default":"thread.message"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the message.","example":1699017614},"thread_id":{"type":"string","description":"Identifier of the thread to which this message belongs.","example":"thread_abc123"},"role":{"type":"string","description":"Role of the sender, either \'user\' or \'assistant\'.","example":"user"},"content":{"type":"array","items":{"type":"object","properties":{"type":{"type":"string","description":"Type of content, e.g., \'text\'.","example":"text"},"text":{"type":"object","properties":{"value":{"type":"string","description":"Text content of the message.","example":"How does AI work? Explain it in simple terms."},"annotations":{"type":"array","items":{"type":"string"},"description":"Annotations for the text content, if any.","example":[]}}}}}},"file_ids":{"type":"array","items":{"type":"string"},"description":"Array of file IDs associated with the message, if any.","example":[]},"assistant_id":{"type":"string","description":"Identifier of the assistant involved in the message, if applicable.","example":null},"run_id":{"type":"string","description":"Run ID associated with the message, if applicable.","example":null},"metadata":{"type":"object","description":"Metadata associated with the message.","example":{}}}},"ModelObject":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the model.\\n","example":"trinity-v1.2-7b"},"object":{"type":"string","description":"The type of the object, indicating it\'s a model.\\n","default":"model"},"created":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the model.\\n","example":1253935178},"owned_by":{"type":"string","description":"The entity that owns the model.\\n","example":"_"}}},"AssistantObject":{"type":"object","properties":{"id":{"type":"string","description":"The identifier of the assistant.","example":"asst_abc123"},"object":{"type":"string","description":"Type of the object, indicating it\'s an assistant.","default":"assistant"},"version":{"type":"integer","description":"Version number of the assistant.","example":1},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the assistant.","example":1698984975},"name":{"type":"string","description":"Name of the assistant.","example":"Math Tutor"},"description":{"type":"string","description":"Description of the assistant. Can be null.","example":null},"avatar":{"type":"string","description":"URL of the assistant\'s avatar. Jan-specific property.","example":"https://pic.png"},"models":{"type":"array","description":"List of models associated with the assistant. Jan-specific property.","items":{"type":"object","properties":{"model_id":{"type":"string","example":"model_0"}}}},"instructions":{"type":"string","description":"A system prompt for the assistant.","example":"Be concise"},"events":{"type":"object","description":"Event subscription settings for the assistant.","properties":{"in":{"type":"array","items":{"type":"string"}},"out":{"type":"array","items":{"type":"string"}}}},"metadata":{"type":"object","description":"Metadata associated with the assistant."}}},"MessageObject":{"type":"object","properties":{"id":{"type":"string","description":"Sequential or UUID identifier of the message.\\n","example":0},"object":{"type":"string","description":"Type of the object, defaults to \'thread.message\'.\\n","example":"thread.message"},"created_at":{"type":"integer","format":"int64","description":"Unix timestamp representing the creation time of the message.\\n"},"thread_id":{"type":"string","description":"Identifier of the thread to which this message belongs. Defaults to parent thread.\\n","example":"thread_asdf"},"assistant_id":{"type":"string","description":"Identifier of the assistant involved in the message. Defaults to parent thread.\\n","example":"jan"},"role":{"type":"string","enum":["user","assistant"],"description":"Role of the sender, either \'user\' or \'assistant\'.\\n"},"content":{"type":"array","items":{"type":"object","properties":{"type":{"type":"string","description":"Type of content, e.g., \'text\'.\\n"},"text":{"type":"object","properties":{"value":{"type":"string","description":"Text content of the message.\\n","example":"Hi!?"},"annotations":{"type":"array","items":{"type":"string"},"description":"Annotations for the text content, if any.\\n","example":[]}}}}}},"metadata":{"type":"object","description":"Metadata associated with the message, defaults to an empty object.\\n","example":{}}}}}}}}},"docusaurus-theme-redoc":{"theme-redoc":{"lightTheme":{"typography":{"fontFamily":"var(--ifm-font-family-base)","fontSize":"var(--ifm-font-size-base)","lineHeight":"var(--ifm-line-height-base)","fontWeightLight":"var(--ifm-font-weight-light)","fontWeightRegular":"var(--ifm-font-weight-base)","fontWeightBold":"var(--ifm-font-weight-bold)","headings":{"fontFamily":"var(--ifm-heading-font-family)","fontWeight":"var(--ifm-heading-font-weight)","lineHeight":"var(--ifm-heading-line-height)"},"code":{"fontFamily":"var(--ifm-font-family-monospace)","lineHeight":"var(--ifm-pre-line-height)"}},"sidebar":{"width":"300px","backgroundColor":"#ffffff"},"rightPanel":{"backgroundColor":"#303846"},"colors":{"primary":{"main":"#1a73e8"}},"theme":{"prism":{"additionalLanguages":["scala"]}}},"darkTheme":{"typography":{"fontFamily":"var(--ifm-font-family-base)","fontSize":"var(--ifm-font-size-base)","lineHeight":"var(--ifm-line-height-base)","fontWeightLight":"var(--ifm-font-weight-light)","fontWeightRegular":"var(--ifm-font-weight-base)","fontWeightBold":"var(--ifm-font-weight-bold)","headings":{"fontFamily":"var(--ifm-heading-font-family)","fontWeight":"var(--ifm-heading-font-weight)","lineHeight":"var(--ifm-heading-line-height)"},"code":{"fontFamily":"var(--ifm-font-family-monospace)","lineHeight":"var(--ifm-pre-line-height)"}},"sidebar":{"width":"300px","backgroundColor":"rgb(24, 25, 26)","textColor":"#f5f6f7","arrow":{"color":"#f5f6f7"}},"colors":{"text":{"primary":"#f5f6f7","secondary":"rgba(255, 255, 255, 1)"},"gray":{"50":"#FAFAFA","100":"#F5F5F5"},"border":{"dark":"#ffffff","light":"rgba(0,0,0, 0.1)"},"primary":{"main":"#1a73e8"}},"schema":{"nestedBackground":"rgb(24, 25, 26)","typeNameColor":"rgba(255, 255, 255, 1)","typeTitleColor":"rgba(255, 255, 255, 1)"},"theme":{"prism":{"additionalLanguages":["scala"]}}},"options":{"scrollYOffset":"nav.navbar","expandSingleSchemaField":true,"menuToggle":true,"suppressWarnings":true,"requiredPropsFirst":true,"noAutoAuth":true,"hideDownloadButton":true}}},"docusaurus-plugin-google-tag-manager":{"default":{"containerId":"G-YK53MX8M8M","id":"default"}},"docusaurus-plugin-content-docs":{"default":{"path":"/","versions":[{"name":"current","label":"Next","isLast":true,"path":"/","mainDocId":"about/about","docs":[{"id":"about/2035","path":"/about/2035"},{"id":"about/about","path":"/about","sidebar":"aboutSidebar"},{"id":"about/faq","path":"/about/faq","sidebar":"aboutSidebar"},{"id":"about/roadmap","path":"/about/roadmap"},{"id":"about/vision","path":"/vision"},{"id":"acknowledgements","path":"/acknowledgements","sidebar":"aboutSidebar"},{"id":"community/community","path":"/community","sidebar":"aboutSidebar"},{"id":"developer/framework/engineering/assistants","path":"/developer/framework/engineering/assistants","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/chats","path":"/developer/framework/engineering/chats","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/engine","path":"/developer/framework/engineering/engine","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/files","path":"/developer/framework/engineering/files","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/messages","path":"/developer/framework/engineering/messages","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/models","path":"/developer/framework/engineering/models","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/README","path":"/developer/engineering","sidebar":"developerSidebar"},{"id":"developer/framework/engineering/threads","path":"/developer/framework/engineering/threads","sidebar":"developerSidebar"},{"id":"developer/framework/product/chat","path":"/developer/framework/product/chat","sidebar":"developerSidebar"},{"id":"developer/framework/product/hub","path":"/developer/framework/product/hub","sidebar":"developerSidebar"},{"id":"developer/framework/product/jan","path":"/developer/framework/product/jan","sidebar":"developerSidebar"},{"id":"developer/framework/product/README","path":"/developer/product","sidebar":"developerSidebar"},{"id":"developer/framework/product/settings","path":"/developer/framework/product/settings","sidebar":"developerSidebar"},{"id":"developer/framework/product/system-monitor","path":"/developer/framework/product/system-monitor","sidebar":"developerSidebar"},{"id":"developer/framework/README","path":"/developer/framework/","sidebar":"developerSidebar"},{"id":"developer/overview/architecture","path":"/developer/architecture","sidebar":"developerSidebar"},{"id":"developer/overview/file-based","path":"/developer/file-based","sidebar":"developerSidebar"},{"id":"developer/overview/install-and-prerequisites","path":"/developer/prereq","sidebar":"developerSidebar"},{"id":"developer/overview/README","path":"/developer","sidebar":"developerSidebar"},{"id":"developer/overview/user-interface","path":"/developer/ui","sidebar":"developerSidebar"},{"id":"ecosystem/ecosystem","path":"/ecosystem/","sidebar":"ecosystemSidebar"},{"id":"events/hcmc-oct23","path":"/events/hcmc-oct23"},{"id":"events/nvidia-llm-day-nov-23","path":"/events/nvidia-llm-day-nov-23"},{"id":"features/agents-framework","path":"/features/agents-framework","sidebar":"productSidebar"},{"id":"features/api-server","path":"/features/api-server","sidebar":"productSidebar"},{"id":"features/data-security","path":"/features/data-security","sidebar":"productSidebar"},{"id":"features/extensions-framework","path":"/features/extensions-framework","sidebar":"productSidebar"},{"id":"features/features","path":"/features/","sidebar":"productSidebar"},{"id":"features/local","path":"/features/local","sidebar":"productSidebar"},{"id":"features/remote","path":"/features/remote","sidebar":"productSidebar"},{"id":"foundry/foundry","path":"/foundry/"},{"id":"guides/extensions/extensions","path":"/extensions","sidebar":"guidesSidebar"},{"id":"guides/get-started/hardware-setup","path":"/guides/hardware"},{"id":"guides/get-started/overview","path":"/guides","sidebar":"guidesSidebar"},{"id":"guides/get-started/quickstart","path":"/guides/quickstart","sidebar":"guidesSidebar"},{"id":"guides/get-started/settingup-gpu","path":"/guides/hardware/gpu"},{"id":"guides/inference/overview-inference","path":"/guides/engines"},{"id":"guides/installation/docker","path":"/guides/install/server"},{"id":"guides/installation/linux","path":"/guides/install/linux"},{"id":"guides/installation/mac","path":"/guides/install/mac"},{"id":"guides/installation/README","path":"/guides/install/"},{"id":"guides/installation/windows","path":"/guides/install/windows"},{"id":"guides/integrations/crewai","path":"/integrations/crewai"},{"id":"guides/integrations/discord","path":"/integrations/discord","sidebar":"guidesSidebar"},{"id":"guides/integrations/interpreter","path":"/integrations/interpreter","sidebar":"guidesSidebar"},{"id":"guides/integrations/overview-integration","path":"/integrationss"},{"id":"guides/integrations/raycast","path":"/integrations/raycast","sidebar":"guidesSidebar"},{"id":"guides/integrations/README","path":"/integrations/","sidebar":"guidesSidebar"},{"id":"guides/integrations/router","path":"/integrations/openrouter","sidebar":"guidesSidebar"},{"id":"guides/integrations/unsloth","path":"/integrations/unsloth"},{"id":"guides/integrations/vscode","path":"/integrations/continue","sidebar":"guidesSidebar"},{"id":"guides/local-providers/llamacpp","path":"/guides/engines/llamacpp","sidebar":"guidesSidebar"},{"id":"guides/local-providers/lmstudio","path":"/guides/engines/lmstudio","sidebar":"guidesSidebar"},{"id":"guides/local-providers/ollama","path":"/guides/engines/ollama","sidebar":"guidesSidebar"},{"id":"guides/local-providers/README","path":"/guides/engines/local","sidebar":"guidesSidebar"},{"id":"guides/local-providers/tensorrt","path":"/guides/engines/tensorrt-llm","sidebar":"guidesSidebar"},{"id":"guides/providers/tensorrt-llm","path":"/guides/providers/tensorrt-llm"},{"id":"guides/remote-providers/claude","path":"/guides/engines/claude"},{"id":"guides/remote-providers/groq","path":"/guides/engines/groq","sidebar":"guidesSidebar"},{"id":"guides/remote-providers/mistral","path":"/guides/engines/mistral","sidebar":"guidesSidebar"},{"id":"guides/remote-providers/openai","path":"/guides/engines/openai","sidebar":"guidesSidebar"},{"id":"guides/remote-providers/README","path":"/guides/engines/remote","sidebar":"guidesSidebar"},{"id":"guides/remote-providers/remote-server-integration","path":"/guides/engines/remote-server","sidebar":"guidesSidebar"},{"id":"guides/troubleshooting","path":"/troubleshooting","sidebar":"guidesSidebar"},{"id":"guides/user-guides/advanced-settings","path":"/guides/advanced","sidebar":"guidesSidebar"},{"id":"guides/user-guides/jan-data-folder","path":"/guides/data-folder"},{"id":"guides/user-guides/local-server","path":"/guides/local-api","sidebar":"guidesSidebar"},{"id":"guides/user-guides/manage-assistants","path":"/guides/assistants"},{"id":"guides/user-guides/manage-models","path":"/guides/models","sidebar":"guidesSidebar"},{"id":"guides/user-guides/manage-threads","path":"/guides/threads","sidebar":"guidesSidebar"},{"id":"guides/user-guides/overview-guides","path":"/guides/overview"},{"id":"hardware/community","path":"/hardware/community"},{"id":"hardware/concepts/chassis","path":"/hardware/concepts/chassis"},{"id":"hardware/concepts/concepts","path":"/hardware/concepts"},{"id":"hardware/concepts/cpu-and-ram","path":"/hardware/concepts/cpu-and-ram"},{"id":"hardware/concepts/gpu-and-vram","path":"/hardware/concepts/gpu-and-vram"},{"id":"hardware/concepts/motherboard","path":"/hardware/concepts/motherboard"},{"id":"hardware/concepts/network","path":"/hardware/concepts/network"},{"id":"hardware/concepts/power","path":"/hardware/concepts/power"},{"id":"hardware/concepts/storage","path":"/hardware/concepts/storage"},{"id":"hardware/examples/4090x2-@dan-jan","path":"/hardware/examples/4090x2-@dan-jan"},{"id":"hardware/hardware","path":"/hardware/"},{"id":"hardware/overview/cloud-vs-self-hosting","path":"/hardware/overview/cloud-vs-self-hosting"},{"id":"hardware/overview/cpu-vs-gpu","path":"/hardware/overview/cpu-vs-gpu"},{"id":"hardware/recommendations/by-budget","path":"/hardware/recommendations/by-budget"},{"id":"hardware/recommendations/by-hardware","path":"/hardware/recommendations/by-hardware"},{"id":"hardware/recommendations/by-model","path":"/hardware/recommendations/by-model"},{"id":"hardware/recommendations/by-usecase","path":"/hardware/recommendations/by-usecase"},{"id":"how-we-work","path":"/how-we-work","sidebar":"aboutSidebar"},{"id":"how-we-work/analytics/analytics","path":"/how-we-work/analytics","sidebar":"aboutSidebar"},{"id":"how-we-work/engineering/ci-cd","path":"/engineering/ci-cd","sidebar":"aboutSidebar"},{"id":"how-we-work/engineering/engineering","path":"/engineering","sidebar":"aboutSidebar"},{"id":"how-we-work/engineering/qa","path":"/engineering/qa","sidebar":"aboutSidebar"},{"id":"how-we-work/product-design/product-design","path":"/how-we-work/product-design","sidebar":"aboutSidebar"},{"id":"how-we-work/project-management/project-management","path":"/how-we-work/project-management","sidebar":"aboutSidebar"},{"id":"how-we-work/strategy/strategy","path":"/how-we-work/strategy/","sidebar":"aboutSidebar"},{"id":"how-we-work/website-docs/website-docs","path":"/how-we-work/website-docs/","sidebar":"aboutSidebar"},{"id":"integrations","path":"/integrations","sidebar":"ecosystemSidebar"},{"id":"integrations/langchain","path":"/integrations/langchain","sidebar":"ecosystemSidebar"},{"id":"integrations/llamacpp","path":"/integrations/llamacpp","sidebar":"ecosystemSidebar"},{"id":"integrations/ollama","path":"/integrations/ollama","sidebar":"ecosystemSidebar"},{"id":"integrations/openai","path":"/integrations/openai","sidebar":"ecosystemSidebar"},{"id":"integrations/openrouter","path":"/integrations/openrouter","sidebar":"ecosystemSidebar"},{"id":"partners/become-a-partner","path":"/partners/become-a-partner","sidebar":"ecosystemSidebar"},{"id":"partners/partners","path":"/partners/","sidebar":"ecosystemSidebar"},{"id":"pending-content/blogpost/finetune-with-docs","path":"/tutorial/how-to-fine-tune-llms"},{"id":"pending-content/blogpost/surpassing-chatgpt-with-open-source-alternatives","path":"/blog/surpassing-chatgpt-with-open-source-alternatives"},{"id":"platforms/desktop","path":"/desktop","sidebar":"productSidebar"},{"id":"platforms/hub","path":"/platforms/hub"},{"id":"platforms/mobile","path":"/mobile"},{"id":"pricing/pricing","path":"/pricing","sidebar":"pricingSidebar"},{"id":"privacy/privacy","path":"/privacy/"},{"id":"releases/changelog/changelog-v0.2.0","path":"/changelog/changelog-v0.2.0","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.2.1","path":"/changelog/changelog-v0.2.1","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.2.2","path":"/changelog/changelog-v0.2.2","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.2.3","path":"/changelog/changelog-v0.2.3","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.3.0","path":"/changelog/changelog-v0.3.0","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.3.1","path":"/changelog/changelog-v0.3.1","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.3.2","path":"/changelog/changelog-v0.3.2","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.3.3","path":"/changelog/changelog-v0.3.3","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.0","path":"/changelog/changelog-v0.4.0","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.1","path":"/changelog/changelog-v0.4.1","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.2","path":"/changelog/changelog-v0.4.2","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.3","path":"/changelog/changelog-v0.4.3","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.4","path":"/changelog/changelog-v0.4.4","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.5","path":"/changelog/changelog-v0.4.5","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.6","path":"/changelog/changelog-v0.4.6","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.7","path":"/changelog/changelog-v0.4.7","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.8","path":"/changelog/changelog-v0.4.8","sidebar":"releasesSidebar"},{"id":"releases/changelog/changelog-v0.4.9","path":"/changelog/changelog-v0.4.9","sidebar":"releasesSidebar"},{"id":"releases/changelog/README","path":"/changelog","sidebar":"releasesSidebar"},{"id":"server-suite/admin-console","path":"/server-suite/admin-console"},{"id":"server-suite/audit-compliance","path":"/server-suite/audit-compliance"},{"id":"server-suite/enterprise","path":"/enterprise"},{"id":"server-suite/home-server","path":"/home-server","sidebar":"productSidebar"},{"id":"server-suite/identity-access-management","path":"/server-suite/identity-access-management"},{"id":"server-suite/observability","path":"/server-suite/observability"},{"id":"solutions/ai-employees","path":"/solutions/ai-employees"},{"id":"solutions/ai-pc","path":"/solutions/ai-pc","sidebar":"solutionSidebar"},{"id":"solutions/chatgpt-alternative","path":"/solutions/chatgpt-alternative","sidebar":"solutionSidebar"},{"id":"solutions/consultants","path":"/solutions/consultants","sidebar":"solutionSidebar"},{"id":"solutions/developers","path":"/solutions/developers","sidebar":"solutionSidebar"},{"id":"solutions/enterprises","path":"/solutions/enterprises","sidebar":"solutionSidebar"},{"id":"solutions/finance","path":"/solutions/finance","sidebar":"solutionSidebar"},{"id":"solutions/government","path":"/solutions/government","sidebar":"solutionSidebar"},{"id":"solutions/healthcare","path":"/solutions/healthcare","sidebar":"solutionSidebar"},{"id":"solutions/legal","path":"/solutions/legal","sidebar":"solutionSidebar"},{"id":"solutions/startups","path":"/solutions/startups","sidebar":"solutionSidebar"},{"id":"studio/studio","path":"/studio/"},{"id":"support/support","path":"/support/"},{"id":"team/contributor-program","path":"/team/contributor-program","sidebar":"aboutSidebar"},{"id":"team/join-us","path":"/team/join-us","sidebar":"aboutSidebar"},{"id":"team/team","path":"/team/","sidebar":"aboutSidebar"},{"id":"template/QA_script","path":"/template/QA_script"},{"id":"wall-of-love","path":"/wall-of-love","sidebar":"aboutSidebar"}],"draftIds":[],"sidebars":{"aboutSidebar":{"link":{"path":"/about","label":"What is Jan?"}},"productSidebar":{"link":{"path":"/desktop","label":"platforms/desktop"}},"solutionSidebar":{"link":{"path":"/solutions/ai-pc","label":"solutions/ai-pc"}},"pricingSidebar":{"link":{"path":"/pricing","label":"pricing/pricing"}},"ecosystemSidebar":{"link":{"path":"/ecosystem/","label":"ecosystem/ecosystem"}},"guidesSidebar":{"link":{"path":"/guides","label":"guides/get-started/overview"}},"developerSidebar":{"link":{"path":"/developer","label":"Overview"}},"releasesSidebar":{"link":{"path":"/changelog","label":"Changelog"}}}}],"breadcrumbs":true}}}'),s=JSON.parse('{"defaultLocale":"en","locales":["en"],"path":"i18n","currentLocale":"en","localeConfigs":{"en":{"label":"English","direction":"ltr","htmlLang":"en","calendar":"gregory","path":"en"}}}');var i=n(22654);const l=JSON.parse('{"docusaurusVersion":"3.1.1","siteVersion":"0.0.0","pluginVersions":{"docusaurus-plugin-content-docs":{"type":"package","name":"@docusaurus/plugin-content-docs","version":"3.1.1"},"docusaurus-plugin-content-blog":{"type":"package","name":"@docusaurus/plugin-content-blog","version":"3.1.1"},"docusaurus-plugin-content-pages":{"type":"package","name":"@docusaurus/plugin-content-pages","version":"3.1.1"},"docusaurus-plugin-google-tag-manager":{"type":"package","name":"@docusaurus/plugin-google-tag-manager","version":"3.1.1"},"docusaurus-plugin-sitemap":{"type":"package","name":"@docusaurus/plugin-sitemap","version":"3.1.1"},"docusaurus-plugin-redoc":{"type":"package","name":"docusaurus-plugin-redoc","version":"2.0.2"},"docusaurus-theme-classic":{"type":"package","name":"@docusaurus/theme-classic","version":"3.1.1"},"docusaurus-theme-search-algolia":{"type":"package","name":"@docusaurus/theme-search-algolia","version":"3.1.1"},"docusaurus-theme-redoc":{"type":"package","name":"docusaurus-theme-redoc","version":"2.0.2"},"docusaurus-plugin-sass":{"type":"package","name":"docusaurus-plugin-sass","version":"0.2.5"},"docusaurus-tailwindcss":{"type":"local"},"posthog-docusaurus":{"type":"package","name":"posthog-docusaurus","version":"2.0.0"},"docusaurus-plugin-client-redirects":{"type":"package","name":"@docusaurus/plugin-client-redirects","version":"3.1.1"},"changelog-plugin":{"type":"project"},"@scalar/docusaurus":{"type":"package","name":"@scalar/docusaurus","version":"0.1.15"},"docusaurus-theme-live-codeblock":{"type":"package","name":"@docusaurus/theme-live-codeblock","version":"3.1.1"},"docusaurus-theme-mermaid":{"type":"package","name":"@docusaurus/theme-mermaid","version":"3.1.1"}}}');var c=n(74848);const u={siteConfig:a.default,siteMetadata:l,globalData:o,i18n:s,codeTranslations:i},d=r.createContext(u);function p(e){let{children:t}=e;return(0,c.jsx)(d.Provider,{value:u,children:t})}},67489:(e,t,n)=>{"use strict";n.d(t,{A:()=>f});var r=n(96540),a=n(38193),o=n(5260),s=n(70440),i=n(6011),l=n(74848);function c(e){let{error:t,tryAgain:n}=e;return(0,l.jsxs)("div",{style:{display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"flex-start",minHeight:"100vh",width:"100%",maxWidth:"80ch",fontSize:"20px",margin:"0 auto",padding:"1rem"},children:[(0,l.jsx)("h1",{style:{fontSize:"3rem"},children:"This page crashed"}),(0,l.jsx)("button",{type:"button",onClick:n,style:{margin:"1rem 0",fontSize:"2rem",cursor:"pointer",borderRadius:20,padding:"1rem"},children:"Try again"}),(0,l.jsx)(u,{error:t})]})}function u(e){let{error:t}=e;const n=(0,s.getErrorCausalChain)(t).map((e=>e.message)).join("\n\nCause:\n");return(0,l.jsx)("p",{style:{whiteSpace:"pre-wrap"},children:n})}function d(e){let{error:t,tryAgain:n}=e;return(0,l.jsxs)(f,{fallback:()=>(0,l.jsx)(c,{error:t,tryAgain:n}),children:[(0,l.jsx)(o.A,{children:(0,l.jsx)("title",{children:"Page Error"})}),(0,l.jsx)(i.default,{children:(0,l.jsx)(c,{error:t,tryAgain:n})})]})}const p=e=>(0,l.jsx)(d,{...e});class f extends r.Component{constructor(e){super(e),this.state={error:null}}componentDidCatch(e){a.default.canUseDOM&&this.setState({error:e})}render(){const{children:e}=this.props,{error:t}=this.state;if(t){const e={error:t,tryAgain:()=>this.setState({error:null})};return(this.props.fallback??p)(e)}return e??null}}},38193:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>a});const r="undefined"!=typeof window&&"document"in window&&"createElement"in window.document,a={canUseDOM:r,canUseEventListeners:r&&("addEventListener"in window||"attachEvent"in window),canUseIntersectionObserver:r&&"IntersectionObserver"in window,canUseViewport:r&&"screen"in window}},5260:(e,t,n)=>{"use strict";n.d(t,{A:()=>o});n(96540);var r=n(80545),a=n(74848);function o(e){return(0,a.jsx)(r.mg,{...e})}},28774:(e,t,n)=>{"use strict";n.d(t,{A:()=>f});var r=n(96540),a=n(54625),o=n(70440),s=n(44586),i=n(16654),l=n(38193),c=n(63427),u=n(86025),d=n(74848);function p(e,t){let{isNavLink:n,to:p,href:f,activeClassName:m,isActive:h,"data-noBrokenLinkCheck":g,autoAddBaseUrl:b=!0,...y}=e;const{siteConfig:{trailingSlash:v,baseUrl:w}}=(0,s.A)(),{withBaseUrl:x}=(0,u.h)(),k=(0,c.A)(),_=(0,r.useRef)(null);(0,r.useImperativeHandle)(t,(()=>_.current));const S=p||f;const E=(0,i.A)(S),j=S?.replace("pathname://","");let T=void 0!==j?(A=j,b&&(e=>e.startsWith("/"))(A)?x(A):A):void 0;var A;T&&E&&(T=(0,o.applyTrailingSlash)(T,{trailingSlash:v,baseUrl:w}));const C=(0,r.useRef)(!1),R=n?a.k2:a.N_,I=l.default.canUseIntersectionObserver,O=(0,r.useRef)(),L=()=>{C.current||null==T||(window.docusaurus.preload(T),C.current=!0)};(0,r.useEffect)((()=>(!I&&E&&null!=T&&window.docusaurus.prefetch(T),()=>{I&&O.current&&O.current.disconnect()})),[O,T,I,E]);const N=T?.startsWith("#")??!1,P=!y.target||"_self"===y.target,M=!T||!E||!P||N;return g||!N&&M||k.collectLink(T),y.id&&k.collectAnchor(y.id),M?(0,d.jsx)("a",{ref:_,href:T,...S&&!E&&{target:"_blank",rel:"noopener noreferrer"},...y}):(0,d.jsx)(R,{...y,onMouseEnter:L,onTouchStart:L,innerRef:e=>{_.current=e,I&&e&&E&&(O.current=new window.IntersectionObserver((t=>{t.forEach((t=>{e===t.target&&(t.isIntersecting||t.intersectionRatio>0)&&(O.current.unobserve(e),O.current.disconnect(),null!=T&&window.docusaurus.prefetch(T))}))})),O.current.observe(e))},to:T,...n&&{isActive:h,activeClassName:m}})}const f=r.forwardRef(p)},21312:(e,t,n)=>{"use strict";n.d(t,{A:()=>c,T:()=>l});var r=n(96540),a=n(74848);function o(e,t){const n=e.split(/(\{\w+\})/).map(((e,n)=>{if(n%2==1){const n=t?.[e.slice(1,-1)];if(void 0!==n)return n}return e}));return n.some((e=>(0,r.isValidElement)(e)))?n.map(((e,t)=>(0,r.isValidElement)(e)?r.cloneElement(e,{key:t}):e)).filter((e=>""!==e)):n.join("")}var s=n(22654);function i(e){let{id:t,message:n}=e;if(void 0===t&&void 0===n)throw new Error("Docusaurus translation declarations must have at least a translation id or a default translation message");return s[t??n]??n??t}function l(e,t){let{message:n,id:r}=e;return o(i({message:n,id:r}),t)}function c(e){let{children:t,id:n,values:r}=e;if(t&&"string"!=typeof t)throw console.warn("Illegal children",t),new Error("The Docusaurus component only accept simple string values");const s=i({message:t,id:n});return(0,a.jsx)(a.Fragment,{children:o(s,r)})}},17065:(e,t,n)=>{"use strict";n.d(t,{W:()=>r});const r="default"},16654:(e,t,n)=>{"use strict";function r(e){return/^(?:\w*:|\/\/)/.test(e)}function a(e){return void 0!==e&&!r(e)}n.d(t,{A:()=>a,z:()=>r})},86025:(e,t,n)=>{"use strict";n.d(t,{A:()=>i,h:()=>s});var r=n(96540),a=n(44586),o=n(16654);function s(){const{siteConfig:{baseUrl:e,url:t}}=(0,a.A)(),n=(0,r.useCallback)(((n,r)=>function(e,t,n,r){let{forcePrependBaseUrl:a=!1,absolute:s=!1}=void 0===r?{}:r;if(!n||n.startsWith("#")||(0,o.z)(n))return n;if(a)return t+n.replace(/^\//,"");if(n===t.replace(/\/$/,""))return t;const i=n.startsWith(t)?n:t+n.replace(/^\//,"");return s?e+i:i}(t,e,n,r)),[t,e]);return{withBaseUrl:n}}function i(e,t){void 0===t&&(t={});const{withBaseUrl:n}=s();return n(e,t)}},63427:(e,t,n)=>{"use strict";n.d(t,{A:()=>s});var r=n(96540);n(74848);const a=r.createContext({collectAnchor:()=>{},collectLink:()=>{}}),o=()=>(0,r.useContext)(a);function s(){return o()}},44586:(e,t,n)=>{"use strict";n.d(t,{A:()=>o});var r=n(96540),a=n(26988);function o(){return(0,r.useContext)(a.o)}},66588:(e,t,n)=>{"use strict";n.d(t,{P_:()=>s,kh:()=>o});var r=n(44586),a=n(17065);function o(e,t){void 0===t&&(t={});const n=function(){const{globalData:e}=(0,r.A)();return e}()[e];if(!n&&t.failfast)throw new Error(`Docusaurus plugin global data not found for "${e}" plugin.`);return n}function s(e,t,n){void 0===t&&(t=a.W),void 0===n&&(n={});const r=o(e),s=r?.[t];if(!s&&n.failfast)throw new Error(`Docusaurus plugin global data not found for "${e}" plugin with id "${t}".`);return s}},92303:(e,t,n)=>{"use strict";n.d(t,{A:()=>o});var r=n(96540),a=n(6125);function o(){return(0,r.useContext)(a.o)}},205:(e,t,n)=>{"use strict";n.d(t,{A:()=>a});var r=n(96540);const a=n(38193).default.canUseDOM?r.useLayoutEffect:r.useEffect},86921:(e,t,n)=>{"use strict";n.d(t,{A:()=>a});const r=e=>"object"==typeof e&&!!e&&Object.keys(e).length>0;function a(e){const t={};return function e(n,a){Object.entries(n).forEach((n=>{let[o,s]=n;const i=a?`${a}.${o}`:o;r(s)?e(s,i):t[i]=s}))}(e),t}},53102:(e,t,n)=>{"use strict";n.d(t,{W:()=>s,o:()=>o});var r=n(96540),a=n(74848);const o=r.createContext(null);function s(e){let{children:t,value:n}=e;const s=r.useContext(o),i=(0,r.useMemo)((()=>function(e){let{parent:t,value:n}=e;if(!t){if(!n)throw new Error("Unexpected: no Docusaurus route context found");if(!("plugin"in n))throw new Error("Unexpected: Docusaurus topmost route context has no `plugin` attribute");return n}const r={...t.data,...n?.data};return{plugin:t.plugin,data:r}}({parent:s,value:n})),[s,n]);return(0,a.jsx)(o.Provider,{value:i,children:t})}},48295:(e,t,n)=>{"use strict";n.d(t,{zK:()=>h,vT:()=>d,gk:()=>p,Gy:()=>c,HW:()=>g,ht:()=>u,r7:()=>m,jh:()=>f});var r=n(56347),a=n(66588);const o=e=>e.versions.find((e=>e.isLast));function s(e,t){const n=o(e);return[...e.versions.filter((e=>e!==n)),n].find((e=>!!(0,r.B6)(t,{path:e.path,exact:!1,strict:!1})))}function i(e,t){const n=s(e,t),a=n?.docs.find((e=>!!(0,r.B6)(t,{path:e.path,exact:!0,strict:!1})));return{activeVersion:n,activeDoc:a,alternateDocVersions:a?function(t){const n={};return e.versions.forEach((e=>{e.docs.forEach((r=>{r.id===t&&(n[e.name]=r)}))})),n}(a.id):{}}}const l={},c=()=>(0,a.kh)("docusaurus-plugin-content-docs")??l,u=e=>(0,a.P_)("docusaurus-plugin-content-docs",e,{failfast:!0});function d(e){void 0===e&&(e={});const t=c(),{pathname:n}=(0,r.zy)();return function(e,t,n){void 0===n&&(n={});const a=Object.entries(e).sort(((e,t)=>t[1].path.localeCompare(e[1].path))).find((e=>{let[,n]=e;return!!(0,r.B6)(t,{path:n.path,exact:!1,strict:!1})})),o=a?{pluginId:a[0],pluginData:a[1]}:void 0;if(!o&&n.failfast)throw new Error(`Can't find active docs plugin for "${t}" pathname, while it was expected to be found. Maybe you tried to use a docs feature that can only be used on a docs-related page? Existing docs plugin paths are: ${Object.values(e).map((e=>e.path)).join(", ")}`);return o}(t,n,e)}function p(e){void 0===e&&(e={});const t=d(e),{pathname:n}=(0,r.zy)();if(!t)return;return{activePlugin:t,activeVersion:s(t.pluginData,n)}}function f(e){return u(e).versions}function m(e){const t=u(e);return o(t)}function h(e){const t=u(e),{pathname:n}=(0,r.zy)();return i(t,n)}function g(e){const t=u(e),{pathname:n}=(0,r.zy)();return function(e,t){const n=o(e);return{latestDocSuggestion:i(e,t).alternateDocVersions[n.name],latestVersionSuggestion:n}}(t,n)}},76294:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>o});var r=n(5947),a=n.n(r);a().configure({showSpinner:!1});const o={onRouteUpdate(e){let{location:t,previousLocation:n}=e;if(n&&t.pathname!==n.pathname){const e=window.setTimeout((()=>{a().start()}),200);return()=>window.clearTimeout(e)}},onRouteDidUpdate(){a().done()}}},26134:(e,t,n)=>{"use strict";n.r(t);var r=n(84876),a=n(4784);!function(e){const{themeConfig:{prism:t}}=a.default,{additionalLanguages:r}=t;globalThis.Prism=e,r.forEach((e=>{"php"===e&&n(19700),n(64424)(`./prism-${e}`)})),delete globalThis.Prism}(r.My)},51107:(e,t,n)=>{"use strict";n.d(t,{A:()=>u});n(96540);var r=n(18215),a=n(21312),o=n(6342),s=n(28774),i=n(63427);const l={anchorWithStickyNavbar:"anchorWithStickyNavbar_LWe7",anchorWithHideOnScrollNavbar:"anchorWithHideOnScrollNavbar_WYt5"};var c=n(74848);function u(e){let{as:t,id:n,...u}=e;const d=(0,i.A)(),{navbar:{hideOnScroll:p}}=(0,o.p)();if("h1"===t||!n)return(0,c.jsx)(t,{...u,id:void 0});d.collectAnchor(n);const f=(0,a.T)({id:"theme.common.headingLinkTitle",message:"Direct link to {heading}",description:"Title for link to heading"},{heading:"string"==typeof u.children?u.children:n});return(0,c.jsxs)(t,{...u,className:(0,r.A)("anchor",p?l.anchorWithHideOnScrollNavbar:l.anchorWithStickyNavbar,u.className),id:n,children:[u.children,(0,c.jsx)(s.A,{className:"hash-link",to:`#${n}`,"aria-label":f,title:f,children:"\u200b"})]})}},43186:(e,t,n)=>{"use strict";n.d(t,{A:()=>o});n(96540);const r={iconExternalLink:"iconExternalLink_nPIU"};var a=n(74848);function o(e){let{width:t=13.5,height:n=13.5}=e;return(0,a.jsx)("svg",{width:t,height:n,"aria-hidden":"true",viewBox:"0 0 24 24",className:r.iconExternalLink,children:(0,a.jsx)("path",{fill:"currentColor",d:"M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"})})}},23465:(e,t,n)=>{"use strict";n.d(t,{A:()=>u});n(96540);var r=n(28774),a=n(86025),o=n(44586),s=n(6342),i=n(21122),l=n(74848);function c(e){let{logo:t,alt:n,imageClassName:r}=e;const o={light:(0,a.A)(t.src),dark:(0,a.A)(t.srcDark||t.src)},s=(0,l.jsx)(i.A,{className:t.className,sources:o,height:t.height,width:t.width,alt:n,style:t.style});return r?(0,l.jsx)("div",{className:r,children:s}):s}function u(e){const{siteConfig:{title:t}}=(0,o.A)(),{navbar:{title:n,logo:i}}=(0,s.p)(),{imageClassName:u,titleClassName:d,...p}=e,f=(0,a.A)(i?.href||"/"),m=n?"":t,h=i?.alt??m;return(0,l.jsxs)(r.A,{to:f,...p,...i?.target&&{target:i.target},children:[i&&(0,l.jsx)(c,{logo:i,alt:h,imageClassName:u}),null!=n&&(0,l.jsx)("b",{className:d,children:n})]})}},41463:(e,t,n)=>{"use strict";n.d(t,{A:()=>o});n(96540);var r=n(5260),a=n(74848);function o(e){let{locale:t,version:n,tag:o}=e;const s=t;return(0,a.jsxs)(r.A,{children:[t&&(0,a.jsx)("meta",{name:"docusaurus_locale",content:t}),n&&(0,a.jsx)("meta",{name:"docusaurus_version",content:n}),o&&(0,a.jsx)("meta",{name:"docusaurus_tag",content:o}),s&&(0,a.jsx)("meta",{name:"docsearch:language",content:s}),n&&(0,a.jsx)("meta",{name:"docsearch:version",content:n}),o&&(0,a.jsx)("meta",{name:"docsearch:docusaurus_tag",content:o})]})}},21122:(e,t,n)=>{"use strict";n.d(t,{A:()=>u});var r=n(96540),a=n(15066),o=n(92303),s=n(95293);const i={themedComponent:"themedComponent_mlkZ","themedComponent--light":"themedComponent--light_NVdE","themedComponent--dark":"themedComponent--dark_xIcU"};var l=n(74848);function c(e){let{className:t,children:n}=e;const c=(0,o.A)(),{colorMode:u}=(0,s.G)();return(0,l.jsx)(l.Fragment,{children:(c?"dark"===u?["dark"]:["light"]:["light","dark"]).map((e=>{const o=n({theme:e,className:(0,a.A)(t,i.themedComponent,i[`themedComponent--${e}`])});return(0,l.jsx)(r.Fragment,{children:o},e)}))})}function u(e){const{sources:t,className:n,alt:r,...a}=e;return(0,l.jsx)(c,{className:n,children:e=>{let{theme:n,className:o}=e;return(0,l.jsx)("img",{src:t[n],alt:r,className:o,...a})}})}},41422:(e,t,n)=>{"use strict";n.d(t,{N:()=>b,u:()=>c});var r=n(96540),a=n(38193),o=n(205),s=n(53109),i=n(74848);const l="ease-in-out";function c(e){let{initialState:t}=e;const[n,a]=(0,r.useState)(t??!1),o=(0,r.useCallback)((()=>{a((e=>!e))}),[]);return{collapsed:n,setCollapsed:a,toggleCollapsed:o}}const u={display:"none",overflow:"hidden",height:"0px"},d={display:"block",overflow:"visible",height:"auto"};function p(e,t){const n=t?u:d;e.style.display=n.display,e.style.overflow=n.overflow,e.style.height=n.height}function f(e){let{collapsibleRef:t,collapsed:n,animation:a}=e;const o=(0,r.useRef)(!1);(0,r.useEffect)((()=>{const e=t.current;function r(){const t=e.scrollHeight,n=a?.duration??function(e){if((0,s.O)())return 1;const t=e/36;return Math.round(10*(4+15*t**.25+t/5))}(t);return{transition:`height ${n}ms ${a?.easing??l}`,height:`${t}px`}}function i(){const t=r();e.style.transition=t.transition,e.style.height=t.height}if(!o.current)return p(e,n),void(o.current=!0);return e.style.willChange="height",function(){const t=requestAnimationFrame((()=>{n?(i(),requestAnimationFrame((()=>{e.style.height=u.height,e.style.overflow=u.overflow}))):(e.style.display="block",requestAnimationFrame((()=>{i()})))}));return()=>cancelAnimationFrame(t)}()}),[t,n,a])}function m(e){if(!a.default.canUseDOM)return e?u:d}function h(e){let{as:t="div",collapsed:n,children:a,animation:o,onCollapseTransitionEnd:s,className:l,disableSSRStyle:c}=e;const u=(0,r.useRef)(null);return f({collapsibleRef:u,collapsed:n,animation:o}),(0,i.jsx)(t,{ref:u,style:c?void 0:m(n),onTransitionEnd:e=>{"height"===e.propertyName&&(p(u.current,n),s?.(n))},className:l,children:a})}function g(e){let{collapsed:t,...n}=e;const[a,s]=(0,r.useState)(!t),[l,c]=(0,r.useState)(t);return(0,o.A)((()=>{t||s(!0)}),[t]),(0,o.A)((()=>{a&&c(t)}),[a,t]),a?(0,i.jsx)(h,{...n,collapsed:l}):null}function b(e){let{lazy:t,...n}=e;const r=t?g:h;return(0,i.jsx)(r,{...n})}},65041:(e,t,n)=>{"use strict";n.d(t,{Mj:()=>h,oq:()=>m});var r=n(96540),a=n(92303),o=n(89466),s=n(89532),i=n(6342),l=n(74848);const c=(0,o.Wf)("docusaurus.announcement.dismiss"),u=(0,o.Wf)("docusaurus.announcement.id"),d=()=>"true"===c.get(),p=e=>c.set(String(e)),f=r.createContext(null);function m(e){let{children:t}=e;const n=function(){const{announcementBar:e}=(0,i.p)(),t=(0,a.A)(),[n,o]=(0,r.useState)((()=>!!t&&d()));(0,r.useEffect)((()=>{o(d())}),[]);const s=(0,r.useCallback)((()=>{p(!0),o(!0)}),[]);return(0,r.useEffect)((()=>{if(!e)return;const{id:t}=e;let n=u.get();"annoucement-bar"===n&&(n="announcement-bar");const r=t!==n;u.set(t),r&&p(!1),!r&&d()||o(!1)}),[e]),(0,r.useMemo)((()=>({isActive:!!e&&!n,close:s})),[e,n,s])}();return(0,l.jsx)(f.Provider,{value:n,children:t})}function h(){const e=(0,r.useContext)(f);if(!e)throw new s.dV("AnnouncementBarProvider");return e}},95293:(e,t,n)=>{"use strict";n.d(t,{G:()=>b,a:()=>g});var r=n(96540),a=n(38193),o=n(89532),s=n(89466),i=n(6342),l=n(74848);const c=r.createContext(void 0),u="theme",d=(0,s.Wf)(u),p={light:"light",dark:"dark"},f=e=>e===p.dark?p.dark:p.light,m=e=>a.default.canUseDOM?f(document.documentElement.getAttribute("data-theme")):f(e),h=e=>{d.set(f(e))};function g(e){let{children:t}=e;const n=function(){const{colorMode:{defaultMode:e,disableSwitch:t,respectPrefersColorScheme:n}}=(0,i.p)(),[a,o]=(0,r.useState)(m(e));(0,r.useEffect)((()=>{t&&d.del()}),[t]);const s=(0,r.useCallback)((function(t,r){void 0===r&&(r={});const{persist:a=!0}=r;t?(o(t),a&&h(t)):(o(n?window.matchMedia("(prefers-color-scheme: dark)").matches?p.dark:p.light:e),d.del())}),[n,e]);(0,r.useEffect)((()=>{document.documentElement.setAttribute("data-theme",f(a))}),[a]),(0,r.useEffect)((()=>{if(t)return;const e=e=>{if(e.key!==u)return;const t=d.get();null!==t&&s(f(t))};return window.addEventListener("storage",e),()=>window.removeEventListener("storage",e)}),[t,s]);const l=(0,r.useRef)(!1);return(0,r.useEffect)((()=>{if(t&&!n)return;const e=window.matchMedia("(prefers-color-scheme: dark)"),r=()=>{window.matchMedia("print").matches||l.current?l.current=window.matchMedia("print").matches:s(null)};return e.addListener(r),()=>e.removeListener(r)}),[s,t,n]),(0,r.useMemo)((()=>({colorMode:a,setColorMode:s,get isDarkTheme(){return a===p.dark},setLightTheme(){s(p.light)},setDarkTheme(){s(p.dark)}})),[a,s])}();return(0,l.jsx)(c.Provider,{value:n,children:t})}function b(){const e=(0,r.useContext)(c);if(null==e)throw new o.dV("ColorModeProvider","Please see https://docusaurus.io/docs/api/themes/configuration#use-color-mode.");return e}},55597:(e,t,n)=>{"use strict";n.d(t,{VQ:()=>b,XK:()=>w,g1:()=>v});var r=n(96540),a=n(48295),o=n(17065),s=n(6342),i=n(84142),l=n(89532),c=n(89466),u=n(74848);const d=e=>`docs-preferred-version-${e}`,p={save:(e,t,n)=>{(0,c.Wf)(d(e),{persistence:t}).set(n)},read:(e,t)=>(0,c.Wf)(d(e),{persistence:t}).get(),clear:(e,t)=>{(0,c.Wf)(d(e),{persistence:t}).del()}},f=e=>Object.fromEntries(e.map((e=>[e,{preferredVersionName:null}])));const m=r.createContext(null);function h(){const e=(0,a.Gy)(),t=(0,s.p)().docs.versionPersistence,n=(0,r.useMemo)((()=>Object.keys(e)),[e]),[o,i]=(0,r.useState)((()=>f(n)));(0,r.useEffect)((()=>{i(function(e){let{pluginIds:t,versionPersistence:n,allDocsData:r}=e;function a(e){const t=p.read(e,n);return r[e].versions.some((e=>e.name===t))?{preferredVersionName:t}:(p.clear(e,n),{preferredVersionName:null})}return Object.fromEntries(t.map((e=>[e,a(e)])))}({allDocsData:e,versionPersistence:t,pluginIds:n}))}),[e,t,n]);return[o,(0,r.useMemo)((()=>({savePreferredVersion:function(e,n){p.save(e,t,n),i((t=>({...t,[e]:{preferredVersionName:n}})))}})),[t])]}function g(e){let{children:t}=e;const n=h();return(0,u.jsx)(m.Provider,{value:n,children:t})}function b(e){let{children:t}=e;return i.C5?(0,u.jsx)(g,{children:t}):(0,u.jsx)(u.Fragment,{children:t})}function y(){const e=(0,r.useContext)(m);if(!e)throw new l.dV("DocsPreferredVersionContextProvider");return e}function v(e){void 0===e&&(e=o.W);const t=(0,a.ht)(e),[n,s]=y(),{preferredVersionName:i}=n[e];return{preferredVersion:t.versions.find((e=>e.name===i))??null,savePreferredVersionName:(0,r.useCallback)((t=>{s.savePreferredVersion(e,t)}),[s,e])}}function w(){const e=(0,a.Gy)(),[t]=y();function n(n){const r=e[n],{preferredVersionName:a}=t[n];return r.versions.find((e=>e.name===a))??null}const r=Object.keys(e);return Object.fromEntries(r.map((e=>[e,n(e)])))}},26588:(e,t,n)=>{"use strict";n.d(t,{V:()=>l,t:()=>c});var r=n(96540),a=n(89532),o=n(74848);const s=Symbol("EmptyContext"),i=r.createContext(s);function l(e){let{children:t,name:n,items:a}=e;const s=(0,r.useMemo)((()=>n&&a?{name:n,items:a}:null),[n,a]);return(0,o.jsx)(i.Provider,{value:s,children:t})}function c(){const e=(0,r.useContext)(i);if(e===s)throw new a.dV("DocsSidebarProvider");return e}},32252:(e,t,n)=>{"use strict";n.d(t,{n:()=>i,r:()=>l});var r=n(96540),a=n(89532),o=n(74848);const s=r.createContext(null);function i(e){let{children:t,version:n}=e;return(0,o.jsx)(s.Provider,{value:n,children:t})}function l(){const e=(0,r.useContext)(s);if(null===e)throw new a.dV("DocsVersionProvider");return e}},22069:(e,t,n)=>{"use strict";n.d(t,{M:()=>f,e:()=>p});var r=n(96540),a=n(75600),o=n(24581),s=n(57485),i=n(6342),l=n(89532),c=n(74848);const u=r.createContext(void 0);function d(){const e=function(){const e=(0,a.YL)(),{items:t}=(0,i.p)().navbar;return 0===t.length&&!e.component}(),t=(0,o.l)(),n=!e&&"mobile"===t,[l,c]=(0,r.useState)(!1);(0,s.$Z)((()=>{if(l)return c(!1),!1}));const u=(0,r.useCallback)((()=>{c((e=>!e))}),[]);return(0,r.useEffect)((()=>{"desktop"===t&&c(!1)}),[t]),(0,r.useMemo)((()=>({disabled:e,shouldRender:n,toggle:u,shown:l})),[e,n,u,l])}function p(e){let{children:t}=e;const n=d();return(0,c.jsx)(u.Provider,{value:n,children:t})}function f(){const e=r.useContext(u);if(void 0===e)throw new l.dV("NavbarMobileSidebarProvider");return e}},75600:(e,t,n)=>{"use strict";n.d(t,{GX:()=>c,YL:()=>l,y_:()=>i});var r=n(96540),a=n(89532),o=n(74848);const s=r.createContext(null);function i(e){let{children:t}=e;const n=(0,r.useState)({component:null,props:null});return(0,o.jsx)(s.Provider,{value:n,children:t})}function l(){const e=(0,r.useContext)(s);if(!e)throw new a.dV("NavbarSecondaryMenuContentProvider");return e[0]}function c(e){let{component:t,props:n}=e;const o=(0,r.useContext)(s);if(!o)throw new a.dV("NavbarSecondaryMenuContentProvider");const[,i]=o,l=(0,a.Be)(n);return(0,r.useEffect)((()=>{i({component:t,props:l})}),[i,t,l]),(0,r.useEffect)((()=>()=>i({component:null,props:null})),[i]),null}},14090:(e,t,n)=>{"use strict";n.d(t,{w:()=>a,J:()=>o});var r=n(96540);const a="navigation-with-keyboard";function o(){(0,r.useEffect)((()=>{function e(e){"keydown"===e.type&&"Tab"===e.key&&document.body.classList.add(a),"mousedown"===e.type&&document.body.classList.remove(a)}return document.addEventListener("keydown",e),document.addEventListener("mousedown",e),()=>{document.body.classList.remove(a),document.removeEventListener("keydown",e),document.removeEventListener("mousedown",e)}}),[])}},24255:(e,t,n)=>{"use strict";n.d(t,{b:()=>i,w:()=>l});var r=n(96540),a=n(44586),o=n(57485);const s="q";function i(){return(0,o.l)(s)}function l(){const{siteConfig:{baseUrl:e,themeConfig:t}}=(0,a.A)(),{algolia:{searchPagePath:n}}=t;return(0,r.useCallback)((t=>`${e}${n}?${s}=${encodeURIComponent(t)}`),[e,n])}},24581:(e,t,n)=>{"use strict";n.d(t,{l:()=>i});var r=n(96540),a=n(38193);const o={desktop:"desktop",mobile:"mobile",ssr:"ssr"},s=996;function i(e){let{desktopBreakpoint:t=s}=void 0===e?{}:e;const[n,i]=(0,r.useState)((()=>"ssr"));return(0,r.useEffect)((()=>{function e(){i(function(e){if(!a.default.canUseDOM)throw new Error("getWindowSize() should only be called after React hydration");return window.innerWidth>e?o.desktop:o.mobile}(t))}return e(),window.addEventListener("resize",e),()=>{window.removeEventListener("resize",e)}}),[t]),n}},17559:(e,t,n)=>{"use strict";n.d(t,{G:()=>r});const r={page:{blogListPage:"blog-list-page",blogPostPage:"blog-post-page",blogTagsListPage:"blog-tags-list-page",blogTagPostListPage:"blog-tags-post-list-page",docsDocPage:"docs-doc-page",docsTagsListPage:"docs-tags-list-page",docsTagDocListPage:"docs-tags-doc-list-page",mdxPage:"mdx-page"},wrapper:{main:"main-wrapper",blogPages:"blog-wrapper",docsPages:"docs-wrapper",mdxPages:"mdx-wrapper"},common:{editThisPage:"theme-edit-this-page",lastUpdated:"theme-last-updated",backToTopButton:"theme-back-to-top-button",codeBlock:"theme-code-block",admonition:"theme-admonition",unlistedBanner:"theme-unlisted-banner",admonitionType:e=>`theme-admonition-${e}`},layout:{},docs:{docVersionBanner:"theme-doc-version-banner",docVersionBadge:"theme-doc-version-badge",docBreadcrumbs:"theme-doc-breadcrumbs",docMarkdown:"theme-doc-markdown",docTocMobile:"theme-doc-toc-mobile",docTocDesktop:"theme-doc-toc-desktop",docFooter:"theme-doc-footer",docFooterTagsRow:"theme-doc-footer-tags-row",docFooterEditMetaRow:"theme-doc-footer-edit-meta-row",docSidebarContainer:"theme-doc-sidebar-container",docSidebarMenu:"theme-doc-sidebar-menu",docSidebarItemCategory:"theme-doc-sidebar-item-category",docSidebarItemLink:"theme-doc-sidebar-item-link",docSidebarItemCategoryLevel:e=>`theme-doc-sidebar-item-category-level-${e}`,docSidebarItemLinkLevel:e=>`theme-doc-sidebar-item-link-level-${e}`},blog:{}}},53109:(e,t,n)=>{"use strict";function r(){return window.matchMedia("(prefers-reduced-motion: reduce)").matches}n.d(t,{O:()=>r})},84142:(e,t,n)=>{"use strict";n.d(t,{$S:()=>h,B5:()=>j,C5:()=>p,Nr:()=>m,OF:()=>k,QB:()=>E,Vd:()=>_,Y:()=>w,cC:()=>f,d1:()=>T,fW:()=>S,w8:()=>y});var r=n(96540),a=n(56347),o=n(22831),s=n(48295),i=n(55597),l=n(32252),c=n(26588),u=n(31682),d=n(99169);const p=!!s.Gy;function f(e){const t=(0,l.r)();if(!e)return;const n=t.docs[e];if(!n)throw new Error(`no version doc found by id=${e}`);return n}function m(e){return"link"!==e.type||e.unlisted?"category"===e.type?function(e){if(e.href&&!e.linkUnlisted)return e.href;for(const t of e.items){const e=m(t);if(e)return e}}(e):void 0:e.href}function h(){const{pathname:e}=(0,a.zy)(),t=(0,c.t)();if(!t)throw new Error("Unexpected: cant find current sidebar in context");const n=x({sidebarItems:t.items,pathname:e,onlyCategories:!0}).slice(-1)[0];if(!n)throw new Error(`${e} is not associated with a category. useCurrentSidebarCategory() should only be used on category index pages.`);return n}const g=(e,t)=>void 0!==e&&(0,d.ys)(e,t),b=(e,t)=>e.some((e=>y(e,t)));function y(e,t){return"link"===e.type?g(e.href,t):"category"===e.type&&(g(e.href,t)||b(e.items,t))}function v(e,t){switch(e.type){case"category":return y(e,t)||e.items.some((e=>v(e,t)));case"link":return!e.unlisted||y(e,t);default:return!0}}function w(e,t){return(0,r.useMemo)((()=>e.filter((e=>v(e,t)))),[e,t])}function x(e){let{sidebarItems:t,pathname:n,onlyCategories:r=!1}=e;const a=[];return function e(t){for(const o of t)if("category"===o.type&&((0,d.ys)(o.href,n)||e(o.items))||"link"===o.type&&(0,d.ys)(o.href,n)){return r&&"category"!==o.type||a.unshift(o),!0}return!1}(t),a}function k(){const e=(0,c.t)(),{pathname:t}=(0,a.zy)(),n=(0,s.vT)()?.pluginData.breadcrumbs;return!1!==n&&e?x({sidebarItems:e.items,pathname:t}):null}function _(e){const{activeVersion:t}=(0,s.zK)(e),{preferredVersion:n}=(0,i.g1)(e),a=(0,s.r7)(e);return(0,r.useMemo)((()=>(0,u.s)([t,n,a].filter(Boolean))),[t,n,a])}function S(e,t){const n=_(t);return(0,r.useMemo)((()=>{const t=n.flatMap((e=>e.sidebars?Object.entries(e.sidebars):[])),r=t.find((t=>t[0]===e));if(!r)throw new Error(`Can't find any sidebar with id "${e}" in version${n.length>1?"s":""} ${n.map((e=>e.name)).join(", ")}".\nAvailable sidebar ids are:\n- ${t.map((e=>e[0])).join("\n- ")}`);return r[1]}),[e,n])}function E(e,t){const n=_(t);return(0,r.useMemo)((()=>{const t=n.flatMap((e=>e.docs)),r=t.find((t=>t.id===e));if(!r){if(n.flatMap((e=>e.draftIds)).includes(e))return null;throw new Error(`Couldn't find any doc with id "${e}" in version${n.length>1?"s":""} "${n.map((e=>e.name)).join(", ")}".\nAvailable doc ids are:\n- ${(0,u.s)(t.map((e=>e.id))).join("\n- ")}`)}return r}),[e,n])}function j(e){let{route:t}=e;const n=(0,a.zy)(),r=(0,l.r)(),s=t.routes,i=s.find((e=>(0,a.B6)(n.pathname,e)));if(!i)return null;const c=i.sidebar,u=c?r.docsSidebars[c]:void 0;return{docElement:(0,o.v)(s),sidebarName:c,sidebarItems:u}}function T(e){return e.filter((e=>!("category"===e.type||"link"===e.type)||!!m(e)))}},12181:(e,t,n)=>{"use strict";n.d(t,{bq:()=>u,MN:()=>c,a2:()=>l,k2:()=>d});var r=n(96540),a=n(21312),o=n(70440);const s={errorBoundaryError:"errorBoundaryError_a6uf",errorBoundaryFallback:"errorBoundaryFallback_VBag"};var i=n(74848);function l(e){return(0,i.jsx)("button",{type:"button",...e,children:(0,i.jsx)(a.A,{id:"theme.ErrorPageContent.tryAgain",description:"The label of the button to try again rendering when the React error boundary captures an error",children:"Try again"})})}function c(e){let{error:t,tryAgain:n}=e;return(0,i.jsxs)("div",{className:s.errorBoundaryFallback,children:[(0,i.jsx)("p",{children:t.message}),(0,i.jsx)(l,{onClick:n})]})}function u(e){let{error:t}=e;const n=(0,o.getErrorCausalChain)(t).map((e=>e.message)).join("\n\nCause:\n");return(0,i.jsx)("p",{className:s.errorBoundaryError,children:n})}class d extends r.Component{componentDidCatch(e,t){throw this.props.onError(e,t)}render(){return this.props.children}}},20481:(e,t,n)=>{"use strict";n.d(t,{s:()=>a});var r=n(44586);function a(e){const{siteConfig:t}=(0,r.A)(),{title:n,titleDelimiter:a}=t;return e?.trim().length?`${e.trim()} ${a} ${n}`:n}},57485:(e,t,n)=>{"use strict";n.d(t,{$Z:()=>s,aZ:()=>i,l:()=>l});var r=n(96540),a=n(56347),o=n(89532);function s(e){!function(e){const t=(0,a.W6)(),n=(0,o._q)(e);(0,r.useEffect)((()=>t.block(((e,t)=>n(e,t)))),[t,n])}(((t,n)=>{if("POP"===n)return e(t,n)}))}function i(e){return function(e){const t=(0,a.W6)();return(0,r.useSyncExternalStore)(t.listen,(()=>e(t)),(()=>e(t)))}((t=>null===e?null:new URLSearchParams(t.location.search).get(e)))}function l(e){const t=i(e)??"",n=function(){const e=(0,a.W6)();return(0,r.useCallback)(((t,n,r)=>{const a=new URLSearchParams(e.location.search);n?a.set(t,n):a.delete(t),(r?.push?e.push:e.replace)({search:a.toString()})}),[e])}();return[t,(0,r.useCallback)(((t,r)=>{n(e,t,r)}),[n,e])]}},31682:(e,t,n)=>{"use strict";function r(e,t){return void 0===t&&(t=(e,t)=>e===t),e.filter(((n,r)=>e.findIndex((e=>t(e,n)))!==r))}function a(e){return Array.from(new Set(e))}n.d(t,{X:()=>r,s:()=>a})},69024:(e,t,n)=>{"use strict";n.d(t,{e3:()=>f,be:()=>d,Jx:()=>m});var r=n(96540),a=n(15066),o=n(5260),s=n(53102);function i(){const e=r.useContext(s.o);if(!e)throw new Error("Unexpected: no Docusaurus route context found");return e}var l=n(86025),c=n(20481),u=n(74848);function d(e){let{title:t,description:n,keywords:r,image:a,children:s}=e;const i=(0,c.s)(t),{withBaseUrl:d}=(0,l.h)(),p=a?d(a,{absolute:!0}):void 0;return(0,u.jsxs)(o.A,{children:[t&&(0,u.jsx)("title",{children:i}),t&&(0,u.jsx)("meta",{property:"og:title",content:i}),n&&(0,u.jsx)("meta",{name:"description",content:n}),n&&(0,u.jsx)("meta",{property:"og:description",content:n}),r&&(0,u.jsx)("meta",{name:"keywords",content:Array.isArray(r)?r.join(","):r}),p&&(0,u.jsx)("meta",{property:"og:image",content:p}),p&&(0,u.jsx)("meta",{name:"twitter:image",content:p}),s]})}const p=r.createContext(void 0);function f(e){let{className:t,children:n}=e;const s=r.useContext(p),i=(0,a.A)(s,t);return(0,u.jsxs)(p.Provider,{value:i,children:[(0,u.jsx)(o.A,{children:(0,u.jsx)("html",{className:i})}),n]})}function m(e){let{children:t}=e;const n=i(),r=`plugin-${n.plugin.name.replace(/docusaurus-(?:plugin|theme)-(?:content-)?/gi,"")}`;const o=`plugin-id-${n.plugin.id}`;return(0,u.jsx)(f,{className:(0,a.A)(r,o),children:t})}},89532:(e,t,n)=>{"use strict";n.d(t,{Be:()=>c,ZC:()=>i,_q:()=>s,dV:()=>l,fM:()=>u});var r=n(96540),a=n(205),o=n(74848);function s(e){const t=(0,r.useRef)(e);return(0,a.A)((()=>{t.current=e}),[e]),(0,r.useCallback)((function(){return t.current(...arguments)}),[])}function i(e){const t=(0,r.useRef)();return(0,a.A)((()=>{t.current=e})),t.current}class l extends Error{constructor(e,t){super(),this.name="ReactContextError",this.message=`Hook ${this.stack?.split("\n")[1]?.match(/at (?:\w+\.)?(?\w+)/)?.groups.name??""} is called outside the <${e}>. ${t??""}`}}function c(e){const t=Object.entries(e);return t.sort(((e,t)=>e[0].localeCompare(t[0]))),(0,r.useMemo)((()=>e),t.flat())}function u(e){return t=>{let{children:n}=t;return(0,o.jsx)(o.Fragment,{children:e.reduceRight(((e,t)=>(0,o.jsx)(t,{children:e})),n)})}}},91252:(e,t,n)=>{"use strict";function r(e,t){return void 0!==e&&void 0!==t&&new RegExp(e,"gi").test(t)}n.d(t,{G:()=>r})},99169:(e,t,n)=>{"use strict";n.d(t,{Dt:()=>i,ys:()=>s});var r=n(96540),a=n(35947),o=n(44586);function s(e,t){const n=e=>(!e||e.endsWith("/")?e:`${e}/`)?.toLowerCase();return n(e)===n(t)}function i(){const{baseUrl:e}=(0,o.A)().siteConfig;return(0,r.useMemo)((()=>function(e){let{baseUrl:t,routes:n}=e;function r(e){return e.path===t&&!0===e.exact}function a(e){return e.path===t&&!e.exact}return function e(t){if(0===t.length)return;return t.find(r)||e(t.filter(a).flatMap((e=>e.routes??[])))}(n)}({routes:a.A,baseUrl:e})),[e])}},23104:(e,t,n)=>{"use strict";n.d(t,{Mq:()=>f,Tv:()=>u,a_:()=>m,gk:()=>h});var r=n(96540),a=n(38193),o=n(92303),s=n(205),i=n(89532),l=n(74848);const c=r.createContext(void 0);function u(e){let{children:t}=e;const n=function(){const e=(0,r.useRef)(!0);return(0,r.useMemo)((()=>({scrollEventsEnabledRef:e,enableScrollEvents:()=>{e.current=!0},disableScrollEvents:()=>{e.current=!1}})),[])}();return(0,l.jsx)(c.Provider,{value:n,children:t})}function d(){const e=(0,r.useContext)(c);if(null==e)throw new i.dV("ScrollControllerProvider");return e}const p=()=>a.default.canUseDOM?{scrollX:window.pageXOffset,scrollY:window.pageYOffset}:null;function f(e,t){void 0===t&&(t=[]);const{scrollEventsEnabledRef:n}=d(),a=(0,r.useRef)(p()),o=(0,i._q)(e);(0,r.useEffect)((()=>{const e=()=>{if(!n.current)return;const e=p();o(e,a.current),a.current=e},t={passive:!0};return e(),window.addEventListener("scroll",e,t),()=>window.removeEventListener("scroll",e,t)}),[o,n,...t])}function m(){const e=d(),t=function(){const e=(0,r.useRef)({elem:null,top:0}),t=(0,r.useCallback)((t=>{e.current={elem:t,top:t.getBoundingClientRect().top}}),[]),n=(0,r.useCallback)((()=>{const{current:{elem:t,top:n}}=e;if(!t)return{restored:!1};const r=t.getBoundingClientRect().top-n;return r&&window.scrollBy({left:0,top:r}),e.current={elem:null,top:0},{restored:0!==r}}),[]);return(0,r.useMemo)((()=>({save:t,restore:n})),[n,t])}(),n=(0,r.useRef)(void 0),a=(0,r.useCallback)((r=>{t.save(r),e.disableScrollEvents(),n.current=()=>{const{restored:r}=t.restore();if(n.current=void 0,r){const t=()=>{e.enableScrollEvents(),window.removeEventListener("scroll",t)};window.addEventListener("scroll",t)}else e.enableScrollEvents()}}),[e,t]);return(0,s.A)((()=>{queueMicrotask((()=>n.current?.()))})),{blockElementScrollPositionUntilNextRender:a}}function h(){const e=(0,r.useRef)(null),t=(0,o.A)()&&"smooth"===getComputedStyle(document.documentElement).scrollBehavior;return{startScroll:n=>{e.current=t?function(e){return window.scrollTo({top:e,behavior:"smooth"}),()=>{}}(n):function(e){let t=null;const n=document.documentElement.scrollTop>e;return function r(){const a=document.documentElement.scrollTop;(n&&a>e||!n&&at&&cancelAnimationFrame(t)}(n)},cancelScroll:()=>e.current?.()}}},2967:(e,t,n)=>{"use strict";n.d(t,{Cy:()=>s,af:()=>l,tU:()=>i});var r=n(48295),a=n(44586),o=n(55597);const s="default";function i(e,t){return`docs-${e}-${t}`}function l(){const{i18n:e}=(0,a.A)(),t=(0,r.Gy)(),n=(0,r.gk)(),l=(0,o.XK)();const c=[s,...Object.keys(t).map((function(e){const r=n?.activePlugin.pluginId===e?n.activeVersion:void 0,a=l[e],o=t[e].versions.find((e=>e.isLast));return i(e,(r??a??o).name)}))];return{locale:e.currentLocale,tags:c}}},89466:(e,t,n)=>{"use strict";n.d(t,{Dv:()=>u,Wf:()=>c});var r=n(96540);const a="localStorage";function o(e){let{key:t,oldValue:n,newValue:r,storage:a}=e;if(n===r)return;const o=document.createEvent("StorageEvent");o.initStorageEvent("storage",!1,!1,t,n,r,window.location.href,a),window.dispatchEvent(o)}function s(e){if(void 0===e&&(e=a),"undefined"==typeof window)throw new Error("Browser storage is not available on Node.js/Docusaurus SSR process.");if("none"===e)return null;try{return window[e]}catch(n){return t=n,i||(console.warn("Docusaurus browser storage is not available.\nPossible reasons: running Docusaurus in an iframe, in an incognito browser session, or using too strict browser privacy settings.",t),i=!0),null}var t}let i=!1;const l={get:()=>null,set:()=>{},del:()=>{},listen:()=>()=>{}};function c(e,t){if("undefined"==typeof window)return function(e){function t(){throw new Error(`Illegal storage API usage for storage key "${e}".\nDocusaurus storage APIs are not supposed to be called on the server-rendering process.\nPlease only call storage APIs in effects and event handlers.`)}return{get:t,set:t,del:t,listen:t}}(e);const n=s(t?.persistence);return null===n?l:{get:()=>{try{return n.getItem(e)}catch(t){return console.error(`Docusaurus storage error, can't get key=${e}`,t),null}},set:t=>{try{const r=n.getItem(e);n.setItem(e,t),o({key:e,oldValue:r,newValue:t,storage:n})}catch(r){console.error(`Docusaurus storage error, can't set ${e}=${t}`,r)}},del:()=>{try{const t=n.getItem(e);n.removeItem(e),o({key:e,oldValue:t,newValue:null,storage:n})}catch(t){console.error(`Docusaurus storage error, can't delete key=${e}`,t)}},listen:t=>{try{const r=r=>{r.storageArea===n&&r.key===e&&t(r)};return window.addEventListener("storage",r),()=>window.removeEventListener("storage",r)}catch(r){return console.error(`Docusaurus storage error, can't listen for changes of key=${e}`,r),()=>{}}}}}function u(e,t){const n=(0,r.useRef)((()=>null===e?l:c(e,t))).current(),a=(0,r.useCallback)((e=>"undefined"==typeof window?()=>{}:n.listen(e)),[n]);return[(0,r.useSyncExternalStore)(a,(()=>"undefined"==typeof window?null:n.get()),(()=>null)),n]}},32131:(e,t,n)=>{"use strict";n.d(t,{o:()=>s});var r=n(44586),a=n(56347),o=n(70440);function s(){const{siteConfig:{baseUrl:e,url:t,trailingSlash:n},i18n:{defaultLocale:s,currentLocale:i}}=(0,r.A)(),{pathname:l}=(0,a.zy)(),c=(0,o.applyTrailingSlash)(l,{trailingSlash:n,baseUrl:e}),u=i===s?e:e.replace(`/${i}/`,"/"),d=c.replace(e,"");return{createUrl:function(e){let{locale:n,fullyQualified:r}=e;return`${r?t:""}${function(e){return e===s?`${u}`:`${u}${e}/`}(n)}${d}`}}}},75062:(e,t,n)=>{"use strict";n.d(t,{$:()=>s});var r=n(96540),a=n(56347),o=n(89532);function s(e){const t=(0,a.zy)(),n=(0,o.ZC)(t),s=(0,o._q)(e);(0,r.useEffect)((()=>{n&&t!==n&&s({location:t,previousLocation:n})}),[s,t,n])}},6342:(e,t,n)=>{"use strict";n.d(t,{p:()=>a});var r=n(44586);function a(){return(0,r.A)().siteConfig.themeConfig}},38126:(e,t,n)=>{"use strict";n.d(t,{c:()=>a});var r=n(44586);function a(){const{siteConfig:{themeConfig:e}}=(0,r.A)();return e}},51062:(e,t,n)=>{"use strict";n.d(t,{C:()=>i});var r=n(96540),a=n(91252),o=n(86025),s=n(38126);function i(){const{withBaseUrl:e}=(0,o.h)(),{algolia:{externalUrlRegex:t,replaceSearchResultPathname:n}}=(0,s.c)();return(0,r.useCallback)((r=>{const o=new URL(r);if((0,a.G)(t,o.href))return r;const s=`${o.pathname+o.hash}`;return e(function(e,t){return t?e.replaceAll(new RegExp(t.from,"g"),t.to):e}(s,n))}),[e,t,n])}},12983:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){const{trailingSlash:n,baseUrl:r}=t;if(e.startsWith("#"))return e;if(void 0===n)return e;const[a]=e.split(/[#?]/),o="/"===a||a===r?a:(s=a,n?function(e){return e.endsWith("/")?e:`${e}/`}(s):function(e){return e.endsWith("/")?e.slice(0,-1):e}(s));var s;return e.replace(a,o)}},80253:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.getErrorCausalChain=void 0,t.getErrorCausalChain=function e(t){return t.cause?[t,...e(t.cause)]:[t]}},70440:function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0}),t.getErrorCausalChain=t.applyTrailingSlash=t.blogPostContainerID=void 0,t.blogPostContainerID="__blog-post-container";var a=n(12983);Object.defineProperty(t,"applyTrailingSlash",{enumerable:!0,get:function(){return r(a).default}});var o=n(80253);Object.defineProperty(t,"getErrorCausalChain",{enumerable:!0,get:function(){return o.getErrorCausalChain}})},23390:function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});r(n(38193)).default.canUseDOM&&(window.Prism=window.Prism||{},window.Prism.manual=!0)},29530:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>r});const r=n(38193).default.canUseDOM?{onRouteUpdate(){window.posthog.capture("$pageview")}}:null},6011:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>gt});var r=n(96540),a=n(20053),o=n(67489),s=n(69024),i=n(56347),l=n(21312),c=n(75062),u=n(74848);const d="__docusaurus_skipToContent_fallback";function p(e){e.setAttribute("tabindex","-1"),e.focus(),e.removeAttribute("tabindex")}function f(){const e=(0,r.useRef)(null),{action:t}=(0,i.W6)(),n=(0,r.useCallback)((e=>{e.preventDefault();const t=document.querySelector("main:first-of-type")??document.getElementById(d);t&&p(t)}),[]);return(0,c.$)((n=>{let{location:r}=n;e.current&&!r.hash&&"PUSH"===t&&p(e.current)})),{containerRef:e,onClick:n}}const m=(0,l.T)({id:"theme.common.skipToMainContent",description:"The skip to content label used for accessibility, allowing to rapidly navigate to main content with keyboard tab/enter navigation",message:"Skip to main content"});function h(e){const t=e.children??m,{containerRef:n,onClick:r}=f();return(0,u.jsx)("div",{ref:n,role:"region","aria-label":m,children:(0,u.jsx)("a",{...e,href:`#${d}`,onClick:r,children:t})})}var g=n(17559),b=n(14090);const y={skipToContent:"skipToContent_fXgn"};function v(){return(0,u.jsx)(h,{className:y.skipToContent})}var w=n(6342),x=n(65041),k=n(18215);function _(e){let{width:t=21,height:n=21,color:r="currentColor",strokeWidth:a=1.2,className:o,...s}=e;return(0,u.jsx)("svg",{viewBox:"0 0 15 15",width:t,height:n,...s,children:(0,u.jsx)("g",{stroke:r,strokeWidth:a,children:(0,u.jsx)("path",{d:"M.75.75l13.5 13.5M14.25.75L.75 14.25"})})})}const S={closeButton:"closeButton_CVFx"};function E(e){return(0,u.jsx)("button",{type:"button","aria-label":(0,l.T)({id:"theme.AnnouncementBar.closeButtonAriaLabel",message:"Close",description:"The ARIA label for close button of announcement bar"}),...e,className:(0,k.A)("clean-btn close",S.closeButton,e.className),children:(0,u.jsx)(_,{width:14,height:14,strokeWidth:3.1})})}const j={content:"content_knG7"};function T(e){const{announcementBar:t}=(0,w.p)(),{content:n}=t;return(0,u.jsx)("div",{...e,className:(0,k.A)(j.content,e.className),dangerouslySetInnerHTML:{__html:n}})}const A={announcementBar:"announcementBar_mb4j",announcementBarPlaceholder:"announcementBarPlaceholder_vyr4",announcementBarClose:"announcementBarClose_gvF7",announcementBarContent:"announcementBarContent_xLdY"};function C(){const{announcementBar:e}=(0,w.p)(),{isActive:t,close:n}=(0,x.Mj)();if(!t)return null;const{backgroundColor:r,textColor:a,isCloseable:o}=e;return(0,u.jsxs)("div",{className:A.announcementBar,style:{backgroundColor:r,color:a},role:"banner",children:[o&&(0,u.jsx)("div",{className:A.announcementBarPlaceholder}),(0,u.jsx)(T,{className:A.announcementBarContent}),o&&(0,u.jsx)(E,{onClick:n,className:A.announcementBarClose})]})}var R=n(22069),I=n(23104);var O=n(89532),L=n(75600);const N=r.createContext(null);function P(e){let{children:t}=e;const n=function(){const e=(0,R.M)(),t=(0,L.YL)(),[n,a]=(0,r.useState)(!1),o=null!==t.component,s=(0,O.ZC)(o);return(0,r.useEffect)((()=>{o&&!s&&a(!0)}),[o,s]),(0,r.useEffect)((()=>{o?e.shown||a(!0):a(!1)}),[e.shown,o]),(0,r.useMemo)((()=>[n,a]),[n])}();return(0,u.jsx)(N.Provider,{value:n,children:t})}function M(e){if(e.component){const t=e.component;return(0,u.jsx)(t,{...e.props})}}function D(){const e=(0,r.useContext)(N);if(!e)throw new O.dV("NavbarSecondaryMenuDisplayProvider");const[t,n]=e,a=(0,r.useCallback)((()=>n(!1)),[n]),o=(0,L.YL)();return(0,r.useMemo)((()=>({shown:t,hide:a,content:M(o)})),[a,o,t])}function F(e){let{header:t,primaryMenu:n,secondaryMenu:r}=e;const{shown:a}=D();return(0,u.jsxs)("div",{className:"navbar-sidebar",children:[t,(0,u.jsxs)("div",{className:(0,k.A)("navbar-sidebar__items",{"navbar-sidebar__items--show-secondary":a}),children:[(0,u.jsx)("div",{className:"navbar-sidebar__item menu",children:n}),(0,u.jsx)("div",{className:"navbar-sidebar__item menu",children:r})]})]})}var B=n(95293),$=n(92303);function z(e){return(0,u.jsx)("svg",{viewBox:"0 0 24 24",width:24,height:24,...e,children:(0,u.jsx)("path",{fill:"currentColor",d:"M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"})})}function U(e){return(0,u.jsx)("svg",{viewBox:"0 0 24 24",width:24,height:24,...e,children:(0,u.jsx)("path",{fill:"currentColor",d:"M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"})})}const q={toggle:"toggle_vylO",toggleButton:"toggleButton_gllP",darkToggleIcon:"darkToggleIcon_wfgR",lightToggleIcon:"lightToggleIcon_pyhR",toggleButtonDisabled:"toggleButtonDisabled_aARS"};function V(e){let{className:t,buttonClassName:n,value:r,onChange:a}=e;const o=(0,$.A)(),s=(0,l.T)({message:"Switch between dark and light mode (currently {mode})",id:"theme.colorToggle.ariaLabel",description:"The ARIA label for the navbar color mode toggle"},{mode:"dark"===r?(0,l.T)({message:"dark mode",id:"theme.colorToggle.ariaLabel.mode.dark",description:"The name for the dark color mode"}):(0,l.T)({message:"light mode",id:"theme.colorToggle.ariaLabel.mode.light",description:"The name for the light color mode"})});return(0,u.jsx)("div",{className:(0,k.A)(q.toggle,t),children:(0,u.jsxs)("button",{className:(0,k.A)("clean-btn",q.toggleButton,!o&&q.toggleButtonDisabled,n),type:"button",onClick:()=>a("dark"===r?"light":"dark"),disabled:!o,title:s,"aria-label":s,"aria-live":"polite",children:[(0,u.jsx)(z,{className:(0,k.A)(q.toggleIcon,q.lightToggleIcon)}),(0,u.jsx)(U,{className:(0,k.A)(q.toggleIcon,q.darkToggleIcon)})]})})}const H=r.memo(V),W={darkNavbarColorModeToggle:"darkNavbarColorModeToggle_X3D1"};function G(e){let{className:t}=e;const n=(0,w.p)().navbar.style,r=(0,w.p)().colorMode.disableSwitch,{colorMode:a,setColorMode:o}=(0,B.G)();return r?null:(0,u.jsx)(H,{className:t,buttonClassName:"dark"===n?W.darkNavbarColorModeToggle:void 0,value:a,onChange:o})}var K=n(23465);function Y(){return(0,u.jsx)(K.A,{className:"navbar__brand",imageClassName:"navbar__logo",titleClassName:"navbar__title text--truncate"})}function Q(){const e=(0,R.M)();return(0,u.jsx)("button",{type:"button","aria-label":(0,l.T)({id:"theme.docs.sidebar.closeSidebarButtonAriaLabel",message:"Close navigation bar",description:"The ARIA label for close button of mobile sidebar"}),className:"clean-btn navbar-sidebar__close",onClick:()=>e.toggle(),children:(0,u.jsx)(_,{color:"var(--ifm-color-emphasis-600)"})})}function J(){return(0,u.jsxs)("div",{className:"navbar-sidebar__brand",children:[(0,u.jsx)(Y,{}),(0,u.jsx)(G,{className:"margin-right--md"}),(0,u.jsx)(Q,{})]})}var Z=n(28774),X=n(86025),ee=n(16654),te=n(91252),ne=n(43186);function re(e){let{activeBasePath:t,activeBaseRegex:n,to:r,href:a,label:o,html:s,isDropdownLink:i,prependBaseUrlToHref:l,...c}=e;const d=(0,X.A)(r),p=(0,X.A)(t),f=(0,X.A)(a,{forcePrependBaseUrl:!0}),m=o&&a&&!(0,ee.A)(a),h=s?{dangerouslySetInnerHTML:{__html:s}}:{children:(0,u.jsxs)(u.Fragment,{children:[o,m&&(0,u.jsx)(ne.A,{...i&&{width:12,height:12}})]})};return a?(0,u.jsx)(Z.A,{href:l?f:a,...c,...h}):(0,u.jsx)(Z.A,{to:d,isNavLink:!0,...(t||n)&&{isActive:(e,t)=>n?(0,te.G)(n,t.pathname):t.pathname.startsWith(p)},...c,...h})}function ae(e){let{className:t,isDropdownItem:n=!1,...r}=e;const a=(0,u.jsx)(re,{className:(0,k.A)(n?"dropdown__link":"navbar__item navbar__link",t),isDropdownLink:n,...r});return n?(0,u.jsx)("li",{children:a}):a}function oe(e){let{className:t,isDropdownItem:n,...r}=e;return(0,u.jsx)("li",{className:"menu__list-item",children:(0,u.jsx)(re,{className:(0,k.A)("menu__link",t),...r})})}function se(e){let{mobile:t=!1,position:n,...r}=e;const a=t?oe:ae;return(0,u.jsx)(a,{...r,activeClassName:r.activeClassName??(t?"menu__link--active":"navbar__link--active")})}var ie=n(41422),le=n(99169),ce=n(44586);const ue={dropdownNavbarItemMobile:"dropdownNavbarItemMobile_S0Fm"};function de(e,t){return e.some((e=>function(e,t){return!!(0,le.ys)(e.to,t)||!!(0,te.G)(e.activeBaseRegex,t)||!(!e.activeBasePath||!t.startsWith(e.activeBasePath))}(e,t)))}function pe(e){let{items:t,position:n,className:a,onClick:o,...s}=e;const i=(0,r.useRef)(null),[l,c]=(0,r.useState)(!1);return(0,r.useEffect)((()=>{const e=e=>{i.current&&!i.current.contains(e.target)&&c(!1)};return document.addEventListener("mousedown",e),document.addEventListener("touchstart",e),document.addEventListener("focusin",e),()=>{document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e),document.removeEventListener("focusin",e)}}),[i]),(0,u.jsxs)("div",{ref:i,className:(0,k.A)("navbar__item","dropdown","dropdown--hoverable",{"dropdown--right":"right"===n,"dropdown--show":l}),children:[(0,u.jsx)(re,{"aria-haspopup":"true","aria-expanded":l,role:"button",href:s.to?void 0:"#",className:(0,k.A)("navbar__link",a),...s,onClick:s.to?void 0:e=>e.preventDefault(),onKeyDown:e=>{"Enter"===e.key&&(e.preventDefault(),c(!l))},children:s.children??s.label}),(0,u.jsx)("ul",{className:"dropdown__menu",children:t.map(((e,t)=>(0,r.createElement)(Fe,{isDropdownItem:!0,activeClassName:"dropdown__link--active",...e,key:t})))})]})}function fe(e){let{items:t,className:n,position:a,onClick:o,...s}=e;const l=function(){const{siteConfig:{baseUrl:e}}=(0,ce.A)(),{pathname:t}=(0,i.zy)();return t.replace(e,"/")}(),c=de(t,l),{collapsed:d,toggleCollapsed:p,setCollapsed:f}=(0,ie.u)({initialState:()=>!c});return(0,r.useEffect)((()=>{c&&f(!c)}),[l,c,f]),(0,u.jsxs)("li",{className:(0,k.A)("menu__list-item",{"menu__list-item--collapsed":d}),children:[(0,u.jsx)(re,{role:"button",className:(0,k.A)(ue.dropdownNavbarItemMobile,"menu__link menu__link--sublist menu__link--sublist-caret",n),...s,onClick:e=>{e.preventDefault(),p()},children:s.children??s.label}),(0,u.jsx)(ie.N,{lazy:!0,as:"ul",className:"menu__list",collapsed:d,children:t.map(((e,t)=>(0,r.createElement)(Fe,{mobile:!0,isDropdownItem:!0,onClick:o,activeClassName:"menu__link--active",...e,key:t})))})]})}function me(e){let{mobile:t=!1,...n}=e;const r=t?fe:pe;return(0,u.jsx)(r,{...n})}var he=n(32131);function ge(e){let{width:t=20,height:n=20,...r}=e;return(0,u.jsx)("svg",{viewBox:"0 0 24 24",width:t,height:n,"aria-hidden":!0,...r,children:(0,u.jsx)("path",{fill:"currentColor",d:"M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z"})})}const be="iconLanguage_nlXk";var ye=n(40961),ve=n(22525),we=n(17785),xe=n(5260),ke=n(24255),_e=n(51062),Se=n(2967);const Ee={button:{buttonText:(0,l.T)({id:"theme.SearchBar.label",message:"Search",description:"The ARIA label and placeholder for search button"}),buttonAriaLabel:(0,l.T)({id:"theme.SearchBar.label",message:"Search",description:"The ARIA label and placeholder for search button"})},modal:{searchBox:{resetButtonTitle:(0,l.T)({id:"theme.SearchModal.searchBox.resetButtonTitle",message:"Clear the query",description:"The label and ARIA label for search box reset button"}),resetButtonAriaLabel:(0,l.T)({id:"theme.SearchModal.searchBox.resetButtonTitle",message:"Clear the query",description:"The label and ARIA label for search box reset button"}),cancelButtonText:(0,l.T)({id:"theme.SearchModal.searchBox.cancelButtonText",message:"Cancel",description:"The label and ARIA label for search box cancel button"}),cancelButtonAriaLabel:(0,l.T)({id:"theme.SearchModal.searchBox.cancelButtonText",message:"Cancel",description:"The label and ARIA label for search box cancel button"})},startScreen:{recentSearchesTitle:(0,l.T)({id:"theme.SearchModal.startScreen.recentSearchesTitle",message:"Recent",description:"The title for recent searches"}),noRecentSearchesText:(0,l.T)({id:"theme.SearchModal.startScreen.noRecentSearchesText",message:"No recent searches",description:"The text when no recent searches"}),saveRecentSearchButtonTitle:(0,l.T)({id:"theme.SearchModal.startScreen.saveRecentSearchButtonTitle",message:"Save this search",description:"The label for save recent search button"}),removeRecentSearchButtonTitle:(0,l.T)({id:"theme.SearchModal.startScreen.removeRecentSearchButtonTitle",message:"Remove this search from history",description:"The label for remove recent search button"}),favoriteSearchesTitle:(0,l.T)({id:"theme.SearchModal.startScreen.favoriteSearchesTitle",message:"Favorite",description:"The title for favorite searches"}),removeFavoriteSearchButtonTitle:(0,l.T)({id:"theme.SearchModal.startScreen.removeFavoriteSearchButtonTitle",message:"Remove this search from favorites",description:"The label for remove favorite search button"})},errorScreen:{titleText:(0,l.T)({id:"theme.SearchModal.errorScreen.titleText",message:"Unable to fetch results",description:"The title for error screen of search modal"}),helpText:(0,l.T)({id:"theme.SearchModal.errorScreen.helpText",message:"You might want to check your network connection.",description:"The help text for error screen of search modal"})},footer:{selectText:(0,l.T)({id:"theme.SearchModal.footer.selectText",message:"to select",description:"The explanatory text of the action for the enter key"}),selectKeyAriaLabel:(0,l.T)({id:"theme.SearchModal.footer.selectKeyAriaLabel",message:"Enter key",description:"The ARIA label for the Enter key button that makes the selection"}),navigateText:(0,l.T)({id:"theme.SearchModal.footer.navigateText",message:"to navigate",description:"The explanatory text of the action for the Arrow up and Arrow down key"}),navigateUpKeyAriaLabel:(0,l.T)({id:"theme.SearchModal.footer.navigateUpKeyAriaLabel",message:"Arrow up",description:"The ARIA label for the Arrow up key button that makes the navigation"}),navigateDownKeyAriaLabel:(0,l.T)({id:"theme.SearchModal.footer.navigateDownKeyAriaLabel",message:"Arrow down",description:"The ARIA label for the Arrow down key button that makes the navigation"}),closeText:(0,l.T)({id:"theme.SearchModal.footer.closeText",message:"to close",description:"The explanatory text of the action for Escape key"}),closeKeyAriaLabel:(0,l.T)({id:"theme.SearchModal.footer.closeKeyAriaLabel",message:"Escape key",description:"The ARIA label for the Escape key button that close the modal"}),searchByText:(0,l.T)({id:"theme.SearchModal.footer.searchByText",message:"Search by",description:"The text explain that the search is making by Algolia"})},noResultsScreen:{noResultsText:(0,l.T)({id:"theme.SearchModal.noResultsScreen.noResultsText",message:"No results for",description:"The text explains that there are no results for the following search"}),suggestedQueryText:(0,l.T)({id:"theme.SearchModal.noResultsScreen.suggestedQueryText",message:"Try searching for",description:"The text for the suggested query when no results are found for the following search"}),reportMissingResultsText:(0,l.T)({id:"theme.SearchModal.noResultsScreen.reportMissingResultsText",message:"Believe this query should return results?",description:"The text for the question where the user thinks there are missing results"}),reportMissingResultsLinkText:(0,l.T)({id:"theme.SearchModal.noResultsScreen.reportMissingResultsLinkText",message:"Let us know.",description:"The text for the link to report missing results"})}},placeholder:(0,l.T)({id:"theme.SearchModal.placeholder",message:"Search docs",description:"The placeholder of the input of the DocSearch pop-up modal"})};let je=null;function Te(e){let{hit:t,children:n}=e;return(0,u.jsx)(Z.A,{to:t.url,children:n})}function Ae(e){let{state:t,onClose:n}=e;const r=(0,ke.w)();return(0,u.jsx)(Z.A,{to:r(t.query),onClick:n,children:(0,u.jsx)(l.A,{id:"theme.SearchBar.seeAll",values:{count:t.context.nbHits},children:"See all {count} results"})})}function Ce(e){let{contextualSearch:t,externalUrlRegex:a,...o}=e;const{siteMetadata:s}=(0,ce.A)(),l=(0,_e.C)(),c=function(){const{locale:e,tags:t}=(0,Se.af)();return[`language:${e}`,t.map((e=>`docusaurus_tag:${e}`))]}(),d=o.searchParameters?.facetFilters??[],p=t?function(e,t){const n=e=>"string"==typeof e?[e]:e;return[...n(e),...n(t)]}(c,d):d,f={...o.searchParameters,facetFilters:p},m=(0,i.W6)(),h=(0,r.useRef)(null),g=(0,r.useRef)(null),[b,y]=(0,r.useState)(!1),[v,w]=(0,r.useState)(void 0),x=(0,r.useCallback)((()=>je?Promise.resolve():Promise.all([Promise.all([n.e(6513),n.e(8158)]).then(n.bind(n,48158)),Promise.all([n.e(1869),n.e(8913)]).then(n.bind(n,58913)),Promise.all([n.e(1869),n.e(416)]).then(n.bind(n,90416))]).then((e=>{let[{DocSearchModal:t}]=e;je=t}))),[]),k=(0,r.useCallback)((()=>{x().then((()=>{h.current=document.createElement("div"),document.body.insertBefore(h.current,document.body.firstChild),y(!0)}))}),[x,y]),_=(0,r.useCallback)((()=>{y(!1),h.current?.remove()}),[y]),S=(0,r.useCallback)((e=>{x().then((()=>{y(!0),w(e.key)}))}),[x,y,w]),E=(0,r.useRef)({navigate(e){let{itemUrl:t}=e;(0,te.G)(a,t)?window.location.href=t:m.push(t)}}).current,j=(0,r.useRef)((e=>o.transformItems?o.transformItems(e):e.map((e=>({...e,url:l(e.url)}))))).current,T=(0,r.useMemo)((()=>e=>(0,u.jsx)(Ae,{...e,onClose:_})),[_]),A=(0,r.useCallback)((e=>(e.addAlgoliaAgent("docusaurus",s.docusaurusVersion),e)),[s.docusaurusVersion]);return(0,ve.E)({isOpen:b,onOpen:k,onClose:_,onInput:S,searchButtonRef:g}),(0,u.jsxs)(u.Fragment,{children:[(0,u.jsx)(xe.A,{children:(0,u.jsx)("link",{rel:"preconnect",href:`https://${o.appId}-dsn.algolia.net`,crossOrigin:"anonymous"})}),(0,u.jsx)(we.B,{onTouchStart:x,onFocus:x,onMouseOver:x,onClick:k,ref:g,translations:Ee.button}),b&&je&&h.current&&(0,ye.createPortal)((0,u.jsx)(je,{onClose:_,initialScrollY:window.scrollY,initialQuery:v,navigator:E,transformItems:j,hitComponent:Te,transformSearchClient:A,...o.searchPagePath&&{resultsFooterComponent:T},...o,searchParameters:f,placeholder:Ee.placeholder,translations:Ee.modal}),h.current)]})}function Re(){const{siteConfig:e}=(0,ce.A)();return(0,u.jsx)(Ce,{...e.themeConfig.algolia})}const Ie={navbarSearchContainer:"navbarSearchContainer_Bca1"};function Oe(e){let{children:t,className:n}=e;return(0,u.jsx)("div",{className:(0,k.A)(n,Ie.navbarSearchContainer),children:t})}var Le=n(48295),Ne=n(84142);var Pe=n(55597);const Me=e=>e.docs.find((t=>t.id===e.mainDocId));const De={default:se,localeDropdown:function(e){let{mobile:t,dropdownItemsBefore:n,dropdownItemsAfter:r,queryString:a="",...o}=e;const{i18n:{currentLocale:s,locales:c,localeConfigs:d}}=(0,ce.A)(),p=(0,he.o)(),{search:f,hash:m}=(0,i.zy)(),h=[...n,...c.map((e=>{const n=`${`pathname://${p.createUrl({locale:e,fullyQualified:!1})}`}${f}${m}${a}`;return{label:d[e].label,lang:d[e].htmlLang,to:n,target:"_self",autoAddBaseUrl:!1,className:e===s?t?"menu__link--active":"dropdown__link--active":""}})),...r],g=t?(0,l.T)({message:"Languages",id:"theme.navbar.mobileLanguageDropdown.label",description:"The label for the mobile language switcher dropdown"}):d[s].label;return(0,u.jsx)(me,{...o,mobile:t,label:(0,u.jsxs)(u.Fragment,{children:[(0,u.jsx)(ge,{className:be}),g]}),items:h})},search:function(e){let{mobile:t,className:n}=e;return t?null:(0,u.jsx)(Oe,{className:n,children:(0,u.jsx)(Re,{})})},dropdown:me,html:function(e){let{value:t,className:n,mobile:r=!1,isDropdownItem:a=!1}=e;const o=a?"li":"div";return(0,u.jsx)(o,{className:(0,k.A)({navbar__item:!r&&!a,"menu__list-item":r},n),dangerouslySetInnerHTML:{__html:t}})},doc:function(e){let{docId:t,label:n,docsPluginId:r,...a}=e;const{activeDoc:o}=(0,Le.zK)(r),s=(0,Ne.QB)(t,r),i=o?.path===s?.path;return null===s||s.unlisted&&!i?null:(0,u.jsx)(se,{exact:!0,...a,isActive:()=>i||!!o?.sidebar&&o.sidebar===s.sidebar,label:n??s.id,to:s.path})},docSidebar:function(e){let{sidebarId:t,label:n,docsPluginId:r,...a}=e;const{activeDoc:o}=(0,Le.zK)(r),s=(0,Ne.fW)(t,r).link;if(!s)throw new Error(`DocSidebarNavbarItem: Sidebar with ID "${t}" doesn't have anything to be linked to.`);return(0,u.jsx)(se,{exact:!0,...a,isActive:()=>o?.sidebar===t,label:n??s.label,to:s.path})},docsVersion:function(e){let{label:t,to:n,docsPluginId:r,...a}=e;const o=(0,Ne.Vd)(r)[0],s=t??o.label,i=n??(e=>e.docs.find((t=>t.id===e.mainDocId)))(o).path;return(0,u.jsx)(se,{...a,label:s,to:i})},docsVersionDropdown:function(e){let{mobile:t,docsPluginId:n,dropdownActiveClassDisabled:r,dropdownItemsBefore:a,dropdownItemsAfter:o,...s}=e;const{search:c,hash:d}=(0,i.zy)(),p=(0,Le.zK)(n),f=(0,Le.jh)(n),{savePreferredVersionName:m}=(0,Pe.g1)(n),h=[...a,...f.map((e=>{const t=p.alternateDocVersions[e.name]??Me(e);return{label:e.label,to:`${t.path}${c}${d}`,isActive:()=>e===p.activeVersion,onClick:()=>m(e.name)}})),...o],g=(0,Ne.Vd)(n)[0],b=t&&h.length>1?(0,l.T)({id:"theme.navbar.mobileVersionsDropdown.label",message:"Versions",description:"The label for the navbar versions dropdown on mobile view"}):g.label,y=t&&h.length>1?void 0:Me(g).path;return h.length<=1?(0,u.jsx)(se,{...s,mobile:t,label:b,to:y,isActive:r?()=>!1:void 0}):(0,u.jsx)(me,{...s,mobile:t,label:b,to:y,items:h,isActive:r?()=>!1:void 0})}};function Fe(e){let{type:t,...n}=e;const r=function(e,t){return e&&"default"!==e?e:"items"in t?"dropdown":"default"}(t,n),a=De[r];if(!a)throw new Error(`No NavbarItem component found for type "${t}".`);return(0,u.jsx)(a,{...n})}function Be(){const e=(0,R.M)(),t=(0,w.p)().navbar.items;return(0,u.jsx)("ul",{className:"menu__list",children:t.map(((t,n)=>(0,r.createElement)(Fe,{mobile:!0,...t,onClick:()=>e.toggle(),key:n})))})}function $e(e){return(0,u.jsx)("button",{...e,type:"button",className:"clean-btn navbar-sidebar__back",children:(0,u.jsx)(l.A,{id:"theme.navbar.mobileSidebarSecondaryMenu.backButtonLabel",description:"The label of the back button to return to main menu, inside the mobile navbar sidebar secondary menu (notably used to display the docs sidebar)",children:"\u2190 Back to main menu"})})}function ze(){const e=0===(0,w.p)().navbar.items.length,t=D();return(0,u.jsxs)(u.Fragment,{children:[!e&&(0,u.jsx)($e,{onClick:()=>t.hide()}),t.content]})}function Ue(){const e=(0,R.M)();var t;return void 0===(t=e.shown)&&(t=!0),(0,r.useEffect)((()=>(document.body.style.overflow=t?"hidden":"visible",()=>{document.body.style.overflow="visible"})),[t]),e.shouldRender?(0,u.jsx)(F,{header:(0,u.jsx)(J,{}),primaryMenu:(0,u.jsx)(Be,{}),secondaryMenu:(0,u.jsx)(ze,{})}):null}const qe={navbarHideable:"navbarHideable_m1mJ",navbarHidden:"navbarHidden_jGov"};function Ve(e){return(0,u.jsx)("div",{role:"presentation",...e,className:(0,k.A)("navbar-sidebar__backdrop",e.className)})}function He(e){let{children:t}=e;const{navbar:{hideOnScroll:n,style:a}}=(0,w.p)(),o=(0,R.M)(),{navbarRef:s,isNavbarVisible:i}=function(e){const[t,n]=(0,r.useState)(e),a=(0,r.useRef)(!1),o=(0,r.useRef)(0),s=(0,r.useCallback)((e=>{null!==e&&(o.current=e.getBoundingClientRect().height)}),[]);return(0,I.Mq)(((t,r)=>{let{scrollY:s}=t;if(!e)return;if(s=i?n(!1):s+c{if(!e)return;const r=t.location.hash;if(r?document.getElementById(r.substring(1)):void 0)return a.current=!0,void n(!1);n(!0)})),{navbarRef:s,isNavbarVisible:t}}(n);return(0,u.jsxs)("nav",{ref:s,"aria-label":(0,l.T)({id:"theme.NavBar.navAriaLabel",message:"Main",description:"The ARIA label for the main navigation"}),className:(0,k.A)("navbar","navbar--fixed-top",n&&[qe.navbarHideable,!i&&qe.navbarHidden],{"navbar--dark":"dark"===a,"navbar--primary":"primary"===a,"navbar-sidebar--show":o.shown}),children:[t,(0,u.jsx)(Ve,{onClick:o.toggle}),(0,u.jsx)(Ue,{})]})}var We=n(12181);const Ge="right";function Ke(e){let{width:t=30,height:n=30,className:r,...a}=e;return(0,u.jsx)("svg",{className:r,width:t,height:n,viewBox:"0 0 30 30","aria-hidden":"true",...a,children:(0,u.jsx)("path",{stroke:"currentColor",strokeLinecap:"round",strokeMiterlimit:"10",strokeWidth:"2",d:"M4 7h22M4 15h22M4 23h22"})})}function Ye(){const{toggle:e,shown:t}=(0,R.M)();return(0,u.jsx)("button",{onClick:e,"aria-label":(0,l.T)({id:"theme.docs.sidebar.toggleSidebarButtonAriaLabel",message:"Toggle navigation bar",description:"The ARIA label for hamburger menu button of mobile navigation"}),"aria-expanded":t,className:"navbar__toggle clean-btn",type:"button",children:(0,u.jsx)(Ke,{})})}const Qe={colorModeToggle:"colorModeToggle_DEke"};function Je(e){let{items:t}=e;return(0,u.jsx)(u.Fragment,{children:t.map(((e,t)=>(0,u.jsx)(We.k2,{onError:t=>new Error(`A theme navbar item failed to render.\nPlease double-check the following navbar item (themeConfig.navbar.items) of your Docusaurus config:\n${JSON.stringify(e,null,2)}`,{cause:t}),children:(0,u.jsx)(Fe,{...e})},t)))})}function Ze(e){let{left:t,right:n}=e;return(0,u.jsxs)("div",{className:"navbar__inner",children:[(0,u.jsx)("div",{className:"navbar__items",children:t}),(0,u.jsx)("div",{className:"navbar__items navbar__items--right",children:n})]})}function Xe(){const e=(0,R.M)(),t=(0,w.p)().navbar.items,[n,r]=function(e){function t(e){return"left"===(e.position??Ge)}return[e.filter(t),e.filter((e=>!t(e)))]}(t),a=t.find((e=>"search"===e.type));return(0,u.jsx)(Ze,{left:(0,u.jsxs)(u.Fragment,{children:[!e.disabled&&(0,u.jsx)(Ye,{}),(0,u.jsx)(Y,{}),(0,u.jsx)(Je,{items:n})]}),right:(0,u.jsxs)(u.Fragment,{children:[(0,u.jsx)(Je,{items:r}),(0,u.jsx)(G,{className:Qe.colorModeToggle}),!a&&(0,u.jsx)(Oe,{children:(0,u.jsx)(Re,{})})]})})}function et(){return(0,u.jsx)(He,{children:(0,u.jsx)(Xe,{})})}var tt=n(54263),nt=n(35504),rt=n(49785);const at=[{icon:(0,u.jsx)(tt.oU_,{className:"text-xl text-black/60 dark:text-white/60"}),href:"https://twitter.com/janframework"},{icon:(0,u.jsx)(nt.wZs,{className:"text-xl text-black/60 dark:text-white/60"}),href:"https://discord.com/invite/FTk2MvZwJH"},{icon:(0,u.jsx)(tt.Gy$,{className:"text-lg text-black/60 dark:text-white/60"}),href:"https://github.com/janhq/jan"},{icon:(0,u.jsx)(nt.LnC,{className:"text-xl text-black/60 dark:text-white/60"}),href:"https://www.linkedin.com/company/janframework/"}],ot=[{name:"Product",child:[{menu:"Download",path:"/download"},{menu:"Documentation",path:"/developer"},{menu:"Changelog",path:"https://github.com/janhq/jan/releases",external:!0}]},{name:"For Developers",child:[{menu:"Guides",path:"/guides"},{menu:"Developer",path:"/developer"},{menu:"API Reference",path:"/api-reference"}]},{name:"Community",child:[{menu:"Github",path:"https://github.com/janhq/jan",external:!0},{menu:"Discord",path:"https://discord.gg/FTk2MvZwJH",external:!0},{menu:"Twitter",path:"https://twitter.com/janframework",external:!0},{menu:"LinkedIn",path:"https://www.linkedin.com/company/janframework/",external:!0}]},{name:"Company",child:[{menu:"About",path:"/about"},{menu:"Blog",path:"/blog"},{menu:"Careers",path:"https://janai.bamboohr.com/careers",external:!0},{menu:"Newsletter",path:"/community#newsletter"}]}],st=(new Date).getFullYear();function it(){const{register:e,handleSubmit:t,reset:n}=(0,rt.mN)({defaultValues:{email:""}}),{siteConfig:{customFields:a}}=(0,ce.A)(),[o,s]=(0,r.useState)("");return(0,u.jsxs)("footer",{className:"flex-shrink-0 relative overflow-hidden py-10",children:[(0,u.jsx)("div",{className:"container",children:(0,u.jsxs)("div",{className:"grid grid-cols-2 gap-8 md:grid-cols-2 lg:grid-cols-6",children:[(0,u.jsxs)("div",{className:"col-span-2",children:[(0,u.jsxs)("div",{className:"flex items-center space-x-2 mb-3",children:[(0,u.jsx)("img",{alt:"Jan Logo",src:"/img/logo.svg"}),(0,u.jsx)("h2",{className:"h5",children:"Jan"})]}),(0,u.jsxs)("div",{className:"w-full lg:w-3/4 mt-2",children:[(0,u.jsx)("h6",{children:"The Soul of a New Machine"}),(0,u.jsxs)("p",{className:"dark:text-gray-400 text-gray-600 mt-2",children:["Subscribe to our newsletter on AI"," ",(0,u.jsx)("br",{className:"hidden lg:block"}),"research and building Jan:"]}),(0,u.jsxs)("div",{className:"mt-4",children:[(0,u.jsxs)("form",{className:"relative",onSubmit:t((e=>{const{email:t}=e,r={method:"POST",body:JSON.stringify({updateEnabled:!1,email:t,listIds:[13]})};t&&fetch("https://brevo.jan.ai/",r).then((e=>e.json())).then((e=>{e.id?s("You have successfully joined our newsletter"):s(e.message),n(),setTimeout((()=>{s("")}),5e3)})).catch((e=>console.error(e)))})),children:[(0,u.jsx)("input",{type:"email",className:"w-full h-12 p-4 pr-14 rounded-xl border dark:border-gray-600 dark:bg-[#252525] border-[#F0F0F0]",placeholder:"Enter your email",...e("email")}),(0,u.jsx)("button",{type:"submit",className:"absolute flex p-2 bg-black dark:bg-[#3B3B3C] w-8 h-8 border dark:border-gray-600 rounded-lg top-1/2 right-3 -translate-y-1/2",children:(0,u.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:(0,u.jsx)("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M6.09026 8.41933L3.72077 7.62985C1.24061 6.80348 0 6.3903 0 5.63033C0 4.87142 1.24061 4.45718 3.72077 3.63081L12.6938 0.639442C14.4393 0.0576106 15.3121 -0.233305 15.7727 0.227312C16.2333 0.687928 15.9424 1.56068 15.3616 3.30512L12.3692 12.2792C11.5428 14.7594 11.1296 16 10.3697 16C9.61076 16 9.19652 14.7594 8.37015 12.2792L7.57962 9.9108L12.1689 5.3215C12.3609 5.1227 12.4672 4.85645 12.4648 4.58008C12.4624 4.30372 12.3515 4.03935 12.1561 3.84392C11.9607 3.64849 11.6963 3.53764 11.4199 3.53524C11.1435 3.53284 10.8773 3.63908 10.6785 3.83108L6.09026 8.41933Z",fill:"white"})})})]}),o&&(0,u.jsx)("p",{className:"text-left mt-4",children:o})]})]})]}),ot.map(((e,t)=>(0,u.jsxs)("div",{className:"lg:text-right",children:[(0,u.jsx)("h2",{className:"mb-3 h6",children:e.name}),(0,u.jsx)("ul",{children:e.child.map(((e,t)=>(0,u.jsx)("li",{children:(0,u.jsx)("a",{href:e.path,target:e.external?"_blank":"_self",className:"inline-block py-1 dark:text-gray-400 text-gray-600",children:e.menu})},t)))})]},t)))]})}),(0,u.jsx)("div",{className:"container mt-8",children:(0,u.jsxs)("div",{className:"flex w-full justify-between items-center",children:[(0,u.jsxs)("span",{className:"dark:text-gray-300 text-gray-700",children:["\xa9",st,"\xa0Jan AI Pte Ltd."]}),(0,u.jsx)("div",{className:"flex items-center gap-x-3",children:at.map(((e,t)=>(0,u.jsx)("a",{"aria-label":`social-${t}`,href:e.href,target:"_blank",rel:"noopener",children:e.icon},t)))})]})})]})}const lt=(0,O.fM)([B.a,x.oq,I.Tv,Pe.VQ,s.Jx,function(e){let{children:t}=e;return(0,u.jsx)(L.y_,{children:(0,u.jsx)(R.e,{children:(0,u.jsx)(P,{children:t})})})}]);function ct(e){let{children:t}=e;return(0,u.jsx)(lt,{children:t})}var ut=n(51107);function dt(e){let{error:t,tryAgain:n}=e;return(0,u.jsx)("main",{className:"container margin-vert--xl",children:(0,u.jsx)("div",{className:"row",children:(0,u.jsxs)("div",{className:"col col--6 col--offset-3",children:[(0,u.jsx)(ut.A,{as:"h1",className:"hero__title",children:(0,u.jsx)(l.A,{id:"theme.ErrorPageContent.title",description:"The title of the fallback page when the page crashed",children:"This page crashed."})}),(0,u.jsx)("div",{className:"margin-vert--lg",children:(0,u.jsx)(We.a2,{onClick:n,className:"button button--primary shadow--lw"})}),(0,u.jsx)("hr",{}),(0,u.jsx)("div",{className:"margin-vert--md",children:(0,u.jsx)(We.bq,{error:t})})]})})})}const pt={mainWrapper:"mainWrapper_l3_l"};var ft=n(54625);function mt(){(0,i.zy)();return(0,u.jsx)("nav",{className:"bg-white dark:bg-gray-800 h-12 px-10 pt-3 flex items-center justify-between fixed top-14 left-0 w-full z-50 hidden md:block",children:(0,u.jsxs)("div",{className:"flex items-center space-x-16",children:[(0,u.jsx)(ft.k2,{to:"/docs",className:"text-gray-700 font-medium hover:text-gray-900 dark:text-gray-300 dark:hover:text-gray-200",activeClassName:"text-gray-900 dark:text-gray-100 font-bold border-b-2 border-gray-900 dark:border-gray-100",children:"Docs"}),(0,u.jsx)(ft.k2,{to:"/guides",className:"text-gray-700 font-medium hover:text-gray-900 dark:text-gray-300 dark:hover:text-gray-200",activeClassName:"text-gray-900 dark:text-gray-100 font-bold border-b-2 border-gray-900 dark:border-gray-100",children:"Guides"}),(0,u.jsx)(ft.k2,{to:"/developer",className:"text-gray-700 font-medium hover:text-gray-900 dark:text-gray-300 dark:hover:text-gray-200",activeClassName:"text-gray-900 dark:text-gray-100 font-semibold border-b-2 border-gray-900 dark:border-gray-100",children:"Developer"}),(0,u.jsx)(ft.k2,{to:"/api-reference",className:"text-gray-700 font-medium hover:text-gray-900 dark:text-gray-300 dark:hover:text-gray-200",activeClassName:"text-gray-900 dark:text-gray-100 font-semibold border-b-2 border-gray-900 dark:border-gray-100",children:"API Reference"}),(0,u.jsx)(ft.k2,{to:"/changelog",className:"text-gray-700 font-medium hover:text-gray-900 dark:text-gray-300 dark:hover:text-gray-200",activeClassName:"text-gray-900 dark:text-gray-100 font-bold border-b-2 border-gray-900 dark:border-gray-100",children:"Changelog"})]})})}const ht=["/docs/","/developer/","/api-reference/","/guides/","/guides","/docs","/developer","/api-reference","/changelog"];function gt(e){const{children:t,noFooter:n,wrapperClassName:r,title:l,description:c}=e;(0,b.J)();const p=(0,i.zy)(),f=ht.some((e=>p.pathname.startsWith(e)));return(0,u.jsxs)(ct,{children:[(0,u.jsx)(s.be,{title:l,description:c}),(0,u.jsx)(v,{}),(0,u.jsx)(C,{}),(0,u.jsx)(et,{}),f?(0,u.jsx)(mt,{}):"",(0,u.jsx)("div",{id:d,className:(0,a.A)(g.G.wrapper.main,pt.mainWrapper,r,f&&"mt-0 md:mt-11"),children:(0,u.jsx)(o.A,{fallback:e=>(0,u.jsx)(dt,{...e}),children:t})}),!n&&(0,u.jsx)(it,{})]})}},20053:(e,t,n)=>{"use strict";function r(e){var t,n,a="";if("string"==typeof e||"number"==typeof e)a+=e;else if("object"==typeof e)if(Array.isArray(e))for(t=0;ta});const a=function(){for(var e,t,n=0,a="";n{"use strict";n.d(t,{zR:()=>w,TM:()=>j,yJ:()=>f,sC:()=>A,AO:()=>p});var r=n(58168);function a(e){return"/"===e.charAt(0)}function o(e,t){for(var n=t,r=n+1,a=e.length;r=0;p--){var f=s[p];"."===f?o(s,p):".."===f?(o(s,p),d++):d&&(o(s,p),d--)}if(!c)for(;d--;d)s.unshift("..");!c||""===s[0]||s[0]&&a(s[0])||s.unshift("");var m=s.join("/");return n&&"/"!==m.substr(-1)&&(m+="/"),m};var i=n(11561);function l(e){return"/"===e.charAt(0)?e:"/"+e}function c(e){return"/"===e.charAt(0)?e.substr(1):e}function u(e,t){return function(e,t){return 0===e.toLowerCase().indexOf(t.toLowerCase())&&-1!=="/?#".indexOf(e.charAt(t.length))}(e,t)?e.substr(t.length):e}function d(e){return"/"===e.charAt(e.length-1)?e.slice(0,-1):e}function p(e){var t=e.pathname,n=e.search,r=e.hash,a=t||"/";return n&&"?"!==n&&(a+="?"===n.charAt(0)?n:"?"+n),r&&"#"!==r&&(a+="#"===r.charAt(0)?r:"#"+r),a}function f(e,t,n,a){var o;"string"==typeof e?(o=function(e){var t=e||"/",n="",r="",a=t.indexOf("#");-1!==a&&(r=t.substr(a),t=t.substr(0,a));var o=t.indexOf("?");return-1!==o&&(n=t.substr(o),t=t.substr(0,o)),{pathname:t,search:"?"===n?"":n,hash:"#"===r?"":r}}(e),o.state=t):(void 0===(o=(0,r.A)({},e)).pathname&&(o.pathname=""),o.search?"?"!==o.search.charAt(0)&&(o.search="?"+o.search):o.search="",o.hash?"#"!==o.hash.charAt(0)&&(o.hash="#"+o.hash):o.hash="",void 0!==t&&void 0===o.state&&(o.state=t));try{o.pathname=decodeURI(o.pathname)}catch(i){throw i instanceof URIError?new URIError('Pathname "'+o.pathname+'" could not be decoded. This is likely caused by an invalid percent-encoding.'):i}return n&&(o.key=n),a?o.pathname?"/"!==o.pathname.charAt(0)&&(o.pathname=s(o.pathname,a.pathname)):o.pathname=a.pathname:o.pathname||(o.pathname="/"),o}function m(){var e=null;var t=[];return{setPrompt:function(t){return e=t,function(){e===t&&(e=null)}},confirmTransitionTo:function(t,n,r,a){if(null!=e){var o="function"==typeof e?e(t,n):e;"string"==typeof o?"function"==typeof r?r(o,a):a(!0):a(!1!==o)}else a(!0)},appendListener:function(e){var n=!0;function r(){n&&e.apply(void 0,arguments)}return t.push(r),function(){n=!1,t=t.filter((function(e){return e!==r}))}},notifyListeners:function(){for(var e=arguments.length,n=new Array(e),r=0;rt?n.splice(t,n.length-t,a):n.push(a),d({action:r,location:a,index:t,entries:n})}}))},replace:function(e,t){var r="REPLACE",a=f(e,t,h(),w.location);u.confirmTransitionTo(a,r,n,(function(e){e&&(w.entries[w.index]=a,d({action:r,location:a}))}))},go:v,goBack:function(){v(-1)},goForward:function(){v(1)},canGo:function(e){var t=w.index+e;return t>=0&&t{"use strict";var r=n(44363),a={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},o={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},s={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},i={};function l(e){return r.isMemo(e)?s:i[e.$$typeof]||a}i[r.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},i[r.Memo]=s;var c=Object.defineProperty,u=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,p=Object.getOwnPropertyDescriptor,f=Object.getPrototypeOf,m=Object.prototype;e.exports=function e(t,n,r){if("string"!=typeof n){if(m){var a=f(n);a&&a!==m&&e(t,a,r)}var s=u(n);d&&(s=s.concat(d(n)));for(var i=l(t),h=l(n),g=0;g{"use strict";e.exports=function(e,t,n,r,a,o,s,i){if(!e){var l;if(void 0===t)l=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var c=[n,r,a,o,s,i],u=0;(l=new Error(t.replace(/%s/g,(function(){return c[u++]})))).name="Invariant Violation"}throw l.framesToPop=1,l}}},64634:e=>{e.exports=Array.isArray||function(e){return"[object Array]"==Object.prototype.toString.call(e)}},73339:(e,t,n)=>{"use strict";n.r(t)},7767:(e,t,n)=>{"use strict";n.r(t)},10119:(e,t,n)=>{"use strict";n.r(t)},5947:function(e,t,n){var r,a;r=function(){var e,t,n={version:"0.2.0"},r=n.settings={minimum:.08,easing:"ease",positionUsing:"",speed:200,trickle:!0,trickleRate:.02,trickleSpeed:800,showSpinner:!0,barSelector:'[role="bar"]',spinnerSelector:'[role="spinner"]',parent:"body",template:'
    '};function a(e,t,n){return en?n:e}function o(e){return 100*(-1+e)}function s(e,t,n){var a;return(a="translate3d"===r.positionUsing?{transform:"translate3d("+o(e)+"%,0,0)"}:"translate"===r.positionUsing?{transform:"translate("+o(e)+"%,0)"}:{"margin-left":o(e)+"%"}).transition="all "+t+"ms "+n,a}n.configure=function(e){var t,n;for(t in e)void 0!==(n=e[t])&&e.hasOwnProperty(t)&&(r[t]=n);return this},n.status=null,n.set=function(e){var t=n.isStarted();e=a(e,r.minimum,1),n.status=1===e?null:e;var o=n.render(!t),c=o.querySelector(r.barSelector),u=r.speed,d=r.easing;return o.offsetWidth,i((function(t){""===r.positionUsing&&(r.positionUsing=n.getPositioningCSS()),l(c,s(e,u,d)),1===e?(l(o,{transition:"none",opacity:1}),o.offsetWidth,setTimeout((function(){l(o,{transition:"all "+u+"ms linear",opacity:0}),setTimeout((function(){n.remove(),t()}),u)}),u)):setTimeout(t,u)})),this},n.isStarted=function(){return"number"==typeof n.status},n.start=function(){n.status||n.set(0);var e=function(){setTimeout((function(){n.status&&(n.trickle(),e())}),r.trickleSpeed)};return r.trickle&&e(),this},n.done=function(e){return e||n.status?n.inc(.3+.5*Math.random()).set(1):this},n.inc=function(e){var t=n.status;return t?("number"!=typeof e&&(e=(1-t)*a(Math.random()*t,.1,.95)),t=a(t+e,0,.994),n.set(t)):n.start()},n.trickle=function(){return n.inc(Math.random()*r.trickleRate)},e=0,t=0,n.promise=function(r){return r&&"resolved"!==r.state()?(0===t&&n.start(),e++,t++,r.always((function(){0==--t?(e=0,n.done()):n.set((e-t)/e)})),this):this},n.render=function(e){if(n.isRendered())return document.getElementById("nprogress");u(document.documentElement,"nprogress-busy");var t=document.createElement("div");t.id="nprogress",t.innerHTML=r.template;var a,s=t.querySelector(r.barSelector),i=e?"-100":o(n.status||0),c=document.querySelector(r.parent);return l(s,{transition:"all 0 linear",transform:"translate3d("+i+"%,0,0)"}),r.showSpinner||(a=t.querySelector(r.spinnerSelector))&&f(a),c!=document.body&&u(c,"nprogress-custom-parent"),c.appendChild(t),t},n.remove=function(){d(document.documentElement,"nprogress-busy"),d(document.querySelector(r.parent),"nprogress-custom-parent");var e=document.getElementById("nprogress");e&&f(e)},n.isRendered=function(){return!!document.getElementById("nprogress")},n.getPositioningCSS=function(){var e=document.body.style,t="WebkitTransform"in e?"Webkit":"MozTransform"in e?"Moz":"msTransform"in e?"ms":"OTransform"in e?"O":"";return t+"Perspective"in e?"translate3d":t+"Transform"in e?"translate":"margin"};var i=function(){var e=[];function t(){var n=e.shift();n&&n(t)}return function(n){e.push(n),1==e.length&&t()}}(),l=function(){var e=["Webkit","O","Moz","ms"],t={};function n(e){return e.replace(/^-ms-/,"ms-").replace(/-([\da-z])/gi,(function(e,t){return t.toUpperCase()}))}function r(t){var n=document.body.style;if(t in n)return t;for(var r,a=e.length,o=t.charAt(0).toUpperCase()+t.slice(1);a--;)if((r=e[a]+o)in n)return r;return t}function a(e){return e=n(e),t[e]||(t[e]=r(e))}function o(e,t,n){t=a(t),e.style[t]=n}return function(e,t){var n,r,a=arguments;if(2==a.length)for(n in t)void 0!==(r=t[n])&&t.hasOwnProperty(n)&&o(e,n,r);else o(e,a[1],a[2])}}();function c(e,t){return("string"==typeof e?e:p(e)).indexOf(" "+t+" ")>=0}function u(e,t){var n=p(e),r=n+t;c(n,t)||(e.className=r.substring(1))}function d(e,t){var n,r=p(e);c(e,t)&&(n=r.replace(" "+t+" "," "),e.className=n.substring(1,n.length-1))}function p(e){return(" "+(e.className||"")+" ").replace(/\s+/gi," ")}function f(e){e&&e.parentNode&&e.parentNode.removeChild(e)}return n},void 0===(a="function"==typeof r?r.call(t,n,t,e):r)||(e.exports=a)},57022:()=>{!function(e){var t="\\b(?:BASH|BASHOPTS|BASH_ALIASES|BASH_ARGC|BASH_ARGV|BASH_CMDS|BASH_COMPLETION_COMPAT_DIR|BASH_LINENO|BASH_REMATCH|BASH_SOURCE|BASH_VERSINFO|BASH_VERSION|COLORTERM|COLUMNS|COMP_WORDBREAKS|DBUS_SESSION_BUS_ADDRESS|DEFAULTS_PATH|DESKTOP_SESSION|DIRSTACK|DISPLAY|EUID|GDMSESSION|GDM_LANG|GNOME_KEYRING_CONTROL|GNOME_KEYRING_PID|GPG_AGENT_INFO|GROUPS|HISTCONTROL|HISTFILE|HISTFILESIZE|HISTSIZE|HOME|HOSTNAME|HOSTTYPE|IFS|INSTANCE|JOB|LANG|LANGUAGE|LC_ADDRESS|LC_ALL|LC_IDENTIFICATION|LC_MEASUREMENT|LC_MONETARY|LC_NAME|LC_NUMERIC|LC_PAPER|LC_TELEPHONE|LC_TIME|LESSCLOSE|LESSOPEN|LINES|LOGNAME|LS_COLORS|MACHTYPE|MAILCHECK|MANDATORY_PATH|NO_AT_BRIDGE|OLDPWD|OPTERR|OPTIND|ORBIT_SOCKETDIR|OSTYPE|PAPERSIZE|PATH|PIPESTATUS|PPID|PS1|PS2|PS3|PS4|PWD|RANDOM|REPLY|SECONDS|SELINUX_INIT|SESSION|SESSIONTYPE|SESSION_MANAGER|SHELL|SHELLOPTS|SHLVL|SSH_AUTH_SOCK|TERM|UID|UPSTART_EVENTS|UPSTART_INSTANCE|UPSTART_JOB|UPSTART_SESSION|USER|WINDOWID|XAUTHORITY|XDG_CONFIG_DIRS|XDG_CURRENT_DESKTOP|XDG_DATA_DIRS|XDG_GREETER_DATA_DIR|XDG_MENU_PREFIX|XDG_RUNTIME_DIR|XDG_SEAT|XDG_SEAT_PATH|XDG_SESSION_DESKTOP|XDG_SESSION_ID|XDG_SESSION_PATH|XDG_SESSION_TYPE|XDG_VTNR|XMODIFIERS)\\b",n={pattern:/(^(["']?)\w+\2)[ \t]+\S.*/,lookbehind:!0,alias:"punctuation",inside:null},r={bash:n,environment:{pattern:RegExp("\\$"+t),alias:"constant"},variable:[{pattern:/\$?\(\([\s\S]+?\)\)/,greedy:!0,inside:{variable:[{pattern:/(^\$\(\([\s\S]+)\)\)/,lookbehind:!0},/^\$\(\(/],number:/\b0x[\dA-Fa-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:[Ee]-?\d+)?/,operator:/--|\+\+|\*\*=?|<<=?|>>=?|&&|\|\||[=!+\-*/%<>^&|]=?|[?~:]/,punctuation:/\(\(?|\)\)?|,|;/}},{pattern:/\$\((?:\([^)]+\)|[^()])+\)|`[^`]+`/,greedy:!0,inside:{variable:/^\$\(|^`|\)$|`$/}},{pattern:/\$\{[^}]+\}/,greedy:!0,inside:{operator:/:[-=?+]?|[!\/]|##?|%%?|\^\^?|,,?/,punctuation:/[\[\]]/,environment:{pattern:RegExp("(\\{)"+t),lookbehind:!0,alias:"constant"}}},/\$(?:\w+|[#?*!@$])/],entity:/\\(?:[abceEfnrtv\\"]|O?[0-7]{1,3}|U[0-9a-fA-F]{8}|u[0-9a-fA-F]{4}|x[0-9a-fA-F]{1,2})/};e.languages.bash={shebang:{pattern:/^#!\s*\/.*/,alias:"important"},comment:{pattern:/(^|[^"{\\$])#.*/,lookbehind:!0},"function-name":[{pattern:/(\bfunction\s+)[\w-]+(?=(?:\s*\(?:\s*\))?\s*\{)/,lookbehind:!0,alias:"function"},{pattern:/\b[\w-]+(?=\s*\(\s*\)\s*\{)/,alias:"function"}],"for-or-select":{pattern:/(\b(?:for|select)\s+)\w+(?=\s+in\s)/,alias:"variable",lookbehind:!0},"assign-left":{pattern:/(^|[\s;|&]|[<>]\()\w+(?:\.\w+)*(?=\+?=)/,inside:{environment:{pattern:RegExp("(^|[\\s;|&]|[<>]\\()"+t),lookbehind:!0,alias:"constant"}},alias:"variable",lookbehind:!0},parameter:{pattern:/(^|\s)-{1,2}(?:\w+:[+-]?)?\w+(?:\.\w+)*(?=[=\s]|$)/,alias:"variable",lookbehind:!0},string:[{pattern:/((?:^|[^<])<<-?\s*)(\w+)\s[\s\S]*?(?:\r?\n|\r)\2/,lookbehind:!0,greedy:!0,inside:r},{pattern:/((?:^|[^<])<<-?\s*)(["'])(\w+)\2\s[\s\S]*?(?:\r?\n|\r)\3/,lookbehind:!0,greedy:!0,inside:{bash:n}},{pattern:/(^|[^\\](?:\\\\)*)"(?:\\[\s\S]|\$\([^)]+\)|\$(?!\()|`[^`]+`|[^"\\`$])*"/,lookbehind:!0,greedy:!0,inside:r},{pattern:/(^|[^$\\])'[^']*'/,lookbehind:!0,greedy:!0},{pattern:/\$'(?:[^'\\]|\\[\s\S])*'/,greedy:!0,inside:{entity:r.entity}}],environment:{pattern:RegExp("\\$?"+t),alias:"constant"},variable:r.variable,function:{pattern:/(^|[\s;|&]|[<>]\()(?:add|apropos|apt|apt-cache|apt-get|aptitude|aspell|automysqlbackup|awk|basename|bash|bc|bconsole|bg|bzip2|cal|cargo|cat|cfdisk|chgrp|chkconfig|chmod|chown|chroot|cksum|clear|cmp|column|comm|composer|cp|cron|crontab|csplit|curl|cut|date|dc|dd|ddrescue|debootstrap|df|diff|diff3|dig|dir|dircolors|dirname|dirs|dmesg|docker|docker-compose|du|egrep|eject|env|ethtool|expand|expect|expr|fdformat|fdisk|fg|fgrep|file|find|fmt|fold|format|free|fsck|ftp|fuser|gawk|git|gparted|grep|groupadd|groupdel|groupmod|groups|grub-mkconfig|gzip|halt|head|hg|history|host|hostname|htop|iconv|id|ifconfig|ifdown|ifup|import|install|ip|java|jobs|join|kill|killall|less|link|ln|locate|logname|logrotate|look|lpc|lpr|lprint|lprintd|lprintq|lprm|ls|lsof|lynx|make|man|mc|mdadm|mkconfig|mkdir|mke2fs|mkfifo|mkfs|mkisofs|mknod|mkswap|mmv|more|most|mount|mtools|mtr|mutt|mv|nano|nc|netstat|nice|nl|node|nohup|notify-send|npm|nslookup|op|open|parted|passwd|paste|pathchk|ping|pkill|pnpm|podman|podman-compose|popd|pr|printcap|printenv|ps|pushd|pv|quota|quotacheck|quotactl|ram|rar|rcp|reboot|remsync|rename|renice|rev|rm|rmdir|rpm|rsync|scp|screen|sdiff|sed|sendmail|seq|service|sftp|sh|shellcheck|shuf|shutdown|sleep|slocate|sort|split|ssh|stat|strace|su|sudo|sum|suspend|swapon|sync|sysctl|tac|tail|tar|tee|time|timeout|top|touch|tr|traceroute|tsort|tty|umount|uname|unexpand|uniq|units|unrar|unshar|unzip|update-grub|uptime|useradd|userdel|usermod|users|uudecode|uuencode|v|vcpkg|vdir|vi|vim|virsh|vmstat|wait|watch|wc|wget|whereis|which|who|whoami|write|xargs|xdg-open|yarn|yes|zenity|zip|zsh|zypper)(?=$|[)\s;|&])/,lookbehind:!0},keyword:{pattern:/(^|[\s;|&]|[<>]\()(?:case|do|done|elif|else|esac|fi|for|function|if|in|select|then|until|while)(?=$|[)\s;|&])/,lookbehind:!0},builtin:{pattern:/(^|[\s;|&]|[<>]\()(?:\.|:|alias|bind|break|builtin|caller|cd|command|continue|declare|echo|enable|eval|exec|exit|export|getopts|hash|help|let|local|logout|mapfile|printf|pwd|read|readarray|readonly|return|set|shift|shopt|source|test|times|trap|type|typeset|ulimit|umask|unalias|unset)(?=$|[)\s;|&])/,lookbehind:!0,alias:"class-name"},boolean:{pattern:/(^|[\s;|&]|[<>]\()(?:false|true)(?=$|[)\s;|&])/,lookbehind:!0},"file-descriptor":{pattern:/\B&\d\b/,alias:"important"},operator:{pattern:/\d?<>|>\||\+=|=[=~]?|!=?|<<[<-]?|[&\d]?>>|\d[<>]&?|[<>][&=]?|&[>&]?|\|[&|]?/,inside:{"file-descriptor":{pattern:/^\d/,alias:"important"}}},punctuation:/\$?\(\(?|\)\)?|\.\.|[{}[\];\\]/,number:{pattern:/(^|\s)(?:[1-9]\d*|0)(?:[.,]\d+)?\b/,lookbehind:!0}},n.inside=e.languages.bash;for(var a=["comment","function-name","for-or-select","assign-left","parameter","string","environment","function","keyword","builtin","boolean","file-descriptor","operator","punctuation","number"],o=r.variable[1].inside,s=0;s{Prism.languages.javascript=Prism.languages.extend("clike",{"class-name":[Prism.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp(/(^|[^\w$])/.source+"(?:"+/NaN|Infinity/.source+"|"+/0[bB][01]+(?:_[01]+)*n?/.source+"|"+/0[oO][0-7]+(?:_[0-7]+)*n?/.source+"|"+/0[xX][\dA-Fa-f]+(?:_[\dA-Fa-f]+)*n?/.source+"|"+/\d+(?:_\d+)*n/.source+"|"+/(?:\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\.\d+(?:_\d+)*)(?:[Ee][+-]?\d+(?:_\d+)*)?/.source+")"+/(?![\w$])/.source),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),Prism.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:RegExp(/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)/.source+/\//.source+"(?:"+/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}/.source+"|"+/(?:\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.)*\])*\])*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source+")"+/(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/.source),lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:Prism.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:Prism.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),Prism.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[ \t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),Prism.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[ \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,lookbehind:!0,alias:"property"}}),Prism.languages.markup&&(Prism.languages.markup.tag.addInlined("script","javascript"),Prism.languages.markup.tag.addAttribute(/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,"javascript")),Prism.languages.js=Prism.languages.javascript},72514:()=>{Prism.languages.json={property:{pattern:/(^|[^\\])"(?:\\.|[^\\"\r\n])*"(?=\s*:)/,lookbehind:!0,greedy:!0},string:{pattern:/(^|[^\\])"(?:\\.|[^\\"\r\n])*"(?!\s*:)/,lookbehind:!0,greedy:!0},comment:{pattern:/\/\/.*|\/\*[\s\S]*?(?:\*\/|$)/,greedy:!0},number:/-?\b\d+(?:\.\d+)?(?:e[+-]?\d+)?\b/i,punctuation:/[{}[\],]/,operator:/:/,boolean:/\b(?:false|true)\b/,null:{pattern:/\bnull\b/,alias:"keyword"}},Prism.languages.webmanifest=Prism.languages.json},65903:()=>{!function(e){var t=e.util.clone(e.languages.javascript),n=/(?:\s|\/\/.*(?!.)|\/\*(?:[^*]|\*(?!\/))\*\/)/.source,r=/(?:\{(?:\{(?:\{[^{}]*\}|[^{}])*\}|[^{}])*\})/.source,a=/(?:\{*\.{3}(?:[^{}]|)*\})/.source;function o(e,t){return e=e.replace(//g,(function(){return n})).replace(//g,(function(){return r})).replace(//g,(function(){return a})),RegExp(e,t)}a=o(a).source,e.languages.jsx=e.languages.extend("markup",t),e.languages.jsx.tag.pattern=o(/<\/?(?:[\w.:-]+(?:+(?:[\w.:$-]+(?:=(?:"(?:\\[\s\S]|[^\\"])*"|'(?:\\[\s\S]|[^\\'])*'|[^\s{'"/>=]+|))?|))**\/?)?>/.source),e.languages.jsx.tag.inside.tag.pattern=/^<\/?[^\s>\/]*/,e.languages.jsx.tag.inside["attr-value"].pattern=/=(?!\{)(?:"(?:\\[\s\S]|[^\\"])*"|'(?:\\[\s\S]|[^\\'])*'|[^\s'">]+)/,e.languages.jsx.tag.inside.tag.inside["class-name"]=/^[A-Z]\w*(?:\.[A-Z]\w*)*$/,e.languages.jsx.tag.inside.comment=t.comment,e.languages.insertBefore("inside","attr-name",{spread:{pattern:o(//.source),inside:e.languages.jsx}},e.languages.jsx.tag),e.languages.insertBefore("inside","special-attr",{script:{pattern:o(/=/.source),alias:"language-javascript",inside:{"script-punctuation":{pattern:/^=(?=\{)/,alias:"punctuation"},rest:e.languages.jsx}}},e.languages.jsx.tag);var s=function(e){return e?"string"==typeof e?e:"string"==typeof e.content?e.content:e.content.map(s).join(""):""},i=function(t){for(var n=[],r=0;r0&&n[n.length-1].tagName===s(a.content[0].content[1])&&n.pop():"/>"===a.content[a.content.length-1].content||n.push({tagName:s(a.content[0].content[1]),openedBraces:0}):n.length>0&&"punctuation"===a.type&&"{"===a.content?n[n.length-1].openedBraces++:n.length>0&&n[n.length-1].openedBraces>0&&"punctuation"===a.type&&"}"===a.content?n[n.length-1].openedBraces--:o=!0),(o||"string"==typeof a)&&n.length>0&&0===n[n.length-1].openedBraces){var l=s(a);r0&&("string"==typeof t[r-1]||"plain-text"===t[r-1].type)&&(l=s(t[r-1])+l,t.splice(r-1,1),r--),t[r]=new e.Token("plain-text",l,null,l)}a.content&&"string"!=typeof a.content&&i(a.content)}};e.hooks.add("after-tokenize",(function(e){"jsx"!==e.language&&"tsx"!==e.language||i(e.tokens)}))}(Prism)},19700:()=>{!function(e){function t(e,t){return"___"+e.toUpperCase()+t+"___"}Object.defineProperties(e.languages["markup-templating"]={},{buildPlaceholders:{value:function(n,r,a,o){if(n.language===r){var s=n.tokenStack=[];n.code=n.code.replace(a,(function(e){if("function"==typeof o&&!o(e))return e;for(var a,i=s.length;-1!==n.code.indexOf(a=t(r,i));)++i;return s[i]=e,a})),n.grammar=e.languages.markup}}},tokenizePlaceholders:{value:function(n,r){if(n.language===r&&n.tokenStack){n.grammar=e.languages[r];var a=0,o=Object.keys(n.tokenStack);!function s(i){for(var l=0;l=o.length);l++){var c=i[l];if("string"==typeof c||c.content&&"string"==typeof c.content){var u=o[a],d=n.tokenStack[u],p="string"==typeof c?c:c.content,f=t(r,u),m=p.indexOf(f);if(m>-1){++a;var h=p.substring(0,m),g=new e.Token(r,e.tokenize(d,n.grammar),"language-"+r,d),b=p.substring(m+f.length),y=[];h&&y.push.apply(y,s([h])),y.push(g),b&&y.push.apply(y,s([b])),"string"==typeof c?i.splice.apply(i,[l,1].concat(y)):c.content=y}}else c.content&&s(c.content)}return i}(n.tokens)}}}})}(Prism)},30905:()=>{!function(e){var t=e.languages.powershell={comment:[{pattern:/(^|[^`])<#[\s\S]*?#>/,lookbehind:!0},{pattern:/(^|[^`])#.*/,lookbehind:!0}],string:[{pattern:/"(?:`[\s\S]|[^`"])*"/,greedy:!0,inside:null},{pattern:/'(?:[^']|'')*'/,greedy:!0}],namespace:/\[[a-z](?:\[(?:\[[^\]]*\]|[^\[\]])*\]|[^\[\]])*\]/i,boolean:/\$(?:false|true)\b/i,variable:/\$\w+\b/,function:[/\b(?:Add|Approve|Assert|Backup|Block|Checkpoint|Clear|Close|Compare|Complete|Compress|Confirm|Connect|Convert|ConvertFrom|ConvertTo|Copy|Debug|Deny|Disable|Disconnect|Dismount|Edit|Enable|Enter|Exit|Expand|Export|Find|ForEach|Format|Get|Grant|Group|Hide|Import|Initialize|Install|Invoke|Join|Limit|Lock|Measure|Merge|Move|New|Open|Optimize|Out|Ping|Pop|Protect|Publish|Push|Read|Receive|Redo|Register|Remove|Rename|Repair|Request|Reset|Resize|Resolve|Restart|Restore|Resume|Revoke|Save|Search|Select|Send|Set|Show|Skip|Sort|Split|Start|Step|Stop|Submit|Suspend|Switch|Sync|Tee|Test|Trace|Unblock|Undo|Uninstall|Unlock|Unprotect|Unpublish|Unregister|Update|Use|Wait|Watch|Where|Write)-[a-z]+\b/i,/\b(?:ac|cat|chdir|clc|cli|clp|clv|compare|copy|cp|cpi|cpp|cvpa|dbp|del|diff|dir|ebp|echo|epal|epcsv|epsn|erase|fc|fl|ft|fw|gal|gbp|gc|gci|gcs|gdr|gi|gl|gm|gp|gps|group|gsv|gu|gv|gwmi|iex|ii|ipal|ipcsv|ipsn|irm|iwmi|iwr|kill|lp|ls|measure|mi|mount|move|mp|mv|nal|ndr|ni|nv|ogv|popd|ps|pushd|pwd|rbp|rd|rdr|ren|ri|rm|rmdir|rni|rnp|rp|rv|rvpa|rwmi|sal|saps|sasv|sbp|sc|select|set|shcm|si|sl|sleep|sls|sort|sp|spps|spsv|start|sv|swmi|tee|trcm|type|write)\b/i],keyword:/\b(?:Begin|Break|Catch|Class|Continue|Data|Define|Do|DynamicParam|Else|ElseIf|End|Exit|Filter|Finally|For|ForEach|From|Function|If|InlineScript|Parallel|Param|Process|Return|Sequence|Switch|Throw|Trap|Try|Until|Using|Var|While|Workflow)\b/i,operator:{pattern:/(^|\W)(?:!|-(?:b?(?:and|x?or)|as|(?:Not)?(?:Contains|In|Like|Match)|eq|ge|gt|is(?:Not)?|Join|le|lt|ne|not|Replace|sh[lr])\b|-[-=]?|\+[+=]?|[*\/%]=?)/i,lookbehind:!0},punctuation:/[|{}[\];(),.]/};t.string[0].inside={function:{pattern:/(^|[^`])\$\((?:\$\([^\r\n()]*\)|(?!\$\()[^\r\n)])*\)/,lookbehind:!0,inside:t},boolean:t.boolean,variable:t.variable}}(Prism)},52342:()=>{Prism.languages.python={comment:{pattern:/(^|[^\\])#.*/,lookbehind:!0,greedy:!0},"string-interpolation":{pattern:/(?:f|fr|rf)(?:("""|''')[\s\S]*?\1|("|')(?:\\.|(?!\2)[^\\\r\n])*\2)/i,greedy:!0,inside:{interpolation:{pattern:/((?:^|[^{])(?:\{\{)*)\{(?!\{)(?:[^{}]|\{(?!\{)(?:[^{}]|\{(?!\{)(?:[^{}])+\})+\})+\}/,lookbehind:!0,inside:{"format-spec":{pattern:/(:)[^:(){}]+(?=\}$)/,lookbehind:!0},"conversion-option":{pattern:/![sra](?=[:}]$)/,alias:"punctuation"},rest:null}},string:/[\s\S]+/}},"triple-quoted-string":{pattern:/(?:[rub]|br|rb)?("""|''')[\s\S]*?\1/i,greedy:!0,alias:"string"},string:{pattern:/(?:[rub]|br|rb)?("|')(?:\\.|(?!\1)[^\\\r\n])*\1/i,greedy:!0},function:{pattern:/((?:^|\s)def[ \t]+)[a-zA-Z_]\w*(?=\s*\()/g,lookbehind:!0},"class-name":{pattern:/(\bclass\s+)\w+/i,lookbehind:!0},decorator:{pattern:/(^[\t ]*)@\w+(?:\.\w+)*/m,lookbehind:!0,alias:["annotation","punctuation"],inside:{punctuation:/\./}},keyword:/\b(?:_(?=\s*:)|and|as|assert|async|await|break|case|class|continue|def|del|elif|else|except|exec|finally|for|from|global|if|import|in|is|lambda|match|nonlocal|not|or|pass|print|raise|return|try|while|with|yield)\b/,builtin:/\b(?:__import__|abs|all|any|apply|ascii|basestring|bin|bool|buffer|bytearray|bytes|callable|chr|classmethod|cmp|coerce|compile|complex|delattr|dict|dir|divmod|enumerate|eval|execfile|file|filter|float|format|frozenset|getattr|globals|hasattr|hash|help|hex|id|input|int|intern|isinstance|issubclass|iter|len|list|locals|long|map|max|memoryview|min|next|object|oct|open|ord|pow|property|range|raw_input|reduce|reload|repr|reversed|round|set|setattr|slice|sorted|staticmethod|str|sum|super|tuple|type|unichr|unicode|vars|xrange|zip)\b/,boolean:/\b(?:False|None|True)\b/,number:/\b0(?:b(?:_?[01])+|o(?:_?[0-7])+|x(?:_?[a-f0-9])+)\b|(?:\b\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\B\.\d+(?:_\d+)*)(?:e[+-]?\d+(?:_\d+)*)?j?(?!\w)/i,operator:/[-+%=]=?|!=|:=|\*\*?=?|\/\/?=?|<[<=>]?|>[=>]?|[&|^~]/,punctuation:/[{}[\];(),.:]/},Prism.languages.python["string-interpolation"].inside.interpolation.inside.rest=Prism.languages.python,Prism.languages.py=Prism.languages.python},64424:(e,t,n)=>{var r={"./prism-bash":57022,"./prism-javascript":25723,"./prism-json":72514,"./prism-jsx":65903,"./prism-powershell":30905,"./prism-python":52342};function a(e){var t=o(e);return n(t)}function o(e){if(!n.o(r,e)){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}return r[e]}a.keys=function(){return Object.keys(r)},a.resolve=o,e.exports=a,a.id=64424},2694:(e,t,n)=>{"use strict";var r=n(6925);function a(){}function o(){}o.resetWarningCache=a,e.exports=function(){function e(e,t,n,a,o,s){if(s!==r){var i=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw i.name="Invariant Violation",i}}function t(){return e}e.isRequired=e;var n={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:o,resetWarningCache:a};return n.PropTypes=n,n}},5556:(e,t,n)=>{e.exports=n(2694)()},6925:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},22551:(e,t,n)=>{"use strict";var r=n(96540),a=n(69982);function o(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n