- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发这个项目,该项目处理 python 中的向量。但我是 python 新手,真的不知道如何破解它。说明如下:
“向 Vector 类添加一个构造函数。构造函数应采用单个参数。如果此参数是 int 或 long 或从其中之一派生的类的实例,则将此参数视为长度Vector 实例的。在本例中,构造一个指定长度的 Vector,每个元素都初始化为 0.0。如果长度为负数,则引发 ValueError 并提供适当的消息。如果参数不被视为长度,则如果参数是一个序列(例如列表),则使用给定序列的长度和值的向量进行初始化。如果参数不用作向量的长度并且它不是序列,则引发TypeError 并带有适当的消息。
接下来实现__repr__
方法以返回可用于初始化Vector的Python代码字符串。该代码字符串应包含类名,后跟一个左括号,后跟表示为列表的向量内容,后跟一个右括号。”
我不确定如何进行类类型检查,以及如何根据给定对象初始化向量。有人可以帮我解决这个问题吗?谢谢!
最佳答案
你的老师似乎并没有“把Python当作母语来讲”。 ;) 这个类的整个概念非常愚蠢;真正的Python程序员只是直接使用内置的序列类型。但是,这种事情对于学术练习来说是很正常的,可悲的是......
Add a constructor to the Vector class.
在 Python 中,默认情况下会在内部处理常见的“这就是创建新对象并说明它是其实例的方式”的内容,然后将婴儿对象传递给类的初始化 方法,通过设置类的新实例应具有的属性,使其成为“正确的”实例。我们将该方法称为 __init__
。
The constructor should take a single argument. If this argument is either an int or a long or an instance of a class derived from one of these
这是通过使用内置函数 isinstance
进行测试的。您可以在文档中自行查找(或在 REPL 中尝试 help(isinstance)
)。
In this case, construct a Vector of the specified length with each element is initialized to 0.0.
在我们的__init__
中,我们通常只是为属性分配起始值。 __init__
的第一个参数是我们正在初始化的新对象,我们通常将其称为“self”,以便人们理解我们在做什么。其余参数是调用者请求实例时传递的任何参数。在我们的例子中,我们总是期待一个参数。它可能有不同的类型和不同的含义,所以我们应该给它一个通用的名称。
当我们检测到泛型参数是带有 isinstance
的整数类型时,我们通过设置适当的数据来“构造”向量。我们只是分配给 self
的某个属性(无论什么都有意义),其值将是......那么,您将使用什么来在内部表示向量的数据?希望您已经考虑过这一点:)
If the length is negative, raise a ValueError with an appropriate message.
哦,好点......我们应该在尝试构建存储之前检查一下。一些明显的方法基本上将负数视为零。其他方式可能会引发我们无法控制的异常。
If the argument is not considered to be the length, then if the argument is a sequence (such as a list), then initialize with vector with the length and values of the given sequence.
“序列”是一个更加模糊的概念;列表和元组以及诸如此类的东西没有“序列”基类,因此我们无法使用 isinstance
轻松检查这一点。 (毕竟,有人可以轻松发明一种我们没有想到的新型序列)。检查某物是否是序列的最简单方法是尝试使用内置的 iter 函数为其创建迭代器。如果事情不可迭代(尝试一下!),这将已经引发一个相当有意义的 TypeError
,因此这使得错误处理变得容易 - 我们只是让它做它的事情。
假设我们有一个迭代器,我们可以轻松地创建存储:大多数序列类型(我假设您已经想到其中一种,并且肯定包括其中一种)将接受其迭代器 em> __init__
方法并执行复制序列数据的明显操作。
Next implement the
__repr__
method to return a string of python code which could be used to initialize the Vector. This string of code should consist of the name of the class followed by an open parenthesis followed by the contents of the vector represented as a list followed by a close parenthesis."
希望这是不言自明的。提示:您应该能够通过使用存储属性自己的 __repr__
来简化此过程。还可以考虑使用字符串格式将字符串放在一起。
关于python - python 中的向量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8262017/
我想用一个向量执行以下操作。 a = np.array(np.arange(0, 4, 1)) 我想得到一个乘法,结果是一个矩阵 | 0 1 2 3 4 -| - - - - - - - 0
正如标题所述,我正在尝试使用 gsub,其中我使用向量作为“模式”和“替换”。目前,我的代码如下所示: names(x1) names(x1) [1] "2110023264A.Ms.Amp
所以当我需要做一些线性代数时,我更容易将向量视为列向量。因此,我更喜欢 (n,1) 这样的形状。 形状 (n,) 和 (n,1) 之间是否存在显着的内存使用差异? 什么是首选方式? 以及如何将 (n,
我不明白为什么 seq() 可以根据元素中是否存在小数点输出不同的类,而 c() 总是创建一个 num向量,无论是否存在小数。 例如: seqDec <- seq(1, 2, 0.5) # num v
机器学习与传统编程的一个重要区别在于机器学习比传统编程涉及了更多的数学知识。不过,随着机器学习的飞速发展,各种框架应运而生,在数据分析等应用中使用机器学习时,使用现成的库和框架成为常态,似乎越来越不需
寻找有关如何将 RegEnable 用作向量的示例/建议。此外,我想控制输入和使能信号成为 Vector 中寄存器索引的函数。 首先,我如何声明 RegEnable() 的 Vector,其次如何迭代
假设我有一个包含变量名称的向量 v1,我想为每个变量分配一个值(存储在单独的向量中)。我如何在没有迭代的情况下做到这一点? v1 <- c("a","b","c") v2 <- c(1,2,3) 我想
R 提供了三种类型来存储同质对象列表:向量、矩阵 和数组。 据我所知: 向量是一维数组的特殊情况 矩阵是二维数组的特例 数组还可以具有任意维度级别(包括 1 和 2)。 在向量上使用一维数组和在矩阵上
我正在绕着numpy/scipy中的所有选项转圈。点积、乘法、matmul、tensordot、einsum 等 我想将一维向量与二维矩阵(这将是稀疏csr)相乘并对结果求和,这样我就有了一个一维向量
我是一个 IDL 用户,正在慢慢切换到 numpy/scipy,并且有一个操作我在 IDL 中非常经常做,但无法用 numpy 重现: IDL> a = [2., 4] IDL> b = [3., 5
在python计算机图形工具包中,有一个vec3类型用于表示三分量向量,但是我如何进行以下乘法: 三分量向量乘以其转置结果得到 3*3 矩阵,如下例所示: a = vec3(1,1,1) matrix
我正在构建一款小型太空射击游戏。当涉及到空间物理学时,我曾经遇到过数学问题。 用文字描述如下:有一个最大速度。因此,如果您全速行驶,您的飞船将在屏幕上一遍又一遍地移动,就像在旧的小行星游戏中一样。如果
我正在尝试在 python 中实现 Vector3 类。如果我用 c++ 或 c# 编写 Vector3 类,我会将 X、Y 和 Z 成员存储为 float ,但在 python 中,我读到鸭式是要走
我是 Spark 和 Scala 的新手,我正在尝试阅读有关 MLlib 的文档。 http://spark.apache.org/docs/1.4.0/mllib-data-types.html上的
我有一个包含四个逻辑向量的数据框, v1 , v2 , v3 , v4 是对还是错。我需要根据 boolean 向量的组合对数据帧的每一行进行分类(例如, "None" , "v1 only" , "
我正在创建一个可视化来说明主成分分析的工作原理,方法是绘制一些实际数据的特征值(为了说明的目的,我将子集化为二维)。 我想要来自 this fantastic PCA tutorial 的这两个图的组
我有以下排序向量: > v [1] -1 0 1 2 4 5 2 3 4 5 7 8 5 6 7 8 10 11 如何在不遍历整个向量的情况下删除 -1、0 和 11
有什么方法可以让 R 对向量和其他序列数据结构使用基于零的索引,例如在 C 和 python 中。 我们有一些代码在 C 中进行一些数值处理,我们正在考虑将其移植到 R 中以利用其先进的统计功能,但是
我有一个函数可以查询我的数据库中最近的 X 个条目,它返回一个 map 向量,如下所示: [{:itemID "item1" :category "stuff" :price 5} {:itemI
我有 ([[AA ww me bl qw 100] [AA ee rr aa aa 100] [AA qq rr aa aa 90]] [[CC ww me bl qw 100] [CC ee rr
我是一名优秀的程序员,十分优秀!