女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深度:了解訓(xùn)練神經(jīng)網(wǎng)絡(luò)時所用到的數(shù)學(xué)過程

智能感知與物聯(lián)網(wǎng)技術(shù)研究所 ? 來源:YXQ ? 2019-07-15 15:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

模型的訓(xùn)練、調(diào)參是一項(xiàng)非常費(fèi)時費(fèi)力的工作,了解神經(jīng)網(wǎng)絡(luò)內(nèi)部的數(shù)學(xué)原理有利于快速找出問題所在。本文作者從零開始,一步一步講解了訓(xùn)練神經(jīng)網(wǎng)絡(luò)時所用到的數(shù)學(xué)過程。

神經(jīng)網(wǎng)絡(luò)是線性模塊和非線性模塊的巧妙排列。當(dāng)聰明地選擇并連接這些模塊時,我們就得到了一個強(qiáng)大的工具來逼近任何一個數(shù)學(xué)函數(shù),如一個能夠借助非線性決策邊界進(jìn)行分類的神經(jīng)網(wǎng)絡(luò)。

運(yùn)行代碼的步驟如下:

git clone https://github.com/omar-florez/scratch_mlp/python scratch_mlp/scratch_mlp.py

盡管反向傳播技術(shù)具有直觀、模塊化的特質(zhì),但是它負(fù)責(zé)更新可訓(xùn)練的參數(shù),這是一個一直未被深入解釋的主題。讓我們以樂高積木為喻,一次增加一塊,從零構(gòu)建一個神經(jīng)網(wǎng)絡(luò)來一探其內(nèi)部功能。

神經(jīng)網(wǎng)絡(luò)就像是由樂高積木組成的

上圖描述了訓(xùn)練一個神經(jīng)網(wǎng)絡(luò)時所用到的部分?jǐn)?shù)學(xué)過程。我們將在本文中解釋這個。讀者可能感到有趣的一點(diǎn)是:一個神經(jīng)網(wǎng)絡(luò)就是很多模塊以不同的目標(biāo)堆疊起來。

輸入變量 X 向神經(jīng)網(wǎng)絡(luò)饋送原始數(shù)據(jù),它被存儲在一個矩陣中,矩陣的行是觀察值,列是維度。

權(quán)重 W_1 將輸入 X 映射到第一個隱藏層 h_1。然后權(quán)重 W_1 充當(dāng)一個線性核。

Sigmoid 函數(shù)防止隱藏層中的數(shù)字落到 0-1 的范圍之外。結(jié)果就是一個神經(jīng)激活的數(shù)組,h_1 = Sigmoid(WX)。

此時,這些運(yùn)算只是組成了一個一般線性系統(tǒng),無法對非線性交互建模。當(dāng)我們再疊加一層,給模塊的結(jié)構(gòu)增加深度的時候這一點(diǎn)就會改變。網(wǎng)絡(luò)越深,我們就會學(xué)到越多微妙的非線性交互,能解決的問題也就越復(fù)雜,或許這也是深度神經(jīng)模型興起的原因之一。

為什么我要讀這篇文章?

如果你理解一個神經(jīng)網(wǎng)絡(luò)的內(nèi)部部分,你就能夠在遇到問題的時候快速知道先去改變哪里,并且能夠制定策略來測試你所知道的這個算法的部分不變量和預(yù)期的行為。

