booleanModifier_multistep.f90 Source File


Source Code

program main
    use FEMDomainClass
    implicit none

    type(FEMDomain_) :: soil,plate,box
    real(real64),allocatable :: PorePressure(:),Velocity(:,:)
    integer(int32) :: i
    real(real64)   :: height
    
    height=10.0d0
    call soil%create("Cube3D",x_num=100,y_num=100,z_num=100)
    call soil%resize(x=10.0d0,y=10.0d0,z=10.0d0)
    
    do i = 1,100

        call plate%create("Cube3D",x_num=3,y_num=10,z_num=10)
        call plate%resize(x=0.70d0,y=10.0d0,z=10.0d0)
        call plate%move(x=5.0d0,z=2.00d0+height)

        call box%create("Cube3D",x_num=3,y_num=3,z_num=3)
        call box%resize(x=5.0d0,y=10.0d0,z=5.0d0)
        call box%move(x=5.50d0,z=5.00d0+height)
        call box%vtk("box")

        call soil%boolean(object=plate,difference=.True.)
        call soil%boolean(object=box,difference=.True.)
        
        call plate%vtk("plate_" + str(i) )
        call box%vtk(  "box_"   + str(i) )
        call soil%vtk( "cut_"   + str(i) )    

        height = height - 0.10d0

        call plate%remove()
        call box%remove()
    enddo

end program main