# Documentation

### This is machine translation

Translated by
Mouseover text to see original. Click the button below to return to the English verison of the page.

Note: This page has been translated by MathWorks. Please click here
To view all translated materals including this page, select Japan from the country navigator on the bottom of this page.

## Fundamental MATLAB Classes

There are many different data types, or classes, that you can work with in the MATLAB® software. You can build matrices and arrays of floating-point and integer data, characters and strings, and logical `true` and `false` states. Function handles connect your code with any MATLAB function regardless of the current scope. Tables, structures, and cell arrays provide a way to store dissimilar types of data in the same container.

There are 16 fundamental classes in MATLAB. Each of these classes is in the form of a matrix or array. With the exception of function handles, this matrix or array is a minimum of 0-by-0 in size and can grow to an n-dimensional array of any size. A function handle is always scalar (1-by-1).

All of the fundamental MATLAB classes are shown in the diagram below:

Numeric classes in the MATLAB software include signed and unsigned integers, and single- and double-precision floating-point numbers. By default, MATLAB stores all numeric values as double-precision floating point. (You cannot change the default type and precision.) You can choose to store any number, or array of numbers, as integers or as single-precision. Integer and single-precision arrays offer more memory-efficient storage than double-precision.

All numeric types support basic array operations, such as subscripting, reshaping, and mathematical operations.

You can create two-dimensional `double` and `logical` matrices using one of two storage formats: `full` or `sparse`. For matrices with mostly zero-valued elements, a sparse matrix requires a fraction of the storage space required for an equivalent full matrix. Sparse matrices invoke methods especially tailored to solve sparse problems.

These classes require different amounts of storage, the smallest being a `logical` value or 8-bit integer which requires only 1 byte. It is important to keep this minimum size in mind if you work on data in files that were written using a precision smaller than 8 bits.

The following table describes the fundamental classes in more detail.

Class Name

Documentation

Intended Use

`double`, `single`Floating-Point Numbers
`int8`, `uint8`, `int16`, `uint16`, `int32`, `uint32`, `int64`, `uint64`Integers
`char`, `string`Characters and Strings
• Data type for text.

• Native or Unicode®.

• Converts to/from numeric.

• Use with regular expressions.

• For multiple character arrays, use cell arrays.

• Starting in R2016b, you also can store text in string arrays. For more information, see `string`.

`logical`Logical Operations
`function_handle`Function Handles
• Pointer to a function.

• Enables passing a function to another function

• Can also call functions outside usual scope.

• Use to specify graphics callback functions.

• Save to MAT-file and restore later.

`table`Tables
• Rectangular container for mixed-type, column-oriented data.

• Row and variable names identify contents.

• Use the properties of a table to store metadata such as variable units.

• Manipulation of elements similar to numeric or logical arrays.

• Access data by numeric or named index.

• Can select a subset of data and preserve the table container or can extract the data from a table.

`struct`Structures
• Fields store arrays of varying classes and sizes.

• Access one or all fields/indices in single operation.

• Field names identify contents.

• Method of passing function arguments.

• Use in comma-separated lists.

• More memory required for overhead

`cell`Cell Arrays
• Cells store arrays of varying classes and sizes.

• Allows freedom to package data as you want.

• Manipulation of elements is similar to numeric or logical arrays.

• Method of passing function arguments.

• Use in comma-separated lists.

• More memory required for overhead

## Related Topics

Was this topic helpful?

#### Beyond Excel: The Manager's Guide to Solving the Big Data Conundrum

Download white paper