因?yàn)檎{(diào)試機(jī)器學(xué)習(xí)模型是一項(xiàng)復(fù)雜的任務(wù)。根據(jù)經(jīng)驗(yàn),數(shù)學(xué)模型在首次嘗試的時候不會奏效。它們可能會對新數(shù)據(jù)給出較低的準(zhǔn)確率,會耗費(fèi)很長的訓(xùn)練時間或者太多的內(nèi)存,返回一個很大的錯誤負(fù)數(shù)值或者 NAN 的預(yù)測……在有些情況下,了解算法的運(yùn)行機(jī)制可以讓我們的任務(wù)變得更加便利:

如果訓(xùn)練花費(fèi)了太多的時間,那增加 minibatch 的大小或許是一個好主意,這能夠減小觀察值的方差,從而有助于算法收斂。

如果你看到了 NAN 的預(yù)測值,算法可能接收到了大梯度,產(chǎn)生了內(nèi)存溢出??梢詫⑦@個視為在很多次迭代之后發(fā)生爆炸的矩陣乘法。減小學(xué)習(xí)率可以縮小這些數(shù)值。減少層數(shù)能夠減少乘法的數(shù)量。剪切梯度也能夠明顯地控制這個問題。

具體的例子:學(xué)習(xí)異或函數(shù)

讓我們打開黑盒子。我們現(xiàn)在要從零開始構(gòu)建一個學(xué)習(xí)異或函數(shù)的神經(jīng)網(wǎng)絡(luò)。選擇這個非線性函數(shù)可絕對不是隨機(jī)的。沒有反向傳播的話,就很難學(xué)會用一條直線分類。

為了描述這個重要的概念,請注意下圖中,一條直線是為何不能對異或函數(shù)輸出中的 0 和 1 進(jìn)行分類?,F(xiàn)實(shí)生活中的問題也是非線性可分的。

這個網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu)非常簡單:

輸入變量 X 是二維向量

權(quán)重 W_1 是具有隨機(jī)初始化數(shù)值的 2x3 的矩陣

隱藏層 h_1 包含 3 個神經(jīng)元。每個神經(jīng)元接受觀察值的加權(quán)和作為輸入,這就是下圖中綠色高亮的內(nèi)積:z_1 = [x_1, x_2][w_1, w_2]

權(quán)重 W_2 是具有隨機(jī)初始化值的 3x2 的矩陣

輸出層 h_2 包含兩個神經(jīng)元,因?yàn)楫惢蚝瘮?shù)的輸出要么是 0(y_1=[0,1]),要么是 1(y_2 = [1,0])

下圖更加直觀:

我們現(xiàn)在來訓(xùn)練這個模型。在我們這個簡單的例子中,可訓(xùn)練的參數(shù)就是權(quán)重,但是應(yīng)該知道的是,目前的研究正在探索更多可以被優(yōu)化的參數(shù)類型。例如層之間的快捷連接、正則化分布、拓?fù)浣Y(jié)構(gòu)、殘差、學(xué)習(xí)率等等。

反向傳播是這樣的一種方法:在給定的一批具有標(biāo)簽的觀察值上,朝著將預(yù)定義的錯誤指標(biāo)(就是損失函數(shù))最小化的方向(梯度)更新權(quán)重。該算法已經(jīng)多次被重復(fù)發(fā)現(xiàn),這是另一種更通用的被稱為自動微分的技術(shù)在反向積累模式下的特例。

網(wǎng)絡(luò)初始化

讓我們用隨機(jī)數(shù)來初始化網(wǎng)絡(luò)權(quán)重

前向步驟:

這一步的目標(biāo)就是把輸入變量 X 向前傳遞到網(wǎng)絡(luò)的每一層,直至計算出輸出層 h_2 的向量。

這就是其中發(fā)生的計算過程:

以權(quán)重 W_1 為線性核對輸入數(shù)據(jù) X 做線性變換:

使用 Sigmoid 激活函數(shù)對加權(quán)和進(jìn)行縮放,得到了第一個隱藏層 h_1 的值。請注意,原始的 2D 向量現(xiàn)在映射到了 3D 空間。

第 2 層 h_2 中發(fā)生了類似的過程。讓我們首先來計算第一個隱藏層的加權(quán)和 z_2,它現(xiàn)在是輸入數(shù)據(jù)。

然后計算它們的 Sigmoid 激活函數(shù)。向量 [0.37166596 0.45414264] 代表的是網(wǎng)絡(luò)對給定的輸入 X 計算出的對數(shù)概率或者預(yù)測向量。

計算整體損失

也被稱為「實(shí)際值減去預(yù)測值」,這個損失函數(shù)的目標(biāo)就是量化預(yù)測向量 h_2 和人工標(biāo)簽 y 之間的距離。

