分形网络(FractalNet)----学习笔记

  1. 这个网络的提出是为了证明residual对于极深的网络并不是必须的。
  2. 通过一种分形的结构,达到了teacher-student机制,深度监督的效果。
  3. Fractal :分形,从多个层次、多个角度、多个组成成分来共同解决一个问题
  4. 通过多个不同深度的网络的组合提高模型的效果:浅层提供更迅速的回答,深层提供更准确的回答
  5. 网络架构中每一个Fractal的模块,是由多个浅层和深层的联合而成,层的深度呈2的指数型增长。不同深度的输出进行联合时采用求均值的方式。因为每个联合层的输入的个数可能不同,求均值可以起到一个类似于归一化的效果。
  6. 架构更重要的训练学习机制:drop path
    1. dropout:一般用于使神经元随机失活来减少模型的过拟合
    2. droppath:让路径随机失活,即在多个不同深度的层进行联合时,模型会以一个比例随机地让某些路径的输入关闭,但最少保证有一个输入。
    3. 优点:
      1. 减少过拟合
      2. 强化每条路径的输出
      3. 不同路径的联合。在droppath机制下,与teacher-student类似的效果:如果某条路径学到了对最终分类非常重要的特征,如果在某一次迭代中该路径被关闭了,则通过loss进行反向传播时,可能就会指导和该路径进行联合的另一条路径也学习到这种特征。如此不断训练不仅可提高整个模型的效果,而且单独提取出任意一条路径使用也可达到非常好的效果。并且该网络架构不同因为深度加深而出现退化问题,即从整个模型中提取出最深的路径使用可以到达整个fractalnet接近的效果。
    4. 有两种droppath方式:
      1. local:在每一个联合层以固定几率舍弃每个输入,但保证至少保留一个输入
      2. global:在整个网络中随机只保留一条完整的路径进行学习
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 绘制花草树木的分可以使用L-system方法,L-system是一种基于字符串替换的方法,用于生成自相似的状。以下是使用octave绘制分花草树木的步骤: 1.定义L-system规则 首先,我们需要定义L-system规则。这里我们使用以下规则: - A → B[+A][-A],表示从A开始,向前移动1个单位,转向右侧,绘制B,然后向左转,绘制A的左子代,向右转,绘制A的右子代。 - B → BB,表示将B替换为两个B。 2.生成L-system字符串 接下来,我们使用octave生成指定迭代次数的L-system字符串。例如,我们可以使用以下代码生成迭代2次的字符串: ```octave n = 2; axiom = 'A'; rules = {'A', 'B[+A][-A]', 'B', 'BB'}; lsystem = axiom; for i = 1:n lsystem = strrep(lsystem, rules{1}, rules{2}); lsystem = strrep(lsystem, rules{3}, rules{4}); end disp(lsystem); ``` 输出结果为:`B[+B[+B][-B]][-B[+B][-B]]` 3.解析L-system字符串 接下来,我们需要解析L-system字符串,并根据规则绘制花草树木。我们可以使用以下代码实现: ```octave n = 2; axiom = 'A'; rules = {'A', 'B[+A][-A]', 'B', 'BB'}; lsystem = axiom; for i = 1:n lsystem = strrep(lsystem, rules{1}, rules{2}); lsystem = strrep(lsystem, rules{3}, rules{4}); end disp(lsystem); angle = 25; step = 10; stack = []; pos = [0, 0]; dir = [0, -1]; for i = 1:length(lsystem) switch lsystem(i) case 'F' pos = pos + step * dir; plot([pos(1) pos(1)-step*dir(1)], [pos(2) pos(2)-step*dir(2)], 'k'); case '+' dir = [dir(1)*cosd(angle) - dir(2)*sind(angle), dir(1)*sind(angle) + dir(2)*cosd(angle)]; case '-' dir = [dir(1)*cosd(-angle) - dir(2)*sind(-angle), dir(1)*sind(-angle) + dir(2)*cosd(-angle)]; case '[' stack = [stack; pos dir]; case ']' last = stack(end, :); pos = last(1:2); dir = last(3:4); stack = stack(1:end-1, :); end end ``` 这段代码将生成迭代2次的花草树木分,使用plot函数绘制线条。其中,F表示向前移动一定距离,+表示向右转一定角度,-表示向左转一定角度,[表示保存当前位置和方向,]表示回到最近的[位置,并将方向恢复为之前的方向。 4.调整参数 最后,我们可以调整angle和step参数来改变分状。例如,我们可以将angle设为30,step设为5,生成迭代3次的花草树木分: ```octave n = 3; axiom = 'A'; rules = {'A', 'B[+A][-A]', 'B', 'BB'}; lsystem = axiom; for i = 1:n lsystem = strrep(lsystem, rules{1}, rules{2}); lsystem = strrep(lsystem, rules{3}, rules{4}); end disp(lsystem); angle = 30; step = 5; stack = []; pos = [0, 0]; dir = [0, -1]; for i = 1:length(lsystem) switch lsystem(i) case 'F' pos = pos + step * dir; plot([pos(1) pos(1)-step*dir(1)], [pos(2) pos(2)-step*dir(2)], 'k'); case '+' dir = [dir(1)*cosd(angle) - dir(2)*sind(angle), dir(1)*sind(angle) + dir(2)*cosd(angle)]; case '-' dir = [dir(1)*cosd(-angle) - dir(2)*sind(-angle), dir(1)*sind(-angle) + dir(2)*cosd(-angle)]; case '[' stack = [stack; pos dir]; case ']' last = stack(end, :); pos = last(1:2); dir = last(3:4); stack = stack(1:end-1, :); end end ``` 运行以上代码,将生成迭代3次的花草树木分。 ### 回答2: 要利用Octave绘制花草树木的分,可以使用L-系统(L-system)来生成这些状。L-系统是一种式语法系统,它可以通过迭代规则生成自相似的结构。 首先,我们需要定义一些规则来生成花草树木的状。以下是一个例子: 1. 定义“F”为向前移动一定距离的指令 2. 定义“+”为顺时针旋转的指令 3. 定义“-”为逆时针旋转的指令 4. 定义“[”为保存当前状态的指令 5. 定义“]”为恢复到之前保存的状态的指令 6. 定义“X”为删除的指令(即不绘制线段) 接下来,我们可以创建一个递归函数,该函数将根据这些规则以及一些参数绘制出花草树木的状。以下是一个例子: ```octave function drawTree(length, angle, generations, axiom) if generations == 0 return; endif nextGeneration = ''; for i = 1:length(axiom) currentChar = axiom(i); if currentChar == 'X' nextGeneration = [nextGeneration, currentChar]; elseif currentChar == 'F' line([0, 0], [0, length]); translate([0, length]); elseif currentChar == '+' rotate(angle); elseif currentChar == '-' rotate(-angle); elseif currentChar == '[' saveState(); elseif currentChar == ']' restoreState(); endif endfor drawTree(length * 0.6, angle, generations - 1, nextGeneration); endfunction ``` 通过调用这个函数,我们可以绘制出花草树木的分。例如,以下是一个绘制二叉树的示例: ```octave clf; hold on; drawTree(100, pi/4, 9, 'X'); ``` 使用这些规则和参数,您可以根据自己的需要绘制出各种不同状的花草树木分图。调整绘制函数中的参数以及规则定义,您可以创建出独特的花草树木图。 ### 回答3: 利用Octave绘制花草树木分可以通过递归的方式实现。以下是一种常见的方法: 首先,我们需要确定绘制花草树木所需的参数,如树的高度、分支角度、分支长度和分支的减小比例等。 接下来,我们可以定义一个递归函数,用于在每个分支的末端绘制一个更小分支。该函数可能接受参数,如当前分支的起点坐标、当前分支的角度、当前分支的长度等。 在递归函数中,我们可以绘制当前分支,并计算出下一个分支的起点坐标、角度和长度。然后,我们可以调用递归函数,并将下一个分支的信息作为参数传入,以绘制更小的分支。 我们可以通过迭代调用递归函数,绘制出一个完整的花草树木状。 在Octave中,我们可以使用plot函数进行绘图。我们可以定义一个函数来实现花草树木的绘制,然后在主程序中调用该函数。 最后,我们可以调整绘图窗口的大小、添加坐标轴和标题等元素,以美化我们的花草树木分。 通过上述步骤,我们可以在Octave中使用递归函数和plot函数来绘制花草树木分。这种方法允许我们根据定义的参数来创建不同状的花草树木,并在绘图窗口中进行显示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值