Advertisement
aka_zaratustra

crop_stats1.1.3

Oct 30th, 2020 (edited)
4,364
2
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Lua 36.34 KB | None | 2 0
  1. --Скрипт для робота, для поднятия статов у кропсов или разведения дубликатов (режим задается константой mode)
  2. --Автор: aka_zaratustra осень 2020
  3. local ver = "1.1.3" -- версия программы
  4. --Историю версий см. в конце файла
  5.  
  6. -- схема грядки
  7. --|C1|M1|C2
  8. --|M2|C3|M3
  9. --|C4|M4|C5
  10. --|CH|P0|BR
  11.  
  12. -- P0 - исходное положение робота. Робот находится на 1 блок выше кропсов (чтобы мог летать над ними), смотрит на север (в сторону грядок). В руках у робота должна быть лопатка Spade. В первом слоте инвентори робота или должны быть палки или он должен быть пустой (робот сам возьмет и положет туда палки)
  13. -- С[n] - дочерние (разводимые) растения
  14. -- M[n] - материнские растения
  15. -- СН - chest, сундук, куда будут помещаться мешочки с семечками и урожай
  16. -- BR - барель с кропсами(палками)
  17.  
  18. -- В начале работы материнские кропсы должны быть высажены на грядку. Дочерние (разводимые) могут быть высажены, а может быть голая земля.
  19. -- У робота должны в обязательном порядке присутстовать компоненты: Geolyzer, Inventory Upgrade, Inventory Controller Upgrade
  20. -- Рекомендуется для удобства поместить файл с этим скриптом в папку /home/ , а имя файла скрипта добавить в файл /home/.shrc - тогда скрипт будет запускаться при включении робота автоматически
  21. -- Если в бочке кончаются кропсы(палки), робот сломает пустые палки, если они есть на поле и завершит свою работу с ошибкой (чтобы всё поле не сожрали сорняки)
  22. -- Максимальные статы кропсов, выше которых робот поднимать статы выводимых кропсов не будет, задаются константами max_grow и max_gain
  23. -- Стат resistans робот не поднимает, а при возможости опускает до 0
  24. -- Начиная с версии 1.1.3 робот перестал быть уязвим к коллизиям. Нахождение игрока на пути следования робота больше не приводит к потере роботом маршрута. Робот после столкновения с игроком замирает на секунду, после чего продолжает попытку движения.
  25. -- Механизм оценки приемлемости (качества) полученного растения менять в функции howInterestingIsThisCrop(с)
  26. -- При наличии интернет карты в роботе, скрипт в робота можно загрузить командой `pastebin get cZY3P7As -f crop_stats.lua`
  27.  
  28. -- mode:
  29. -- 1 - режим поднятия статов кропсов
  30. -- 2 - режим разведения дубликатов кропсов (НЕ ТЕСТИРОВАЛСЯ! НЕ ИСПОЛЬЗОВАТЬ!)
  31. local mode = 1
  32. -- выше заданных здесь значений робот понимать статы не будет
  33. local max_grow = 20 -- если больше 23, то кроп начинает вести себя как сорняк
  34. local max_gain = 28
  35. local grow_kill = 24 -- значение стата grow, при котором и выше которого робот будет убивать растение на корню
  36.  
  37. local robot = require("robot")
  38. local computer = require("computer")
  39. local component = require("component")
  40. local geo = component.geolyzer
  41. local cropname
  42.  
  43. local c_cropname = {} --имена дочерних кропов
  44. --статы дочерних кропов
  45. local c_gain = {}
  46. local c_grow = {}
  47. local c_resistans = {}
  48. local c_size = {}
  49. local c_maxSize = {}
  50.  
  51. -- статус может принимать значения:
  52. -- "unknown" - неисследованный. назначается при старте, дальше не используется
  53. -- "double crop" - жердочки
  54. -- "growing" - растущий кроп, у которого статы или дошли до целевых или лучше материнских. после вырастания или отправится в сундук или может заменить собой материнский кроп
  55. local c_status = {"unknown", "unknown", "unknown", "unknown", "unknown"} -- "unknown" для всех пяти дочерних кропов
  56.  
  57.  
  58. local m_gain = {}
  59. local m_grow = {}
  60. local m_resistans = {}
  61.  
  62. local error_string
  63. local bestSeedsSlot --слот в инвентори робота с семенами с лучшими статами
  64. local robotLocation -- текущее местонаходение робота. значение из списка: {"С1", "С2", ... , "С5", "M1", "M2", "M3", "M4", "P0"}
  65.  
  66.  
  67. function robot_error(msg)
  68.     print("Ошибка: ", msg)
  69.     computer.beep(1000,0.3)
  70.     computer.beep(1000,0.3)
  71.     computer.beep(1000,0.3)
  72.     os.exit()
  73. end
  74.  
  75. function robotTryForward() -- роботы пытается сделать шаг вперед, до тех пор, пока ему это не удастся
  76.     while robot.forward() == nil do
  77.         print("Робот столкнулся с препятствием.")
  78.         os.sleep(1) -- останавливаем робота на 1 секунду
  79.     end
  80. end
  81. --------------------------------------
  82. function get_crop_stat(analyze_result, stat_name) --функция - просматривает таблицу скана блока и возвращает значение поля, имя которого передано в stat_name. если не находит, то возвращает nil
  83.  
  84.     --file = io.open("log.txt", "a") --файл для лога
  85.  
  86.     found = false
  87.     for name, v in pairs(analyze_result) do --просмотрим таблицу реультата анализа кропса
  88.        
  89.         pos = string.find(name, stat_name)
  90.         --print(pos)
  91.         if pos ~=  nil then -- если строку в метадате нашли
  92.             found = true
  93.             --print(v)
  94.             return v
  95.         end
  96.     end
  97.  
  98. end
  99.  
  100. function robotMove_P0_M1()
  101.     --исходное положение P0 смотрит вверх
  102.     robotTryForward()
  103.     robotTryForward()
  104.     robotTryForward()
  105.     --конечное положение M1 смотрит вверх
  106. end
  107. function robotMove_M1_M2()
  108.     --начальное положение M1 смотрит вверх
  109.     robot.turnLeft()
  110.     robotTryForward()
  111.     robot.turnLeft()
  112.     robotTryForward()
  113.     --конечное положение M2 смотрит вниз
  114. end
  115. function robotMove_M2_M3()
  116.     --начальное положение M2 смотрит вниз
  117.     robot.turnLeft()
  118.     robotTryForward()
  119.     robotTryForward()
  120.     --конечное положение M3 смотрит вправо
  121. end
  122. function robotMove_M3_M4()
  123.     --начальное положение M3 смотрит вправо
  124.     robot.turnRight()
  125.     robotTryForward()
  126.     robot.turnRight()
  127.     robotTryForward()
  128.     --конечное положение M4 смотрит влево
  129. end
  130. function robotMove_M4_P0()
  131.     --начальное положение M4 смотрит влево
  132.     robot.turnLeft()
  133.     robotTryForward()
  134.     robot.turnAround()
  135.     --конечное положение P0 смотрит вверх
  136. end
  137. function robotMove_P0_C1()
  138.     --начальное положение P0 смотрит вверх
  139.     robotTryForward()
  140.     robotTryForward()
  141.     robotTryForward()
  142.     robot.turnLeft()
  143.     robotTryForward()
  144.     --конечное положение C1 смотрит влево
  145. end
  146. function robotMove_C1_C4()
  147.     --начальное положение C1 смотрит влево
  148.     robot.turnLeft()
  149.     robotTryForward()
  150.     robotTryForward()
  151.     --конечное положение C4 смотрит вниз
  152. end
  153. function robotMove_C4_C5()
  154.     --начальное положение C4 смотрит вниз
  155.     robot.turnLeft()
  156.     robotTryForward()
  157.     robotTryForward()
  158.     --конечное положение C5 смотрит вправо
  159. end
  160. function robotMove_C5_C2()
  161.     --начальное положение C5 смотрит вправо
  162.     robot.turnLeft()
  163.     robotTryForward()
  164.     robotTryForward()
  165.     --конечное положение C2 смотрит вверх
  166. end
  167. function robotMove_C2_C3()
  168.     --начальное положение C2 смотрит вверх
  169.     robot.turnLeft()
  170.     robotTryForward()
  171.     robot.turnLeft()
  172.     robotTryForward()
  173.     --конечное положение C3 смотрит вниз
  174. end
  175. function robotMove_C3_P0()
  176.     --начальное положение C3 смотрит вниз
  177.     robotTryForward()
  178.     robotTryForward()
  179.     robot.turnAround()
  180.     --конечное положение P0 смотрит вверх
  181. end
  182. function robotGoToParkFrom_M_Crop(m) --едем на парковку. "m" - номер материнского кропа с которого мы едем
  183.     if m == 1 then
  184.         --начальное положение M1 смотрит вверх
  185.         robot.turnAround()
  186.         robotTryForward()
  187.         robotTryForward()
  188.         robotTryForward()
  189.         robot.turnAround()
  190.         --конечное положение P0 смотрит вверх
  191.     end
  192.     if m == 2 then
  193.         --начальное положение M2 смотрит влево
  194.         robot.turnAround()
  195.         robotTryForward()
  196.         robot.turnRight()
  197.         robotTryForward()
  198.         robotTryForward()
  199.         robot.turnAround()
  200.         --конечное положение P0 смотрит вверх
  201.     end
  202.     if m == 3 then
  203.         --начальное положение M3 смотрит вправо
  204.         robot.turnAround()
  205.         robotTryForward()
  206.         robot.turnLeft()
  207.         robotTryForward()
  208.         robotTryForward()
  209.         robot.turnAround()
  210.         --конечное положение P0 смотрит вверх
  211.     end
  212.     if m == 4 then
  213.         --начальное положение M4 смотрит влево
  214.         robot.turnLeft()
  215.         robotTryForward()
  216.         robot.turnAround()
  217.         --конечное положение P0 смотрит вверх 
  218.     end
  219. end
  220. function robotGoToPark(c) --едем на парковку. "с" - номер дочернего кропа с которого мы едем
  221.     if c == 1 then
  222.         --начальное положение C1 смотрит влево
  223.         robot.turnAround()
  224.         robotTryForward()
  225.         robot.turnRight()
  226.         robotTryForward()
  227.         robotTryForward()
  228.         robotTryForward()
  229.         robot.turnAround()
  230.         --конечное положение P0 смотрим вверх
  231.     end
  232.     if c == 2 then
  233.         --начальное положение C2 смотрит вверх
  234.         robot.turnLeft()
  235.         robotTryForward()
  236.         robot.turnLeft()
  237.         robotTryForward()
  238.         robotTryForward()
  239.         robotTryForward()
  240.         robot.turnAround()
  241.         --конечное положение P0 смотрим вверх
  242.     end
  243.     if c == 3 then
  244.         --начальное положение C3 смотрит вниз
  245.         robotTryForward()
  246.         robotTryForward()
  247.         robot.turnAround()
  248.         --конечное положение P0 смотрим вверх
  249.     end
  250.     if c == 4 then
  251.         --начальное положение C4 смотрит вниз
  252.         robot.turnLeft()
  253.         robotTryForward()
  254.         robot.turnRight()
  255.         robotTryForward()
  256.         robot.turnAround()
  257.         --конечное положение P0 смотрим вверх
  258.     end
  259.     if c == 5 then
  260.         --начальное положение C5 смотрит вправо
  261.         robot.turnAround()
  262.         robotTryForward()
  263.         robot.turnLeft()
  264.         robotTryForward()
  265.         robot.turnAround()
  266.         --конечное положение P0 смотрим вверх
  267.     end
  268.  
  269. end
  270. function robotGoTo_M_Crop_FromPark(m) --едем с парковки P0 к материнскому кропу. "m" - номер кропа к которому мы едем
  271.     if m==1 then
  272.         --исходное положение P0 смотрит вверх
  273.         robotTryForward()
  274.         robotTryForward()
  275.         robotTryForward()
  276.         --конечное положение M1 смотрит вверх
  277.     end
  278.     if m==2 then
  279.         --начальное положение P0 смотрит вверх
  280.         robotTryForward()
  281.         robotTryForward()
  282.         robot.turnLeft()
  283.         robotTryForward()
  284.         --конечное положение M2 смотрит влево
  285.     end
  286.     if m==3 then
  287.         --начальное положение P0 смотрит вверх
  288.         robotTryForward()
  289.         robotTryForward()
  290.         robot.turnRight()
  291.         robotTryForward()
  292.         --конечное положение M3 смотрит вправо
  293.     end
  294.     if m==4 then
  295.         --начальное положение P0 смотрит вверх
  296.         robotTryForward()
  297.         robot.turnLeft()       
  298.         --конечное положение M4 смотрит влево
  299.     end
  300. end
  301. function robotGoTo_C_Crop_FromPark(c) --едем с парковки P0 к дочернему кропу. "с" - номер кропа к которому мы едем
  302.     if c == 1 then
  303.         --начальное положение P0 смотрим вверх
  304.         robotTryForward()
  305.         robotTryForward()
  306.         robotTryForward()
  307.         robot.turnLeft()
  308.         robotTryForward()
  309.         --конечное положение C1 смотрит влево
  310.     end
  311.     if c == 2 then
  312.         --начальное положение P0 смотрим вверх
  313.         robotTryForward()
  314.         robotTryForward()
  315.         robotTryForward()
  316.         robot.turnRight()
  317.         robotTryForward()
  318.         robot.turnLeft()
  319.         --конечное положение C2 смотрит вверх
  320.     end
  321.     if c == 3 then
  322.         --начальное положение P0 смотрим вверх
  323.         robotTryForward()
  324.         robotTryForward()
  325.         robot.turnAround()
  326.         --конечное положение C3 смотрит вниз
  327.     end
  328.     if c == 4 then
  329.         --начальное положение P0 смотрим вверх
  330.         robotTryForward()
  331.         robot.turnLeft()
  332.         robotTryForward()
  333.         robot.turnLeft()
  334.         --конечное положение C4 смотрит вниз
  335.     end
  336.     if c == 5 then
  337.         --начальное положение P0 смотрим вверх
  338.         robotTryForward()
  339.         robot.turnRight()
  340.         robotTryForward()
  341.         --конечное положение C5 смотрит вправо
  342.     end
  343.  
  344. end
  345. function grabCropsFromBarrel() --пополняем запас палок в роботе из бочки.
  346.     --возвращает true если после попытки взять палки, есть хотя бы одна палка в роботе
  347.     --возвращает false если палки в роботе и в бочке кончились
  348.     cropsStackSize = 62 --размер стака палок, который робот возит с собой. 62 потому что при уничтожения кропса робот выдерает из земли и палки, и они могут попасть в нецелевой слот
  349.    
  350.     --палки лежат в первом слоте
  351.     returnValue = true
  352.     itemCount = robot.count(1)
  353.     if itemCount < cropsStackSize then --если палок неполный стак, до доберем из бочки
  354.         robot.select(1) --активизируем слот, в котором лежат палки
  355.         robot.turnRight() --повернемся к бочке
  356.         --добираем палок до полного стака
  357.         robot.suck(cropsStackSize-itemCount)
  358.         itemCount = robot.count(1) --смотрим сколько палок в роботе
  359.         if itemCount == 0 then --если палки в роботе кончились
  360.             returnValue = false --возвращаем признак, что ПАЛКИ В РОБОТЕ И БОЧКЕ КОНЧИЛИСЬ
  361.         elseif itemCount < cropsStackSize then --если после попытки взять палки из бочки, мы имеем меньше стака палок в роботе
  362.             print("В бочке закончились палки!")
  363.             computer.beep(1000,1)
  364.             returnValue = true
  365.         else
  366.             returnValue = true
  367.         end
  368.         robot.turnLeft() --повернемся обратно к кропсам
  369.     end
  370.     return returnValue
  371. end
  372. function dropToChest() --все что есть в инвентори, скидываем в сундук
  373.     --начальная позиция - P0 смотрим вверх
  374.     robot.turnLeft()
  375.     for i=2,16 do
  376.         item = component.inventory_controller.getStackInInternalSlot(i)
  377.         if item then --если в слоте что-то есть
  378.             robot.select(i)
  379.             robot.drop() --сдаем все из текущего слота в сундук
  380.         end
  381.     end
  382.     robot.turnRight() --поворачиваемся к с0
  383.     robot.select(1)
  384. end
  385. function destroyAllDoubleCrops() --уничтожим все двойные кропсы
  386.     --пройдемся по массиву статусов кропсов и у всех кропсов, у которых статус = "жердочки", съездим к ним и сломаем их
  387.     for c=1,5 do
  388.         if c_status[c] == "double crop" then
  389.             robotGoTo_C_Crop_FromPark(c)
  390.             robot.swingDown() --ломаем кропсы
  391.             robotGoToPark(c)
  392.         end
  393.     end
  394.    
  395. end
  396. function howInterestingIsThisCrop(c) --оценивает полезность нового растения сравнивая статы дочернего ростения [с] со статами материнский растений . тип растения во внимание не принимается
  397. --возвращает: 0 - негодное
  398. --            -1 - годно для сохранения
  399. --            m - превосходит материнское, где 1<m<4 - номер материнского кропа, который нужно заменить новым растением
  400.  
  401.     if c_grow[c] >= grow_kill then --если grow у дочернего растения достигло опасного значения, то это растение считаем негодным
  402.         return 0
  403.     end
  404.    
  405.     --если статы нового растения больше максимально разрешенных
  406.     if (c_gain[c] > max_gain) or (c_grow[c] > max_grow) then
  407.         --то считаем это растение приемлемым
  408.         print("Полученое растение, превышает максимальные статы.")
  409.         return -1
  410.     end
  411.  
  412.     --сравним статы нового растения со статами материнских растений
  413.     maxDifference = 0 --самая лучшая разница в качестве
  414.     m_crop_maxDifference = 0 --материнский кроп с самой лучшей разницей в качестве
  415.     for m = 1, 4 do
  416.         --сравниваем статы полученного растения со статами материнских растений
  417.         difference = (c_gain[c] + c_grow[c] - c_resistans[c]) - (m_gain[m] + m_grow[m] - m_resistans[m])
  418.         if (difference > 0) and (difference > maxDifference) then --если растение лучше и это лучшая разница в качестве
  419.             maxDifference = difference --обновим лучшую разницу в качестве
  420.             m_crop_maxDifference = m --материнский кроп с самой лучшей разницей в качестве
  421.         end
  422.     end
  423.     if maxDifference>0 then
  424.         --полученное растение лучше чем одно из материнских, а значит нужно пересадить (на самый слабый материнский кроп)
  425.         return m_crop_maxDifference --возвращаем материнский кроп с самой лучшей разницей в качестве
  426.     end
  427.    
  428.     --если мы здесь, значит новое растение не привысило максимальные статы и не лучше чем материнские растения
  429.     --а занчит   РАСТЕНИЕ ПЛОХОЕ
  430.     return 0
  431.  
  432. end
  433. function placeDoubleCrops() --ставит новые палки
  434.     component.inventory_controller.equip() --экипируем кропсы(палки)
  435.     robot.useDown() --ставим палку на землю
  436.     robot.useDown() --ставим палку (получаются жердочки для скрещивания)
  437.     component.inventory_controller.equip() --возвращаем в руки лопатку
  438. end
  439. function findSeedsInRobotInventory() --возвращает номер слота в инвентори робота с семечками, если нет семечек, то возвращает 0, а если вообще ничего нет, то возвращает -1
  440.     foundAnything = false
  441.     for i=2,16 do
  442.         item = component.inventory_controller.getStackInInternalSlot(i)
  443.         if item then --если в слоте что-то есть
  444.             foundAnything = true
  445.             if item.name == "IC2:itemCropSeed" then --если в слоте семена
  446.                 return i --возвращаем номер слота, в котором семена
  447.             end
  448.         end
  449.     end
  450.     if foundAnything then --если что-то нашли (обычно это урожай), но семян не было
  451.         return 0
  452.     end
  453.     return -1 --вообще ничего нет
  454. end
  455. function analizeAndProceed(c) --функция анализа и обработки кропа. с - номер кропа.
  456.  
  457.    
  458.     analyze_result = geo.analyze(0) --анализируем блок под роботом
  459.     c_cropname[c] = get_crop_stat(analyze_result, "crop:name")
  460.     if c_cropname[c] ~= nil then -- если перед нами что-то вывелось, а не пустые палки
  461.        
  462.        
  463.         --получаем остальные статы кропа
  464.         c_gain[c] = get_crop_stat(analyze_result, "crop:gain")
  465.         c_grow[c] = get_crop_stat(analyze_result, "crop:grow")
  466.         c_resistans[c] = get_crop_stat(analyze_result, "crop:resistance")
  467.         c_size[c] = get_crop_stat(analyze_result, "crop:size")
  468.         c_maxSize[c] = get_crop_stat(analyze_result, "crop:maxSize")
  469.  
  470.         if c_status[c] == "double crop" or c_status[c] == "unknown" then  --если статус растения был двойные палки, значит появилось новое растение
  471.             print("Новый кроп С"..c..": "..c_cropname[c].."  "..c_grow[c].."  "..c_gain[c].."  "..c_resistans[c]) -- "Новый кроп С1:    reed"
  472.             --print(c_grow[c], c_gain[c], c_resistans[c], "size: "..c_size[c].."/"..c_maxSize[c]) --"23   31   0   size: 2/3"
  473.         end
  474.        
  475.         --если прокнуло растение другого вида, выкапываем его лопаткой и отвозим в сундук
  476.         if c_cropname[c] ~= cropname then
  477.             robot.useDown()--по умолчанию у нас в руках лопатка, юзаем ее
  478.             component.inventory_controller.equip() --экипируем кропсы(палки)
  479.             robot.useDown() --ставим палку (получаются жердочки для скрещивания)
  480.             component.inventory_controller.equip() --возвращаем в руки лопатку
  481.             c_status[c] = "double crop" --устанавливаем статус растения - жердочки
  482.            
  483.             --после копки проверим инвентори робота
  484.             foundAnything = false
  485.             for i=2,16 do
  486.                 item = component.inventory_controller.getStackInInternalSlot(i)
  487.                 if item then --если в слоте что-то есть
  488.                     foundAnything = true
  489.                 end
  490.             end
  491.            
  492.             if foundAnything or robot.count(1) == 0 then --если что-то выкопалось от этого непрофильного растения или закончились палки
  493.                 robotGoToPark(c) --едем на парковку  
  494.                 if foundAnything then --если есть в инветори что-то выкопанное, сдаем в сундук
  495.                     dropToChest()
  496.                 end
  497.                 --пополняем запас палок в роботе
  498.                 if grabCropsFromBarrel() then
  499.                 else --если палки кончились
  500.                     destroyAllDoubleCrops() --уничтожим все двойные кропсы
  501.                     robot_error("ПАЛКИ КОНЧИЛИСЬ!") --заканчиваем работу с ошибкой
  502.                 end
  503.                 robotGoTo_C_Crop_FromPark(c)
  504.             end
  505.         else--если растение нужного типа
  506.             if c_status[c] == "double crop" or c_status[c] == "unknown" then  --если статус растения был двойные палки, значит появилось новое растение
  507.                 --оценим полезность нового растения
  508.                 interest = howInterestingIsThisCrop(c)
  509.                
  510.                 --выведем инфу о новом кропе
  511.                 interestString = ""
  512.                 if interest == 0 then
  513.                     interestString = "негодное"
  514.                 elseif interest == -1 then
  515.                     interestString = "годное, статы дошли до целевых"
  516.                 else
  517.                     interestString = "превосходит материнское М"..interest
  518.                 end
  519.                 print("Полезность:"..interestString)
  520.                
  521.                 if interest == 0 then -- растение с плохими статами
  522.                     --уничтожаем растение
  523.                     robot.swingDown() --ломаем кропсы
  524.                     placeDoubleCrops() --ставим новые палки
  525.                     c_status[c] = "double crop" --устанавливаем статус растения - жердочки
  526.                     --посмотрим, попали ли семечки в инвентори
  527.                     seedSlot = findSeedsInRobotInventory() --находим слот с семечками
  528.                     if seedSlot > 0 then --если семечки есть
  529.                         --отвезем эти семечки домой
  530.                         robotGoToPark(c) --едем на парковку
  531.                         dropToChest() --сбрасываем всё в сундук
  532.                         grabCropsFromBarrel() --добираем палок из бочки
  533.                         robotGoTo_C_Crop_FromPark(c) --возвращаемся на кроп
  534.                     end
  535.                 else --растение со статами превышающими материнские или статы дошли до целевых
  536.                     c_status[c] = "growing" --устанавливаем статус растущего кропа
  537.                     --оставляем его в покое, пусть растет
  538.                 end
  539.            
  540.             else -- c_status[c] == "growing" --растение уже ранее сканировалось
  541.                
  542.                 if c_size[c] == c_maxSize[c] then --если растение доросло
  543.                     robot.swingDown() --ломаем кропсы, собираем урожай
  544.                     placeDoubleCrops() --ставим новые палки
  545.                     c_status[c] = "double crop" --устанавливаем статус растения - жердочки
  546.                    
  547.                     --посмотрим, попали ли семечки в инвентори
  548.                     seedSlot = findSeedsInRobotInventory() --находим слот с семечками
  549.                     if seedSlot > 0 then --если семечки есть
  550.                         --делаем повторную оценку полезности
  551.                         interest = howInterestingIsThisCrop(c)
  552.                         if interest == -1 then --годное, статы дошли до целевых
  553.                             --везем в сундук
  554.                             robotGoToPark(c) --едем на парковку
  555.                             dropToChest() --сбрасываем всё в сундук
  556.                             grabCropsFromBarrel() --добираем палок из бочки
  557.                             robotGoTo_C_Crop_FromPark(c) --возвращаемся на кроп
  558.                            
  559.                         elseif interest > 0 then --превосходит материнское
  560.                             --меняем материнское ростение на текущее дочернее
  561.                             print("Заменяем кроп М"..interest..":  "..m_grow[interest].."  "..m_gain[interest].."  "..m_resistans[interest].." -> "..c_grow[c].."  "..c_gain[c].."  "..c_resistans[c])
  562.                             --обновляем статы материнского растения
  563.                             m_grow[interest] = c_grow[c]
  564.                             m_gain[interest] = c_gain[c]
  565.                             m_resistans[interest] = c_resistans[c]
  566.                             --едем менять материнское растение
  567.                             robotGoToPark(c) --едем через паркинг. прямых маршрутов от С до M робот не знает
  568.                             robotGoTo_M_Crop_FromPark(interest) --едем на материнский кропс, который будем менять
  569.                             robot.swingDown() --ломаем кропсы, собираем урожай
  570.                             component.inventory_controller.equip() --экипируем кропсы(палки)
  571.                             robot.useDown() --ставим палку на землю
  572.                             component.inventory_controller.equip() --возвращаем в руки лопатку
  573.                             robot.select(seedSlot) --делаем активным слот с семенами, которые мы собираемся сажать
  574.                             component.inventory_controller.equip() -- берем семена в руки
  575.                             robot.useDown() --сажаем
  576.                             component.inventory_controller.equip() -- берем обратно лопатку в руки
  577.                             robot.select(1)
  578.                             robotGoToParkFrom_M_Crop(interest) --едем на паркинг
  579.                             dropToChest() --сбрасываем всё в сундук
  580.                             grabCropsFromBarrel() --добираем палок из бочки
  581.                             robotGoTo_C_Crop_FromPark(c) --возвращаемся на кроп
  582.                         end
  583.                     end
  584.                    
  585.                    
  586.                 end
  587.             end
  588.        
  589.        
  590.         end
  591.        
  592.        
  593.            
  594.        
  595.        
  596.  
  597.    
  598.     else -- если перед нами или пустые палки или воздух
  599.         if c_status[c] == "unknown" then -- если мы сканируем этот кроп впервые
  600.             if get_crop_stat(analyze_result, "name") == "IC2:blockCrop" then --если перед нами двойные палки
  601.                 c_status[c] = "double crop"
  602.             else --перед нами не растение и не двойные палки. значит перед нами воздух
  603.                 --ставим палки
  604.                 component.inventory_controller.equip() --экипируем кропсы(палки)
  605.                 robot.useDown() --ставим палку на землю
  606.                 robot.useDown() --ставим палку (получаются жердочки для скрещивания)
  607.                 component.inventory_controller.equip() --возвращаем в руки лопатку
  608.                 c_status[c] = "double crop" --устанавливаем статус растения - жердочки
  609.             end
  610.            
  611.         end
  612.        
  613.     end
  614.  
  615. end
  616.  
  617.  
  618.  
  619. ----------------------------------------------------
  620. --Шаг 1
  621. --Начинаем работать
  622. print("--------------------------------------"); --выводим приветствие
  623. print("Скрипт для робота, для поднятия статов у кропсов или разведения дубликатов запущен.");
  624. print("Версия: "..ver)
  625. if mode == 1 then -- 1 - режим поднятия статов кропсов
  626.     print("Выбран режим поднятия статов кропсов.");
  627. else -- 2 - режим разведения дубликатов кропсов
  628.     print("Выбран режим разведения дубликатов кропсов.");
  629. end
  630. print("Шаг 1. Проверка входящих условий.");
  631.  
  632. -- проверяем правильность входящий условий
  633.  
  634. --В руках должна быть лопатка
  635. robot.select(1) --выбираем первый слот инвентори, на случай если при начале работы был выбран другой слот
  636. component.inventory_controller.equip() --убираем лопатку к себе в инвентори и смотрим, лопатка ли это?
  637. item = component.inventory_controller.getStackInInternalSlot(1)
  638. if item == nil then --если в слоте ничего нет
  639.     robot_error("Нет лопатки в слоте для инструмента!")
  640. end
  641. if item.name ~= "berriespp:itemSpade" then --если в слоте что-то есть, но это не лопатка
  642.     robot_error("Нет лопатки в слоте для инструмента!")
  643. end
  644. component.inventory_controller.equip() --лопатку возвращаем в слот для инструмента
  645.  
  646. --print("Входящие условия соблюдены.")
  647.  
  648. ----------------------------------------------------
  649. --Шаг 2
  650. if mode == 1 then -- 1 - режим поднятия статов кропсов
  651.     print("Шаг 2. Сканируем материнские кропсы и запоминаем их статы.")
  652.  
  653.     --Сканируем материнские кропсы и запоминаем их статы
  654.     --Исходная позиция - робот стоит на P0
  655.  
  656.     -- кроп M1
  657.     robotMove_P0_M1()
  658.     analyze_result = geo.analyze(0)
  659.     cropname = get_crop_stat(analyze_result, "crop:name")
  660.     m_gain[1] = get_crop_stat(analyze_result, "crop:gain")
  661.     m_grow[1] = get_crop_stat(analyze_result, "crop:grow")
  662.     m_resistans[1] = get_crop_stat(analyze_result, "crop:resistance")
  663.     print("M1:", cropname, m_grow[1], m_gain[1], m_resistans[1])
  664.  
  665.     -- кроп M2
  666.     robotMove_M1_M2()
  667.     analyze_result = geo.analyze(0)
  668.     cropname = get_crop_stat(analyze_result, "crop:name")
  669.     m_gain[2] = get_crop_stat(analyze_result, "crop:gain")
  670.     m_grow[2] = get_crop_stat(analyze_result, "crop:grow")
  671.     m_resistans[2] = get_crop_stat(analyze_result, "crop:resistance")
  672.     print("M2:", cropname, m_grow[2], m_gain[2], m_resistans[2])
  673.    
  674.     -- кроп M3
  675.     robotMove_M2_M3()
  676.     analyze_result = geo.analyze(0)
  677.     cropname = get_crop_stat(analyze_result, "crop:name")
  678.     m_gain[3] = get_crop_stat(analyze_result, "crop:gain")
  679.     m_grow[3] = get_crop_stat(analyze_result, "crop:grow")
  680.     m_resistans[3] = get_crop_stat(analyze_result, "crop:resistance")
  681.     print("M3:", cropname, m_grow[3], m_gain[3], m_resistans[3])
  682.  
  683.     -- кроп M4
  684.     robotMove_M3_M4()
  685.     analyze_result = geo.analyze(0)
  686.     cropname = get_crop_stat(analyze_result, "crop:name")
  687.     m_gain[4] = get_crop_stat(analyze_result, "crop:gain")
  688.     m_grow[4] = get_crop_stat(analyze_result, "crop:grow")
  689.     m_resistans[4] = get_crop_stat(analyze_result, "crop:resistance")
  690.     print("M4:", cropname, m_grow[4], m_gain[4], m_resistans[4])
  691.  
  692.    
  693.     robotMove_M4_P0() --возвращаем робота в исходное положение
  694.  
  695. end
  696. ----------------------------------------------------
  697. --Шаг 3
  698. if mode == 1 then -- 1 - режим поднятия статов кропсов
  699.     print("Шаг 3. Приступаем к поднятию статов.");
  700. else -- 2 - режим разведения дубликатов кропсов
  701.     print("Шаг 2. Приступаем к разведению дубликатов кропсов.");
  702. end
  703.  
  704. while true do --главный цикл
  705.    
  706.     --пополняем запас палок в роботе
  707.     if grabCropsFromBarrel() then
  708.     else --если палки кончились
  709.         destroyAllDoubleCrops() --уничтожим все двойные кропсы
  710.         robot_error("ПАЛКИ КОНЧИЛИСЬ!")
  711.     end
  712.    
  713.     --едем сканить дочерние кропсы
  714.     robotMove_P0_C1()
  715.     analizeAndProceed(1)
  716.     robotMove_C1_C4()
  717.     analizeAndProceed(4)
  718.     robotMove_C4_C5()
  719.     analizeAndProceed(5)
  720.     robotMove_C5_C2()
  721.     analizeAndProceed(2)
  722.     robotMove_C2_C3()
  723.     analizeAndProceed(3)
  724.     robotMove_C3_P0() --конечное положение P0 смотрим вверх
  725.    
  726.     --os.exit()
  727.    
  728.  
  729.     os.sleep(15)
  730. end
  731.  
  732. os.exit()
  733.  
  734. --История версий:
  735.  
  736. --Версия 1.1.3
  737. --Устранена уязвимость к коллизиям. Нахождение игрока на пути следования робота больше не приводит к потере роботом маршрута. Робот после столкновения с игроком замирает на секунду, после чего продолжает попытку движения
  738. --Добавлена история версий в файл скрипта робота
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement