vb.net做直线拟合 直线拟合小程序
VB.Net中画直线问题
不想整个重画,最好用单色的背景,例如黑色,线条是白色的
创新互联建站主要从事网站设计制作、网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务诏安,10年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18982081108
用变量把线条的内容备份
当想改变线条的位置或者长度之前,先用存下来的变量以黑色重画一次,覆盖原来的白色线条
然后再画新的白色线条,这种重画方法比较节省资源
假如需要用花哨的背景或者图片当背景,也可以用局部重回的方式。
代码就不提供了,只提供思路。
VB直线最小二乘法拟合
'新建窗体,添加text1,command1,picture1
Private Sub Command1_Click()
If Text1.Text = "" Then Exit Sub
Dim x() As Single, y() As Single, cnt As Integer
Dim xmax As Single, xmin As Single, ymax As Single, ymin As Single
Dim p() As String, z() As String
Dim xyh As Single, xh As Single, yh As Single, xph As Single, k As Single, b As Single
p = Split(Text1.Text, "/")
For i = 0 To UBound(p)
If p(i) "" Then
z = Split(p(i), "*")
If UBound(z) = 1 Then
If IsNumeric(z(0)) And IsNumeric(z(1)) Then
If cnt = 0 Then xmax = z(0): xmin = z(0): ymax = z(1): ymin = z(1)
If xmax z(0) Then xmax = z(0)
If xmin z(0) Then xmin = z(0)
If ymax z(1) Then ymax = z(1)
If ymin z(1) Then ymin = z(1)
xyh = xyh + z(0) * z(1): xh = xh + z(0): yh = yh + z(1): xph = xph + z(0) ^ 2
ReDim Preserve x(cnt), y(cnt)
x(cnt) = z(0): y(cnt) = z(1): cnt = cnt + 1
End If
End If
End If
Next
Picture1.Cls
Picture1.DrawWidth = 1
If xmax = xmin And ymax = ymin Then
MsgBox "单点无法拟合"
ElseIf xmax = xmin Then
Picture1.Scale (xmin * 0.5, ymax + 0.2 * (ymax - ymin))-(xmin * 1.5, ymin - 0.2 * (ymax - ymin))
zuobiaozhou xmin * 0.5, ymax + 0.2 * (ymax - ymin), xmin * 1.5, ymin - 0.2 * (ymax - ymin)
Picture1.Line (xmax, ymax + 0.2 * (ymax - ymin))-(xmax, ymin - 0.2 * (ymax - ymin)), vbBlue
ElseIf ymax = ymin Then
Picture1.Scale (xmin - 0.2 * (xmax - xmin), ymax * 1.5)-(xmax + 0.2 * (xmax - xmin), ymin * 0.5)
zuobiaozhou xmin - 0.2 * (xmax - xmin), ymax * 1.5, xmax + 0.2 * (xmax - xmin), ymin * 0.5
Picture1.Line (xmin - 0.2 * (xmax - xmin), ymax)-(xmax + 0.2 * (xmax - xmin), ymax), vbBlue
Else
Picture1.Scale (xmin - 0.2 * (xmax - xmin), ymax + 0.2 * (ymax - ymin))-(xmax + 0.2 * (xmax - xmin), ymin - 0.2 * (ymax - ymin))
zuobiaozhou xmin - 0.2 * (xmax - xmin), ymax + 0.2 * (ymax - ymin), xmax + 0.2 * (xmax - xmin), ymin - 0.2 * (ymax - ymin)
k = (xyh - (xh * yh) / cnt) / (xph - xh ^ 2 / cnt)
b = yh / cnt - k * xh / cnt
Picture1.Line (xmin - 0.2 * (xmax - xmin), k * (xmin - 0.2 * (xmax - xmin)) + b)-(xmax + 0.2 * (xmax - xmin), k * (xmax + 0.2 * (xmax - xmin)) + b), vbBlue
End If
Picture1.DrawWidth = 5
For i = 0 To cnt - 1
Picture1.PSet (x(i), y(i)), vbRed
Next
Text1.SetFocus
End Sub
Private Sub Form_Activate()
Text1.SetFocus
End Sub
Private Sub Form_Load()
Text1.Text = ""
Text1.ToolTipText = "横纵坐标间以乘号*分隔,各点间以除号/分隔。例如:100*100/200*200"
Command1.Caption = "绘图"
Picture1.AutoRedraw = True
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
If Not (IsNumeric(Chr(KeyAscii)) Or KeyAscii = 8 Or KeyAscii = 42 Or KeyAscii = 45 Or KeyAscii = 46 Or KeyAscii = 47) Then KeyAscii = 0
End Sub
Function zuobiaozhou(ByVal x1 As Single, y1 As Single, x2 As Single, y2 As Single)
For i = x1 + (x2 - x1) / 5 To x2 Step (x2 - x1) / 5
Picture1.Line (i, y2 + 100 * (y1 - y2) / Picture1.Height)-(i, y2)
Picture1.CurrentX = i - 250 * (x2 - x1) / Picture1.Width
Picture1.CurrentY = y2 + 350 * (y1 - y2) / Picture1.Height
Picture1.Print i
Next
For i = y2 + (y1 - y2) / 5 To y1 Step (y1 - y2) / 5
Picture1.Line (x1, i)-(x1 + 100 * (x2 - x1) / Picture1.Width, i)
Picture1.CurrentX = x1 + 150 * (x2 - x1) / Picture1.Width
Picture1.CurrentY = i + 80 * (y1 - y2) / Picture1.Height
Picture1.Print i
Next
End Function
用VB编写,根据六组坐标数据能自动拟合一条直线,并且显示在窗体中,包括表达式
不考虑厘米和毫米的转换,
添加PictureBox控件,假设X一列的Text控件是 名为Text1(0 to 5)的控件数组,
Y一列数是 名为Text2(0~5)的控件数组:
Private Sub Command1_Click()
'注:最小二乘法拟合y=ax+b直线的系数a,b分别为:
'设A=∑xi^2,B=∑xi,C=∑yixi,D=∑yi,则方程化为:
'Aa BB = C
'Ba nb = D
'解出a , b得:
'a = (Cn - BD) / (An - BB)
'b = (AD - CB) / (An - BB)
Dim minX, maxX, minY, maxY As Single '用来设置PictureBox控件的坐标Scale
Dim aa As Single, bb As Single
Dim A, B, C, D
n = 6 '初始化数据
A = 0: B = 0: C = 0: D = 0
minX = Val(Text1(0).Text): maxX = minX
minY = Val(Text2(0).Text): maxY = minY
For i = 0 To 5
A = A + Val(Text1(i).Text) ^ 2
B = B + Val(Text1(i).Text)
C = C + Val(Text1(i).Text) * Val(Text2(i).Text)
D = D + Val(Text2(i).Text)
If Val(Text1(i).Text) minX Then minX = Val(Text1(i).Text)
If Val(Text1(i).Text) maxX Then maxX = Val(Text1(i).Text)
If Val(Text2(i).Text) minY Then minY = Val(Text2(i).Text)
If Val(Text2(i).Text) maxY Then maxY = Val(Text2(i).Text)
Next i
aa = (n * C - B * D) / (n * A - B * B)
bb = (A * D - C * B) / (n * A - B * B)
'设置PictureBox坐标,并画直线及6个点:
With Picture1
.ScaleMode = 0
.ScaleWidth = (maxX - minX) * 1.4
.ScaleHeight = -(maxY - minY) * 1.4
.ScaleLeft = minX - (maxX - minX) / 5
.ScaleTop = maxY + (maxY - minY) / 5
End With
Picture1.Line (minX, aa * minX + bb)-(maxX, aa * maxX + bb)
For i = 0 To 5
Picture1.Circle (Val(Text1(i).Text), Val(Text2(i).Text)), (maxX - minX) / 100, RGB(255, 0, 0)
Next i
Picture1.CurrentX = Picture1.ScaleLeft: Picture1.CurrentY = Picture1.ScaleTop
Picture1.Print "y=" aa "*x + " bb
End Sub
文章标题:vb.net做直线拟合 直线拟合小程序
链接分享:http://scyanting.com/article/doeohop.html