首页 > 其他分享 >基于GPT4的AI镜子

基于GPT4的AI镜子

时间:2023-08-26 21:48:31浏览次数:569  
标签:__ GPT4 镜子 AI text self cv2 -- url

基于GPT4的AI镜子

一、树莓派系统搭建

1. 搭建系统

两种方法,一种是直接使用Raspberry Pi Imager安装,这种相关于是自动安装系统,好处是比较方便,但是问题是比较慢;另一种是自行下载镜像,然后再把镜像安装到内存卡中,这种步骤相对来说稍繁琐,但是因为已经提前下载好了镜像,安装相对比较快。

第一种方法:

  • 从官网下载自动安装软件,Raspberry Pi OS – Raspberry Pi
  • 然后双击软件,选择合适的系统,然后选择内存卡,然后等待系统安装完成
  • 系统做好之后将内存卡拔出,放入树莓派中即可启动系统

第二种方法:

2. 设置VNC远程访问

树莓派操作:

  • 依次选择首选项——Raspberry Pi Configuration——interfaces
  • 然后将VNC选项打开
  • 重启树莓派

windows操作:

二、miniconda环境搭建

注:树莓派上面的miniconda和pyqt有冲突,pyqt无法用minianaconda搭建

  • 首先下载合适的软件包,Index of /anaconda/miniconda/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror
  • 笔者项目中使用的是树莓派4 8G版本的,前后尝试了多个版本,最后能够正常安装使用的版本是:Miniconda3-py39_4.9.2-Linux-aarch64.sh
  • 下载完成之后进入下载的目录进行安装sudo sh Miniconda3-py39_4.9.2-Linux-aarch64.sh
  • 安装期间会提示安装的路径,笔者安装的路径为:/opt/miniconda3
  • 设置为打开终端默认进入(base)环境,需要deactivate退出。若改为false,打开终端需要activate环境。我设置为false。conda config --set auto_activate_base false
  • 安装完成之后,这个minicondaanaconda是一样使用的,这边不在赘述。

三、VPN配置

VPN的配置和在linux下配置是一样,用的也是clash,然后选择代理,最后购买节点完成kx上网。

四、语音识别

语音识别部分主要使用的是speechrecognition
安装库:pip install speechrecognition
这边插一条,使用pip下载嫌慢可以使用国内镜像下载,如:pip3 install speechrecognition -i https://pypi.tuna.tsinghua.edu.cn/simple

一个测试例程:

import speech_recognition as sr

def real_time_speech_to_text():
    # 创建一个Recognizer对象
    recognizer = sr.Recognizer()

    # 使用麦克风实时监听语音并转换为文本
    with sr.Microphone() as source:
        recognizer.adjust_for_ambient_noise(source)  # 将该行代码放在with语句块内
        print("请开始说话...")
        try:
          while True:
              audio = recognizer.listen(source, timeout=5)  # 设置超时时间为5秒
              if not audio:
                  print("没有检测到声音,程序结束。")
                  break
              text = recognizer.recognize_google(audio, language='zh-CN')
              print("识别结果:", text)
              if "退出" in text:
                  print("检测到退出指令,程序结束。")
                  break
        except KeyboardInterrupt:
            print("监听结束")
        except sr.UnknownValueError:
            print("无法识别语音")
        except sr.RequestError as e:
            print("无法连接到Google Speech Recognition服务;{0}".format(e))

if __name__ == "__main__":
    real_time_speech_to_text()

五、语音合成

这边有两个选择:
一:使用'pyttsx3',简单方便,但是声音可选择空间小,声音比较僵硬,特别是linux环境下
二:使用第三方的API,声音可选择空间大,但是使用需要充钱。

1. pyttsx3

文字转语音(Text-to-Speech,TTS)可以使用Python的pyttsx3库来实现。pyttsx3是一个简单易用的文字转语音库,它可以将文字转换为语音,并通过系统的声音输出设备进行播放。

以下是一个使用pyttsx3库实现文字转语音的例程:

import pyttsx3

