抠图

Blue Screen Matting

  • 始祖抠图算法

定义matting问题

I=αF+(1−α)BI=\alpha F+(1-\alpha)B I=αF+(1α)B

  • 假设一张图片由背景(background),前景(foreground),透明度组成。
    • 而透明度也就是RGBA的第4个元素,对于每一个RGB像素都有着对应的A(就是α\alphaα),当然也可以全部的α\alphaα都相等
  • 那么现在的问题就变成了:已知I,求解α,F,B\alpha,F,Bα,F,B的其中两个

条件放松,问题转化

首先有:F是由前景对应的图片和一个纯色背景按照matting公式合成的

  • 从上面的式子可知,要直接求出想要的东西是很难的,所以我们要加一些限制条件

    • 第一种限制形式:假设背景只要一种颜色,我们假定这个是蓝色

      • 这个显然是一个极好的限制条件,这可能也是我们的各种证件照为什么会有限制的底色的原因
      • 既然B只有蓝色,那么显然的我们就可以让前景F没有蓝色了,所以matting后的图片的所有蓝色分量全部来自于B,那么就能求出对应的α\alphaα
    • 第二种限制形式:假设图片是灰度图,也就是说R=G=BR=G=BR=G=B

      • 当然我们可以不用把条件限制的那么禁,如只用R=G即可
    • 第三种限制形式:对于同一个前景目标,在不同的背景下拍摄

      • 当然可以使两张图对应的α\alphaα相同

      • I1=αF+(1−α)B1I2=αF+(1−α)B2I_1 = \alpha F + (1-\alpha)B_1\\ I_2 = \alpha F + (1-\alpha)B_2 I1=αF+(1α)B1I2=αF+(1α)B2

        • 已知I1,I2,B1,B2,求解α,F已知I_1,I_2,B_1,B_2,求解\alpha ,FI1,I2,B1,B2,αF
      • 下面我们简化一下问题: 我们简化一下就是已知背景图BBB

      • 现在已知将问题转化为优化问题

        • I1−I2=(1−α)(B1−B2)当(I1−I2)与(B1−B2)共线的时候才有确定的α所以我们让等式尽可能成立,问题转化成min⁡α∣∣(I1−I2)−(1−α)(B1−B2)∣∣然后就转化成了残差最小问题−−−−>最小二乘法即可I_1 - I_2 = (1-\alpha)(B_1 - B_2)\\ 当(I_1-I_2) 与 (B_1-B_2)共线的时候才有确定的\alpha\\ 所以我们让等式尽可能成立,问题转化成\\ \min_{\alpha} ||(I_1-I_2)-(1-\alpha)(B_1-B_2) ||\\ 然后就转化成了残差最小问题---->最小二乘法即可 I1I2=(1α)(B1B2)(I1I2)(B1B2)线ααmin(I1I2)(1α)(B1B2)>

        • 两种方式:我们可以对整张图片的RGB来做最小二乘,也可以只针对一个小方框来做

Bayes Matting

前要知识

tri-map和scribbles

  • tri-map:三区标注图(标注前景,背景,未知领域)

    img

    • 上图黑白灰分别对应:背景,标注前景,未知领域
  • scribbles:手动粗略地画出前景与背景

  • scripple

  • 上图白色涂前景,黑色涂背景

  • 所以我们只用对上面两种方式的不确定部分建模即可

