sysml-v2-lsp 0.1.6 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -90
- package/README.md +63 -264
- package/dist/server/mcpServer.mjs +20 -20
- package/dist/server/parser/parseWorker.mjs +11 -11
- package/dist/server/server.mjs +80 -67
- package/package.json +2 -2
- package/sysml.library/.project +17 -0
- package/sysml.library/.settings/org.eclipse.jdt.core.prefs +11 -0
- package/sysml.library/Domain Libraries/Analysis/.meta.json +10 -0
- package/sysml.library/Domain Libraries/Analysis/.project.json +27 -0
- package/sysml.library/Domain Libraries/Analysis/AnalysisTooling.sysml +34 -0
- package/sysml.library/Domain Libraries/Analysis/SampledFunctions.sysml +119 -0
- package/sysml.library/Domain Libraries/Analysis/StateSpaceRepresentation.sysml +143 -0
- package/sysml.library/Domain Libraries/Analysis/TradeStudies.sysml +171 -0
- package/sysml.library/Domain Libraries/Cause and Effect/.meta.json +8 -0
- package/sysml.library/Domain Libraries/Cause and Effect/.project.json +23 -0
- package/sysml.library/Domain Libraries/Cause and Effect/CausationConnections.sysml +83 -0
- package/sysml.library/Domain Libraries/Cause and Effect/CauseAndEffect.sysml +81 -0
- package/sysml.library/Domain Libraries/Geometry/.meta.json +8 -0
- package/sysml.library/Domain Libraries/Geometry/.project.json +27 -0
- package/sysml.library/Domain Libraries/Geometry/ShapeItems.sysml +899 -0
- package/sysml.library/Domain Libraries/Geometry/SpatialItems.sysml +168 -0
- package/sysml.library/Domain Libraries/Metadata/.meta.json +10 -0
- package/sysml.library/Domain Libraries/Metadata/.project.json +19 -0
- package/sysml.library/Domain Libraries/Metadata/ImageMetadata.sysml +78 -0
- package/sysml.library/Domain Libraries/Metadata/ModelingMetadata.sysml +143 -0
- package/sysml.library/Domain Libraries/Metadata/ParametersOfInterestMetadata.sysml +39 -0
- package/sysml.library/Domain Libraries/Metadata/RiskMetadata.sysml +100 -0
- package/sysml.library/Domain Libraries/Quantities and Units/.meta.json +29 -0
- package/sysml.library/Domain Libraries/Quantities and Units/.project.json +23 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQ.sysml +42 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQAcoustics.sysml +439 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQAtomicNuclear.sysml +2726 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQBase.sysml +206 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQCharacteristicNumbers.sysml +1991 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQChemistryMolecular.sysml +1353 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQCondensedMatter.sysml +1223 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQElectromagnetism.sysml +2333 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQInformation.sysml +958 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQLight.sysml +1537 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQMechanics.sysml +1564 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQSpaceTime.sysml +1169 -0
- package/sysml.library/Domain Libraries/Quantities and Units/ISQThermodynamics.sysml +1256 -0
- package/sysml.library/Domain Libraries/Quantities and Units/MeasurementRefCalculations.sysml +30 -0
- package/sysml.library/Domain Libraries/Quantities and Units/MeasurementReferences.sysml +526 -0
- package/sysml.library/Domain Libraries/Quantities and Units/Quantities.sysml +107 -0
- package/sysml.library/Domain Libraries/Quantities and Units/QuantityCalculations.sysml +70 -0
- package/sysml.library/Domain Libraries/Quantities and Units/SI.sysml +378 -0
- package/sysml.library/Domain Libraries/Quantities and Units/SIPrefixes.sysml +48 -0
- package/sysml.library/Domain Libraries/Quantities and Units/TensorCalculations.sysml +50 -0
- package/sysml.library/Domain Libraries/Quantities and Units/Time.sysml +274 -0
- package/sysml.library/Domain Libraries/Quantities and Units/USCustomaryUnits.sysml +260 -0
- package/sysml.library/Domain Libraries/Quantities and Units/VectorCalculations.sysml +62 -0
- package/sysml.library/Domain Libraries/Requirement Derivation/.meta.json +8 -0
- package/sysml.library/Domain Libraries/Requirement Derivation/.project.json +19 -0
- package/sysml.library/Domain Libraries/Requirement Derivation/DerivationConnections.sysml +63 -0
- package/sysml.library/Domain Libraries/Requirement Derivation/RequirementDerivation.sysml +39 -0
- package/sysml.library/Kernel Libraries/Kernel Data Type Library/.meta.json +9 -0
- package/sysml.library/Kernel Libraries/Kernel Data Type Library/.project.json +11 -0
- package/sysml.library/Kernel Libraries/Kernel Data Type Library/Collections.kerml +147 -0
- package/sysml.library/Kernel Libraries/Kernel Data Type Library/ScalarValues.kerml +23 -0
- package/sysml.library/Kernel Libraries/Kernel Data Type Library/VectorValues.kerml +64 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/.meta.json +23 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/.project.json +15 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/BaseFunctions.kerml +80 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/BooleanFunctions.kerml +22 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/CollectionFunctions.kerml +68 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/ComplexFunctions.kerml +47 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/ControlFunctions.kerml +117 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/DataFunctions.kerml +43 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/IntegerFunctions.kerml +43 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/NaturalFunctions.kerml +27 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/NumericalFunctions.kerml +43 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/OccurrenceFunctions.kerml +154 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/RationalFunctions.kerml +49 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/RealFunctions.kerml +56 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/ScalarFunctions.kerml +33 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/SequenceFunctions.kerml +111 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/StringFunctions.kerml +25 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/TrigFunctions.kerml +35 -0
- package/sysml.library/Kernel Libraries/Kernel Function Library/VectorFunctions.kerml +273 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/.meta.json +22 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/.project.json +15 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Base.kerml +95 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Clocks.kerml +156 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/ControlPerformances.kerml +135 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/FeatureReferencingPerformances.kerml +190 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/KerML.kerml +483 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Links.kerml +67 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Metaobjects.kerml +58 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Objects.kerml +212 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Observation.kerml +161 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Occurrences.kerml +992 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Performances.kerml +293 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/SpatialFrames.kerml +197 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/StatePerformances.kerml +145 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Transfers.kerml +281 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/TransitionPerformances.kerml +66 -0
- package/sysml.library/Kernel Libraries/Kernel Semantic Library/Triggers.kerml +188 -0
- package/sysml.library/Systems Library/.meta.json +27 -0
- package/sysml.library/Systems Library/.project.json +19 -0
- package/sysml.library/Systems Library/Actions.sysml +552 -0
- package/sysml.library/Systems Library/Allocations.sysml +29 -0
- package/sysml.library/Systems Library/AnalysisCases.sysml +38 -0
- package/sysml.library/Systems Library/Attributes.sysml +25 -0
- package/sysml.library/Systems Library/Calculations.sysml +37 -0
- package/sysml.library/Systems Library/Cases.sysml +71 -0
- package/sysml.library/Systems Library/Connections.sysml +60 -0
- package/sysml.library/Systems Library/Constraints.sysml +44 -0
- package/sysml.library/Systems Library/Flows.sysml +126 -0
- package/sysml.library/Systems Library/Interfaces.sysml +89 -0
- package/sysml.library/Systems Library/Items.sysml +153 -0
- package/sysml.library/Systems Library/Metadata.sysml +32 -0
- package/sysml.library/Systems Library/Parts.sysml +81 -0
- package/sysml.library/Systems Library/Ports.sysml +54 -0
- package/sysml.library/Systems Library/Requirements.sysml +194 -0
- package/sysml.library/Systems Library/StandardViewDefinitions.sysml +123 -0
- package/sysml.library/Systems Library/States.sysml +103 -0
- package/sysml.library/Systems Library/SysML.sysml +539 -0
- package/sysml.library/Systems Library/UseCases.sysml +57 -0
- package/sysml.library/Systems Library/VerificationCases.sysml +103 -0
- package/sysml.library/Systems Library/Views.sysml +164 -0
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "sysml-v2-lsp",
|
|
3
3
|
"displayName": "SysML v2 Language Server",
|
|
4
4
|
"description": "Language Server Protocol implementation for SysML v2, powered by ANTLR4",
|
|
5
|
-
"version": "0.
|
|
5
|
+
"version": "0.2.0",
|
|
6
6
|
"publisher": "JamieD",
|
|
7
7
|
"license": "MIT",
|
|
8
8
|
"repository": {
|
|
@@ -127,4 +127,4 @@
|
|
|
127
127
|
"zod": "^4.3.6"
|
|
128
128
|
},
|
|
129
129
|
"dependencies": {}
|
|
130
|
-
}
|
|
130
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<projectDescription>
|
|
3
|
+
<name>sysml.library</name>
|
|
4
|
+
<comment></comment>
|
|
5
|
+
<projects>
|
|
6
|
+
</projects>
|
|
7
|
+
<buildSpec>
|
|
8
|
+
<buildCommand>
|
|
9
|
+
<name>org.eclipse.xtext.ui.shared.xtextBuilder</name>
|
|
10
|
+
<arguments>
|
|
11
|
+
</arguments>
|
|
12
|
+
</buildCommand>
|
|
13
|
+
</buildSpec>
|
|
14
|
+
<natures>
|
|
15
|
+
<nature>org.eclipse.xtext.ui.shared.xtextNature</nature>
|
|
16
|
+
</natures>
|
|
17
|
+
</projectDescription>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
eclipse.preferences.version=1
|
|
2
|
+
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
|
3
|
+
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
|
|
4
|
+
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
|
|
5
|
+
org.eclipse.jdt.core.compiler.compliance=1.8
|
|
6
|
+
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
|
|
7
|
+
org.eclipse.jdt.core.compiler.debug.localVariable=generate
|
|
8
|
+
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
|
|
9
|
+
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
|
10
|
+
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
|
11
|
+
org.eclipse.jdt.core.compiler.source=1.8
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"index": {
|
|
3
|
+
"AnalysisTooling": "AnalysisTooling.sysml",
|
|
4
|
+
"SampledFunctions": "SampledFunctions.sysml",
|
|
5
|
+
"StateSpaceRepresentation": "StateSpaceRepresentation.sysml",
|
|
6
|
+
"TradeStudies": "TradeStudies.sysml"
|
|
7
|
+
},
|
|
8
|
+
"created": "2025-03-13T00:00:00Z",
|
|
9
|
+
"metamodel": "https://www.omg.org/spec/SysML/20250201"
|
|
10
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "SysML Analysis Library",
|
|
3
|
+
"version": "2.0.0",
|
|
4
|
+
"description": "Standard analysis domain library for the Systems Modeling Language (SysML)",
|
|
5
|
+
"usage": [
|
|
6
|
+
{
|
|
7
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Semantic-Library.kpar",
|
|
8
|
+
"versionConstraint": "1.0.0"
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Data-Type-Library.kpar",
|
|
12
|
+
"versionConstraint": "1.0.0"
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Function-Library.kpar",
|
|
16
|
+
"versionConstraint": "1.0.0"
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
"resource": "https://www.omg.org/spec/SysML/20250201/Systems-Library.kpar",
|
|
20
|
+
"versionConstraint": "2.0.0"
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Quantities-and-Units-Library.kpar",
|
|
24
|
+
"versionConstraint": "2.0.0"
|
|
25
|
+
}
|
|
26
|
+
]
|
|
27
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
standard library package AnalysisTooling {
|
|
2
|
+
doc
|
|
3
|
+
/*
|
|
4
|
+
* This package contains definitions for metadata annotations related
|
|
5
|
+
* to analysis tool integration.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
private import ScalarValues::*;
|
|
9
|
+
|
|
10
|
+
metadata def ToolExecution {
|
|
11
|
+
doc
|
|
12
|
+
/*
|
|
13
|
+
* ToolExecution metadata identifies an external analysis tool to be
|
|
14
|
+
* used to implement the annotated action.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
attribute toolName : String;
|
|
18
|
+
attribute uri : String;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
metadata def ToolVariable {
|
|
22
|
+
doc
|
|
23
|
+
/*
|
|
24
|
+
* ToolVariable metadata is used in the context of an action that has
|
|
25
|
+
* been annotated with ToolExecution metadata. It is used to annotate
|
|
26
|
+
* a parameter or other feature of the action with the name of the
|
|
27
|
+
* variable in the tool that is to correspond to the annotated
|
|
28
|
+
* feature.
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
attribute name : String;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
standard library package SampledFunctions {
|
|
2
|
+
doc
|
|
3
|
+
/*
|
|
4
|
+
* This package provides a library model of discretely sampled mathematical functions.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
private import Base::Anything;
|
|
8
|
+
private import ScalarValues::Positive;
|
|
9
|
+
private import Collections::KeyValuePair;
|
|
10
|
+
private import Collections::OrderedMap;
|
|
11
|
+
private import SequenceFunctions::size;
|
|
12
|
+
private import ControlFunctions::forAll;
|
|
13
|
+
private import ControlFunctions::collect;
|
|
14
|
+
private import ControlFunctions::select;
|
|
15
|
+
|
|
16
|
+
attribute def SamplePair :> KeyValuePair {
|
|
17
|
+
doc
|
|
18
|
+
/*
|
|
19
|
+
* SamplePair is a key-value pair of a domain-value and a range-value, used as a sample element in SampledFunction.
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
attribute domainValue :>> key;
|
|
23
|
+
attribute rangeValue :>> val;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
attribute def SampledFunction :> OrderedMap {
|
|
27
|
+
doc
|
|
28
|
+
/*
|
|
29
|
+
* SampledFunction is a variable-size, ordered collection of 'SamplePair' elements that represents a generic, discretely sampled,
|
|
30
|
+
* uni-variate or multi-variate mathematical function. The function must be montonic, either strictly increasing or strictly
|
|
31
|
+
* decreasing.
|
|
32
|
+
*
|
|
33
|
+
* It maps discrete domain values to discrete range values.
|
|
34
|
+
* The domain of the function is represented by the sequence of 'domainValue' of each 'SamplePair' in 'samples', and
|
|
35
|
+
* the range of the function is represented by the sequence of 'rangeValue' of each 'SamplePair' in 'samples'.
|
|
36
|
+
*/
|
|
37
|
+
|
|
38
|
+
attribute samples: SamplePair[0..*] ordered :>> elements;
|
|
39
|
+
|
|
40
|
+
assert constraint {
|
|
41
|
+
// Note: Assumes the functions '<' and '>' are defined for the domain type.
|
|
42
|
+
(1..size(samples)-1)->forAll { in i; (samples.domainValue#(i) < samples.domainValue#(i+1)) } or // Strictly increasing
|
|
43
|
+
(1..size(samples)-1)->forAll { in i; (samples.domainValue#(i) > samples.domainValue#(i+1)) } // Strictly decreasing
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
calc def Domain {
|
|
48
|
+
doc
|
|
49
|
+
/*
|
|
50
|
+
* Domain returns the sequence of the domainValues of all samples in a SampledFunction.
|
|
51
|
+
*/
|
|
52
|
+
|
|
53
|
+
in fn : SampledFunction;
|
|
54
|
+
return : Anything[0..*] = fn.samples.domainValue;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
calc def Range {
|
|
58
|
+
doc
|
|
59
|
+
/*
|
|
60
|
+
* Range returns the sequence of the rangeValues of all samples in a SampledFunction.
|
|
61
|
+
*/
|
|
62
|
+
|
|
63
|
+
in fn : SampledFunction;
|
|
64
|
+
return : Anything[0..*] = fn.samples.rangeValue;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
calc def Sample {
|
|
68
|
+
doc
|
|
69
|
+
/*
|
|
70
|
+
* Sample returns a SampledFunction that samples a given calculation over a sequence of domainValues.
|
|
71
|
+
*/
|
|
72
|
+
|
|
73
|
+
in calc calculation { in x; }
|
|
74
|
+
in attribute domainValues [0..*];
|
|
75
|
+
return sampling = new SampledFunction (
|
|
76
|
+
samples = domainValues->collect { in x; new SamplePair(x, calculation(x)) }
|
|
77
|
+
);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
calc def Interpolate {
|
|
81
|
+
doc
|
|
82
|
+
/*
|
|
83
|
+
* An Interpolate calculation returns an interpolated range value from a given SampledFunction for a given domain value.
|
|
84
|
+
* If the input domain value is outside the bounds of the domainValues of the SampleFunction, null is returned.
|
|
85
|
+
*/
|
|
86
|
+
|
|
87
|
+
in attribute fn : SampledFunction;
|
|
88
|
+
in attribute value;
|
|
89
|
+
return attribute result;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
calc interpolateLinear : Interpolate {
|
|
93
|
+
doc
|
|
94
|
+
/*
|
|
95
|
+
* interpolateLinear is an Interpolate calculation assuming a linear functional form between SamplePairs.
|
|
96
|
+
*/
|
|
97
|
+
|
|
98
|
+
in attribute fn : SampledFunction;
|
|
99
|
+
in attribute value;
|
|
100
|
+
|
|
101
|
+
private attribute domainValues = Domain(fn);
|
|
102
|
+
private attribute index : Positive[0..1] =
|
|
103
|
+
(1..size(domainValues))->select { in i : Positive; domainValues#(i) <= value }#(1);
|
|
104
|
+
|
|
105
|
+
private calc def Linear {
|
|
106
|
+
in attribute lowerSample : SamplePair;
|
|
107
|
+
in attribute upperSample : SamplePair;
|
|
108
|
+
in attribute value;
|
|
109
|
+
private attribute f = (value - lowerSample.domainValue) / (lowerSample.domainValue - upperSample.domainValue);
|
|
110
|
+
return result = upperSample.rangeValue + f * (lowerSample.rangeValue - upperSample.rangeValue);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
return result [0..1] =
|
|
114
|
+
if index == null or index == size(domainValues)? null
|
|
115
|
+
else if domainValues#(index) < domainValues#(index+1)? Linear(fn.samples#(index), fn.samples#(index+1), value)
|
|
116
|
+
else Linear(fn.samples#(index+1), fn.samples#(index), value);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
standard library package StateSpaceRepresentation {
|
|
2
|
+
doc
|
|
3
|
+
/*
|
|
4
|
+
* This package provides a model of the foundational state-space system representation,
|
|
5
|
+
* commonly used in control systems.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
private import ISQ::DurationValue;
|
|
9
|
+
private import Quantities::VectorQuantityValue;
|
|
10
|
+
private import VectorCalculations::*;
|
|
11
|
+
|
|
12
|
+
abstract attribute def StateSpace :> VectorQuantityValue;
|
|
13
|
+
abstract attribute def Input :> VectorQuantityValue;
|
|
14
|
+
abstract attribute def Output :> VectorQuantityValue;
|
|
15
|
+
|
|
16
|
+
abstract calc def GetNextState {
|
|
17
|
+
in input: Input;
|
|
18
|
+
in stateSpace: StateSpace;
|
|
19
|
+
in timeStep: DurationValue;
|
|
20
|
+
return : StateSpace;
|
|
21
|
+
}
|
|
22
|
+
abstract calc def GetOutput {
|
|
23
|
+
in input: Input;
|
|
24
|
+
in stateSpace: StateSpace;
|
|
25
|
+
return : Output;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
abstract action def StateSpaceEventDef {
|
|
29
|
+
doc
|
|
30
|
+
/*
|
|
31
|
+
* Events to be received.
|
|
32
|
+
*/
|
|
33
|
+
}
|
|
34
|
+
action def ZeroCrossingEventDef :> StateSpaceEventDef;
|
|
35
|
+
|
|
36
|
+
item def StateSpaceItem {
|
|
37
|
+
doc
|
|
38
|
+
/*
|
|
39
|
+
* Item for SSR connection
|
|
40
|
+
*/
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
abstract action def StateSpaceDynamics {
|
|
44
|
+
doc
|
|
45
|
+
/*
|
|
46
|
+
* StateSpaceDynamics is the simplest form of State Space Representation,
|
|
47
|
+
* and nextState directly computes the stateSpace of the next timestep.
|
|
48
|
+
*/
|
|
49
|
+
|
|
50
|
+
in attribute input: Input;
|
|
51
|
+
|
|
52
|
+
abstract calc getNextState: GetNextState;
|
|
53
|
+
abstract calc getOutput: GetOutput;
|
|
54
|
+
attribute stateSpace: StateSpace;
|
|
55
|
+
|
|
56
|
+
out attribute output: Output = getOutput(input, stateSpace);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
abstract attribute def StateDerivative :> VectorQuantityValue {
|
|
60
|
+
doc
|
|
61
|
+
/*
|
|
62
|
+
* The definition of the time derivative of StateSpace, which means dx/dt, where x is StateSpace
|
|
63
|
+
*/
|
|
64
|
+
|
|
65
|
+
ref stateSpace: StateSpace;
|
|
66
|
+
constraint { stateSpace.order == order }
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
abstract calc def GetDerivative {
|
|
70
|
+
doc
|
|
71
|
+
/*
|
|
72
|
+
* Computes the time derivative of stateSpace, which corresponds dx/dt = f(u, x), where u is input and x is stateSpace.
|
|
73
|
+
*/
|
|
74
|
+
|
|
75
|
+
in input: Input;
|
|
76
|
+
in stateSpace: StateSpace;
|
|
77
|
+
return : StateDerivative;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
abstract calc def Integrate {
|
|
81
|
+
doc
|
|
82
|
+
/*
|
|
83
|
+
* Integrates stateSpace to compute the next stateSpace, which corresponds to x + int dx/dt dt.
|
|
84
|
+
* Its actual implementation should be given by a solver.
|
|
85
|
+
*/
|
|
86
|
+
|
|
87
|
+
in getDerivative: GetDerivative;
|
|
88
|
+
in input: Input;
|
|
89
|
+
in initialState: StateSpace;
|
|
90
|
+
in timeInterval: DurationValue;
|
|
91
|
+
return result: StateSpace;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
abstract action def ContinuousStateSpaceDynamics :> StateSpaceDynamics {
|
|
95
|
+
doc
|
|
96
|
+
/*
|
|
97
|
+
* ContinuousStateSpaceDynamics represents continuous behavior.
|
|
98
|
+
* derivative needs to return a time derivative of stateSpace, i.e. dx/dt.
|
|
99
|
+
*/
|
|
100
|
+
|
|
101
|
+
abstract calc getDerivative: GetDerivative;
|
|
102
|
+
calc :>> getNextState: GetNextState {
|
|
103
|
+
/* We compute nextState by Integrate defined above by giving derivative calc. */
|
|
104
|
+
calc integrate: Integrate {
|
|
105
|
+
in getDerivative = ContinuousStateSpaceDynamics::getDerivative;
|
|
106
|
+
in input = GetNextState::input;
|
|
107
|
+
in initialState = GetNextState::stateSpace;
|
|
108
|
+
in timeInterval = GetNextState::timeStep;
|
|
109
|
+
}
|
|
110
|
+
return result = integrate.result;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
event occurrence zeroCrossingEvents[0..*] : ZeroCrossingEventDef {
|
|
114
|
+
/* ContinuousStateSpaceDynamics may cause zero crossings anomaly. */
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
abstract calc def GetDifference {
|
|
119
|
+
doc
|
|
120
|
+
/*
|
|
121
|
+
* Computes difference of stateSpace by one timestep, that is x(k+1) - x(k),
|
|
122
|
+
* where k is the timestep number.
|
|
123
|
+
*/
|
|
124
|
+
|
|
125
|
+
in input: Input;
|
|
126
|
+
in stateSpace: StateSpace;
|
|
127
|
+
return : StateSpace;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
abstract action def DiscreteStateSpaceDynamics :> StateSpaceDynamics {
|
|
131
|
+
doc
|
|
132
|
+
/*
|
|
133
|
+
* DiscreteStateSpaceDynamics represents discrete behavior.
|
|
134
|
+
* differences needs to return difference of the stateSpace for each timestep.
|
|
135
|
+
*/
|
|
136
|
+
|
|
137
|
+
abstract calc getDifference: GetDifference;
|
|
138
|
+
calc :>> getNextState: GetNextState {
|
|
139
|
+
attribute diff: StateSpace = getDifference(input, stateSpace);
|
|
140
|
+
return result = stateSpace + diff;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
standard library package TradeStudies {
|
|
2
|
+
doc
|
|
3
|
+
/*
|
|
4
|
+
* This package provides a simple framework for defining trade-off study analysis cases.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
private import Base::Anything;
|
|
8
|
+
private import ScalarValues::*;
|
|
9
|
+
private import ScalarFunctions::*;
|
|
10
|
+
private import ControlFunctions::*;
|
|
11
|
+
|
|
12
|
+
abstract calc def EvaluationFunction {
|
|
13
|
+
doc
|
|
14
|
+
/*
|
|
15
|
+
* An EvaluationFunction is a calculation that evaluates a TradeStudy alternative,
|
|
16
|
+
* producing a ScalarValue that can be comparted with the evaluation of other
|
|
17
|
+
* alternatives.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
in ref alternative : Anything {
|
|
21
|
+
doc
|
|
22
|
+
/*
|
|
23
|
+
* The alternative to be evaluated.
|
|
24
|
+
*/
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
return attribute result : ScalarValue[1] {
|
|
28
|
+
doc
|
|
29
|
+
/*
|
|
30
|
+
* A ScalarValue representing the evaluation of the given alternative.
|
|
31
|
+
*/
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
abstract requirement def TradeStudyObjective {
|
|
36
|
+
doc
|
|
37
|
+
/*
|
|
38
|
+
* A TradeStudyObjective is the base definition for the objective of a TradeStudy.
|
|
39
|
+
* The requirement is to choose from a given set of alternatives the selectedAlternative
|
|
40
|
+
* for that has the best evaluation according to a given EvaluationFunction. What
|
|
41
|
+
* value is considered "best" is not defined in the abstract base definition but must be
|
|
42
|
+
* computed in any concrete specialization.
|
|
43
|
+
*/
|
|
44
|
+
|
|
45
|
+
subject selectedAlternative : Anything {
|
|
46
|
+
doc
|
|
47
|
+
/*
|
|
48
|
+
* The alternative that should be selected, as evaluated using the given
|
|
49
|
+
* ObjectiveFunction.
|
|
50
|
+
*/
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
in ref alternatives : Anything[1..*] {
|
|
54
|
+
doc
|
|
55
|
+
/*
|
|
56
|
+
* The alternatives being considered in the TradeStudy for which this TradeStudyObjective
|
|
57
|
+
* is the objective.
|
|
58
|
+
*/
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
in calc eval : EvaluationFunction {
|
|
62
|
+
doc
|
|
63
|
+
/*
|
|
64
|
+
* The EvaluationFunction to be used in evaluating the given alternatives.
|
|
65
|
+
*/
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
attribute best : ScalarValue {
|
|
69
|
+
doc
|
|
70
|
+
/*
|
|
71
|
+
* Out of the evaluation results of all the given alternatives, the one that is considered
|
|
72
|
+
* "best", in the sense that it is the value the selectedAlternative should have. This
|
|
73
|
+
* value must be computed in any concrete specialization of TradeStudyObjective.
|
|
74
|
+
*/
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
require constraint { eval(selectedAlternative) == best }
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
requirement def MinimizeObjective :> TradeStudyObjective {
|
|
81
|
+
doc
|
|
82
|
+
/*
|
|
83
|
+
* A MinimizeObjective is a TradeStudyObjective that requires that the
|
|
84
|
+
* selectedAlternative have the minimum ObjectiveFunction value of all the
|
|
85
|
+
* given alternatives.
|
|
86
|
+
*/
|
|
87
|
+
|
|
88
|
+
attribute :>> best = alternatives->minimize {
|
|
89
|
+
doc
|
|
90
|
+
/*
|
|
91
|
+
* For a MinimizeObjective, the best value is the minimum one.
|
|
92
|
+
*/
|
|
93
|
+
|
|
94
|
+
in x; eval(x)
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
requirement def MaximizeObjective :> TradeStudyObjective {
|
|
99
|
+
doc
|
|
100
|
+
/*
|
|
101
|
+
* A MaximizeObjective is a TradeStudyObjective that requires that the
|
|
102
|
+
* selectedAlternative have the maximum ObjectiveFunction value of all the
|
|
103
|
+
* given alternatives.
|
|
104
|
+
*/
|
|
105
|
+
|
|
106
|
+
attribute :>> best = alternatives->maximize {
|
|
107
|
+
doc
|
|
108
|
+
/*
|
|
109
|
+
* For a MinimizeObjective, the best value is the maximum one.
|
|
110
|
+
*/
|
|
111
|
+
|
|
112
|
+
in x; eval(x)
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
abstract analysis def TradeStudy {
|
|
117
|
+
doc
|
|
118
|
+
/*
|
|
119
|
+
* A TradeStudy is an analysis case whose subject is a set of alternatives
|
|
120
|
+
* (at least one) and whose result is a selection of one of those alternatives.
|
|
121
|
+
* The alternatives are evaluated based on a given ObjectiveFunction and the
|
|
122
|
+
* selection is made such that it satisfies the objective of the TradeStudy
|
|
123
|
+
* (which must be a TradeStudyObjective).
|
|
124
|
+
*/
|
|
125
|
+
|
|
126
|
+
subject studyAlternatives : Anything[1..*] {
|
|
127
|
+
doc
|
|
128
|
+
/*
|
|
129
|
+
* The set of alternatives being considered in this TradeStudy.
|
|
130
|
+
*
|
|
131
|
+
* In a TradeStudy usage, bind this feature to the actual collection of
|
|
132
|
+
* alternatives to be considered.
|
|
133
|
+
*/
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
abstract calc evaluationFunction : EvaluationFunction {
|
|
137
|
+
doc
|
|
138
|
+
/*
|
|
139
|
+
* The EvaluationFunction to be used to evaluate the alternatives.
|
|
140
|
+
*
|
|
141
|
+
* In a TradeStudy usage, redefine this feature to provide the desired
|
|
142
|
+
* calculation (or bind it to a calculation usage that does so).
|
|
143
|
+
*/
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
objective tradeStudyObjective : TradeStudyObjective {
|
|
147
|
+
doc
|
|
148
|
+
/*
|
|
149
|
+
* The objective of this TradeStudy.
|
|
150
|
+
*
|
|
151
|
+
* Redefine this feature to give it a definition that is a concrete
|
|
152
|
+
* specialization of TradeStudyObjective. That can either be one of the
|
|
153
|
+
* specializations provided in this package, or a more specific user-
|
|
154
|
+
* defined one.
|
|
155
|
+
*/
|
|
156
|
+
|
|
157
|
+
subject :>> selectedAlternative;
|
|
158
|
+
in ref :>> alternatives = studyAlternatives;
|
|
159
|
+
in calc :>> eval = evaluationFunction;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
return selectedAlternative : Anything = studyAlternatives->selectOne {in ref a {
|
|
163
|
+
doc
|
|
164
|
+
/*
|
|
165
|
+
* The alternative selected by this TradeStudy, which is the one that meets the
|
|
166
|
+
* requirement of the tradeStudyObjective.
|
|
167
|
+
*/
|
|
168
|
+
} tradeStudyObjective(selectedAlternative = a)};
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "SysML Cause and Effect Library",
|
|
3
|
+
"version": "2.0.0",
|
|
4
|
+
"description": "Standard cause-and-effect domain library for the Systems Modeling Language (SysML)",
|
|
5
|
+
"usage": [
|
|
6
|
+
{
|
|
7
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Semantic-Library.kpar",
|
|
8
|
+
"versionConstraint": "1.0.0"
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Data-Type-Library.kpar",
|
|
12
|
+
"versionConstraint": "1.0.0"
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"resource": "https://www.omg.org/spec/KerML/20250201/Function-Library.kpar",
|
|
16
|
+
"versionConstraint": "1.0.0"
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
"resource": "https://www.omg.org/spec/SysML/20250201/Systems-Library.kpar",
|
|
20
|
+
"versionConstraint": "2.0.0"
|
|
21
|
+
}
|
|
22
|
+
]
|
|
23
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
standard library package CausationConnections {
|
|
2
|
+
doc
|
|
3
|
+
/*
|
|
4
|
+
* This package provides a library model modeling causes, effects, and causation connections
|
|
5
|
+
* between them.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
private import SequenceFunctions::isEmpty;
|
|
9
|
+
private import SequenceFunctions::size;
|
|
10
|
+
private import SequenceFunctions::intersection;
|
|
11
|
+
|
|
12
|
+
abstract occurrence causes[*] {
|
|
13
|
+
doc /* Occurrences that are causes. */
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
abstract occurrence effects[*] {
|
|
17
|
+
doc /* Occurrences that are effects. */
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
abstract connection def Multicausation {
|
|
21
|
+
doc
|
|
22
|
+
/*
|
|
23
|
+
* A Multicausation connection models the situation in which one set of
|
|
24
|
+
* occurrences causes another.
|
|
25
|
+
*
|
|
26
|
+
* To create a Multicausation connection, specialize this connection definition
|
|
27
|
+
* adding specific end features of the relavent types. Ends representing causes
|
|
28
|
+
* should subset 'causes', while ends representing effects should subset 'effects'.
|
|
29
|
+
* There must be at least one cause and at least one effect.
|
|
30
|
+
*/
|
|
31
|
+
|
|
32
|
+
abstract constant ref occurrence causes[1..*] :>> causes :> participant {
|
|
33
|
+
doc
|
|
34
|
+
/*
|
|
35
|
+
* The causing occurrences. (Constant for each Multicausation instance.)
|
|
36
|
+
*/
|
|
37
|
+
}
|
|
38
|
+
abstract constant ref occurrence effects[1..*] :>> effects :> participant {
|
|
39
|
+
doc
|
|
40
|
+
/*
|
|
41
|
+
* The effect occurrences caused by the causing occurrences.
|
|
42
|
+
* (Constant for each Multicausation instance.)
|
|
43
|
+
*/
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
private assert constraint disjointCauseEffect {
|
|
47
|
+
doc /* causes must be disjoint from effects. */
|
|
48
|
+
isEmpty(intersection(causes, effects))
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
private succession causalOrdering first [nCauses] causes.startShot then [nEffects] effects {
|
|
52
|
+
doc /* All causes must exist before all effects. */
|
|
53
|
+
attribute nCauses = size(causes);
|
|
54
|
+
attribute nEffects = size(effects);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
abstract connection multicausations : Multicausation[*] {
|
|
59
|
+
doc /* multicausations is the base feature for Multicausation ConnectionUsages. */
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
connection def Causation :> Multicausation {
|
|
63
|
+
doc
|
|
64
|
+
/*
|
|
65
|
+
* A Causation is a binary Multicausation in which a single cause occurrence
|
|
66
|
+
* causes a single effect occurrence. (However, a single cause can separately
|
|
67
|
+
* have multiple effects, and a single effect can have separate Causation
|
|
68
|
+
* connections with multiple causes.)
|
|
69
|
+
*/
|
|
70
|
+
|
|
71
|
+
end theCauses [*] occurrence theCause :> causes :>> source {
|
|
72
|
+
doc /* The single causing occurrence. */
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
end theEffects [*] occurrence theEffect :> effects :>> target {
|
|
76
|
+
doc /* The single effect occurrence resulting from the cause. */
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
abstract connection causations : Causation[*] :> multicausations {
|
|
81
|
+
doc /* causations is the base feature for Causation ConnectionUsages. */
|
|
82
|
+
}
|
|
83
|
+
}
|