ref_out

之前学习C#时候就遇到了这个问题,不过当时没有深究。昨晚想到这个问题时候自己尝试敲了敲代码,结果从运行的结果来看,越看越乱。在查看了一些资料的基础上,自己总结了一下。
可能会有点乱,但是自己总结出来的东西。
 
一:ref 关键字使参数按引用传递。【引用参数类似指针】返回两个或两个以上的值
其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。若要使用 ref 参数,则方法定义和调用方法都必须显式使用 ref 关键字。
也即是说,在方法中对参数的设置和改变将会直接影响函数调用之处代码①及②)。无论是函数的定义还是调用时均不可忽略关键字ref.【传递的是地址,即使是值类型】【ref定义的参数在使用前必须初始化,一般用于传递数组参数,不允许传递 ref string】
可以对比代码:
代码①:
复制代码
 1 class Program
 2     {
 3         static void Main(string[] args)
 4         {
 5             Program pg = new Program();
 6             int x = 10;
 7             int y = 20;
 8             pg.GetValue(ref x, ref  y);
 9             Console.WriteLine("x={0},y={1}", x, y);
10 
11             Console.ReadLine();
12           
13         }
14 
15         public void GetValue(ref int x, ref int y)
16         {
17             x = 521;
18             y = 520;
19         }
20     }
复制代码

 

运行结果为 

代码②

复制代码
 1 class Program
 2     {
 3         static void Main(string[] args)
 4         {
 5             Program pg = new Program();
 6             int x = 10;
 7             int y = 20;
 8             pg.GetValue(ref x, ref  y);
 9             Console.WriteLine("x={0},y={1}", x, y);
10 
11             Console.ReadLine();
12           
13         }
14 
15         public void GetValue(ref int x, ref int y)
16         {
17             x = 1000;
18             y = 1;
19         }
20     }
复制代码

 

由代码① 和②的运行结果可以看出,在方法中对参数所做的任何更改都将反映在该变量中,而在main函数中对参数的赋值却没有起到作用,无论在函数定义时候参数有没有赋予初值。


三 :对out来说,第一条同样适用。将代码①以及②中的ref全部修改成out,则可与使用ref得到同样的结果。
 
四:out指定的参数必须在函数定义的时候就赋初值。否则则出现错误。对比ref指定的参数则可以不在函数内部进行赋初值,在函数调用时候再赋初值也可以。

代码④:
复制代码
 1 class Program
 2     {
 3         static void Main(string[] args)
 4         {
 5             Program pg = new Program();
 6             int x=10;
 7             int y=233;
 8             pg.Swap(out x, out y);
 9             Console.WriteLine("x={0},y={1}", x, y);
10 
11             Console.ReadLine();
12           
13         }
14 
15         public void Swap(out int a,out  int b)
16         {
17             
18             int temp = a;   //a,b在函数内部没有赋初值,则出现错误。
19             a = b;
20             b = temp;
21         }     
22     
23     }
复制代码

 

出现错误:使用了未赋值的out参数“a”,"b" 至少被赋值一次【out 声明的】
则在swap函数定义时候给a,b赋上初值则运行正确。
 
总结以上四条得到ref和out使用时的区别是:
①:ref指定的参数在函数调用时候必须初始化,不能为空的引用。而out指定的参数在函数调用时候可以不初始化;
②:out指定的参数在进入函数时会清空自己,必须在函数内部赋初值。而ref指定的参数不需要。


`include "constants.h" `include "disciplines.h" module self_compensated_sensor (p, n, ref_p, ref_n, NO2_concentration,SO2_concentration,NO_concentration, V_out, Error_diff); // 端口定义 inout p, n, ref_p, ref_n; input NO2_concentration,SO2_concentration,NO_concentration; // 模拟待测气体浓度 output V_out, Error_diff; // 输出电压端口和误差差值端口 // 电气守恒 electrical p, n, ref_p, ref_n, V_out, Error_diff; //参数定义 parameter real R_sensor = 4000 ;//from (1 : inf); // 气敏传感器初始阻值 parameter real R_ref = 4000 ;//from (1 : inf); // 补偿传感器初始阻值 parameter real sensitivity = 1 ;//from [0 : inf); // 灵敏度系数 (浓度 -> 阻值变化) parameter real interference_factor = 0.1; //from [0 : 1); // 干扰因子 parameter real V_supply = 5 ;//from (0 : inf); // 桥路供电电压 parameter real smooth_tc = 1e-6 ;// from (0 : inf); // 平滑滤波器时间常数 // 内部变量 real V_p, V_ref, V_out_ideal; real R_xg, R_r; // 气体浓度和干扰引起的电阻变化 real Error_theory, Error_actual; real SVM_output; real temp_drift; //温漂 // SVM 相关参数 (代入 PSO-SVM 模型学习到的参数) parameter real SVM_weight_SO2 = 1; parameter real SVM_weight_NO2 = 1; parameter real SVM_weight_NO = 1; parameter real SVM_bias = 0; // 温度漂移和干扰模型参数 parameter real temp_drift_coeff = 0.001 ;// 温漂系数 parameter real interference_freq1 = 100 ;// 干扰频率1 parameter real interference_freq2 = 50 ;// 干扰频率2 parameter real interference_amplitude = 0.05 ;// 干扰幅度 // 状态变量 integer measurement_count; real last_gas_concentration; // Analog 行为描述 analog begin // 每隔 measurement_interval 秒测量一次气体浓度 if ($time > measurement_count * measurement_interval) begin measurement_count = $floor($time / measurement_interval); last_gas_concentration = gas_concentration; // 存储上一次测量的气体浓度 end temp_drift=temp_drift_coeff * $abstime; // 干扰模型 R_r = interference_factor * R_sensor * (sin(`M_TWO_PI * $abstime * interference_freq1)+ sin(`M_TWO_PI * $abstime * interference_freq2) + ($urandom-2147483647) / 2147483648.0 * 0.1 ); SVM_output = SVM_weight_SO2 * SO2_concentration + SVM_weight_NO2 * NO2_concentration + SVM_weight_NO * NO_concentration + SVM_bias; // 传感器电阻随气体浓度变化 (使用上次测量的气体浓度) R_xg = SVM_output; R_r = temo_drift; // 支路阻值计算 (考虑范围限制) real R_sensor_eff = R_sensor - R_xg - R_r; real R_ref_eff = R_ref - R_r; // 理想情况下 (无干扰) 的电阻值 real R_sensor_ideal = R_sensor - R_xg; real R_ref_ideal = R_ref; // 分压计算各支路电压 V_p = V_supply * R_sensor_eff / (R_sensor_eff + R_ref_eff); V_ref = V_supply * R_ref_eff / (R_sensor_eff + R_ref_eff); // 理想状态下的支路电压 V_out_ideal = V_supply * R_sensor_ideal / ( R_sensor_ideal + R_ref_ideal) - V_supply * R_ref_ideal / (R_sensor_ideal + R_ref_ideal); // 计算误差 Error_theory = (V_p - V_ref) - V_out_ideal; // 输出电压 V(V_out) <+ V(p,0) - V(ref_p,0); Error_actual = (V_p - V_ref) - V(V_out); // 将误差输出到端口 V(Error_diff) <+ Error_theory; end endmodule 这是我气体传感器建模的veriloga代码,请现在基于这个原理,根据得到的输出电压反推SO2,NO2,NO三种气体浓度
05-15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值