2022-07-18 18:51:49 +05:00
|
|
|
|
using AsbCloudDb.Model;
|
2022-08-01 13:55:51 +05:00
|
|
|
|
using AsbCloudDb.Model.Subsystems;
|
2022-10-10 15:05:32 +05:00
|
|
|
|
using AsbCloudInfrastructure.Services.Subsystems.Utils;
|
2022-07-18 18:51:49 +05:00
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
using Microsoft.Extensions.Configuration;
|
2022-07-14 03:47:11 +05:00
|
|
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2022-08-15 01:17:00 +05:00
|
|
|
|
using System.Data;
|
2022-10-10 15:05:32 +05:00
|
|
|
|
using System.Data.Common;
|
2022-07-18 18:51:49 +05:00
|
|
|
|
using System.Diagnostics;
|
2022-07-14 03:47:11 +05:00
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace AsbCloudInfrastructure.Services.Subsystems
|
|
|
|
|
{
|
2022-08-16 02:22:16 +05:00
|
|
|
|
#nullable enable
|
2022-07-14 03:47:11 +05:00
|
|
|
|
internal class SubsystemOperationTimeBackgroundService : BackgroundService
|
2022-09-18 23:25:34 +05:00
|
|
|
|
{
|
2022-07-14 03:47:11 +05:00
|
|
|
|
private readonly string connectionString;
|
2022-08-01 13:55:51 +05:00
|
|
|
|
private readonly TimeSpan period = TimeSpan.FromHours(1);
|
2022-08-15 01:17:00 +05:00
|
|
|
|
private const int idSubsytemTorqueMaster = 65537;
|
2022-08-17 17:23:24 +05:00
|
|
|
|
private const int idSubsytemSpinMaster = 65536;
|
2022-09-14 12:34:24 +05:00
|
|
|
|
private const int idSubsytemAkb = 1;
|
|
|
|
|
private const int idSubsytemMse = 2;
|
2022-10-19 13:55:10 +05:00
|
|
|
|
|
2022-07-14 03:47:11 +05:00
|
|
|
|
public SubsystemOperationTimeBackgroundService(IConfiguration configuration)
|
|
|
|
|
{
|
|
|
|
|
connectionString = configuration.GetConnectionString("DefaultConnection");
|
|
|
|
|
}
|
2022-09-07 18:01:39 +05:00
|
|
|
|
|
2022-07-18 18:51:49 +05:00
|
|
|
|
protected override async Task ExecuteAsync(CancellationToken token)
|
2022-07-14 03:47:11 +05:00
|
|
|
|
{
|
2022-09-07 18:01:39 +05:00
|
|
|
|
var timeToStart = DateTime.Now;
|
2022-07-18 18:51:49 +05:00
|
|
|
|
var options = new DbContextOptionsBuilder<AsbCloudDbContext>()
|
|
|
|
|
.UseNpgsql(connectionString)
|
|
|
|
|
.Options;
|
|
|
|
|
while (!token.IsCancellationRequested)
|
|
|
|
|
{
|
2022-09-07 18:01:39 +05:00
|
|
|
|
if (DateTime.Now > timeToStart)
|
2022-07-18 18:51:49 +05:00
|
|
|
|
{
|
2022-09-07 18:01:39 +05:00
|
|
|
|
timeToStart = DateTime.Now + period;
|
2022-07-18 18:51:49 +05:00
|
|
|
|
try
|
|
|
|
|
{
|
2022-08-01 13:55:51 +05:00
|
|
|
|
using var context = new AsbCloudDbContext(options);
|
|
|
|
|
var added = await OperationTimeAllTelemetriesAsync(context, token);
|
2022-08-15 01:17:00 +05:00
|
|
|
|
Trace.TraceInformation($"Total subsystem operation time complete. Added {added} operations time.");
|
2022-07-18 18:51:49 +05:00
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
Trace.TraceError(ex.Message);
|
|
|
|
|
}
|
2022-08-01 13:55:51 +05:00
|
|
|
|
GC.Collect();
|
2022-07-18 18:51:49 +05:00
|
|
|
|
}
|
2022-09-07 18:01:39 +05:00
|
|
|
|
var ms = (int)(timeToStart - DateTime.Now).TotalMilliseconds;
|
2022-07-18 18:51:49 +05:00
|
|
|
|
ms = ms > 100 ? ms : 100;
|
|
|
|
|
await Task.Delay(ms, token).ConfigureAwait(false);
|
|
|
|
|
}
|
2022-08-17 17:23:24 +05:00
|
|
|
|
}
|
2022-08-01 13:55:51 +05:00
|
|
|
|
|
|
|
|
|
public override async Task StopAsync(CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
await base.StopAsync(token).ConfigureAwait(false);
|
2022-07-14 03:47:11 +05:00
|
|
|
|
}
|
2022-08-01 13:55:51 +05:00
|
|
|
|
|
|
|
|
|
private static async Task<int> OperationTimeAllTelemetriesAsync(IAsbCloudDbContext db, CancellationToken token)
|
|
|
|
|
{
|
2022-08-15 01:17:00 +05:00
|
|
|
|
var lastDetectedDates = await db.SubsystemOperationTimes
|
2022-08-01 13:55:51 +05:00
|
|
|
|
.GroupBy(o => o.IdTelemetry)
|
|
|
|
|
.Select(g => new
|
|
|
|
|
{
|
|
|
|
|
IdTelemetry = g.Key,
|
|
|
|
|
LastDate = g.Max(o => o.DateEnd)
|
|
|
|
|
})
|
|
|
|
|
.ToListAsync(token);
|
|
|
|
|
|
|
|
|
|
var telemetryIds = await db.Telemetries
|
|
|
|
|
.Where(t => t.Info != null && t.TimeZone != null)
|
|
|
|
|
.Select(t => t.Id)
|
|
|
|
|
.ToListAsync(token);
|
|
|
|
|
|
2022-09-07 18:01:39 +05:00
|
|
|
|
var telemetryLastDetectedDates = telemetryIds
|
2022-08-01 13:55:51 +05:00
|
|
|
|
.GroupJoin(lastDetectedDates,
|
|
|
|
|
t => t,
|
|
|
|
|
o => o.IdTelemetry,
|
|
|
|
|
(outer, inner) => new
|
|
|
|
|
{
|
|
|
|
|
IdTelemetry = outer,
|
|
|
|
|
inner.SingleOrDefault()?.LastDate,
|
|
|
|
|
});
|
2022-09-07 18:01:39 +05:00
|
|
|
|
|
2022-08-01 13:55:51 +05:00
|
|
|
|
var affected = 0;
|
2022-09-07 18:01:39 +05:00
|
|
|
|
foreach (var item in telemetryLastDetectedDates)
|
2022-08-01 13:55:51 +05:00
|
|
|
|
{
|
2022-08-16 02:22:16 +05:00
|
|
|
|
var newOperationsSaub = await OperationTimeSaubAsync(item.IdTelemetry, item.LastDate ?? DateTimeOffset.MinValue, db, token);
|
|
|
|
|
if (newOperationsSaub?.Any() == true)
|
2022-08-01 13:55:51 +05:00
|
|
|
|
{
|
2022-08-03 16:35:21 +05:00
|
|
|
|
db.SubsystemOperationTimes.AddRange(newOperationsSaub);
|
|
|
|
|
affected += await db.SaveChangesAsync(token);
|
|
|
|
|
}
|
2022-08-15 01:17:00 +05:00
|
|
|
|
var newOperationsSpin = await OperationTimeSpinAsync(item.IdTelemetry, item.LastDate ?? DateTimeOffset.MinValue, db, token);
|
2022-08-16 02:22:16 +05:00
|
|
|
|
if (newOperationsSpin?.Any() == true)
|
2022-08-15 01:17:00 +05:00
|
|
|
|
{
|
|
|
|
|
db.SubsystemOperationTimes.AddRange(newOperationsSpin);
|
|
|
|
|
affected += await db.SaveChangesAsync(token);
|
|
|
|
|
}
|
2022-08-01 13:55:51 +05:00
|
|
|
|
}
|
|
|
|
|
return affected;
|
|
|
|
|
}
|
2022-10-19 13:55:10 +05:00
|
|
|
|
|
|
|
|
|
private static async Task<DbDataReader> ExecuteReaderAsync(IAsbCloudDbContext db, string query, CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
var connection = db.Database.GetDbConnection();
|
|
|
|
|
if (
|
|
|
|
|
connection?.State is null ||
|
|
|
|
|
connection.State == ConnectionState.Broken ||
|
|
|
|
|
connection.State == ConnectionState.Closed)
|
|
|
|
|
{
|
|
|
|
|
await db.Database.OpenConnectionAsync(token);
|
|
|
|
|
connection = db.Database.GetDbConnection();
|
|
|
|
|
}
|
|
|
|
|
using var command = connection.CreateCommand();
|
|
|
|
|
command.CommandText = query;
|
|
|
|
|
|
|
|
|
|
var result = await command.ExecuteReaderAsync(token);
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-07 18:01:39 +05:00
|
|
|
|
private static async Task<IEnumerable<SubsystemOperationTime>> OperationTimeSaubAsync(int idTelemetry, DateTimeOffset begin, IAsbCloudDbContext db, CancellationToken token)
|
|
|
|
|
{
|
2022-09-20 22:24:51 +05:00
|
|
|
|
static bool isSubsytemAkb(short? mode)
|
2022-09-07 18:01:39 +05:00
|
|
|
|
{
|
2022-09-20 22:24:51 +05:00
|
|
|
|
if (mode is null)
|
|
|
|
|
return false;
|
2022-09-14 12:34:24 +05:00
|
|
|
|
if (mode == 1 | mode == 3)
|
2022-09-20 22:24:51 +05:00
|
|
|
|
return true;
|
|
|
|
|
return false;
|
2022-09-07 18:01:39 +05:00
|
|
|
|
}
|
|
|
|
|
|
2022-09-20 22:24:51 +05:00
|
|
|
|
static bool IsSubsystemMse(short? state)
|
2022-09-18 23:25:34 +05:00
|
|
|
|
{
|
2022-09-20 22:24:51 +05:00
|
|
|
|
if (state is null)
|
|
|
|
|
return false;
|
2022-09-16 13:47:19 +05:00
|
|
|
|
if ((state & 1) > 0)
|
|
|
|
|
return true;
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-07 18:01:39 +05:00
|
|
|
|
var query =
|
2022-09-14 12:34:24 +05:00
|
|
|
|
$"select tt.date, tt.mode, tt.well_depth, tt.mse_state " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$"from ( " +
|
|
|
|
|
$" select " +
|
|
|
|
|
$" date, " +
|
|
|
|
|
$" mode, " +
|
2022-09-14 12:34:24 +05:00
|
|
|
|
$" mse_state, " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$" well_depth, " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$" lag(mode,1) over (order by date) as mode_lag, " +
|
|
|
|
|
$" lead(mode,1) over (order by date) as mode_lead " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$" from t_telemetry_data_saub " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$" where id_telemetry = {idTelemetry} and well_depth is not null and well_depth > 0" +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$" order by date ) as tt " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$"where (tt.mode_lag is null or (tt.mode != tt.mode_lag and tt.mode_lead != tt.mode_lag)) and tt.date >= '{begin:u}' " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$"order by tt.date;";
|
2022-09-18 23:25:34 +05:00
|
|
|
|
|
2022-10-19 13:55:10 +05:00
|
|
|
|
using var result = await ExecuteReaderAsync(db, query, token);
|
2022-09-18 23:25:34 +05:00
|
|
|
|
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var subsystemsOperationTimes = new List<SubsystemOperationTime>();
|
|
|
|
|
|
|
|
|
|
(bool isEnable, DateTimeOffset date, float depth) akbPre = default;
|
|
|
|
|
(bool isEnable, DateTimeOffset date, float depth) msePre = default;
|
2022-09-07 18:01:39 +05:00
|
|
|
|
|
2022-09-20 22:24:51 +05:00
|
|
|
|
while (result.Read())
|
2022-08-16 02:22:16 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var mode = result.GetFieldValue<short?>(1);
|
|
|
|
|
var state = result.GetFieldValue<short?>(3);
|
|
|
|
|
|
|
|
|
|
var isAkbEnable = isSubsytemAkb(mode);
|
|
|
|
|
var isMseEnable = IsSubsystemMse(state);
|
|
|
|
|
var date = result.GetFieldValue<DateTimeOffset>(0);
|
|
|
|
|
var depth = result.GetFieldValue<float>(2);
|
|
|
|
|
|
|
|
|
|
if (!akbPre.isEnable && isAkbEnable)
|
|
|
|
|
{
|
|
|
|
|
akbPre = (true, date, depth);
|
|
|
|
|
}
|
|
|
|
|
else if (akbPre.isEnable && !isAkbEnable)
|
|
|
|
|
{
|
|
|
|
|
var subsystemOperationTime = new SubsystemOperationTime
|
|
|
|
|
{
|
|
|
|
|
IdTelemetry = idTelemetry,
|
|
|
|
|
IdSubsystem = idSubsytemAkb,
|
|
|
|
|
DateStart = akbPre.date,
|
|
|
|
|
DateEnd = date,
|
|
|
|
|
DepthStart = akbPre.depth,
|
|
|
|
|
DepthEnd = depth,
|
|
|
|
|
};
|
|
|
|
|
if (IsValid(subsystemOperationTime))
|
|
|
|
|
subsystemsOperationTimes.Add(subsystemOperationTime);
|
|
|
|
|
akbPre.isEnable = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!msePre.isEnable && isMseEnable)
|
|
|
|
|
{
|
|
|
|
|
msePre = (true, date, depth);
|
|
|
|
|
}
|
|
|
|
|
else if (msePre.isEnable && !isMseEnable)
|
2022-08-16 02:22:16 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var subsystemOperationTime = new SubsystemOperationTime
|
|
|
|
|
{
|
|
|
|
|
IdTelemetry = idTelemetry,
|
|
|
|
|
IdSubsystem = idSubsytemMse,
|
|
|
|
|
DateStart = akbPre.date,
|
|
|
|
|
DateEnd = date,
|
|
|
|
|
DepthStart = akbPre.depth,
|
|
|
|
|
DepthEnd = depth,
|
|
|
|
|
};
|
|
|
|
|
if (IsValid(subsystemOperationTime))
|
|
|
|
|
subsystemsOperationTimes.Add(subsystemOperationTime);
|
|
|
|
|
|
|
|
|
|
msePre.isEnable = false;
|
|
|
|
|
}
|
2022-08-16 02:22:16 +05:00
|
|
|
|
}
|
2022-10-19 13:55:10 +05:00
|
|
|
|
|
|
|
|
|
return subsystemsOperationTimes;
|
2022-08-17 17:23:24 +05:00
|
|
|
|
}
|
2022-09-07 18:01:39 +05:00
|
|
|
|
|
2022-10-19 13:55:10 +05:00
|
|
|
|
private static async Task<IEnumerable<SubsystemOperationTime>> OperationTimeSpinAsync(int idTelemetry, DateTimeOffset begin, IAsbCloudDbContext db, CancellationToken token)
|
2022-08-03 16:35:21 +05:00
|
|
|
|
{
|
2022-10-06 14:43:43 +05:00
|
|
|
|
static int? GetSubsytemId(short? mode, int? state)
|
2022-09-07 18:01:39 +05:00
|
|
|
|
{
|
|
|
|
|
if (state == 7 && (mode & 2) > 0)
|
|
|
|
|
return idSubsytemTorqueMaster;
|
|
|
|
|
|
|
|
|
|
if (state != 0 & state != 6 & state != 7)
|
|
|
|
|
return idSubsytemSpinMaster;
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2022-10-19 13:55:10 +05:00
|
|
|
|
|
2022-10-06 14:43:43 +05:00
|
|
|
|
var querySpin =
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$"select " +
|
|
|
|
|
$" tspin.date, " +
|
|
|
|
|
$" tspin.mode, " +
|
2022-10-06 14:43:43 +05:00
|
|
|
|
$" tspin.state " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$"from ( " +
|
|
|
|
|
$" select " +
|
|
|
|
|
$" date, " +
|
|
|
|
|
$" mode, " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$" lag(mode, 1) over (order by date) as mode_lag, " +
|
|
|
|
|
$" lead(mode, 1) over (order by date) as mode_lead, " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$" state, " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$" lag(state, 1) over (order by date) as state_lag " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$" from t_telemetry_data_spin " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$" where id_telemetry = {idTelemetry} and date >= '{begin:u}'" +
|
2022-10-06 14:43:43 +05:00
|
|
|
|
$" order by date ) as tspin " +
|
2022-10-19 13:55:10 +05:00
|
|
|
|
$"where mode_lag is null or state_lag is null or (mode != mode_lag and mode_lead != mode_lag) or state != state_lag " +
|
2022-09-07 18:01:39 +05:00
|
|
|
|
$"order by date;";
|
2022-10-10 15:05:32 +05:00
|
|
|
|
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var rows = new List<(int? IdSubsystem, DateTimeOffset Date)>(32);
|
2022-08-17 17:23:24 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
using var resultSpin = await ExecuteReaderAsync(db, querySpin, token);
|
|
|
|
|
int? idSubsystemLast = null;
|
|
|
|
|
while (resultSpin.Read())
|
2022-10-06 14:43:43 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var mode = resultSpin.GetFieldValue<short?>(1);
|
|
|
|
|
var state = resultSpin.GetFieldValue<short?>(2);
|
|
|
|
|
var idSubsystem = GetSubsytemId(mode, state);
|
|
|
|
|
if(idSubsystemLast != idSubsystem)
|
|
|
|
|
{
|
|
|
|
|
idSubsystemLast = idSubsystem;
|
|
|
|
|
var date = resultSpin.GetFieldValue<DateTimeOffset>(0);
|
|
|
|
|
rows.Add((idSubsystem, date));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
await resultSpin.DisposeAsync();
|
2022-10-14 15:12:30 +05:00
|
|
|
|
}
|
2022-10-19 13:55:10 +05:00
|
|
|
|
|
|
|
|
|
if (rows.Count < 2)
|
|
|
|
|
return Enumerable.Empty<SubsystemOperationTime>();
|
|
|
|
|
|
|
|
|
|
var minSpinDate = rows.Min(i => i.Date);
|
|
|
|
|
var maxSpinDate = rows.Max(i => i.Date);
|
|
|
|
|
var depthInterpolation = await GetInterpolation(db, idTelemetry, minSpinDate, maxSpinDate, token);
|
|
|
|
|
|
|
|
|
|
if (depthInterpolation is null)
|
|
|
|
|
return Enumerable.Empty<SubsystemOperationTime>();
|
|
|
|
|
|
|
|
|
|
var subsystemsOperationTimes = new List<SubsystemOperationTime>(32);
|
|
|
|
|
|
|
|
|
|
for (int i = 1; i < rows.Count; i++)
|
2022-10-10 15:05:32 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var r0 = rows[i - 1];
|
|
|
|
|
var r1 = rows[i];
|
|
|
|
|
if (r0.IdSubsystem is not null && r0.IdSubsystem != r1.IdSubsystem)
|
2022-08-03 16:35:21 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var subsystemOperationTime = new SubsystemOperationTime()
|
2022-08-17 17:23:24 +05:00
|
|
|
|
{
|
2022-10-19 13:55:10 +05:00
|
|
|
|
IdTelemetry = idTelemetry,
|
|
|
|
|
IdSubsystem = r0.IdSubsystem.Value,
|
|
|
|
|
DateStart = r0.Date,
|
|
|
|
|
DateEnd = r1.Date,
|
|
|
|
|
DepthStart = depthInterpolation.GetDepth(r0.Date),
|
|
|
|
|
DepthEnd = depthInterpolation.GetDepth(r1.Date),
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if (IsValid(subsystemOperationTime))
|
|
|
|
|
subsystemsOperationTimes.Add(subsystemOperationTime);
|
2022-10-10 15:05:32 +05:00
|
|
|
|
}
|
2022-08-16 02:22:16 +05:00
|
|
|
|
}
|
2022-10-19 13:55:10 +05:00
|
|
|
|
|
|
|
|
|
return subsystemsOperationTimes;
|
2022-08-17 17:23:24 +05:00
|
|
|
|
}
|
2022-09-20 22:24:51 +05:00
|
|
|
|
|
2022-10-19 13:55:10 +05:00
|
|
|
|
private static bool IsValid(SubsystemOperationTime item)
|
|
|
|
|
{
|
|
|
|
|
var validateCode = GetValidateErrorCode(item);
|
|
|
|
|
if (validateCode != 0)
|
|
|
|
|
{
|
|
|
|
|
var str = System.Text.Json.JsonSerializer.Serialize(item);
|
|
|
|
|
Trace.TraceWarning($"Wrong({validateCode}) SubsystemOperationTime: {str}");
|
|
|
|
|
}
|
|
|
|
|
return validateCode == 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static int GetValidateErrorCode(SubsystemOperationTime item)
|
|
|
|
|
{
|
|
|
|
|
if (item.DateStart > item.DateEnd)
|
|
|
|
|
return -1;
|
|
|
|
|
if ((item.DateEnd - item.DateStart).TotalHours > 48)
|
|
|
|
|
return -2;
|
|
|
|
|
if (item.DepthEnd < item.DepthStart)
|
|
|
|
|
return -3;
|
|
|
|
|
if (item.DepthEnd - item.DepthStart > 2000d)
|
|
|
|
|
return -4;
|
|
|
|
|
if (item.DepthEnd < 0d)
|
|
|
|
|
return -5;
|
|
|
|
|
if (item.DepthStart < 0d)
|
|
|
|
|
return -6;
|
|
|
|
|
if (item.DepthEnd > 24_0000d)
|
2022-10-19 14:36:01 +05:00
|
|
|
|
return -7;
|
2022-10-19 13:55:10 +05:00
|
|
|
|
if (item.DepthStart > 24_0000d)
|
2022-10-19 14:36:01 +05:00
|
|
|
|
return -8;
|
2022-10-19 13:55:10 +05:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static async Task<DepthInterpolation?> GetInterpolation(IAsbCloudDbContext db, int idTelemetry, DateTimeOffset dateBegin, DateTimeOffset dateEnd, CancellationToken token)
|
|
|
|
|
{
|
|
|
|
|
var dataDepthFromSaub = await db.TelemetryDataSaub
|
|
|
|
|
.Where(d => d.IdTelemetry == idTelemetry)
|
|
|
|
|
.Where(d => d.DateTime >= dateBegin)
|
|
|
|
|
.Where(d => d.DateTime <= dateEnd)
|
|
|
|
|
.Where(d => d.WellDepth != null)
|
|
|
|
|
.Where(d => d.WellDepth > 0)
|
|
|
|
|
.GroupBy(d => Math.Ceiling(d.WellDepth ?? 0 * 10))
|
|
|
|
|
.Select(g => new {
|
|
|
|
|
DateMin = g.Min(d => d.DateTime),
|
|
|
|
|
DepthMin = g.Min(d => d.WellDepth) ?? 0,
|
|
|
|
|
})
|
|
|
|
|
.OrderBy(i => i.DateMin)
|
|
|
|
|
.ToArrayAsync(token);
|
|
|
|
|
|
|
|
|
|
if (!dataDepthFromSaub.Any())
|
|
|
|
|
return null;
|
2022-09-20 22:24:51 +05:00
|
|
|
|
|
2022-10-19 13:55:10 +05:00
|
|
|
|
var depthInterpolation = new DepthInterpolation(dataDepthFromSaub.Select(i=>(i.DateMin, i.DepthMin)));
|
|
|
|
|
return depthInterpolation;
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-08-16 02:22:16 +05:00
|
|
|
|
#nullable disable
|
2022-07-14 03:47:11 +05:00
|
|
|
|
}
|