Определение размера массива структур
Обращение к полям структуры с применением функций setfield и getfield
127.0000 28.5000 504.7000
Ann Lane
Mypatients(1)
Test
Billing
Name
Первая структура в массиве mypatients совпадает с первой структурой в массиве patient:
ans =
name: 'John Doe'
billing: 127
test: [3x3 double].
Для обращения к полю определенной структуры, нужно добавить точку (.) после имени стру-ктуры, с указанием далее имени поля:
str = patient(2) . name
str =
Для обращения к элементам внутри полей, следует добавить требуемые индексы к имени поля. Если поле содержит числовой массив, нужно использовать индексация цифровых массивов. Если поле содержит массив ячеек, используйте соответствующую индексацию ячеек и так далее. Например,
test2b = patient(3).test(2,2)
test2b =
Аналогичную форму записи следует использовать и для задания значений переменных внутри поля, например,
patient(3).test(2,2) = 7
Вы можете также одновременно извлечь данные одноименных полей многомерной структу-ры. Например, запись ниже создает вектор 1х3, содержащий все значения счетов полей billing fields.
bills = [patient.billing]
bills =
Аналогично, вы можете создать массив ячеек, содержащий данные температур test для пер-вых двух структур.
tests = {patient(1:2).test}
tests =
[3x3 double] [3x3 double]
Прямая индексация обычно является наиболее эффективным способом задания или получе-ния значений полей структуры. Если, однако, вы знаете только название поля в виде строки, например, если вы использовали функцию 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.