請注意,這個損失函數(shù)包括一個正則項(xiàng),它以嶺回歸的形式懲罰較大的權(quán)重。換言之,平方值比較大的權(quán)重會增大損失函數(shù),而這正是我們希望最小化的指標(biāo)。

反向步驟:

這一步的目標(biāo)就是沿著最小化損失函數(shù)的方向更新神經(jīng)網(wǎng)絡(luò)的權(quán)重。正如我們將要看到的,這是一個遞歸算法,它可以重用之前計算出來的梯度,而且嚴(yán)重依賴微分函數(shù)。因?yàn)檫@些更新減小了損失函數(shù),所以一個神經(jīng)網(wǎng)絡(luò)便「學(xué)會了」去逼近具有已知類別的觀察值的標(biāo)簽。這就是被稱作泛化的一種屬性。

與前向步驟不同的是,這個步驟沿著反向的順序進(jìn)行。它首先計算出輸出層中損失函數(shù)對每個權(quán)重的偏導(dǎo)數(shù) (dLoss/dW_2),然后計算隱藏層的偏導(dǎo)數(shù) (dLoss/dW1)。讓我們詳細(xì)地解釋每個導(dǎo)數(shù)吧。

dLoss/dW_2:

鏈?zhǔn)椒▌t表明,我們可以將一個神經(jīng)網(wǎng)絡(luò)的梯度計算分解成好多個微分部分:

為了幫助記憶,下表列出了上面用到的一些函數(shù)定義以及它們的一階導(dǎo)數(shù):

更直觀地,我們在下圖中要更新權(quán)重 W_2(藍(lán)色部分)。為了做到這件事,我們需要沿著導(dǎo)數(shù)鏈計算三個偏導(dǎo)數(shù)。

將數(shù)值代入到這些偏導(dǎo)數(shù)中,我們就能夠計算出 W_2 的偏導(dǎo)數(shù),如下所示:

結(jié)果是一個 3x2 的矩陣 dLoss/dW_2,它將會沿著最小化損失函數(shù)的方向更新 W_2 的數(shù)值。

dLoss/dW_1:

計算用于更新第一個隱藏層 W_1 權(quán)重的鏈?zhǔn)揭?guī)則就展現(xiàn)了重復(fù)使用已有計算結(jié)果的可能。

更直觀地,從輸出層到權(quán)重 W_1 的路徑會碰到在后面層中早已計算出來的偏導(dǎo)數(shù)。

例如,偏導(dǎo)數(shù) dLoss/dh_2 和 dh_2/dz_2 在上一節(jié)中已經(jīng)被計算為輸出層 dLoss/dW_2 學(xué)習(xí)權(quán)值的依賴項(xiàng)。

將所有的導(dǎo)數(shù)放在一起,我們就能夠再一次執(zhí)行鏈?zhǔn)椒▌t,來為隱藏層的 W_1 更新權(quán)重。

最后,我們給權(quán)重賦予新的數(shù)值,完成了對神經(jīng)網(wǎng)絡(luò)的一步訓(xùn)練。

實(shí)現(xiàn)

讓我們僅使用 numpy 作為線性代數(shù)引擎來將上面的數(shù)學(xué)方程轉(zhuǎn)換成代碼。神經(jīng)網(wǎng)絡(luò)在一個循環(huán)中進(jìn)行訓(xùn)練,其中每次迭代會給神經(jīng)網(wǎng)絡(luò)展示標(biāo)準(zhǔn)的輸入數(shù)據(jù)。在這個小例子中,我們只考慮每次迭代中的整個數(shù)據(jù)集。前向步驟、損失函數(shù)和反向步驟的計算會得到比較好的泛化,因?yàn)槲覀冊诿恳淮窝h(huán)中都用它們對應(yīng)的梯度(矩陣 dL_dw1 和 dL_dw2)來更新可訓(xùn)練的參數(shù)。

代碼保存在這個 repo 中:https://github.com/omar-florez/scratch_mlp

讓我們來運(yùn)行這份代碼!

