0

下面是我的程序的代码。我试图找到 1/ln(x) 的积分值,然后计算从 0 到 x 的积分,以此作为被积函数。我不确定自己做错了什么,但我对 Scilab 还是很陌生。

t = input("t");
x=10; while x<t, x=x+10,
function y=f(x), y=(1/(log (x))), endfunction
I=intg(2,x,f);
function z=g(x), z=I, endfunction
W = intg(0,x,z);
W
end
4

2 回答 2

0

我不完全确定您要实现的目标,但我重新格式化了您的代码并在文档中添加了一些建议。也许它会帮助你找到答案。

While 循环

您可以将while 循环转换为for 循环

你的代码

x=10; 
while x<t
   x=x+10
   //some code
end

可能

for x=10:10:t
   //some code
end

功能

在您的代码中,您在 while 循环的每一次迭代中重新声明这两个函数。您可以在 while 循环外声明它们并在循环内调用它们。

重新格式化

t = input("Please provide t: ");

// The function of 1/ln(x)
function y=f(x), y=1/log(x), endfunction

// Every time g(x) is called the current value of I is returned
function z=g(x), z=I, endfunction

for x=10:10:t

    //Find definite integral of function f from 2 to x 
    I = intg(2,x,f);

    //Find definite integral of I from 0 to x
    W = intg(0,x,g);

    disp( string(W) ); 
end
于 2013-08-14T15:03:02.360 回答
0

我知道这个问题可能已经过时了。但话题仍然活跃。我正在寻找一个双积分的代码。在这里,使用“intg”来计算由其对角线定义的矩形面积((0,0),(x,I))看起来很奇怪:结果只是x * I......可能是初始目的是将“I”视为“x”的函数(但在这种情况下,x=1 处存在收敛问题......);因此,将“I”的积分限制在 1 以上会给出以下代码:

x=10:10:100;W2=integrate('integrate(''1/log(x2)'',''x2'',2,x1)','x1',1.001,x);

注意积分变量 x1 和 x2 的使用,以及引号的使用...

于 2020-09-17T12:01:56.847 回答