Документация Engee
Notebook

Моделирование катушки индуктивности с гистерезисом.

В данном примере показано, как изменение коэффициентов уравнения магнитного гистерезиса Джайлса-Атертона влияет на результирующую кривую B-H. Параметры моделирования настроены на выполнение четырех полных циклов переменного тока с начальной напряженностью поля (H) и плотностью магнитного потока (B), установленными на ноль.

Схема модели:

inductor_with_hysteresis_1732692062795.png

Определение функции для загрузки и запуска модели:

In [ ]:
function start_model_engee()
    try
        engee.close("inductor_with_hysteresis", force=true) # закрытие модели 
        catch err # в случае, если нет модели, которую нужно закрыть и engee.close() не выполняется, то будет выполнена её загрузка после catch
            m = engee.load("$(@__DIR__)/inductor_with_hysteresis.engee") # загрузка модели
        end;

    try
        engee.run(m) # запуск модели
        catch err # в случае, если модель не загружена и engee.run() не выполняется, то будут выполнены две нижние строки после catch
            m = engee.load("$(@__DIR__)/inductor_with_hysteresis.engee") # загрузка модели
            engee.run(m) # запуск модели
        end
end
Out[0]:
start_model_engee (generic function with 1 method)

Запуск модели:

In [ ]:
try
    start_model_engee() # запуск симуляции с помощью специальной функции, реализованной выше
    catch err
    end;

Вывод результатов моделирования из переменной simout:

In [ ]:
res = collect(simout)
Out[0]:
12-element Vector{WorkspaceArray}:
 WorkspaceArray("Nonlinear Inductor.Phi")
 WorkspaceArray("Nonlinear Inductor.n.v")
 WorkspaceArray("Nonlinear Inductor.p.v")
 WorkspaceArray("Nonlinear Inductor.v")
 WorkspaceArray("Nonlinear Inductor.n.i")
 WorkspaceArray("inductor_with_hysteresis/SysOutput_1")
 WorkspaceArray("Nonlinear Inductor.H")
 WorkspaceArray("Nonlinear Inductor.i")
 WorkspaceArray("Nonlinear Inductor.B")
 WorkspaceArray("Nonlinear Inductor.p.i")
 WorkspaceArray("Nonlinear Inductor.M")
 WorkspaceArray("Nonlinear Inductor.power_dissipated")

Запись результатов в переменные:

In [ ]:
H = collect(res[7]) # напряжённость поля
B = collect(res[9]) # плотность магнитного потока
Out[0]:
651×2 DataFrame
626 rows omitted
Rowtimevalue
Float64Float64
10.00.0
20.00010.00734923
30.00020.0234542
40.00030.0465331
50.00040.0762651
60.00050.112378
70.00060.154527
80.00070.202262
90.00080.255024
100.00090.312132
110.0010.37279
120.00110.436089
130.00120.501028
6400.0639-1.24976
6410.064-1.24918
6420.0641-1.24854
6430.0642-1.24783
6440.0643-1.24705
6450.0644-1.24619
6460.0645-1.24525
6470.0646-1.24421
6480.0647-1.24307
6490.0648-1.24181
6500.0649-1.24042
6510.065-1.23889
In [ ]:
using Plots
plot(H[100:end,2], B[100:end,2], linewidth=3, xlabel= "H, А/м", ylabel= "B, Т", legend=:bottomright)
Out[0]:

Определение нового коэффициента обратной намагниченности:

Вывод параметров блока Nonlinear Inductor:

In [ ]:
engee.get_param("inductor_with_hysteresis/Nonlinear Inductor")
Out[0]:
BlockParameters(
  A_effective => 1.6e-05,
  H_anhysteretic => 1000,
  effective_gap => 0.032,
  c => 0.1,
  parameterization => Magnetic flux density versus magnetic field strength characteristic with hysteresis,
  N => 10,
  dB_dH_0 => 0.005,
  B_start => 0,
  H_start => 0,
  g => 1e-9,
  alpha => 0.0001,
  B_anhysteretic => 1.49,
  K => 200.0,
)

Переопределяем значения коэффициентов уравнения магнитного гистерезиса с помощью функции set_param!, скрытой под маской:

In [ ]:
engee.load("$(@__DIR__)/inductor_with_hysteresis.engee")
# @markdown Коэффициент обратимой намагниченности:
c = 0.2 # @param {type:"slider", min:0, max:1, step:0.1}
# @markdown Коэффициент объемной связи:
K = 200.0 # @param {type:"slider", min:0, max:1000, step:1}
# @markdown Коэффициент междоменной связи:
alpha = 0.0001 # @param {type:"slider", min:0, max:0.001, step:0.0001}
engee.set_param!("inductor_with_hysteresis/Nonlinear Inductor", "c" => c)
engee.set_param!("inductor_with_hysteresis/Nonlinear Inductor", "K" => K)
engee.set_param!("inductor_with_hysteresis/Nonlinear Inductor", "alpha" => alpha)
engee.run("inductor_with_hysteresis")
res1 = collect(simout)
H1 = collect(res1[7])
B1 = collect(res1[9])
engee.close("inductor_with_hysteresis", force = true)
plot(H[100:end,2], B[100:end,2], label = "Исходные параметры модели", xlabel= "H, А/м", ylabel= "B, Т", linewidth=3)
plot!(H1[100:end,2], B1[100:end,2], label = "Изменённые параметры модели", legend=:bottomright, linewidth=3)
Out[0]:

Выводы:

В данном примере с помощью программного управления была проведена симуляция модели катушки индуктивности с гистерезисом. На графиках показано, как отдельные коэффициенты уравнений Джайлса-Атертона влияют на кривую гистерезиса.

Блоки, использованные в примере