- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
下面的代码
x = [1.1, 2.22, -3.3; 4.44, 5.55, 6.6];
fmt = '%.16g ';
y = num2str(x, fmt)
在 Matlab (R20105b) 中产生不同的结果
y =
1.1 2.22 -3.3
4.44 5.55 6.6
在 Octave (4.0.0) 中
y =
1.1 2.22 -3.3
4.44 5.55 6.6
区别在于对齐方式:在 Matlab 中,列是右对齐的,而在 Octave 中,它们不是对齐的。
我想在 Octave 中完全实现 Matlab 的行为。你知道这个有什么解决办法吗?当然,我可以编写自己的函数,但也许已经存在解决方案。
编辑
另一个区别是如何处理多维数组。例如,
x = cat(3, magic(3), -magic(3));
fmt = '%.16g ';
y = num2str(x, fmt)
在 Matlab 中生成
y =
8 1 6 -8 -1 -6
3 5 7 -3 -5 -7
4 9 2 -4 -9 -2
在 Octave 音阶
y =
8 1 6
3 5 7
4 9 2
-8 -1 -6
-3 -5 -7
-4 -9 -2
也就是说,Matlab 沿第二维附加 3D 切片,沿第一维附加 Octave。
最佳答案
这与其说是解决方案,不如说是一种变通方法;我对此并不完全满意。但事情就是这样。如果有人有更好或更通用的解决方案,请告诉。
以下仅适用于单一格式化运算符,如示例所示(不适用于 fmt = '%.2f %.1f'
),并且仅适用于实数(非复数)。它适用于维度超过 2
的数组,模仿 Matlab 的行为:它将第一个维度之外的所有维度折叠成一个(第二个)维度。
if ischar(x)
y = x;
else
y = sprintf([fmt '\n'], reshape(x,size(x,1),[]).'); %'// each row of y is a string.
% // '\n' is used as separator
y = regexp(y, '\n', 'split'); %// separate
y = y(1:end-1).'; %'// remove last '\n'
y = cellfun(@fliplr, y, 'uniformoutput', false); %// invert each string
y = char(y); %// concatenate the strings vertically. This aligns to the left
y = fliplr(y); %// invert back to get right alignment
y = reshape(y.',[],size(x,1)).'; %// reshape into the shape of x
y = strtrim(y); %// remove leading and trailing space, like num2str does
end
这在 Octave 的 Matlab 中产生的结果与在 Matlab 中 y = num2str(x, fmt)
产生的结果相同。
应该注意的是,当第一个输入是一个字符数组时,num2str
忽略第二个输入(格式说明符),并在 Matlab 和 Octave 中生成相同的字符数组作为输出。因此 num2str('abc', '%f ')
产生 'abc'
。但是,sprintf
的工作方式不同:它强制使用格式说明符,如果需要,将输入的字符解释为 ASCII 代码。这就是上面代码中需要 if
分支的原因。
关于string - 在 Octave 中实现 Matlab 的 `num2str` 行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34483961/
我知道这是基本的,但我不确定,我哪里出错了,之前从未写过正则表达式.. 我需要从命令中获取一些输出 cmd | grep '[0-9]+:[0-9]+:[0-9]+:[0-9]+' 我需要grep一些
这个问题在这里已经有了答案: How does assignment work with list slices? [duplicate] (5 个答案) What does colon at as
我在一本 C 书中读到,对于数组 num[7],术语 num 等同于 &num[0]。这个概念对我来说很好,但是当我编写如下所示的程序时,我再次感到困惑。 #include #include int
例如,一种不好的方法是通过字符串分解: toReadableNum :: (Num a, Num b, Read b) => a -> b toReadableNum = read . show 如果
在输入文本字段中,我必须获取该值并在我的 .ts 文件中使用它。你能建议我应该使用以下哪种语法吗? 最佳答案 如果您希望在文本字段中看到的内容与变量中看到的内容之间进行同步对齐,请使用 如果您想在文
我正在研究 while 循环。我目前正在研究一个问题,要求从名为 a、b 和 c 的用户那里获取三个数字。我尝试显示 a 和 b 之间的所有数字,它们除以 c。我尝试使用“if”的想法,但没有成功。
因为这些符号,我很难用谷歌搜索。 num & 8, num >> 8 和 num >> 8 & 64 在 javascript 中是什么意思? 最佳答案 它们是 bitwise operators 关
显然,我的类型签名已关闭。从那以后我发现了原因。现在,我有兴趣了解更多关于我的错字上的 GHCI 推断签名。我试图让这段代码工作: elemNum :: (Eq a, Num b) => a -> [
我有一个程序根据定义的规则接受特定的字符串,即数字运算符编号。例如:2+4-5*9/8 上面的字符串是可以接受的。现在,当我输入类似 2+4-a 的内容时,它再次显示可接受,这是完全 Not Acce
我读到了这样一个旋转数组的解决方案 问题: public class Solution { public void rotate(int[] nums, int k) { in
一般来说,对于 int num , num++ (或 ++num ),作为读-修改-写操作,是 不是原子的 .但是我经常看到编译器,比如GCC ,为其生成以下代码( try here ): void
这个问题在这里已经有了答案: What's the difference between my ($variableName) and my $variableName in Perl? (4 个回答
如果列表中的 num 大于 0.5,我想得到 1,否则得到 0。 例如,a是一个列表 Matlab: b = (a > 0.5) Python: b = [1 if x > 0.5 else 0 fo
第4行为什么要在“-”后面加上“=”? num = 5 if num > 2: print(num) num -= 1 print(num) 最佳答案 num - 1:产生num减一的
iex> num = [9] '\t' 分配单个 [9] 列表返回 '\t'。这是什么原因? 最佳答案 您可以使用 i helper in IEx有关数据类型的更多信息: iex> i [9] Te
好吧,我做错了什么 - Moose 忽略了我的强制: package moo; use Moose; use Moose::Util::TypeConstraints; subtype Bar =>
这个问题已经有答案了: JavaScript property access: dot notation vs. brackets? (17 个回答) 已关闭 4 年前。 我正在练习编写一些代码。在练
我有声明 SELECT COUNT(*) as num_requests, ip_address FROM requests GROUP BY ip_address ORDER BY num_requ
有什么方法可以在 javascript 中编写更短的 (num>0)?num:0 吗? 原因是 num 变量还没有定义,在上面的例子中需要计算两次。 换句话说,a和b是已知的。我想写 (a>b)?(a
这个问题在这里已经有了答案: Why does 2 == [2] in JavaScript? (9 个回答) 关闭 9 年前。 这些陈述的计算结果为真是否有原因? 0 == [0]; 1 == [
我是一名优秀的程序员,十分优秀!