### 主要内容

  • 我们有F,B,I(已知),αF,B,I(已知),\alphaF,B,I(),α,依据最大后验概率和贝叶斯定理,有
    max⁡F,B,αP(F,B,α∣I)=max⁡F,B,αP(I∣F,B,α)P(F)P(B)P(α)P(I)=max⁡F,B,αL(I∣F,B,α)+L(F)+L(B)+L(α)\max_{F,B,\alpha}P(F,B,\alpha|I)=\\ \max_{F,B,\alpha}\frac{P(I|F,B,\alpha)P(F)P(B)P(\alpha) }{P(I)}=\\ \max_{F,B,\alpha}L(I|F,B,\alpha)+L(F)+L(B)+L(\alpha) F,B,αmaxP(F,B,αI)=F,B,αmaxP(I)P(IF,B,α)P(F)P(B)P(α)=F,B,αmaxL(IF,B,α)+L(F)+L(B)+L(α)

    • L表示取对数
  • 1、求解L(I∣F,B,α)L(I|F,B,\alpha)L(IF,B,α)

    • 假设图像是满足高斯分布的,那有

    L(I∣F,B,α)=−∣∣I−αF−(1−α)B∣∣2/σI2I‾=αF−(1−α)BσI为I的标准差L(I|F,B,\alpha)=-||I-\alpha F-(1-\alpha)B||^2/ {\sigma_I}^2\\ {\overline I }= \alpha F-(1-\alpha)B\\ \sigma_I 为I的标准差 L(IF,B,α)=IαF(1α)B2/σI2I=αF(1α)BσII

  • 2、求解L(F)L(F)L(F)

    • 这一项相当于计算当前点属于前景的概率,所以L(B)L(B)L(B)的求解类似

Closed_form_matting

  • matting问题都是要假设的,该方法最重要的假设如下

    • 在一个小方框w内Ii≈αiF+(1−αi)B(i∈w)⇒αi≈aIi+b(a=1F−B,b=−BF−B)在一个小方框w内\\I_i\approx\alpha_i F+(1-\alpha_i)B\qquad(i\in w)\\ \Rightarrow \alpha_i \approx aI_i+b\qquad (a=\frac{1}{F-B},b=\frac{-B}{F-B}) wIiαiF+(1αi)B(iw)αiaIi+b(a=FB1,b=FBB)

      • 以上≈\approx是假设a和b为常数(或说F和B)引入的

