| m325nhl | R Documentation | 
Calculate normative heat loss of pipe that is legally affirmed by Minenergo Order 325.
m325nhl(
  year = 1986,
  laying = "underground",
  exp5k = TRUE,
  insulation = 0,
  d = 700,
  temperature = 110,
  len = 1,
  duration = 1,
  beta = FALSE,
  extra = 2
)
| year | year when the pipe is put in operation after laying or total overhaul.
Type:  | 
| laying | type of pipe laying depicting the position of pipe in space: 
 Type:  | 
| exp5k | pipe regime flag: is pipe operated more that 5000 hours per year?
Type:  | 
| insulation | insulation that covers the exterior of pipe: 
 Type:  | 
| d | internal diameter of pipe, [mm]. Type:  | 
| temperature | temperature of heat carrier (water) inside the pipe, [°C].
Type:  | 
| len | length of pipe, [m]. Type:  | 
| duration | duration of heat loss, [hour]. Type:  | 
| beta | should they consider additional heat loss of fittings?
Type:  | 
| extra | number of points used for temperature extrapolation:  | 
Temperature extrapolation and pipe diameter interpolation are leveraged
for better accuracy. Both are linear as it dictated by
Minenergo Order 325.
Nevertheless, one could control the extrapolation behavior by extra
argument: use lower values of extra for soft curvature near extrapolation
edges, and higher values for more physically reasoned behavior in far regions
of extrapolation.
Normative heat loss of cylindrical pipe during duration, [kcal].
If len of pipe is 1 m (meter) as well as duration is set to
1 h (hour) (default values) then the return value is also the
specific heat loss power, [kcal/m/h], prescribed by
Minenergo Order 325.
Type: assert_double.
Other Minenergo: 
m278hlair(),
m278hlcha(),
m278hlund(),
m278insdata,
m278inshcm(),
m278soildata,
m325beta(),
m325nhldata,
m325testbench
 library(pipenostics)
 ## Consider a 1-meter length pipe with
 pipe_diameter <-  700.0  # [mm]
 pipe_dating   <- 1980
 pipe_laying   <- "underground"
 ## Linear extrapolation adopted in Minenergo's Order 325 using last two points:
 operation_temperature <- seq(0, 270, 10)
 qs <- m325nhl(
   year = pipe_dating, laying = pipe_laying, d = pipe_diameter,
   temperature = operation_temperature
 )  # [kcal/m/h]
 plot(
     operation_temperature,
     qs,
     type = "b",
     main = "Minenergo's Order 325. Normative heat loss of pipe",
     sub = sprintf(
       "%s pipe of diameter %i [mm] laid in %i",
        pipe_laying, pipe_diameter, pipe_dating
     ),
     xlab = "Temperature, [°C]",
     ylab = "Specific heat loss power, [kcal/m/h]"
   )
 ## Consider heat loss due fittings:
 operation_temperature <- 65  # [°C]
 fittings_qs <- m325nhl(
   year = pipe_dating, laying = pipe_laying, d = pipe_diameter,
   temperature = operation_temperature, beta = c(FALSE, TRUE)
 )  # [kcal/m/h]
 print(fittings_qs); stopifnot(all(round(fittings_qs ,1)  == c(272.0, 312.8)))
 # [1] 272.0 312.8  # [kcal/m/h]
 ## Calculate heat flux:
 operation_temperature <- c(65, 105)  # [°C]
 qs <- m325nhl(
   year = pipe_dating, laying = pipe_laying, d = pipe_diameter,
   temperature = operation_temperature
 )  # [kcal/m/h]
 print(qs)
 # [1] 272.00 321.75  # [kcal/m/h]
 pipe_diameter <- pipe_diameter * 1e-3          # [m]
 factor        <- 2.701283                      # [kcal/h/W]
 flux <- qs/factor/pipe_diameter -> a  # heat flux, [W/m^2]
 print(flux)
 # [1] 143.8470 170.1572  # [W/m^2]
 ## The above line is equivalent to:
 flux <- flux_loss(qs, pipe_diameter) -> b
 stopifnot(all.equal(a, b, tolerance = 5e-6))
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.