SpringAI

機器學習:

  • 定義:人工智能的子領域,通過數據驅動的方法讓計算機學習規律,進行預測或決策。

  • 核心方法

    • 監督學習(如線性回歸、SVM)。

    • 無監督學習(如聚類、降維)。

    • 強化學習(如Q-learning)。

  • 特點:依賴特征工程,模型復雜度較低,適用于中小型數據。

深度學習:

  • 定義:基于深層神經網絡的機器學習方法,可自動提取特征。

  • 關鍵技術

    • 神經網絡架構:CNN(圖像)、RNN/LSTM(序列數據)、Transformer。

    • 優化算法:反向傳播、梯度下降(如Adam優化器)。

  • 優勢:處理高維數據(如圖像、文本),減少人工特征工程。

自然語言處理:

  • 目標:使計算機理解、生成人類語言。

  • 技術演進

    • 傳統方法:詞袋模型、TF-IDF、隱馬爾可夫模型。

    • 深度學習方法:詞嵌入(Word2Vec)、預訓練模型(BERT、GPT)。

  • 任務:機器翻譯、情感分析、文本生成等。

大語言模型:

  • 定義:參數量巨大(數億至萬億)的深度學習模型,專注于語言任務。

  • 代表模型:GPT系列、BERT、T5。

  • 核心技術

    • Transformer架構:自注意力機制(捕捉長距離依賴)。

    • 預訓練與微調:在大規模語料上預訓練(如掩碼語言建模),再針對下游任務微調。

大模型底層原理:

T:基于Transformer的神經網絡

P:通過大量數據預訓練,掌握自然語言規律

G:基于上文計算概率,生成下一個token

模型部署:

云部署:

優點:前期成本低、部署維護簡單、彈性擴展、全球訪問

缺點:數據隱私、網絡依賴、長期成本高

本地部署:

優點:數據安全、不依賴外部網絡、長期成本低、高度定制

缺點:初始成本高、維護復雜、部署周期長

開放API:

優點:前期成本極低、無需部署、無需維護、全球訪問

缺點:數據隱私、網絡依賴、長期成本高、定制限制


調用大模型:

傳統應用和大模型應用:

大模型應用是基于大模型的推理、分析、生成能力,結合傳統編程能力,開發出的各種應用

AI應用開發技術架構:

Fine-tuning(模型微調)

針對特有業務場景對基礎大模型做數據訓練與微調,以滿足特定場景的需求。

SpringAI:

是一個大模型應用框架。其目標是將Spring生態系統的設計原則(如可移植性的模塊化設計)應用于人工智能鄰域。可以無縫接入Spring生態體系,快速改造傳統項目。

對話機器人-入門

引入依賴:

配置模型:

配置客戶端:

創建項目:

引入依賴自動完成

配置:

創建包config,包下創建相應類

創建controller包,包下創建相應的類:

手動加入

阻塞式,響應時間較長

流式默認采用event事件流,默認情況沒有編碼

需要在@RequestMapping注解后自己設置響應的類型

system設定:

這里是controller和前端的對話

對話機器人-會話日志

對chatclinet做修改加入環繞增強

修改配置文件,新增日志相關:

在application.yaml加入

日志功能通過環繞通知來去實現的

對話機器人-前端對接

解決跨域問題

對話機器人-會話記憶

步驟:

定義會話存儲方式:

存儲在內部的會話記憶

配置會話記憶:

添加會話id:

第三排:匿名環繞增強器

配置類中

添加

對話機器人-會話歷史

新增接口:

public interface ChatHistoryRepository {
?
? ? /**
? ? ?* 保存會話記錄
? ? ?* @param type
? ? ?* @param charId
? ? ?*/
? ? void save(String type,String charId);
?
?
? ? /**
? ? ?* 獲取會話記錄
? ? ?* @param type
? ? ?* @return
? ? ?*/
? ? List<String> getChatIds(String type);
}

接口實現:


?
/**
?* @author TonySong
?* @date 2025/4/12 0012
?* @time 10:35
?*/
@Component
public class InMemoryChatRepository implements ChatHistoryRepository{
?
? ? private final Map<String,List<String>> chatHistory= new HashMap<>();
?
? ? @Override
? ? public void save(String type, String charId) {
// ? ? ? ?if(!chatHistory.containsKey(type)){
// ? ? ? ? ? ?chatHistory.put(charId,new ArrayList<>());
// ? ? ? ?}
// ? ? ? ?List<String> charIds = chatHistory.get(type);
? ? ? ? List<String> charIds = chatHistory.computeIfAbsent(type, k -> new ArrayList<>());
? ? ? ? if(charIds.contains(charId)){
? ? ? ? ? ? return;
? ? ? ? }
? ? ? ? charIds.add(charId);
? ? }
?
? ? @Override
? ? public List<String> getChatIds(String type) {
// ? ? ? ?List<String> list = chatHistory.get(type);
// ? ? ? ?return list==null? List.of():list;
? ? ? ? return chatHistory.getOrDefault(type,List.of());
? ? }
}

