- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这是我尝试使用 numpy 和线性代数进行线性回归的尝试:
def linear_function(w , x , b):
return np.dot(w , x) + b
x = np.array([[1, 1,1],[0, 0,0]])
y = np.array([0,1])
w = np.random.uniform(-1,1,(1 , 3))
print(w)
learning_rate = .0001
xT = x.T
yT = y.T
for i in range(30000):
h_of_x = linear_function(w , xT , 1)
loss = h_of_x - yT
if i % 10000 == 0:
print(loss , w)
w = w + np.multiply(-learning_rate , loss)
linear_function(w , x , 1)
这会导致错误:
ValueError Traceback (most recent call last)
<ipython-input-137-130a39956c7f> in <module>()
24 if i % 10000 == 0:
25 print(loss , w)
---> 26 w = w + np.multiply(-learning_rate , loss)
27
28 linear_function(w , x , 1)
ValueError: operands could not be broadcast together with shapes (1,3) (1,2)
这似乎适用于降低训练集维度:
import numpy as np
def linear_function(w , x , b):
return np.dot(w , x) + b
x = np.array([[1, 1],[0, 0]])
y = np.array([0,1])
w = np.random.uniform(-1,1,(1 , 2))
print(w)
learning_rate = .0001
xT = x.T
yT = y.T
for i in range(30000):
h_of_x = linear_function(w , xT , 1)
loss = h_of_x - yT
if i % 10000 == 0:
print(loss , w)
w = w + np.multiply(-learning_rate , loss)
linear_function(w , x , 1)
print(linear_function(w , x[0] , 1))
print(linear_function(w , x[1] , 1))
哪个返回:
[[ 0.68255806 -0.49717912]]
[[ 1.18537894 0. ]] [[ 0.68255806 -0.49717912]]
[[ 0.43605474 0. ]] [[-0.06676614 -0.49717912]]
[[ 0.16040755 0. ]] [[-0.34241333 -0.49717912]]
[ 0.05900769]
[ 1.]
[ 0.05900769] & [ 1.]
接近训练示例,因此看来此实现是正确的。抛出错误的实现有什么问题?我没有正确实现 2 -> 3 的维度扩展?
最佳答案
我列出了以下问题:
您的数组形状不一致。这可能会导致广播/点出现问题,尤其是在梯度下降期间。修复您的初始化。我还建议使用 b
扩充 w
并使用一列 1 扩充 X
。
我觉得你的损失函数和梯度计算不正确。一般来说,不推荐使用曼哈顿距离作为损失函数,因为它不是一个足够的距离度量。我会使用欧氏距离并尝试最小化平方和(这称为 OLS regression )。然后,我们按如下方式进行梯度计算。
您的更新规则将根据 (2) 相应更改。
确保为您的代码设置停止条件。您不想超过最佳值。通常,当梯度变化不大时就应该停止。
完整列表:
# input, augmented
x = np.array([[1, 1, 1], [0, 0, 0]])
x = np.column_stack((np.ones(len(x)), x))
# predictions
y = np.array([[0, 1]])
# weights, augmented with bias
w = np.random.uniform(-1, 1, (1, 4))
learning_rate = .0001
loss_old = np.inf
for i in range(30000):
h_of_x = w.dot(x.T)
loss = ((h_of_x - y) ** 2).sum()
if abs(loss_old - loss) < 1e-5:
break
w = w - learning_rate * (h_of_x - y).dot(x)
loss_old = loss
其他建议/改进
接下来,考虑这里正则化的使用。 L1 (ridge) 和 L2 (lasso) 都是不错的选择。
最后,线性回归有一个封闭形式的解决方案,保证收敛于局部最优(梯度下降只保证局部最优)。这很快,但计算量大(因为它涉及计算逆)。查看权衡 here .
w = y.dot(np.linalg.inv(x.dot(x.T)).dot(x))
当 xT.x 不可逆时,您需要进行正则化。
请记住,线性回归只能为线性决策边界建模。如果您确信您的实现是正确的,并且您的损失仍然很严重,则您的数据可能不适用于其当前的向量空间,因此您将需要非线性基函数来转换它(这实际上是非线性的回归)。
关于python - 矢量化线性回归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50156643/
我正在尝试将字符串列表转换为字符向量的向量: import collection.breakOut def stringsToCharVectors(xs: List[String]) = x
我正在尝试使用 Pytorch 通过 2D 向量(嘈杂语音帧序列)的回归来预测 1D 向量(干净语音数据帧) data) - 之前已经完成过。帧序列为帧提供时间上下文,以更准确地预测干净帧。这些向量可
在尝试构建时,我收到此错误: Operator '+=' is ambiguous on operands of type 'Vector3' and 'Vector2' 这是问题出处的脚本代码: u
是否存在实现 FIFO 意义上的循环数组或向量的 R 包? 假设我们有这个数组: 2 4 7 1 当在位置 1 插入一个新的观察值(比如 3)时,我希望第 n 个元素被第 n-1 个元素替换: 3 2
我在游戏中有两个对象,为此可以将其视为 2d 平面上的点,但我使用 Vector3s,因为游戏本身是 3d。 我有一个游戏相机,我想将其与两个物体垂直(也在平面上)对齐,以便它们都在相机的视野中。由于
我做了一个Telegram robot ,它的工作之一是从音频文件创建样本。现在对于发送给它的大多数音频,样本都非常好;像这样: 但是,对于一些音频,样本看起来有点奇怪: 如您所见,此文件中的波形未显
由于对 JavaScript 非常陌生,我在使用 JQuery VectorMaps 时遇到了以下问题: 当我用这种语法突出显示一个国家时,一切都很完美: jQuery('#vmap').vector
我正在使用 ChartJS 在我的网站中包含一些 map ,但 ChartJS 库没有我想要的 map 。 我想知道这种类型的矢量 map 是否很容易在网上免费找到,还是必须从头开始构建? Chart
我需要创建一个函数。在此范围内,我需要发生以下事情: List 1: '(a 5 6) List 2: '(c 8 10) List 3: '(d 4 9) 以上是列表。我需要忽略每个列表的第一列(这
我在地球表面有一个点,我正在将其从地球中心转换为向量。 我有一个以度数表示的真北航向,描述了该点将在地球表面行进的路径。 我需要计算一个向量,该向量垂直于该点沿地球表面的路径所创建的平面。 我尝试
大家好,这是我的 JavaScript 代码,用于为矢量 map 制作 ip 标记以显示在线 ip.. 所有 ips 都有 3 个不同的端口,例如:ip1:1020 或 ip2:5050 或 ip3:
我正在使用 Three.js 透视相机,我需要了解相机所注视的点。 如何使用相机的矩阵/旋转向量计算它? 最佳答案 相机向下看它的内部负 z 轴。所以选择相机负 z 轴上的任意点,如下所示: var
重要提示:请注意这个问题是关于 VECTOR map 的。不是高度图。 我正在尝试在 Scenekit 中实现 Vector 位移,如 apple 演示文稿中所述: https://www.youtu
我正在处理一个稳定增长的语料库。我使用用 Python 实现的 Doc2Vec 来训练我的文档向量。 是否可以更新文档向量? 我想使用文档向量进行文档推荐。 最佳答案 单个向量可以更新,但是 gens
我正在努力寻找一种比较(测量)两个不同信号之间相似性的好方法。我不想找出一个信号到另一个信号的时间延迟,但我想看看它们之间有何相似之处。例如,我有以下两个信号,比如说 s1 ans s2。这两个信号看
我想绘制 y 与 x 线,然后在它上面我想绘制向量。我可以使用 matplotlib 的 plot 和 quiver 函数来做到这一点。但是,矢量将始终绘制在线的后面,而不是在线的顶部。也就是说,线将
包含复数的向量 a 的大小为 N×1。任务是找到乘法a * a^HA (N-by-N) >,其中 H 是 Hermitian 算子(共轭转置),因此矩阵 A 是 Hermitian。 有没有比 O(N
三天来,我一直在努力从我的响应中获取复杂类型(列表),但总是收到 ClassCastException D/SOAPEnvelope(1552): Error: java.lang.ClassCast
在我的 android 项目中,我想要离线 map 。使用图 block ,我的 map 占用 500 MB 的空间,我还想在 map 上离线搜索地址。我认为减小尺寸并使搜索成为可能的唯一方法是矢量
什么是 Android Compose 方法来平铺图像以用小图案填充我的背景? 没有旋转的位图的天真方法可能是这样的: @Composable fun TileImage() { val pa
我是一名优秀的程序员,十分优秀!