下面可以看到一些進(jìn)行了好多次迭代訓(xùn)練得到的能夠近似異或函數(shù)的神經(jīng)網(wǎng)絡(luò)。

左圖:準(zhǔn)確率;中間的圖:學(xué)習(xí)到的決策邊界;右圖:損失函數(shù)

首先,我們來看一下隱藏層具有 3 個神經(jīng)元的神經(jīng)網(wǎng)絡(luò)為何能力較弱。這個模型學(xué)會了用一個簡單的決策邊界來進(jìn)行二分類,這個邊界開始是一條直線,但是隨后就表現(xiàn)出了非線性的行為。隨著訓(xùn)練的持續(xù),右圖中的損失函數(shù)也明顯地減小。

隱藏層擁有 50 個神經(jīng)元的神經(jīng)網(wǎng)絡(luò)明顯地增加了模型學(xué)習(xí)復(fù)雜決策邊界的能力。這不僅僅能夠得到更準(zhǔn)確的結(jié)果,而且也使梯度發(fā)生了爆炸,這是訓(xùn)練神經(jīng)網(wǎng)絡(luò)時的一個顯著問題。當(dāng)梯度非常大的時候,反向傳播中的連乘會產(chǎn)生很大的更新權(quán)重。這就是最后幾步訓(xùn)練時損失函數(shù)突然增大的原因(step>90)。損失函數(shù)的正則項(xiàng)計算出了已經(jīng)變得很大的權(quán)重的平方值(sum(W2)/2N)。

正如你所看到的一樣,這個問題可以通過減小學(xué)習(xí)率來避免??梢酝ㄟ^實(shí)現(xiàn)一個能夠隨著時間減小學(xué)習(xí)率的策略來實(shí)現(xiàn)?;蛘咄ㄟ^強(qiáng)制執(zhí)行一個更強(qiáng)的正則化來實(shí)現(xiàn),可能是 L1 或者 L2。梯度消失和梯度爆炸是很有趣的現(xiàn)象,我們后續(xù)會做完整的分析。

原文鏈接:https://medium.com/towards-artificial-intelligence/one-lego-at-a-time-explaining-the-math-of-how-neural-networks-learn-with-implementation-from-scratch-39144a1cf80

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 神經(jīng)網(wǎng)絡(luò)

    關(guān)注

    42

    文章

    4814

    瀏覽量

    103555
  • GitHub
    +關(guān)注

    關(guān)注

    3

    文章

    483

    瀏覽量

    17670

原文標(biāo)題:像堆樂高一樣:從零開始解釋神經(jīng)網(wǎng)絡(luò)的數(shù)學(xué)過程

