24小时热门版块排行榜    

查看: 235  |  回复: 2

vs570588

木虫 (正式写手)

[求助] 大家看看这个matlab中自定义函数的意思

function Y=mynf1(beta,t)
x=213.63;
for j=1:size(beta,1)
    q(j)=beta(j,1);
    K(j)=(beta(j,2))^2;
    for i=1:length(t)
        Y(j,i)=fsolve(@(S)(K(j)*log(S)+S+x*q(j)*t(i)-(3.8106*K(j)+x*q(j)*19.9167))/130.6542-1,120);
    end;
end;
Y=Y';
大家帮忙,看看这个函数,最好能给我解释每一步,我matlab一点基础都没有。for语句定义的向量函数,我实在不懂。
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★
vs570588(金币+2): 2011-06-23 20:25:02
sunyang1988(金币+3): 谢谢指点 2011-06-25 12:42:15
ben_ladeng: 2011-08-17 00:35:54
vs570588(金币+2): 2011-08-19 21:17:34
应该是根据输入参数解方程的,大概解释下:
CODE:
% 子函数:
% 输入:
%   beta: 矩阵
%   t:  向量
% 输出:
%   Y:  矩阵
function Y=mynf1(beta,t)

% 常数x
x = 213.63;

% 循环1,次数等于beta矩阵行数
for j=1:size(beta,1)

    % q等于beta第一列
    q(j)=beta(j,1);

    % K等于beta第二列的平方
    K(j)=(beta(j,2))^2;

    % 循环2,次数等于t长度
    for i=1:length(t)
        % Y第j行第i个元素等于解出来的S
        Y(j,i)=fsolve(@(S)(K(j)*log(S)+S+x*q(j)*t(i)-(3.8106*K(j)+x*q(j)*19.9167))/130.6542-1,120);
    end;
end;

% Y转置输出
Y=Y';

end

其实此函数有待优化,应避免操作变长向量,而应该一次赋值,加快处理速度
修改版如下(其实q和K这2个中间变量完全可以不用,只是在解方程函数fsolve中用beta(j,1)和beta(j,2)^2代替即可):
CODE:
% 子函数:
% 输入:
%   beta: 矩阵
%   t:  向量
% 输出:
%   Y:  矩阵
function Y=mynf1(beta,t)

% 常数x
x = 213.63;

% q和k一次性赋值:q等于beta第一列;K等于beta第二列的平方
q = beta(:,1);
K = beta(:,2).^2;

% 循环1,次数等于beta矩阵行数
for j=1:size(beta,1)
    % 循环2,次数等于t长度
    for i=1:length(t)
        % Y第j行第i个元素等于解出来的S
        Y(j,i)=fsolve(@(S)(K(j)*log(S)+S+x*q(j)*t(i)-(3.8106*K(j)+x*q(j)*19.9167))/130.6542-1,120);
    end;
end;

% Y转置输出
Y=Y';

end

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2011-06-23 17:52:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军


sunyang1988(金币+1): 谢谢交流 2011-06-25 12:42:24
ben_ladeng: 2011-08-17 00:36:02
另:如果不想要最后一句转置Y=Y',就在循环中Y(i,j)就行了
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
3楼2011-06-23 17:54:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 学员BmWXvC 的主题更新
信息提示
请填处理意见