转化成可优化问题

  • 既然已经有上述的等式了,那么下一步显然的就是求loss了
    J(α,a,b)=∑j∈I(∑i∈wj(αi−ajIi−bj)2+εaj2)J(\alpha,a,b)=\sum_{j\in I}(\sum_{i \in w_j}(\alpha_i-a_jI_i-b_j)^2+\varepsilon a_j^2) J(α,a,b)=jI(iwj(αiajIibj)2+εaj2)

    • 后面的ε\varepsilonε是为了正则化的
  • 如果不加思考的话,那么很多人可能就会针对这条式子来优化了,但是该算法的巧妙之处就在于,作者思考怎么消去常数a,b常数a,ba,b,变成只有α\alphaα的优化问题,最后求得α\alphaα的解析解

  • 我们假设第二条式子是某个向量的模的平方,通过观察然后构造

    • 假设当前窗口是3×3的,用背景颜色(Fk,Bk)求得(ak,bk)(F_k,B_k)求得(a_k,b_k)(Fk,Bk)(ak,bk)

    Gk=[I11I21......I99ε0],αk=[α1α2...α90]⇒Gk[akbk]−ak=[I1ak+bk−α1I2ak+bk−α2...I9ak+bk−α9εak]所以,最后有⇒J(α,a,b)=∑k∈I(Gk[akbk]−αk)T(Gk[akbk]−αk)=∑k∈I∥(Gk[akbk]−αk)∥2G_k={\left[\begin{matrix} I_1&1\\ I_2&1\\ .&.\\ .&.\\ .&.\\ I_9&9\\ \sqrt{\varepsilon}&0 \end{matrix}\right]}, \alpha_k={\left[\begin{matrix} \alpha_1\\ \alpha_2\\ .\\ .\\ .\\ \alpha_9\\ 0 \end{matrix}\right]}\\ \Rightarrow G_k\left[\begin{matrix}a_k\\b_k\end{matrix}\right]-a_k=\left[\begin{matrix}I_1a_k+b_k-\alpha_1\\I_2a_k+b_k-\alpha_2 \\...\\I_9a_k+b_k-\alpha_9\\\sqrt{\varepsilon}a_k\end{matrix}\right]\\ 所以,最后有\Rightarrow J(\alpha,a,b)=\sum_{k\in I}(G_k\left[\begin{matrix}a_k\\b_k\end{matrix}\right]-\alpha_k)^T(G_k\left[\begin{matrix}a_k\\b_k\end{matrix}\right]-\alpha_k)=\\\sum_{k\in I}\|(G_k\left[\begin{matrix}a_k\\b_k\end{matrix}\right]-\alpha_k)\|^2\\ Gk=I1I2...I9ε11...90,αk=α1α2...α90Gk[akbk]ak=I1ak+bkα1I2ak+bkα2...I9ak+bkα9εakJ(α,a,b)=kI(Gk[akbk]αk)T(Gk[akbk]αk)=kI(Gk[akbk]αk)2

  • 那么现在的问题就转化成:

    • 1、先对给定的α\alphaαa,ba,ba,b的最小值
    • 2、然后再求对应loss最小的α\alphaα
  • 先针对第一步:我们对ak,bka_k,b_kak,bk求导
    设β=[akbk],α=αkJk=(Gkβ−α)T(Gkβ−α)求导∂Jk∂β=2GkTGkβ−2GkTα=0β∗=[ak∗bk∗]=(GkTGk)−1GkTα(β∗表示最优的β,其他同理)设\beta=\left[\begin{matrix}a_k\\b_k\end{matrix}\right],\alpha=\alpha_k\\ J_k=(G_k\beta-\alpha)^T(G_k\beta-\alpha)\\ 求导\\ \frac{\partial J_k}{\partial \beta}=2G_k^TG_k\beta-2G_k^T\alpha=0\\ \beta^{*}=\left[\begin{matrix}a_k^{*}\\b_k^{*}\end{matrix}\right]=(G_k^TG_k)^{-1}G_k^T\alpha\qquad (\beta^{*}表示最优的\beta,其他同理) β=[akbk],α=αkJk=(Gkβα)T(Gkβα)βJk=2GkTGkβ2GkTα=0β=[akbk]=(GkTGk)1GkTα(ββ)

  • 再针对第二步:
    将β∗代入J(α,a,b)=∑k∈I∥(Gk[akbk]−αk)∥2提取因子α,并设G‾k=I−Gk(GkTGk)−1GkT⇒J(α,a,b)=∑k∈Iαk(GkTGk)αk=∑k∈IαkLαk(L=GkTGk)将\beta^{*}代入\\ J(\alpha,a,b)=\sum_{k \in I}\|(G_k\left[\begin{matrix}a_k\\b_k\end{matrix}\right]-\alpha_k)\|^2\\ 提取因子\alpha,并设\overline G_k=I-G_k(G_k^TG_k)^{-1}G_k^T\\ \Rightarrow J(\alpha,a,b)=\sum_{k \in I}\alpha_k(G_k^TG_k)\alpha_k=\sum_{k \in I}\alpha_kL\alpha_k\qquad(L=G_k^TG_k) βJ(α,a,b)=kI(Gk[akbk]αk)2αGk=IGk(GkTGk)1GkTJ(α,a,b)=kIαk(GkTGk)αk=kIαkLαk(L=GkTGk)

    • 我们可以发现上面的GkG_kGk和正则化的拉普拉斯矩阵的形式是一样的,然后人们把L称为matting Laplace Matrix,在后续的抠图算法中,L是个很重要的矩阵

    • Li,j=δi,j−1∣wk∣(1+1ε∣wk∣+σk2(Ii−μk)(Ij−μk))δ是克罗内克函数(当i=j时为1,其余为0)μ和σ分别是均值和方差,∣wk∣是窗口内像素的个数L_{i,j}=\delta_{i,j}-\frac{1}{|w_k|}(1+\frac{1}{\frac{\varepsilon}{|w_k|}+\sigma_k^2}(I_i-\mu_k)(I_j-\mu_k))\\ \delta 是克罗内克函数(当i=j时为1,其余为0)\\\mu和\sigma分别是均值和方差,|w_k|是窗口内像素的个数 Li,j=δi,jwk1(1+wkε+σk21(Iiμk)(Ijμk))δi=j10μσwk

