Перейти к публикации

Правка постпроцессора


Насибулла

Рекомендованные сообщения

Здравствуйте!

Прошу помощи с правкой постпроцессора под синумерик 828д. Станок фрезерный трехкоординатный.

При сверлении отверстий пост выдает цикл на каждое отверстие. Мне нужно, чтобы выводился один цикл с MCALL. Плюс нужно, чтобы всегда выводились координаты по двум осям (X Y)

 

Сейчас получается так

;centr sverlo
N10 T9
N20 M6
N30 G17 G54
N40 S3000 M3
N50 G0 X-56 Y-32 Z10
N60 M8 F150
N70 CYCLE81(10,0,1,-2)
N80 G0 X-72
N90 CYCLE81(10,0,1,-2)
N100 G0 Y32
N110 CYCLE81(10,0,1,-2)
N120 G0 X-56
N130 CYCLE81(10,0,1,-2)
N140 G0 X-40
N150 CYCLE81(10,0,1,-2)
N160 G0 M5 M9

N170 M30

 

Как должно быть

;centr sverlo
N10 T9
N20 M6
N30 G17 G54
N40 S3000 M3
N50 G0 X-56 Y-32 Z10
N60 M8 F150
N70 MCALL CYCLE81(10,0,1,-2)

N75 G0 X-56 Y-32 ; координаты Х и У дублируются из кадра N50
N80 G0 X-72 Y-32
N100 G0 X-72 Y32
N120 G0 X-56 Y32
N140 G0 X-40 Y32

MCALL
N160 G0 M5 M9

N170 M30

 

 

насколько я понимаю править нужно ExtCycle

Сейчас там вот что

