New question #294036 on Yade:
https://answers.launchpad.net/yade/+question/294036

Hello everyone,
I looked up document information and found that the concrete’s strain at 
maximum compressive strength is about 0.0033 and the strain at maximum tensile 
strength is about 0.00015. The rate of compressive strain and tensile strain is 
about 20. I used the following code to compress the concrete and tense it and I 
found from the diagram that the rate is about 2. I tried to change the rate by 
modifying the parameters, but I failed. Can you give me some suggestion about 
how to change the rate between the strain at maximum compressive strength and 
the strain at maximum tensile strength?

#########################################first code, calculate the strain at 
maximum compressive strength
#!/usr/bin/python           
import string
from yade import plot,qt
from yade.pack import *
from yade import pack, plot
O.materials.append(CpmMat(young=24e9,frictionAngle=atan(0.8),poisson=.2,sigmaT=3.5e6,relDuctility=30,epsCrackOnset=1e-4))

initSize=1.2

sp=pack.randomPeriPack(radius=.05,initSize=Vector3(initSize,initSize,initSize))

sp.toSimulation()

O.save('/tmp/hh.gz')

plot.plots={'ex':('sx',)}
def plotAddData():
        plot.addData(
                sx=p3d.stress[0],
                ex=p3d.strain[0],

        )


O.dt=PWaveTimeStep()/2

EnlargeFactor=1.5
EnlargeFactor=1.0
O.engines=[
        ForceResetter(),
        
InsertionSortCollider([Bo1_Sphere_Aabb(aabbEnlargeFactor=EnlargeFactor,label='bo1s')]),
        InteractionLoop(
                
[Ig2_Sphere_Sphere_ScGeom(interactionDetectionFactor=EnlargeFactor,label='ig2ss')],
                [Ip2_CpmMat_CpmMat_CpmPhys()],[Law2_ScGeom_CpmPhys_Cpm()]),
        NewtonIntegrator(),
        Peri3dController(
                                        
                                                        nSteps=4000,            
        # how many time steps the simulation will last
                                                        # after reaching nSteps 
do doneHook action
                                                        doneHook='print 
"Simulation with Peri3dController finished."; O.pause()',

                                                        # the prescribed path 
(step,value of stress/strain) can be defined in absolute values
                                                        
                                                        # or in relative values
                                                        
                                                        # if the goal value is 
0, the absolute stress/strain values are always considered (step values remain 
relative)
                                                        
                                                        # if ##Path is not 
explicitly defined, it is considered as linear function between (0,0) and 
(nSteps,goal)
                                                        # as in yzPath and 
xyPath
                                                        # the relative values 
are really relative (zxPath gives the same - except of the sign from goal value 
- result as yyPath)
                                                        
                                                        
                                                        # variables used in the 
first step
                                                        label='p3d'
                                                        ),
        PyRunner(command='plotAddData()',iterPeriod=1),
        
]

p3d.stressMask=0b111110       # prescribed ex,ey,sz,syz,ezx,sxy;   e..strain;  
s..stress
p3d.goal=(-0.005,0,0,0,0,0)  #xx, yy, zz, yz, zx, xy
O.step()
bo1s.aabbEnlargeFactor=ig2ss.interactionDetectionFactor=1.
O.run(); O.wait()
plot.plot(subPlots=False)

#########################################second code, calculate the strain at 
maximum tensile strength
#!/usr/bin/python           
import string
from yade import plot,qt
from yade.pack import *
from yade import pack, plot


O.load('/tmp/hh.gz')

plot.plots={'ex':('sx',)}
def plotAddData():
        plot.addData(
                sx=p3d.stress[0],
                ex=p3d.strain[0],

        )


O.dt=PWaveTimeStep()/2

EnlargeFactor=1.5
EnlargeFactor=1.0
O.engines=[
        ForceResetter(),
        
InsertionSortCollider([Bo1_Sphere_Aabb(aabbEnlargeFactor=EnlargeFactor,label='bo1s')]),
        InteractionLoop(
                
[Ig2_Sphere_Sphere_ScGeom(interactionDetectionFactor=EnlargeFactor,label='ig2ss')],
                [Ip2_CpmMat_CpmMat_CpmPhys()],[Law2_ScGeom_CpmPhys_Cpm()]),
        NewtonIntegrator(),
        Peri3dController(
                                        
                                                        nSteps=4000,            
        # how many time steps the simulation will last
                                                        # after reaching nSteps 
do doneHook action
                                                        doneHook='print 
"Simulation with Peri3dController finished."; O.pause()',

                                                        # the prescribed path 
(step,value of stress/strain) can be defined in absolute values
                                                        
                                                        # or in relative values
                                                        
                                                        # if the goal value is 
0, the absolute stress/strain values are always considered (step values remain 
relative)
                                                        
                                                        # if ##Path is not 
explicitly defined, it is considered as linear function between (0,0) and 
(nSteps,goal)
                                                        # as in yzPath and 
xyPath
                                                        # the relative values 
are really relative (zxPath gives the same - except of the sign from goal value 
- result as yyPath)
                                                        
                                                        
                                                        # variables used in the 
first step
                                                        label='p3d'
                                                        ),
        PyRunner(command='plotAddData()',iterPeriod=1),
        
]




p3d.stressMask=0b111110       # prescribed ex,ey,sz,syz,ezx,sxy;   e..strain;  
s..stress
p3d.goal=(0.0015,0,0,0,0,0)  #xx, yy, zz, yz, zx, xy
O.step()
bo1s.aabbEnlargeFactor=ig2ss.interactionDetectionFactor=1.

O.run(); O.wait()
plot.plot(subPlots=False)


-- 
You received this question notification because your team yade-users is
an answer contact for Yade.

_______________________________________________
Mailing list: https://launchpad.net/~yade-users
Post to     : [email protected]
Unsubscribe : https://launchpad.net/~yade-users
More help   : https://help.launchpad.net/ListHelp

Reply via email to