Сайт AZJIO
Главная | Регистрация | Вход Приветствую Вас Гость | RSS
Меню сайта
Категории раздела
Скрипты для LiveCD [0]
Скрипты для WindowsXP [8]
Примеры скриптов [15]
Функции [5]
Поиск
Главная » Статьи » Скрипты AutoIt3 » Скрипты для WindowsXP

Пример график функции
Пример демонстрирующий график разряда конденсатора в выпрямительном блоке питания. Необходимая GraphGDIPlus.au3 есть в коллекции скриптов.





#include "GraphGDIPlus.au3"
#NoTrayIcon
Global $Um, $Rn, $Cf, $f, $k2, $k3, $R1rt, $R2rt, $ktr, $In, $Rtr, $kp, $Ucr, $Ud1, $Ud2, $Ar

$GUI
= GUICreate("Разрядка конденсатора в выпрямительном блоке питания", 590, 530)

$start = GUICtrlCreateButton("Пересчитать", 480, 485, 97, 33)

$Um00 = GUICtrlCreateInput("12", 10, 298, 40, 20)
GUICtrlCreateLabel("Пиковое напряжение без нагрузки, В.", 55, 300, 190, 17)

$Rn00 = GUICtrlCreateInput("9", 10, 323, 40, 20)
GUICtrlCreateLabel("Сопротивление нагрузки, Ом.", 55, 325, 190, 17)

$Cf00 = GUICtrlCreateInput("1370", 10, 348, 40, 20)
GUICtrlCreateLabel("Ёмкость конденсатора, мкФ.", 55, 350, 190, 17)

$f00 = GUICtrlCreateInput("100", 10, 373, 40, 20)
GUICtrlCreateLabel("Частота пульсаций, Гц (100 Гц при входном переменном токе 50 Гц).", 55, 375, 360, 17)

$k200 = GUICtrlCreateInput("0", 10, 398, 40, 20)
GUICtrlCreateLabel("Коэфф. для перемещения графика U2 вверх/вниз. (оранж, экспонента)", 55, 400, 360, 17)

$k300 = GUICtrlCreateInput("0", 10, 423, 40, 20)
GUICtrlCreateLabel("Коэфф. для перемещения графика U3 вверх/вниз (зелён. стаб.ток).", 55, 425, 360, 17)

$R1rt00 = GUICtrlCreateInput("0.1", 10, 448, 40, 20)
GUICtrlCreateLabel("Сопротивление первичной обмотки трансформатора, Ом.", 55, 450, 360, 17)

$R2rt00 = GUICtrlCreateInput("0.1", 10, 473, 40, 20)
GUICtrlCreateLabel("Сопротивление вторичной обмотки трансформатора, Ом.", 55, 475, 360, 17)

$ktr00 = GUICtrlCreateInput("1", 10, 498, 40, 20)
GUICtrlCreateLabel("Коэфф. Трансформации (повышающий, если kтр>1).", 55, 500, 360, 17)

_Read()

GUICtrlCreateLabel('', 250, 303, 1, 63, 0x11)
$Label_Ucr = GUICtrlCreateLabel('', 260, 300, 190, 17)
$Label_In = GUICtrlCreateLabel('', 260, 325, 190, 17)
$Label_kp = GUICtrlCreateLabel('', 260, 350, 190, 17)

; Создание окна диаграммы
$Graph = _GraphGDIPlus_Create($GUI, 40, 10, 530, 260, 0xFF000000, 0xFFCEE3E0)

;рисуем графики при старте
_start()

GUISetState()

While 1
    $msg = GUIGetMsg()
    Select
        Case $msg = $start
            _Read()
            _start()
        Case $msg = -3
            Exit
    EndSelect
WEnd

Func
_Read() ; читаем комбобоксы, высчитываем коэф.
    $Um = GUICtrlRead($Um00)
    $Rn = GUICtrlRead($Rn00)
    $Cf = GUICtrlRead($Cf00)
    $f = GUICtrlRead($f00)
    $k2 = GUICtrlRead($k200)
    $k3 = GUICtrlRead($k300)
    $R1rt = GUICtrlRead($R1rt00)
    $R2rt = GUICtrlRead($R2rt00)
    $ktr = GUICtrlRead($ktr00)
    $In = $Um / $Rn
    $Rtr = $R1rt * $ktr + $R2rt
    $kp = 1 - $Rtr / ($Rtr + $Rn)
    $Ucr = $Um / Sqrt(2)
    $Ud1 = ($Um + $k3) * $kp
    $Ud2 = $Ud1 - ($Um - 50000 * $Um / ($f * $Rn * $Cf) + $k3) * $kp
    $Ar = ASin($Ud2 / ($Ud1 * 0.025 * 3.14))
