在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 8905|回复: 11

[求助] 关于veriloga写出来的全差分运放问题

[复制链接]
发表于 2016-9-21 21:33:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
我参考的模拟集成电路设计与仿真 何乐年的写了个基本上一一模一样的差分op,但是仿tran的时候出了个问题,不知道怎么改代码,求前辈帮忙看看 ,输出共模应该是在1.65v啊,怎么输出成这样了。
2.png 1.png
`include "discipline.h"
`include "constants.h"
// $Date: 1997/08/28 05:45:21 $
// $Revision: 1.1 $
//
//
// Based on the OVI Verilog-A Language Reference Manual, version 1.0 1996
//
//

`define PI   3.14159265358979323846264338327950288419716939937511

//--------------------
// opamp-diff
//
// - differential operational amplifier
//
// vin_p,vin_n: differential input voltage [V,A]
// vout_p,vout_n:differential output voltage [V,A]
// vref: reference voltage [V,A]
// vspply_p: positive supply voltage [V,A]
// vspply_n: negative supply voltage [V,A]
//
// INSTANCE parameters
//    gain           = gain []
//    freq_unitygain = unity gain frequency [Hz]
//    rin            = input resistance [Ohms]
//    vin_offset     = input offset voltage referred to negative [V]
//    ibias          = input current [A]
//    iin_max           = maximum current [A]
//    slew_rate      = slew rate [A/F]
//    rout           = output resistance [Ohms]
//    vsoft          = soft output limiting value [V]
//
// MODEL parameters
//    {none}
//
module opamp_diff(vref, vin_p, vin_n, vspply_p, vspply_n, vout_p, vout_n);
input vref, vspply_p, vspply_n;
inout vout_p, vout_n, vin_p, vin_n;
electrical vout_n, vout_p, vref, vin_p, vin_n, vspply_p, vspply_n;
parameter real gain = 835e3;
parameter real freq_unitygain  = 1.0e6;
parameter real rin = 1e6;
parameter real vin_offset = 0.0;
parameter real ibias = 0.0;
parameter real iin_max = 100e-6;
parameter real slew_rate = 0.5e6;
parameter real rout = 80;
parameter real vsoft = 0.5;
   real c1;
   real gm_nom;
   real r1;
   real vmax_in;
   real vin_val;
electrical cout_p, cout_n;

   analog begin
      @ ( initial_step or initial_step("dc") ) begin
  c1 = iin_max/(slew_rate);
  gm_nom = 2 * `PI * freq_unitygain * c1;
  r1 = gain/gm_nom;
  vmax_in = iin_max/gm_nom;
      end

      vin_val = V(vin_p,vin_n)/2 + vin_offset;
      //
      // Input stage.
      //
      I(vin_p, vin_n) <+ (V(vin_p, vin_n) + vin_offset)/ rin;
      I(vref, vin_p) <+ ibias;
      I(vref, vin_n) <+ ibias;
      //
      // GM stage with slewing
      //
      I(vref, cout_p) <+ V(vref, cout_p)/100e6;
      I(vref, cout_n) <+ V(vref, cout_n)/100e6;
      if (vin_val > vmax_in) begin
         I(vref, cout_p) <+ iin_max;
         I(vref, cout_n) <+ -iin_max;
      end
      else if (vin_val < -vmax_in) begin
         I(vref, cout_p) <+ -iin_max;
         I(vref, cout_n) <+ iin_max;
     end
      else begin
         I(vref, cout_p) <+ 1*gm_nom*vin_val ;
         I(vref, cout_n) <+ -1*gm_nom*vin_val ;
    end
      //
      // Dominant Pole.
      //
      I(cout_p, vref) <+ ddt(c1*V(cout_p, vref));
      I(cout_p, vref) <+ V(cout_p, vref)/r1;
      I(cout_n, vref) <+ ddt(c1*V(cout_n, vref));
      I(cout_n, vref) <+ V(cout_n, vref)/r1;
      //
      // Output Stage.
      //
      I(vref, vout_p) <+ V(cout_p, vref)/rout;
      I(vout_p, vref) <+ V(vout_p, vref)/rout;
      I(vref, vout_n) <+ V(cout_n, vref)/rout;
      I(vout_n, vref) <+ V(vout_n, vref)/rout;
      //
      // Soft Output Limiting.
      //
      if (V(vout_p) > (V(vspply_p) - vsoft))
         I(cout_p, vref) <+ gm_nom*(V(vout_p, vspply_p)+vsoft);
      else if (V(vout_p) < (V(vspply_n) + vsoft))
         I(cout_p, vref) <+ gm_nom*(V(vout_p, vspply_n)-vsoft);
      if (V(vout_n) > (V(vspply_p) - vsoft))
         I(cout_n, vref) <+ gm_nom*(V(vout_n, vspply_p)+vsoft);
      else if (V(vout_n) < (V(vspply_n) + vsoft))
         I(cout_n, vref) <+ gm_nom*(V(vout_n, vspply_n)-vsoft);   
