1 Star 0 Fork 0

zhouxs1023/eigenmath_pratt

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
dirac.cpp 1.28 KB
一键复制 编辑 原始数据 按行查看 历史
Calin Barbat 提交于 2018-02-24 10:52 . Initial commit.
//-----------------------------------------------------------------------------
//
// Author : philippe.billet@noos.fr
//
// Dirac function dirac(x)
// dirac(-x)=dirac(x)
// dirac(b-a)=dirac(a-b)
//-----------------------------------------------------------------------------
#include "stdafx.h"
#include "defs.h"
static void ydirac(void);
void
eval_dirac(void)
{
push(cadr(p1));
eval();
dirac();
}
void
dirac(void)
{
save();
ydirac();
restore();
}
#define X p1
static void
ydirac(void)
{
X = pop();
if (isdouble(X)) {
if (X->u.d == 0)
{push_integer(1);
return;}
else
{push_integer(0);
return;}
}
if (isrational(X)) {
if (MZERO(mmul(X->u.q.a,X->u.q.b)))
{push_integer(1);
return;}
else
{push_integer(0);
return;}
}
if (car(X) == symbol(POWER)) {
push_symbol(DIRAC);
push(cadr(X));
list(2);
return;
}
if (isnegativeterm(X)) {
push_symbol(DIRAC);
push(X);
negate();
list(2);
return;
}
if (isnegativeterm(p1) || (car(p1) == symbol(ADD) && isnegativeterm(cadr(p1)))) {
push(p1);
negate();
p1 = pop();
}
push_symbol(DIRAC);
push(X);
list(2);
}
#if SELFTEST
static const char *s[] = {
"dirac(-x)",
"dirac(x)",
};
void
test_dirac(void)
{
test(__FILE__, s, sizeof s / sizeof (char *));
}
#endif
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/zhouxs1023/eigenmath_pratt.git
git@gitee.com:zhouxs1023/eigenmath_pratt.git
zhouxs1023
eigenmath_pratt
eigenmath_pratt
master

搜索帮助