467 lines
16 KiB
VB.net
467 lines
16 KiB
VB.net
Public Class CCo2발생량
|
|
Public Mon As String
|
|
Private ErrMsg As String = "에너지소요량 계산되지 않았습니다"
|
|
Private MIdx As Integer
|
|
Private Result As CResult
|
|
Public Sub New(ByRef presult As CResult, Optional ByVal pmIdx As Integer = 0)
|
|
Result = presult
|
|
MIdx = pmIdx
|
|
Mon = "M" & Format(MIdx, "00")
|
|
End Sub
|
|
ReadOnly Property 발생량() As Decimal
|
|
Get
|
|
If MIdx = 0 Then '//최종합계는 저람량을 제하지않는다?
|
|
Return Me.난방발생량 + Me.냉방발생량 + Me.급탕발생량 + Me.조명발생량 + Me.환기발생량
|
|
Else
|
|
Return Me.난방발생량 + Me.냉방발생량 + Me.급탕발생량 + Me.조명발생량 + Me.환기발생량 - Me.저감량태양광 - Me.저감량풍력 - Me.저감량열병합
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 단위면적() As Decimal
|
|
Get '//월구분없음 실제로는 최종합 M00 에만 값이 있다.
|
|
Return Me.난방면적 + Me.냉방면적 + Me.급탕면적 + Me.조명면적 + Me.환기면적
|
|
End Get
|
|
End Property
|
|
|
|
#Region "난방"
|
|
ReadOnly Property 난방발생량() As Decimal
|
|
Get
|
|
If MIdx = 0 Then
|
|
Dim R As Decimal = Me.난방등유 + Me.난방LNG + Me.난방LPG + Me.난방지역 + Me.난방전력
|
|
Try
|
|
Return R - (Me.저감량열병합 + Me.저감량태양광 + Me.저감량풍력) / (Me.난방전력 + Me.냉방전력 + Me.조명전력 + Me.환기전력 + Me.급탕전력) * Me.난방전력
|
|
Catch ex As Exception
|
|
|
|
End Try
|
|
|
|
Else
|
|
Return Me.난방등유 + Me.난방LNG + Me.난방LPG + Me.난방지역 + Me.난방전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 난방등유() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).난방등유
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).난방등유 * Result.Co2배출계수.등유
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 난방LNG() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).난방LNG
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).난방LNG * Result.Co2배출계수.LNG
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 난방LPG() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).난방LPG
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).난방LPG * Result.Co2배출계수.LPG
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 난방지역() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).난방지역
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).난방지역 * Result.Co2배출계수.지역난방
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 난방전력() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).난방전력
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).난방전력 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
'ReadOnly Property 난방펠렛() As Decimal
|
|
' Get
|
|
' If Me.MIdx = 0 Then
|
|
' Dim Res As Decimal = 0
|
|
' For i As Short = 1 To 12
|
|
' Res += Result.Co2발생량(i).난방펠렛
|
|
' Next
|
|
' Return Res
|
|
' Else
|
|
' Return Result.일차E소요량(MIdx).난방펠렛 * Result.Co2배출계수.펠렛
|
|
' End If
|
|
' End Get
|
|
'End Property
|
|
ReadOnly Property 난방면적() As Decimal
|
|
Get
|
|
If Result.사용면적.H = 0 Then
|
|
Return 0
|
|
Else
|
|
Return Me.난방발생량 / Result.사용면적.H
|
|
End If
|
|
End Get
|
|
End Property
|
|
#End Region
|
|
|
|
ReadOnly Property 냉방발생량() As Decimal
|
|
Get
|
|
Dim R As Decimal = Me.냉방등유 + Me.냉방LNG + Me.냉방LPG + Me.냉방지역난방열 + Me.냉방지역냉방열 + Me.냉방전력
|
|
If MIdx = 0 Then
|
|
Try
|
|
Return R - (Me.저감량열병합 + Me.저감량태양광 + Me.저감량풍력) / (Me.난방전력 + Me.냉방전력 + Me.조명전력 + Me.환기전력 + Me.급탕전력) * Me.냉방전력
|
|
Catch ex As Exception
|
|
|
|
End Try
|
|
|
|
Else
|
|
Return R
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 냉방등유() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).냉방등유
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).냉방등유 * Result.Co2배출계수.등유
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 냉방LNG() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).냉방LNG
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).냉방LNG * Result.Co2배출계수.LNG
|
|
End If
|
|
End Get
|
|
End Property
|
|
'ReadOnly Property 냉방펠렛() As Decimal
|
|
' Get
|
|
' If Me.MIdx = 0 Then
|
|
' Dim Res As Decimal = 0
|
|
' For i As Short = 1 To 12
|
|
' Res += Result.Co2발생량(i).냉방펠렛
|
|
' Next
|
|
' Return Res
|
|
' Else
|
|
' Return Result.일차E소요량(MIdx).냉방펠렛 * Result.Co2배출계수.펠렛
|
|
' End If
|
|
' End Get
|
|
'End Property
|
|
ReadOnly Property 냉방LPG() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).냉방LPG
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).냉방LPG * Result.Co2배출계수.LPG
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 냉방지역난방열() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).냉방지역난방열
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).냉방지역난방열 * Result.Co2배출계수.지역난방
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 냉방지역냉방열() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).냉방지역냉방열
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).냉방지역냉방열 * Result.Co2배출계수.지역냉방
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 냉방전력() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).냉방전력
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).냉방전력 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 냉방면적() As Decimal
|
|
Get
|
|
If Result.사용면적.C = 0 Then
|
|
Return 0
|
|
Else
|
|
Return Me.냉방발생량 / Result.사용면적.C
|
|
End If
|
|
End Get
|
|
End Property
|
|
|
|
ReadOnly Property 급탕발생량() As Decimal
|
|
Get
|
|
If MIdx = 0 Then
|
|
Dim R As Decimal = Me.급탕등유 + Me.급탕LNG + Me.급탕LPG + Me.급탕지역 + Me.급탕전력
|
|
Try
|
|
Return R - (Me.저감량열병합 + Me.저감량태양광 + Me.저감량풍력) / (Me.난방전력 + Me.냉방전력 + Me.조명전력 + Me.환기전력 + Me.급탕전력) * Me.급탕전력
|
|
Catch ex As Exception
|
|
|
|
End Try
|
|
|
|
Else
|
|
Return Me.급탕등유 + Me.급탕LNG + Me.급탕LPG + Me.급탕지역 + Me.급탕전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 급탕등유() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).급탕등유
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).급탕등유 * Result.Co2배출계수.등유
|
|
End If
|
|
End Get
|
|
End Property
|
|
'ReadOnly Property 급탕펠렛() As Decimal
|
|
' Get
|
|
' If Me.MIdx = 0 Then
|
|
' Dim Res As Decimal = 0
|
|
' For i As Short = 1 To 12
|
|
' Res += Result.Co2발생량(i).급탕펠렛
|
|
' Next
|
|
' Return Res
|
|
' Else
|
|
' Return Result.일차E소요량(MIdx).급탕펠렛 * Result.Co2배출계수.펠렛
|
|
' End If
|
|
' End Get
|
|
'End Property
|
|
ReadOnly Property 급탕LNG() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).급탕LNG
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).급탕LNG * Result.Co2배출계수.LNG
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 급탕LPG() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).급탕LPG
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).급탕LPG * Result.Co2배출계수.LPG
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 급탕지역() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).급탕지역
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).급탕지역 * Result.Co2배출계수.지역난방
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 급탕전력() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).급탕전력
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).급탕전력 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 급탕면적() As Decimal
|
|
Get
|
|
If Result.사용면적.W = 0 Then
|
|
Return 0
|
|
Else
|
|
Return Me.급탕발생량 / Result.사용면적.W
|
|
End If
|
|
End Get
|
|
End Property
|
|
|
|
ReadOnly Property 조명발생량() As Decimal
|
|
Get
|
|
If MIdx = 0 Then
|
|
Dim R As Decimal = Me.조명전력
|
|
Try
|
|
Return R - (Me.저감량열병합 + Me.저감량태양광 + Me.저감량풍력) / (Me.난방전력 + Me.냉방전력 + Me.조명전력 + Me.환기전력 + Me.급탕전력) * Me.조명전력
|
|
Catch ex As Exception
|
|
|
|
End Try
|
|
|
|
Else
|
|
Return Me.조명전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 조명전력() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).조명전력
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).조명전력 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 조명면적() As Decimal
|
|
Get
|
|
If Result.사용면적.L = 0 Then
|
|
Return 0
|
|
Else
|
|
Return Me.조명발생량 / Result.사용면적.L
|
|
End If
|
|
End Get
|
|
End Property
|
|
|
|
ReadOnly Property 환기발생량() As Decimal
|
|
Get
|
|
If MIdx = 0 Then
|
|
Dim R As Decimal = Me.환기전력
|
|
Try
|
|
Return R - (Me.저감량열병합 + Me.저감량태양광 + Me.저감량풍력) / (Me.난방전력 + Me.냉방전력 + Me.조명전력 + Me.환기전력 + Me.급탕전력) * Me.환기전력
|
|
Catch ex As Exception
|
|
|
|
End Try
|
|
|
|
Else
|
|
Return Me.환기전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 환기전력() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).환기전력
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.일차E소요량(MIdx).환기전력 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 환기면적() As Decimal
|
|
Get
|
|
If Result.사용면적.V = 0 Then
|
|
Return 0
|
|
Else
|
|
Return Me.환기발생량 / Result.사용면적.V
|
|
End If
|
|
End Get
|
|
End Property
|
|
|
|
ReadOnly Property 저감량태양광() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).저감량태양광
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.생산E(MIdx).태양광전력생산량 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
ReadOnly Property 저감량풍력() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).저감량풍력
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.생산E(MIdx).풍력전력생산량 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
|
|
ReadOnly Property 저감량열병합() As Decimal
|
|
Get
|
|
If Me.MIdx = 0 Then
|
|
Dim Res As Decimal = 0
|
|
For i As Short = 1 To 12
|
|
Res += Result.Co2발생량(i).저감량열병합
|
|
Next
|
|
Return Res
|
|
Else
|
|
Return Result.생산E(MIdx).열병합전력생산량 * Result.Co2배출계수.전력
|
|
End If
|
|
End Get
|
|
End Property
|
|
End Class
|