name: building-simulink-models description: Builds and edits Simulink, System Composer, Stateflow, and Simscape models. Use when modifying model structure, parameters, ports, connections, or Stateflow chart internals. license: MathWorks BSD-3-Clause metadata: version: "1.1"
Building Models
Use model_edit for Simulink, System Composer, and Simscape models (structural changes and parameter configuration). For Stateflow chart internals, use evaluate_matlab_code with the Stateflow API (see below).
When to Use
- Adding, connecting, deleting, or replacing blocks in a model
- Configuring block parameters, signal properties, or model settings
- Creating or editing Stateflow chart internals (states, transitions, junctions)
- Building System Composer architecture models
- Wiring Simscape physical connections
When NOT to Use
- Querying parameter values → use
model_query_params - Resolving variable references to numeric values → use
model_resolve_params
Workflow
- Read first: Use
model_readon the target scope to get block IDs and understand existing topology. - Plan the data flow: For complex edits, sketch inputs → operations → outputs, then map to blocks.
- Edit: Use
model_editwith operations scoped to one subsystem level at a time. - Verify: Use
model_readon the scope to confirm the structure matches your intent.
CRITICAL: If model_edit returns status: partial, run model_read immediately to determine if corrective action is needed.
Operation Chaining with ref
Use ref to name a block and #ref to reference it in later operations within the same call:
[{"op": "add_block", "type": "Gain", "name": "MyGain", "ref": "g1"},
{"op": "connect", "target": "blk_5.y1 -> #g1.u1"}]
The response created map shows ref → blk_id. In subsequent calls, use the blk_id (e.g., blk_42) — #ref only works within a single call.
Guardrails
- Never manually construct block path strings from names shown in
model_overviewormodel_read. Block names can contain invisible newlines and trailing whitespace that causehilite_system,open_system, andget_paramto fail. Instead, resolve paths fromblk_XIDs:% blk_42 → use the number after "blk_" as the SID blockPath = Simulink.ID.getFullName('<ModelName>:42'); hilite_system(blockPath) open_system(blockPath) get_param(blockPath, 'BlockType') - Do not call
Simulink.BlockDiagram.arrangeSystemor useset_paramfor block positioning unless the user explicitly requests it.model_edithas a built-in autolayout engine that runs automatically after each call. - Always pass
layout_modetomodel_edit. Use"full"when populating an empty scope (new model root, or a newly-created subsystem) for optimal block arrangement. Use"incremental"when adding blocks to a scope that already has existing blocks (preserves existing positions). - Use meaningfully named variables (e.g.,
Kp_SpeedController) instead of hardcoded numeric values. Define variables in model workspace or a.minit script. - Don't use
evaluate_matlab_codewithset_param/add_blockto bypassmodel_edit— it skips autolayout, undo tracking, and error recovery - Use
open_systemrather thanload_systemto open models that are not already open, or when creating new models, unless the user explicitly asks otherwise or the model is a library. This ensures the user can see live edits as they happen.
Naming Conventions
Prefer code-generation-safe names for blocks, signals, and variables:
- Use only:
a-z,A-Z,0-9, underscore (_) - Don't start with a number
- Don't use leading/trailing or consecutive underscores
- Prefer names under 32 characters (required for some code generation targets)
Block Types
Use the block's display name in the type field. Do not construct or guess library paths.
- Built-in Simulink blocks: Use the BlockType directly:
Gain,Sum,Constant,Integrator,SubSystem,Scope - Library blocks (Simscape, Aerospace, DSP, Communications, etc.): Use the display name as it appears in the Simulink Library Browser:
Voltage Source,Resistor,DC Motor,Solver Configuration,6DOF (Euler Angles) - If
model_editreturnsINVALID_TYPE: Fall back to the full library path from MATLAB documentation (e.g.,ee_lib/Sources/Voltage Source)
[{"op": "add_block", "type": "Voltage Source", "name": "V1", "ref": "v1"},
{"op": "add_block", "type": "Resistor", "name": "R1", "ref": "r1"},
{"op": "add_block", "type": "Electrical Reference", "name": "Gnd", "ref": "gnd"},
{"op": "add_block", "type": "Solver Configuration", "name": "Solver", "ref": "sc"}]
Domain-Specific Rules
When working with these domains, read the corresponding reference file before editing:
- Stateflow charts ->
reference/stateflow.md—model_editcan add Chart blocks but cannot edit chart internals. Useevaluate_matlab_codewith the Stateflow API for states, transitions, junctions, and data. The reference covers API gotchas, subcharts, lint checks, and layout. - System Composer architecture models ->
reference/system-composer.md— Create models withsystemcomposer.createModel, then usemodel_edit. Components usetype: "SubSystem", ports use Bus Element blocks. The reference covers component creation, port wiring, and behavior model generation. - Simscape physical models ->
reference/simscape.md— Physical connections use bidirectional<->syntax. The reference covers connection semantics, port patterns, and initial target variables.