Программа 33.2
100 'ФИЛЬТР ЧЕБЫШЕВА – ВЫЧИСЛЕНИЕ ВЕСОВЫХ КОЭФФИЦИЕНТОВ
110 '
120 'НАЧАЛЬНЫЕ ЗНАЧЕНИЯ
130 DIM A[22] 'содержит коэффициенты a по завершении выполнения программы
140 DIM B[22] 'содержит коэффициенты b по завершении выполнения программы
150 DIM TA[22] 'используется внутри программы для объединения ступеней
160 DIM TB[22] 'используется внутри программы для объединения ступеней
170 '
180 FOR I% = 0 TO 22
190 A[I%] = 0
200 B[I%] = 0
210 NEXT I%
220 '
230 A[2] = 1
240 B[2] = 1
250 PI = 3.14159265
260 'ВВОД ЧЕТЫРЁХ ПАРАМЕТРОВ ФИЛЬТРА
270 INPUT "Введите частоту среза (от 0 до 0.5): ", FC
280 INPUT "Введите 0 для НЧ-фильтра, 1 для ВЧ-фильтра: ", LH
290 INPUT "Введите размах колебаний АЧХ в процентах (0…29): ", PR
300 INPUT "Введите количество полюсов (2,4,...20): ", NP
310 '
320 FOR P% = 1 TO NP/2 'ЦИКЛ ДЛЯ КАЖДОЙ ПАРЫ ПОЛЮСОВ
330 '
340 GOSUB 1000 'Подпрограмма (Программа 33.3)
350 '
360 FOR I% = 0 TO 22 'Добавление коэффициентов в каскад
370 TA[I%] = A[I%]
380 TB[I%] = B[I%]
390 NEXT I%
400 '
410 FOR I% = 2 TO 22
420 A[I%] = A0*TA[I%] + A1*TA[I%-1] + A2*TA[I%-2]
430 B[I%] = TB[I%] - B1*TB[I%-1] - B2*TB[I%-2]
440 NEXT I%
450 '
460 NEXT P%
470 '
480 B[2] = 0 'Окончание объединения коэффициентов
490 FOR I% = 0 TO 20
500 A[I%] = A[I%+2]
510 B[I%] = -B[I%+2]
520 NEXT I%
530 '
540 SA = 0 'НОРМИРОВАНИЕ КОЭФФИЦИЕНТА УСИЛЕНИЯ
550 SB = 0
560 FOR I% = 0 TO 20
570 IF LH = 0 THEN SA = SA + A[I%]
580 IF LH = 0 THEN SB = SB + B[I%]
590 IF LH = 1 THEN SA = SA + A[I%] * (-1)^I%
600 IF LH = 1 THEN SB = SB + B[I%] * (-1)^I%
610 NEXT I%
620 '
630 GAIN = SA / (1 - SB)
640 '
650 FOR I% = 0 TO 20
660 A[I%] = A[I%] / GAIN
670 NEXT I%
680 ' 'Результирующие коэффициенты содержатся в A[ ] и B[ ]
690 END