EndFunc   ;==>_Read

Func _start()
    _GraphGDIPlus_Clear($Graph)
    ;----- шкала по оси XY
    _GraphGDIPlus_Set_RangeX($Graph, 0, 20, 10, 1, 0)
    _GraphGDIPlus_Set_RangeY($Graph, 0, $Um * 1.1, 10, 1, 1)
    ;----------------------------------------------------------макс, деление, ,округление
    ;----- сетка по оси XY
    _GraphGDIPlus_Set_RangeX($Graph, 1, 0xFF6993BE)
    _GraphGDIPlus_Set_RangeY($Graph, $Um * 1.1 / 10, 0xFF6993BE)
    _GraphGDIPlus_Set_PenSize($Graph, 1)

    ; цвет графиков указывается в RGB, т.е. 0xFF339966=0xFF+RGB
    _Draw_Graph3(0xFF339966) ; U3 разряд стабильным током
    _Draw_none() ; обход графика за пределами окна, так как графики рисует одна линия
    _Draw_Graph31(0xFF800080) ; U31 касательнаяв точке пересечения
    _Draw_none() ; обход
    _Draw_Graph2(0xFFFF6600) ; U2 экспонента разряда на постоянное сопротивление
    _Draw_none() ; обход
    _Draw_Graph1(0xFF0000FF) ; U1 синусоида после диодов
    _Draw_none() ; обход
    _GraphGDIPlus_Refresh($Graph)
    ; установка параметров после пересчёта
    GUICtrlSetData($Label_Ucr, 'Uср.кв =' & Round($Ucr, 2) & ' B (без конденсатора)')
    GUICtrlSetData($Label_In, 'Начальный ток нагрузки =' & Round($In, 2) & ' А')
    GUICtrlSetData($Label_kp, 'Коэфф. падения напряжения =' & Round($kp, 2) & ' %')
EndFunc   ;==>_start

Func _Draw_none()
    _GraphGDIPlus_Plot_Line($Graph, 21, -1)
    _GraphGDIPlus_Plot_Line($Graph, -1, -1)
EndFunc   ;==>_Draw_none

Func _Draw_Graph1($ColorGr)
    _GraphGDIPlus_Set_PenColor($Graph, $ColorGr)
    For $i = 0 To 20
        $yy = $i * 3.14 / 20
        $U1 = $Um * Sqrt(Cos($yy) ^ 2) * $kp
        _GraphGDIPlus_Plot_Line($Graph, $i, $U1)
    Next
EndFunc
  ;==>_Draw_Graph1

Func _Draw_Graph2($ColorGr)
    _GraphGDIPlus_Set_PenColor($Graph, $ColorGr)
    For $i = 0 To 20
        $tt = 50 * $i / $f
        $U2 = $Um * Exp(-1000 * $tt / ($Rn * $Cf)) * $kp + $k2
        _GraphGDIPlus_Plot_Line($Graph, $i, $U2)
    Next
EndFunc
  ;==>_Draw_Graph2

Func _Draw_Graph3($ColorGr)
    _GraphGDIPlus_Set_PenColor($Graph, $ColorGr)
    For $i = 0 To 20
        $tt = 50 * $i / $f
        $yy = $i * 3.14 / 20
        $U3 = ($Um - 1000 * $Um * $tt / ($Rn * $Cf) + $k3) * $kp
        _GraphGDIPlus_Plot_Line($Graph, $i, $U3)
    Next
EndFunc
  ;==>_Draw_Graph3

Func _Draw_Graph31($ColorGr)
    _GraphGDIPlus_Set_PenColor($Graph, $ColorGr)
    For $i = 0 To 20
        $tt = 50 * $i / $f
        $U31 = (Cos($Ar) - Sin($Ar) * ($tt * 3.14 / 10 - $Ar)) * $Um * $kp
        _GraphGDIPlus_Plot_Line($Graph, $i, $U31)
    Next
EndFunc
  ;==>_Draw_Graph31

Категория: Скрипты для WindowsXP | Добавил: AZJIO (23.05.2010)
Просмотров: 4184 | Рейтинг: 0.0/0
Всего комментариев: 0
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]
Вход
Друзья сайта
  • Справки AZJIO
  • USBTOR
  • PureBasic (Ru)
  • PureBasic (En)
  • AutoIT3 - Ru.Board
  • autoit-script.ru
  • autoitscript.com
  • WinPE - Ru.Board
  • Статистика

    Онлайн всего: 1
    Гостей: 1
    Пользователей: 0
    ЮMoney

    Мой кошелёк

    ЮMoney: 4100117604217624


    AZJIO © 2024