ღl 2021-10-06 15:26 采纳率: 42.9%
浏览 78
已结题

请问这个图用matlab应该怎么画呢?

已知Pst(x)的表达式,要求画x-Pst的图像和a-D的图像。

img

img


其他参数已经给出了,请大家指教。

img

  • 写回答

1条回答 默认 最新

  • joel_1993 2021-10-06 16:16
    关注

    你好!

    tau = 1;
    b=0.1;
    alpha = 0.3;
    lambda = 0.5;
    D = 5.0;
    a = 0.5;
    N = 0.5;
    x = 0:0.01:10;%这个你自己设置
    beta = 1/sqrt(D*alpha*(1-lambda^2))*((2*lambda^2-1)*alpha/D*(tau*a*b-2*lambda*tau*b^2*...
    sqrt(alpha/D)-b) + a*lambda*sqrt(alpha/D)+alpha*tau*b^2*lambda/b*sqrt(alpha/D));
    gamma = 1/2/D*(a + alpha*tau*b^2/D + 2*lambda*sqrt(alpha/D)*(tau*a*b-2*lambda*tau*b^2*...
    sqrt(alpha/D)-b))-1/2;
    Pst = N*(1+tau*b*x).*(D*x.^2-2*lambda*x.*sqrt(D*alpha)+alpha).^gamma.*...
        exp(-tau*b^2/2/D*x.^2+(tau*a*b-2*lambda*tau*b^2*sqrt(alpha/D)-b)/D.*x...
        +beta*atan((D*x-lambda*sqrt(D*alpha))./sqrt(D*alpha*(1-lambda^2))));
    figure(1);clf%画图
    plot(x,Pst)
    xlabel('x');ylabel('Pst')
    
    tau = 1; b = 0.1; alpha = 3; 
    afun = @(D, lambda) D + tau*b*lambda*sqrt(alpha*D);
    D = 0:0.01:2.5;
    a1 = afun(D, 0);
    a2 = afun(D, 0.5);
    a3 = afun(D, 1);
    figure(2);clf
    plot(D, a1,'r--', D,a2,'b-', D,a3,'m-.')
    legend('\lambda=0','\lambda=0.5','\lambda=1')
    xlabel('D');ylabel('a')
    

    img

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月9日
  • 已采纳回答 10月6日
  • 创建了问题 10月6日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