def text_to_speech(text):
    # 初始化语音引擎
    engine = pyttsx3.init()

    # 设置要转换的文本
    engine.say(text)

    # 播放语音
    engine.runAndWait()

if __name__ == "__main__":
    text_to_speech("你好,这是一个文字转语音的例程。")

在上述例程中,我们首先通过pyttsx3.init()来初始化语音引擎。然后使用engine.say(text)将要转换的文本传递给引擎。最后通过engine.runAndWait()方法来播放语音。

运行该例程后,你应该能听到计算机通过声音输出设备播放出文字转换为语音的结果。

pyttsx3库支持多种声音引擎,可以根据你的系统配置和需求来选择合适的声音引擎。默认情况下,pyttsx3使用的是SAPI5引擎,但你可以设置其他支持的引擎,例如nsss(MacOS)espeak(Linux)。可以通过pyttsx3.init(driverName)来设置使用的引擎。

2. 使用阿里云API

这边给出相关例程:

ALiYunConfig.py

# -*- coding: UTF-8 -*-
# Python 2.x引入httplib模块。
# import httplib
# Python 3.x引入http.client模块。
import http.client
import io
import pydub
from pydub.playback import play
# Python 2.x引入urllib模块。
# import urllib
# Python 3.x引入urllib.parse模块。
import urllib.parse
import json

import pygame
# 初始化pygame
pygame.init()


class ttsConfig():

    def __init__(self):
        self.appKey = 'appKey'         # 从阿里云复制appkey
        self.token = 'token'           # 从阿里云复制token
        self.audioSaveFile = 'syAudio0.wav'
        self.format = 'wav'
        self.sampleRate = 16000

        pygame.mixer.init()

    # def processGETRequest(self, appKey, token, text, audioSaveFile, format, sampleRate) :  # 原
    def processGETRequest(self, text) :   # 只剩一个text参数
        appKey = self.appKey
        token = self.token
        audioSaveFile = self.audioSaveFile
        format = self.format
        sampleRate = self.sampleRate

        host = 'nls-gateway-cn-shanghai.aliyuncs.com'
        url = 'https://' + host + '/stream/v1/tts'
        # 设置URL请求参数
        url = url + '?appkey=' + appKey
        url = url + '&token=' + token
        url = url + '&text=' + text
        url = url + '&format=' + format
        url = url + '&sample_rate=' + str(sampleRate)
        # voice 发音人,可选,默认是xiaoyun。
        # url = url + '&voice=' + 'xiaoyun'
        # volume 音量,范围是0~100,可选,默认50。
        url = url + '&volume=' + str(100)
        # speech_rate 语速,范围是-500~500,可选,默认是0。
        # url = url + '&speech_rate=' + str(300)
        # pitch_rate 语调,范围是-500~500,可选,默认是0。
        # url = url + '&pitch_rate=' + str(0)
        # print(url)
        # Python 2.x请使用httplib。
        # conn = httplib.HTTPSConnection(host)
        # Python 3.x请使用http.client。
        conn = http.client.HTTPSConnection(host)
        conn.request(method='GET', url=url)
        # 处理服务端返回的响应。
        response = conn.getresponse()
        # print('Response status and response reason:')
        # print(response.status ,response.reason)
        contentType = response.getheader('Content-Type')
        # print(contentType)
        body = response.read()
        if 'audio/mpeg' == contentType :
            with open(audioSaveFile, mode='wb') as f:
                f.write(body)

            print('The GET request succeed!')
        else :
            print('The GET request failed: ' + str(body))
        conn.close()
    
    def processPOSTRequest(self, appKey, token, text, audioSaveFile, format, sampleRate) :
        host = 'nls-gateway-cn-shanghai.aliyuncs.com'
        url = 'https://' + host + '/stream/v1/tts'
        # 设置HTTPS Headers。
        httpHeaders = {
            'Content-Type': 'application/json'
            }
        # 设置HTTPS Body。
        body = {'appkey': appKey, 'token': token, 'text': text, 'format': format, 'sample_rate': sampleRate}
        body = json.dumps(body)
        # print('The POST request body content: ' + body)
        # Python 2.x请使用httplib。
        # conn = httplib.HTTPSConnection(host)
        # Python 3.x请使用http.client。
        conn = http.client.HTTPSConnection(host)
        conn.request(method='POST', url=url, body=body, headers=httpHeaders)
        # 处理服务端返回的响应。
        response = conn.getresponse()
        print('Response status and response reason:')
        print(response.status ,response.reason)
        contentType = response.getheader('Content-Type')
        print("contentType: \n", contentType)

        # stream = io.BytesIO(contentType)  
        # # 将字节流转换为音频片段对象
        # audio_segment = pydub.AudioSegment.from_wav(stream)
        # play(audio_segment)
        # body = response.read()

        if 'audio/mpeg' == contentType :
            with open(audioSaveFile, mode='wb') as f:
                f.write(body)
            print('The POST request succeed!')
        else :
            print('The POST request failed: ' + str(body))
        conn.close()


