色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

PyTorch教程-5.4. 數(shù)值穩(wěn)定性和初始化

jf_pJlTbmA9 ? 來(lái)源:PyTorch ? 作者:PyTorch ? 2023-06-05 15:43 ? 次閱讀

到目前為止,我們實(shí)現(xiàn)的每個(gè)模型都需要我們根據(jù)一些預(yù)先指定的分布來(lái)初始化它的參數(shù)。直到現(xiàn)在,我們都認(rèn)為初始化方案是理所當(dāng)然的,掩蓋了如何做出這些選擇的細(xì)節(jié)。您甚至可能覺得這些選擇并不是特別重要。相反,初始化方案的選擇在神經(jīng)網(wǎng)絡(luò)學(xué)習(xí)中起著重要作用,對(duì)于保持?jǐn)?shù)值穩(wěn)定性至關(guān)重要。此外,這些選擇可以以有趣的方式與非線性激活函數(shù)的選擇聯(lián)系起來(lái)。我們選擇哪個(gè)函數(shù)以及我們?nèi)绾纬跏蓟瘏?shù)可以決定我們的優(yōu)化算法收斂的速度。這里的錯(cuò)誤選擇可能會(huì)導(dǎo)致我們?cè)谟?xùn)練時(shí)遇到梯度爆炸或消失的情況。在這個(gè)部分,

%matplotlib inline
import torch
from d2l import torch as d2l

%matplotlib inline
from mxnet import autograd, np, npx
from d2l import mxnet as d2l

npx.set_np()

%matplotlib inline
import jax
from jax import grad
from jax import numpy as jnp
from jax import vmap
from d2l import jax as d2l

No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)

%matplotlib inline
import tensorflow as tf
from d2l import tensorflow as d2l

5.4.1. 消失和爆炸梯度

考慮一個(gè)深度網(wǎng)絡(luò)L圖層,輸入x 和輸出o. 每層l由轉(zhuǎn)換定義fl權(quán)重參數(shù)化 W(l), 隱藏層輸出為 h(l)(讓h(0)=x),我們的網(wǎng)絡(luò)可以表示為:

(5.4.1)h(l)=fl(h(l?1))and thuso=fL°…°f1(x).

如果所有隱藏層的輸出和輸入都是向量,我們可以寫出梯度為o關(guān)于任何一組參數(shù) W(l)如下:

(5.4.2)?W(l)o=?h(L?1)h(L)?M(L)=def?…??h(l)h(l+1)?M(l+1)=def?W(l)h(l)?v(l)=def.

換句話說(shuō),這個(gè)梯度是L?l矩陣 M(L)?…?M(l+1)和梯度向量v(l). 因此,當(dāng)將太多概率相乘時(shí),我們很容易遇到同樣的數(shù)值下溢問題。在處理概率時(shí),一個(gè)常見的技巧是切換到對(duì)數(shù)空間,即將壓力從尾數(shù)轉(zhuǎn)移到數(shù)值表示的指數(shù)。不幸的是,我們上面的問題更嚴(yán)重:最初矩陣 M(l)可能有各種各樣的特征值。它們可能很小或很大,它們的產(chǎn)品可能很大或 很小。

不穩(wěn)定梯度帶來(lái)的風(fēng)險(xiǎn)超出了數(shù)值表示。不可預(yù)測(cè)的梯度也會(huì)威脅到我們優(yōu)化算法的穩(wěn)定性。我們可能面臨以下參數(shù)更新:(i) 過大,破壞了我們的模型( 梯度爆炸問題);或 (ii) 過小(梯度消失問題),由于參數(shù)幾乎不會(huì)在每次更新時(shí)移動(dòng),因此無(wú)法進(jìn)行學(xué)習(xí)。

5.4.1.1。消失的漸變