文章出處:【微信號:tyutcsplab,微信公眾號:智能感知與物聯(lián)網(wǎng)技術(shù)研究所】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    無刷電機(jī)小波神經(jīng)網(wǎng)絡(luò)轉(zhuǎn)子位置檢測方法的研究

    摘要:論文通過對無刷電機(jī)數(shù)學(xué)模型的推導(dǎo),得出轉(zhuǎn)角:與三相相電壓之間存在映射關(guān)系,因此構(gòu)建了一個以三相相電壓為輸人,轉(zhuǎn)角為輸出的小波神經(jīng)網(wǎng)絡(luò)來實(shí)現(xiàn)轉(zhuǎn)角預(yù)測,并采用改進(jìn)遺傳算法來訓(xùn)練網(wǎng)絡(luò)結(jié)
    發(fā)表于 06-25 13:06

    如何優(yōu)化BP神經(jīng)網(wǎng)絡(luò)的學(xué)習(xí)率

    訓(xùn)練過程中發(fā)生震蕩,甚至無法收斂到最優(yōu)解;而過小的學(xué)習(xí)率則會使模型收斂速度緩慢,容易陷入局部最優(yōu)解。因此,正確設(shè)置和調(diào)整學(xué)習(xí)率對于訓(xùn)練高效、準(zhǔn)確的神經(jīng)網(wǎng)絡(luò)模型至關(guān)重要。 二、學(xué)習(xí)率優(yōu)化算法 梯度下降法及其變種 : 標(biāo)準(zhǔn)梯
    的頭像 發(fā)表于 02-12 15:51 ?928次閱讀

    BP神經(jīng)網(wǎng)絡(luò)的優(yōu)缺點(diǎn)分析

    自學(xué)習(xí)能力 : BP神經(jīng)網(wǎng)絡(luò)能夠通過訓(xùn)練數(shù)據(jù)自動調(diào)整網(wǎng)絡(luò)參數(shù),實(shí)現(xiàn)對輸入數(shù)據(jù)的分類、回歸等任務(wù),無需人工進(jìn)行復(fù)雜的特征工程。 泛化能力強(qiáng) : BP神經(jīng)網(wǎng)絡(luò)通過
    的頭像 發(fā)表于 02-12 15:36 ?909次閱讀

    BP神經(jīng)網(wǎng)絡(luò)深度學(xué)習(xí)的關(guān)系

    ),是一種多層前饋神經(jīng)網(wǎng)絡(luò),它通過反向傳播算法進(jìn)行訓(xùn)練。BP神經(jīng)網(wǎng)絡(luò)由輸入層、一個或多個隱藏層和輸出層組成,通過逐層遞減的方式調(diào)整網(wǎng)絡(luò)權(quán)重,目的是最小化
    的頭像 發(fā)表于 02-12 15:15 ?850次閱讀

    如何訓(xùn)練BP神經(jīng)網(wǎng)絡(luò)模型

    BP(Back Propagation)神經(jīng)網(wǎng)絡(luò)是一種經(jīng)典的人工神經(jīng)網(wǎng)絡(luò)模型,其訓(xùn)練過程主要分為兩個階段:前向傳播和反向傳播。以下是訓(xùn)練BP神經(jīng)網(wǎng)絡(luò)
    的頭像 發(fā)表于 02-12 15:10 ?901次閱讀

    深度學(xué)習(xí)入門:簡單神經(jīng)網(wǎng)絡(luò)的構(gòu)建與實(shí)現(xiàn)

    深度學(xué)習(xí)中,神經(jīng)網(wǎng)絡(luò)是核心模型。今天我們用 Python 和 NumPy 構(gòu)建一個簡單的神經(jīng)網(wǎng)絡(luò)神經(jīng)網(wǎng)絡(luò)由多個神經(jīng)元組成,
    的頭像 發(fā)表于 01-23 13:52 ?528次閱讀

    人工神經(jīng)網(wǎng)絡(luò)的原理和多種神經(jīng)網(wǎng)絡(luò)架構(gòu)方法

    所擬合的數(shù)學(xué)模型的形式受到大腦中神經(jīng)元的連接和行為的啟發(fā),最初是為了研究大腦功能而設(shè)計的。然而,數(shù)據(jù)科學(xué)中常用的神經(jīng)網(wǎng)絡(luò)作為大腦模型已經(jīng)過時,現(xiàn)在它們只是能夠在某些應(yīng)用中提供最先進(jìn)性能的機(jī)器學(xué)習(xí)模型。近年來,由于
    的頭像 發(fā)表于 01-09 10:24 ?1180次閱讀
    人工<b class='flag-5'>神經(jīng)網(wǎng)絡(luò)</b>的原理和多種<b class='flag-5'>神經(jīng)網(wǎng)絡(luò)</b>架構(gòu)方法

    卷積神經(jīng)網(wǎng)絡(luò)與傳統(tǒng)神經(jīng)網(wǎng)絡(luò)的比較

    深度學(xué)習(xí)領(lǐng)域,神經(jīng)網(wǎng)絡(luò)模型被廣泛應(yīng)用于各種任務(wù),如圖像識別、自然語言處理和游戲智能等。其中,卷積神經(jīng)網(wǎng)絡(luò)(CNNs)和傳統(tǒng)神經(jīng)網(wǎng)絡(luò)是兩種常見的模型。 1. 結(jié)構(gòu)差異 1.1 傳統(tǒng)
    的頭像 發(fā)表于 11-15 14:53 ?1862次閱讀

    LSTM神經(jīng)網(wǎng)絡(luò)訓(xùn)練數(shù)據(jù)準(zhǔn)備方法

    LSTM(Long Short-Term Memory,長短期記憶)神經(jīng)網(wǎng)絡(luò)訓(xùn)練數(shù)據(jù)準(zhǔn)備方法是一個關(guān)鍵步驟,它直接影響到模型的性能和效果。以下是一些關(guān)于LSTM神經(jīng)網(wǎng)絡(luò)訓(xùn)練數(shù)據(jù)準(zhǔn)備的
    的頭像 發(fā)表于 11-13 10:08 ?2098次閱讀

    關(guān)于卷積神經(jīng)網(wǎng)絡(luò),這些概念你厘清了么~

    必須通過決策閾值做出決定。 另一個區(qū)別是AI并不依賴固定的規(guī)則,而是要經(jīng)過訓(xùn)練。訓(xùn)練過程需要將大量貓的圖像展示給神經(jīng)網(wǎng)絡(luò)以供其學(xué)習(xí)。最終,神經(jīng)網(wǎng)絡(luò)將能夠獨(dú)立識別圖像中是否有貓。關(guān)鍵的一
    發(fā)表于 10-24 13:56

    【飛凌嵌入式OK3576-C開發(fā)板體驗(yàn)】RKNN神經(jīng)網(wǎng)絡(luò)算法開發(fā)環(huán)境搭建

    download_model.sh 腳本,該腳本 將下載一個可用的 YOLOv5 ONNX 模型,并存放在當(dāng)前 model 目錄下,參考命令如下: 安裝COCO數(shù)據(jù)集,在深度神經(jīng)網(wǎng)絡(luò)算法中,模型的訓(xùn)練離不開大量的數(shù)據(jù)集,數(shù)據(jù)
    發(fā)表于 10-10 09:28

    matlab 神經(jīng)網(wǎng)絡(luò) 數(shù)學(xué)建模數(shù)值分析

    matlab神經(jīng)網(wǎng)絡(luò) 數(shù)學(xué)建模數(shù)值分析 精通的可以討論下
    發(fā)表于 09-18 15:14

    FPGA在深度神經(jīng)網(wǎng)絡(luò)中的應(yīng)用

    隨著人工智能技術(shù)的飛速發(fā)展,深度神經(jīng)網(wǎng)絡(luò)(Deep Neural Network, DNN)作為其核心算法之一,在圖像識別、語音識別、自然語言處理等領(lǐng)域取得了顯著成果。然而,傳統(tǒng)的深度神經(jīng)網(wǎng)絡(luò)
    的頭像 發(fā)表于 07-24 10:42 ?1194次閱讀

    如何構(gòu)建多層神經(jīng)網(wǎng)絡(luò)

    構(gòu)建多層神經(jīng)網(wǎng)絡(luò)(MLP, Multi-Layer Perceptron)模型是一個在機(jī)器學(xué)習(xí)和深度學(xué)習(xí)領(lǐng)域廣泛使用的技術(shù),尤其在處理分類和回歸問題時。在本文中,我們將深入探討如何從頭開始構(gòu)建一個多層神經(jīng)網(wǎng)絡(luò)模型,包括模型設(shè)計、
    的頭像 發(fā)表于 07-19 17:19 ?1554次閱讀

    Python自動訓(xùn)練人工神經(jīng)網(wǎng)絡(luò)

    人工神經(jīng)網(wǎng)絡(luò)(ANN)是機(jī)器學(xué)習(xí)中一種重要的模型,它模仿了人腦神經(jīng)元的工作方式,通過多層節(jié)點(diǎn)(神經(jīng)元)之間的連接和權(quán)重調(diào)整來學(xué)習(xí)和解決問題。Python由于其強(qiáng)大的庫支持(如TensorFlow、PyTorch等),成為了實(shí)現(xiàn)和
    的頭像 發(fā)表于 07-19 11:54 ?697次閱讀