首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Sympy中的Steinhart-Hart热敏电阻校准

Sympy中的Steinhart-Hart热敏电阻校准
EN

Stack Overflow用户
提问于 2019-11-04 13:35:35
回答 1查看 351关注 0票数 0

基于热敏电阻模型的施泰因哈特方程,我有一个简单的NTC热敏电阻校准的三点程序:

代码语言:javascript
复制
from sympy import *

var('R1 R2 R3')
var('T1 T2 T3')
var('A  B  C')

#Ametherm DG103395
T1,R1 = 273.150,31991.6
T2,R2 = 323.150, 3641.0
T3,R3 = 373.150,  686.2

equations = [
    Eq( A + B*ln(R1) + C*ln(R1)**3 , 1.0/T1 ),
    Eq( A + B*ln(R2) + C*ln(R2)**3 , 1.0/T2 ),
    Eq( A + B*ln(R3) + C*ln(R3)**3 , 1.0/T3 ),
]

print solve(equations, (A,B,C))

理想情况下,它应该推广到极简矩阵形式中的多点。

代码语言:javascript
复制
T = Matrix([ 273.150, 323.150, 373.150, ....])
R = Matrix([1991.6,  3641.0,   686.2,   ....])
K = MatrixSymbol('K', 3, 1)

print solve( Eq( [1,ln(?),ln(?)**3]*K - 1/T]) )

通过在循环中创建方程来扩展原始代码是非常简单的。但看起来很灰色。

它是否存在清洁和适当的矩阵方式去做它?

更新:似乎是我自己找到了解决方案。也许它可以减少更多?

代码语言:javascript
复制
from sympy import *

#Ametherm DG103395
T = Matrix([  273.150,   298.150, 323.150,  373.150, ])
R = Matrix([31991.6,   10000.0,  3641.0,   686.2,    ])

M = Matrix.vstack( *R.applyfunc( lambda x: Matrix([[1, ln(x), ln(x)**3]]) ) )

ABC = M.solve_least_squares( T.applyfunc(lambda x: 1/x) )

print ABC
EN

回答 1

Stack Overflow用户

发布于 2019-11-04 14:38:06

下面是一种编写它的方法,不是使用矩阵,而是使用列表:

代码语言:javascript
复制
from sympy import *

T = [273.150, 323.150, 373.150]
R = [31991.6, 3641.0, 686.2]
n = len(T)
assert n == len(R), "R and T need to have the same length"

A, B, C = symbols("A B C", real=True)

equations = [ Eq( A + B*ln(R[i]) + C*ln(R[i])**3 , 1.0/T[i] ) for i in range(n) ]
print (solve(equations, (A,B,C)))

输出:{A: 0.00115679797363983, B: 0.000227813584600384, C: 1.26349943638314e-7}

注意,您不需要将T和R声明为SymPy符号。它们是常量,当SymPy在混合公式中遇到它们时会自动转换它们。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58694558

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档