ALiYun_module.py

from ALiYunConfig import *


def say(config, text):
    # 采用RFC 3986规范进行urlencode编码。
    textUrlencode = text

    textUrlencode = urllib.parse.quote_plus(textUrlencode)
    textUrlencode = textUrlencode.replace("+", "%20")
    textUrlencode = textUrlencode.replace("*", "%2A")
    textUrlencode = textUrlencode.replace("%7E", "~")

    # GET请求方式
    config.processGETRequest(textUrlencode)

    # 设置音频参数
    # pygame.mixer.init()
    pygame.mixer.music.load(config.audioSaveFile)

    # 播放音频
    pygame.mixer.music.play()
    # 等待音频播放完毕
    while pygame.mixer.music.get_busy():
        continue
    # 关闭pygame
    # pygame.quit()

# test
if __name__ == '__main__':
    myTTS = ttsConfig()
    say(myTTS, 'config.processGETRequest(设置音频参数)')

六、GPT API使用

首先安装相关库:pip install openai

例程(这个例程是不能记忆上下文的)

import os
import openai

# Load your API key from an environment variable or secret management service
# openai.api_key = "you_api_key" # 填入你的API key

while True:
  content = input()
  # content= "hellow!"
  response = chat_completion = openai.ChatCompletion.create(model="gpt-3.5-turbo", max_tokens=100, temperature=0.6  messages=[{"role": "user", "content": content}])
  # response = chat_completion = openai.ChatCompletion.create(model="gpt-4", messages=[{"role": "user", "content": content}])
  print(response.choices[0].message.content)

然后这个仓库给出的相关程序是可以进行上下文记忆的:https://github.com/ChristopheZhao/ChaGPT-API-Call

七、yolov5算法部署

1. 部署使用

yolo使用onnx进行部署的方法可以参考这个仓库:GitHub - hpc203/yolov5-v6.1-opencv-onnxrun: 分别使用OpenCV、ONNXRuntime部署yolov5-v6.1目标检测,包含C++和Python两个版本的程序。支持yolov5s,yolov5m,yolov5l,yolov5n,yolov5x,yolov5s6,yolov5m6,yolov5l6,yolov5n6,yolov5x6的十种结构的yolov5-v6.1

仓库中基于python的主要代码改写如下:

import cv2
import argparse
import numpy as np

