Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Pfem Melting application #9324

Closed
wants to merge 57 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
e90cb14
new element
juliobarna Mar 11, 2021
8cff0ff
removing warnings
juliobarna Mar 12, 2021
311a8fd
changes: several json has been added in order to consider differents …
juliobarna Mar 19, 2021
4ff0f65
adding a new element and new json files
juliobarna Mar 29, 2021
f023aba
adding heat source
juliobarna Mar 29, 2021
ccfad12
organized element and functions
juliobarna Apr 8, 2021
22a8689
forcing dependencies
Sep 19, 2021
050acb8
windows compilation
Sep 19, 2021
e83e92f
missing dependencies
jginternational Sep 24, 2021
22ef02f
solver type
jginternational Sep 24, 2021
822d634
Merge branch 'master' into meltingapplication
jginternational Sep 24, 2021
26c7a15
Changes needed to build windows
jginternational Sep 24, 2021
631fd2c
compilation warning
jginternational Sep 24, 2021
3dfbeb4
new updates
juliobarna Oct 5, 2021
1af6904
new updates
juliobarna Oct 5, 2021
f590be2
Delete applications/PfemMeltingApplication1 directory
juliobarna Oct 5, 2021
aa36f5c
new example
juliobarna Oct 8, 2021
2f876d4
erasing pfem2 application into pfemmelting
juliobarna Oct 14, 2021
df01f0c
fixing Windows compilation
Oct 27, 2021
e3e9e20
Merge branch 'master' into meltingapplication
Nov 2, 2021
d9f1c8a
using the lumped mass matrix instead of the full one due to numerical…
juliobarna Nov 3, 2021
03f68ad
Merge branch 'meltingapplication' of https://github.com/KratosMultiph…
juliobarna Nov 3, 2021
70bc7cd
new
juliobarna Nov 3, 2021
e4b9613
basic example running. Empty laser process is created.
Nov 3, 2021
0c9a415
Merge branch 'meltingapplication' of https://github.com/KratosMultiph…
Nov 3, 2021
527706a
example with only the required model parts
juliobarna Nov 9, 2021
81e5090
without properties in the mdpa file
juliobarna Nov 10, 2021
999008b
commenting some operations with model parts
juliobarna Nov 10, 2021
0e4d491
windows compilation fixed
Nov 10, 2021
cd0daa9
Merge branch 'master' into meltingapplication
jginternational Nov 11, 2021
29fcdfc
Laser utility added
juliobarna Nov 12, 2021
e28ac88
Merge branch 'meltingapplication' of https://github.com/KratosMultiph…
juliobarna Nov 12, 2021
da2e602
Merge branch 'meltingapplication' of https://github.com/KratosMultiph…
jginternational Nov 14, 2021
0a3d181
Some bugfixes
Nov 17, 2021
dfbc8ec
fixes
Nov 30, 2021
f55ef79
adding ambient temperature and mesh size
juliobarna Nov 30, 2021
0d456ce
with variable viscosity
juliobarna Nov 30, 2021
3fbc901
more adaptations. Adding values to json
Nov 30, 2021
18cd7ee
example new
juliobarna Nov 30, 2021
95368d9
adding new model part
juliobarna Nov 30, 2021
5593028
Merge branch 'meltingapplication' of https://github.com/KratosMultiph…
juliobarna Nov 30, 2021
b64ada1
reading laser file and improving the example
juliobarna Dec 16, 2021
2de1c39
Merge branch 'meltingapplication' of https://github.com/KratosMultiph…
jginternational Dec 16, 2021
2ea2451
Merge branch 'master' into meltingapplication
jginternational Dec 16, 2021
0e95472
missing space
jginternational Dec 16, 2021
21df0ea
flat laser working
Feb 1, 2022
3021255
minor changes
juliobarna Feb 2, 2022
5248a23
saving memory and improving laser process
juliobarna Feb 8, 2022
9a489f9
including normals in the faceheatflux
juliobarna Feb 21, 2022
15084dd
updates
juliobarna Feb 21, 2022
276680d
erasing elements when j>0
juliobarna Mar 15, 2022
768846f
cleaning the outputs
juliobarna Mar 22, 2022
41c2cf9
cleaning the outputs
juliobarna Mar 22, 2022
1feee7e
solver without remesh
juliobarna Apr 4, 2022
8fab508
adding solver without remesh
juliobarna Apr 4, 2022
da176b0
including time measurements
juliobarna Apr 20, 2022
722c773
adding a hypoelastic element
juliobarna Jun 30, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -1006,20 +1006,25 @@ void CalculateLocalVelocityContribution(MatrixType& rDampingMatrix,

double Temperature;
this->EvaluateInPoint(Temperature, TEMPERATURE, rShapeFunc);

//Temperature=900.0;
double Activation_energy;
this->EvaluateInPoint(Activation_energy, ACTIVATION_ENERGY, rShapeFunc);

double Arrhenius_coefficient;
this->EvaluateInPoint(Arrhenius_coefficient, ARRHENIUS_COEFFICIENT, rShapeFunc);

//KRATOS_WATCH(Arrhenius_coefficient)
//KRATOS_WATCH(Activation_energy)
//KRATOS_WATCH(Temperature)
double R=8.31; //universal gas constant
//constexpr double E_over_R_polymer = 21877.25;
//constexpr double C_polymer = 1.93e12;

double aux_var_polymer= Arrhenius_coefficient * exp(-Activation_energy/(R*Temperature));


double E_over_R_polymer = Activation_energy / R;
//double FFFF = E_over_R_polymer/Temperature;
//KRATOS_WATCH(FFFF)
//KRATOS_WATCH(E_over_R_polymer)
double aux_var_polymer= Arrhenius_coefficient * std::exp(- E_over_R_polymer/Temperature) ;
//double aux_var_polymer= 1.0 * std::exp(- 1.0) ;
//KRATOS_WATCH(aux_var_polymer)
for (unsigned int i = 0; i < TNumNodes; ++i) // iterate over rows
{
for (unsigned int j = 0; j < TNumNodes; ++j) // iterate over columns
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,10 @@ class ApplyLaserProcess : public Process

mRadius = rParameters["laser_profile"]["radius"].GetDouble();
mPower = rParameters["laser_profile"]["power"].GetDouble();
mDirectionx = rParameters["direction"][0].GetDouble();
mDirectiony = rParameters["direction"][1].GetDouble();
mDirectionz = rParameters["direction"][2].GetDouble();


// Now validate agains defaults -- this also ensures no type mismatch
//rParameters.ValidateAndAssignDefaults(default_parameters);
Expand Down Expand Up @@ -135,28 +139,44 @@ class ApplyLaserProcess : public Process
Node < 3 > work_point(0, 0.0, 0.0, 0.0);

array_1d<double, 3> direction;
direction[0] = 0.0;
direction[1] = 0.0;
direction[2] = -1.0;
/*direction[0] = 0.0;
direction[1] = 1.0;
direction[2] = 0.0;*/

direction[0] = mDirectionx;
direction[1] = mDirectiony;
direction[2] = mDirectionz;

//KRATOS_WATCH(direction)
array_1d<double, 3> unitary_dir = direction * (1.0 / MathUtils<double>::Norm3(direction));

//KRATOS_WATCH(unitary_dir)
for (size_t k = 0; k < list_of_nodes.size(); k++) {
const array_1d<double, 3>& coords = list_of_nodes[k]->Coordinates();
array_1d<double, 3> distance_vector;
distance_vector[0] = coords[0]-x;
distance_vector[1] = coords[1]-y;
distance_vector[2] = coords[2]-z;
//KRATOS_WATCH(distance_vector)

const double distance = MathUtils<double>::Norm3(distance_vector); // TODO: squared norm is better here
const double distance_projected_to_dir = distance_vector[0]*unitary_dir[0] + distance_vector[1]*unitary_dir[1] + distance_vector[2]*unitary_dir[2];

//KRATOS_WATCH(distance)
const double distance_projected_to_dir = distance_vector[0]*unitary_dir[0] + distance_vector[1]*unitary_dir[1] + distance_vector[2]*unitary_dir[2];
//KRATOS_WATCH(distance_projected_to_dir)
const double distance_to_laser_axis = std::sqrt(distance*distance - distance_projected_to_dir*distance_projected_to_dir);

//KRATOS_WATCH(distance_to_laser_axis)
//KRATOS_THROW_ERROR(std::logic_error, "method not implemented", "");
//KRATOS_WATCH(mRadius)
if(distance_to_laser_axis < mRadius) {
double& aux= list_of_nodes[k]->FastGetSolutionStepValue(FACE_HEAT_FLUX);
aux = mPower / (Globals::Pi * mRadius * mRadius);

//KRATOS_WATCH(aux)
}
}

//KRATOS_THROW_ERROR(std::logic_error, "method not implemented", "");
KRATOS_CATCH("");
}

Expand Down Expand Up @@ -210,6 +230,10 @@ class ApplyLaserProcess : public Process
array_1d<int, 3> mPositionLaserTableId;
double mPower;
double mRadius;
double mDirectionx;
double mDirectiony;
double mDirectionz;

/// Assignment operator.
ApplyLaserProcess& operator=(ApplyLaserProcess const& rOther);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ namespace Kratos

//node_it->FastGetSolutionStepValue(ARRHENIUS_VALUE)=aux_var_polymer;

node_it->FastGetSolutionStepValue(HEAT_FLUX) = (-1.0) * density * heat_of_vaporization * aux_var_polymer;
node_it->FastGetSolutionStepValue(HEAT_FLUX) = 0.0 * (-1.0) * density * heat_of_vaporization * aux_var_polymer;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is this temporary? Maybe we can put just
node_it->FastGetSolutionStepValue(HEAT_FLUX) = 0.0;


//KRATOS_WATCH(node_it->FastGetSolutionStepValue(HEAT_FLUX))

Expand Down