我正在使用FindRoot语句。我的问题是结果 只是象征性的形式。如何让mathematica将结果存储为向量 或列表以便日后使用。
g[r_]:=(A^r - 1)/(A^r - B^r);
func[r_]:= Piecewise[{{g[r],r<-.01 },{ g[r],r>.01} }];
roots = Table[0,{10}];
q= Table[pp,{pp,.01,0.1,0.01}];
Do[ roots[[i]]=FindRoot[func[r]== q[[i]],{r,0.9}];,{i,1,10}]; ********
Print[r/.roots]; *********** this prints out ok as a list
Pa2=Table[0,{10}];
myPa2=Table[0,{10}];
i/:IntegerQ[i]=True;
r2=r;
h[r2_]:=(A^r2 - 1)/(A^r2 - B^r2);
funcOC[r2_]:= Piecewise[{{h[r2],r2<-.01 },{ h[r2],r2>.01} }];
Do[ Pa2[[i]]=funcOC[r2[[i]]], {i,1,10} ];
Print[myPa2/.Pa2]; ****************symbolic notation is output
答案 0 :(得分:1)
为了扩展迈克尔的问题,目前的代码不会产生数值,因为A和B的值尚未设定。
如果为A和B选择了值,则FindRoot不再返回符号答案。
g[r_] := (A^r - 1)/(A^r - B^r);
A = .4; B = .5;
func[r_] := Piecewise[{{g[r], r < -.01}, {g[r], r > .01}}];
roots = Table[0, {10}];
q = Table[pp, {pp, .01, 0.1, 0.01}];
Do[roots[[i]] = FindRoot[func[r] == q[[i]], {r, 0.9}];, {i, 1, 10}];
Print[r /. roots];
{-201.021,-198.983,-196.97,-194.98,-186.987,-178.398,-170.282,-162.61,-155.352,-148.484}
对于你的第二段代码,我认为你的问题是由r2 [[i]]引起的:
Do[ Pa2[[i]]=funcOC[r2[[i]]], {i,1,10} ];
我认为你的意思是:
Do[ Pa2[[i]]=funcOC[i], {i,1,10} ];
您的意思是使用您在第一个代码块中找到的根吗?如果是这样,你需要更换。
r2=r;
与
r2=r /. roots;