Система математических расчетов MATLAB

Методическое пособие - Компьютеры, программирование

Другие методички по предмету Компьютеры, программирование

Скачать Бесплатно!
Для того чтобы скачать эту работу.
1. Пожалуйста введите слова с картинки:

2. И нажмите на эту кнопку.
закрыть



ов должны иметь одинаковый вид (единственное значение или мас-сив ячеек).

 

Вы можете использовать различные методы для задания массива структур. Эти методы отличаются способом инициализации полей структуры. В качестве примера расмотрим зада-ние структуры размера 1х3 с именем weather (погода), имеющую поля temp (температура)

и rainfall (дождевые осадки). Три различные способа задания такой структуры даны в приведенной ниже таблице.

 

 

МетодСинтаксисЗаданиеФункция structweather(3) = struct(temp,72,rainfall,0.0);

Структура weather(3) инициализируется с указан-ными значениями полей. По-ля остальных двух структур в массиве, weather(1) и weather(2), содержат в качес-тве данных пустые матрицы.Сочетание функций struct и repmatweather =

repmat (struct (temp, 72,

rainfall, 0.0), 1, 3);Все структуры в массиве weather инициализируются с использованием одинаковых значений одноименных полей.Функция struct с использованием синтаксиса ячеекweather =

struct (temp,{68, 80, 72},

rainfall, {0.2,0.4,0.0} );Структуры в массиве weather инициализируются с разными значениями полей, заданных массивом ячеек.

 

 

Обращение к данным в массивах структур.

Используя индексацию массива структур, можно осуществить обращение к данным любого поля или любого элемента поля в массиве структуры. Аналогичным образом, вы можете за-дать значение любого поля или элемента поля структуры. В качестве примера, используемо-го в данном разделе, рассмотрим структуру, представленную на приведенном ниже рисунке.

 

 

Вы можете обратиться к подмассивам путем дабавления стандартной индексации к имени массива структур. Например, следующая запись приводит к структуре размера 1х2

 

mypatients = patient(1:2)

 

1x2 struct array with fields:

name

billing

test

 

Первая структура в массиве mypatients совпадает с первой структурой в массиве patient:

 

mypatients(1)

 

ans =

name: John Doe

billing: 127

test: [3x3 double].

 

Для обращения к полю определенной структуры, нужно добавить точку (.) после имени стру-ктуры, с указанием далее имени поля:

 

str = patient(2) . name

 

str =

Ann Lane

 

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

 

test2b = patient(3).test(2,2)

 

test2b =

153

 

Аналогичную форму записи следует использовать и для задания значений переменных внутри поля, например,

 

patient(3).test(2,2) = 7

 

Вы можете также одновременно извлечь данные одноименных полей многомерной структу-ры. Например, запись ниже создает вектор 1х3, содержащий все значения счетов полей billing fields.

 

bills = [patient.billing]

 

bills =

127.0000 28.5000 504.7000

 

Аналогично, вы можете создать массив ячеек, содержащий данные температур test для пер-вых двух структур.

 

tests = {patient(1:2).test}

 

tests =

[3x3 double] [3x3 double]

 

 

Обращение к полям структуры с применением функций setfield и getfield

Прямая индексация обычно является наиболее эффективным способом задания или получе-ния значений полей структуры. Если, однако, вы знаете только название поля в виде строки, например, если вы использовали функцию fieldnames для получения имени поля в пределах M-файла то для указанных операций с данными этих полей можно также применить функ-ции setfield и getfield.

Функция getfield позволяет получить значение или значения поля или элемента поля и име-ет следующий синтаксис

 

f = getfield(array,{array_index},field,{field_index})

 

где индекс field_index является необязательным , а array_index является необязательным для массива структур размера 1х1. Данный синтаксис соответствует записи

 

f = array(array_index).field(field_index)

 

Например, для обращения к полю name во второй структуре массива patient запишем

 

str = getfield(patient,{2},name)

 

Аналогично, функция setfield дает возможность задать значения полей используя синтаксис

 

f = setfield (array,{array_index},field,{field_index},value)

 

 

Определение размера массива структур

Для получения размера массива структур или размера любого поля структуры. можно вос-пользоваться функцией size. При вводе в качестве аргумента функции size имени структуры, данная функция возвращает вектор размерностей массива. Если задать аргумент в форме массив(n).поле, функция size возвращает размер содержимого поля. Например, для нашей структуры patient размера 1х3, запись size(patient) возвращает вектор [1 3]. Выражение size(patient(1,2).name) возвращает длину строки имени элемента (1,2) структуры patient.

 

Добавление полей к структуре

Вы можете добавить поле ко

s