導(dǎo)致梯度消失問題的一個(gè)常見罪魁禍?zhǔn)资羌せ詈瘮?shù)的選擇σ在每一層的線性操作之后附加。從歷史上看,sigmoid 函數(shù)1/(1+exp?(?x))(在第 5.1 節(jié)中介紹)很受歡迎,因?yàn)樗愃朴陂撝岛瘮?shù)。由于早期的人工神經(jīng)網(wǎng)絡(luò)受到生物神經(jīng)網(wǎng)絡(luò)的啟發(fā),神經(jīng)元要么完全放電要么根本不放電(就像生物神經(jīng)元一樣)的想法似乎很有吸引力。讓我們仔細(xì)看看 sigmoid,看看它為什么會(huì)導(dǎo)致梯度消失。

x = torch.arange(-8.0, 8.0, 0.1, requires_grad=True)
y = torch.sigmoid(x)
y.backward(torch.ones_like(x))

d2l.plot(x.detach().numpy(), [y.detach().numpy(), x.grad.numpy()],
     legend=['sigmoid', 'gradient'], figsize=(4.5, 2.5))

poYBAGR9NLSAaUiRAAD4Yy-HP94664.svg

x = np.arange(-8.0, 8.0, 0.1)
x.attach_grad()
with autograd.record():
  y = npx.sigmoid(x)
y.backward()

d2l.plot(x, [y, x.grad], legend=['sigmoid', 'gradient'], figsize=(4.5, 2.5))

[07:15:48] src/base.cc:49: GPU context requested, but no GPUs found.

pYYBAGR9NLaAQR30AAD4Yx6sDr0480.svg

x = jnp.arange(-8.0, 8.0, 0.1)
y = jax.nn.sigmoid(x)
grad_sigmoid = vmap(grad(jax.nn.sigmoid))
d2l.plot(x, [y, grad_sigmoid(x)],
     legend=['sigmoid', 'gradient'], figsize=(4.5, 2.5))

poYBAGR9NLiAG47UAAD4Wfwoe20706.svg

x = tf.Variable(tf.range(-8.0, 8.0, 0.1))
with tf.GradientTape() as t:
  y = tf.nn.sigmoid(x)
d2l.plot(x.numpy(), [y.numpy(), t.gradient(y, x).numpy()],
     legend=['sigmoid', 'gradient'], figsize=(4.5, 2.5))

poYBAGR9NLuAGHgVAAD4Xi6uXEc210.svg

如您所見,S 形函數(shù)的梯度在其輸入較大和較小時(shí)都消失了。此外,當(dāng)通過多層反向傳播時(shí),除非我們處于 Goldilocks 區(qū),其中許多 sigmoid 的輸入接近于零,否則整個(gè)產(chǎn)品的梯度可能會(huì)消失。當(dāng)我們的網(wǎng)絡(luò)擁有很多層時(shí),除非我們小心,否則梯度可能會(huì)在某一層被切斷。事實(shí)上,這個(gè)問題曾經(jīng)困擾著深度網(wǎng)絡(luò)訓(xùn)練。因此,更穩(wěn)定(但在神經(jīng)上不太可信)的 ReLU 已成為從業(yè)者的默認(rèn)選擇。

5.4.1.2. 爆炸梯度

相反的問題,當(dāng)梯度爆炸時(shí),可能同樣令人煩惱。為了更好地說(shuō)明這一點(diǎn),我們繪制了 100 個(gè)高斯隨機(jī)矩陣并將它們與某個(gè)初始矩陣相乘。對(duì)于我們選擇的尺度(方差的選擇σ2=1), 矩陣乘積爆炸。當(dāng)由于深度網(wǎng)絡(luò)的初始化而發(fā)生這種情況時(shí),我們沒有機(jī)會(huì)讓梯度下降優(yōu)化器收斂。

M = torch.normal(0, 1, size=(4, 4))
print('a single matrix n',M)
for i in range(100):
  M = M @ torch.normal(0, 1, size=(4, 4))
print('after multiplying 100 matricesn', M)

