使用AnythingLLM配置向量数据库

使用AnythingLLM配置向量数据库

AnythingLLM简介

AnythingLLM将文本文件矢量化,存入矢量数据库中,在后续进行提问时,将问题也转换为矢量数据前往矢量数据库中寻找,达到Anything都转化为LLM的效果。

AnythingLLM | The ultimate AI business intelligence tool

联合Ollama配置

在之前已经配置好了Ollama,选择qwen2模型,配置最多的Token为8192

配置文件

新增一个工作空间

上传相关文档

找到菜鸟教程、官方API配置文档、英语下的echarts教程文章,以及之前使用过的JSON数据库。

处理结束后,将大模型从Chat改成Query

测试

基本结果还是成功了,格式还是存在一些“不够聪明的问题”。

好的,根据您的需求,我为您提供以下设计思路和代码实现: 1. 设计思路 智能小车需要借助蓝牙遥控模块进行控制,同时也需要进行避障功能的设计。因此,我们可以选择一个带有蓝牙功能的控制板来实现这一功能。目前市场上比较常用的控制板有 STM32F103C8T6、Arduino UNO 等。 在硬件电路方面,我们可以将一组超声波传感器接入控制板,用于检测前方障碍物的距离,并控制小车的行驶方向。同时,通过蓝牙模块与手机 APP 进行通信,实现小车的遥控和避障功能。 在软件方面,我们可以使用 Keil 或者其他嵌入式开发工具编写 C 语言程序,实现以下功能: - 通过超声波传感器检测前方障碍物的距离,并根据距离控制小车的行驶方向; - 通过蓝牙模块与手机 APP 进行通信,实现小车的遥控和避障功能。 2. 代码实现 下面是一份基于 STM32F103C8T6 控制板的蓝牙避障小车代码示例: ``` #include "stm32f10x.h" #include "delay.h" #include "usart.h" #include "ultrasonic.h" int main(void) { uint16_t distance = 0; char buffer[20]; USART1_Config(); Ultrasonic_Config(); while (1) { distance = Ultrasonic_GetDistance(); sprintf(buffer, "Distance: %d cm.\r\n", distance); USART1_SendString(buffer); if (distance < 20) { // 前方有障碍物,向左转 GPIO_ResetBits(GPIOB, GPIO_Pin_0); GPIO_SetBits(GPIOB, GPIO_Pin_1); GPIO_SetBits(GPIOB, GPIO_Pin_2); GPIO_ResetBits(GPIOB, GPIO_Pin_3); } else { // 前方无障碍物,直行 GPIO_SetBits(GPIOB, GPIO_Pin_0); GPIO_ResetBits(GPIOB, GPIO_Pin_1); GPIO_SetBits(GPIOB, GPIO_Pin_2); GPIO_ResetBits(GPIOB, GPIO_Pin_3); } delay_ms(100); } } ``` 在这段代码中,我们通过超声波传感器检测前方障碍物的距离,并根据距离控制小车的行驶方向。当检测到前方障碍物距离小于 20cm 时,小车会向左转;否则,小车会直行。 同时,我们还需要实现与手机 APP 的通信功能,以便对小车进行遥控和避障操作。这部分代码可以借助蓝牙模块的 AT 指令集来实现,具体实现方式可以参考以下代码示例: ``` #include "stm32f10x.h" #include "usart.h" void USART2_IRQHandler(void) { if (USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) { uint8_t data = USART_ReceiveData(USART2); USART_SendData(USART1, data); } } void Bluetooth_Config(void) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; // 配置蓝牙模块引脚 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, &GPIO_InitStructure); // 配置蓝牙模块串口 RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); USART_InitStructure.USART_BaudRate = 9600; USART_InitStructure.USART_WordLength = USART_WordLength_8b; USART_InitStructure.USART_StopBits = USART_StopBits_1; USART_InitStructure.USART_Parity = USART_Parity_No; USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART2, &USART_InitStructure); USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); USART_Cmd(USART2, ENABLE); // 配置中断 NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); } void Bluetooth_SendString(char* str) { while (*str) { USART_SendData(USART2, *str++); while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET); } } int main(void) { USART1_Config(); Bluetooth_Config(); while (1) { // 接收蓝牙模块发送的数据,并将数据发送到 USART1 串口 delay_ms(100); } } ``` 在这段代码中,我们通过 USART2 串口与蓝牙模块进行通信,并将蓝牙模块发送的数据转发到 USART1 串口,以便进行调试和测试。同时,我们还可以通过 `Bluetooth_SendString()` 函数向蓝牙模块发送数据,实现遥控小车的功能。 以上代码示例仅供参考,具体实现方式还需要根据您的具体需求进行调整和修改。同时,还需要注意硬件电路的连接和配置,以确保程序能够正常工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值