加上用户交互的限制(以scribbles为例)

  • scribbles上,我们的限制可以构造成,如果涂了色那么就有对应的贡献

  • 然后就变成了有约束的极值问题了–>拉格朗日乘子法

    • α=argminLoss=argmin(αTLα+λ(αT−bsT)Ds(α−bs))Ds是对角矩阵,对角上有值的元素对应scribbles上涂色的点,设涂色为1,未涂为0bs是与α维度相同的列向量,涂色点上对应αi的值,其余为0继续求导∂Loss∂α=2Lα+2λDs(α−bs)所以α∗=λ(L+λDs)−1Dsbs=λ(L+λDs)−1bs\alpha=argmin\text{ } Loss=argmin\text{ } (\alpha^TL\alpha+\lambda(\alpha^T-b_s^T)D_s(\alpha-b_s))\\ D_s是对角矩阵,对角上有值的元素对应scribbles上涂色的点,\\设涂色为1,未涂为0\\ b_s是与\alpha维度相同的列向量,涂色点上对应\alpha_i的值,其余为0\\ 继续求导\\ \frac{\partial Loss}{\partial \alpha}=2L\alpha+2\lambda D_s(\alpha-b_s)\\ 所以\alpha^{*}=\lambda(L+\lambda D_s)^{-1}D_sb_s=\lambda(L+\lambda D_s)^{-1}b_s α=argmin Loss=argmin (αTLα+λ(αTbsT)Ds(αbs))Dsscribbles10bsααi0αLoss=2Lα+2λDs(αbs)α=λ(L+λDs)1Dsbs=λ(L+λDs)1bs

    • 由于计算量大,所以λ\lambdaλ不训练,而是提前设定好一个值(事实证明,λ\lambdaλ的值在一定范围内影响不了多少)