class yolov5():
    def __init__(self, modelpath, confThreshold=0.5, nmsThreshold=0.5, objThreshold=0.5):
        # with open('class.names', 'rt') as f:
        with open('.\\class.names', 'rt') as f:
            self.classes = f.read().rstrip('\n').split('\n')
        self.num_classes = len(self.classes)
        if modelpath.endswith('6.onnx'):
            self.inpHeight, self.inpWidth = 1280, 1280
            anchors = [[19, 27, 44, 40, 38, 94], [96, 68, 86, 152, 180, 137], [140, 301, 303, 264, 238, 542],
                       [436, 615, 739, 380, 925, 792]]
            self.stride = np.array([8., 16., 32., 64.])
        else:
            self.inpHeight, self.inpWidth = 640, 640
            anchors = [[10, 13, 16, 30, 33, 23], [30, 61, 62, 45, 59, 119], [116, 90, 156, 198, 373, 326]]
            self.stride = np.array([8., 16., 32.])
        self.nl = len(anchors)
        self.na = len(anchors[0]) // 2
        self.grid = [np.zeros(1)] * self.nl
        self.anchor_grid = np.asarray(anchors, dtype=np.float32).reshape(self.nl, -1, 2)
        self.net = cv2.dnn.readNet(modelpath)
        self.confThreshold = confThreshold
        self.nmsThreshold = nmsThreshold
        self.objThreshold = objThreshold
        self._inputNames = ''

    def resize_image(self, srcimg, keep_ratio=True, dynamic=False):
        top, left, newh, neww = 0, 0, self.inpWidth, self.inpHeight
        if keep_ratio and srcimg.shape[0] != srcimg.shape[1]:
            hw_scale = srcimg.shape[0] / srcimg.shape[1]
            if hw_scale > 1:
                newh, neww = self.inpHeight, int(self.inpWidth / hw_scale)
                img = cv2.resize(srcimg, (neww, newh), interpolation=cv2.INTER_AREA)
                if not dynamic:
                    left = int((self.inpWidth - neww) * 0.5)
                    img = cv2.copyMakeBorder(img, 0, 0, left, self.inpWidth - neww - left, cv2.BORDER_CONSTANT,
                                             value=(114, 114, 114))  # add border
            else:
                newh, neww = int(self.inpHeight * hw_scale), self.inpWidth
                img = cv2.resize(srcimg, (neww, newh), interpolation=cv2.INTER_AREA)
                if not dynamic:
                    top = int((self.inpHeight - newh) * 0.5)
                    img = cv2.copyMakeBorder(img, top, self.inpHeight - newh - top, 0, 0, cv2.BORDER_CONSTANT,
                                             value=(114, 114, 114))
        else:
            img = cv2.resize(srcimg, (self.inpWidth, self.inpHeight), interpolation=cv2.INTER_AREA)
        return img, newh, neww, top, left

    def _make_grid(self, nx=20, ny=20):
        xv, yv = np.meshgrid(np.arange(ny), np.arange(nx))
        return np.stack((xv, yv), 2).reshape((-1, 2)).astype(np.float32)

    def preprocess(self, img):
        img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
        img = img.astype(np.float32) / 255.0
        return img

    def postprocess(self, frame, outs, padsize=None):
        frameHeight = frame.shape[0]
        frameWidth = frame.shape[1]
        newh, neww, padh, padw = padsize
        ratioh, ratiow = frameHeight / newh, frameWidth / neww
        # Scan through all the bounding boxes output from the network and keep only the
        # ones with high confidence scores. Assign the box's class label as the class with the highest score.

        confidences = []
        boxes = []
        classIds = []
        for detection in outs:
            if detection[4] > self.objThreshold:
                scores = detection[5:]
                classId = np.argmax(scores)
                confidence = scores[classId] * detection[4]
                if confidence > self.confThreshold:
                    center_x = int((detection[0] - padw) * ratiow)
                    center_y = int((detection[1] - padh) * ratioh)
                    width = int(detection[2] * ratiow)
                    height = int(detection[3] * ratioh)
                    left = int(center_x - width * 0.5)
                    top = int(center_y - height * 0.5)

                    confidences.append(float(confidence))
                    boxes.append([left, top, width, height])
                    classIds.append(classId)
        # Perform non maximum suppression to eliminate redundant overlapping boxes with
        # lower confidences.
        indices = cv2.dnn.NMSBoxes(boxes, confidences, self.confThreshold, self.nmsThreshold).flatten()
        for i in indices:
            box = boxes[i]
            left = box[0]
            top = box[1]
            width = box[2]
            height = box[3]
            frame = self.drawPred(frame, classIds[i], confidences[i], left, top, left + width, top + height)
        return frame

    def drawPred(self, frame, classId, conf, left, top, right, bottom):
        if classId == 0:
            # Draw a bounding box.
            cv2.rectangle(frame, (left, top), (right, bottom), (0, 0, 255), thickness=4)

            label = '%.2f' % conf
            label = '%s:%s' % (self.classes[classId], label)

            # Display the label at the top of the bounding box
            labelSize, baseLine = cv2.getTextSize(label, cv2.FONT_HERSHEY_SIMPLEX, 0.5, 1)
            top = max(top, labelSize[1])
            # cv.rectangle(frame, (left, top - round(1.5 * labelSize[1])), (left + round(1.5 * labelSize[0]), top + baseLine), (255,255,255), cv.FILLED)
            cv2.putText(frame, label, (left, top - 10), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), thickness=2)
            return frame

    def detect(self, srcimg):
        img, newh, neww, padh, padw = self.resize_image(srcimg)
        blob = cv2.dnn.blobFromImage(img, scalefactor=1 / 255.0, swapRB=True)
        # blob = cv2.dnn.blobFromImage(self.preprocess(img))
        # Sets the input to the network
        self.net.setInput(blob, self._inputNames)

        # Runs the forward pass to get output of the output layers
        outs = self.net.forward(self.net.getUnconnectedOutLayersNames())[0].squeeze(axis=0)

        # inference output
        row_ind = 0
        for i in range(self.nl):
            h, w = int(self.inpHeight / self.stride[i]), int(self.inpWidth / self.stride[i])
            length = int(self.na * h * w)
            if self.grid[i].shape[2:4] != (h, w):
                self.grid[i] = self._make_grid(w, h)

            outs[row_ind:row_ind + length, 0:2] = (outs[row_ind:row_ind + length, 0:2] * 2. - 0.5 + np.tile(
                self.grid[i], (self.na, 1))) * int(self.stride[i])
            outs[row_ind:row_ind + length, 2:4] = (outs[row_ind:row_ind + length, 2:4] * 2) ** 2 * np.repeat(
                self.anchor_grid[i], h * w, axis=0)
            row_ind += length
        srcimg = self.postprocess(srcimg, outs, padsize=(newh, neww, padh, padw))
        return srcimg

