Simulation Core
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CPathGeneration.f90 4.0 KiB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. module CPathGeneration
  2. use SimulationVariables !@
  3. use json_module
  4. implicit none
  5. public
  6. contains
  7. subroutine PathGenerationToJson(parent)
  8. type(json_value),pointer :: parent
  9. type(json_core) :: json
  10. type(json_value),pointer :: ppath,pitems,p
  11. integer::i,n
  12. ! 1. create new node
  13. call json%create_object(ppath,'Path')
  14. call json%create_array(pitems,'Items')
  15. n = data%Configuration%Path%ItemCount
  16. do i=1,n
  17. call json%create_object(p,'')
  18. call json%add(p,"HoleType",data%Configuration%Path%items(i)%HoleType)
  19. call json%add(p,"Angle",data%Configuration%Path%items(i)%Angle)
  20. call json%add(p,"Length",data%Configuration%Path%items(i)%Length)
  21. call json%add(p,"FinalAngle",data%Configuration%Path%items(i)%FinalAngle)
  22. call json%add(p,"TotalLength",data%Configuration%Path%items(i)%TotalLength)
  23. call json%add(p,"MeasuredDepth",data%Configuration%Path%items(i)%MeasuredDepth)
  24. call json%add(p,"TotalVerticalDepth",data%Configuration%Path%items(i)%TotalVerticalDepth)
  25. call json%add(pitems,p)
  26. end do
  27. ! call json%create_array(pdp,'DataPoints')
  28. ! do i=1,data%Configuration%Path%DataPointsCount
  29. ! call json%create_object(p,'')
  30. ! call json%add(p,"X",data%Configuration%Path%DataPoints(i)%X)
  31. ! call json%add(p,"Y",data%Configuration%Path%DataPoints(i)%Y)
  32. ! call json%add(pdp,p)
  33. ! end do
  34. ! 3. add new node to parent
  35. call json%add(ppath,pitems)
  36. ! call json%add(ppath,pdp)
  37. call json%add(parent,ppath)
  38. end subroutine
  39. subroutine PathGenerationFromJson(parent)
  40. use json_module,IK =>json_ik
  41. type(json_value),pointer :: parent
  42. type(json_core) :: json
  43. type(json_value),pointer :: p,pitems,pitem,pval
  44. logical::is_found
  45. integer::i,n_children
  46. call json%get(parent,'Path',p)
  47. call json%get(p,'Items',pitems)
  48. call json%info(pitems, n_children=n_children)
  49. if (.not. allocated(data%Configuration%Path%Items)) then
  50. ALLOCATE(data%Configuration%Path%Items(n_children))
  51. endif
  52. if(size(data%Configuration%Path%Items)/=n_children) then
  53. DEALLOCATE(data%Configuration%Path%Items)
  54. ALLOCATE(data%Configuration%Path%Items(n_children))
  55. endif
  56. do i=1,n_children
  57. call json%get_child(pitems, i, pitem, found=is_found)
  58. call json%get(pitem,"HoleType",pval)
  59. call json%get(pval,data%Configuration%Path%Items(i)%HoleType)
  60. call json%get(pitem,"Angle",pval)
  61. call json%get(pval,data%Configuration%Path%Items(i)%Angle)
  62. call json%get(pitem,"Length",pval)
  63. call json%get(pval,data%Configuration%Path%Items(i)%Length)
  64. call json%get(pitem,"FinalAngle",pval)
  65. call json%get(pval,data%Configuration%Path%Items(i)%FinalAngle)
  66. call json%get(pitem,"TotalLength",pval)
  67. call json%get(pval,data%Configuration%Path%Items(i)%TotalLength)
  68. call json%get(pitem,"MeasuredDepth",pval)
  69. call json%get(pval,data%Configuration%Path%Items(i)%MeasuredDepth)
  70. call json%get(pitem,"TotalVerticalDepth",pval)
  71. call json%get(pval,data%Configuration%Path%Items(i)%TotalVerticalDepth)
  72. end do
  73. ! call json%get(p,'DataPoints',dpoints)
  74. ! call json%info(dpoints, n_children=n_children)
  75. ! if (.not. allocated(data%Configuration%Path%DataPoints) .or. size(data%Configuration%Path%DataPoints)/=n_children) then
  76. ! ALLOCATE(data%Configuration%Path%DataPoints(n_children))
  77. ! endif
  78. ! do i=1,n_children
  79. ! call json%get_child(dpoints, i, dpoint, found=is_found)
  80. ! call json%get(dpoint,"X",pval)
  81. ! call json%get(pval,data%Configuration%Path%DataPoints(i)%X)
  82. ! call json%get(dpoint,"Y",pval)
  83. ! call json%get(pval,data%Configuration%Path%DataPoints(i)%Y)
  84. ! end do
  85. end subroutine
  86. end module CPathGeneration