对彩色图:color line model(两色线模型)

  • 上文的方法显然是基于灰度图的,所以需要每个通道都算一次,而且效果不一定好(因为要满足一个小方框内的三元向量(R,G,B)保持线性,这个约束太强)

  • 所以我们加一个假设条件,假设:一个小方框内,背景和前景的值都是近似位于一条直线上的
    {Fi=βiFF1+(1−βiF)F2Bi=βiBB1+(1−βiB)B2\begin{cases} F_i=\beta_i^FF_1+(1-\beta_i^F)F_2\\ B_i=\beta_i^BB_1+(1-\beta_i^B)B_2\\ \end{cases} {Fi=βiFF1+(1βiF)F2Bi=βiBB1+(1βiB)B2

    • F1,F2,B1,B2F_1,F_2,B_1,B_2F1,F2,B1,B2分别对应着前景和背景的颜色向量(表示的一个线段的两个端点),β\betaβ表示基于这两个端点的插值斜率
  • 则最后能推到

    • αi≈∑c∈(R,G,B)acIic+b⇒αi=aTIi+b(a=[aRaGaB])\alpha_i \approx\sum_{c \in \text{(R,G,B)}}a^cI_i^c+b\\ \Rightarrow\alpha_i=a^TI_i+b\qquad(a=\left[\begin{matrix}a^R\\a^G\\a^B\end{matrix}\right]) αic(R,G,B)acIic+bαi=aTIi+b(a=aRaGaB)

推导证明

  • 虽然上面的结论看起来很有道理,可能不用说你都知道,但是我们还是给出一番证明

将Fi.Bi的式子代入Ii=αiFi+(1−αi)BiIi=αi(βiFF1+(1−βiF)F2)+(1−αi)(βiBB1+(1−βiB)B2)我们把式子转化成类似Blue Screen Matting中的式子I1−I2=(1−α)(B1−B2)所以有⇒Ii−B2=H⋅[αiαiβiF(1−αi)βiB](H=[F2−B2,F1−F2,B1−B2])将F_i.B_i的式子代入I_i=\alpha_iF_i+(1-\alpha_i)B_i\\ I_i=\alpha_i(\beta_i^FF_1+(1-\beta_i^F)F_2)+(1-\alpha_i)(\beta_i^BB_1+(1-\beta_i^B)B_2)\\ 我们把式子转化成类似\text{Blue Screen Matting}中的式子\\ I_1 - I_2 = (1-\alpha)(B_1 - B_2)\\ 所以有\Rightarrow I_i-B_2=H\cdot \left[\begin{matrix}\alpha_i\\\alpha^i\beta_i^F\\(1-\alpha_i)\beta_i^B\end{matrix}\right]\\(H=[F_2-B_2,F_1-F_2,B_1-B_2]) Fi.BiIi=αiFi+(1αi)BiIi=αi(βiFF1+(1βiF)F2)+(1αi)(βiBB1+(1βiB)B2)Blue Screen MattingI1I2=(1α)(B1B2)IiB2=HαiαiβiF(1αi)βiB(H=[F2B2,F1F2,B1B2])

  • 然后我们就把问题转化成了一个线性方程组
    设x1=αi,x2=αiβiF,x3=(1−αi)βiB所以H⋅[x1x2x3]=Ii−B2设\qquad x_1=\alpha_i,x_2=\alpha^i\beta_i^F,x_3=(1-\alpha_i)\beta_i^B\\ 所以H\cdot \left[\begin{matrix}x_1\\x_2\\x_3\end{matrix}\right]=I_i-B_2 x1=αi,x2=αiβiF,x3=(1αi)βiBHx1x2x3=IiB2

    • 那么我们求出线性方程组后的第一行的元素就是答案,所以把H−1H^{-1}H1乘过去

      • [x1x2x3]=H−1⋅(Ii−B2)\left[\begin{matrix}x_1\\x_2\\x_3\end{matrix}\right]=H^{-1}\cdot (I_i-B_2) x1x2x3=H1(IiB2)

      • 所以,x1x_1x1的值只和H−1H^{-1}H1的第一行元素有关,我们提取出来就能得到形为x1=αi=aTIi+bx_1=\alpha_i=a^TI_i+bx1=αi=aTIi+b的式子

得到新的Matting Laplace Matrix

  • 将上述公式代入此模型重新推导后得到

    • Li,j=∑(i,j)∈wk[δi,j1∣wk∣(1+(Ii−μk)T(∑k+ϵ∣wk∣I3)−1(Ii−μk))]L_{i,j}=\sum_{(i,j)\in w_k}[\delta_{i,j}\frac{1}{|w_k|}(1+(I_i-\mu_k)^T(\sum_k + \frac{\epsilon}{|w_k|}I_3)^{-1}(I_i-\mu_k))] Li,j=(i,j)wk[δi,jwk1(1+(Iiμk)T(k+wkϵI3)1(Iiμk))]
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. C# WinForm 强大的图形控件ScottPlot

    C# WinForm 强大的图形控件ScottPlot 最近公司业务需要,要进行音频采集和图谱分析,网上找了各种资料,进行了一下对比,最终采用了ScottPlot这个图形控件进行开发。 内容很简单,就是把采集的音频信号进行算法分析展示到…...

    2024/4/30 15:31:07
  2. Hive将时间格式转为时间戳函数

    SELECT unix_timestamp(substr(time,1,19),‘yyyy-MM-dd HH:mm:ss’)*1000substr(time,21,3),write_time from tableA 原始时间格式:2020-09-15 10:35:33:841 转换后时间戳:1600137333841...

    2024/4/27 5:24:13
  3. 英语报纸

    ...

    2024/4/7 11:18:49
  4. SDL编程入门(1)Hello SDL

    Hello SDL 你的第一个图形窗口 所以你学会了C的基础知识,但你厌倦了制作基于文本的小程序。为了使用诸如图形、声音、键盘、操纵杆等东西,你需要一个API(应用程序员接口),将所有这些硬件功能转化为C可以交互的东西。 …...

    2024/5/2 21:59:14
  5. JavaScript对象模型

    BOM(浏览器对象模型) -BOM提供了很多对象,用于访问浏览器的功能 -BOM将浏览器中的各个部分转换成了一个一个的对象,我们通过修改这些对象的属性,调用他们的方法,从而控制浏览器的各种行为 -BOM缺少规范。由…...

    2024/4/22 6:11:11
  6. 9、OpenCV 画矩形 —— cv.rectangle()

    1、格式: rectangle(img, pt1, pt2, color[, thickness[, lineType[, shift]]]) 2、功能 在图像 img 上,以两点 pt1, pt2 为对角点,画一个颜色为 color 的空心或实心直角矩形 3、输入 img:要在上面画矩形的图像pt1&#xff1…...

    2024/4/22 8:29:50
  7. 鸿蒙开发资料下载

    第二章 资料下载方法 2.1百度网盘使用教程 2.1.1 使用简介 注册百度盘帐号 a) 注册百度账号(https://pan.baidu.com/); b) 也许现在还可以免费获赠大空间,在手机上下载百度网盘APP、登录试试;转存文件到自己的网盘 a) 在电脑上&#xff0c…...

    2024/4/7 11:18:45
  8. MySQL中时间使用

    1.时间类型如下 类型大小(字节)范围格式用途DATE31000-01-01/9999-12-31YYYY-MM-DD日期值TIME3-838:59:59/838:59:59HH:MM:SS时间值或持续时间YEAR11901/2155YYYY年份值DATETIME81000-01-01 00:00:00/9999-12-31 23:59:59YYYY-MM-DD HH:MM:SS混合日期和时间值TIMESTAMP4 1970…...

    2024/4/28 15:09:51
  9. leetcode:1380. 矩阵中的幸运数

    给你一个 m * n 的矩阵&#xff0c;矩阵中的数字 各不相同 。请你按 任意 顺序返回矩阵中的所有幸运数。 幸运数是指矩阵中满足同时下列两个条件的元素&#xff1a; 在同一行的所有元素中最小 在同一列的所有元素中最大 class Solution {public List<Integer> luckyNum…...

    2024/4/25 13:50:11
  10. JSON的格式类型到底有哪些呢?

    JSON的格式类型到底有哪些呢&#xff1f; JSON是目前最流行的一种数据交换格式&#xff0c;对于它我们有必要非常熟悉它的各方面知识&#xff0c;这次我们来看看它的格式类型有哪些。 数据交换格式方式 基本类型数组类型对象嵌套 案例实操 基本类型 {“键” : 值, “键”…...

    2024/4/12 0:12:00
  11. 隐马尔科夫模型(HMM)学习小记

    隐马尔科夫模型(HMM) 基于时序的概率模型 定义 Q[q1,q2...,qN]是所有可能的状态集合V[v1,v2...vM]是所有目标集合I[i1,i2...iT]表示长度为T的状态序列O[o1,o2...oT]表示长度为T的观测序列概率转移矩阵A[aij]nnaijP(it1qj∣itqi)(在t时刻)观测概率矩阵B[bj(k)]NMbj(k)P(otvk∣…...

    2024/4/29 9:31:36
  12. Android的UI适配总结

    1几种ui适配方案分析 2同一张图放在不同drawable下区别...

    2024/4/23 7:29:40
  13. 系统集成项目管理工程师第2章信息系统集成及服务管理-历年真题+解析(第4期)

    1、信息技术服务标准(ITSS)定义了IT服务的核心要素由人员、过程、技术和资源组成。( )要素关注“正确做事”。 A、人员 B、过程 C、技术 D、资源 2、一般公认信息系统审计原则不包括( )。 A、ISACA公告 B、ISACA公告职业准则 C、ISACA职业道德规范 D、COBIT框架 3、信息…...

    2024/4/24 21:47:41
  14. C#把字符串截取成数组并不要空字符

    string str “AAA,BBB,CCC,DDD,EEE”; string[] strTemp str.Split(new string[] { “,” }, StringSplitOptions.RemoveEmptyEntries);...

    2024/4/7 11:18:38
  15. cookie中不能有空格

    做cookie的demo时&#xff0c;加入时间戳 new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");这里报了个错&#xff0c;如下 java.lang.IllegalArgumentException: An invalid character [32] was present in the Cookie value报错中说一个无效字符[32]在cookie中&…...

    2024/4/26 2:34:02
  16. CentOS7.x [Errno 256] No more mirrors to try

    解决方案如下&#xff1a; 1.清理软件源 $ yum clean all 2.建立源数据缓存 $ yum makecache...

    2024/4/27 3:51:51
  17. 《Precision Event Coreference Resolution Using Neural Network Classifiers》阅读笔记

    这篇文章研究的问题是篇章内和跨篇章的事件共指消解任务。如下图所示&#xff0c;本文使用的模型由简单的两层前馈神经网络softmax层组成。其输入特征由三部分组成&#xff1a; &#xff08;1&#xff09;event mention 1的特征向量&#xff1a;embeddings of the event word&…...

    2024/4/26 19:42:18
  18. 支持向量机(SVM)学习小记

    支持向量机(SVM) 简介 是一种二分类模型&#xff0c;基本模型的定义是在特征空间上的间隔最大的线性分类器间隔最大有利于感知学习策略&#xff1a; 间隔最大化&#xff0c;可以形式化为一个求解凸二次规划问题&#xff0c;也等价于正则化的合页损失函数的最小化问题 线性可…...

    2024/4/28 1:48:03
  19. DEDE副栏目|织梦CMS取消9个副栏目的数量限制

    使用dede建站&#xff0c;用到织梦副栏目且数量较多时&#xff0c;会发现一篇文章的副栏目选择最大数量被限制为9个&#xff0c;即一篇文档最多只能同时属于9个副栏目和一个主栏目&#xff0c;下面就来分享下织梦CMS取消副栏目数量限制的修改方法。 找到并打开 /dede/js/main.j…...

    2024/4/21 22:57:36
  20. Ubuntu安装QQ与微信

    Ubuntu1804安装QQ与微信 本人安装参考连接&#xff0c;确实成功了写的很好很详细&#xff1a; Ubuntu18.04 安装QQ、Tim、微信与win无差异_欢迎访问我的个人博客 https://plushine.cn-CSDN博客 如果出现中文字体显示方框问题&#xff1a; 系统默认语言从英文改为中文即可解决…...

    2024/4/7 10:39:59

最新文章

  1. 使用 Langchain、Langfuse、Nemo-gaurdrails、RAGAs构建 RAG 管道并进行监控和评估

    原文地址:build-end-to-end-rag-pipeline-with-monitoring-and-evaluation-using-langchain-azure-ai-search 2024 年 4 月 21 日 介绍 使用现代的LLM框架,如Langchain或llamaindex,可以迅速搭建一个用于 RAG 的管道,通常只需编写大约5-6行代码。然而,若要构建一个适用于生…...

    2024/5/2 23:45:48
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 安卓java打包uniapp原生插件 和 uniapp使用安卓android原生插件

    1.uniapp dcloud官方文档 简介 | uni小程序SDK 2.前提&#xff0c;需要有经验的安卓java开发人员&#xff0c;并且同时具备uniapp移动端开发经验。说明&#xff1a;android打包的.aar和uniapp需要的.aar是不一样的&#xff0c;uniapp需要的.aar是需要有一些特定配置的&#x…...

    2024/5/1 10:20:40
  4. 01背包问题 小明的背包

    2.小明的背包1 - 蓝桥云课 (lanqiao.cn) #include <bits/stdc.h> using namespace std; const int N1010;//开始写的105 开小了 样例过了但最后只过了很少一部分 int n,m; int v[N],w[N]; int f[N][N];int main() {cin>>n>>m;for(int i1;i<n;i){cin>&…...

    2024/4/30 7:25:11
  5. JVM学习笔记

    文章目录 一、内存模型1. 程序计数器2. 栈3. 本地方法栈4. 堆5. 方法区方法区位置字符串常量池位置 6. 直接内存 二、虚拟机参数设置三、类的生命周期1. 加载2. 连接1&#xff09;验证2&#xff09;准备3&#xff09;解析 3. 初始化4. 卸载 四、类加载器1. 启动类加载器2. 扩展…...

    2024/5/1 13:33:02
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/2 11:19:01
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/2 16:04:58
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/1 21:18:12
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/2 9:47:31
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/2 9:47:31
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/2 6:03:07
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/2 9:47:30
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/2 23:47:43
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/2 5:31:39
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/1 20:22:59
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/2 9:47:28
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/2 9:47:27
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/2 0:07:22
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/2 8:37:00
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/2 9:47:26
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/2 9:47:25
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/2 23:47:16
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/2 18:46:52
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/2 7:30:11
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/1 20:56:20
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57