The S3D.model namespace provides functions which take action on the s3d_model object.


To create a model object, see s3d_model.


Setting a model is the first step to running any analysis, design or running any other functionality on a structural model.

s3d_modelobjectA s3d_model objectAn object containing information that represents a Structural 3D model.
Sample input for S3D.model.set
"function": "S3D.model.set",
"arguments": {
"s3d_model": MODEL_OBJECT

The response will confirm whether or not the model was successfully set.

Sample response for S3D.model.set
"msg": "Model was successfully set.",
"status": 0,
"data": ""
Try S3D.model.set


Once the model is set, you can request the model data at any time by calling the function S3D.model.get. This function takes no arguments, and will return the s3d_model object.


S3D.model.get will only work if S3D.model.set has been called earlier in the session.

Sample input for S3D.model.get
"function": "S3D.model.get"

The response will return the s3d_model object.

Sample response for S3D.model.get
"status": 0,
"function": "S3D.model.get",
"msg": ""


S3D.model.repair will run SkyCiv's repair model functionality. This will identify any issues with the model and repair them to ensure the analysis model is built correctly. To test the behaviour of these features, we recommend using the Repair Model function in the S3D UI.


S3D.model.set must be called earlier in the session.

An array of strings defining the checks to be performed.all


  • unused_nodes - scan model for nodes that are floating and disconnected.
  • large_structure - detect extremely slender members (used to detect unit issues).
  • merge_nodes - merge close nodes with a tolerance based on unit system.
  • zero_members - detect members that have the same start/end node.
  • continuous_to_normal_members - detect any members with intermediate nodes and splits them to ensure they are properly connected. This will also change the member type to 'normal'
  • intersect_members - detect and connect intersecting members.
  • default_section - find any members with no section data, add a default section.
  • force_plate_mesh - allow analysis to run without plates being meshed first.
Sample input for S3D.model.repair
"function": "S3D.model.repair",
"arguments": {
"checks": [

The response will confirm whether or not the model was successfully repaired.

Sample response for S3D.model.repair
"msg": "S3D model successfully repaired",
"status": 0


Runs a structural analysis on your s3d_model.

analysis_typestringlinear, nonlinear, buckling, dynamic, response_spectrumThe type of analysis to be performed.linear
repair_modelbooleantrue, falseIf S3D.model.repair should be executed prior to solving.false
return_databooleantrue, falseTo minimize data downloaded, solve data will be removed.true
formatstringjson, csvExport results in particular file format.json
lc_filter[string]envelope, load_case, load_group, load_combo, envelope_abs_maxOnly return specific data in the response. You can also provide names you have applied to load combination. E.g. LC1.All cases
result_filter[string]reactions, member_displacements, member_forces, member_stresses, member_lengths, member_stations, member_discontinuities, member_minimums, member_maximums, member_peak_results, plate_displacements, plate_forces, plate_stresses, plate_minimums, plate_maximums, plate_peak_results, buckling, dynamic_frequencyOnly return specific data in the response.All results
ignore_area_load_validationbooleantrue or falseIgnore area load variance checks and solve anywaytrue
allowable_area_load_variancefloate.g 3Ignore area load variance that are below this percentage. In percentage as a whole numbertrue

Using the filter properties will drastically reduce the size of the response therefore saving on download data and time.

Sample input for S3D.model.solve
"function": "S3D.model.solve",
"arguments": {
"analysis_type": "nonlinear",
"repair_model": true,
"lc_filter": ["envelope_abs_max", "LC1"],
"result_filter": ["member_peak_results", "member_discontinuities"]
Try S3D.model.solve

The analysis results will return an object of all the load combination results in the following format. If the solver fails to run, it will return with a status: 1 and an error message to assist in debugging the issue.

Sample response for S3D.model.solve
"1": {
"name": "LC1",
"type": "user_defined",
"reactions": {},
"member_displacements": {},
"member_forces": {},
"member_stresses": {},
"member_lengths": {},
"member_stations": {},
"member_discontinuities": {},
"member_minimums": {},
"member_maximums": {},
"member_peak_results": {},
"plate_displacements": {},
"plate_forces": {},
"plate_stresses": {},
"plate_minimums": {},
"plate_maximums": {},
"plate_peak_results": {}
"2": {} // etc


Take screenshots of the model.


S3D.model.set must be called earlier in the session.

views[string]iso, front, side, top, thumbnail, customArray of strings, defining the different perspectives to take a screenshot from.
is_rendererbooleantrue, falseTake screenshots of the structure in the 3D renderer.
wireframe_settingsobjectAn object as defined in wireframe_settingsAn object defining additional settings. Only applicable to WIREFRAME display.
renderer_settingsobjectAn object which matches the S3D Renderer settings: renderer_settingsAn object defining additional settings. Only applicable to RENDERER display.
custom_viewobject optionalAn object with x, y, z valuesThis object specifies the position of the camera in global 3D space { x: 100, y: 2, z: 3 }. Only applies when view=custom.
scalefloat optionalA number between 0 and 5 (default is 1)Defines the scale slider for the graphics (loads and results). A higher number makes the scale larger. Only applicable to WIREFRAME display.
zoom_factorfloat optionalA number between -50 and 50 (default is 0 which is no zoom)Defines the factor to zoom the graphics. A positive number zooms in while a negative number zooms out. Only applicable to WIREFRAME display.

Input for wireframe_settings#

show_nodesbooleantrue, falseIf nodes should be visible.
show_loadsbooleantrue, falseIf loads should be visible.
show_platesbooleantrue, falseIf plates should be visible.
projectionstringperspective, orthographicThe projection of the model to the view-point.
Sample input for Wireframe
"function": "S3D.model.takeScreenshot",
"arguments": {
"views": ["iso", "front", "side", "top"],
"is_renderer": false,
"scale": 1,
"zoom_factor": 1,
"wireframe_settings": {
"show_nodes": true,
"show_loads": false,
"show_plates": true,
"projection": "perspective"
Sample input for Renderer
"function": "S3D.model.takeScreenshot",
"arguments": {
"is_renderer": true,
"renderer_settings": {
"visibility": {
"nodes": true,
"node_id_labels": false,
"members": true,
"member_id_labels": false,
"plates": true,
"plates_mesh": false,
"supports": false,
"floor_grid": false,
"local_axis": false,
"global_origin_axis": false,
"global_axis": true,
"logo": true,
"label_font_size": "12px",
"loads": false,
"load_labels": false,
"load_group": null
"grid": {
"vertical_offset": 0
"lighting": {
"shadows": false,
"shadow_softening": 1,
"sun_horizontal_position": 180
"projection_mode": "perspective",
"display_mode": "solids_and_edges",
"colors": 1,
"transparency": {
"members": 0.5,
"plates": 0.3
"views": [
Try S3D.model.takeScreenshot


The response will return an object of screenshots in base64 format.

Sample response for S3D.model.takeScreenshot
"status": 0,
"msg": "Screenshots successfully taken and returned in base64 format.",
"data": {
"iso": "...",
"front": "....",
"side": "....",
"top": "...."

The following is an example of the isometric screenshot from the above sample:


Mesh the plates in the s3d_model object.

methodstringfrontal_quads, frontal, adapt, packing_parallelograms, delaunaySpecify what type of mesher to use.frontal
granularityinteger1-5Integer between 1 and 5 for level of granularity of mesh (1 is coarse, 5 is fine).1
plate_ids[integer]An array of plate ids.Array of plates you wish to mesh.All plates if property is not provided.
Sample input for S3D.model.mesh
"function": "S3D.model.mesh",
"arguments": {
"method": "delaunay",
"granularity": 3,
"plate_ids": [1, 3]


Allows you to run custom JavaScript functions to access all S3D functionality such as intersecting or adding new nodes or members. Available functions can be found here.

scriptstringA string of JavaScriptDefine custom actions to run. Available functions can be found here.

Note: Users can write to a pre-made global variable API_RETURN_DATA and this will return back from the SkyCiv API. This allows you to return data you need from your operations.

Sample input for S3D.model.script
const custom_script = `
//splits members by intersecting nodes
"typ": "intersectingMembers",
"memberNo": 343
//node already exists here, so will return existing node ID
var new_node_id = S3D.structure.nodes.add({
x: 32,
y: 36,
z: 104
var new_node_id2 = S3D.structure.nodes.add({
x: 32,
y: 0,
z: 0
nodeA: new_node_id,
nodeB: new_node_id2,
section_id: 1,
type: "continuous", //normal, rigid, tension, compression, cable
fixityA: "FFFFFF",
fixityB: "FFFFFF",
offsetsA: "0,0,0",
offsetsB: "0,0,0",
new_nodes_created: [new_node_id, new_node_id2],
last_member_added: last_member_added,
notes: "Nodes were added, supports were aded and then we joined them with a member!"
const functions = [
function: 'S3D.session.start',
arguments: {
keep_open: false,
function: 'S3D.model.set',
arguments: {
s3d_model: MODEL_OBJECT,
function: 'S3D.model.script',
arguments: {
script: custom_script,

The response will return the following message, as well as data you set to API_RETURN_DATA

Sample response for S3D.model.script
"status": 0,
"msg": "Custom script ran successfully",
"data": {
"new_nodes_created": [
"last_member_added": 9,
"notes": "Nodes were added, supports were aded and then we joined them with a member!"
"function": "S3D.model.script"


Returns the local axis vectors for each member.

Sample input for S3D.model.getLocalAxisVectors
"function": "S3D.model.getLocalAxisVectors",
"arguments": {}
Sample response for S3D.model.getLocalAxisVectors
"response": {
"data": {
"members": {
"1": { "x": [0, 1, 0], "y": [-1, 0, 0], "z": [0, 0, 1] },
"2": { "x": [1, 0, 0], "y": [0, 1, 0], "z": [0, 0, 1] },
"3": { "x": [0, -1, 0], "y": [1, 0, 0], "z": [0, 0, 1] },
"4": { "x": [0, 1, 0], "y": [-1, 0, 0], "z": [0, 0, 1] },
"5": { "x": [1, 0, 0], "y": [0, 1, 0], "z": [0, 0, 1] },
"6": { "x": [0, -1, 0], "y": [1, 0, 0], "z": [0, 0, 1] },
"7": { "x": [0, 0, 1], "y": [0, 1, 0], "z": [-1, 0, 0] },
"8": { "x": [0, 0, 1], "y": [0, 1, 0], "z": [-1, 0, 0] }
"meshed_plates": {},
"plates": {}
"msg": "Successfully computed local axes vectors.",
"status": 0,
"function": "S3D.model.getLocalAxisVectors",
"last_session_id": "S7MtXyVMtX0SPCGFkfOyj4eHqWEKwSy71dRwwN7WSCTSeAcS5pGIXgS4KqeIG1gF_0"