求一个或门逻辑关系函数
本帖最后由 hn10183051 于 2025-1-11 13:13 编辑研究一个表的或门逻辑关系,求高手指点!
(("1.85" "1800" "4000" "100") ("1.85" "1700" "5500" "100")
("1.85" "1600" "5000" "100") ("1.85" "1500" "4500" "100")
("1.85" "1400" "4200" "100") ("1.85" "1300" "4200" "100")
("1.85" "1200" "3500" "100") ("1.85" "1100" "2500" "100")
)
;当2个比较结果不一致时写入结果最大值,反之写入相同结果
(("1.85" "1800" "4000" "100" "4") ("1.85" "1700" "5500" "100" "4")
("1.85" "1600" "5000" "100" "3") ("1.85" "1500" "4500" "100" "2")
("1.85" "1400" "4200" "100" "1") ("1.85" "1300" "4200" "100" "1")
("1.85" "1200" "3500" "100" "0") ("1.85" "1100" "2500" "100" "0")
)(DEFUN C->TH (C D / TH);比较表第2个元素
(COND
((AND (>= 1300 C ) (>= 4000 D ))(setq TH 0))
((AND (>= 1400 C ) (>= 4200 D ))(setq TH 1))
((AND (>= 1500 C ) (>= 4500 D ))(setq TH 2))
((AND (>= 1600 C ) (>= 5000 D ))(setq TH 3))
(T (setq TH 4))
)
TH
)
(C->TH 900 4000) 0
(C->TH 900 5500) 4
(C->TH 1300 4400)2
(C->TH 1400 4400)2
(C->TH 1500 4400)2
(C->TH 1600 300) 3
(C->TH 1700 200) 4
 (defun tt(lst)
(mapcar(function(lambda(x / a b)
(setq a(atoi(cadr x))
a(COND((>= 1300 a)0)((>= 1400 a)1)((>= 1500 a)2)((>= 1600 a)3)(t 4))
b(atoi(caddr x))
b(COND((>= 4000 b)0)((>= 4200 b)1)((>= 4500 b)2)((>= 5000 b)3)(t 4)))
(append x(list(itoa(max a b))))))lst))
(tt'(("1.85" "1800" "4000" "100") ("1.85" "1700" "5500" "100") ("1.85" "1600" "5000" "100") ("1.85" "1500" "4500" "100") ("1.85" "1400" "4200" "100")("1.85" "1300" "4200" "100") ("1.85" "1200" "3500" "100") ("1.85" "1100" "2500" "100") ))
=>
(("1.85" "1800" "4000" "100" "4") ("1.85" "1700" "5500" "100" "4") ("1.85" "1600" "5000" "100" "3") ("1.85" "1500" "4500" "100" "2") ("1.85" "1400" "4200" "100" "1") ("1.85" "1300" "4200" "100" "1") ("1.85" "1200" "3500" "100" "0") ("1.85" "1100" "2500" "100" "0"))
(defun tt1 (lst)
(mapcar (function (lambda (x / a b)
(setq C (atoi (cadr x)))
(setq D (atoi (caddr x)))
(COND
((AND (>= 1300 C ) (>= 4000 D ))(setq TH 0))
((AND (>= 1400 C ) (>= 4200 D ))(setq TH 1))
((AND (>= 1500 C ) (>= 4500 D ))(setq TH 2))
((AND (>= 1600 C ) (>= 5000 D ))(setq TH 3))
(T (setq TH 4))
)
(append x (list (itoa TH)))
)
)
lst
)
) llsheng_73 发表于 2025-1-11 12:46
(tt'(("1.85" "1800" "4000" "100") ("1.85" "1700" "5500" "100") ("1.85" "1600" "5000" "100") ("1.85 ...
谢谢,llsheng_73大神 hn10183051 发表于 2025-1-11 13:23
(defun tt1 (lst)
(mapcar (function (lambda (x / a b)
(setq C (atoi (cadr x)))
看错了,好象不会出现结果不正确的情况,因为几个梯度是逐级增大的。。。比如1300以下它可以返回01234
1600只能返回3,1600以上只能返回4,没注意到区间的这种划分办法可以直接隐含或逻辑... 坐标系中划分一下,不能有重叠或遗漏区域,没那么复杂。 (defun c->th (c d)
(cond ((and (>= 1300 c) (>= 4000 d)) 0)
((and (>= 1400 c) (>= 4200 d)) 1)
((and (>= 1500 c) (>= 4500 d)) 2)
((and (>= 1600 c) (>= 5000 d)) 3)
(t 4)
)
)
;(tt lst)
(defun tt (lst)(mapcar '(lambda (x)(append x (list (itoa (c->th (atoi (cadr x)) (atoi (caddr x))))))) lst))
页:
[1]