if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument('--imgpath', type=str, default='.\\yolov5-v6.1-opencv-onnxrun\\opencv\\images\\bus.jpg', help="image path")
    parser.add_argument('--modelpath', type=str, default='.\\yolov5-v6.1-opencv-onnxrun\\opencv\\weights\\yolov5n.onnx')
    parser.add_argument('--confThreshold', default=0.3, type=float, help='class confidence')
    parser.add_argument('--nmsThreshold', default=0.5, type=float, help='nms iou thresh')
    parser.add_argument('--objThreshold', default=0.3, type=float, help='object confidence')
    args = parser.parse_args()

    yolonet = yolov5(args.modelpath, confThreshold=args.confThreshold, nmsThreshold=args.nmsThreshold,
                     objThreshold=args.objThreshold)
    
    cap = cv2.VideoCapture(0)

    while True:
        ret, frame = cap.read()
        frame = cv2.flip(frame, 1)     # 绕y轴翻转

        srcimg = yolonet.detect(frame)

        winName = 'Deep learning object detection in OpenCV'
        # cv2.imshow(winName, srcimg)
        
        cv2.imshow(winName, frame)
        # 按esc键退出循环
        if cv2.waitKey(1) & 0xff == 27:
            break

    #释放资源
    cap.release()
    cv2.destroyAllWindows()

2. 调参

parser.add_argument('--confThreshold', default=0.3, type=float, help='classconfidence')
parser.add_argument('--nmsThreshold', default=0.5, type=float, help='nms iou thresh')
parser.add_argument('--objThreshold', default=0.3, type=float, help='object confidence')

针对yolov5参数的配置记录如下:

含义:

这几个参数是用于目标检测算法中的YOLO模型的阈值设置,用于控制检测的灵敏度和准确性。下面解释一下每个参数的含义:

  1. --confThreshold:类别置信度阈值(Class Confidence Threshold)。该阈值用于过滤掉模型对于检测框所属类别置信度较低的预测。通常情况下,模型会对每个检测框预测其所属类别以及置信度,--confThreshold指定了一个阈值,低于这个置信度的检测结果将被过滤掉。较小的--confThreshold值会保留更多的检测结果,但可能包含更多的误检,而较大的值会过滤掉低置信度的检测结果,但可能丢失一些真实目标。

  2. --nmsThreshold:非极大值抑制(NMS)的IoU阈值(Intersection over Union Threshold)。NMS用于抑制重叠的检测框,保留置信度最高的一个框。--nmsThreshold指定了一个IoU阈值,当两个检测框的IoU大于这个阈值时,较低置信度的框将被抑制。较小的--nmsThreshold值会保留更多的重叠框,较大的值会过滤掉重叠度较高的框。

  3. --objThreshold:目标检测的置信度阈值(Object Confidence Threshold)。该阈值用于过滤掉检测框中预测目标的置信度较低的预测。较小的--objThreshold值会保留更多的检测结果,但可能包含更多的误检,而较大的值会过滤掉低置信度的检测结果。

调参方法:

调整这些参数可以影响目标检测算法的性能和效果。调参通常需要通过反复试验和评估来找到最优的参数组合。以下是一些调参的方法:

  1. 初始值:通常可以使用作者建议的默认值作为初始值,例如--confThreshold 0.3、--nmsThreshold 0.5和--objThreshold 0.3。

  2. 网格搜索:可以选择一组参数值范围,然后使用网格搜索或随机搜索来在这个范围内搜索最优的参数组合。比如可以尝试不同的阈值范围,例如--confThreshold [0.1, 0.3, 0.5],--nmsThreshold [0.3, 0.5, 0.7],--objThreshold [0.1, 0.3, 0.5]。

  3. 调整顺序:通常建议先调整--confThreshold和--objThreshold,再调整--nmsThreshold。因为--nmsThreshold主要影响重叠框的抑制,它的影响会受到前两个阈值的影响。

  4. 数据集评估:使用标注好的验证集数据,对不同参数组合的模型进行评估,观察其在验证集上的性能指标(如精度、召回率等),并选择表现最好的组合。

  5. 视觉调试:使用不同的参数值进行目标检测,观察其在图像上的结果,通过直观观察来判断检测效果是否满足需求。

需要注意的是,调参是一个相对复杂的过程,需要根据具体的数据集和任务需求进行适配。建议结合实际应用场景和数据特点,进行综合考虑和调整。同时,建议使用验证集来进行评估,以确保调整的参数能够在未知数据上表现良好。

八、双目测距算法

九、pyqt系统搭建

直接使用pip安装有问题,所有选择以下方式安装,这样安装的pyqt不能在miniconda虚拟环境中运行。所以在本地的python环境中使用。

【树莓派】:pyqt5安装(附code)_树莓派安装pyqt5_时间之里的博客-CSDN博客

1.更新源(可选)

sudo apt-get update
sudo apt-get upgrade
  1. 下载安装pyqt5需要的依赖库:
sudo apt-get install python3-pyqt5
sudo apt-get install pyqt5-dev-tools
sudo apt-get install qttools5-dev-tools
  1. 验证是否安装成功,运行一个以下命令
python3 -c "import PyQt5"

如果安装了anaconda环境,则运行

/bin/python -c "import PyQt5"
  1. 测试程序
from PyQt5.QtWidgets import QApplication, QLabel

app = QApplication([])
label = QLabel('Hello PyQt5')
label.show()
app.exec_()

十、AI数字人

AI数字人的制作过程主要如下链接:

1. AI绘图神器使用——Midjourney

【AI绘画神器】Midjourney 最新免费注册和使用教程,无门槛,人人都可以轻松驾驭 !| 零度解说 - YouTube

2. 做AI数字人 D-ID

D-ID Creative Reality Studio

标签:__,GPT4,镜子,AI,text,self,cv2,--,url
From: https://www.cnblogs.com/Balcher/p/17659481.html

