Камчатский государственный технический университет
Ю.В. Марапулец, А.О. Щербина, М.А. Мищенко, А.В. Шадрин
МЕТОДЫ ИССЛ...
48 downloads
182 Views
3MB Size
Report
This content was uploaded by our users and we assume good faith they have the permission to share this book. If you own the copyright to this book and it is wrongfully on our website, we offer a simple DMCA procedure to remove your content from our site. Start by pressing the button below!
Report copyright / DMCA form
Камчатский государственный технический университет
Ю.В. Марапулец, А.О. Щербина, М.А. Мищенко, А.В. Шадрин
МЕТОДЫ ИССЛЕДОВАНИЯ ВЫСОКОЧАСТОТНОЙ ГЕОАКУСТИЧЕСКОЙ ЭМИССИИ Монография
Петропавловск-Камчатский 2008
УДК 534.6 ББК 22.32 М25 Авторы глав: Ю.В. Марапулец – общая редакция монографии, введение, главы 1, 3, 4, заключение; А.О. Щербина – главы 2, 4; М.А. Мищенко – глава 2; А.В. Шадрин – глава 5 Рецензент Г.А. Пюкке, доктор технических наук, профессор кафедры систем управления КамчатГТУ Марапулец, Юрий Валентинович М25
Методы исследования высокочастотной геоакустической эмиссии: Монография / Ю.В. Марапулец, А.О. Щербина, М.А. Мищенко, А.В. Шадрин. – ПетропавловскКамчатский: КамчатГТУ, 2008. – 105 с. ISBN 978–5–328–00181–6 Исследование высокочастотной геоакустической эмиссии является одним из перспективных направлений в изучении физики предвестников землетрясений и развитии методов их прогноза. В работе рассмотрены методы регистрации и анализа сигналов геоакустической эмиссии. Особое внимание уделено вопросам технической реализации аппаратно-программных комплексов. Для выявления высокочастотных сигналов на фоне помех реализованы нейросетевые методы. Приведена архитектура нейронной сети и результаты ее использования. Для исследования анизотропии геоакустических сигналов использованы векторно-фазовые методы. В работе реализованы методы автоматизации поиска геоакустических импульсов и выявления их направленности. УДК 534.6 ББК 22.32
ISBN 978–5–328–00181–6
© КамчатГТУ, 2008 © Авторы, 2008
2
ОГЛАВЛЕНИЕ Введение .................................................................................
4
Глава 1. Постановка задачи и методика исследований ....
6
Глава 2. Аппаратно-программная реализация комплекса ........................................................... 12 2.1. Система регистрации широкополосного геоакустического сигнала ......................................... 12 2.2. Система фильтрации геоакустического сигнала ......................................... 40 Глава 3. Многообразие форм акустических сигналов ...... 56 Глава 4. Применение векторно-фазовых методов для исследования анизотропии акустических сигналов .......................................................... 67 Глава 5. Применение нейронных сетей для выявления и классификации геоакустических аномалий ................................................... 77 Заключение ............................................................................ 101 Литература ............................................................................. 103
3
ВВЕДЕНИЕ Землетрясение – одно из наиболее страшных природных катастроф, уносящее десятки и сотни тысяч человеческих жизней и вызывающее опустошительные разрушения на огромных пространствах. Примером может служить мощное землетрясение, произошедшее 7 декабря 1988 г. в Армении и получившее название Спитакского по наименованию города, полностью стертого с лица Земли. Лос-Анджелес в США, Кобе в Японии, Нефтегорск в России… Этот список можно продолжать бесконечно, так как землетрясения разной силы в различных регионах земного шара происходят постоянно, нанося огромный материальный ущерб и приводя к многочисленным жертвам. Ученые разных стран изучают природу сейсмических событий и пытаются разработать системы их прогноза. К сожалению, до сих пор не создано эффективных систем, позволяющих предсказать место и время готовящегося землетрясения. В настоящее время наиболее популярной теорией, объясняющей причины возникновения землетрясений, является концепция тектоники плит. Согласно ей литосфера состоит из граничащих между собой больших плит, которые перемещаются относительно друг друга. При этом наблюдается тенденция, при которой океанические плиты со скоростью нескольких сантиметров в год наползают на материковые, т. е. испытывают субдукцию. Зоны субдукции образуют участки (гипоцентры) с очень высокими уровнями напряжений, в которых и происходят наиболее сильные землетрясения. Следовательно, землетрясение – это не внезапное событие, а процесс, который готовится достаточно длительное время и состоит из нескольких этапов. Первый этап, самый продолжительный во времени, может длиться годами и характеризуется накоплением упругой потенциальной энергии в гипоцентральной области. Следующий этап быстрого роста 4
упругих напряжений, приводящих к лавинному трещинообразованию и подготовке магистрального разрыва, измеряется уже сутками или часами [18, 20]. И, наконец, последний этап – ослабление энергии и процессов разрушения, наступление стадии покоя. Из вышеизложенного следует, что поскольку землетрясение – это событие, которое готовится достаточно продолжительное время, то возможно его предсказание. Наибольший интерес в этом случае представляет второй этап – процесс лавинного трещинообразования. Мировые исследования, которые проводятся учеными в различных сейсмоактивных районах, свидетельствуют о том, что перед землетрясениями возникают аномалии в огромном количестве геофизических полей. Это изменения в электромагнитных и акустических полях, увеличение концентрации газа радона, изменения химического состава и давления подземных вод и т. д. В настоящее время неоспоримым является тот факт, что только комплексные наблюдения за различными геофизическими полями позволят в будущем разработать эффективные методы прогноза землетрясений. Причем чем больше будет таких исследований, тем более вероятен правильный прогноз. На современной стадии исследований необходимо тщательное изучение аномалий, возникающих перед землетрясениями в каждом виде наблюдений, объяснение их физической природы, математическое и физическое моделирование явлений. Данная работа посвящена исследованию одного из перспективных методов прогноза землетрясений – высокочастотной геоакустической эмиссии (ГАЭ).
5
Глава 1. ПОСТАНОВКА ЗАДАЧИ И МЕТОДИКА ИССЛЕДОВАНИЙ Анализ имеющейся в литературе информации о биологических предвестниках землетрясений свидетельствует о способности млекопитающих, птиц, земноводных и рыб предчувствовать приближение землетрясений на расстояниях до 200 км, что выражается в появлении у них беспокойного поведения за сутки или часы до землетрясения. Подобные явления известны человечеству уже более 2000 лет. Предполагается, что главным источником такого поведения являются аномалии в электромагнитных и акустических полях. Часто в литературе встречаются и сообщения от местных жителей, которые за несколько часов до землетрясения слушали гул и странные звуки, идущие из глубины земли. Описания таких явлений приводятся в литературе Японии, Новой Зеландии, Америки и Азии. Ученые давно проявляли интерес к подобному явлению. Еще в конце XIX в. английский астроном Дж. Дарвин описывал эксперимент Де Росси из Рима, который установил микрофон под землей на глубине 20 метров и услышал странные звуки, похожие на взрывы. Через полчаса произошло значительное землетрясение. Подобные эксперименты проводились и в более позднее время. Так, например, в Армении во время Спитакского землетрясения было зафиксировано в 80 км от эпицентра увеличение амплитуды геоакустической эмиссии в диапазоне 800–1200 Гц за 12 часов до и после основного события [15]. Подобный эффект был зафиксирован и в 1998 г. в Японии в сейсмологической обсерватории Мацуширо на частотах 500 и 1000 Гц [5]. Но несмотря на тот факт, что наблюдения геоакустической эмиссии в высокочастотном (звуковом) диапазоне частот проводятся уже достаточно длительное время и в 6
результате таких исследований наблюдались аномалии перед землетрясениями, только в последние годы данному направлению уделяется достаточно пристальное внимание. Это объясняется двумя факторами. Во-первых, до последнего времени был неизвестен механизм передачи звука килогерцового диапазона на расстояния в сотни километров (именно на таком расстоянии от готовящегося землетрясения наблюдались высокочастотные аномалии акустической эмиссии). Во-вторых, сигналы геоакустической эмиссии находятся за пределами чувствительности традиционных приборов, используемых в сейсмологических исследованиях [4]. В настоящее время установлено, что из будущих очагов землетрясений хорошо распространяются деформационные процессы, которые приводят к образованию зон поверхностной дилатансии размерностью до сотен километров [1, 2, 20]. Данное явление обусловлено возникновением отклика породы на динамическую локальную перестройку структуры и сопровождается испусканием импульсов высокочастотных акустических волн как из-за образования микроразломов и трещин, так и из-за подвижек в существующих разломах, заполненных обычно водонасыщенными осадочными породами. Таким образом, наблюдаемые сигналы высокочастотной геоакустической эмиссии не распространяются из очага готовящегося землетрясения, а генерируются в непосредственной близости от места наблюдения под действием деформационных сил. Для регистрации таких сигналов можно использовать магнитоупругие сейсмоакустические приемники [3] или пьезокерамические преобразователи [10]. Пьезокерамические преобразователи (гидрофоны), позволяющие исследовать сигналы в диапазоне от долей герца до десятка килогерц, более эффективны. Но подобные приборы изготавливаются для работы в водной среде, поэтому их необходимо использовать либо в прибрежной морской зоне [16, 19], либо в небольших естественных или искусственных водоемах на земле [11]. Второй способ более целесообразен, так как в прибрежной зоне присутствуют помехи от прибоя, судоходства и других 7
источников океанических шумов, мешающие выявлению сигналов сейсмического происхождения. В качестве гидрофона можно использовать любые акустические приемники, построенные на пьезокерамических преобразователях, предназначенные для работы в звуковом диапазоне частот с чувствительностью в сотни мВ/Па. В частности, в работе [8] используется система из четырех разнонаправленных керамических приемников градиента давления силового типа с предусилителями, объединенных в единую конструкцию. Чувствительность приемников с предусилителями в килогерцовом диапазоне составляет сотни мВ/Па. Применение гидрофонов другого типа, например типа 1П2М производства концерна «Океанприбор», векторно-фазового комбинированного приемника Г3304-0.1 производства ЗАО «Геоакустика» при ФГУП ВНИИФТРИ, привело к аналогичным результатам. Регистрацию и первичный анализ сигналов ГАЭ целесообразно производить как во всем принимаемом диапазоне частот (0,1–10 000 Гц), так и на выходе полосовых фильтров, делящих частотный диапазон на несколько поддиапазонов. Такая система позволит оперативно выявлять акустические сигналы различной природы и при этом анализировать их в широком диапазоне. Структурная схема предлагаемой системы представлена на рис. 1.1. Сигналы с выходов четырех пьезокерамических преобразователей усиливаются, оцифровываются с частотой дискретизации не менее 20 кГц и записываются на «жесткий диск» персонального компьютера. В качестве устройства для оцифровки могут использоваться АЦП или звуковые карты. По ряду параметров современные звуковые карты превосходят АЦП средней ценовой категории, а именно: – цена качественной звуковой карты на порядок ниже цены среднего АЦП; – частота дискретизации звуковых карт выше частоты дискретизации АЦП; современные звуковые карты позволяют использовать частоту дискретизации 96 кГц и выше; 8
– как правило, разрядность звуковой карты равна 16 или 24 бит, АЦП – 14 бит; – все звуковые карты имеют стандартный физический интерфейс и могут быть быстро и без ущерба заменены аналогами от других производителей; – стандартизация программного интерфейса обеспечивается драйвером звуковой карты и гарантируется операционной системой, что позволяет менять техническое оснащение без изменения программного продукта; – формат звуковых карт Wave является общепринятым форматом звуковых данных. Существует огромное количество программных продуктов для профессионалов, работающих со звуком, которые позволяют производить анализ данных с применением различных численных и спектральных методов. Недостатком звуковых карт является ограничение числа каналов записи. Их, как правило, два, следствие чего необходимо использовать несколько звуковых карт с организацией синхронизации между ними. Некоторые производители обеспечивают такую синхронизацию на аппаратном уровне, например компания «Terratec» в линейке звуковых карт Phase. С учетом вышесказанного использование звуковых карт предпочтительнее АЦП, что, конечно, не исключает возможности применения последних. Размеры современных «жестких дисков» (500 ГБ и более) позволяют с учетом четырех каналов записи и частоты дискретизации 22 кГц накапливать широкополосные данные примерно в течение месяца, что вполне достаточно для их детального анализа в лаборатории. Одновременно с записью широкополосных сигналов на второй ЭВМ реализуется система фильтрации сигналов в семи частотных поддиапазонах: 0,1–10; 10–50; 50–200; 200–700; 700–1500; 1500–6000; 6000–10 000 Гц. Подобное разделение позволяет отдельно рассматривать сигналы в сейсмическом, высокочастотном сейсмическом (ВСШ) и сейсмоакустическом диапазонах частот. Необходимость второй ЭВМ обусловлена высокой нагрузкой центрального процессора при расчете цифровых фильтров в реальном времени. Выполнение этой задачи 9
на первой ЭВМ может привести к частичной потере данных при записи на «жесткий диск», что нежелательно.
Рис. 1.1. Структурная схема системы регистрации ГАЭ
Сигналы на выходе каждого из семи частотных поддиапазонов детектируются (рассчитывается абсолютное значение) и накапливаются за 4 секунды. Таким образом, один раз в 4 секунды по каждому пространственному каналу рассчитываются семь отсчетов. Понятно, что объем занимаемого 10
места на «жестком диске» в данном случае многократно меньше записи широкополосного сигнала. Суточные данные составляют около 10 МБ, что позволяет беспрепятственно накапливать их на сменных носителях, таких как CD или DVD диски. К сожалению, полностью восстановить всю информацию по этим данным невозможно. В них содержатся только изменения интегрального уровня сигнала во времени, по которому можно судить о наличии или отсутствии аномалий в соответствующих частотных поддиапазонах. Детальный же анализ аномалий возможен только по широкополосным данным, накапливаемым на первой ЭВМ. В последующих главах аппаратно-программная реализация комплекса будет рассмотрена более подробно.
11
Глава 2. АППАРАТНО-ПРОГРАММНАЯ РЕАЛИЗАЦИЯ КОМПЛЕКСА 2.1. Система регистрации широкополосного геоакустического сигнала Для организации сбора широкополосного геоакустического сигнала в режиме реального времени разработан аппаратнопрограммный комплекс [21], представленный на рис. 2.1. Программный продукт написан на языке программирования C++, среда разработки – Microsoft Visual Studio. Основными компонентами системы является: система предварительного усиления, устройства оцифровки аналогового сигнала, подсистема предварительной обработки и подсистема записи и хранения оцифрованных данных. Система предварительного усиления предназначена для нормализации уровня сигнала, подаваемого на вход устройств оцифровки. Усилительная система имеет известный и стабильный коэффициент усиления, который учитывается при пересчете разрядов АЦП в величину, описывающую физическую природу сигнала. В качестве устройств оцифровки аналогового сигнала выбраны звуковые карты. Как было указано выше, основным недостатком в этом случае являются проблемы при синхронизации записи между картами из-за аппаратного расхождения частот тактовых генераторов. Решить проблему возможно применением комплекса следующих мер: – использование звуковых карт, имеющих возможность аппаратной или программной синхронизации тактовых генераторов; – реализация одновременного старта записи небольших по времени файлов. При небольшой продолжительности файлов ошибка синхронизации не успевает накапливаться до существенного значения и может быть приравнена к нулю. 12
Рис. 2.1. Структурная схема системы регистрации широкополосных сигналов
Существенную сложность в разработке системы добавляет случайное поведение операционных систем семейства Microsoft Windows при управлении аппаратными устройствами. При работе со звуковыми картами это может проявляться в виде их несинхронного старта, причем разница по времени между запусками является случайной величиной и не может быть вычислена заранее. Корни проблемы лежат в самой операционной системе, поэтому она не имеет абсолютного решения при использовании Microsoft Windows. Одним из методов достижения приемлемых результатов является точная запись времени прихода данных со звуковых карт, но при этом точность времени определяется возможностью таймеров операционной системы и, как правило, составляет от нескольких сотен микросекунд до миллисекунд. Другим методом является запрос позиций записи у драйверов звуковых карт после запуска последней из них. Полученные значения можно использовать для вычисления расхождения между картами. Но этот метод имеет недостаток: точность определения реальной позиции зависит от используемого устройства. Это 13
может быть либо конкретный звуковой отсчет, либо небольшая группа отсчетов, находящаяся в данный момент в обработке. Кроме того, как правило, все адаптеры имеют скрытую небольшую очередь между встроенным процессором и ЦАП/АЦП, так что полученная от драйвера позиция почти всегда будет отличаться от реальной на несколько отсчетов. В разработанной системе полученные погрешности записываются непосредственно в тег комментариев RIFF-файла. Использование данных из комментария позволяет в дальнейшем учитывать ошибки синхронизации без специальных программных средств. Для автоматического учета и компенсации расхождения звуковых карт необходимо в программах обработки предусмотреть соответствующие функции по определению и учету погрешностей. Все созданные файлы регистрируются в специальном индексном файле с указанием точного времени создания. Время создания определяется с помощью функций операционной системы, которая постоянно синхронизируется с сигналами точного времени, полученными от системы GPS. Для представления аналогового сигнала в цифровом виде используется традиционный способ цифрового кодирования PCM (Pulse Code Modulation – импульсно-кодовая модуляция, или ИКМ). Совокупность основных параметров цифрового потока ИКМ – способ кодирования, частота дискретизации, количество каналов (стерео/моно) и разрядность отсчета – называется форматом потока. Главным параметром формата является способ кодирования, который называется также признаком формата. Каждый способ кодирования порождает группу однотипных форматов, различающихся лишь точностью представления и, следовательно, качеством передачи звука. Основные частоты дискретизации (11 025, 22 050 и 44 100 Гц) в сочетаниях с различным количеством каналов (1 или 2) и различной разрядностью отсчета (8 или 16) при способе кодирования PCM образуют 12 типовых форматов. Частота 11 025 Гц (полоса звуковых частот – до 5 кГц) приблизительно соответствует качеству телефонного сигнала, частота 22 050 Гц (полоса до 10 кГц) – качеству среднего радиоприемника, частота 14
44 100 Гц (полоса до 20 кГц) – качеству звуковой аппаратуры высшего класса. Наименьшей единицей звукового потока является блок. Соответственно размер каждого буфера, передаваемого или принимаемого звуковой подсистемой, кратен размеру блока. В формате PCM блоком считается набор отсчетов, передаваемых за один период частоты дискретизации: один отсчет – для монофонических потоков, два – для стереофонических и т. д. Таким образом, блоки следуют друг за другом с частотой дискретизации, а отсчеты в блоках размещаются начиная с левого (нулевого) канала. Если отсчет занимает более одного байта, то они размещаются по старшинству в порядке возрастания, как это принято в процессорах Intel. Восьмиразрядные отсчеты в PCM представляются в виде беззнаковых целых чисел, за нуль сигнала принято «центральное» значение 128 (шестнадцатеричное – 80). Таким образом, предельной отрицательной амплитуде сигнала соответствует нулевое значение отсчета, а предельной положительной – значение FF. Отсчеты с разрядностью более восьми представляются в виде целых чисел со знаком в стандартном формате Intel, за нуль сигнала принято нулевое значение отсчета. Здесь может без каких-либо ограничений применяться обычная целочисленная арифметика с применением типов данных short (16-разрядный) и long (32-разрядный). Если разрядность отсчета превышает 16 разрядов, то она может быть и не кратной 1 байту – современные звуковые адаптеры могут использовать от 18 до 24 разрядов на отсчет. В таком случае отсчет выравнивается по старшей границе трех- или четырехбайтового слова, а лишние младшие разряды заполняются нулями. В целях оптимизации некоторые адаптеры и драйверы могут использовать четырехбайтовые 32-разрядные слова для отсчетов с любой разрядностью, большей 16. В любом случае фактическая разрядность отсчета задается параметром разрядности формата, а размер слова, в котором размещается отсчет, определяется из размера блока путем деления его на количество каналов в потоке. 15
Преобразование форматов захваченного сигнала, а также разделение блоков на отдельные цифровые потоки, соответствующие различным каналам, осуществляет специальная подсистема предварительной обработки, включенная в состав программной части разработанной системы регистрации акустического сигнала. Разделенные подсистемой предварительной обработки цифровые потоки передаются подсистеме записи и хранения цифровых данных. Запись производится в формате RIFF (WAVE) без использования сжатия. Использование режима записи без сжатия продиктовано необходимостью сохранения сигнала в максимально точном виде. Обратной стороной такого подхода является интенсивный поток данных, записываемых на диск. Например, при использовании двух звуковых карт с частотой дискретизации 44 100 Гц и разрядностью 16 бит за сутки накапливается около 30 Гбайт данных. В связи со сложностью обработки интенсивного потока данных отдельно проработана ситуация переполнения носителей информации (при обеспечении непрерывности записи данных). Это достигается удалением наиболее устаревших данных, тем самым освобождается место новым. Для этого все записываемые за сутки данные сохраняются в отдельный каталог. По наступлении новых суток система удаляет самую устаревшую директорию и создает новую, в которую будут записываться свежие данные. Таким образом, на диске постоянно содержатся самые последние данные за несколько прошедших суток. Число одновременно хранимых суток задается оператором исходя из объема свободного пространства на используемом носителе. Кроме записи широкополосного геоакустического сигнала производится и его отображение. На форму отображаемых сигналов оказывают заметное влияние помехи от питающей сети, на фоне которых плохо просматривается полезная информация. Поэтому до визуализации информации применены процедуры фильтрации (высокочастотный КИХ-фильтр с частотой среза 1 кГц) и усреднения. 16
На рис. 2.2 представлена архитектура программного продукта, в котором заложена возможность одновременной и независимой работы с несколькими звуковыми картами. При этом каждая звуковая карта может регистрировать данные, используя различные параметры оцифровки аналогового сигнала. Для этого используется система независимых трактов обработки, работающих в отдельных потоках выполнения. Каждый тракт является объектом класса обработки, за которым при создании закреплена одна из звуковых карт. В состав каждого тракта обработки включены специализированные классы, реализующие необходимые преобразования сигнала. Все тракты функционально независимы, и работа каждого из них не влияет на работу остальных.
Рис. 2.2. Тракт обработки звукового сигнала (реализация для одной звуковой карты)
При проектировании системы большое внимание было уделено приданию ей свойств максимальной гибкости, для чего был разработан родительский (базовый) класс передачи 17
цифровых данных. Основной задачей, решаемой классом, является реализация унифицированной системы передачи новых данных между блоками обработки. Кроме того, на него возложены задачи управления параметрами объектов и обеспечение событийной работы дочерних классов. Для реализации унифицированной системы передачи данных был разработан специальный формат данных. При этом передаваемые данные оформлены в виде класса, в функции которого включены операции выделения и освобождения памяти, обеспечения целостности данных при многопоточной работе программы. Кроме того, в него включены дополнительные поля, позволяющие типизировать содержащиеся данные. Типизация позволяет объединить механизмы передачи новых данных и управления параметрами блока. Так как базовый класс передачи данных предназначен для унификации семантики передачи данных, он организует прием данных от предыдущего объекта и передачу их следующему, а также функции управления связями с соседними объектами. При этом механизм передачи данных типизирует передаваемую информацию и при ее получении организовывает сортировку и передачу внутреннему обработчику, реализованному дочерними классами. Иерархия классов для передачи данных представлена на рис. 2.3.
Рис. 2.3. Иерархия классов обработки
18
Интерфейс IReceiver необходим для унификации приема данных любым объектом и имеет следующее описание: class IReceiver { protected: virtual long OnCallbackEvent(long lSystemID, long lMessageID, long lParam1, long lParam2) = 0; };
IReceiver является «чисто» виртуальным классом. Классприемник должен наследоваться от него и обязательно переопределять виртуальную функцию OnCallbackEvent, которая используется для приема данных. Класс CNode реализует функции приема и передачи данных, а также управление связями с соседними блоками и сортировку сообщений. Данный класс является полностью законченным и осуществляет все необходимые функции, но не выполняет какой-либо обработки данных. Класс CWaveBlock модифицирует класс CNode для нужд обработки звука и осуществляет специализацию CNode. Классы в иерархии до класса CWaveBlock рассчитаны на использование в любых системах и являются универсальными. Класс CWaveBlock – специализированный класс, оптимизированный для обработки звука. Для реализации функции взаимодействия отдельных блоков в состав класса CNode включены четыре специальные переменные: – указатель на следующий объект обработки; – указатель на предыдущий объект обработки; – указатель на объект обработки ошибок; – указатель на объект управления. Все эти переменные имеют тип CNode*. Передача данных производится путем вызова по указателю на приемник информации функции OnCallbackEvent, унаследованной от интерфейса IReceiver. Вышеуказанные четыре переменные образуют систему связей, которые позволяют создать выбранную топологию (рис. 2.4). 19
Каждый объект может быть как приемником, так и источником информации. Также данная система связей обеспечивает двунаправленную передачу данных за счет введенного указателя на предыдущий объект.
Рис. 2.4. Система связей класса CNode
Используя связи, можно построить своего рода сеть обработки данных. Учитывая то, что базовый класс является универсальным, полученная сеть может обрабатывать данные любой спецификации. Общей остается только возможность централизованного управления и обработки ошибок. Для примера показан простейший участок сети (рис. 2.5). Благодаря универсальности класса CNode появилась возможность использовать в системе только этот класс (и его потомков) для решения всех необходимых задач. Особенность выполняемых функций блоков системы определяется при наследовании от базового класса путем придания производному классу определенной спецификации. Сам же класс CNode берет на себя функции промежуточного звена в передаче данных и контроль связей между соседними блоками. В общем случае любому соседнему объекту можно послать любую информацию, но в системе принято отсылать только те данные, на которые рассчитан объект-приемник. Это значит, что если отослать обработчику ошибок информацию, отличную от информации об ошибке, то он, проверив ID команды и тип данных, вернет в ответ информацию о неправильном формате данных. 20
Рис. 2.5. Пример сети обработки данных
Так как класс CNode является базовым классом, то для выполнения каких-либо полезных задач используются его производные рабочие классы, что позволяет их свободно комбинировать, не обращая внимания на конкретную специализацию, реализованную в родительском классе. Единственным отличием блоков в данном случае является набор параметров, необходимых для их правильной инициализации и работы. Работа с параметрами предполагает точное знание рабочего класса на этапе компиляции программы, т. е. установка и чтение параметров являются статическими действиями, что противоречит динамичной структуре программы. Этот факт делает невозможной свободную комбинацию объектов. Для решения этой проблемы в состав класса CNode были добавлены функции установки и чтения параметров по их идентификатору, которые стандартизуют работу. В состав класса был введен список связанных параметров. При очередном наследовании новый класс добавляет в него свои параметры и их численные идентификаторы. При операциях с параметрами базовый класс пролистывает список и, найдя нужный элемент, выполняет над ним указанную операцию. 21
Для реализации работы с параметрами используется механизм передачи команды класса CNode (рис. 2.6).
Рис. 2.6. Использование механизма передачи команды
Этот класс в функции OnCallBackEvent производит также сортировку входящих команд по обработчикам. Это позволяет при наследовании переопределять только необходимые обработчики команд, что существенно экономит время разработки. При этом пользователю предоставляется следующий набор функций, которые могут переопределяться при необходимости: virtual long OnError(long lErrorID, long lpErrorDescription); // Вызывается при необходимости обработать ошибку virtual long OnRequestWait(long lRequestID, long lRequestValue); // Выполнить немедленно запрос внешнего блока virtual long OnRequestSend(long lRequestID, long lpRequestUser); // Выполнить запрос когда удобно, // но возвратить управление немедленно virtual long OnReleaseAllRelations(); // Удалить все связи с внешними блоками virtual long OnCreateBlock(long lParam1, long lParam2); // Создать блок (один раз в жизни объекта) virtual long OnInitBlock (long lParam1, long lParam2); // Инициализировать блок virtual long OnDestroyBlock(long lParam1, long lParam2); // Удалить объект (один раз в жизни объекта)
22
virtual long OnSetParam(long lParamID, long lParamValue); // Установить параметр virtual long OnGetParam(long lParamID, long lParamValue); // Прочитать параметр virtual long OnResetBlock(); // Сбросить все значения блока в значения по умолчанию virtual long OnAnswer(long lRequestID, long lRequestValue); // Пришел ответ на запрос OnRequestSend virtual long OnUserMsgFromPrev(long lMessageID, long lParam1, long lParam2); virtual long OnUserMsgFromNext(long lMessageID, long lParam1, long lParam2); virtual long OnMsgFromNext(long lMessageID, long lParam1, long lParam2); virtual long OnMsgFromPrev(long lMessageID, long lParam1, long lParam2); …
Все функции реализованы в базовом классе, но большинство из них только возвращают код успешного выполнения. Кроме приведенных функций событий используется некоторое количество функций из набора WinAPI: long Error (long lErrorID, char *lpErrorDescription); // Сообщить об ошибке long SendTo(CNode *lpBlock, long lDirection, long lMessageID, long lParam1, long lParam2); // Отослать сообщение объекту *lpBlock long ConnectBlock(CNode *lpBlockPtr, long lParam); // Присоединить следующий блок long ReleaseBlock(CNode *lpBlockPtr, long lParam); // Отсоединить следующий блок long SetParam(long lParamID, long lParamValue); // Установить параметр long GetParam(long lParamID, long lParamValue); // Прочесть параметр long Command(long lMessageID, long lParam1, long lParam2); // Выполнить команду long SendForward(long lMessageID, long lParam1, long lParam2); // Отослать сообщение следующему блоку long SendBackward(long lMessageID, long lParam1, long lParam2); // Отослать сообщение предыдущему блоку…
23
Влияние данного класса на производительность системы незначительна, так как активных действий он не производит, а только осуществляет перевызов других функций. При этом класс является ключевым в обеспечении гибкости системы. Структура данных описана лишь для CWaveBlock и его потомков, так как классы, находящиеся выше по иерархии, могут работать с любыми форматами. Спецификация CWaveBlock – работа со звуковыми данными, следовательно, структура данных, с которыми работает данный класс, должна отражать свойства звуковых данных. К ним относятся количество каналов и их параметры: – значения дискретизации и квантования по уровню; – время поступления данных; – идентификатор типа данных; – размер данных. Количество каналов ограничено двумя режимами – моно (один канал) и стерео (два канала). Кроме этого, новые каналы могут синтезироваться в процессе работы системы. Разное количество каналов данных является причиной объединения их в некий контейнер, являющийся, по сути, массивом каналов и содержащий информацию об их числе. При передаче данных нерационально создавать массивы в каждом блоке и организовывать их копирование при каждой передаче от одного блока к другому. Вместо этого целесообразнее создавать один контейнер в начале пути преобразования и далее передавать указатель на него. Таким образом, получается, что топология программы – это всего лишь очередность действий над определенным контейнером данных. Данный подход требует минимальных затрат памяти, но при этом порождает проблему разделения по времени операций чтения и записи в условиях многозадачности. Для временного разделения операций чтения и записи в класс передаваемых данных включены функции запроса на чтение и запись, а также механизм выполнения и отклонения запросов. Так как в корректно работающей программе доступ к данным осуществляется периодически (по мере необходи24
мости), то рано или поздно операция над данными прекращается и их можно занять для выполнения следующей операции. Поэтому механизм выполнения и отклонения запросов имеет программируемый период ожидания завершения предыдущей операции, по истечении которого запрос на доступ откланяется. Период ожидания позволяет избежать блокировки программы и, как следствие, потери всех данных при единичных сбоях системы. Защита данных обеспечивается разделением по времени операций чтения и записи в память для исключения ситуации искажения данных различными потоками. Разделение организовано следующим образом: разрешена либо запись одному потоку, либо чтение любому числу потоков (одновременное чтение не приводит к искажению). При выбранной структуре класса CNode невозможно передавать данные нескольким объектам, так как передача происходит по одному указателю, который указывает только на один объект. Поэтому для организации функции передачи данных нескольким объектам предназначен специальный класс, внутри которого содержатся два связанных списка: один – для прямой передачи, другой – для обратной. В момент, когда приходит сообщение от предыдущего блока, происходит инициализация перебора списка следующих объектов и трансляция пришедшего для них сообщения. То же самое происходит и при обратном сообщении. Таким образом, осуществляется прозрачное для блока обработки распараллеливание сообщения. Помимо основного класса в программе по ряду причин созданы дополнительные классы: 1. Повышение надежности системы. Это связано с тем, что отдельный класс легче всесторонне протестировать. Также класс может сам следить за выделенной памятью и вовремя ее удалить, что уменьшает вероятность утечки памяти. 2. Оптимизация повторного использования кода. В этом случае можно использовать функции, но класс намного удобнее благодаря инкапсуляции методов и данных в единое целое.
25
3. Реализация переносимости программы на разные платформы. Рассмотрим эти классы. Класс интерфейса памяти – самый важный из дополнительных классов, так как вся обрабатываемая информация хранится в нем. Обработка данных приводит к интенсивной работе с памятью компьютера, что приводит к очень частому ее выделению, освобождению и копированию. При малейшей неточности в работе возникнут либо ошибки недостоверности данных (при выделении памяти меньше рабочего размера), либо утечка (при выделении большего объема). Любая из этих ошибок может привести к краху системы. Особенно нежелательны утечки памяти, так как они очень сложно выявляются и, постоянно накапливаясь, в конечном итоге приводят к полному израсходованию системных ресурсов, что неизбежно вызовет крах системы. Для решения последней задачи был создан интерфейс памяти IMemoryBlock. Он позволяет контролировать освобождение памяти, чтобы не допустить ее утечки. На данный интерфейс также возложены задачи по сохранению целостности данных при одновременном доступе. Для этого используется класс управления доступом. Для большей гибкости введена возможность выбора объекта контроля доступа, что позволяет использовать одни и те же правила доступа для различных данных, а также отказаться от возможности контроля для увеличения производительности. Кроме того, данный интерфейс позволяет (за счет наследования и переопределения методов выделения и освобождения памяти) менять место хранения данных. На данный момент реализованы классы для хранения данных в стандартной куче (Heap) и в виртуальной памяти Windows. Этот же механизм позволяет реализовывать работу с памятью при переходе на другие операционные системы. В процессе разработки программ под многозадачные операционные системы часто возникает необходимость ограничивать одновременный доступ к каким-то ресурсам (память, файлы, порты ввода/вывода и т. п.). Как правило, необходимо разграничивать операции записи и чтения, так как их одно26
временное исполнение нарушит достоверность данных. Для решения этой проблемы был реализован класс управления доступом CSWMRG (Single Write Multi Read Guard) [17]. Работа данного класса осуществляется тремя функциями: virtual DWORD WaitToRead(DWORD dwMilliseconds = = INFINITE); virtual DWORD WaitToWrite(DWORD dwMilliseconds = = INFINITE); virtual VOID Done(); …
Перед доступом к объекту необходимо сделать запрос одной из первых двух функций, указав при этом период ожидания. Функции возвращают код успешности ожидания. При положительном результате (время ожидания не истекло и объект не удален во время ожидания) процесс может получить указанный доступ к защищаемому ресурсу. После работы с ресурсом поток обязан вызвать метод Done(), иначе защищаемый объект не освободится. Число вызовов функций запроса и освобождения должно совпадать. Работа класса в основном реализована с помощью критических секций (рис. 2.7), только для перехода в состояние ожидания используются события. Поэтому взаимодействие с классом происходит очень быстро, что немаловажно при реализации защиты памяти его объектом (по специфике программы это сильно влияет на производительность в целом). При попытке совместного доступа к ресурсу предпочтение отдается операции записи, что необходимо для исключения потери данных. Так как чтение разрешено нескольким потокам, то они могут, чередуясь и накладываясь друг на друга, на длительный срок занять объект. Класс-список параметров облегчает работу с параметрами в классе CNode. В функции данного класса входит добавление новых параметров, их удаление, а также поиск параметра по его идентификатору и возврат ссылки или указателя на него. Внутренне класс основан на двунаправленном связанном списке. Наличие обратного направления позволяет вдвое уменьшить время поиска параметра при случайном доступе. 27
28 Рис. 2.7. Алгоритм работы класса управления доступом
Класс проецируемого в память файла необходим для инкапсуляции многочисленных функций при работе с проекциями файлов в одном классе. Кроме этого в данный класс были включены функции создания файла, чтение/запись данных, уменьшение размера открытого файла. Основными операциями класса являются чтение и запись данных в файл. При этом объект класса следит за местоположением проекции таким образом, чтобы виртуальной памяти по адресу записи/чтения была передана физическая память, связанная с файлом на диске. Если этого не делать, а целиком спроецировать файл в память, то при некотором времени работы все остальные программы вытесняются в файл подкачки, что сильно замедляет процесс работы с памятью. Как следствие, возможна потеря новых непрерывно поступающих данных. При применении окна проекции эта проблема решается. В данном случае максимальный объем памяти, занимаемой программой, равен размеру проекций. Но с другой стороны, перемещение окна требует дополнительного процессорного времени. Поэтому в результате тестирований было решено использовать окно размером 10 Мбайт. Класс-контейнер данных CTransactionContainer предназначен для хранения звуковых данных. После предварительной обработки данные представляют собой набор одномерных массивов, которые целесообразно хранить в объектах класса памяти. Контейнер данных хранит массив объектов IMemoryBlock, а также маску каналов. В класс добавлены функции создания каналов по предложенной маске и размеру для каждого канала, а также функция их удаления. Классконтейнер необходим для удобной передачи набора каналов от одного блока к другому, и его быстродействие определяется производительностью класса памяти. Так как класс CTransactionContainer не имеет методов для выборки отдельных каналов или их фильтрации, был разработан класс-перечислитель контейнеров CTransactionContainerEnum, который осуществляет эти функции. Применение данного класса для организации фильтрации необходимо в 29
условиях многозадачности, так как маска блока, текущие позиции и таблицы переиндексации являются внутренней для потока информацией. Если бы эти данные были включены в класс CTransactionContainer, то они изменяли бы все потоки, что неизбежно привело бы к проблемным ситуациям. Поэтому перечислитель контейнеров создается в контексте конкретного потока и никак не влияет на перечислители других потоков, в которых обрабатываются эти же данные. Работа класса заключается в следующем. При изменении условий (изменение маски обработки или контейнера) происходит поиск всех совпадающих установленных битов. Затем создается массив с размером, равным числу совпадений. В каждую ячейку массива по порядку заносятся номера совпавших каналов. В результате создается таблица преобразования индексов из логической индексации в реальные номера каналов. Логическая индексация перечисляет совпадения масок. Например, при обращении к логическому нулевому каналу доступ производится к первому каналу, подходящему по маскам. При этом реальный номер канала может не равняться нулю. Кроме базового и дополнительных классов в программе реализована группа рабочих классов. Это классы, которые занимаются непосредственно обработкой данных. Все они наследуются в соответствии с принятым порядком (рис. 2.3). Рассмотрим функции и параметры рабочих классов. Класс организации захвата звукового сигнала. Его основными функциями являются: – инициализация интерфейсов DirectSoundCapture; – создание основного для системы контейнера; – управление запуском/остановкой записи; – разделение блоков данных по отдельным каналам; – передача управления следующему блоку; – удаление интерфейсов DirectSoundCapture. Для работы с DirectSound был разработан специальный класс CWaveCapt, работа с которым осуществляется следующим образом. Вначале указывается объект (наследник от CTranslator), который будет принимать звуковые данные. За30
тем инициализируется интерфейс DirectSoundCapture с необходимыми параметрами захвата звука. После этого класс полностью готов к работе. Для управления захватом/остановкой у него есть соответствующие функции. Этот же класс прекращает работу с DirectSoundCapture. При возникновении каких-либо ошибок их код возвращается вызвавшей ошибку функцией. Коды ошибок совпадают с кодами соответствующих ошибок в DirectSound. После того как объект класса CWaveCapt инициализирован, он создает контейнер по предложенной маске и ждет начала записи. Контейнер содержит некоторое число каналов. Каждый канал имеет следующий заголовок: // Заголовок звукового буфера , используемого в транзакциях typedef struct defWTBUFFERHEAD { BYTE nBufferType; // Тип блока (амплитуды, спектр и т. д.) BYTE nDataType; // Тип применяемых данных WORD wSamplePerSecond; // Частота дискретизации FILETIME timeStartDate; // Время начала записи фрагмента DWORD dwDataSize; // Размер данных в байтах } WTBUFFERHEAD, *LPWTBUFFERHEAD; …
При записи происходит вызов метода CallBackFunc, унаследованного от класса CTranslator, с указателем на массив данных и его размер. Данные приходят в блочном формате, поэтому в этом же методе происходит их разделение на отдельные команды. После того как все данные разделены по каналам, происходит их передача следующему объекту. При разделении данных блокируется только тот канал в рабочем контейнере, который в данный момент необходим. Таким образом, остальным блокам оставляется возможность доделать свою работу с оставшимися каналами. Время ожидания при блокировке канала вычисляется по формуле 31
T =k
n , FД
(2.1)
где FД – частота дискретизации; n – число отчетов в буфере; k – число в диапазоне от нуля до количества каналов записи. Коэффициент k указывает на число каналов, которое успеет обслужиться за время ожидания. Для нормальной работы коэффициент равен единице. Таким образом, при сбоях мы пренебрегаем только обрабатываемым каналом и приступаем к обработке следующего. До заполнения канала новыми данными в его заголовок заносится текущее время в формате FILETIME, что необходимо для точной обработки данных. Запись времени реализована для каждого фрагмента, так как существует небольшая разность частот дискретизации для различных звуковых карт. Это приводит к различной скорости заполнения буферов и, как следствие, к рассогласованию обработки. В классе происходит замер времени, затраченного на разделение данных и их обработку в следующем блоке. По завершении класс удаляет интерфейс DirectSoundCapture. Класс записи оцифрованных данных. Одной из главных задач, решаемой программой, является запись звукового потока на диск компьютера для последующей обработки. Записанные данные необходимо сохранять в набор файлов, размер которых выбирает оператор. Разделение всего потока на отдельные файлы повышает удобство обработки и удаление ненужной информации. Для сохраненных данных было решено использовать стандартный WAVE-файл, так как данный формат позволяет сохранять данные без потери качества. Применение этого типа файлов дает также возможность использовать для анализа данных любой звуковой редактор, что увеличивает удобство обработки. Недостатком формата является большой размер звуковых файлов. Wave – формат универсальный, так как он проектировался только как контейнер для звуковых данных, т. е. он может содержать звуковые данные любого формата, но в 32
системах звукозаписи принято вкладывать в него звуковые данные формата RIFF. Формат RIFF, в свою очередь, может содержать данные с PCM-форматом (импульсно-кодовая модуляция) и соответственно содержит характеристики данной модуляции. Таким образом, заголовок Wave-файла выглядит следующим образом: typedef struct tagWAVEFILEHEAD { unsigned long ID_Of_File; // Должен быть равен 'RIFF'; unsigned long lSize_Of_RIFF; // Размер всего файла unsigned long ID_Of_Wave; // Должен быть равен 'WAVE'; unsigned long ID_Of_Fmt; // Должен быть равен 'fmt '; unsigned long lSize_Of_Ftm; // = 10h unsigned short wFormatTag; // 1 - PCM file unsigned short nChannels ; // 1 - mono; 2 - stereo unsigned long nSamplesPerSec; // 8000, 11025, 22050, 44100 (Гц) unsigned long nAvgBytesPerSec; // Скорость звукового потока unsigned short nBlockAlign; // Выравнивание блоков unsigned short nBitsPerSample; // = (8 или 16) } WAVEFILEHEAD, *LPWAVEFILEHEAD; …
За заголовком следует произвольное число тегов WAVEфайла со следующей структурой: struct { unsigned long name; unsigned long size; } tag_t; …
// идентификатор тега // размер тега
33
Важнейшим тегом является тег данных с идентификатором «data». За ним следует информационный тег LIST, в который записываются теги с параметрами оцифрованного сигнала: INAM – заголовок файла; ICRD – дата создания файла; ICMT – комментарии к файлу. Комментарии к файлу содержат дополнительную строковую информацию, для которой нет подходящего стандартного тега. Формат строки имеет вид: «device = ИУ date = Д time = В time_hi = ССД time_lo = = МСД master = МУ offset = СМУ», где ИУ – идентификатор устройства в формате устройство@станция; Д – дата в формате ДД.ММ.ГГГГ; В – время в формате ЧЧ.ММ.СС.мс; ССД – старшее двойное слово даты формата FILETIME; МСД – младшее двойное слово даты формата FILETIME; МУ – мастер-устройство, т. е. устройство, по которому синхронизируются остальные; СМУ – смещение относительно мастер-устройства (для мастер-устройства смещение равно "."). Записанная в WAVE-файл дополнительная информация позволяет избежать отдельной каталогизации записанных файлов и их параметров. Кроме того, записанная в комментариях информация позволяет автоматизировать процессы последующей обработки данных. Для своей работы данный блок использует дополнительный класс CMappedFile, который выполняет все операции с файлом. В функции класса входит генерация имен файлов в выбранном формате, своевременное закрытие старого файла и создание нового. Размер записываемых файлов выбирается пользователем при инициализации программы. Генерация имен файлов основывается на времени создания файла. Для этого при создании нового файла определяется локальное время, выбранные поля которого заносятся в имя файла. Выбор полей определяется оператором путем ука34
зания строкового шаблона. Строковый шаблон применяется в функции strftime стандартной библиотеки time.h, которая генерирует имя. После этого к строке прибавляется маска канала в десятичном виде. После того как открывается новый файл (с уже сгенерированным именем), в него записывается заголовок Waveфайла. Далее формируется структура с информацией о файле, которая пересылается объекту регистрации созданных файлов. При удалении данного объекта происходит закрытие рабочего файла и обнуление всех указателей. Класс определения точного времени. Для последующей обработки записанных данных необходимо знать точное время начала записи. Применяемый формат файла WAVE допускает вставку блоков, в которые можно поместить любую информацию, в том числе и точное время начала записи. Но правильная реакция приложения, обрабатывающего файл, с такой вставкой не гарантируется. Запись точного времени в имя файла не допускается, так как система может работать с полной длиной файла, не превышающей 260 символов. Поэтому для фиксации времени начала был применен специальный индексный файл, который содержит информацию обо всех записанных файлах. Информация о файле содержится в следующей структуре: typedef struct defFileListItem { DWORD dwFileType; // Тип файла char strName[MAX_PATH]; // Полное имя файла char strAddOn[MAX_PATH]; // Файл с дополнительной информацией FILETIME timeStartTime; // Дата начала записи } FILELISTITEM, *LPFILELISTITEM; …
Структура данных FILETIME имеет 64-битный размер и позволяет хранить время в 100 наносекундных интервалах начиная с 1 января 1601 г. по Гринвичу. Такая точность опре35
деления времени возможна благодаря наличию аппаратного высокоточного таймера, который присутствует на всех современных материнских платах. Но точность измерения времени различается на различных платформах и лежит в пределах от 4 · 10–7 до 9 · 10–7 секунды. Недостатком данного таймера является то, что он работает только в период работы компьютера и показывает время от начала запуска системы. Начальное значение для инициализации берется в стандартном энергонезависимом таймере реального времени, точность которого равна 0,054 секунды. Таким образом, точное время измеряется только в период работы системы, а между различными периодами работы разность во времени может достигать 0,054 секунды. Поэтому введение индексного файла позволяет очень точно позиционировать файлы по времени в течение работы компьютера. Класс работы по сети. Для расширения числа систем обработки сигнала в реальном масштабе времени в состав трактов обработки включена возможность передачи оцифрованного сигнала по локальной сети. Кроме реального сигнала в сеть может быть направлен поток с выхода ВЧ КИХфильтра с частотой среза 1000 Гц. Работа сетевой подсистемы программы основана на TCP/IP сокетах (sockets) версии 1.1 с применением клиентсерверной архитектуры. Сервером является сама программа, к которой может быть подключено неограниченное число клиентских приложений. Разделение типов сигнала одного тракта и трактов между собой реализовано посредством использования различных TCP/IP портов. Для работы клиентов сервер поддерживает три запроса: – параметров потока (числа каналов и параметров тракта обработки); – следующего буфера левого и/или правого канала тракта обработки; – на завершение работы канала связи. В ответ на запрос параметров потока, а также перед передачей буферов сервер направляет клиенту следующую структуру данных: 36
typedef struct defWBSTREAMINFO { DWORD channel_count; DWORD sample_rate; DWORD bits_per_sample; FILETIME capture_time; DWORD buffer_size; } WBSTREAMINFO; …
// число каналов // частота дискретизации // разрядность отчетов // время захвата буфера // размер буфера
В случае ответа на запрос параметров потока в поле, содержащее время захвата буфера, записывается нулевое значение. Организация метода передачи новых буферов посредством запросов продиктовано необходимостью защиты от переполнения в случае отставания в обработке клиентским приложением. Класс обработки ошибок. В каждый класс, унаследованный от класса CNode, включена возможность передачи данных об ошибке специализированному блоку. Это позволяет при программировании новых классов легко сообщать пользователю любую информацию: ошибку, успех или просто важную информацию. Таким образом, происходит более полный контроль работы программы, что совершенно необходимо в условиях многодневной автономной работы. Для отображения ошибок необходимо отослать сообщение блоку обработки, в котором следует указать код ошибки, код источника (блок обработки, операционная система или DirectSound) и указатель на строку с пояснением ошибки. Далее блок на основании кода источника расшифрует ошибку в строку и произведет ее обработку. В некоторых ситуациях не обязательно отображать или записывать в файл отчета всю информацию, так как в большинстве случаев этот механизм нужен только для контроля ошибок. Поэтому в класс добавлены функции фильтрации типов сообщений. Все сообщения делятся на следующие типы: успех, информация, предупреждение и ошибка. В свою очередь, типы обработки ошибок блоком тоже делятся на группы: – отображение в консоли; – запись в файл отчета; 37
– передача следующему блоку. Эта группа необходима для особой обработки какого-либо типа сообщений. Например, при возникновении ошибки необходимо остановить выполнение программы и произвести операцию завершения работы. Создание всех классов не обеспечивает работы программы в целом. Для этого необходимо организовать управление всеми входящими в нее объектами. Вообще работа программы делится на три основных периода: инициализации; работы; завершения работы. Период инициализации. Первоначально система загружает значения из файла настройки программы (если файл с настройками не найден, то устанавливаются значения по умолчанию) и определяет количество звуковых карт, присутствующих в системе. Для отображения названий и идентификаторов создаются два массива: массив указателей на строки названий звуковых карт и массив их идентификаторов. Когда все эти действия выполнены, программа ожидает от пользователя команды записи или изменения загруженных настроек. После этого происходит полная инициализация блока обработки ошибок. Это необходимо для отчетов о выполненных действиях при инициализации остальных блоков. Далее выполняются следующие действия: – динамическое создание всех блоков обработки и подключение их к блоку обработки ошибок; – объединение блоков в соответствии с выбранной топологией; – установка параметров; – инициализация блоков; – инициализация директории для звуковых данных. Каждое действие проверяется на ошибки, и если они обнаружены, то программа завершает свое выполнение, сообщая пользователю о причине. Если все в порядке, программа переходит в ожидание записи данных. Период работы наступает при нажатии кнопки «Старт» после захвата и записи первых блоков звуковых данных. В это время необходимо выполнять следующие действия: – обновлять на экране статистику работы программы; 38
– производить перезапуск записи; – производить суточные преобразования. Для этого организованы три таймера (по одному на каждое действие). Обновление статистики происходит наиболее часто, так как отображаемая информация должна быть актуальной. Перезапуск записи выполняет две функции: – при перезапуске закрываются файлы данных и уменьшается их размер до значения, выбранного оператором (при создании файлы имеют размер на 2 минуты больше, чем необходимо); – происходит синхронный старт захвата звуковых карт, после чего производится их опрос с целью определения смещения текущей позиции записи. Информация о разнице смещений устройств относительно мастер-устройства передается в блок записи для включения данной информации в дополнительные теги WAVE-файла. Время для перезапуска записи выбирается оператором. Третий таймер с периодом, равным 1 секунде, проверяет факт начала новых суток. В случае наступления новых суток выполняются следующие действия: – остановка записи; – перебор всех созданных каталогов и удаление устаревших; – создание нового каталога для записи суточных данных; – старт записи в новый каталог. На этапе разработки программы для записи суточных данных было решено использовать отдельный каталог, в имени которого указывается порядковый номер суток в текущем году. При переходе на новый год нумерация начинается с начала. Применение записи такого типа упрощает проблему определения устаревших данных, так как исключаются операции работы с датами (и как следствие, учет числа дней в месяце, поправки для високосного года и т. д.). Время начала новых суток и число хранимых суток выбираются пользователем. Период завершения работы наступает при закрытии главного окна приложения (по получении сообщения WM_DESTROY). При этом происходит остановка всех дейст39
вий, удаление всех динамически созданных объектов из памяти, остановка всех таймеров и закрытие всех файлов. После этого обнуляются указатели, а окружение программы восстанавливается в состояние, которое было до инициализации.
2.2. Система фильтрации геоакустического сигнала Для разработки системы (рис. 1.1) был реализован отдельный программный комплекс на языке высокого уровня для научно-технических вычислений – MATLAB. Выбор этой среды обусловлен наличием полного набора методов для создания цифровых фильтров с разнообразными характеристиками, что позволяет быстро разрабатывать фильтры существующих типов и классов. Кроме того, MATLAB содержит большой инструментарий для обработки и визуализации цифровых данных. Разработанная система запускается автоматически после включения персонального компьютера, на котором она установлена, и в начале каждого часа производит обработку поступающих данных. Новизна разработки заключается в том, что в среде MATLAB реализована система непрерывной обработки данных, способная самостоятельно работать без участия человека в течение длительного времени. Входные данные поступают от системы регистрации широкополосного геоакустического сигнала (рис. 2.1) в виде файлов звукового формата. Далее происходит их обработка (фильтрация, вычисление абсолютного значения и накопление сигнала на интервале 4 секунды), после чего происходит их отображение и запись на диск. Система обработки обеспечивает [13, 20]: – фильтрацию записанного сигнала в семи частотных диапазонах (0,1–10, 10–50, 50–200, 200–700, 700–1500, 1500– 6000, 6000–10 000 Гц); – обработку нескольких потоков данных большого объема; 40
– наглядное графическое представление результирующих данных за последние сутки; – сохранение результирующих данных для их дальнейшего анализа; – работу в режиме реального времени с оперативностью в один час. На первом этапе при разработке системы необходимо осуществить проектирование цифровых фильтров. Мощное средство для интерактивного конструирования фильтров – проектировщик-анализатор фильтров среды MATLAB «Filter Design & Analysis Tool». При его запуске открывается окно (рис. 2.8) с множеством полей для выбора типа фильтра, его параметров, а также средств визуализации проектирования.
Рис. 2.8. Окно проектировщика фильтров при задании параметров
На рис. 2.8 показан вид окна при проектировании фильтра низких частот. В окне просмотра представлены зоны допусков амплитудно-частотной характеристики (АЧХ) с указанием их названий. После задания типа фильтра и его параметров достаточно нажать кнопку Design Filter (Конструирование фильтра) для того, чтобы запустить программное конструирование 41
фильтра под заданные параметры. После этого, используя кнопки панели инструментов, можно посмотреть и, если необходимо, скорректировать полученные характеристики фильтра (рис. 2.9).
Рис. 2.9. Окно проектировщика-анализатора фильтров после запуска этапа проектирования
В большинстве случаев фильтр представляет собой частотно-избирательное устройство, которое пропускает сигналы на частотах определенного диапазона и задерживает или ослабляет сигналы других частотных диапазонов. Полоса пропускания относится к диапазону пропускаемых частот, в то время как полоса задерживания – к диапазону блокируемых частот. Переходная область находится между ними (рис. 2.10, а). Наиболее общими типами частотно-избирательных фильтров являются фильтры нижних частот (ФНЧ), высоких частот (ФВЧ), полосно-пропускающие и полосно-заграждающие. Все эти типы в персональном компьютере могут быть реализованы посредством цифровых КИХ- и БИХ-фильтров. 42
При этом БИХ-фильтры обладают более стабильными характеристиками, поэтому на них целесообразнее разработать предлагаемую систему. Фильтры Баттерворта, Чебышева, инверсные Чебышева и эллиптические образуют четыре наиболее известных класса БИХ-фильтров. Рассмотрим их преимущества и недостатки для реализации в системе.
а
в
б
г
Рис. 2.10. АЧХ фильтров различного типа: а – нижних частот; б – высоких частот; в – полосно-пропускающий; г – полосно-заграждающий
Разрабатываемая система фильтрации должна работать в режиме реального времени, значит, время на обработку данных ограниченно. Известно, что чем выше порядок фильтра, тем дольше длится процесс фильтрации. Поэтому критерием выбора будем считать наличие наименьшей переходной области (наиболее крутой АЧХ) при заданном порядке фильтра. Для примера спроектируем фильтр низких частот четвертого порядка с частотой среза 2 кГц. Наиболее простая АЧХ у фильтра Баттерворта, которая в случае ФНЧ n-го порядка определяется следующим образом: 43
H (e
jω
)=
A 1 + ( ω / ωc ) 2 n
, n = 1, 2, 3, …,
(2.2)
где ωc – частота среза. АЧХ фильтра Баттерворта монотонно спадает при увеличении частоты. Увеличение порядка приводит к повышению крутизны характеристики. По сравнению с характеристикой любого полиномиального фильтра четвертого порядка у фильтра данного типа АЧХ наиболее плоская в окрестности частоты ω = 0. Вследствие этого АЧХ фильтра Баттерворта называется максимально плоской. Однако для частот, расположенных около точки среза и в полосе задерживания, характеристика фильтра Баттерворта заметно уступает характеристике фильтра Чебышева. АЧХ фильтра Баттерворта четвертого порядка для заданной частоты среза представлена на рис. 2.11.
Рис. 2.11. АЧХ фильтра Баттерворта четвертого порядка (ширина переходной области равна 3981 Гц)
АЧХ фильтра Чебышева нижних частот определяется следующим образом: 44
H (e
jω
)=
К 1 + ε 2 Сn2 (ω / ωc )
, n = 1, 2, 3, …,
(2.3)
где ε и К – постоянные числа; Сn – полином Чебышева первого рода степени n, определяемый как Cn = cos(n · arсcos x). АЧХ достигает своего наибольшего значения К в тех точках, где Cn равно нулю. Поскольку эти точки распределены по полосе пропускания, то характеристика фильтра Чебышева содержит пульсации в полосе пропускания и монотонна в других областях. Размах пульсаций определяет параметр ε, а их число – n. Коэффициент усиления фильтра определяется значением К. АЧХ фильтра Чебышева для заданной частоты среза более оптимальна характеристики фильтра Баттерворта, так как у фильтра Чебышева ýже ширина переходной области. АЧХ фильтра Чебышева изображена на рис. 2.12.
Рис. 2.12. АЧХ фильтра Чебышева четвертого порядка (ширина переходной области равна 2544 Гц)
АЧХ инверсного фильтра Чебышева нижних частот определяется следующим образом: 45
H (e
jω
)=
εС n (ω1 / ω)
1 + ε 2 Сn2 (ω1 / ω)
, n = 1, 2, 3, …,
(2.4)
где ε – положительное постоянное число; Сn – полином Чебышева первого рода степени n. Постоянная ω1 определяет начальную частоту полосы задерживания. АЧХ инверсного фильтра Чебышева монотонна в полосе пропускания и содержит пульсации в полосе задерживания. Аналогично предыдущему примеру АЧХ данного фильтра также более оптимальна, чем характеристика фильтра Баттерворта, из-за меньшей ширины переходной области (рис. 2.13).
Рис. 2.13. АЧХ инверсного фильтра Чебышева четвертого порядка (ширина переходной области равна 2544 Гц)
В АЧХ эллиптического фильтра (фильтр Кауэра) имеются пульсации как в полосе пропускания, так и в полосе задерживания. Величина пульсаций в каждой из полос независима друг от друга. Амплитудная характеристика эллиптического фильтра низких частот является функцией круговой частоты ω и задается следующим выражением: 46
H (e
jω
)=
1 1 + ε 2 Rn2 (ξ, ω / ω0 )
,
(2.5)
где Rn – рациональная эллиптическая функция n-го порядка; ω0 – частота среза; ε – показатель пульсаций; ξ – показатель селективности. Значение показателя пульсаций определяет пульсации в полосе пропускания, пульсации же в полосе задерживания зависят как от ε, так и от показателя селективности. Данный вид фильтра имеет самую узкую переходную область, что позволяет достигать наиболее эффективного разделения частот (рис. 2.14).
Рис. 2.14. АЧХ эллиптического фильтра четвертого порядка (ширина переходной области равна 1009 Гц)
Таким образом, для решения поставленной задачи из наиболее известных классов фильтров (Баттерворта, Чебышева, инверсные Чебышева и эллиптические) были выбраны эллиптические фильтры, которые являются наименее ресурсоемкими для реализации заданных характеристик. 47
При помощи проектировщика-анализатора фильтров «Filter Design & Analysis Tool» формировалась амплитудночастотная характеристика проектируемого фильтра с минимальным порядком. На рис. 2.15 представлен пример АЧХ эллиптического фильтра нижних частот, где Fc – частота среза, Fs – начальная частота полосы задерживания, Rp – максимум пульсаций в полосе пропускания, Rs – минимум пульсаций в полосе задерживания, Ac – ослабление амплитуды сигнала на частоте среза. В данной работе частота среза соответствовала области АЧХ, в которой амплитуда уменьшена в 0,707 раза (т. е. на 3 децибела). В качестве минимального значения пульсаций в полосе задерживания был принят порог в 40 децибел, а максимальное значение пульсаций в полосе пропускания – 0,5 децибела. Варьируя перечисленными выше параметрами, была получена требуемая АЧХ фильтра при его наименьшем порядке.
Рис. 2.15. Параметры АЧХ эллиптического фильтра нижних частот
48
Для обеспечения минимальной нелинейности АЧХ в полосе пропускания (не более 2 децибел) отдельно подбиралось значение Rр. Потребность в данной задаче наиболее остро возникла при расчете фильтров второго поддиапазона (10–50 Гц). На рис. 2.16 приведены АЧХ проектируемого фильтра с нелинейностью в полосе пропускания до и после корректировки значения Rр. До корректировки при Rр = 0,5 дБ максимум нелинейного всплеска составил 24 дБ, а на этапе корректировки было подобрано Rр = 0,008 дБ, при котором максимум нелинейного всплеска составил 1,9 дБ. После получения АЧХ фильтра с заданными характеристиками его параметры (n – порядок фильтра, а также Rp, Rs, Fc) фиксировались для дальнейшего программирования.
а
б
Рис. 2.16. АЧХ проектируемого фильтра: а – до корректировки Rp; б – после корректировки Rp
Для всех семи указанных выше частотных поддиапазонов с учетом возможных частот дискретизации входного сигнала (22,05, 24, 44,1 и 48 кГц) были сконструированы эллиптические фильтры (всего 28 фильтров). Далее на языке MATLAB была реализована система, включающая в себя фильтрацию, вычисление абсолютного значения, накопление на интервале 4 секунды, отображение на экране и запись сигналов на диск. 49
Работу системы обработки можно разбить на три этапа (рис. 2.17): 1) режим настройки; 2) режим дежурства; 3) режим обработки. Для обеспечения непрерывной обработки получаемых данных было предложено использовать имеющиеся в среде MATLAB объекты – таймеры. В нашем случае для корректной непрерывной работы системы достаточно использовать три взаимодействующих таймера.
а
б
Рис. 2.17. Этапы работы системы обработки: а – в общем виде; б – с детальным рассмотрением режимов
На первом этапе происходит инициализация главного окна, настройка параметров работы программы с помощью вспомогательного окна, описание и запуск блока таймеров. 50
На втором этапе в зависимости от системного времени компьютера управление программой передается блоку таймеров. Он включает в себя три таймера, которые в зависимости от системного времени компьютера поочередно передают управление программой друг другу. Это позволяет на протяжении длительного времени поддерживать процесс передачи управления от одного таймера другому, запуская обработку данных в начале каждого часа и обеспечивая работу программы в режиме реального времени. Третий этап является основным. Здесь в соответствии с настройками программы происходит частотная и временная обработка данных, результаты которой формируются в виде суточных файлов и визуализируются на дисплее персонального компьютера (блок обработки данных представлен на рис. 2.17). По окончании суток сформированные данные подвергаются анализу при помощи нейронных методов (более подробно работа этого блока будет рассмотрена в гл. 5). После этого происходит возвращение ко второму этапу. Рассмотрим работу блока таймеров (рис. 2.18). Реализация параметров таймеров производится в режиме настройки. Переход из режима настройки в режим дежурства происходит при запуске первого таймера (t1). Он срабатывает сразу же, без задержки, вносит изменения в параметры предстоящей обработки и запускает второй таймер (t2), который должен будет сработать в hh : 59 : 55 текущего часа. Сработав в указанное время, таймер t2 производит запуск третьего таймера (t3). Таймер t3 контролирует переход программы из одного часа в другой и далее в hh : 05 : 05 запускает режим обработки. После окончания обработки данных программа переходит в режим дежурства, возвратив управление третьему таймеру, который вслед за этим запускает таймер t1. Далее все повторяется в очередном часе. Таким образом, блок таймеров реализует переход программы из одного часа в другой (а впоследствии – переход через начало суток), запускает процесс обработки данных в начале каждого часа и обеспечивает работу программы в режиме реального времени с оперативностью в один час. 51
Рис. 2.18. Работа блока таймеров
Основная обработка сигналов производится в блоке обработки данных. Алгоритм работы блока представлен на рис. 2.19. В начале каждого часа система обработки производит поиск wav-файлов за последний час на ПК системы регистрации. При наличии данных происходит захват аудиосигнала последовательно из каждого wav-файла. После загрузки сигнала в рабочую область оценивается его длина и вычисляется размер результирующего массива. Далее сигнал разбивается на блоки, размер каждого из которых соответствует сигналу длиной в 4 секунды. Затем данные из каждого блока поступают на вход семи разработанных фильтров, где осуществляется фильтрация по частотным поддиапазонам. Далее вычисляется абсолютное значение каждого отсчета. На следующем этапе данные накапливаются, образуя из блока один отсчет на каждый поддиапазон. Таким образом, получается результирующий массив, который имеет восемь столбцов. Элементы первого столбца – значения времени для каждого отсчета (интервал 4 секунды), а остальные семь – сигналы соответствующих поддиапазонов. Полученный массив данных записывается в суточный файл на диск и визуализируется на дисплее ПК системы обработки. 52
Рис. 2.19. Алгоритм работы блока обработки данных
Первоначально при запуске программы открывается главное окно с активной кнопкой «Настройки» (рис. 2.20). При нажатии этой кнопки появляется возможность проконтролировать выбранные опции программы и при необходимости их изменить (рис. 2.21). Для корректной работы в панели настроек нужно указать место хранения входных и выходных данных, а также каналы звуковых данных, поступающих с системы регистрации. Галочка «Выравнивать АЧХ» позволяет при обработке сигналов учитывать неравномерность АЧХ гидрофонов. Выбор значения для поля «Кол-во суток» предусматривает вывод на дисплей ПК обработанных данных за период от одного до трех дней. 53
Для сохранения изменений нужно нажать кнопку «Сохранить», а затем кнопку «ВЫХОД» для закрытия панели настроек.
Рис. 2.20. Главное окно программы
Рис. 2.21. Окно настроек программы
Далее при нажатии в главном окне кнопки «Пуск», которая активируется при выходе из элемента «Настройки», система переводится в состояние дежурства. В этом состоянии система будет находиться до начала следующего часа, после чего перейдет в режим обработки данных. Закончив обработку данных за последний час, система снова переходит в режим дежурства, ожидая начала нового часа. На рис. 2.22 изображено главное окно программы после обработки суточных данных. 54
Рис. 2.22. Главное окно программы после обработки суточных данных
В качестве примера выбрана высокочастотная аномалия ГАЭ, зарегистрированная 23 августа 2006 г. за сутки до землетрясения с локальной магнитудой М = 6,1, произошедшего 24.08.2006 г. в 21:50 UT на эпицентральном расстоянии 220 км от пункта наблюдения. Координаты гипоцентра землетрясения: 51,01°N, 158,01°E, глубина – 40 км (оперативные данные Камчатского филиала ГС РАН). Как видно на рис. 2.22, интерфейс разработанной программы осуществляет отображение результатов обработки за текущие сутки по каждому частотному поддиапазону (верхние семь графиков). Кроме этого, в нижнем окне выводятся графики всех пространственных каналов для выбранного частотного поддиапазона, что облегчает их визуальное сравнение. В настоящее время произошла незначительная корректировка границ частотных поддиапазонов, которая учитывает особенности регистрации сигналов ГАЭ. Новые значения границ частотных поддиапазонов составляют 0,1–10, 30–60, 70– 200, 200–600, 600–2000, 2000–6500, 6500–11 000 Гц, что уже отображено на рис. 2.22. 55
Глава 3. МНОГООБРАЗИЕ ФОРМ АКУСТИЧЕСКИХ СИГНАЛОВ В марте 2004 г. на дне озера Микижа (Камчатка) на глубине 4 метра установлена система регистрации ГАЭ, структурная схема которой представлена на рис. 1.1. Вообще исследования ГАЭ на озере начались в 2001 г. [7], но только в 2004 г. в систему были включены возможности по регистрации и анализу акустических сигналов как во всем принимаемом диапазоне частот, так и на выходе частотных каналов. Анализ полученных данных показывает, что аппаратура регистрирует сигналы землетрясений, возмущения геоакустической эмиссии, обусловленные деформационными процессами, а также сигналы, сгенерированные воздействием метеофакторов (осадки, ветер), и сигналы техногенного и биологического характера [8]. Рассмотрим их более подробно. Сигналы землетрясений. Анализ данных показал, что система регистрирует сигналы землетрясений аналогично стандартным сейсмостанциям. За период наблюдения регистрировались сигналы сейсмических событий начиная от класса 7,5 (локальная магнитуда М = 3,0) с расстояния 100 км и заканчивая 14-м классом и более (М > 6,25) с расстояния до 700 км. Примеры таких сигналов показаны на рис. 3.1, 3.2. На рис. 3.1 представлено сейсмическое событие с локальной магнитудой М = 6,0, произошедшее 14 апреля 2004 г. в 1:54 UT на эпицентральном расстоянии 380 км от пункта наблюдения. Координаты гипоцентра землетрясения: 55,11°N, 162,82°E, глубина – 39 км (оперативные данные Камчатского филиала ГС РАН). На рис. 3.2 представлено сейсмическое событие с локальной магнитудой М = 6,25, произошедшее 10 июня 2004 г. в 15:19 UT на эпицентральном расстоянии 325 км. Координаты гипоцентра землетрясения: 55,55°N, 160,67°E, глубина – 197 км (оперативные данные Камчатского филиала ГС РАН). 56
Представленные рисунки демонстрируют направленные свойства системы: наиболее сильные сигналы регистрируются с направлений на эпицентры землетрясений.
Рис. 3.1. Сигналы землетрясения от 14 апреля 2004 г. в 1:54 UT
Рис. 3.2. Сигналы землетрясения от 10 июня 2004 г. в 15:19 UT
57
Возмущения геоакустической эмиссии, обусловленные деформационными процессами. Анализ сигналов ГАЭ показал, что перед многими землетрясениями с классом более 10,5 (М > 4,5), произошедшими на эпицентральном расстоянии до 200 км от пункта наблюдения, в суточном временном интервале наблюдаются сигналы, многократно превышающие фоновый уровень. Продолжительность данного явления составляет от десятков минут до нескольких часов. Далее за несколько часов до землетрясения ГАЭ возвращается к спокойному фоновому уровню. В качестве примера на рис. 3.3 представлена реакция ГАЭ перед землетрясением от 23 мая 2004 г. в 03:06 UT (локальная магнитуда М = 4,55, эпицентральное расстояние – 130 км). Координаты гипоцентра землетрясения: 51,88°N, 158,8°E, глубина – 69 км (оперативные данные Камчатского филиала ГС РАН). За сутки до события – 22 мая в 01:30 было зарегистрировано превышение уровня ГАЭ продолжительностью около 14 часов. В данном случае сигналы напоминали звуки, близкие к скрежету открываемых дверей, вздохам, резко нарастающему шуму и т. п.
Рис. 3.3. Аномалия ГАЭ перед землетрясением 23 мая 2004 г. в 03:06 UT
На рис. 3.4 представлены сигналы на выходе семи частотных каналов. Из данного рисунка видно, что наиболее сильно 58
аномалия наблюдается в диапазоне 1500–6000 Гц. Стрелкой показано время землетрясения.
Рис. 3.4. Аномалия ГАЭ перед землетрясением от 23 мая 2004 г в 03:06 UT
Несколько другая форма геоакустических сигналов представлена на рис. 3.5
а
б
Рис. 3.5. Аномалия ГАЭ перед землетрясением от 6 апреля 2004 г. в 9:54 UT: а – фрагмент записи протяженностью 12 с; б – одиночный импульс из данного фрагмента
59
В данном случае приведена аномалия ГАЭ перед землетрясением, происшедшим 6 апреля 2004 г. в 09:54 UT в районе полуострова Шипунский (локальная магнитуда М = 5,0, эпицентральное расстояние – 177 км). Координаты гипоцентра землетрясения: 53,77°N, 160,58°E, глубина – 40 км (оперативные данные Камчатского филиала ГС РАН). В этот день с 2:00 до 2:50 и с 5:00 до 5:10 (за 7 часов до землетрясения) было зарегистрировано аномальное поведение ГАЭ. Анализ явления показал, что в данном случае наблюдаются квазипериодические повторяющиеся импульсы, по форме напоминающие микроземлетрясения. При этом наиболее сильно аномалия вновь наблюдается в диапазоне 1500–6000 Гц (рис. 3.6).
Рис. 3.6. Аномалия ГАЭ перед землетрясением от 6 апреля 2004 г. в 9:54 UT
Перед землетрясением с локальной магнитудой М = 5,85, происшедшим 26 июля 2005 г. в 12:17 UT на эпицентральном расстоянии 140 км, 25 и 26 июля была обнаружена аномалия ГАЭ общей продолжительностью 14 часов, отличная от представленных ранее. Координаты гипоцентра землетрясения: 60
52,74°N, 160,29°E, глубина – 20 км (оперативные данные Камчатского филиала ГС РАН). В данном случае сигналы представляли собой высокочастотный шум, похожий на «белый», с плавно меняющейся амплитудой (рис. 3.7). При этом наиболее сильно аномалия вновь наблюдается в диапазоне 1500–6000 Гц (рис. 3.8).
Рис. 3.7. Аномалия ГАЭ перед землетрясением от 26 июля 2005 г. в 12:17 UT
Рис. 3.8. Аномалия ГАЭ перед землетрясением от 26 июля 2005 г. в 12:17 UT
61
Предварительный статистический анализ данных, наблюдаемых с системы, показывает, что более чем в 30% случаев в суточном временном интервале перед землетрясениями наблюдается аномальное повышение уровня ГАЭ. При этом возможно появление сигналов (рис. 3.3), импульсов (рис. 3.5) и шумоподобных сигналов (рис. 3.7). Для объяснения разнообразия форм геоакустических сигналов требуется более детальный анализ геологического строения прилежащей к озеру Микижа местности, характеристик самих землетрясений, а также анализ времен года, в который наиболее часто встречаются аномалии разных типов. Сигналы, сгенерированные воздействием метеофакторов. Формы таких сигналов различаются по временам года, что обусловлено в первую очередь наличием зимой ледового покрова на озере. Поэтому в данный период основной причиной появления таких сигналов является сильный ветер (рис. 3.9). В летний период это волнение, обусловленное повышением силы ветра (рис. 3.10), и осадки (рис. 3.11). Следует отметить, что воздействие метеофакторов оказывает существенное мешающее воздействие при анализе геоакустических сигналов. Если основными диапазонами, в которых преобладают сигналы, сгенерированные воздействием ветра, являются диапазоны 50–200 и 200–700 Гц (рис. 3.12), т. е. возможно на фоне ветра выделить сигналы ГАЭ, обусловленные деформационными явлениями, то при дожде генерируются сигналы во всем принимаемом диапазоне и выявить полезные сигналы на фоне дождя обычными методами частотной фильтрации практически невозможно. Но поскольку природа этих сигналов значительно различается, то для выявления полезной информации возможно применение современных методов численного анализа, что является одним из направлений дальнейшей работы. Для учета влияния метеопараметров необходима установка метеостанции в пункте наблюдения ГАЭ. Например, возможна установка достаточно недорогой и полностью автоматизированной станции от немецкой компании «Conrad». 62
Рис. 3.9. Акустические сигналы, сгенерированные ветром в зимний период
Рис. 3.10. Акустические сигналы, сгенерированные ветром в летний период
Рис. 3.11. Акустические сигналы, сгенерированные осадками
63
Рис. 3.12. Влияние ветра в различных частотных поддиапазонах
Сигналы техногенного и биологического характера. Сигналы такого типа достаточно часто регистрируются на озере. Их форма достаточно специфична, поэтому выявление подобных сигналов не представляет существенного труда. В зимний период наиболее часто регистрируются сигналы снегоходов, проезжающих мимо датчика по поверхности озера (рис. 3.13).
Рис. 3.13. Сигналы от проезжающего снегохода
64
В летний период основными сигналами являются шумы от движения прогулочных лодок (рис. 3.14) и биологические шумы, в первую очередь крики птиц (рис. 3.15).
Рис. 3.14. Сигналы прогулочных лодок
Рис. 3.15. Сигналы от криков птиц
Следует отметить, что гидрофонами, установленными на дне озера, фиксируются и пролеты летательных аппаратов (рис. 3.16) над поверхностью озера, что также является дополнительным источником помех техногенного характера. 65
а
б Рис. 3.16. Сигналы от пролетающих летательных аппаратов: а – самолета; б – вертолета
В заключение следует отметить, что выявление, анализ и классификация мешающих воздействий метеорологического, техногенного и биологического характера позволит в дальнейшем создать математические модели этих сигналов, что позволит исключить их влияние на выявление сигналов ГАЭ, обусловленных воздействием деформационных процессов.
66
Глава 4. ПРИМЕНЕНИЕ ВЕКТОРНО-ФАЗОВЫХ МЕТОДОВ ДЛЯ ИССЛЕДОВАНИЯ АНИЗОТРОПИИ АКУСТИЧЕСКИХ СИГНАЛОВ Для более детального исследования анизотропии геоакустического излучения на различных стадиях сейсмической активности в сентябре 2004 г. на озере Микижа была установлена на глубине около 5 метров новая приемная система. В состав ее аппаратной части входит векторно-фазовый комбинированный гидроакустический приемник (ВФП), разработанный в ЗАО «Геоакустика» при ФГУП ВНИИФТРИ, предварительный усилитель и IBM совместимый ПК со звуковыми картами, обеспечивающими синхронность передачи данных по каналам. Программная часть – это специально разработанные программы для регистрации в режиме реального времени (используется программное обеспечение, рассмотренное в гл. 2), автоматического выявления геоакустических сигналов и детального анализа их направленности. ВФП, являющийся основным элементом системы, позволяет одновременно регистрировать три взаимно ортогональных проекции колебательной скорости и акустическое давление в диапазоне частот 0–10 кГц [6]. Внешний вид приемника и его характеристики направленности представлены на рис. 4.1. Такое конструктивное решение позволяет пеленговать геоакустические импульсы приемниками колебательной скорости по трем координатам и устранять неоднозначность пеленга за счет встроенного датчика давления. Корпус приемника герметичен и подвешен на упругих растяжках в специальной рамке (рис. 4.2), которая обеспечивает его подвес и постоянную ориентацию в пространстве. Рамка датчика жестко подвешена в несущей конструкции, которая устанавливается на дно водоема. Использование несущей конструк67
ции необходимо для обеспечения стабильности положения ВФП, а также для предотвращения его погружения в ил на дне водоема. Использование упругих подвесов обеспечивает механическую изоляцию приемника от колебаний конструкции.
а
б
в
Рис. 4.1. Внешний вид и характеристики направленности: а – внешний вид; б – характеристики одиночного приемника колебательной скорости; в – характеристики ВФП в горизонтальной плоскости
Система регистрации широкополосного сигнала с выхода ВФП существенно не отличается от рассмотренной в гл. 2 (структурная схема представлена на рис. 2.1).
Рис. 4.2. Схема установки векторно-фазового приемника
68
Анализ широкополосного сигнала с ВФП показал, что он представляет собой череду ударных импульсов с амплитудой 0,1–1 Па. При этом частота таких импульсов зависит от относительных деформаций и меняется в широких пределах – от одиночных щелчков на временном интервале продолжительностью несколько секунд в фоновый период до десятков и даже сотен щелчков в секунду. Средняя протяженность импульса составляет 200 мс. На рис. 4.3 показана форма одиночного импульса с взаимно ортогональных компонентов в горизонтальной плоскости, а его направленные свойства в полярной плоскости представлены на рис. 4.4.
Рис. 4.3. Пример одиночного геоакустического импульса
б
а Рис. 4.4. Пример одиночного импульса, изображенного в полярных координатах (а), и график распределения радиусов точек (б)
В целом форма импульса однотипна и состоит из трех основных частей: тихая область вначале, резкое увеличение ин69
тенсивности в середине, достаточно шумная область затухания сигнала. Такая типовая структура импульсов позволяет автоматизировать процесс их обнаружения в полученном сигнале. Для автоматизации процесса поиска импульсов в непрерывном сигнале был разработан специальный метод, который состоит из двух стадий: выявление импульса по амплитуде и проверка его формы в полярных координатах. После успешного выполнения этих двух стадий производится фиксация направления прихода импульса. По итогам обработки сигналов в полярной системе координат строится зависимость частоты следования импульсов от направления прихода. Для исследования направления прихода импульса используется его отображение в полярных координатах с взаимно ортогональных компонентов в горизонтальной плоскости. При этом каждый отчет оцифрованного сигнала отображается на координатной плоскости в виде точки, имеющей определенный угол и радиус (рис. 4.4). Первичное обнаружение сигналов производится скользящим окном с шириной, соответствующей средней продолжительности импульса. Шаг перемещения окна равен его продолжительности в случае успешного выявления импульса и 1/3 от продолжительности в остальных случаях. Первичная стадия необходима для грубого отбора проверяемых импульсов. Это позволяет ускорить процесс обработки, не допуская избыточную проверку окна данных на следующем этапе, который требует существенно больших аппаратных затрат. На этом этапе окно разбивается на три области (рис. 4.5), в каждой из которых находится среднее значение N по формуле N=
n + nmax , 2
(4.1)
где n – среднее значение отсчетов в выбранном интервале; nmax – максимальное значение на данном интервале. Такое усреднение позволяет учитывать малые по времени, но большие по амплитуде сигналы. Полученные значения 70
N попадают в определенные пределы (заштрихованные области на рис. 4.5).
Рис. 4.5. Пример разбиения импульса на участки
Размах средней области импульса имеет пороги в максимальном и минимальном значениях. Минимальное значение необходимо для выявления всплеска сигнала на фоновом уровне. Верхнее значение необходимо для отбрасывания при обработке заведомо искаженного выходом за пределы динамического диапазона сигнала. Численные значения порогов определяются опытным путем в соответствии с уровнем шумов на данном измерительном пункте. На второй стадии определяется направление на источник сигнала и осуществляется проверка формы импульса в полярных координатах. Определение направления каждого отсчета выделенного сигнала определяется по формуле ⎛ y⎞ γ = arctg⎜ ⎟. ⎝x⎠
(4.2)
В идеале пеленг на источник импульса определяется как совокупность пеленгов каждого отсчета сигнала, что в реальных условиях осложняется условиями регистрации сигнала и его спецификой, а именно: – неравномерное распределение радиусов точек сигнала (рис. 4.4): основная часть отсчетов расположена близко к центру координат и не несет информацию о направлении на источник, поэтому очень мало отсчетов (порядка 60 на 200 мс данных) имеют практическую ценность; – влияние отражений звуковой волны от границ водоема, дна и поверхности воды;
71
– случайные единичные выбросы с большой амплитудой, приводящие к значительному смещению среднего значения; – неоднозначность направления, вызванная диаграммой направленности датчика, вследствие которой было решено ограничить диапазон определения пеленга интервалом от 0 до 180°. Учитывая эти особенности регистрации сигнала, был разработан следующий метод. Первоначально определяется диаграмма максимальных радиусов B[] , являющаяся массивом 360 максимальных значений радиусов отчетов, взятых с интервалом в 1°. Затем диаграмма B[] сглаживается алгоритмом скользящего среднего по формуле j =i + m
A[i ] =
∑ B[ F ( j)]
j =i − m
2m
,
(4.3)
где i, j – целые числа, 0 ≤ i < 360 ; A[] – сглаженная диаграмма максимальных радиусов; F ( j ) – функция нормализации угла, определяемая как
⎡ j mod 360, если j ≥ 0, F ( j) = ⎢ ⎣360 + ( j mod 360), если j < 0; m – интервал усреднения. Функция F ( j ) нормализует угол j , приводя значение результирующего угла к виду 0 ≤ F ( j ) < 360 . Таким образом, применение функции F ( j ) в формуле (4.3) позволяет избежать обращений к индексам, находящимся за пределами массива B[] (ячейкам с отрицательными или выходящими за пределы 359 индексами). Исходя из практического опыта и минимизации аппаратных затрат, интервал усреднения m выбран равным 5. После усреднения на сглаженной диаграмме максимальных радиусов A[] находится точка М (рис. 4.6) с максимальным радиусом, расположенная в положительной полуплоскости, по которой строится предполагаемый угол прихода импульса α . 72
Рис. 4.6. Определение направления на источник сигнала
Относительно предполагаемого направления определяются перпендикуляры ( β1 = α + 90 и β 2 = α − 90 ), затем вычисляется средний радиус R в перпендикулярных направлениях по формуле. При этом, как следует из данного выражения, при вычислении R учитываются усредненные и максимальные значения радиусов: R=
r (β1 ) + r (β1 )max + r (β 2 ) + r (β 2 )max , 4
(4.4)
где β1 , β 2 – углы, перпендикулярные основному направлению; r (β ) – средний радиус по направлению β , определенный на промежутке от β − a до β + a , вычисляемый по формуле i+a
r (β) =
∑ A[i + β] i−a
2a 73
;
A[i ] – максимальный радиус по направлению угла i ; a – интервал усреднения; r (β )max – максимальный радиус, определенный на промежутке от β − a до β + a . Предполагается, что все точки с радиусами, меньшими R , являются либо шумом, либо отражениями основного сигнала и не учитываются на следующих этапах метода. Затем происходит определение центра масс отсчетов, попадающих под условие ⎧⎪ri ≥ R, ⎨ ⎪⎩α + 90 > γ i > α − 90, mi = 3
ri , rM
(4.5) (4.6)
где rM – радиус точки М. Масса каждого отсчета вычисляется по формуле (4.6). Окончательное направление – это направление на полученный центр масс (рис. 4.7, заштрихованная область).
Рис. 4.7. Определение формы импульса
74
После получения истинного направления производится проверка формы импульса в полярных координатах. Для этого вычисляется усредненный радиус в основном направлении импульса R M по формуле (4.4). Вычисляется отношение полученного радиуса к R . Если полученное значение больше порогового значения (в данный момент оно установлено равным 4), то импульс считается определенным и регистрируется в специальном файле на диске. Используя предложенный метод, можно организовать потоковую обработку сигнала в реальном масштабе времени, обеспечивая непрерывный контроль за его формой и направлением. Применение метода в условиях лаборатории позволяет в короткий срок анализировать продолжительные сигналы с большим количеством импульсов. Пример подобной обработки представлен на рис. 4.8. В качестве численной характеристики радиальной оси принята частота регистрации импульсов с каждого направления. На рис. 4.8 четко просматривается существенная анизотропия геоакустических сигналов в пространстве, что говорит о наличии локальных источников геоакустического излучения в непосредственной близости от места установки Рис. 4.8. Пример гистограммы векторно-фазового приемнисигнала с озера Микижа ка на озере Микижа. Полученные данные позволяют исследовать анизотропию геоакустического излучения на различных стадиях сейсмической активности. Основным фактором, снижающим эффективность предложенного 75
метода, является влияние атмосферных явлений (осадки, сильный ветер), которые вызывают повышение общего уровня сигнала и тем самым осуществляют маскирование на его фоне полезных импульсов. Достоинством метода является низкая требовательность к системным ресурсам, что позволяет использовать его на компьютерных системах с невысокими техническими характеристиками. Кроме того, программа, реализующая данный метод, может обрабатывать сигналы в реальном масштабе времени, что является полезным свойством в специфических условиях изучения геоакустической эмиссии на различных стадиях сейсмической активности.
76
Глава 5. ПРИМЕНЕНИЕ НЕЙРОННЫХ СЕТЕЙ ДЛЯ ВЫЯВЛЕНИЯ И КЛАССИФИКАЦИИ ГЕОАКУСТИЧЕСКИХ АНОМАЛИЙ Для выявления и классификации аномалий ГАЭ, возникающих перед землетрясениями, целесообразно использовать систему распознавания образов. Одним из возможных вариантов в данном случае являются нейронные сети. Перед тем как приступить к созданию такой системы, необходимо выяснить, как человек, анализируя данные, представленные в виде графических зависимостей, определяет наличие или отсутствие возмущений. Если предположить, что человек интуитивно разбивает график на небольшие подобласти и анализирует каждую из подобластей, при этом уже зная, что одни возмущения – это аномалия ГАЭ перед землетрясением, а другие – шумовые воздействия (метеорологического, техногенного или биологического характера), то для реализации данной способности человека хорошо подходит нейронная сеть. В этом случае следует разбить суточный файл на небольшие участки и затем представить их сети. Для того чтобы сеть могла различить, что это за участок, ее можно обучить стандартным аномалиям ГАЭ и шумовым воздействиям. Далее уже от сети зависит, как определить участок, который не подходит под ее стандарт. В качестве исходных данных для нейронной сети целесообразно использовать накопленные за 4 секунды сигналы на выходе семи частотных поддиапазонов (рис. 1.1) по следующим причинам. Как было указано ранее, аномалии ГАЭ, предшествующие землетрясениям, наблюдаются в килогерцовой области спектра, в то время как мешающие воздействия метеорологического и техногенного происхождения наблю77
даются в основном в более низкочастотном диапазоне. Таким образом, сигналы еще до нейронной сети разделяются на значимые поддиапазоны. Поток информации в данном случае – отсчет в 4 секунды позволяет использовать нейронную сеть в реальном времени. Использование в качестве исходных данных широкополосного сигнала с частотой дискретизации порядка 20 кГц (т. е. 20 000 отсчетов в секунду) не позволяет применить нейронную сеть в режиме реального времени в связи с ограничениями, обусловленными производительностью современных вычислительных средств. Для анализа данных нейронной сетью выбраны пять частотных поддиапазонов: 1500–6000 и 6000–10 000 Гц – для анализа аномалий ГАЭ перед землетрясениями; 50–200 и 200– 700 Гц – для анализа шумовых мешающих воздействий; 700– 1500 Гц – для анализа всех вышеуказанных воздействий. Поддиапазоны 0,1–10 и 10–50 Гц не используются, поскольку предназначены для наблюдения за сейсмическим и высокочастотным сейсмическим шумом, который на данном этапе не используется при анализе аномалий высокочастотной ГАЭ. Первоначально обучающая выборка была построена на аномалии ГАЭ перед землетрясением с локальной магнитудой М = 5,3, происшедшим 18 декабря 2002 г. в 11:09 UT на эпицентральном расстоянии 105 км от пункта наблюдения. Координаты гипоцентра землетрясения: 52,97°N, 159,8°E, глубина – 42 км (оперативные данные Камчатского филиала ГС РАН). На рис. 5.1 приводится трехсуточная запись с датчика вертикального направления. Детальное изучения аномалий ГАЭ показало, что элементарный сигнал занимает всего шесть отчетов. Помеховые возмущения, которые наблюдались в низкочастотных поддиапазонах, можно было бы представить и меньшим числом отсчетов, но для упрощения обработки было принято решение представить любое элементарное возмущение, состоящее из шести отсчетов. Недостающие данные дополнялись отсчетами, которые наблюдались в отсутствие всяких возмущений в этом диапазоне. 78
Рис. 5.1. Аномалия ГАЭ перед землетрясением от 18 декабря 2002 г. в 11:09 UT
Опираясь на этот факт, была произведена выборка элементарных сигналов, состоящих из шести отсчетов для каждого поддиапазона. Для высокочастотных поддиапазонов 700–1500, 1500–6000 и 6000–10 000 Гц выбирались «полезные» аномалии ГАЭ и моменты, когда наблюдалось спокойствие той же длительности. При выборе моментов спокойствий было замечено, что пороговые уровни в этом случае сильно варьировали и очень часто совпадали со слабыми аномалиями ГАЭ, что затрудняло задачу классификации при выборе сети и играло основополагающую роль. Для диапазонов 50–200 и 200–700 Гц выбирались «вредные» аномалии ГАЭ и периоды затишья. Соответственно обучающей выборке подготавливался массив целей (ответов), который сопоставлялся ей следующим образом: при подаче на вход сети возмущений на выходе ожидалось «2», в противном случае – «1». 79
Во время экспериментов использовалась длина элементарного события и больше шести отсчетов (8, 16, 32, 64). Опыты показали, что с такими выборками сеть чаще ошибалась, поэтому в дальнейшем элементарное событие рассматривалось только длительностью в шесть отсчетов. Следует отметить, что первоначально все эксперименты ставились на выборке частотного поддиапазона 1500–6000 Гц вертикального канала, так как в этом канале наиболее четко просматривались аномалии ГАЭ, возникающие перед землетрясением. После получения положительного результата ставились однотипные эксперименты над обучающей выборкой остальных поддиапазонов вертикального канала. Когда окончательные сети были получены, им на вход подавались сигналы поддиапазонов других каналов. Получив отличный результат, полученные сети для вертикального канала более не переобучались для остальных трех каналов. Во время исследования был также обнаружен следующий факт. В зависимости от внешних условий и местоположения источника событий уровень среднего значения сигналов постоянно варьировался, что приводило к искажению обучающей выборки. Поэтому первоначально сигнал подвергали процедуре центрирования, а потом уже подавали на вход нейронной сети (рис. 5.2). 2200
1400
2000
1200
1800
1000
1600 800
1400 600
1200 400
1000
200
800 600
0
0.5
1
1.5
2
2.5
0
0
0.5
1
1.5
2
4
2.5 4
x 10
x 10
а
б
Рис. 5.2. ГАЭ в диапазоне 1500–6000 Гц за 23 августа 2006 г. до процедуры центрирования (а) и после нее (б)
На рис. 5.3–5.5 приведены примеры обучающих выборок в различных частотных поддиапазонах. На рис. 5.3 приведены 80
примеры «полезных» сигналов (аномалии ГАЭ пред землетрясениями) из обучающей выборки поддиапазона 1500–6000 Гц.
2000
2000
1800
1800
1600
1600
1400
1400
1200
1200
1000 800
1000
600
800
400
600
200
400
0
200 1
2
3
4
5
6
0 1
2
3
4
5
6
2500 700 600
2000
500
1500 400
1000
300 200
500 100
0
0 1
2
3
4
5
1
6
2
3
4
5
6
Рис. 5.3 Примеры «полезных» сигналов поддиапазона 1500–6000 Гц
60,2
18,2
60
18 59,8
17,8 59,6
17,6 59,4
17,4
59,2
17,2
59
17
58,8
16,8
58,6
16,6
58,4 1
2
3
4
5
6
16,4 1
2
3
4
5
6
Рис. 5.4. Примеры «вредных» сигналов поддиапазона 1500–6000 Гц
На рис. 5.4 приведены примеры «вредных» сигналов (шумы) из обучающей выборки поддиапазона 1500–6000 Гц. На рис. 5.5 приведены примеры «полезного» сигнала (аномалии 81
ГАЭ, обусловленные метеорологическими и техногенными явлениями) из обучающей выборки поддиапазона 200–700 Гц. Так как «вредные» сигналы (шумы) в данном случае аналогичны предыдущему примеру (рис. 5.4), то рисунки для поддиапазона 200–700 Гц приводиться не будут. На рис. 5.4 очень четко просматривается избыточность данных в обучающей выборке для шумов. 1200
500 450
1000
400 350
800
300 250
600
200 400
150 100
200
50 0
0
1
2
3
4
5
6
250
1
2
3
4
5
6
1000 900
200
800 700 600
150
500 400
100
300 200
50
100 0
0 1
2
3
4
5
6
1
2
3
4
5
6
Рис. 5.5 Примеры «полезных» сигналов поддиапазона 200–700 Гц
Практически все модели нейронных сетей способны распознавать образы, поэтому были проанализированы различные модели, которые могли справиться с поставленной задачей. Для анализа аномалий ГАЭ первоначально использовались следующие модели нейронных сетей: линейная, радиальнобазисная, карты и слои Кохонена, а также еще одна разновидность карт Кохонена – LVQ-сеть (Learning Vector Quantization). Из-за недостаточной информации о практических решениях все 82
значения архитектуры сети подбирались эвристическим методом. Далее приводятся результаты моделирования сетей. В качестве среды для моделирования использовалась специализированная среда для научно-технических вычислений – MATLAB 7.0 с пакетом Neural Network. Линейная сеть. Во время экспериментов предполагалось, что линейные сети справятся с поставленной задачей разделением выборки на две группы. Были проведены эксперименты с большим числом архитектур линейных сетей. Для наглядности приводятся только значения сети с простой и сложной архитектурой, достигнутые в экспериментах. Первая созданная сеть (linnet1) была трехслойной: – входной слой – число нейронов 6 (размер матрицы обучающей выборки); – второй слой – число нейронов 30; – третий слой – число нейронов 1 (на выходе значения 1 или 2). При этом использовался метод обучения обратного распространения ошибки. Заданное число эпох равно 10 000. На графике обучения сети (рис. 5.6) показано снижение среднеквадратичной ошибки сети. При увеличении числа эпох можно снизить ошибку сети еще на тысячные доли, но полностью нулевой результат невозможен. Результат тестирования модели linnet1 приведен ниже. Во время экспериментов постепенно усложнялась архитектура сети от увеличения нейронов в слое до увеличения слоев. Это позволяло нам увеличить возможности сети и разделить нелинейные образы линейной моделью. Далее создадим девятислойную сеть (linnet2): – входной слой – число нейронов 6 (размер матрицы обучающей выборки); – второй слой – число нейронов 60; – третий слой – число нейронов 40; – четвертый слой – число нейронов 20; – пятый слой – число нейронов 10; – шестой слой – число нейронов 8; – седьмой слой – число нейронов 5; 83
– –
восьмой слой – число нейронов 3; девятый слой – число нейронов 1 (значения 1 или 2).
Рис. 5.6. График обучения нейронной сети
Метод обучения используется тот же, число эпох обучения – 1000. График обучения приведен на рис. 5.7.
Рис. 5.7. График обучения нейронной сети
84
Следует отметить, что при усложнении архитектуры сети время обучения заметно увеличивалось, график обучения во многом повторяет предыдущий вариант сети. Результаты работы полученных сетей приведены в табл. 5.1. Таблица 5.1
1 17 17 21 53 618 159 32 22 17 17 14 14 17 12 16 47 327 69 13 12 11 12 235 11 11 14 150 14 14 27 34 378 35
2 17 17 20 106 903 104 20 19 17 17 14 14 15 12 16 57 434 36 13 12 11 12 314 11 11 14 311 14 14 27 27 402 63
Входные данные 3 4 17 17 17 17 38 37 192 241 835 618 76 36 18 17 18 17 17 17 17 17 14 14 14 535 14 14 13 14 18 22 88 123 265 190 20 26 12 12 12 12 11 12 11 11 62 20 11 12 11 11 14 14 64 23 14 14 14 14 25 26 26 26 104 73 31 26
5 17 17 63 257 547 44 18 17 17 17 14 102 14 17 43 224 139 43 12 12 11 12 13 11 11 14 16 14 14 26 25 56 47
85
6 17 18 69 474 432 48 20 17 17 17 14 29 14 17 31 274 90 18 12 12 12 11 12 11 11 14 14 14 14 82 25 30 34
linnet1 7 –6,9372 –7,4337 –32,404 –126,54 –171,42 –110,4 –20,099 –10,489 –6,9372 –6,9372 –5,1641 356,09 –7,534 –6,7363 –20,54 –141,26 –131,95 –52,151 –4,8394 –3,9827 –3,1033 –4,7033 –175,59 –2,6073 –3,3923 –5,1641 –110,09 –5,1641 –5,1641 –41,342 –17,464 –261,36 –34,184
linnet2 8 1,9871 1,9643 0,68697 62,043 45,102 0,80924 1,8621 1,9408 1,9871 1,9871 1,895 1,3753 1,9015 2,0499 2,3109 21,366 4,0196 0,92912 1,8243 1,846 1,8974 1,8296 1,3898 1,8961 1,8228 1,895 0,68861 1,895 1,895 0,13247 1,9724 0,99875 0,91614
Окончание табл. 5.1 1 27 26 86 28 26 44 75 25 26 27 27 23 24 26 107 24
2 73 25 37 26 25 28 132 25 26 966 26 24 535 25 38 24
3 48 25 27 25 25 204 77 25 26 209 27 24 934 24 26 24
4 29 96 25 203 25 55 34 53 30 67 26 24 203 24 24 24
5 29 37 25 55 25 32 29 30 27 45 28 25 56 27 24 24
6 31 67 27 30 25 26 26 29 26 31 31 24 32 24 24 24
7 –9,7176 16,968 –59,153 109,54 –12,428 70,8 –33,01 6,0439 –9,5797 –6,5974 –15,987 –10,779 452,4 –14,06 –74,411 –11,08
8 1,0631 6,0307 0,71068 4,9919 2,0774 1,0114 0,96664 3,9566 2,3962 0,99596 1,7198 2,1307 1,7672 2,112 0,44468 2,107
Проанализировав табл. 5.1, видно, что сети не справились с поставленной задачей. На выходе должны быть значения 1 или 2, а на самом деле можно увидеть любые значения, кроме требуемых. Заметно, как архитектура сети влияет на исход решения задачи, но все же усложнение архитектуры не привело к положительному решению, поэтому пришлось отказаться от линейной модели нейронной сети. Радиально-базисная сеть. Использовалась вероятностная разновидность радиально-базисных сетей. Сеть rbf состоит из трех слоев: – входной слой – число нейронов 6 (размер матрицы обучающей выборки); – второй слой – радиально симметричные скрытые нейроны. К сожалению, в Matlab количество нейронов в этом слое создается автоматически и минимально равно количеству элементов в обучающей выборке (в нашем случае – 103). При нехватке нейронов для решения задачи их число постепенно увеличивается. В конечном варианте число нейронов осталось неизменным и равно 103; 86
– третий (выходной) слой – число нейронов 1 (на выходе одномерные значения 1 и 2). Обучение сети происходит в несколько этапов. Сначала определяются центры и отклонения радиальных элементов, после этого оптимизируются весовые коэффициенты выходного слоя. Обучение происходит методом обратного распространения ошибки. Результат моделирования приведен в табл. 5.2. Таблица 5.2
17 23 19 17 21 53 618 159 32 22 17 17 16 57 18 17 17 433 16 14 14 17 12 16 47 327 69 13 19 19
17 18 17 17 20 106 903 104 20 19 17 17 17 49 17 17 16 86 16 14 14 15 12 16 57 434 36 13 19 19
Входные данные 17 17 18 17 17 17 17 17 38 37 192 241 835 618 76 36 18 17 18 17 17 17 17 16 30 81 49 42 17 17 17 17 16 16 28 18 16 16 14 14 14 535 14 14 13 14 18 22 88 123 265 190 20 26 12 12 19 18 19 28
87
17 17 17 17 63 257 547 44 18 17 17 17 71 30 25 17 18 17 16 14 102 14 17 43 224 139 43 12 19 20
17 17 17 18 69 474 432 48 20 17 17 16 64 22 18 17 17 16 16 14 29 14 17 31 274 90 18 12 19 19
rbf 2 1 2 2 1 1 1 1 1 1 2 2 1 1 1 2 2 1 2 1 1 1 1 1 1 1 1 1 2 1
Как видно из табл. 5.2, результат моделирования более близок к желаемому. Но при многократных испытаниях (данные испытаний внесены в табл. 5.2) замечено, что сеть очень часто опознает шумовые воздействия как полезный сигнал. Ввиду невозможности изменять архитектуру сети и недостоверности полученных результатов от нее пришлось отказаться. Слой Кохонена. Слои и карты Кохонена – самоорганизующиеся модели нейронных сетей. Одной из самых важных функций этих моделей является классификация. Число классов, на которые сеть будет разбивать обучающую выборку, зависит от числа нейронов, содержащихся в модели. Первоначально требовалось разделить выборку на два класса – «полезные» и «вредные», поэтому первое число нейронов, содержащееся в сети coh2, равнялось двум. Задавалось число эпох обучения, равное 500. Результат тестирования приведен в табл. 5.3. Из-за неудачного результата сети coh2 было принято решение создать еще одну сеть с числом нейронов, равным 20. Число эпох аналогично предыдущему примеру. Результат тестирования приведен в табл. 5.3. Таблица 5.3 Входные данные 1 29 28 117 34 31 46 48 31 38 169 60 194 81 34
2 28 30 223 29 30 43 68 30 75 99 39 276 44 55
3 29 28 263 31 32 103 64 37 283 117 31 188 33 88
4 30 28 109 31 32 55 57 29 375 299 34 176 30 119
5 29 33 85 30 32 32 35 31 123 436 34 602 29 195
88
6 28 36 48 36 37 40 30 33 127 180 54 260 29 336
coh2 (1 – шум) 7 1 1 1 1 1 1 1 1 1 1 1 1 1 1
coh20 (1 – шум) 8 1 1 1 1 1 1 1 1 16 7 1 16 1 1
Окончание табл. 5.3 1 308 195 87 105 150 107 89 61 55 79 102 39 111 51 65 44 616 333
2 100 194 56 187 453 161 44 396 132 475 100 63 135 56 57 187 547 360
3 61 71 35 200 547 131 38 405 230 302 314 115 81 46 53 173 455 244
4 100 155 34 102 211 59 33 255 140 420 123 65 53 45 48 336 354 284
5 295 151 40 66 77 43 31 517 157 476 53 423 566 62 32 202 447 253
6 195 126 58 100 57 72 88 173 77 330 48 139 135 50 45 233 468 320
7 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
8 1 1 1 1 19 1 1 16 1 16 1 1 1 1 1 16 7 16
По итогам испытаний видно, что сеть coh2 практически не справилась с поставленной задачей, а сеть coh20 отлично справилась. Но чувствительность ее невысока (в табл. 5.3 чувствительность выделена жирным), что противоречит поставленной задаче. Карты Кохонена. Учитывая опыт тестирования слоя Кохонена, было принято решение создать двумерные и одномерные карты Кохонена. Двумерная карта: архитектура 3 на 4 нейрона, т. е всего 12 нейронов; трехмерная карта: архитектура 2 на 4 на 4. Зададим, как и ранее, число эпох обучения, равное 500. Итоги тестирования приведены в табл. 5.4. Следует отметить, что вредный сигнал в сети som3*4 классифицируется цифрой 7, а сеть som2*4*4 классифицирует вредное воздействие на четыре класса (с первого по четвертый). При анализе табл. 5.4 видно, что сеть som2*4*4 более чувствительна к слабым сигналам, чем сеть som3*4, поэтому было принято решение остановиться на этой модели нейронной сети. При большом числе экспериментов было обнаруже89
но, что для каждого сейсмического события определенной дальности, направления и глубины сеть отрабатывает данные по-разному, выделяя определенные классы аномалий. Кроме того, большое количество классов неудобно для получения решения на выходе сети в формате «Да – Нет». Но для более глубокого изучения аномалий ГАЭ преимущество «многоклассовости» даст большие возможности. Таблица 5.4 Входные данные 17 17 21 53 618 159 32 22 17 16 57 18 16 47 327 69 22 11 11 22 12 258 21 25 22 203 21 21
17 17 20 106 903 104 20 19 17 17 49 17 16 57 434 36 34 11 11 13 11 53 80 22 21 51 25 21
17 17 38 192 835 76 18 18 17 30 49 17 18 88 265 20 16 11 11 11 11 18 31 21 21 30 22 21
17 17 37 241 618 36 17 17 16 81 42 17 22 123 190 26 13 11 11 11 11 13 23 21 21 27 21 23
17 17 63 257 547 44 18 17 17 71 30 25 43 224 139 43 12 11 413 11 11 12 21 21 21 22 21 22
90
17 18 69 474 432 48 20 17 16 64 22 18 31 274 90 18 12 11 79 11 207 12 21 21 630 21 21 21
som3*4 (7 – шум) 7 7 7 1 2 4 7 7 7 7 7 7 7 4 12 7 7 7 7 7 7 7 7 7 7 7 7 7
som2*4*4 (1÷4 – шум) 1 1 2 12 30 6 1 1 1 2 2 1 1 4 14 1 1 1 4 1 2 5 9 1 4 6 1 1
LVQ-сеть. Этот вид сетей является развитием самоорганизующихся сетей Кохонена. Она имеет три слоя: входной, конкурирующий и линейный. Конкурирующий слой выполняет кластеризацию векторов, а линейный слой соотносит классы с классами, заданными пользователем, т. е. при обучении используется обучающая выборка на входе и соответствующие ей ответы на выходе. Во время экспериментов были созданы сети с разным числом нейронов конкурирующего слоя. Слишком малое число нейронов, как, впрочем, и большое, не привело к успешным результатам. При последовательном увеличении нейронов было замечено, что сеть дает на выходе успешный результат, если число нейронов в конкурирующем слое нечетное. После испытаний было принято решение остановиться на сети с числом нейронов, равным 37. Результаты тестирования сети приведены в табл. 5.5. Таблица 5.5
1 37 922 28 28 28 117 34 31 46 48 31 38 169 60 194 81 34 308 195
2 42 326 28 30 30 223 29 30 43 68 30 75 99 39 276 44 55 100 194
Входные данные 3 4 47 47 138 55 30 30 56 144 28 28 263 109 31 31 32 32 103 55 64 57 37 29 283 375 117 299 31 34 188 176 33 30 88 119 61 100 71 155
5 35 32 28 101 33 85 30 32 32 35 31 123 436 34 602 29 195 295 151
91
6 40 28 28 40 36 48 36 37 40 30 33 127 180 54 260 29 336 195 126
LVQ37 (2 – шум) 7 2 1 2 2 2 1 2 2 2 2 2 1 1 2 1 2 2 1 1
Окончание табл. 5.5 1 87 105 150 107 89 61 55 79 102 39 111 51 44 616 333 737 57 44 150 54
2 56 187 453 161 44 396 132 475 100 63 135 56 187 547 360 380 56 41 137 49
3 35 200 547 131 38 405 230 302 314 115 81 46 173 455 244 159 75 34 302 37
4 34 102 211 59 33 255 140 420 123 65 53 45 336 354 284 161 96 47 234 76
5 40 66 77 43 31 517 157 476 53 423 566 62 202 447 253 80 106 49 208 434
6 58 100 57 72 88 173 77 330 48 139 135 50 233 468 320 109 58 112 243 752
7 2 1 1 1 2 1 1 1 1 1 1 2 1 1 1 1 2 2 1 2
Изучив табл. 5.5, можно сказать, что сеть прекрасно справилась с поставленной задачей, хотя в некоторых случаях допустила некорректные ошибки. Что касается чувствительности, то эта сеть немного уступает сети som2*4*4. При подведении итогов проделанных экспериментов выбор сетей остановился на модели som2*4*4 и LVQ37. Эти два вида моделей хорошо справляются с поставленной задачей. В связи с большей эффективностью модели som2*4*4 и перспективностью использования ее для более детального анализа аномалий ГАЭ окончательный выбор остановился именно на ней. Далее было проведено обучение сети для каждого частотного поддиапазона. Для поддиапазонов 50–200 и 200–700 Гц была выбрана более простая архитектура нейронов: som1*3*5. 92
Система анализа сигналов геоакустической эмиссии. На основе представленных выше моделей сетей в среде Matlab была построена система автоматического выявления и анализа сигналов геоакустической эмиссии (рис. 5.8) как составная часть системы, рассмотренной в гл. 1, 2. Всю систему можно разделить на четыре уровня. Первый уровень состоит из моделей нейронов, описанных выше, которые обрабатывают сигналы с четырех каналов направлений в пяти частотных поддиапазонах. Наличие второго уровня связано с необходимостью перехода на меньшее количество классов для итогового принятия решения от 32/15 к 2 (1 – шумы и 2 – аномалия). Решить эту задачу можно программным путем, но для экономии времени воспользовались радиально-базисной моделью нейронных сетей.
Рис. 5.8. Структурная схема нейросетевой системы анализа сигналов ГАЭ
Сеть второго уровня обучается на следующий режим: 1 – слабые шумы, 2 – аномальный сигнал по каждому из пяти частотных поддиапазонов. Третий уровень системы анализи93
рует совокупность информации со всех частотных поддиапазонов и принимает решение по каждому пространственному каналу, основываясь на таблице истинности (табл. 5.6). Таблица 5.6 Каналы 50–200 Гц 200–700 Гц 700–1500 Гц 1,5–6 КГц 6–10 КГц
Каналы 50–200 Гц 200–700 Гц 700–1500 Гц 1,5–6 КГц 6–10 КГц
1 0 0 0 0 0 т 2
2 0 0 0 0 1 а 4
3 0 0 0 1 0 а 4
4 0 0 0 1 1 а 4
5 0 0 1 0 0 а 4
6 0 0 1 0 1 а 4
17 1 0 0 0 0 ш 3
18 1 0 0 0 1 н 1
19 1 0 0 1 0 н 1
20 1 0 0 1 1 н 1
21 1 0 1 0 0 ш 3
22 1 0 1 0 1 н 1
Классы 8 9 10 0 0 0 0 1 1 1 0 0 1 0 0 1 0 1 а ш ш 4 3 3 Классы 23 24 25 26 1 1 1 1 0 0 1 1 1 1 0 0 1 1 0 0 0 1 0 1 н н ш ш 1 1 3 3 7 0 0 1 1 0 а 4
11 0 1 0 1 0 ш 3
12 0 1 0 1 1 ш 3
13 0 1 1 0 0 ш 3
14 0 1 1 0 1 ш 3
15 0 1 1 1 0 ш 3
16 0 1 1 1 1 ш 3
27 1 1 0 1 0 ш 3
28 1 1 0 1 1 ш 3
29 1 1 1 0 0 ш 3
30 1 1 1 0 1 ш 3
31 1 1 1 1 0 ш 3
32 1 1 1 1 1 ш 3
Примечание. Символ т – тишина; а – аномалия ГАЭ; н – неопределенность; ш – паразитный шум.
Например, наличие сигнала 2-го класса на выходе сети в трех высокочастотных каналах и одновременно сигнала 1-го класса в шумовых каналах приводит к решению «аномалия ГАЭ», при обратной ситуации – к решению «помеховый шум». Неопределенность (н) в таблице – сложный случай, в котором принятие решения возлагается на человека. На третьем уровне также была использована радиально-базисная модель сети. На четвертом уровне сигналы подвергаются процедуре усреднения окном переменной ширины, задаваемой в интерфейсе программы, и в зависимости от установленных временных порогов срабатывания для мешающих шумов и аномалий ГАЭ принимается итоговое решение о классе явле94
ния в канале. Все полученные сведения записываются в файл отчета и выводятся в виде графиков на экран. Пример работы системы представлен на рис. 5.9 [11]. В данном случае в качестве входных воздействий использованы возмущения геоакустической эмиссии, зафиксированные в суточном временном интервале до землетрясения с локальной магнитудой М = 5,4, происшедшего 6 июня 2005 г. в 22:37 UT на эпицентральном расстоянии 270 км от пункта наблюдения. Координаты гипоцентра землетрясения: 50,58°N, 157,62°E, глубина – 51 км (оперативные данные Камчатского филиала ГС РАН). Как следует из рис. 5.9, на выходе первого уровня в каналах 1500–6000 и 6000–10 000 Гц системой принято решение о наличии возмущений (классы принятых решений – 20 и выше).
а
б
в
Рис. 5.9. Пример выработки решения системой: а – сигналы на входе системы распознавания; б – сигналы на выходе первого уровня (классы 32/15); в – сигналы на выходе второго уровня (классы 1, 2)
95
На втором уровне по этим возмущениям также принято решение о наличии возмущений (присвоен класс 2). Далее по этому событию третий уровень системы принял решение 4 – предвестниковая аномалия, на четвертом уровне с учетом установленных временных порогов это решение было подтверждено. Анализ решений, принимаемых нейронной сетью при наличии геоакустических возмущений, предшествующих землетрясениям, показал, что для каждого землетрясения определенной дальности, направления, глубины и магнитуды сеть вырабатывает определенные классы решений. Таким образом, в дальнейшем при достаточном статистическом материале появляется возможность по результатам работы нейронной сети прогнозировать не только направление, но также дальность, глубину и класс готовящегося события. Для более детального анализа этого явления проведено дополнительное моделирование сетей Кохонена различной архитектуры с целью выявления наиболее оптимальной для сигналов ГАЭ. При исследовании длина элементарного события была увеличена с 6 до 20 отсчетов. Пример новой обучающей выборки показан на рис. 5.10 и 5.11. Хотелось бы отметить, что при выборе обучающей выборки особое внимание уделялось низкочастотным поддиапазонам для более качественного выявления среди фоновых шумовых воздействий сигналов, сгенерированных воздействием метеофакторов. Для анализа использовались следующие архитектуры карт Кохонена: │2 4 4│, │4 15│, │20 5 3│, │10 8 3│, │5 9 3│, │4 5 3│, │30 35│, │25 30│, │30 12 4│, │30 12 3│, │2 4 4 2│, │2 4 10│. В качестве обучающей выборки использовались сигналы аномалий ГАЭ перед землетрясениями, мешающих воздействий (ветер и дождь) и фоновые шумы. Применение различных моделей нейросетей на геоакустических данных за 2006 г. показало, что для анализа сигналов наиболее эффективны архитектуры карт Кохонена размерностью │4 15│ и │30 35│. 96
0,5
0,6
0,45 0,5
0,4 0,35
0,4
0,3 0,25
0,3
0,2 0,2
0,15 0,1
0,1
0,05 0
0 1
2
3
4
5
6
7
8
1
9 10 11 12 13 14 15 16 17 18 19 20
2
3
4
5
6
7
8
9 10 11 12 13 14 15 16 17 18 19 20
0,09 0,08 0,07 0,06 0,05 0,04 0,03 0,02 0,01 0 1
2 3
4
5
6
7
8
9 10 11 12 13 14 15 16 17 18 19 20
Рис. 5.10. Примеры «полезных» сигналов поддиапазона 1500–6000 Гц
Рис. 5.11. Примеры «полезных» сигналов поддиапазона 200–700 Гц
При этом сеть │4 15│ позволяет достаточно быстро анализировать сигналы в режиме реального времени непосредственно при регистрации, а сеть │30 35│, различающая шумы спокойного периода и практически соизмеримые с ними по амплитуде сигналы предвестниковых аномалий, дает возмож97
ность дополнительного, более детального изучения сигнала в лаборатории. Оказалось, что модель нейронной сети │2 4 4│, которая использовалась ранее, показала далеко не лучший результат [13]. Также следует отметить ошибочность мнения, что наиболее эффективной является сеть с наибольшей размерностью и наибольшим количеством нейронов. Большое число нейронов ведет к долгому процессу обучения, которое не всегда оправдывается. Пример использования различных сетей представлен на рис. 5.12 и 5.13.
Рис. 5.12 Аномальный сигнал ГАЭ, зарегистрированный 23.08.2006 г.
На рис. 5.12 приведен сигнал с аномалией ГАЭ, зарегистрированной 23.08.2006 г. в поддиапазоне 1500–6000 Гц перед землетрясением с локальной магнитудой М = 6,15, происшедшим 24 августа 2006 г. в 21:50 UT на эпицентральном расстоянии 220 км от пункта наблюдения. Координаты гипоцентра землетрясения: 51,01°N, 158,01°E, глубина – 40 км (оперативные данные Камчатского филиала ГС РАН). На рис. 5.13 показана реакция карт Кохонена различной архитектуры на этот сигнал. 98
В результате проведенного исследования для первого уровня автоматизированной нейросетевой системы была выбрана архитектура нейронной сети │4 15│, позволяющая классифицировать входной сигнал на 60 уровней. Данная модель использована как для высокочастотных, так и для низкочастотных поддиапазонов. Для более детального анализа высокочастотных поддиапазонов в лабораторных условиях дополнительно выбрана архитектура сети │30 35│, позволяющая классифицировать сигнал на 1050 уровней.
а
б
в
г
д
е
ж
з
и
к
л
м
Рис. 5.13. Реакция нейронных сетей различной архитектуры на аномальный сигнал ГАЭ: а – │30 12 3│; б – │30 12 4│; в – │2 4 4│; г – │30 35│; д – │4 15│; е – │4 5 3│; ж – │25 30│; з – │10 8 3│; и – │20 5 3│; к – │2 4 10│; л – │2 4 4 2│; м – │5 9 3│
99
Работа системы первого уровня для 3 высокочастотных поддиапазонов (700–1500, 1500–6000, 6000–10 000 Гц) на примере акустической аномалии 23 августа 2006 г. показана на рис. 5.14. На данном этапе исследования конструкция второго, третьего и четвертого уровней автоматизированной системы пересматривается и находится в стадии разработки.
а
б
в
Рис. 5.14. Пример выработки решения системой: а – геоакустический сигнал на входе; б – реакция нейронной сети │4 15│; в – реакция нейронной сети │30 35│
Очевидно, что эти уровни должны усложниться и анализировать информацию не просто о наличии или отсутствии предвестника, но и о его характере, а также предоставлять возможности по распознаванию различных аномальных сигналов.
100
ЗАКЛЮЧЕНИЕ В работе рассмотрен новый объект исследования – высокочастотная геоакустическая эмиссия. Научные публикации последних лет показывают, что изучение данного направления является одним из перспективных для изучения физики предвестников землетрясений и развития методов их прогноза [4, 5, 8–10, 18]. Причиной генерации ГАЭ являются деформационные процессы, распространяющиеся из будущих очагов землетрясений, которые приводят к образованию зон поверхностной дилатансии размерностью до сотен километров [1, 2, 19]. Данное явление сопровождается испусканием импульсов высокочастотных акустических волн как из-за образования микроразломов и трещин, так и из-за подвижек в существующих разломах, заполненных обычно водонасыщенными осадочными породами. Таким образом, наблюдаемые сигналы высокочастотной ГАЭ не распространяются из очага готовящегося землетрясения, а генерируются в непосредственной близости от места наблюдения под действием деформационных сил. В работе рассмотрены методы регистрации и анализа сигналов геоакустической эмиссии. Особое внимание уделено вопросам технической реализации аппаратно-программных комплексов. Приведены обобщенные структурные схемы и алгоритмы работы программного обеспечения. Рассмотрено многообразие видов акустических сигналов, регистрируемых комплексами. Установлено, что помимо непосредственно геоакустических импульсов системами регистрируются сигналы метеорологического, техногенного и биологического характера. Эти сигналы являются паразитными для исследований, поэтому необходимо научиться правильно их классифицировать и исключать из дальнейшей обработки. Для этого предлагается осуществлять первичный анализ и отбор сиг101
налов многоуровневой нейронной сетью. Приведена возможная архитектура такой сети и результаты ее использования. Для учета метеообстановки при анализе используются данные метеостанции. Для исследования анизотропии геоакустических сигналов предложено использование векторно-фазовых методов. В работе рассмотрены методы автоматизации поиска геоакустических импульсов и выявления их направленности. Установлено, что сигналы высокочастотной ГАЭ как в спокойный период, так и на заключительной стадии подготовки землетрясения существенно анизотропны [6, 7]. Авторы выражают надежду, что дальнейшее развитие методов исследования высокочастотной геоакустической эмиссии позволит использовать ГАЭ в качестве составного элемента комплекса для изучения физики предвестников землетрясений и построения на его основе в будущем эффективной системы прогнозов землетрясений.
102
ЛИТЕРАТУРА 1. Geller R.J. VAN: a critical evaluation // Critical review of VAN, ed. J.Lighthill // World Scientific. – 1996. – P. 155–238. 2. Алексеев А.С., Белоносов А.С., Петренко В.Е. Определение интегрального предвестника землетрясений с использованием многодисциплинарной модели и активного вибросейсмического мониторинга // Пробл. динамики литосферы и сейсмичности. Вычислительная сейсмология: Сб. тр. Вып. 32. – М.: ГЕОС, 2001. – С. 81–97. 3. Беляков А.С., Николаев А.В. Сейсмоакустические приемники с магнитоупругим преобразованием // Физика Земли. – 1993. – № 7. – С. 74–80. 4. Беляков А.С. Землетрясения и подземный звук // Земля и вселенная. – 1996. – № 2. – С. 23–29. 5. Отклик акустической эмиссии на сейсмический процесс / А.В. Горбатиков, О.А. Молчанов, М. Хаякава и др. // Вулканология и сейсмология. – 2001. – № 4. – С. 66–78. 6. Геоакустическая локация областей подготовки землетрясений / В.А. Гордиенко, Т.В. Гордиенко, А.В. Купцов и др. // Докл. Акад. наук. – 2006. – Т. 407. – № 5. – С. 669–672. 7. Результаты исследования анизотропии геоакустических сигналов на озере Микижа векторно-фазовыми методами / В.А. Гордиенко, Т.В. Гордиенко, Ю.В. Марапулец, А.О. Щербина // Солнечно-земные связи и предвестники землетрясений: Сб. тр. IV Междунар. конф. – ПетропавловскКамчатский: ИКИР ДВО РАН, 2007. – С. 140–146. 8. Купцов А.В., Марапулец Ю.В., Шевцов Б.М. Анализ изменений геоакустической эмиссии в процессе подготовки сильных землетрясений на Камчатке // Электронный журн. «Исследовано в России», 262, с. 2809–2818, 2004. http://zhurnal.are.relarn.ru/articles/2004/262.pdf 103
9. Исследование возмущений геоакустической эмиссии в период подготовки землетрясений / А.В. Купцов, Ю.В. Марапулец, А.О. Щербина, Г.Ю. Голотенко // Солнечно-земные связи и электромагнитные предвестники землетрясений: Сб. докл. III Междунар. конф. – Петропавловск-Камчатский: ИКИР ДВО РАН, 2004. 10. Купцов А.В. Изменение характера геоакустической эмиссии в связи с землетрясением на Камчатке // Физика Земли. – 2005. – № 10. – С. 59–65. 11. Купцов А.В., Ларионов И.А., Шевцов Б.М. Особенности геоакустической эмиссии при подготовке камчатских землетрясений // Вулканология и сейсмология. – 2005. – № 5. – С. 45–59. 12. Применение нейронных сетей для оценки возмущений геоакустической эмиссии на заключительной стадии подготовки землетрясений на Камчатке / А.В. Купцов, И.А. Ларионов, Ю.В. Марапулец и др. // Междунар. конф. по мягким вычислениям и измерениям (SCM' 2006): Сб. докл. Т. 1. – СПб., 2006. – С. 238–240. 13. Нейронные сети на картах Кохонена в задачах оценки возмущений геоакустической эмиссии / И.А. Ларионов, Ю.В. Марапулец, М.А. Мищенко и др. // Междунар. конф. по мягким вычислениям и измерениям (SCM' 2007): Сб. докл. – СПб.: Питер, 2007. – С. 290–292. 14. Система реального времени для обработки сигналов геоакустической эмиссии / И.А. Ларионов, Ю.В. Марапулец, М.А. Мищенко и др. // Проектирование инж. и науч. прил. в среде Matlab: Сб. тр. III Всерос. науч. конф. – СПб., 2007. 15. Геоакустический предвестник Спитакского землетрясения / В.А. Моргунов, М.Н. Любошевский, В.З. Фабрициус, З.Э. Фабрициус // Вулканология и сейсмология. – 1991. – № 4. – С. 104–106. 16. Исследования влияния сейсмической активности на шумы океана: Науч.-техн. отчет / Акустический ин-т им. акад. Андреева. Тихоокеанский фил.; Рук. В.Ю. Олещук. – Вилючинск, 1991. – 222 с. 104
17. Рихтер Дж. Создание эффективных Win32-приложений. – СПб.: Питер, 2003. – 752 с. 18. Райс Дж. Механика очага землетрясений. – М.: Мир, 1982. – 217 с. 19. Сасорова Е.В., Левин Б.В. Низкочастотные сейсмические сигналы как региональные признаки подготовки землетрясений // Вулканология и сейсмология. – 1999. – № 4, 5. – С. 126–133. 20. Соболев Г.А., Пономарев А.В. Физика землетрясений и предвестников. – М: Наука, 2003. – 270 с. 21. Щербина А.О., Мищенко М.А., Ларионов И.А. Аппаратно-програмный комплекс мониторинга геоакустической эмиссии // Вестник КРАУНЦ. Сер. «Науки о Земле». – Т. 2. – Петропавловск-Камчатский, 2005. – С. 128–132.
105
Монография
Марапулец Юрий Валентинович Щербина Альберт Олегович Мищенко Михаил Александрович Шадрин Александр Витальевич
МЕТОДЫ ИССЛЕДОВАНИЯ ВЫСОКОЧАСТОТНОЙ ГЕОАКУСТИЧЕСКОЙ ЭМИССИИ Редактор Г.Ф. Майорова Технический редактор Е.Е. Бабух Набор текста Ю.В. Марапулец Верстка, оригинал-макет Е.Е. Бабух Подписано в печать 04.04.2008 г. Формат 61*86/16. Печать цифровая. Гарнитура Times New Roman Авт. л. 4,96. Уч.-изд. л. 5,16. Усл. печ. л. 6,67 Тираж 60 экз. Заказ № 52 Издательство Камчатского государственного технического университета Отпечатано полиграфическим участком издательства КамчатГТУ 683003, г. Петропавловск-Камчатский, ул. Ключевская, 35
106