This example shows how to create a fatigue study.
	
	'----------------------------------------------------------------------------
	' Preconditions:
	
' 1. Add the SOLIDWORKS Simulation as an add-in
(in SOLIDWORKS, click 
	'    Tools > Add-ins > SOLIDWORKS Simulation > OK).
' 2. Add the SOLIDWORKS Simulation primary interop assembly as a reference
'    (in the IDE, click Project > Add Reference > .NET > 
'    SolidWorks.Interop.cosworks > OK).
	
	' 3. Open, rebuild, and fix as needed public_documents\samples\tutorial\api\
	'    landing_gear.sldasm.
	' 4. Activate Ready_Static.
	' 5. Right-click BearingLoads-1 
	and click Edit Definition.
	' 6. Select load-bearing faces that are concentric with the Z-axis of 
	the
	'    selected coordinate system and click the green 
	check mark.
	' 7. Mesh the study.
	' 8. Run the study.
	' 9. Open an Immediate window.
	'
	' Postconditions:
	' 1. A 
	default fatigue study results plot is created.
	' 2. Two fatigue studies are created and analyzed:
	'    * Fatigue_StudyAPIConst (constant amplitude fatigue 
	study)
	'    * Fatigue_StudyAPIVariable (variable amplitude fatigue 
	study)
	' 3. Inspect the Immediate window for fatigue study options, fatigue events,
	'    and fatigue study analysis results.
	' 4. Inspect the fatigue results plots.
	'
	' NOTE: Because the model is used elsewhere,do not save changes.
	' 
	---------------------------------------------------------------------------
	Imports 
	SolidWorks.Interop.sldworks
	Imports 
	SolidWorks.Interop.swconst
	Imports 
	SolidWorks.Interop.cosworks
	Imports 
	System
	Imports 
	System.Diagnostics
	
	Partial
	Class 
	SolidWorksMacro
	
	    Sub 
	ErrorMsg(ByVal 
	Message As
	String)
	        SwApp.SendMsgToUser2(Message, 0, 0)
	        SwApp.RecordLine("'*** WARNING - 
	General")
	        SwApp.RecordLine("'*** " 
	& Message)
	        SwApp.RecordLine("")
	    End
	Sub
	
	    Function 
	SelectByPID(ByVal 
	Part As 
	ModelDoc2, ByVal 
	PIDName As
	String,
	ByVal 
	PIDCollection As 
	Collection) As
	Object
	        Dim 
	PID() As
	Byte
	        Dim 
	PIDVariant As
	Object
	        Dim 
	PIDString As
	String
	        Dim 
	i As 
	Integer
	        Dim 
	SelObj As
	Object
        Dim errCode as Integer
	
	        'Get 
	the string from the collection
	        PIDString = 
	""
	        PIDString = 
	PIDCollection.Item(PIDName)
	
	        'Parse the string into an array
	        PIDVariant = Split(PIDString,
	",")
	        ReDim 
	PID(UBound(PIDVariant))
	
	        'Change to a byte array
	        For 
	i = 0 To (UBound(PIDVariant) 
	- 1)
	            PID(i) = PIDVariant(i)
	        Next 
	i
	
	        'Select the entity
	        SelObj = 
	Part.Extension.GetObjectByPersistReference3((PID), errCode)
	        SelectByPID = SelObj
	        SelObj = Nothing
	    End
	Function
	
	    Function 
	PIDInitializer() As 
	Collection
	        Dim 
	PIDCollection As
	New 
	Collection
	        Dim 
	selection1 As
	String
	
	        'Constants
	        selection1 = 
	
	"255,18,0,0,3,0,0,0,255,254,255,27,85,0,112,0,112,0,114,0,115,0,119,0,97,0,121,0,95,0,108,0,110,0,107,0,45,0,49,0,64,0,108,0,97,0,110,0,100,0,105,0,110,0,103,0,95,0,103,0,101,0,97,0,114,0,4,0,0,0,16,0,0,0,1,0,0,0,1,0,0,0,57,0,0,0,255,255,1,0,13,0,109,111,86,101,114,116,101,120,82,101,102,95,99,255,255,255,255,255,255,255,255,3,0,0,0,0,2,0,0,0,0,0,0,125,195,148,37,173,73,178,84,125,195,148,37,173,73,178,84,0,0,255,255,1,0,23,0,109,111,70,114,111,109,83,107,116,69,110,116,83,117,114,102,73,100,82,101,112,95,99,0,0,255,255,1,0,6,0,109,111,70,82,95,99,255,255,1,0,13,0,109,111,69,120,116,79,98,106,101,99,116,95,99,255,255,1,0,17,0,109,111,67,83,116,114,105,110,103,72,97,110,100,108,101,95,99,255,254,255,104,67,0,58,0,92,0,68,0,111,0,99,0,117,0,109,0,101,0,110,0,116,0,115,0,32,0,97,0,110,0,100,0,32,0,83,0,101,0,116,0,116,0,105,0,110,0,103,0,115,0,92,0,97,0,116,0,114,0,105,0,118,0,101,0,100,0,105,0,92,0,77,0,121,0,32,0,68,0,111,0,99,0,117,0,109,0,101,0,110,0,116,0,115,0,92,0,99,"
	        selection1 = selection1 & 
	
	"0,111,0,115,0,109,0,111,0,115,0,95,0,115,0,117,0,112,0,112,0,111,0,114,0,116,0,92,0,50,0,48,0,48,0,54,0,98,0,101,0,116,0,97,0,92,0,76,0,97,0,110,0,100,0,105,0,110,0,103,0,32,0,71,0,101,0,97,0,114,0,92,0,85,0,112,0,112,0,114,0,115,0,119,0,97,0,121,0,95,0,108,0,110,0,107,0,46,0,83,0,76,0,68,0,80,0,82,0,84,0,9,128,255,254,255,12,85,0,112,0,112,0,114,0,115,0,119,0,97,0,121,0,95,0,108,0,110,0,107,0,2,0,0,247,212,198,52,0,138,187,76,66,1,0,0,0,0,0,0,0,18,0,0,0,255,254,255,7,68,0,101,0,102,0,97,0,117,0,108,0,116,0,32,0,0,0,0,0,0,0,138,187,76,66,8,0,0,0,166,214,198,52,14,0,0,0,3,128,0,0,5,128,8,0,8,0,0,0,166,214,198,52,13,0,0,0,255,255,1,0,20,0,109,111,69,110,100,70,97,99,101,83,117,114,102,73,100,82,101,112,95,99,0,0,5,128,8,0,8,0,0,0,166,214,198,52,1,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0"
	        selection1 = selection1 & 
	",Type=1"
	
	        'Store 
	constants in a collection
	        PIDCollection.Add(selection1,
	"selection1")
	
	        PIDInitializer = PIDCollection
	    End
	Function
	
	    Function 
	ProcErrCode(ByVal 
	errCode As
	Long)
	As 
	String
	        Select
	Case 
	errCode
	            Case 
	0
	                ProcErrCode = 
	"Successful."
	            Case 
	1 To 21
	                ProcErrCode = "Incorrect 
	input conditions."
	            Case 
	22
	                ProcErrCode = 
	"Authorization failed for this analysis type."
	            Case 
	23
	                ProcErrCode = "Mesh not 
	found. Create mesh first."
	            Case 
	24
	                ProcErrCode = "Analysis 
	failed."
	            Case
	Else
	                ProcErrCode = 
	"Unknown error condition."
	        End
	Select
	    End
	Function
	
	    Sub 
	main()
	
	        Dim 
	Part As 
	ModelDoc2
	        Dim 
	COSMOSWORKS As 
	CosmosWorks
	        Dim 
	CWAddinCallBack As 
	CwAddincallback
	        Dim 
	ActDoc As 
	CWModelDoc
	        Dim 
	StudyMngr As 
	CWStudyManager
	        Dim 
	Study As 
	CWStudy
	        Dim 
	Study2 As 
	CWStudy
	        Dim 
	CWFeatObj As 
	CWResults
	        Dim 
	FatigueOptions As 
	CWFatigueStudyOptions
	        Dim 
	FatigueEvent As 
	CWFatigueEvent
	        Dim 
	FatigueOptions2 As 
	CWFatigueStudyOptions
	        Dim 
	FatigueEvent2 As 
	CWFatigueEvent
	        Dim 
	PointsX(10) As
	Object
	        Dim 
	PointsY(10) As
	Object
	        Dim 
	PointsX_2(12) As
	Object
	        Dim 
	PointsY_2(12) As
	Object
	        Dim 
	errCode As
	Long
	        Dim 
	Disp As
	Object
	        Dim 
	VarStudyNames As
	Object =
	Nothing
	        Dim 
	VarScales As
	Object =
	Nothing
	        Dim 
	VarSteps As
	Object =
	Nothing
	        Dim 
	AssocCounts As
	Long
	        Dim 
	VarNewStudyNames As
	Object =
	Nothing
	        Dim 
	VarNewScales As
	Object =
	Nothing
	        Dim 
	VarNewSteps As
	Object =
	Nothing
	        Dim 
	VarVertices As
	Object =
	Nothing
	
	        Dim 
	PIDCollection As
	New 
	Collection
	        PIDCollection = PIDInitializer()
	
	        Part = SwApp.ActiveDoc
	
	        VarVertices = SelectByPID(Part,
	"selection1", 
	PIDCollection)
	
	        CWAddinCallBack = SwApp.GetAddInObject("SldWorks.Simulation")
	        If 
	CWAddinCallBack Is
	Nothing
	Then 
	ErrorMsg("CWAddinCallBack object not 
	found.")
	        COSMOSWORKS = CWAddinCallBack.COSMOSWORKS
	        If 
	COSMOSWORKS Is
	Nothing
	Then 
	ErrorMsg("COSMOSWORKS object not found.")
	
	        ActDoc = COSMOSWORKS.ActiveDoc()
	        If 
	ActDoc Is
	Nothing
	Then 
	ErrorMsg("Failed to get active document.")
 
		        
		' Add default fatigue study results plot
		        
		errCode = ActDoc.AddDefaultFatigueStudyPlot(swsFatigueStudyResultType_e.swsFatigueStudy_DamagePlot)
 
 
	
	        StudyMngr = ActDoc.StudyManager()
	        If 
	StudyMngr Is
	Nothing
	Then 
	ErrorMsg("Failed to get StudyManager 
	object.")
	
	        'Create constant amplitude fatigue 
	study
	        Debug.Print("Creating 
	constant amplitude fatigue study Fatigue_StudyAPIConst...")
	        Study = StudyMngr.CreateNewStudy3("Fatigue_StudyAPIConst", 
	swsAnalysisStudyType_e.swsAnalysisStudyTypeFatigue, 0, errCode)
	        If 
	Study Is
	Nothing
	Then 
	ErrorMsg("Failed to create new study.")
	
	        errCode = Study.SetFatigueResultOptions(1, 
	Nothing)
	
	        FatigueOptions = Study.FatigueStudyOptions
	        If 
	FatigueOptions Is
	Nothing
	Then 
	ErrorMsg("Failed to get 
	FatigueStudyOptions object.")
	
	        FatigueEvent = FatigueOptions.AddFatigueEventForConstantAmplitude("Ready_Static", 
	-0.002, 1, errCode)
	        FatigueEvent.SuppressUnSuppress() 
	'suppress event
	        FatigueEvent.SuppressUnSuppress()
	'unsuppress event
	
	        AssocCounts = FatigueEvent.GetStudyAssociationData(VarStudyNames, 
	VarScales, VarSteps)
	
	        FatigueEvent.FatigueEventBeginEdit()
	        FatigueEvent.Cycles2 = 500.0
	        FatigueEvent.LoadingRatio = 8.9
	        FatigueEvent.LoadingType = 2 
	' Loading ratio
	        VarNewScales = 5.6
	        VarNewStudyNames = "Ready_Static"
	        VarNewSteps = 9
	        errCode = FatigueEvent.SetStudyAssociationData(1, (VarNewStudyNames), 
	(VarNewScales), (VarNewSteps))
	        errCode = FatigueEvent.FatigueEventEndEdit()
	
	        Dim 
	fatEv As 
	CWFatigueEvent
	        fatEv = FatigueOptions.GetFatigueEvent(0, errCode)
	        Debug.Print("  Name of constant 
	amplitude fatigue event is: " & fatEv.Name)
	        Debug.Print("  Number of loading 
	events in this fatigue study: " & 
	FatigueOptions.LoadingEventCount)
	        Debug.Print("  Result folder: " 
	& FatigueOptions.ResultFolder)
	        Debug.Print("  Shell face option 
	as defined in swsShellFace_e: " & 
	FatigueOptions.ShellFace)
	        Dim 
	bchecked As
	Long
	        Dim 
	dcycles As
	Double
	        FatigueOptions.GetInfiniteLifeSettings2(bchecked, 
	dcycles)
	        Debug.Print("  Fatigue study 
	infinite life settings checked? (-1 = yes) " 
	& bchecked)
	        Debug.Print("  Number of cycles 
	to use: " & dcycles)
	        Debug.Print("  Event interaction 
	type as defined in swsFatigueEventInteraction_e: " 
	& FatigueOptions.ConstantAmplitudeEventInteractionOption)
	        Debug.Print("  Computing 
	alternating stress option as defined in swsFatigueAlternatingStressOption_e: 
	" & FatigueOptions.ComputingAlternatingStressOption)
	        Debug.Print("  Fatigue strength 
	reduction factor: " & FatigueOptions.FatigueStrengthReductionFactor)
	        Debug.Print("  Mean stress 
	correction option as defined in swsFatigueMeanStressCorrectionType_e: " 
	& FatigueOptions.MeanStressCorrectionOption)
	
	        errCode = Study.RunAnalysis
	        If 
	errCode <> 0 Then 
	ErrorMsg("Analysis failed with error code 
	" & errCode & 
	" - " & 
	ProcErrCode(errCode))
	
	        'Create variable amplitude fatigue 
	study
	        Debug.Print("")
	        Debug.Print("Creating variable 
	amplitude fatigue study Fatigue_StudyAPIVariable...")
	        Study2 = StudyMngr.CreateNewStudy3("Fatigue_StudyAPIVariable", 
	swsAnalysisStudyType_e.swsAnalysisStudyTypeFatigue, 1, errCode)
	        If 
	Study2 Is
	Nothing
	Then 
	ErrorMsg("Failed to create new study.")
	
	        errCode = Study2.SetFatigueResultOptions(1, (VarVertices))
	
	        FatigueOptions2 = Study2.FatigueStudyOptions
	        If 
	FatigueOptions2 Is
	Nothing
	Then 
	ErrorMsg("Failed to get 
	FatigueStudyOptions Object.")
	
	        PointsX(0) = 0
	        PointsX(1) = 1
	        PointsX(2) = 2
	        PointsX(3) = 3
	        PointsX(4) = 4
	        PointsX(5) = 5
	        PointsX(6) = 6.25714
	        PointsX(7) = 7
	        PointsX(8) = 8.3846
	        PointsX(9) = 9
	        PointsX(10) = 10
	
	        PointsY(0) = 0
	        PointsY(1) = 11
	        PointsY(2) = 21
	        PointsY(3) = 33
	        PointsY(4) = 44
	        PointsY(5) = 21
	        PointsY(6) = 66.25714
	        PointsY(7) = 77
	        PointsY(8) = 88.3846
	        PointsY(9) = 99
	        PointsY(10) = 109
	
	        FatigueEvent2 = FatigueOptions2.AddFatigueEventForVariableAmplitude("Ready_Static", 
	-0.002, 1, (PointsX), (PointsY), 0, 1.0#, errCode)
	
	        fatEv = FatigueOptions2.GetFatigueEvent(0, errCode)
	        Debug.Print("  Name of variable 
	amplitude fatigue event is " & fatEv.Name)
	
	        Debug.Print("  Number of repeats: 
	" & FatigueEvent2.NoOfRepeats)
	        Debug.Print("  Start times: " 
	& FatigueEvent2.StartTimes)
	
	        FatigueEvent2.FatigueEventBeginEdit()
	        
	        PointsX_2(0) = 0
	        PointsX_2(1) = 1
	        PointsX_2(2) = 2
	        PointsX_2(3) = 3
	        PointsX_2(4) = 4
	        PointsX_2(5) = 5
	        PointsX_2(6) = 6.25714
	        PointsX_2(7) = 7
	        PointsX_2(8) = 8.3846
	        PointsX_2(9) = 9
	        PointsX_2(10) = 10
	        PointsX_2(11) = 11
	        PointsX_2(12) = 20
	
	        PointsY_2(0) = 0
	        PointsY_2(1) = 11
	        PointsY_2(2) = 21
	        PointsY_2(3) = 33
	        PointsY_2(4) = 44
	        PointsY_2(5) = 21
	        PointsY_2(6) = 66.25714
	        PointsY_2(7) = 77
	        PointsY_2(8) = 88.3846
	        PointsY_2(9) = 99
	        PointsY_2(10) = 109
	        PointsY_2(11) = 66
	        PointsY_2(12) = 12
	
	        errCode = FatigueEvent2.SetLoadHistoryCurve((PointsX_2), 
	(PointsY_2), 2, 1.8)
	        errCode = FatigueEvent2.FatigueEventEndEdit()
	
	        Dim 
	lhCurve As
	Object
	        Dim 
	ntype As
	Long
	        Dim 
	dsamplingrate As
	Double
	        lhCurve = FatigueEvent2.GetLoadHistoryCurve(ntype, 
	dsamplingrate)
	        Debug.Print("  Type of load 
	history curve as defined in swsFatigueLoadHistoryCurveType_e: " 
	& ntype)
	        Debug.Print("  Sampling rate in 
	seconds: " & dsamplingrate)
	        Debug.Print("  Number of pairs of 
	load history curve data: " & lhCurve(0))
	        Debug.Print("  Load history curve 
	[time, amplitude] data:")
	        Debug.Print("  " 
	& lhCurve(1) & ", " 
	& lhCurve(2))
	        Debug.Print("  " 
	& lhCurve(3) & ", " 
	& lhCurve(4))
	        Debug.Print("  " 
	& lhCurve(5) & ", " 
	& lhCurve(6))
	        Debug.Print("  " 
	& lhCurve(7) & ", " 
	& lhCurve(8))
	        Debug.Print("  " 
	& lhCurve(9) & ", " 
	& lhCurve(10))
	        Debug.Print("  " 
	& lhCurve(11) & ", " 
	& lhCurve(12))
	        Debug.Print("  " 
	& lhCurve(13) & ", " 
	& lhCurve(14))
	        Debug.Print("  " 
	& lhCurve(15) & ", " 
	& lhCurve(16))
	        Debug.Print("  " 
	& lhCurve(17) & ", " 
	& lhCurve(18))
	        Debug.Print("  " 
	& lhCurve(19) & ", " 
	& lhCurve(20))
	        Debug.Print("  " 
	& lhCurve(21) & ", " 
	& lhCurve(22))
	        Debug.Print("  " 
	& lhCurve(23) & ", " 
	& lhCurve(24))
	        Debug.Print("  " 
	& lhCurve(25) & ", " 
	& lhCurve(26))
	
	        Debug.Print("  Number of loading 
	events in this fatigue study: " & 
	FatigueOptions2.LoadingEventCount)
	        Debug.Print("  Result folder: " 
	& FatigueOptions2.ResultFolder)
	        Debug.Print("  Shell face 
	option as defined in swsShellFace_e: " & 
	FatigueOptions2.ShellFace)
	
	        FatigueOptions2.GetInfiniteLifeSettings(bchecked, dcycles)
	        Dim 
	nnoofbins As
	Long
	        Dim 
	npercentfilterloadcycles As
	Long
	        FatigueOptions2.GetVariableAmplitudeEventOptions(nnoofbins, 
	npercentfilterloadcycles)
	        Debug.Print("  Fatigue study 
	infinite life settings checked? (1 = yes) " 
	& bchecked)
	        Debug.Print("  Number of cycles 
	to use: " & dcycles)
	        Debug.Print("  Number of equally 
	spaced buckets in which to distribute the load: " 
	& nnoofbins)
	        Debug.Print("  Filter load cycles 
	below this percentage of maximum load: " & 
	npercentfilterloadcycles)
	        Debug.Print("  Computing 
	alternating stress option as defined in swsFatigueAlternatingStressOption_e: 
	" & FatigueOptions2.ComputingAlternatingStressOption)
	        Debug.Print("  Fatigue strength 
	reduction factor: " & FatigueOptions2.FatigueStrengthReductionFactor)
	        Debug.Print("  Mean stress 
	correction option as defined in swsFatigueMeanStressCorrectionType_e: " 
	& FatigueOptions2.MeanStressCorrectionOption)
	
	        errCode = Study2.RunAnalysis
	        If 
	errCode <> 0 Then 
	ErrorMsg("Analysis failed with error code 
	" & errCode & 
	" - " & 
	ProcErrCode(errCode))
	
	        CWFeatObj = Study2.Results
	        If 
	CWFeatObj Is
	Nothing
	Then 
	ErrorMsg("Failed to get result object.")
	
	        'Get Min/Max Fatigue
	        Disp = CWFeatObj.GetMinMaxFatigue(0, 
	errCode)
	        Debug.Print("  Minimum fatigue is 
	" & Disp(1) & 
	" at node " & 
	Disp(0))
	        Debug.Print("  Maximum fatigue is 
	" & Disp(3) & 
	" at node " & 
	Disp(2))
 
	    End
	Sub
	   
	    Public 
	swApp As 
	SldWorks
	
	End 
	Class