Ivar KJELBERG
COMSOL Multiphysics(r) fan, retired, former "Senior Expert" at CSEM SA (CH)
Please login with a confirmed email address before reporting spam
Posted:
1 decade ago
20.11.2010, 08:16 GMT-5
Hi
"
There is one caveat with importing mesh: you need to make COMSOL "domains" and "boundaries" as geoemtrical entities out of your mesh, because COMSOL sets the physics and the BC on the domains and Boundaries AND NOT on the mesh. The mesh inherits thier properties from the domain they belong to, nodes from the boundaries thy belong to.
In 3.5a there were some functionality to generate the domains and their boundaries from a nastran neutral file format imported mesh (not sure how it is in v4)
--
Good luck
Ivar
Hi
"
There is one caveat with importing mesh: you need to make COMSOL "domains" and "boundaries" as geoemtrical entities out of your mesh, because COMSOL sets the physics and the BC on the domains and Boundaries AND NOT on the mesh. The mesh inherits thier properties from the domain they belong to, nodes from the boundaries thy belong to.
In 3.5a there were some functionality to generate the domains and their boundaries from a nastran neutral file format imported mesh (not sure how it is in v4)
--
Good luck
Ivar
Please login with a confirmed email address before reporting spam
Posted:
1 decade ago
20.11.2010, 18:37 GMT-5
Hi Ivar,
You are right about importing meshes and assigning faces to boundaries. My initial attempts with 3.5 used the MATLAB converter included but this simply imported a mesh with no labels. For a large mesh of a complicated geometry this meant thousands of faces needed to be individually assigned before running a simulation (although it did look like there was some default attempt at face partitioning/grouping running). This amounted to little more than importing an STL file.
The current converter I am using appears to be labelling/grouping boundary nodes correctly. For my flow problems simply groups boundary faces as inlet or outlet, and wall. That said, my real problem is related to post-processing, particularly writing results to file. At some point COMSOL must have arrays storing velocity and pressure (for a flow problem) at each nodal location. For a P1P1 element and a 3D problem I should have 4 values (Ux, Uv, Uw, and P) at each nodal location.
I would like to be able to write the results of a CFD simulation in the format described in my initial post as this would allow me to use some alternative post-processing/visualisation tools.
Thanks again for your time and your interest in my problem.
Cheers, Nathan
Hi Ivar,
You are right about importing meshes and assigning faces to boundaries. My initial attempts with 3.5 used the MATLAB converter included but this simply imported a mesh with no labels. For a large mesh of a complicated geometry this meant thousands of faces needed to be individually assigned before running a simulation (although it did look like there was some default attempt at face partitioning/grouping running). This amounted to little more than importing an STL file.
The current converter I am using appears to be labelling/grouping boundary nodes correctly. For my flow problems simply groups boundary faces as inlet or outlet, and wall. That said, my real problem is related to post-processing, particularly writing results to file. At some point COMSOL must have arrays storing velocity and pressure (for a flow problem) at each nodal location. For a P1P1 element and a 3D problem I should have 4 values (Ux, Uv, Uw, and P) at each nodal location.
I would like to be able to write the results of a CFD simulation in the format described in my initial post as this would allow me to use some alternative post-processing/visualisation tools.
Thanks again for your time and your interest in my problem.
Cheers, Nathan
Please login with a confirmed email address before reporting spam
Posted:
1 decade ago
20.11.2010, 21:04 GMT-5
I think I worked out the problem.
When creating a report of the solution in spreadsheet format COMSOL lists coordinate information and then any expressions that have been specified (velocity component and pressure for me) to be added to the data file you will write. The first value in the file is vertex one of element one, 2nd value is vertex 2 of element 2 .... untile reaching the 4th vertex of the last element in the mesh.
This explains the length of the file not matching the number of nodes in the mesh (there are more rows in the output file than nodes) because the number of rows in the file is the number of elements multiplied by 4 (4 vertices for each tetrahedral element). I should have noticed this earlier.
Writing in this format means that there is a lot of information repeated in the file given that any node can be a part of many elements. It would be nice if the results could be written in a node based order rather than an element order to reduce the size of the exported file.
I think I worked out the problem.
When creating a report of the solution in spreadsheet format COMSOL lists coordinate information and then any expressions that have been specified (velocity component and pressure for me) to be added to the data file you will write. The first value in the file is vertex one of element one, 2nd value is vertex 2 of element 2 .... untile reaching the 4th vertex of the last element in the mesh.
This explains the length of the file not matching the number of nodes in the mesh (there are more rows in the output file than nodes) because the number of rows in the file is the number of elements multiplied by 4 (4 vertices for each tetrahedral element). I should have noticed this earlier.
Writing in this format means that there is a lot of information repeated in the file given that any node can be a part of many elements. It would be nice if the results could be written in a node based order rather than an element order to reduce the size of the exported file.
Ivar KJELBERG
COMSOL Multiphysics(r) fan, retired, former "Senior Expert" at CSEM SA (CH)
Please login with a confirmed email address before reporting spam
Posted:
1 decade ago
21.11.2010, 04:11 GMT-5
Hi
Thanks for your interesting comments. One serious issue I have (being in a small company,) by using COMSOL and doing developments for larger compagnies, is that these have as reference NASTRAN or ANSYS and they forces us to deliver (at least reduced) models in their respective formats so they can include our part into their system model.
File exchange is an important issue. I have located a small company here in Switzerland with an excellent exchange programme translating NASTRAN to ANSYS and reciprocally, with minimum or no loss, but as you are doing it, these "older" programmes are all mesh based, while COMSOL is geometrical entitiy (domain, boundary...) based to allow correctly for the multiphysics approach. This makes it somewhat more complex to echange, but I'm convinced its fully possible.
I had also started to write a matlab code a year or two ago to translate other code file format to COMSOL but gave up because of lack of time and availabilities (I must find some "students" and push it on them, but I'm not in an university).
So anything to improve model exchange (just as for the other important issue script validation and verification of a model following given established rules, at least for traditional themo-structural analysis) are to be improved, minimum by having exchanges between the users here on the forum, until COMSOL manages to introduce it into their code
--
Good luck
Ivar
Hi
Thanks for your interesting comments. One serious issue I have (being in a small company,) by using COMSOL and doing developments for larger compagnies, is that these have as reference NASTRAN or ANSYS and they forces us to deliver (at least reduced) models in their respective formats so they can include our part into their system model.
File exchange is an important issue. I have located a small company here in Switzerland with an excellent exchange programme translating NASTRAN to ANSYS and reciprocally, with minimum or no loss, but as you are doing it, these "older" programmes are all mesh based, while COMSOL is geometrical entitiy (domain, boundary...) based to allow correctly for the multiphysics approach. This makes it somewhat more complex to echange, but I'm convinced its fully possible.
I had also started to write a matlab code a year or two ago to translate other code file format to COMSOL but gave up because of lack of time and availabilities (I must find some "students" and push it on them, but I'm not in an university).
So anything to improve model exchange (just as for the other important issue script validation and verification of a model following given established rules, at least for traditional themo-structural analysis) are to be improved, minimum by having exchanges between the users here on the forum, until COMSOL manages to introduce it into their code
--
Good luck
Ivar