全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SPSS论坛
1828 4
2023-05-31
悬赏 10 个论坛币 已解决
假设有列变量,名为DATA

我想实现 任意两行数据相减之后求绝对值而后再相加

类似于
图片1.png
COMPUTE   GINI_DATA=0.
COMPUTE   N=1173.
Loop  nI=1 to N.
    Loop  nJ=1 to N.
        COMPUTE GINI_DATA=ABS(DATA[nI]-DATA[nJ])+GINI_DATA.
    End loop.
End loop.
EXECUTE.


但是无法执行, 不知道哪里错了,希望大家帮忙看看。

最佳答案

邱宗满 查看完整内容

按照公式,最终只能求出一个数字,而不是一个变量。如果确定这是你需要的,SPSS的普通语法应该是无法实现你需要的功能。 在确保不存在缺失数据的情况下,可以使用以下矩阵语法进行计算,SPSS会输出计算数值。 其中,Var1 是用于计算的目标变量,替换为你的变量名即可。 /****************** SPSS语法 ******************. set mxloop=1000000. matrix. get raw/file=*/vars= Var1 /missing=omit. compute ncase ...
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2023-5-31 14:41:33
按照公式,最终只能求出一个数字,而不是一个变量。如果确定这是你需要的,SPSS的普通语法应该是无法实现你需要的功能。
在确保不存在缺失数据的情况下,可以使用以下矩阵语法进行计算,SPSS会输出计算数值。
其中,Var1 是用于计算的目标变量,替换为你的变量名即可

/******************    SPSS语法   ******************.
set mxloop=1000000.
matrix.
get raw/file=*/vars=    Var1   /missing=omit.
compute ncase=nrow(raw).
compute sumofall=0.
loop #q=1 to ncase.
    compute a1=make(ncase,1,raw(#q,1)).
    compute sumofall=sumofall+csum(abs(a1-raw(:,1))).
end loop.
print sumofall/title='Sum of all'/format=f20.16.
end matrix.
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2023-6-1 15:22:31
可以直接使用函数abs(a-b)呀,SPSS和SPSSAU求差值绝对值操作如图
附件列表
Snipaste_2023-06-01_15-00-40.png

原图尺寸 29.06 KB

Snipaste_2023-06-01_15-00-40.png

Snipaste_2023-06-01_15-20-51.png

原图尺寸 91.97 KB

Snipaste_2023-06-01_15-20-51.png

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2023-6-1 21:08:34
邱宗满 发表于 2023-6-1 15:52
按照公式,最终只能求出一个数字,而不是一个变量。如果确定这是你需要的,SPSS的普通语法应该是无法实现你 ...
也就是说,SPSS无法对一列变量中的单个数据直接引用 ,除非通过矩阵运算,对吧?
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2023-6-2 11:13:13
ethantung 发表于 2023-6-1 21:08
也就是说,SPSS无法对一列变量中的单个数据直接引用 ,除非通过矩阵运算,对吧?
SPSS普通的语法可以计算出某个特定位置的数值,但没法进行两两的遍历计算。

一个思路是,使用汇总方法,先计算出特定个案数值,然后使用汇总功能将所有个案都变成该数值。但是我试了一下,在SPSS的普通循环语法里并不支持汇总功能。

其他软件有的可以使用简单语法进行你想要的功能,是因为其它软件包本身的基础语法就融合了矩阵运算,是面向编程和高级统计工作者的。SPSS里面做了一个区分,统计工作者可以使用矩阵语言,普通用户一般用简单的语法就能解决大部分问题。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群