修改會話實現:


?
/**
?* @author TonySong
?* @date 2025/4/11 0011
?* @time 17:39
?*/
@RestController
@RequestMapping("/ai")
@RequiredArgsConstructor//啟用帶參構造完成創建
public class ChatController {
?
? ? private final ChatClient chatClient;
?
? ? private final ChatHistoryRepository ?chatHistoryRepository;
?
?
? ? @RequestMapping(value = "/chat",produces = "text/html;charset=utf-8")
? ? public Flux<String> chat(@RequestParam(value = "message",defaultValue = "你是誰") String message) {
? ? ? ? //1、保存會話
? ? ? ? chatHistoryRepository.save("chat",message);
? ? ? ? //2、獲取會話
? ? ? ? return chatClient
? ? ? ? ? ? ? ? .prompt()
? ? ? ? ? ? ? ? .user(message)
? ? ? ? ? ? ? ? .stream()
? ? ? ? ? ? ? ? .content();
? ? }
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/79850.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/79850.shtml
英文地址,請注明出處:http://en.pswp.cn/web/79850.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何用Redis實現分布式鎖?RedLock算法的核心思想?Redisson的看門狗機制原理?

一、Redis分布式鎖基礎實現 public class RedisDistributedLock {private JedisPool jedisPool;private String lockKey;private String clientId;private int expireTime 30; // 默認30秒public boolean tryLock() {try (Jedis jedis jedisPool.getResource()) {// NX表示不…

前端面試寶典---js垃圾回收機制

什么是垃圾回收 垃圾回收是指一種自動內存管理機制&#xff0c;當聲明一個變量時&#xff0c;會在內存中開辟一塊內存空間用于存放這個變量。當這個變量被使用過后&#xff0c;可能再也不需要它了&#xff0c;此時垃圾回收器會自動檢測并回收這些不再使用的內存空間。垃圾回收…

阿里媽媽LMA2新進展:集成大語言模型與電商知識的通用召回大模型URM

近日&#xff0c;阿里媽媽在國際頂級學術會議 —— 國際萬維網大會&#xff08;International World Wide Web Conference, 簡稱WWW&#xff09;上共同主持了計算廣告算法技術相關的Tutorial&#xff08;講座&#xff09;&#xff0c;介紹了計算廣告領域的技術發展脈絡&#xf…

數字孿生實時監控汽車零部件工廠智能化巡檢新范式

在汽車制造業面臨數字化轉型時&#xff0c;汽車零部件工廠也面臨著提升生產效率、降低運營成本和增強市場競爭力的多重挑戰。傳統的巡檢方式已經難以滿足現代工廠對高效、精準管理和實時決策的需求。數字孿生系統的出現&#xff0c;為汽車零部件工廠提供了一種創新的智能化巡檢…

【計算機網絡】3數據鏈路層②

1. 數據鏈路層所處的地位 數據鏈路層使用的信道主要有兩種: ①點對點信道:PPP協議 ②廣播信道:有線局域網,CSMA/CD協議;無線局域網,CSMA/CA協議 對比項點對點信道 vs 單播廣播信道 vs 廣播核心是否一致? 一致(一對一傳輸)? 一致(一對所有傳輸)差異點前者是物理層…

c++中的函數(默認參數,占位參數,重載)

1&#xff0c;函數默認參數 在c中&#xff0c;函數的形參列表中的形參是可以有默認值得 語法&#xff1a;返回值類型 函數名 &#xff08;參數 默認值&#xff09;{} 示例&#xff1a; #include<iostream> using namespace std;//函數默認參數 // 就是如果傳了就…

【原創】使用阿里云存放一個臨時共享的文件

在某些場合&#xff0c;需要臨時將一個文件存儲到一個可被公網訪問的地方&#xff0c;某個服務需要訪問一下這個文件。這個文件基本上就是一次壽命&#xff0c;也就是你上傳一下&#xff0c;然后被訪問一下&#xff0c;這個文件的壽命就結束了。 對于這種需求&#xff0c;自建…

Python中列表(list)知識詳解(2)和注意事項以及應用示例

在 Python 中列表&#xff08;list&#xff09; 的包括其結構、常見操作&#xff08;更新、添加、刪除、查找、隊列棧行為等&#xff09;&#xff0c;下面將逐一的進行講解并附相關的示例。 一、列表的基礎知識 1. 定義與特點 定義方式&#xff1a;用 [] 包裹的有序可變集合 …

vscode extention踩坑記

# npx vsce package --allow-missing-repository --no-dependencies #耗時且不穩定 npx vsce package --allow-missing-repository #用這行 code --install-extension $vsixFileName --force我問ai&#xff1a;為什么我的.vsix文件大了那么多 ai答&#xff1a;因為你沒有用 --n…

移動端巡檢點檢,讓設備管理更便捷高效

在企業設備管理的日常工作中&#xff0c;巡檢點檢是保障設備正常運行的重要環節。傳統的巡檢方式依賴紙質記錄、人工操作&#xff0c;效率低、易出錯&#xff0c;已難以滿足現代企業的管理需求。隨著技術發展&#xff0c;越來越多設備管理系統引入移動端功能&#xff0c;為設備…

laravel 中使用的pdf 擴展包 laravel-snappy(已解決中文亂碼)

Centos7 安裝 wkhtmltopdf 1、先查看系統是 32 位的還是 64 位的 uname -a2、通過 composer 安裝 wkhtmltopdf 32位: $ composer require h4cc / wkhtmltopdf-i386 0.12.x $ composer require h4cc / wkhtmltoimage-i386 0.12.x 64位: $ composer require h4cc/wkhtmltopdf-…

Rust:重新定義系統編程的安全與效率邊界

在軟件工程領域&#xff0c;內存安全漏洞每年造成數千億美元損失&#xff0c;而C/C生態中60%的漏洞源于指針誤用。正是在這樣的背景下&#xff0c;Rust憑借其革命性的內存安全機制異軍突起。作為一門現代系統級編程語言&#xff0c;Rust不僅解決了困擾開發者數十年的內存管理難…

C++學習細節回顧(匯總二)

一.初始化列表相關 1.初始化順序受申明順序影響 2.在必要時可以部分不采用初始化列表&#xff0c;避免受特性1影響 二.非類型模板參數 template< class T , size_t N 10 > 三.特化–特殊化處理 template< class T > bool less(T left , T right) { return left&…

勾選某一行的勾選框,更改當前行的顏色,ALV數據發生變化的事件

文章目錄 屏幕ALV的創建定義變量注冊事件方法定義方法實現frm_data_change 效果 屏幕 ALV的創建 DATA: g_gui_custom_container TYPE REF TO cl_gui_custom_container. DATA: g_gui_alv_grid TYPE REF TO cl_gui_alv_grid.DATA: gt_listheader TYPE slis_t_listheader, &quo…

AI-02a5a6.神經網絡-與學習相關的技巧-批量歸一化

批量歸一化 Batch Normalization 設置合適的權重初始值&#xff0c;則各層的激活值分布會有適當的廣度&#xff0c;從而可以順利的進行學習。那么&#xff0c;更進一步&#xff0c;強制性的調整激活值的分布&#xff0c;是的各層擁有適當的廣度呢&#xff1f;批量歸一化&#…

解決SQL Server SQL語句性能問題(9)——合理使用表分區

9.2. 合理使用表分區 本專欄4.1.4節中,我們對表分區相關的概念和機制等基礎理論進行了較為詳細的介紹和論述,讀者可以參考該節中內容,或者,讀者也可以參考官方或其他相關資料。與其他關系庫類似,SQL Server 2005版本中引進的真正意義上的表分區技術,絕對是解決海量數據環…

C語言學習之文件操作

經過前面的學習&#xff0c;我們已經基本掌握了如何去寫一個C語言的代碼了。但是在實際的項目中&#xff0c;我們不可能不需要文件去操作。因為如果沒有文件&#xff0c;我們寫的程序是存儲在電腦的內存中的。如果程序推出&#xff0c;內存回收數據就隨之丟失了。如果我們要對數…

2025年PMP 學習十三 第9章 項目資源管理(9.1,9.2)

2025年PMP 學習十三 第9章 項目資源管理&#xff08;9.1,9.2&#xff09; 序號過程過程組9.1規劃資源管理規劃9.2估算活動資源規劃9.3獲取資源執行9.4建設團隊執行9.5管理團隊執行9.6控制資源監控 文章目錄 2025年PMP 學習十三 第9章 項目資源管理&#xff08;9.1,9.2&#xf…

藍橋杯13屆國B 完全日期

題目描述。 如果一個日期中年月日的各位數字之和是完全平方數&#xff0c;則稱為一個完全日期。 例如&#xff1a;2021 年 6 月 5 日的各位數字之和為 20216516&#xff0c;而 16 是一個完全平方數&#xff0c;它是 4 的平方。所以 2021 年 6 月 5 日是一個完全日期。 例如&…

某某霸翻譯逆向分析[JS逆向]

聲明 本文章中所有內容僅供學習交流使用&#xff0c;不用于其他任何目的&#xff0c;不提供完整代碼&#xff0c;抓包內容、敏感網址、數據接口等均已做脫敏處理&#xff0c;嚴禁用于商業用途和非法用途&#xff0c;否則由此產生的一切后果均與作者無關&#xff01; 本文章未經…