a single matrix
 tensor([[ 0.0837, -0.9784, -0.5752, -0.0418],
    [ 2.0032, 2.0948, -1.4284, -1.5950],
    [-0.9720, -2.1672, -0.2809, 0.2282],
    [-0.7581, 0.0328, -0.2364, -0.5804]])
after multiplying 100 matrices
 tensor([[ 7.5119e+24, -9.2313e+24, -2.1761e+24, 7.0456e+23],
    [-1.3462e+24, 1.6544e+24, 3.8999e+23, -1.2627e+23],
    [ 1.4648e+25, -1.8001e+25, -4.2433e+24, 1.3739e+24],
    [ 8.9242e+24, -1.0967e+25, -2.5852e+24, 8.3702e+23]])

M = np.random.normal(size=(4, 4))
print('a single matrix', M)
for i in range(100):
  M = np.dot(M, np.random.normal(size=(4, 4)))
print('after multiplying 100 matrices', M)

a single matrix [[ 2.2122064  1.1630787  0.7740038  0.4838046 ]
 [ 1.0434403  0.29956347 1.1839255  0.15302546]
 [ 1.8917114 -1.1688148 -1.2347414  1.5580711 ]
 [-1.771029  -0.5459446 -0.45138445 -2.3556297 ]]
after multiplying 100 matrices [[ 3.4459747e+23 -7.8040759e+23 5.9973355e+23 4.5230040e+23]
 [ 2.5275059e+23 -5.7240258e+23 4.3988419e+23 3.3174704e+23]
 [ 1.3731275e+24 -3.1097129e+24 2.3897754e+24 1.8022945e+24]
 [-4.4951091e+23 1.0180045e+24 -7.8232368e+23 -5.9000419e+23]]

get_key = lambda: jax.random.PRNGKey(d2l.get_seed()) # Generate PRNG keys
M = jax.random.normal(get_key(), (4, 4))
print('a single matrix n', M)
for i in range(100):
  M = jnp.matmul(M, jax.random.normal(get_key(), (4, 4)))
print('after multiplying 100 matricesn', M)

a single matrix
 [[-1.531857  -1.6248469 -1.7896363  0.01071274]
 [-0.83422506 -1.583117  -0.04581776 -0.6887173 ]
 [ 0.5935193 -1.4750035  0.5265016 -1.0061077 ]
 [-0.6028679 -0.3464505  1.1737709 -1.3659075 ]]
after multiplying 100 matrices
 [[-2.7093967e+25 6.4777160e+24 -1.1368576e+25 -7.9616848e+25]
 [ 9.1084851e+24 -2.1776870e+24 3.8219019e+24 2.6765695e+25]
 [ 2.6918674e+25 -6.4358044e+24 1.1295020e+25 7.9101732e+25]
 [ 3.1859349e+25 -7.6170382e+24 1.3368117e+25 9.3620141e+25]]

M = tf.random.normal((4, 4))
print('a single matrix n', M)
for i in range(100):
  M = tf.matmul(M, tf.random.normal((4, 4)))
print('after multiplying 100 matricesn', M.numpy())

a single matrix
 tf.Tensor(
[[ 0.6401031 -0.30267003 -1.2595664 -0.09789732]
 [-1.7108601  0.5364894 -0.02595425 0.32053235]
 [-0.40997565 -0.6582443 -0.7346871  1.9668812 ]
 [ 0.16821837 -0.41409513 -0.5977446 -0.38071403]], shape=(4, 4), dtype=float32)
after multiplying 100 matrices
 [[1.5536073e+21 5.0625842e+21 2.7629899e+21 3.1974600e+21]
 [6.6411150e+20 2.1640736e+21 1.1810791e+21 1.3667998e+21]
 [3.0877614e+21 1.0061778e+22 5.4913826e+21 6.3548842e+21]
 [3.9506273e+20 1.2873513e+21 7.0259335e+20 8.1307368e+20]]

5.4.1.3. 打破對(duì)稱

