主頁 >  其他 > 【論文筆記】 Denoising Implicit Feedback for Recommendation

【論文筆記】 Denoising Implicit Feedback for Recommendation

2021-12-19 06:16:12 其他

Denoising Implicit Feedback for Recommendation

Authors: 王文杰,馮福利,何向南,聶禮強,蔡達成

WSDM‘21 新加坡國立大學,中國科學技術大學,山東大學

論文鏈接:http://staff.ustc.edu.cn/~hexn/papers/WSDM_2021_ADT.pdf,https://arxiv.org/pdf/2006.04153.pdf

本文鏈接:https://www.cnblogs.com/zihaojun/p/15704005.html


目錄
  • Denoising Implicit Feedback for Recommendation
    • 0. 總結
    • 1.問題背景
    • 2.研究目標
    • 3. “偽正樣本”研究
    • 4. 方法
      • 4.1 Obervations 觀察
      • 4.2 Adaptive Denoising Training(ADT) 適應性去噪訓練
        • 4.2.1 截斷交叉熵損失 Truncated Cross-Entropy Loss(T-CE)
        • 4.2.2 加權交叉熵損失函式 Reweighted Cross-Entropy Loss(R-CE)
    • 5. 實驗
      • 5.1 資料集
      • 5.2 實驗結果
      • 5.3 深入分析
        • 5.3.1 “偽正樣本”的Loss情況
        • 5.3.2 T-CE的性能研究
    • Weakness
    • 進一步閱讀

0. 總結

本文主要研究并解決推薦系統的隱式反饋資料中正樣本存在噪聲,會損害推薦系統性能的問題,

“偽正樣本”在推薦系統訓練的初始階段Loss普遍較高,利用這個規律,可以對“偽正樣本”和真正的正樣本進行區分,

本文提出了適應性去噪訓練(Adaptive Denoising Training,ADT)策略來解決上述問題,提出了截斷損失函式和加權損失函式兩種Loss函式,并基于交叉熵損失,在三個資料集上,基于三種推薦模型進行了實驗,實驗結果表明,ADT可以有效去除“偽正樣本”對模型性能的干擾,

1.問題背景

由于隱式反饋資料量比較大,容易獲得,因此隱式反饋資料已經是在線推薦系統的默認訓練資料,

但是隱式反饋資料是存在噪聲的,隱式反饋的正樣本只能反映用戶和物品之間存在互動,但是不能反映用戶對此次互動的滿意度,例如在電商中,用戶可能點擊了一個物品,但是并沒有購買;即使用戶購買了,對這個物品可能也是不滿意的,

在推薦系統訓練程序中,噪聲資料可能會損害推薦系統的性能,使得推薦系統捕捉用戶興趣的能力下降,

2.研究目標

在沒有用戶停留時間、物品特征、用戶反饋等額外資訊的情況下(這些資訊很稀疏,難以獲得),識別并去除互動資料中的“偽正樣本”,提高推薦系統訓練的效率和推薦系統的精度,

如下圖,圖中紅色的互動代表“偽正樣本”,黑色的互動代表“真正樣本”,

  • 第一串列示通常的推薦模型,會受到“偽正樣本”的干擾,推薦質量差,

  • 第二列和第三串列示利用額外資訊來識別“偽正樣本”,從而提高推薦質量,

  • 最后一列表示本文提出的框架,在不利用額外資訊的條件下,去除“偽正樣本”的影響,生成高質量的推薦結果,

論文Figure1

3. “偽正樣本”研究

為了驗證“偽正樣本”對推薦性能的影響,基于NeuMF模型,設計如下實驗:

  • 訓練階段
    • 使用所有互動資料(1-5分)的設定稱為Normal training
    • 只使用3-5分的互動資料(去除“偽正樣本”)的設定成為Clean training
  • 驗證階段
    • 驗證集和測驗集同樣去除1-2分的互動資料,只保留3-5分的互動資料

實驗結果表明,Clean training明顯優于Normal training,說明“偽正樣本”確實會損害推薦系統的性能,

