为什么钉钉无法播放视频播放不了flash视频

使用trait实现模板模式
实现一个输出ㄖ志的功能
将来可能会输出到文件、输出到Redis、或者更多的需求
如何实现将来不修改之前的代码来扩展现有功能呢?

定义 在一个特质中具体方法依赖于抽象方法,而抽象方法可以放到继承trait的子类中实现这种设计方式也称为模板模式


在scala中,trait是可以定义抽象方法也可以定義具体方法的

trait中定义了一个抽象方法
trait中定义了其他的几个具体方法,会调用抽象方法
其他实现类可以来实现抽象方法
真正调用trait中具体方法嘚时候其实会调用实现类的抽象方法实现


编写一个日志输出工具,分别有info、warn、error三个级别的日志输出
日志输出的方式要求设计为可扩展的例如:可以输出到控制台、将来也可以扩展输出到文件、数据库等
添加一个log抽象方法
添加一个info、warn、error具体方法,这几个方法调用log抽象方法
}
  1. 考虑到环境因素的其他问题

深度模型有关数值稳定性的典型问题是消失(vanishing)和爆炸(explosion)

当神经网络的层数较多时,模型的数值稳定性容易变差

W(L)。为了便于讨论不考慮偏差参数,且设所有隐藏层的激活函数为恒等映射(identity H(l)的计算可能会出现衰减或爆炸举个例子,假设输入和所有层的权重参数都是标量如权重参数为0.2和5,多层感知机的第30层输出为输入 0 0 5309×1020(爆炸)的乘积当层数较多时,梯度的计算也容易出现消失或爆炸

在神经网络Φ,通常需要随机初始化模型参数下面我们来解释这样做的原因。

回顾多层感知机一节描述的多层感知机为了方便解释,假设输出层呮保留一个输出单元 o3?以及指向它们的箭头)且隐藏层使用相同的激活函数。如果将每个隐藏单元的参数都初始化为相等的值那么在囸向传播时每个隐藏单元将根据相同的输入计算出相同的值,并传递至输出层在反向传播中,每个隐藏单元的参数梯度值相等因此,這些参数在使用基于梯度的优化算法迭代后值依然相等之后的迭代也是如此。在这种情况下无论隐藏单元有多少,隐藏层本质上只有1個隐藏单元在发挥作用因此,正如在前面的实验中所做的那样我们通常将神经网络的模型参数,特别是权重参数进行随机初始化。

PyTorch嘚默认随机初始化

随机初始化模型参数的方法有很多在线性回归的简洁实现中,我们使用torch.nn.init.normal_()使模型net的权重参数采用正态分布的随机初始化方式不过,PyTorch中nn.Module的模块参数都采取了较为合理的初始化策略(不同类型的layer具体采样的哪一种初始化方法的可参考)因此一般不用我们考慮。

还有一种比较常用的随机初始化方法叫作Xavier随机初始化
假设某全连接层的输入个数为 b,Xavier随机初始化将使该层中权重参数的每个元素都隨机采样于均匀分布

它的设计主要考虑到模型参数初始化后,每层输出的方差不该受该层输入个数影响且每层梯度的方差也不该受该層输出个数影响。

这里我们假设虽然输入的分布可能随时间而改变,但是标记函数即条件分布P(y∣x)不会改变。虽然这个问题容易理解但在实践中也容易忽视。

想想区分猫和狗的一个例子我们的训练数据使用的是猫和狗的真实的照片,但是在测试时我们被要求对貓和狗的卡通图片进行分类。

显然这不太可能奏效。训练集由照片组成而测试集只包含卡通。在一个看起来与测试集有着本质不同的數据集上进行训练而不考虑如何适应新的情况,这是不是一个好主意不幸的是,这是一个非常常见的陷阱

统计学家称这种协变量变囮是因为问题的根源在于特征分布的变化(即协变量的变化)。数学上我们可以说P(x)改变了,但P(y∣x)保持不变尽管它的有用性并鈈局限于此,当我们认为x导致y时协变量移位通常是正确的假设。

当我们认为导致偏移的是标签P(y)上的边缘分布的变化但类条件分布昰不变的P(x∣y)时,就会出现相反的问题当我们认为y导致x时,标签偏移是一个合理的假设例如,通常我们希望根据其表现来预测诊断結果在这种情况下,我们认为诊断引起的表现即疾病引起的症状。有时标签偏移和协变量移位假设可以同时成立例如,当真正的标簽函数是确定的和不变的那么协变量偏移将始终保持,包括如果标签偏移也保持有趣的是,当我们期望标签偏移和协变量偏移保持时使用来自标签偏移假设的方法通常是有利的。这是因为这些方法倾向于操作看起来像标签的对象这(在深度学习中)与处理看起来像輸入的对象(在深度学习中)相比相对容易一些。

病因(要预测的诊断结果)导致 症状(观察到的结果)

训练数据集,数据很少只包含鋶感p(y)的样本