神經(jīng)網(wǎng)絡(luò)設(shè)計(jì)中的另一個(gè)問題是其參數(shù)化中固有的對(duì)稱性。假設(shè)我們有一個(gè)帶有一個(gè)隱藏層和兩個(gè)單元的簡(jiǎn)單 MLP。在這種情況下,我們可以置換權(quán)重 W(1)第一層的權(quán)重,同樣置換輸出層的權(quán)重以獲得相同的函數(shù)。第一個(gè)隱藏單元與第二個(gè)隱藏單元沒有什么特別的區(qū)別。換句話說(shuō),我們?cè)诿恳粚拥碾[藏單元之間具有排列對(duì)稱性。

這不僅僅是理論上的麻煩。考慮前面提到的具有兩個(gè)隱藏單元的單隱藏層 MLP。為了說(shuō)明,假設(shè)輸出層將兩個(gè)隱藏單元轉(zhuǎn)換為僅一個(gè)輸出單元。想象一下,如果我們將隱藏層的所有參數(shù)初始化為 W(1)=c對(duì)于一些常數(shù)c. 在這種情況下,在前向傳播過程中,任一隱藏單元采用相同的輸入和參數(shù),產(chǎn)生相同的激活,并將其饋送到輸出單元。在反向傳播期間,根據(jù)參數(shù)區(qū)分輸出單元W(1)給出一個(gè)梯度,其元素都取相同的值. 因此,在基于梯度的迭代(例如,小批量隨機(jī)梯度下降)之后, W(1)仍然取相同的值。這樣的迭代永遠(yuǎn)不會(huì)自行破壞對(duì)稱性,我們可能永遠(yuǎn)無(wú)法實(shí)現(xiàn)網(wǎng)絡(luò)的表達(dá)能力。隱藏層的行為就好像它只有一個(gè)單元。請(qǐng)注意,雖然小批量隨機(jī)梯度下降不會(huì)破壞這種對(duì)稱性,但 dropout 正則化(稍后介紹)會(huì)!

5.4.2. 參數(shù)初始化

解決或至少減輕上述問題的一種方法是通過仔細(xì)初始化。正如我們稍后將看到的,在優(yōu)化和適當(dāng)?shù)恼齽t化過程中額外注意可以進(jìn)一步提高穩(wěn)定性。

5.4.2.1. 默認(rèn)初始化

在前面的部分中,例如,在第 3.5 節(jié)中,我們使用正態(tài)分布來(lái)初始化我們的權(quán)重值。如果我們不指定初始化方法,框架將使用默認(rèn)的隨機(jī)初始化方法,這在實(shí)踐中通常適用于中等規(guī)模的問題。

5.4.2.2. 澤維爾初始化

讓我們看一下輸出的尺度分布o(jì)i對(duì)于一些沒有非線性的完全連接層。和 nin輸入xj及其相關(guān)權(quán)重 wij對(duì)于這一層,輸出由下式給出

(5.4.3)oi=∑j=1ninwijxj.

權(quán)重wij都是從同一個(gè)分布中獨(dú)立抽取的。此外,我們假設(shè)此分布的均值和方差為零σ2. 請(qǐng)注意,這并不意味著分布必須是高斯分布,只是意味著均值和方差需要存在。現(xiàn)在,我們假設(shè)層的輸入 xj也有零均值和方差γ2并且它們獨(dú)立于wij并且相互獨(dú)立。在這種情況下,我們可以計(jì)算的均值和方差oi如下:

(5.4.4)E[oi]=∑j=1ninE[wijxj]=∑j=1ninE[wij]E[xj]=0,Var[oi]=E[oi2]?(E[oi])2=∑j=1ninE[wij2xj2]?0=∑j=1ninE[wij2]E[xj2]=ninσ2γ2.

保持方差固定的一種方法是設(shè)置 ninσ2=1. 現(xiàn)在考慮反向傳播。我們面臨著類似的問題,盡管梯度是從更靠近輸出的層傳播的。使用與前向傳播相同的推理,我們看到梯度的方差會(huì)爆炸,除非 noutσ2=1, 在哪里nout是這一層的輸出個(gè)數(shù)。這讓我們進(jìn)退兩難:我們不可能同時(shí)滿足這兩個(gè)條件。相反,我們只是嘗試滿足:

(5.4.5)12(nin+nout)σ2=1or equivalentlyσ=2nin+nout.

這就是現(xiàn)在標(biāo)準(zhǔn)且實(shí)際有益的Xavier 初始化背后的推理,以其創(chuàng)建者的第一作者命名(Glorot 和 Bengio,2010)。通常,Xavier 初始化從具有零均值和方差的高斯分布中采樣權(quán)重 σ2=2nin+nout. 當(dāng)從均勻分布中采樣權(quán)重時(shí),我們也可以調(diào)整它來(lái)選擇方差。注意均勻分布U(?a,a)有方差a23. 堵漏a23進(jìn)入我們的條件σ2產(chǎn)生根據(jù)初始化的建議

(5.4.6)U(?6nin+nout,6nin+nout).

盡管在神經(jīng)網(wǎng)絡(luò)中很容易違反上述數(shù)學(xué)推理中不存在非線性的假設(shè),但 Xavier 初始化方法在實(shí)踐中表現(xiàn)良好。

5.4.2.3. 超過

上面的推理僅僅觸及了現(xiàn)代參數(shù)初始化方法的皮毛。深度學(xué)習(xí)框架通常會(huì)實(shí)施十幾種不同的啟發(fā)式方法。此外,參數(shù)初始化仍然是深度學(xué)習(xí)基礎(chǔ)研究的熱點(diǎn)領(lǐng)域。其中包括專門用于綁定(共享)參數(shù)、超分辨率、序列模型和其他情況的啟發(fā)式方法。例如, 肖等人。( 2018 )通過使用精心設(shè)計(jì)的初始化方法證明了在沒有架構(gòu)技巧的情況下訓(xùn)練 10000 層神經(jīng)網(wǎng)絡(luò)的可能性。

如果您對(duì)該主題感興趣,我們建議您深入研究該模塊的內(nèi)容,閱讀提出和分析每個(gè)啟發(fā)式的論文,然后探索有關(guān)該主題的最新出版物。也許您會(huì)偶然發(fā)現(xiàn)甚至發(fā)明一個(gè)聰明的想法并為深度學(xué)習(xí)框架貢獻(xiàn)一個(gè)實(shí)現(xiàn)。

5.4.3. 概括

梯度消失和爆炸是深度網(wǎng)絡(luò)中的常見問題。需要非常小心地進(jìn)行參數(shù)初始化,以確保梯度和參數(shù)得到很好的控制。需要初始化啟發(fā)式方法來(lái)確保初始梯度既不過大也不過小。隨機(jī)初始化是確保優(yōu)化前對(duì)稱性被破壞的關(guān)鍵。Xavier 初始化表明,對(duì)于每一層,任何輸出的方差都不受輸入數(shù)量的影響,并且任何梯度的方差都不受輸出數(shù)量的影響。ReLU 激活函數(shù)減輕了梯度消失問題。這可以加速收斂。

5.4.4. 練習(xí)

除了 MLP 層中的置換對(duì)稱性之外,您能否設(shè)計(jì)神經(jīng)網(wǎng)絡(luò)可能表現(xiàn)出需要破壞的對(duì)稱性的其他情況?

我們能否將線性回歸或 softmax 回歸中的所有權(quán)重參數(shù)初始化為相同的值?

查找兩個(gè)矩陣乘積的特征值的解析界限。這告訴您有關(guān)確保梯度條件良好的什么信息