program ExtCycle  
  !Prms: array of Real  ! Cycle parameters
  i: Integer
  CycleNumber: Integer ! Cycle number
  CycleName: String    ! Cycle name
  CycleGeomName: String ! Имя подпрограммы-геометрии цикла
  CDIR: Integer        ! Thread direction 2-G2, 3-G3
  SDIR: Real           ! Spindle rotation direction
  CurPos: Real         ! Current position (applicate)
  CPA: Real            ! Absciss
  CPO: Real            ! Ordinate
  TempCoord: Real      ! Auxiliary variable
  RTP: Real
  RFP: Real
  SDIS: Real
  DP: Real
  DPR: Real

  if cld.SubCmd=71 then begin
    CycleOn = 1      ! ON
    if CLD[9]=1 then
      GFeed=94
    else
      GFeed=95
    Feed_=CLD[10]!; Feed_@=MaxReal
    outblock
  end
  else if cld.SubCmd=72 then CycleOn = 0 ! OFF
  else if cld.SubCmd=52 then begin ! CALL
    call CheckAxesBrake(2, 2, 2)

    for i = 1 to 30 do Prms[i] = MaxReal
    CycleNumber = 0
    CycleName = "CYCLE"
    CycleGeomName = ""
    case cld.SubType of
      473,481,482,
      483,484,485,
      486,487,488,
      489,490,491: begin ! 5D Drilling cycles
        ! Define current position
        case abs(GPlane) of
          17: begin ! XY
            CurPos = Z
            CPA = X
            CPO = Y
          end
          18: begin ! ZX
            CurPos = Y
            CPA = Z
            CPO = X
          end
          19: begin ! YZ
            CurPos = X
            CPA = Y
            CPO = Z
          end
          else begin
            print "Undefined cycle plane"
            CurPos = Z
            CPA = X
            CPO = Y
          end
        end
        if GPlane<0 then begin
          TempCoord = CPA
          CPA = CPO
          CPO = TempCoord
        end
        ! Define base levels
        RTP = CurPos
        RFP = CurPos - cld[7]*sgn(GPlane) ! CurPos - Tp
        SDIS = cld[7] - cld[6] ! Tp - Sf
        DP = CurPos - cld[8]*sgn(GPlane) ! CurPos - Bt
        DPR = cld[8] - cld[7] ! Bt - Tp
        ! CycleXX(RTP,RFP,SDIS,DP)
        Prms[1] = RTP
        Prms[2] = RFP
        Prms[3] = SDIS
        Prms[4] = DP
        CycleNumber = 81
        case cld.SubType of
          481,482,485,486,487,488,489: begin ! Simple drilling
            CycleNumber = cld.SubType - 400
            if cld[15]>0 then Prms[6] = cld[15] ! Delay in seconds
            ! Spindle rotation direction
            if S>0 then SDIR = 3
                   else SDIR = 4
            if (cld.SubType=486) or (cld.SubType=488) then
              Prms[7] = SDIR
            else if cld.SubType=487 then
              Prms[6] = SDIR
            if cld.SubType=485 then begin
              Prms[7] = cld[10] ! WorkFeed
              Prms[8] = cld[14] ! ReturnFeed
            end else if cld.SubType=486 then begin
              Prms[8] = 0 ! RPA
              Prms[9] = 0 ! RPO
              Prms[10] = 0 ! RPAP
              Prms[11] = 0 ! POSS
            end
          end
          473,483: begin ! Deep drilling (473-chip breaking, 483-chip removing)
            CycleNumber = 83
            Prms[6] = CurPos - (cld[7]+cld[17])*sgn(GPlane) ! FDEP = CurPos-(Tp+St)
            Prms[8] = cld[18] ! DAM - degression
            Prms[9] = cld[15] ! DTB - Bottom delay
            Prms[10] = cld[16] ! DTS - Top delay
            Prms[11] = 1 ! FRF - First feed coef
            if cld.SubType=473 then Prms[12] = 0 ! VARI - breaking or removing
                               else Prms[12] = 1
            Prms[14] = CLD[18] ! _MDEP - Minimal deep step (=degression)
            if cld.SubType=473 then
              Prms[15] = cld[20] ! _VRT - LeadOut
            else
              Prms[17] = cld[19] ! _DIS1 - Deceleration
            Prms[16] = 0 ! _DTD - finish delay (if 0 then = DTB)
          end
          484: begin ! Tapping
            if S>0 then SDIR = 3
                   else SDIR = 4
            if cld[19]=1 then begin ! Fixed socket
              CycleNumber = 84
              Prms[7] = SDIR ! SDAC
              if S>0 then Prms[9] = cld[17] ! PIT
                     else Prms[9] = -cld[17]
              Prms[10] = cld[18] ! POSS
              Prms[14] = 1 !  PTAB
            end else begin  ! Floating socket
              CycleNumber = 840
              Prms[7] = 0 ! SDR
              Prms[8] = SDIR ! SDAC
              Prms[9] = 11 ! ENC
              if S>0 then Prms[11] = cld[17] ! PIT
                     else Prms[11] = -cld[17]
              Prms[13] = 1
            end
            if IsFirstCycle>0 then begin
              VARI = 0
              DAM = cld[2]/5
              VRT = DAM/5
              Input "Введите параметры цикла нарезания резьбы CYCLE84:",
                    "Подтип цикла VARI (0-простое, 1-ломка стружки, 2-удаление стружки)", VARI,
                    "Шаг для ломки стружки (DAM)", DAM,
                    "Отвод при ломке стружки (VRT)", VRT
            end
            if VARI>0 then begin
              Prms[16] = VARI  !VARI
              Prms[17] = DAM  !DAM
              Prms[18] = VRT  !VRT
            end
          end
          490: begin ! Thread milling
            CycleNumber = 90
            Prms[6] = cld[16] ! DIATH - Outer diameter
            Prms[7] = cld[16] - cld[22]*2 ! KDIAM - Inner diameter
            Prms[8] = cld[17] ! PIT - thread step
            Prms[9] = cld[10] ! FFR - Work feed
            CDIR = cld[19] ! CDIR - Spiral direction
            if (CDIR<>2) and (CDIR<>3) then begin
              if (S>0) and (CDIR=0) then       CDIR = 3
              else if (S<=0) and (CDIR=0) then CDIR = 2
              else if (S>0) and (CDIR=1) then  CDIR = 2
              else if (S<=0) and (CDIR=1) then CDIR = 3
            end
            Prms[10] = CDIR
            Prms[11] = cld[18] ! TYPTH - 0-inner, 1-outer thread
            Prms[12] = CPA ! CPA - Center X
            Prms[13] = CPO ! CPO - Center Y
          end
          491: begin ! Hole pocketing
            CycleNumber = 4
            CycleName = "POCKET"
            Prms[5] = 0.5*CLD[16] ! PRAD - Radius
            Prms[6] = CPA ! PA - Center X
            Prms[7] = CPO ! PO - Center Y
            Prms[8] = cld[20] ! MID - Deep step
            Prms[9] = 0 ! FAL - finish wall stock
            Prms[10] = 0 ! FALD - finish deep stock
            Prms[11] = cld[10] ! FFP1 - Work feed
            Prms[12] = cld[12] ! FFD - Plunge feed
            CDIR = cld[19]
            if CDIR<=1 then CDIR = 1 - CDIR
            Prms[13] = CDIR ! CDIR - Spiral direction
            Prms[14] = 21 ! VARI - Rough spiral machining
            Prms[15] = cld[22] ! MIDA - Horizontal step
            Prms[18] = 0.5*cld[18] ! RAD1 - Spiral radius
            Prms[19] = cld[17] ! DP1 - Spiral step
          end
        end
      end ! 5D Drilling cycles
    end ! case cld.SubType
    if CycleNumber>0 then begin
      OutBlock
      call OutCycle(CycleName+Str(CycleNumber), CycleGeomName)
      Interp_@ = MaxReal
      IsFirstCycle = 0
    end
  end ! if CALL
