Print temperatures node ids and locations using DPF inside mechanical

Erik Kostson
Erik Kostson Member, Employee Posts: 202
50 Answers 100 Comments Photogenic 5 Likes
✭✭✭✭

We have a named selection (say MY_NS surface scoped) and we want to obtain and print temperatures, node ids and locations in transient thermal analysis.

Comments

  • Erik Kostson
    Erik Kostson Member, Employee Posts: 202
    50 Answers 100 Comments Photogenic 5 Likes
    ✭✭✭✭
    edited May 16

    There was an error rendering this rich post.

  • Erik Kostson
    Erik Kostson Member, Employee Posts: 202
    50 Answers 100 Comments Photogenic 5 Likes
    ✭✭✭✭
    edited May 16
    # Import DPF
    import mech_dpf
    import Ans.DataProcessing as dpf 
    mech_dpf.setExtAPI(ExtAPI)
    
    #Get the data source (i.e. result file)
    analysis = ExtAPI.DataModel.Project.Model.Analyses[0]
    dataSource = dpf.DataSources(analysis.ResultFileName)
    
    #Create Named Selection Operator
    ns_op = dpf.operators.scoping.on_named_selection()
    ns_op.inputs.data_sources.Connect(dataSource)
    ns_op.inputs.requested_location.Connect('Nodal')
    #Name should be in all caps
    ns_op.inputs.named_selection_name.Connect('MY_NS')
    mymeshscoping = ns_op.outputs.mesh_scoping
    
    # Get node numbers for nodes in named selection
    mesh_data = ns_op.outputs.mesh_scoping.GetData()
    mesh_data.Ids #  node Ids
    #Then, let's grab the complete mesh through:
    
    # Get complete mesh
    model=dpf.Model(dataSource)
    mesh=model.Mesh
    #Now we can use the info on the mesh and on the node Ids to get information on the nodes of this named selection:
    # time
    #Get the time data corresponding to result sets
    time_provider = dpf.operators.metadata.time_freq_provider()
    time_provider.inputs.data_sources.Connect(dataSource)
    numSets = time_provider.outputs.time_freq_support.GetData().NumberSets
    timeids = time_provider.outputs.time_freq_support.GetData().TimeFreqs.Data
    
    f1=open("D:\\testtempssdpf.txt","w") #open file in user directory change as needed
    #hget results
    # Get information for first node in named selection
    for mytime in timeids:
        temp=0
        i=0
        mytemp=dpf.operators.result.temperature(time_scoping=mytime,data_sources=dataSource,mesh_scoping=mymeshscoping).outputs.fields_container.GetData()[0]
        temp=mytemp.Data
        for idd in mesh_data.Ids:
            node1=mesh.NodeById(idd)
            f1.write(str(mytime) + "," + str(idd) +","+str(temp[i])+","+ str(node1.X) + "," + str(node1.Y) +"," + str(node1.Z)+ "\n")
            i=i+1
    f1.close()
    model.ReleaseStreams()
    
This discussion has been closed.