如果我們知道某些術(shù)語(yǔ)存在分歧,我們能否在事后解決這個(gè)問題?查看有關(guān)分層自適應(yīng)速率縮放的論文以獲取靈感 (You等人,2017 年)。

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

    關(guān)注

    2

    文章

    808

    瀏覽量

    13233
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    字符型、指針型等變量該如何初始化

    在敲代碼的時(shí)候,我們會(huì)給變量一個(gè)初始值,以防止因?yàn)榫幾g器的原因造成變量初始值的不確定性。對(duì)于數(shù)值類型的變量往往初始化為0,但對(duì)于其他類型的變
    發(fā)表于 09-23 11:50 ?2188次閱讀

    產(chǎn)品程序運(yùn)行穩(wěn)定性問題:假如HSE初始化失敗,需要做哪些事情?

    下面幾點(diǎn)涉及到產(chǎn)品程序穩(wěn)定性,請(qǐng)教一下大神們1、假如HSE初始化失敗,需要做哪些事情?(重啟芯片?將時(shí)鐘配置HSI?或者其他?) if(HSE 成功) {....... } else
    發(fā)表于 01-04 09:27

    喂狗(重載計(jì)數(shù)值)初始化流程

    這里寫代碼片IWDG_Initializes();//初始化IWDG_ReloadCounter();//喂狗(重載計(jì)數(shù)值)初始化流程:void IWDG_Initializes(void){IWDG_Enable();//使能
    發(fā)表于 08-02 07:37

    手機(jī)模塊初始化向?qū)?/a>

    手機(jī)模塊初始化向?qū)?為了剛好的對(duì)手機(jī)模塊進(jìn)行初始化,所以把最基本的向?qū)懴聛?lái).本向?qū)нm用于本公司的西門子TC35I和華為GT9000模塊。一、在初始化手機(jī)模塊前,請(qǐng)先確定DT
    發(fā)表于 09-18 09:41 ?17次下載

    電感的穩(wěn)定性

    電感的穩(wěn)定性 穩(wěn)定性是表示電感線圈參數(shù)隨環(huán)境條件變化而改變的程度。通常用電感溫度系數(shù)αL 來(lái)評(píng)定線圈的穩(wěn)定程度,它表示電感量相對(duì)淚度的穩(wěn)定
    發(fā)表于 08-22 14:33 ?1563次閱讀

    RDA1846S初始化設(shè)置

    RDA1846S初始化設(shè)置RDA1846S初始化設(shè)置RDA1846S初始化設(shè)置
    發(fā)表于 01-15 17:08 ?0次下載

    UCOS_III_配置與初始化

    UCOS_III_配置與初始化
    發(fā)表于 12-20 22:53 ?5次下載

    電力系統(tǒng)暫態(tài)穩(wěn)定性快速數(shù)值計(jì)算方法

    為滿足電力系統(tǒng)暫態(tài)穩(wěn)定性實(shí)時(shí)分析計(jì)算的需求,將邊界值類方法中的廣義向后差分方法應(yīng)用于暫態(tài)穩(wěn)定性數(shù)值計(jì)算,提出了一種新的暫態(tài)穩(wěn)定性快速數(shù)值計(jì)算
    發(fā)表于 03-01 15:05 ?1次下載

    在51平臺(tái)下初始化文件的引入導(dǎo)致全局變量無(wú)法初始化的問題如何解決

    本文檔的主要內(nèi)容詳細(xì)介紹的是在51平臺(tái)下初始化文件的引入導(dǎo)致全局變量無(wú)法初始化的問題如何解決。
    發(fā)表于 08-20 17:31 ?0次下載
    在51平臺(tái)下<b class='flag-5'>初始化</b>文件的引入導(dǎo)致全局變量無(wú)法<b class='flag-5'>初始化</b>的問題如何解決

    PyTorch教程5.4數(shù)值穩(wěn)定性初始化

    電子發(fā)燒友網(wǎng)站提供《PyTorch教程5.4數(shù)值穩(wěn)定性初始化.pdf》資料免費(fèi)下載
    發(fā)表于 06-05 15:30 ?0次下載
    <b class='flag-5'>PyTorch</b>教程<b class='flag-5'>5.4</b>之<b class='flag-5'>數(shù)值</b><b class='flag-5'>穩(wěn)定性</b>和<b class='flag-5'>初始化</b>

    PyTorch教程6.4之惰性初始化

    電子發(fā)燒友網(wǎng)站提供《PyTorch教程6.4之惰性初始化.pdf》資料免費(fèi)下載
    發(fā)表于 06-05 11:52 ?0次下載
    <b class='flag-5'>PyTorch</b>教程6.4之惰性<b class='flag-5'>初始化</b>

    怎么分析電路的穩(wěn)定性

    怎么分析電路的穩(wěn)定性?? 電路的穩(wěn)定性是指電路在不同條件下保持穩(wěn)定的能力。穩(wěn)定性是電路設(shè)計(jì)中十分重要的一個(gè)方面,因?yàn)?b class='flag-5'>穩(wěn)定的電路能夠提供可靠和
    的頭像 發(fā)表于 09-17 16:44 ?1983次閱讀

    字符型、指針型等變量等該如何初始化

     對(duì)于數(shù)值類型的變量往往初始化為0,但對(duì)于其他類型的變量,如字符型、指針型等變量等該如何初始化呢?
    的頭像 發(fā)表于 03-18 11:02 ?1492次閱讀

    質(zhì)量視角下的系統(tǒng)穩(wěn)定性保障--穩(wěn)定性保障常態(tài)自動(dòng)實(shí)踐

    常態(tài)穩(wěn)定性治理。在常態(tài)治理過程中我們將識(shí)別問題等重復(fù)性有規(guī)律的工作實(shí)現(xiàn)自動(dòng),技術(shù)人員更專注于解決問題。 二、穩(wěn)定性治理常態(tài)
    的頭像 發(fā)表于 11-19 11:19 ?407次閱讀
    質(zhì)量視角下的系統(tǒng)<b class='flag-5'>穩(wěn)定性</b>保障--<b class='flag-5'>穩(wěn)定性</b>保障常態(tài)<b class='flag-5'>化</b>自動(dòng)<b class='flag-5'>化</b>實(shí)踐

    STM32F407 MCU使用SD NAND?不斷電初始化失效解決方案

    STM32F407微控制器單元(MCU)與SD NAND的結(jié)合提供了強(qiáng)大的存儲(chǔ)解決方案。然而,不斷電初始化失效問題可能會(huì)導(dǎo)致系統(tǒng)穩(wěn)定性和數(shù)據(jù)完整性受損。我們將STM32F407與SD NAND集成時(shí)可能遇到的初始化問題,并提供專
    的頭像 發(fā)表于 12-11 10:51 ?342次閱讀
    STM32F407 MCU使用SD NAND?不斷電<b class='flag-5'>初始化</b>失效解決方案
    主站蜘蛛池模板: 亚洲中文字幕在线精品| 色偷偷7777www| 免费观看的毛片| 亚洲精品久久99蜜芽尤物TV| gay台湾无套男同志xnxⅹ| 久久999视频| 亚洲 日韩 国产 制服 在线| rio 快播| 久久综合香蕉久久久久久久| 亚洲va在线va天堂XX xX| 国产成人精品自拍| 日本色呦呦| 一本道久在线综合色姐| 国精产品999一区二区三区有限| 日韩中文字幕欧美在线视频| JEALOUSVUE成熟老师APP| 免费被靠视频动漫| 99视频这里只有精品| 男人扒开添女人下部口述| 2017日日干| 欧美18videosex| 超碰在线视频人人AV| 日本漫画无彩翼漫画| 俄罗斯破处| 亚州AV人片一区二区三区99久| 国产精品内射久久久久欢欢| 午夜影院c绿象| 狠日狠干日曰射| 在线少女漫画| 欧美日韩亚洲综合2019| 超级乱淫片午夜电影网99| 欧美一区二区视频在线观看 | 饥渴的护士自慰被发现| 亚洲免费三区| 龙广在线收听| www亚洲欲色成人久久精品| 三级全黄的视频在线观看| 国产精品人妻在线观看| 亚洲国产AV精品卡一卡二| 久久99re热在线播放7| 91极品蜜桃臀在线播放|