end
endmodule
 楼主| 发表于 2016-9-22 08:56:24 | 显示全部楼层
求前辈帮忙
发表于 2016-9-22 15:53:42 | 显示全部楼层
vin_offset设的多少?
发表于 2016-9-22 18:07:40 | 显示全部楼层
这不是挺好么,你想要什么?
发表于 2016-9-22 23:27:36 | 显示全部楼层
Use book about VHDL Coding.
发表于 2016-9-22 23:37:18 | 显示全部楼层




    google find

http://www.designers-guide.org/Forum/YaBB.pl?num=1369925274

// model opamp -  Non Ideal OpAmp Model

                                       
module opamp (voutp,voutn, vin_p, vin_n, vspply_p, vspply_n, vcm  );
  input  vin_p , vin_n , vcm;
  inout  vspply_p, vspply_n;                                       
  output voutp,voutn ;
  electrical vin_p, vin_n, voutp, voutn, vspply_p, vspply_n, vcm;


   parameter real         gain = 1412.5 exclude 0.0;
   parameter real         pole_freq = 172k;
   parameter real         rin = 12.0M exclude 0.0;
   parameter real         rout = 75.0;
   parameter real         ibias = 0.0n;
   parameter real         vin_offset = 0.0u;


//   parameter real        slewp = 20.0M from (0:inf);
//   parameter real        slewn = -20.0M from (-inf:0);

   real c1, r1;
   real r_rout,gm_nom, vin_val;
   electrical coutp, coutn, vref;                           


    analog
    begin

       @(initial_step)// or initial_step("dc", "ac", "tran", "xf"))
        begin
                 gm_nom = 1.0;
             r1 = gain/gm_nom;
                 c1 = gm_nom/(`M_TWO_PI * pole_freq * gain);
                  r_rout = rout;         
                           
        end

       vin_val=  V(vin_p, vin_n) + vin_offset;


      // ------ Vref  is at Virtual Ground

      V(vref,vspply_n) <+ 0.5*V(vspply_p,vspply_n);



      // ------ Input Stage

       I(vin_p, vin_n) <+ vin_val / rin;
       I(vref, vin_p)  <+ ibias;
       I(vref, vin_n)  <+ ibias;



      // ------ GM stage

   
      I(vcm, coutp) <+ (gm_nom/2)*vin_val ;
      I(vcm, coutn) <+ -(gm_nom/2)*vin_val ;



      // ------ Dominant Pole.

      I(coutp, vcm) <+c1*ddt(V(coutp, vcm));
      I(coutp, vcm) <+ V(coutp, vcm)/r1;

      I(coutn,vcm) <+ c1*ddt(V(coutn, vcm));
      I(coutn, vcm) <+ V(coutn, vcm)/r1;



  
      // ------ Output Stage.

      I(vcm, voutp) <+ (V(coutp) - (vcm))/r_rout;                           
      I(voutp, vcm) <+ V(voutp, vcm)/r_rout;

      I(vcm, voutn) <+ (V(coutn) - V(vcm))/r_rout;
      I(voutn, vcm) <+ V(voutn, vcm)/r_rout;



    end
endmodule
 楼主| 发表于 2016-9-24 19:22:53 | 显示全部楼层
回复 3# zcg0697


    vin——offset设的是0
 楼主| 发表于 2016-9-24 19:36:02 | 显示全部楼层
QQ截图20160924193810.png 回复 4# wind2000sp3   不应该是这样的波形吗
发表于 2016-9-24 23:00:10 | 显示全部楼层
回复 8# 弹弹


   估计你输入V6的DC offset不为零
发表于 2016-9-25 14:26:59 | 显示全部楼层
回复 8# 弹弹


    你这是一种差分,Verilog Code的也是一种差分。差分输出的本质是啥?
两个输出端之和是0,输出端之差是输入端的放大倍数。

要改成你想的那样,你要想好是为啥?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-12-19 00:35 , Processed in 0.022456 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表