相关文章

  • 论文解读(TAMEPT)《A Two-Stage Framework with Self-Supervised Distillation For Cros
     论文信息论文标题:ATwo-StageFrameworkwithSelf-SupervisedDistillationForCross-DomainTextClassification论文作者:YunlongFeng,BohanLi,LiboQin,XiaoXu,WanxiangChe论文来源:2023aRxiv论文地址:download 论文代码:download视屏讲解:click1介绍 动......
  • AI自动生成绘画软件:艺术与科技的完美结合
    一、引言随着人工智能(AI)技术的飞速发展,越来越多的领域开始应用AI技术来提升工作效率和创造力。其中,AI自动生成绘画软件在近年来得到了广泛关注。这类软件利用深度学习算法,能够自动生成艺术作品,其应用领域包括数字艺术、广告业、电影制作等。本文将详细介绍AI自动生成绘画软件的工......
  • AI是什么软件?带你全面了解人工智能
    随着科技的快速发展,人工智能(AI)已经逐渐成为当今社会的热门话题。许多人都在谈论AI,但是究竟什么是AI呢?它又是由哪些软件构成的呢?本文将为你详细解答这些问题,带你全面了解人工智能。一、人工智能是什么?人工智能是一种模拟人类智能的计算机技术。它使机器能够像人一样学习、推理、......
  • AI画头像:让你的艺术创作更具个性和创意
    随着人工智能技术的不断发展,越来越多的领域开始应用AI技术来提升工作效率和创造力。其中,AI画头像的技术也日益成熟,为艺术家和设计师们提供了一种全新的创作方式。首先,让我们来了解一下什么是AI画头像。AI画头像是一种基于深度学习和神经网络的技术,通过训练大量的艺术作品和设计师......
  • AI绘画draft:如何利用人工智能技术创造独特的艺术作品
    ​ 随着人工智能(AI)技术的飞速发展,越来越多的领域开始应用AI来提升工作效率和创造力。在艺术领域中,AI绘画已经成为了一个备受关注的话题。其中,AI绘画draft技术更是让许多艺术家和设计师感受到了人工智能的魅力。本文将围绕AI绘画draft展开讨论,介绍其原理和应用,并探讨如何利用AI技......
  • ai人工智能写作是什么
    AI人工智能写作是指利用人工智能技术和算法来生成文本内容的过程和方法。它结合了自然语言处理、机器学习和深度学习等技术,使得计算机能够模仿人类的写作风格和创造力,生成各种类型的文章、故事、新闻、评论等内容。AI人工智能写作可以通过训练模型来学习大量的文本数据,并从中学习......
  • CHAT GPT 国内版:聊天机器人成为AI领域新宠
    近年来,人工智能(AI)技术发展迅猛,其中自然语言处理领域更是取得了突破性进展。在这个背景下,CHATGPT国内版作为一款基于深度学习的聊天机器人,备受瞩目。本文将围绕CHATGPT国内版展开讨论,分析其在AI领域中的地位和优势,探讨其对于人类社会的影响和前景。一、CHATGPT国内版的背景介绍......
  • AI绘画StableDiffusion美女实操教程:斗破苍穹-小医仙
    之前分享过StableDiffusion的入门到精通教程:AI绘画:StableDiffusion终极炼丹宝典:从入门到精通但是还有人就问:安装是安装好了,可是为什么生成的图片和你生成的图片差距那么远呢?怎么真实感和质感一个天一个地呢?出图效果展示:那么,我画的图,和你画的图,差别在哪里呢?很关键的因素,就......
  • openwrt使用tailscale实现内网穿透
    问题之前一直有电信公网ip,最近发现电信公网ip被撤下来了,打电话再去要发现给的是10开头的ip,电信客服还跟我说10开头就是公网ip,==,根本就不是,无奈使用zerotier进行打洞,把zerotier挂载在家里的路由器openwrt系统内,效果和有公网ip是一样的跑满了网速,但是最近zerotier被电信墙了,用不......
  • 2023.08.24T3 - brain - solution
    brainProblem给定一棵以\(1\)为根的树,给定树上所有点权与边权。记\(d(i,j)\)表示\(i\)到\(j\)的路径长度。定义一棵树的权值为:\[\sum\limits_{i=1}^{n-1}\sum\limits_{j=i+1}^{n}a_{i}a_{j}d(i,j)\]定义一次对点\(i\)的改造操作为:删掉\(i\)与其父节......