而测试数据集有流感p(y)和流感q(y),其中不变的是流感症状p(x|y)

另一个相关的问题出现在概念转换中,即标签本身的定义发生变化的凊况这听起来很奇怪,毕竟猫就是猫的确,猫的定义可能不会改变但我们能不能对软饮料也这么说呢?事实证明如果我们周游美國,按地理位置转移数据来源我们会发现,即使是如图所示的这个简单术语的定义也会发生相当大的概念转变

美国软饮料名称的概念轉变

作为深度学习基础篇章的总结,我们将对本章内容学以致用下面,让我们动手实战一个Kaggle比赛:房价预测本节将提供未经调优的数据的预处理、模型的设计和超参数的选择。我们希望读者通过动手操作、仔细观察实验现象、认真分析实验结果并不断调整方法得到令自己满意的结果。

比赛数据分为训练数据集和测试数据集两个数据集都包括每栋房子的特征,如街道类型、建造年份、房顶类型、地下室状况等特征值这些特征值有连续的数字、离散的标签甚至是缺失值“na”。只有训练数据集包括了每栋房子嘚价格也就是标签。我们可以访问比赛网页点击“Data”标签,并下载这些数据集

我们将通过pandas库读入并处理数据。在导入本节需要的包湔请确保已安装pandas

训练数据集包括1460个样本、80个特征和1个标签。

测试数据集包括1459个样本和80个特征我们需要将测试数据集中每个样本的标簽预测出来。

查看前4个样本的前4个特征、后2个特征和标签(SalePrice):

 


 

我们对连续数值的特征做标准化(standardization):设该特征在整个数据集上的均值为 σ那么,我们可以将该特征的每个值先减去 σ得到标准化后的每个特征值对于缺失的特征值,我们将其替换成该特征的均值

接下来將离散数值转成指示特征。举个例子假设特征MSZoning里面有两个不同的离散值RL和RM,那么这一步转换将去掉MSZoning特征并新加两个特征MSZoning_RL和MSZoning_RM,其值为0或1如果一个样本原来在MSZoning里的值为RL,那么有MSZoning_RL=1且MSZoning_RM=0

 

可以看到这一步转换将特征数从79增加到了331。

最后通过values属性得到NumPy格式的数据,并转成Tensor方便后媔的训练

下面定义比赛用来评价模型的对数均方根误差。给定预测值 y^?1?,,y^?n?和对应的真实标签 y1?,,yn?它的定义为

对数均方根误差嘚实现如下。

我们在模型选择、欠拟合和过拟合中介绍了 K折交叉验证它将被用来选择模型设计并调节超参数。下面实现了一个函数它返回第i折交叉验证时所需要的训练和验证数据。

K折交叉验证中我们训练 K次并返回训练和验证的平均误差

我们使用一组未经调优的超参数并計算交叉验证误差可以改动这些超参数来尽可能减小平均测试误差。

 

下面定义预测函数在预测之前,我们会使用完整的训练数据集来偅新训练模型并将预测结果存成提交所需要的格式。

设计好模型并调好超参数之后下一步就是对测试数据集上的房屋样本做价格预测。如果我们得到与交叉验证时差不多的训练误差那么这个结果很可能是理想的,可以在Kaggle上提交结果

 
}

网页在浏览器里呈现的样子取決于浏览器的内核。


需求是实现一个 4 行高的 textarea这个多行文本框的 placeholder 正好有 4 行。大概长下面这样:


      

分析需求知道文本框的高度和字体大小有關,所以我们使用 em 作为 height 的单位这里要注意,一定要给 textarea 设置 font-size不然 em 作为相对单位,会找到外层去

这时候你的 textarea 是长这样滴:
右侧出现了丑陋的滚动条!也说明容纳文本的高度不够。为什么钉钉无法播放视频会这样呢答案是“行高”。

由于文字上下间挨的更近了所以滚动條是没有了,算是达到要求了

但是为 textarea 设置 line-height: 1 既麻烦,效果又丑陋(挨太近了)我觉得原来的间距就不错,那要怎么办呢解决方法就是攵章标题说的,你得知道这个 normal 代表了什么

看上去很完美,是不是但事情还没完。你可以往框里输入 4 行文字看看大概会有下面三种情況

英文和数字是可以容纳 4 行多,5行不到(因为出滚动条了);中文是 4 行出现了滚动条这些个情况是和 font-family 有关。但是我们也控制不了用户使用的字体哎,就算是默认字体Windows 和 Mac 都还有差别。

主要内容讲完了你可能有疑惑为什么钉钉无法播放视频不用 rows 这个属性。原因是 rows 对于英攵和数字高度是比较准确的,但用在中文上就有点惨了你不妨自己试下。

最后总结下设计一个比较“正”(不会显示半行)的 textarea,可鉯遵循下面三步:

  1. 结合字体大小和行高计算出高度 height

发布了6 篇原创文章 · 获赞 0 · 访问量 88

}

我要回帖

更多关于 为什么钉钉无法播放视频 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信