end

 

Смотрел видео по основам создания постпроцессоров, какое то представление появилось, как это работает. С программированием на Вы, и код выше для меня абракадабра. Но если долго сидеть, вникать, разобраться смогу. Но как обычно столько времени нет. Поэтому кому не сложно, подскажите как лучше сделать. 

 

Ссылка на сообщение
Поделиться на других сайтах


Присоединяйтесь к обсуждению

Вы можете опубликовать сообщение сейчас, а зарегистрироваться позже. Если у вас есть аккаунт, войдите в него для написания от своего имени.
Примечание: вашему сообщению потребуется утверждение модератора, прежде чем оно станет доступным.

Гость
Ответить в тему...

×   Вставлено в виде отформатированного текста.   Вставить в виде обычного текста

  Разрешено не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отобразить как ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

  • Сейчас на странице   0 пользователей

    Нет пользователей, просматривающих эту страницу.




  • Сообщения

    • alek77
      Да, спасибо, я уже из интереса ее нашел. Еще раз повторю, чтобы не выхватить, сам я такими методами указния размеров не пользуюсь, это самая вредная практика из всех, что встречал. В свое время имел много проблем в автокаде, корректируя чужие чертежи. Но там и отртогональные линии под углом в 0,001 градуса были в норме, и миллион линий одна поверх другой, и незамкнутые отрезки и много всего, от чего волосы дыбом. В солиде, думал, не столкнусь с таким, наивный. Поэтому искал и нашел макрос который косяки размеров подсвечивает. Он вполне рабочий, но не стабильный. В чем причина не разбирался, так как со своей задачей он справляется. Причем отрабатывает и галочки, и замену текста в размере. Хорошо, что @malvi.dp нашел время и что-то корректирует, спасибо отдельное ему за это. Макрос достаточно полезный при работе с чужими документами. И если удастся сохранить все начальные функции этого макроса против изощренных методов вредительства - будет офигенно.
    • Kelny
      Если этой ссылки достаточно для отображения материала и материал уже есть в обозначенной модели, то возможно подойдёт TabBuilder: https://help.solidworks.com/2023/russian/SolidWorks/SWHelp_List.html?id=e68c1877b4fa431483f8c751bd9fcc78&_gl=1*lby1j3*_up*MQ..*_ga*NTEyNjA5NDQ3LjE3MTQxMTU3MzA.*_ga_XQJPQWHZHH*MTcxNDExNTcyOS4xLjEuMTcxNDExNTczNy4wLjAuMA..#Pg0   В старых версиях при написанни ссылок такого радо в некоторых случаях можно было не писать имя файла, а достаточно было вместо имени файла модели оставить ПРОБЕЛ.SLDPRT и имя после этого подставлялось само. Пробовать надо.   Так же можете глянуть макрос по изменению свойств файла (методы и функции там устаревшие, но возможно даже будет работать и можно поковыряться в коде): https://kelnyproject.ucoz.ru/load/6-1-0-8 по програмированию так же есть справка (версию в ссылке поменяйте на свою, что бы справка была актуальна для вашей версии): https://help.solidworks.com/SearchEx.aspx?query=get custom property&version=2010&lang=english,enu&prod=api
    • gudstartup
      только перед обновлением обязательно выполните  все что написано в руководстве и касается сохранения состояния станка и чпу. и обязательно сделайте образ диска и помните что слишком новые версии могут не заработать на вашем чпу относительно безопасно ставить только сервиспаки
    • NordCom
      Большое спасибо! Через это меню удалось зайти в меню. 95148->MOD
    • Danil89nur
      Доброе время суток. Столкнулся с проблемой на новой работе. Много деталей у который в свойствах отсутствует раздел "Материал" и приходится каждый раз вручную заходить туда, создавать раздел и выбирать там ""SW-Material@Name.SLDPRT". Возможно кто-то знает, либо сможет помочь с написанием простенького макроса, при нажатии на который в свойствах детали будет создаваться необходимый раздел и в нем сразу написан выбранный материал (желательно, чтоб там было указано сразу наименование материала, а не формула для его получения ""SW-Material@Name.SLDPRT"). Пытался самостоятельно через ChatGPT, но так как в програмировании я 0, то ничего не получилось)
    • Bot
      Коллеги, Благодарю вас за интерес к проекту электронной энциклопедии в области инженерного программного обеспечения PLMpedia, который более 15 лет развивался группой компаний ЛЕДАС. Представленный ниже скриншот передаёт содержание и структуру базы данных энциклопедии, накопленной за эти годы: именно такую начальную страницу, можно было до сегодняшнего дня увидеть, придя по адресу https://plmpedia.ru/ В последние несколько лет ЛЕДАС особенно интенсивно и результативно вкладывает все ресурсы в развитие своего основного бизнеса: см. ниже «О компании ЛЕДАС». Сегодня я с некоторым сожалением констатирую, что у компании ЛЕДАС более нет возможности отвлекать ресурсы своих сотрудников на некоммерческий (фактически волонтерский) проект PLMpedia. Вся база данных ресурса может быть безвозмездно передана любому юридическому или физическому лицу с единственным условием: наш преемник должен будет публично объявить о состоявшейся передаче и взятии на себя [...] View the full article
    • gudstartup
      @NordCom  у вас наверное это так происходит читайте этот раздел itnc_530.pdf
    • fenics555
      интересный индус. А нового то чего?
    • gudstartup
      откудова качаете мне интересно?
    • ДОБРЯК
      Совсем забыл про собственные вектора       собственный тон частота           0.013                        1   Расчет собственных форм и частот   1         1   7.0711E-01   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00   1         2   7.0711E-01   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00       собственный тон частота       15910.75                         2   Расчет собственных форм и частот   1         1   7.0711E-01   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00   1         2  -7.0711E-01   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00   0.0000E+00        
×
×
  • Создать...