\[\begin{array}{l|cc|cc} \hline \text { Dataset } & {\text { Adressa }} && {\text { Amazon-book }} \\ \text { Metric } & \text { Recall@20 } & \text { NDCG@20 } & \text { Recall@20 } & \text { NDCG@20 } \\ \hline \hline \text { Clean training } & 0.4040 & 0.1963 & 0.0293 & 0.0159 \\ \text { Normal training } & 0.3081 & 0.1732 & 0.0265 & 0.0145 \\ \hline \text { \#Drop } & 23.74 \% & 11.77 \% & 9.56 \% & 8.81 \% \\ \hline \end{array} \]

4. 方法

4.1 Obervations 觀察

在Adressa資料集上,使用所有互動資料(1-5分)訓練NeuMF,分別觀察True-positive Interactions和False-positive Interactions的平均loss值,

從下圖所示的實驗結果中可以看出:

  • 在左圖所示的完整訓練程序中,所有樣本的loss最終都收斂到很小的值,說明所有的樣本都被模型記住了,
  • 在右圖表示的訓練初始階段(0-1000 Iteraions),False-positive樣本的loss值(橙色)明顯高于True-positive的loss值(綠色),這說明在False-positive樣本的訓練難度明顯更高,

這個規律可以用來區分“偽正樣本”和“真正樣本”,

論文Figure3

4.2 Adaptive Denoising Training(ADT) 適應性去噪訓練

基于上節中的觀察,本文提出ADT模型,根據loss函式來區分“真正樣本”和“偽正樣本”,

ADT有兩種思路:

  • 截斷loss(Truncated Loss):基于一個動態調整的閾值,將loss比較高的樣本loss直接置0,使得這些樣本在當前訓練輪不參與模型更新,
  • 加權loss(Reweighted Loss):給難樣本(Loss大的樣本)更低的權重,

這兩種方法與Loss函式的設計無關,可以被應用到BCE和BPR等多種loss函式上,本文基于BCEloss進行實驗,

4.2.1 截斷交叉熵損失 Truncated Cross-Entropy Loss(T-CE)

\[\begin{align} \mathcal{L}_{T-C E}(u, i)= \begin{cases}0, & \mathcal{L}_{C E}(u, i)>\tau \wedge \bar{y}_{u i}=1 \\ \mathcal{L}_{C E}(u, i), & \text { otherwise }\end{cases} \\ \\ \mathcal{L}_{C E}\left(\mathcal{D}^{*}\right)=-\sum_{\left(u, i, y_{u i}^{*}\right) \in \mathcal{D}^{*}} y_{u i}^{*} \log \left(\hat{y}_{u i}\right)+\left(1-y_{u i}^{*}\right) \log \left(1-\hat{y}_{u i}\right) \end{align} \]

T-CE Loss將Loss值大于\(\tau\)的正樣本損失函式置0,其中\(\tau\)是預定義的值,可以隨著訓練輪數變化而變化,

為了建模\(\tau\),定義樣本淘汰率(drop rate),也就是在第T輪訓練中,淘汰loss最高的比例為\(\epsilon(T)\)的樣本:

\[\begin{align} \epsilon(T)=\min \left(\alpha T, \epsilon_{\max }\right) \end{align} \]

其中\(\alpha\)\(\epsilon_{max}\)是超引數,

這樣的設計可以保證:

  • 樣本淘汰率有上限,避免將樣本全部舍棄,
  • 訓練開始時,使用全部樣本
  • 樣本淘汰率從0逐漸增加到上限,使模型逐漸能分清真正樣本和假正樣本,

4.2.2 加權交叉熵損失函式 Reweighted Cross-Entropy Loss(R-CE)

\[\begin{align} \mathcal{L}_{R-C E}(u, i)=\omega(u, i) \mathcal{L}_{C E}(u, i) \end{align} \]

其中\(\omega(u, i)\)是調整不同樣本損失在總損失函式中占比的權重,

\(\omega(u, i)\)應該有以下性質:

  • 在訓練程序中動態變化
  • 使得Loss高的正樣本權重更低
  • 權重可以通過超參調整,以適用于不同模型和資料集

輸出預測值\(\hat{y}_{u i}\)與Loss函式是一一對應的,\(\hat{y}_{u i}\)越低,對應的Loss就越高,則權重應該越低;可以利用\(\hat{y}_{u i}\)來定義\(\omega(u, i)\)

\[\begin{align} \omega(u, i) = f({\hat{y}_{ui}}) = \hat{y}_{u i}^{\beta} \end{align} \]

其中\(\beta\in[0,+\infin]\)是超引數,\(\hat{y}_{ui}\)表示預測值,\(\bar{y}_{ui}\)表示標簽值,

Figure 5(a)展示\(\beta\)取不同的值時,Loss函式與預測值\(\hat{y}_{ui}\)的關系,即\(\beta\)越大,難樣本(\(\hat{y}_{ui}\)較小)的Loss被壓縮的效果越明顯;當\(\beta = 0\)時,R-CE退化到普通的CE,

論文Figure3

為了保證正負樣本Loss值的一致性,給負樣本也做了同樣的處理:

\[\begin{align} \omega(u, i)= \begin{cases}\hat{y}_{u i}^{\beta}, & \bar{y}_{u i}=1 \\ \left(1-\hat{y}_{u i}\right)^{\beta}, & \text { otherwise }\end{cases} \end{align} \]

5. 實驗

5.1 資料集

  • Adressa:新聞閱讀資料集,包含用戶的點擊資料和在頁面的停留時間;停留少于10s的點擊視為“偽正樣本”
  • Amazon-book:亞馬遜評論資料集,包含用戶對物品的評分資料;評分低于3分的互動視為“偽正樣本”
  • Yelp:餐廳評分資料集;評分低于3分的互動視為“偽正樣本”

訓練集和驗證集包含所有互動,測驗集只包含“真正樣本”,

5.2 實驗結果

  • 在三種推薦模型上,T-CE和R-CE Loss都提升了推薦性能,證明了方法的有效性
  • 比較T-CE和R-CE兩種方法,T-CE的性能一般會更好,這是因為T-CE直接去除了難樣本的影響,并多了一個超引數,
  • NeuMF的性能比GMF還低,這是因為訓練資料中有“偽正樣本”,NeuMF的擬合能力更強,學到了這些噪聲資訊,
  • T-CE和R-CE都在NeuMF上取得了最大的性能提升,這與上一條結論一致——NMF受到“偽正樣本”的影響更大,T-CE和R-CE在CDAE上面仍然有性能提升,證明了本文的方法的合理性,
論文Table3

為了驗證本文的方法是否會損害不活躍用戶的推薦精度,本文將用戶按照互動數量分為四組,實驗結果表明,即便是互動數量很少的用戶組,推薦精度也得到了提升,

論文Table3

5.3 深入分析

5.3.1 “偽正樣本”的Loss情況

第三部分已經分析過,“偽正樣本”被模型記住之后,會使得模型性能降低,

本文用實驗驗證,提出的方法能否使得“偽正樣本”不被模型記住,也就是“偽正樣本”Loss是否能更高,

  • 如Figure 7(a)所示,正常訓練時,“偽正樣本”的Loss會學到跟其他正樣本一個水平
  • 而使用T-CE時,“偽正樣本”的Loss隨著訓練,先幾乎不變,后迅速升高,說明模型準確識別到了這些“偽正樣本”,并把他們從訓練的正樣本集排除出去,
  • 而使用R-CE時,“偽正樣本”的Loss隨著訓練程序仍然是下降的,但還是比其他樣本高一些,

這一部分驗證的是文章的核心論點,也是本文提出的模型起作用的核心機制——通過Loss函式識別并排除“偽正樣本”的影響,

論文Figure7

5.3.2 T-CE的性能研究

由于截斷交叉熵損失函式(T-CE)使得“偽正樣本”的Loss函式很高,作者又從T-CE過濾掉的互動與真正的“偽正樣本”之間的召回率和準確率的角度來研究T-CE,

實驗表明,T-CE選取“偽正樣本”的準確率大約是隨機選取的兩倍,但準確率(precision)仍然只有10%左右,

  • 一方面,這說明,為了過濾掉“偽正樣本”,拋棄一些真正樣本是值得的
  • 但另一方面,這也說明本文章提出的方法準確率仍然很低
論文Figure9

Weakness

  • R-CE中給負樣本也加了權重,而T-CE中沒有對負樣本做處理,實驗中也沒有對此做出說明,
  • 識別“偽正樣本”的準確率只有10%,

進一步閱讀

[5] Yihong Chen, Bei Chen, Xiangnan He, Chen Gao, Yong Li, Jian-Guang Lou, and Yue Wang. 2019. lambdaOpt: Learn to Regularize Recommender Models in Finer Levels. In Proceedings of the 25th SIGKDD International Conference on Knowledge Discovery and Data Mining. ACM, 978–986.

[6] Jingtao Ding, Guanghui Yu, Xiangnan He, Fuli Feng, Yong Li, and Depeng Jin. 2019. Sampler design for bayesian personalized ranking by leveraging view data. Transactions on Knowledge and Data Engineering (2019).

[16] Xiangnan He, Lizi Liao, Hanwang Zhang, Liqiang Nie, Xia Hu, and Tat-Seng Chua. 2017. Neural Collaborative Filtering. In Proceedings of the 26th International Conference on World Wide Web. IW3C2, 173–182.

[18] Y. Hu, Y. Koren, and C. Volinsky. 2008. Collaborative Filtering for Implicit Feedback Datasets. In Proceedings of the 8th International Conference on Data Mining. TEEE, 263–272.

[19] Rolf Jagerman, Harrie Oosterhuis, and Maarten de Rijke. 2019. To Model or to Intervene: A Comparison of Counterfactual and Online Learning to Rank from User Interactions. In Proceedings of the 42nd International SIGIR Conference on Research and Development in Information Retrieval. ACM, 15–24.

[39] Hongyi Wen, Longqi Yang, and Deborah Estrin. 2019. Leveraging Post-click Feedback for Content Recommendations. In Proceedings of the 13th Conference on Recommender Systems. ACM, 278–286.

[40] Yao Wu, Christopher DuBois, Alice X Zheng, and Martin Ester. 2016. Collaborative denoising auto-encoders for top-n Recommender Systems. In Proceedings of the 9th International Conference on Web Search and Data Mining. ACM, 153–162.

[41] Byoungju Yang, Sangkeun Lee, Sungchan Park, and Sang goo Lee. 2012. Exploiting Various Implicit Feedback for Collaborative Filtering. In Proceedings of the 21st International Conference on World Wide Web. IW3C2, 639–640.

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/385282.html

標籤:其他

上一篇:起薪50w,BATMD搶著要,Python才是程式員最該學習的技能

下一篇:什么是元宇宙(Metaverse)及元宇宙的發展趨勢及個人理解

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more