Rapport – Entank Prosjekt i emnet «Styresystemer og reguleringsteknikk» Gruppe 01 Høgskolen i Sør-Trøndelag 2015 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Sammendrag (Skrevet av TM) Entank-prosjektet er en del av et større prosjekt som går i vårsemesteret i emnet «Reguleringsteknikk og styresystemer» for 2EA. Formålet med oppgaven er å regulere nivået i en tank etter gitte kriterier og ved hjelp av det utstyret vi har blitt tildelt fra skolen. Rapporten beskriver detaljert hvordan vi har programmert regulatorer i PLS, kommunikasjonen mellom de forskjellige enhetene, og flere løsninger på brukergrensesnitt. I tillegg til rapporten kommer et simuleringsnotat som vedlegg, hvor modellering, simulering og uthenting av regulatorparametere er beskrevet. Hovedresultatet har blitt en tank med en velfungerende nivåregulering med et innsvingningsforløp av typen «minimum forstyrrelse». Vi har fungerende og oversiktlige brukergrensesnitt, og i tillegg en webserver man kan lese og skrive noen verdier fra. Parameterne fra simuleringsnotatet ga et innsvingningsforløp på riggen som gjenspeilte resultatene fra simuleringen. Erfaringer vi har gjort oss er viktigheten av rekkefølgen av aksjonene i PLS-programmet, regulering med heltallsaritmetikk, og at man må være påpasselig med å ha god oversikt over adresser som blir brukt og oppdaterer disse forløpende. I PLS har kan vi velge om vi skal regulere med P-, eller PI-regulator. I tillegg har vi konstruert P-, D- og PD-foroverkobling. Best resultat oppnådde vi med PI-serieregulator med PD-foroverkobling. De beste innstillingene vi kom frem til er: PI-reg: P: 5.5 I-tid: 4.2 sekunder PD-foroverkobling: P: 0.7 D-tid: 0.3 Kravet gitt i oppgaveteksten var et innsvingningsforløp av typen minimum areal. Vårt innsvingningsforløp er av typen «minimum forstyrrelse». Vi har prøvd hardt å oppnå «minimum areal», men har konkludert med at dynamikken til selve utstyret er et hinder til å oppnå dette. Forord (Skrevet av TM) Denne prosjektrapporten representerer «Entank»-delen i prosjektet som holdes hver vår i emnet «Reguleringsteknikk og styresystemer» for 2EA. Vi i gruppe 1 retter vår takk til de ansatte og våre medstudenter ved HiST AFT - Program for elektrofag. Gjennomføringen av prosjektet har vært lærerikt og utfordrende, vi har alle fått kjent på mestringsfølelsen. Det har vært lærerikt fordi vi har fått konkretisert mye av det vi hadde i forelesninger tidligere i år. Man kan si at prosjektet har gitt oss flere knagger å henge klærne på. Det har vært utfordrende fordi mye av programvaren har vært ny for oss, og fordi vi ikke har lagd et PLSprogram som har vært så omfattende tidligere i utdanning. Vi vil rette en spesiell takk til vår veileder På Gisvold for den hjelpen vi har fått. Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Innholdsfortegnelse 1.0 Innledning .................................................................................................................................... 2 1.1 Bakgrunn ....................................................................................................................................... 2 1.2 Utstyr, programvare, definisjoner og forkortelser ........................................................................ 2 1.2.1 Forkortelser ............................................................................................................................ 2 1.2.2 Definisjoner ............................................................................................................................ 3 1.2.3 Utstyr ...................................................................................................................................... 4 1.2.4 Software ................................................................................................................................. 4 1.3 Hjemmeside................................................................................................................................... 5 2.0 Teknisk del ......................................................................................................................................... 7 2.1 Problemstilling ............................................................................................................................... 7 2.2 Prosessbeskrivelse ......................................................................................................................... 8 2.2.1 Flytskjema............................................................................................................................... 8 2.2.2 Bilder av systemet .................................................................................................................. 9 2.2.3 Kommunikasjon .................................................................................................................... 11 2.3 Antialiasing filter.......................................................................................................................... 12 2.4 Regulatoralgoritmer .................................................................................................................... 16 2.5 PLS programmering (EB) .............................................................................................................. 20 2.5.1 Master-PLS............................................................................................................................ 22 2.5.2 Slave-PLS ............................................................................................................................... 27 2.5.3 Serieregulator ....................................................................................................................... 31 2.5.4 Foroverkobling...................................................................................................................... 35 2.5.5 Alarmhåndtering .................................................................................................................. 39 2.6 HMI programmering .................................................................................................................... 43 2.6.1 OPC-server og tagger............................................................................................................ 43 2.6.2 Design InTouch ..................................................................................................................... 45 2.6.3 Design iX-panel ..................................................................................................................... 49 2.6.4 Alarmhåndtering InTouch..................................................................................................... 54 2.6.5 Alarmhåndtering iX-panel .................................................................................................... 57 2.6.6 Operatørnivåer og rettigheter.............................................................................................. 58 2.6.7 Web-grensesnitt for iX panel................................................................................................ 62 2.7 Simulering .................................................................................................................................... 64 2.7.1 Serieregulering ..................................................................................................................... 64 2.7.2 Foroverkobling...................................................................................................................... 66 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 3.0 Innregulering ................................................................................................................................... 68 3.1 Krav til reguleringen .................................................................................................................... 68 3.2 Manuelle innjusteringsmetoder .................................................................................................. 68 3.3 Serieregulering ............................................................................................................................ 69 3.4 Foroverkobling............................................................................................................................. 70 3.5 Parametere fra simulering........................................................................................................... 71 4.0 Testskjema ....................................................................................................................................... 72 4.1 Operatørpanel ............................................................................................................................. 72 4.2 InTouch ........................................................................................................................................ 72 4.3 PLS ............................................................................................................................................... 73 5.0 Prosjektgjennomføring, erfaringer og konklusjon .......................................................................... 74 5.1 Prosjektgjennomføring ................................................................................................................ 74 5.2 Erfaringer og forslag til forbedringer........................................................................................... 74 5.3 Konklusjon ................................................................................................................................... 75 6.0 Vedlegg .............................................................................................................................................. 1 6.1 PLS program Master ...................................................................................................................... 1 6.2 PLS program Slave ......................................................................................................................... 1 6.3 Simuleringsnotat ........................................................................................................................... 1 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur liste Figur 1 Eksempel kildekode hjemmeside ................................................................................................ 5 Figur 2 Eksempel CSS hjemmeside .......................................................................................................... 5 Figur 3 Eksempel formattering hjemmeside ........................................................................................... 5 Figur 4 Hjemmeside................................................................................................................................. 6 Figur 5 Flytskjema.................................................................................................................................... 8 Bilde 1 PLS-rigg ........................................................................................................................................ 9 Bilde 2 Tankrigg ..................................................................................................................................... 10 Bilde 3 Tankrigg bakside ........................................................................................................................ 10 Figur 6 Kommunikasjon ......................................................................................................................... 11 Figur 7 Kretsskjema antialiasing filter ................................................................................................... 12 Figur 8 Bode diagram filter .................................................................................................................... 13 Figur 9 Kobling MultiSim filter ............................................................................................................... 14 Figur 10 Sprang 1 til 5 volt filter MultiSim............................................................................................. 14 Figur 11 Ferdig filter .............................................................................................................................. 15 Figur 12 Karakteristikk AD/DA omformer ............................................................................................. 17 Figur 13 Prinsipp P-reg foroverkobling .................................................................................................. 18 Figur 14 Prinsipp D-reg foroverkobling ................................................................................................. 18 Figur 15 Prinsipp PD-reg foroverkobling ............................................................................................... 19 Figur 16 MOV blokk ............................................................................................................................... 20 Figur 17 TO blokk ................................................................................................................................... 20 Figur 18 FROM blokk ............................................................................................................................. 20 Figur 19 LD blokk ................................................................................................................................... 21 Figur 20 PLS / PLF blokk ......................................................................................................................... 21 Figur 21 Kontakt positiv flanke .............................................................................................................. 21 Figur 22 PLS initiering status ................................................................................................................. 22 Figur 23 PLS Flytte fra data til enkelte bit ............................................................................................. 22 Figur 24 PLS enkelt Bit til Data .............................................................................................................. 23 Figur 25 PLS Flytte til batterimatede minneceller ................................................................................. 23 Figur 26 PLS Flytte parametre til Profibus ............................................................................................. 23 Figur 27 PLS Start/Stopp pumpe ........................................................................................................... 24 Figur 28 PLS Auto/Manuell .................................................................................................................... 24 Figur 29 Velge P/PI regulator ................................................................................................................ 25 Figur 30 PLS valg av foroverkobling ....................................................................................................... 25 Figur 31 PLS Valg av utløp / Magnetventiler ......................................................................................... 26 Figur 32 PLS Status magnetventiler....................................................................................................... 27 Figur 33 PLS Slave struktur .................................................................................................................... 27 Figur 34 PLS Slave til/fra Master ........................................................................................................... 28 Figur 35 PLS Status bit sendes via Dataregister..................................................................................... 29 Figur 36 PLS Aksjoner mottatt fra Master ............................................................................................. 29 Figur 37 PLS Styring utganger Slave ...................................................................................................... 30 Figur 38 PLS Skriv/les AD/DA slave ........................................................................................................ 30 Figur 39 PLS P-regulator ........................................................................................................................ 31 Figur 40 PLS P-regulator algoritme - mellomregning ............................................................................ 31 Figur 41 PLS Grensesjekk og pådrag ...................................................................................................... 32 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur 42 PLS Av/På P-regulator.............................................................................................................. 32 Figur 43 PLS PI-regulator ....................................................................................................................... 33 Figur 44 PLS PI mellomregning 1 ........................................................................................................... 33 Figur 45 PLS PI mellomregning 2 ........................................................................................................... 33 Figur 46 PLS PI grensesjekk og pådrag .................................................................................................. 34 Figur 47 PLS PI-reg pådrag ..................................................................................................................... 34 Figur 48 PLS Foroverkobling .................................................................................................................. 35 Figur 49 PLS Foroverkobling P-Reg pådrag............................................................................................ 35 Figur 50 PLS Foroverkobling D-Reg endring av Kp til 1 ......................................................................... 36 Figur 51 PLS Foroverkobling D-Reg ....................................................................................................... 36 Figur 52 PLS Foroverkobling pådrag D-del ............................................................................................ 36 Figur 53 PLS Foroverkobling PD-Reg ..................................................................................................... 37 Figur 54 PLS Pådrag til DA-omformer .................................................................................................... 37 Figur 55 PLS Manuelt pådrag................................................................................................................. 38 Figur 56 PLS Rykkfrie overganger .......................................................................................................... 38 Figur 57 PLS Samplingstid ...................................................................................................................... 38 Figur 58 PLS Revers/Direkte regulering ................................................................................................. 39 Figur 59 PLS Status Profibus .................................................................................................................. 39 Figur 60 PLS funksjonsblokk Alarmer .................................................................................................... 40 Figur 61 PLS Alarm 25% under ref. ........................................................................................................ 40 Figur 62 PLS Alarm Kritisk lavt nivå ....................................................................................................... 40 Figur 63 PLS Alarmer tidsbegresning ..................................................................................................... 41 Figur 64 PLS Alarmer Tidsforsinkelse .................................................................................................... 41 Figur 65 PLS Alarmer Kvittering ............................................................................................................. 41 Figur 66 PLS Alarmlampe blink .............................................................................................................. 42 Figur 67 PLS Alarmlampe....................................................................................................................... 42 Figur 68 PLS Alarmer kvittering ............................................................................................................. 42 Figur 69 OPC Tag liste ............................................................................................................................ 43 Figur 70 OPC Tag eksempel skalering .................................................................................................... 44 Figur 71 InTouch Nivå tag ...................................................................................................................... 45 Figur 72 InTouch Plassering av referanse .............................................................................................. 46 Figur 73 InTouch Reguleringsventil ....................................................................................................... 46 Figur 74 InTouch Pumpe........................................................................................................................ 46 Figur 75 InTouch Animering pumpe ...................................................................................................... 47 Figur 76 InTouch Animering rør/ventil .................................................................................................. 47 Figur 77 InTouch display av verdier....................................................................................................... 47 Figur 78 InTouch Regulator parametere ............................................................................................... 48 Figur 79 InTouch Knapper utløpsventiler .............................................................................................. 48 Figur 80 InTouch Knapper ..................................................................................................................... 48 Figur 81 InTouch Trender ...................................................................................................................... 49 Figur 82 iX-panel Navigasjonsmuligheter .............................................................................................. 50 Figur 83 iX-panel Nivåindikator ............................................................................................................. 51 Figur 84 iX-panel Actions til knapper .................................................................................................... 51 Figur 85 iX-panel Trendvindu ................................................................................................................ 52 Figur 86 iX-panel Trendkurver oppsett ................................................................................................. 52 Figur 87 iX-panel Skjermbilde Instillinger .............................................................................................. 53 Figur 88 iX-panel Indikatorfarger .......................................................................................................... 53 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur 89 InTouch Alarmtag .................................................................................................................... 54 Figur 90 InTouch Alarmvindu ................................................................................................................ 54 Figur 91 InTouch Kvitterings script ........................................................................................................ 55 Figur 92 InTouch Alarmknapp animering .............................................................................................. 55 Figur 93 InTouch Oppsett blinking alarm .............................................................................................. 56 Figur 94 InTouch Alarm indikatorer ...................................................................................................... 56 Figur 95 iX-panel Alarmvindu ................................................................................................................ 57 Figur 96 iX-panel Alarmserver ............................................................................................................... 57 Figur 97 iX-panel innlogging .................................................................................................................. 61 Figur 98 iX-panel operatørnivåer .......................................................................................................... 61 Figur 99 iX-panel Webgrensesnitt ......................................................................................................... 62 Figur 100 iX-panel HTML kode eksempel .............................................................................................. 62 Figur 101 Simulering Serieregulering .................................................................................................... 64 Figur 102 Simulering Ziegler-Nichols ..................................................................................................... 64 Figur 103 Simulering Etterjustering....................................................................................................... 65 Figur 104 Simulering Etterjustering....................................................................................................... 65 Figur 105 Simulering Forenklet foroverkobling ..................................................................................... 66 Figur 106 Simulering Modell for foroverkobling ................................................................................... 66 Figur 107 Simulering Innsvingningsforløp med PD-foroverkobling ...................................................... 67 Figur 108 Manuell selvjustering ............................................................................................................ 69 Figur 109 Serieregulering ...................................................................................................................... 69 Figur 110 Foroverkobling ...................................................................................................................... 70 Figur 111 Test av parametere ............................................................................................................... 71 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Gruppedeltakere Prosjektgruppen består av følgende medlemmer Eyvind E. Bjørsland Allmenn 90915799 [email protected] Anders Aabakken Elektriker 95992849 [email protected] Magnus K. Bergsbakk Fagbrev sveiser 99026094 [email protected] Øyvind Eklo Automatiker 92894293 [email protected] Torbjørn Morken Prosesstekniker 45272224 [email protected] Veileder Pål Gisvold er veileder for prosjektgruppen Han jobber som Høgskolelektor ved avdeling for teknologi ved HiST, ved program for elektro- og datateknikk. Mail: [email protected] Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 1.0 Innledning 1.1 Bakgrunn (Skrevet av ØE) Det har blitt en tradisjon at studenter i 4. semester ved Elektro- og datateknikk, med valgt spesialisering automatisering, kjører et prosjekt i emnet «Styresystemer og reguleringsteknikk». I dette prosjektet skal vi prøve ut teorien vi har lært tidligere i semesteret i praksis. «Entank» er hoveddelen av prosjektet. Prosjektet omhandler alle de tre hoveddelene i emnet, reguleringsteknikk, sanntids datateknikk og PLS-/HMI-programmering. Prosjektet teller 40% av karakteren i emnet «Styresystemer og reguleringsteknikk». Klassen er delt inn i seks prosjektgrupper, som igjen består av fem eller seks studenter. 1.2 Utstyr, programvare, definisjoner og forkortelser 1.2.1 Forkortelser (Skrevet av MB) HiST OPC PC PLS HMI PID AD DA mA V Kp Ti Td HTML WAN Høgskolen i Sør-Trøndelag Object Linking and Embedding for Process Control. Personal computer Programmerbar logisk styring Human-Machine-Interface Proporsjonal-, Integral- og Derivat-regulator Analog til digital Digital til analog Milliampere Volt Forsterkning Integrasjonstid Derivasjonstid HyperText Markup Language Wide Area Network – Skolens nettverk i vårt tilfelle Side 2 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 1.2.2 Definisjoner (Skrevet av MB og ØE) HMI BUS Profibus-DP InTouch IEC HTML CSS PID-regulator Brukergrensesnitt for skriving og lesing til prosessen. Kommunikasjonssystem for overføring av data. Feltbuss kommunikasjonsstandard brukt innen automatikk Verktøy for programmering av HMI. International standards and conformity. Programmeringsspråk som kan brukes for å kode hjemmesider. «Cascading Sheet Styles» formateringsspråk til HTML P-regulator: Sørger for å endre pådraget proporsjonalt med avviket. PI-regulator: I-delen (integratordelen) har i oppgave å gjøre det stasjonære avviket lik null. PD-Regulator: D-delen (derivatdelen) har i oppgave å redusere det dynamiske avviket. Den gir ingen bidrag til stasjonært avvik. Stasjonært avvik Dynamisk avvik Innsvingningsforløp Forskjellen mellom referanse og måling ved stabilt system. Det største avviket fra referansen i et innsvingningsforløp. Karakteristikk på prosessverdiens forløp før systemet er stabilt. Vi opererer hovedsakelig med tre typer innsvingningsforløp: Minimum forstyrrelse, minimum areal eller minimum amplitude. Innsvingningsforløp med 4-6 halvperioder. Innsvingningsforløp med 10-15 halvperioder. Innsvingningsforløp med 1-2 halvperioder. Reguleringsstrategi for å motvirke forstyrrelser i prosessregulering. Signal der 4 mA representerer 0% og 20 mA representerer 100%. Signal der 1 V representerer 0% og 5 V representerer 100%. Minimum areal Minimum amplitude Minimum forstyrrelse Foroverkobling 4-20 mA 1-5 V Side 3 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 1.2.3 Utstyr (Skrevet av ØE og MB) Utstyr på PLS riggen: Mitsubishi FX1N PLS Mitsubishi Q00CPU Mitsubishi Q61P-A2 Powersupply modul Mitsubishi QJ71PB92D Ethernet modul Mitsubishi QJ71E71-100 Profibus modul DLink AirPlus G+ Router Mitsubishi FX0N-3A AD/DA modul Mitsubishi FX0N-32NT-DP Profibus modul Beijer iX Panel TA100 Beijer OPC server PC med InTouch software Antall: 2 stk. 1 stk. 1 stk. 1 stk. 1 stk. 1 stk. 2 stk. 2 stk. 1 stk. 1 stk. 1 stk. Utstyr brukt under prosjektet: Agilent Technologies Oscilloscope m/USB tilkobling 1 stk. 1.2.4 Software (Skrevet av ØE) Software navn: Wonderware InTouch GX Works 2 Beijer OPC server iX Developer 2.10 GX Configurator-DP GX IEC Developer MatLab m/ Simulink NI MultiSim Notepad++ WinSCP Benyttet til: HMI interface PLS programmering OPC link mellom PLS og HMI iX touchpanel programmering Oppsett Profibus-DP Oppsett Ethernet PLS Simulering og filter design Simulering av filteret Hjemmeside programmering Opplasting av hjemmeside Hjemmeside: http://www.invensys.com http://www.beijer.no http://www.beijer.no http://www.beijer.no http://www.beijer.no http://www.beijer.no http://www.mathworks.com http://www.ni.com http://notepad-plus-plus.org/ http://www.winscp.net Side 4 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 1.3 Hjemmeside (Skrevet og kodet av ØE) Prosjektet har egen hjemmeside som publiserer alle rapportene, arbeidsnotatene og tidsskriftartikkelen. Her har vi også lagt ut kort hva prosjektoppgaven går ut på og hvem som er med i prosjekt gruppen. Hjemmesiden finner du på: http://www.hekta.org/~p2ea1 Til koden har vi benyttes oss av programmet notepad++, og språket som er benyttet er HTML 4.01. Figur 1 Eksempel kildekode hjemmeside Formatering av sidene er gjort ved hjelp av «Cascading Style Sheets», eller CSS 3.0. Det vil si at vi henter inn ferdige *.css filer i <head> i hver html fil. På den måten slipper vi å skrive formateringskoden for hver gang vi lager en ny html fil. Vi har laget to CSS filer, samt hentet en med font type fra Google. Vi ser i figuren over hvordan disse blir hentet inn i selve HTML filen, på linje 6, 7 og 8. Koden på linje 9 og 10 forteller web-browseren hvilket tegnsett som skal brukes, og hvilket språk siden er på. Dette må være med slik at vi få nordiske bokstaver som æ, ø og å. Koden som står i <style> taggen gir oss muligheten til å formatere hver enkelt HTML side med ting som kun gjelder denne siden. Figur 2 Eksempel CSS hjemmeside Her ser vi et eksempel på hvordan elementet «overskrift» er formatert under <style>. Høyde, bredde, plassering fra toppen og fra venstre. Her settes også bakgrunnsfargen, som her er representert med RGB tall, til grå. Ved å velge class=«overskrift» i <div> elementet, velger vi formattering for hele. Vi bruker <div> til å plassere alt av tekst, bilder og linker. Figur 3 Eksempel formattering hjemmeside Side 5 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Hovedsiden er laget slik at menyer og overskrift kun lastes inn første gang. Innholdsdelen er laget ved hjelp av et <iframe> element, som henter opp og viser HTML sider. Det er laget en HTML side for hver side i menyen. Dette gjør at det blir enkelt å navigere i menyen, siden den ikke lastes hver gang. Størrelsen på siden er også prosent basert slik at den tilpasses skjermstørrelsen på hver PC som laster den. Koden for HTML og CSS er sjekket for kompabilitet mot gjeldende standarder på http://www.w3.org Dette gjør at vi kan benytte oss av logoer som viser at vi har utført denne sjekken av koden. Denne måten å lage hjemmesider på er veldig forskjellig fra den måten vi lærte i emnet Datateknikk. Vi har derfor måtte bruke mye tid på å lese oss opp på hvordan hjemmesider kodes til dagens HTML standard. Bruken av CSS var helt ny for oss, slik at vi begynte fra «scratch». Webgrensesnitt HMI I forbindelse med HMI-delen skulle det settes opp et web-grensesnitt mot touchpanelet. Dette bygger på en innebygget Java del i panelet. Det er satt opp en link fra hjemmesiden til Java serveren i panelet, men denne vil kun være operativ når vår del er lastet inn. Java delen i panelet er av en eldre, usikker type, som blir blokkert av nyere versjoner av Java. For å få denne funksjonen til å fungere må det derfor være installert en Java versjon som er versjon 7.0 eller eldre. Istedenfor er det kodet et webgrensesnitt som viser nivå, pådragsverdi og referanse. Referanse og manuelt pådrag kan også endres. Vi har prøvd å laget knapper som styrer utløpet, pumpe og kvitterer alarmer, men vi har ikke funnet koden som skal til for å styre enkelte bit-verdier. Dette grensesnittet fungerer kun når man er koblet til routeren lokalt. Grensesnittet finnes på http://192.168.1.104 Figur 4 Hjemmeside Side 6 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.0 Teknisk del 2.1 Problemstilling (Skrevet av ØE) Nivået i en tank skal reguleres med referanse 60%. Pådraget til tanken styres av en reguleringsventil. Det er 3 magnetventiler i utløpet som gir forstyrrelser til systemet. Prosjektgruppen skal programmere en regulator i PLSen, og utvikle brukergrensesnitt for prosessen i InTouch, samt et touch brukerpanel montert på riggen. Det skal prøves ut regulatorparametere fra simuleringsnotatet som ble ferdigstilt tidligere. Det er gitte krav til funksjoner og tilgangsnivåer til InTouch og touchpanelet i oppgaveteksten. Reguleringsmetodene som kan benyttes er følgende: Serieregulering: P-Regulator med nominelt pådrag. PI-Regulator. Foroverkobling: P-regulator med P-regulator foroverkobling. PI-regulator med P-regulator foroverkobling. P-regulator med D-regulator foroverkobling. PI-regulator med D-regulator foroverkobling. P-regulator med PD-regulator foroverkobling. PI-regulator med PD-regulator foroverkobling. Kravene til reguleringen er: Intet stasjonært avvik. Innsvingningsforløp av typen «minimum areal». Kjappest mulig innsvingning til ±2% av måleområdet når referansen er 60%. Det skal utarbeides en rapport på 60-80 sider for delprosjektet, samt publiseres på egen hjemmeside. Det praktiske arbeidet skal vises frem til faglærere Tirsdag 28.04.2015 Side 7 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.2 Prosessbeskrivelse 2.2.1 Flytskjema (Laget av AA) Figur 5 Flytskjema Side 8 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.2.2 Bilder av systemet (Tatt av EB) Bilde 1 PLS-rigg Side 9 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Bilde 2 Tankrigg Bilde 3 Tankrigg bakside Side 10 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.2.3 Kommunikasjon (Skrevet av AA) Kommunikasjon mellom de forskjellige nodene i nettverket foregår på forskjellige måter. Vi bruker Ethernet mellom master PLS, operatørpanel og PC med InTouch. Mellom master PLS og slave PLS bruker vi ProfiBus DP. Masteren vil da fungere som en «tolk» mellom operatørpanel, PC med InTouch og slave PLS. Dette er primæroppgaven til master PLS i dette prosjektet. Ofte må man bruke slike «overganger» mellom forskjellige typer kommunikasjonsprotokoller. Dette kommer ofte av at de forskjellige produsentene ikke støtter andre leverandørers protokoller. Da blir det mye mer komplisert, og ikke minst fordyrende. Det kan også være nødvendig å bytte bus type dersom det er store krav til hastighet mellom noen av nodene. Alle bus typer har også en klar begrensning i rekkevidde. Her kan det være veldig kostbare noder som kommuniserer over store avstander, mens rimeligere noder brukes lokalt i de forskjellige avdelingene. Ett eksempel på dette kan være en fabrikk som har flere produksjonslokaler på ett industriområde. I hvert lokale kan det være flere mindre maskiner som har sine egne PLSer. Lokalt på hver enkelt maskin kan det være for eksempel ASI BUS som henter inn signal fra de forskjellige sensorene inn til PLSen. Deretter knyttes de forskjellige maskinene sammen med ProfiBus DP. Til slutt bruker man kanskje Ethernet IP for å sende data fra hver avdeling inn til hovedkontoret som ønsker å se driftsstatus, tilstander og produksjonsstatistikk. For å gjøre dette er man avhengig av noder som kommuniserer på minimum 2 nett samtidig, akkurat slik som vår master PLS gjør. Figur 6 Kommunikasjon Side 11 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.3 Antialiasing filter (Skrevet av ØE) Spesifikasjon AD omformer 8bit 4-20 mA 0-250 oppløsning 250 Ohm motstand inngang til filter 100 ms i samplingstid i PLS (valgt av oss) 2. ordens Butterworth filter Tar utgangspunkt i ukjent støy, og designer filteret ut i fra at alt over halve samplingsfrekvensen skal dempes med 20 dB per dekade. Inngangssignalet på 4-20 mA gjøres om til 1-5V ved hjelp av en 250 Ω motstand i parallell med inngangssignalet. Figur 7 Kretsskjema antialiasing filter 1𝐿𝑆𝐵 = 𝜔𝑠 2 5−1𝑉 250 2𝜋 𝜋 = 0.016 𝑉 = 2ℎ = 0.1 = 31.4 1 𝐿𝑆𝐵 2 𝑟𝑎𝑑 𝑠 𝜔0 = 0.11/2 ∗ 31.4 = 0.316 ∗ 31.4 = 9.93 = 0.016𝑉 2 = 0.008 𝑉 10−20/20 = 0.1 𝑟𝑎𝑑 𝑟𝑎𝑑 ≈ 10 = 1.6 𝐻𝑧 𝑠 2 Side 12 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Vi velger kondensatorer først, for så å bestemme verdiene til motstandene. 𝑉𝑒𝑙𝑔𝑒𝑟 𝐶1 = 𝐶2 = 1 𝜇𝐹 𝑅1 = 1 √2𝜔0 𝐶1 𝑅2 = ℎ𝑖𝑛𝑛 = 𝑢𝑡 = 1 ≈ 70𝑘Ω 𝑟𝑎𝑑 √2 ∗ 10 𝑠 ∗ 1 𝜇𝐹 √2 √2 = ≈ 140 𝑘Ω 𝜔0 𝐶2 10 𝑟𝑎𝑑 ∗ 1 𝜇𝐹 𝑠 𝑅1 𝑅2 𝐶12 𝑠 2 1 1 = 2 + 𝑅2 𝐶2 𝑠 + 1 0.0098𝑠 + 0.14𝑠 + 1 Dette blir ideelle verdier for motstandene. Vi må velge fra reelle verdier som ligger nærmest disse. Vi velger da: 𝑅1 = 68 𝑘Ω, 𝑅2 = 150 𝑘Ω Bode diagram Bode Diagram Antialiasing filter 0 -10 Magnitude (dB) -20 -30 -40 -50 -60 -70 -80 0 Phase (deg) -45 -90 -135 -180 -1 10 10 0 1 10 Frequency (rad/s) 10 2 10 3 Figur 8 Bode diagram filter Side 13 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Test av filteret i MultiSim MultiSim simulering av filteret med inngangssignal 1-5V og 50Hz støy med 2V amplitude. Vi valgte først kondensatorer på 47 𝜇𝐹, men ble anbefalt av Stein-Olav Lund, Labingeniør ved HiST, å velge kondensatorer mellom 1 𝑜𝑔 2.2 𝜇𝐹. Disse hadde mindre lekkasjestrømmer, og filteret ble bedre. Vi har simulert det opprinnelige filteret i MultiSim, og siden dette har samme karakteristikk som det vi skal lage, har vi valgt å ta med figur av simuleringen Figur 9 Kobling MultiSim filter Figur 10 Sprang 1 til 5 volt filter MultiSim Rødkurve = inngangssignal, Blåkurve = utgangssignal, Sprang fra 1 til 5 V Scope innstillinger for kurven over. Side 14 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Filteret i praksis Figur 11 Ferdig filter Systemet er generelt plaget med mye støy, både nettstøy og fra frekvensomformeren. Denne støyen forplantet seg til AD/DA omformeren, slik at den oppfattet at signalet inn endret verdi, selv om nivået var stasjonært. Vi så en klar forbedring når vi koblet til filteret. Støyen ble fjernet, og inngangssignalet ble uforandret når vi hadde stasjonært nivå i tanken. Systemet er fortsatt plaget med støy når spolene til utløpsventilene slår inn. Vi får da en «peak» som tolkes som verdien 250 i AD omformeren. Side 15 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.4 Regulatoralgoritmer (Skrevet av ØE) Vi velger å bruke bakoverdifferans for numerisk integrasjon. 𝑠= 1 − 𝑍 −1 ℎ Det skal være mulig å kjøre hovedregulatoren i både direkte og revers Vi har følgende kombinasjoner for regulatorene: Serieregulering: P-Regulator med nominelt pådrag PI-Regulator (uten nom. Pådrag) Foroverkobling: P-regulator med P-regulator foroverkobling PI-regulator med P-regulator foroverkobling P-regulator med D-regulator foroverkobling med nom. pådrag PI-regulator med D-regulator foroverkobling P-regulator med PD-regulator foroverkobling PI-regulator med PD-regulator foroverkobling Regulator parametere Grenseverdier for Kp, Ti og samplingstid h 𝐾𝑝 = 0.1 𝑡𝑖𝑙 100 𝑇𝑖 = 0.1 𝑡𝑖𝑙 100 𝑠𝑒𝑘 ℎ𝑠𝑎𝑚𝑝𝑙𝑖𝑛𝑔 = 0.1 𝑠𝑒𝑘 Ved heltallsaritmetikk multipliseres disse verdiene opp, slik at vi får kun heltall: 𝐾𝑝10 = 𝐾𝑝 ∗ 10 = 1 𝑡𝑖𝑙 1000 𝑇𝑖10 = 𝑇𝑖 ∗ 10 = 1 𝑡𝑖𝑙 1000 𝑠𝑒𝑘 ℎ = ℎ𝑠𝑎𝑚𝑝𝑙𝑖𝑛𝑔 ∗ 10 = 1 𝑠𝑒𝑘 Vi vil få det samme for foroverkoblingsregulatorens parametere, 𝐾𝑝𝑓𝑓 , 𝑇𝑑𝑓𝑓 , 𝐾𝑝𝑓𝑓10 , 𝑇𝑑𝑓𝑓10. 𝑇𝑑𝑓𝑓 = 0.1 𝑡𝑖𝑙 100 𝑠𝑒𝑘 𝑇𝑑𝑓𝑓10 = 𝑇𝑑𝑓𝑓 ∗ 10 = 1 𝑡𝑖𝑙 1000 𝑠𝑒𝑘 Side 16 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Avvik Det dynamiske avviket regnes ut på følgende måte Reversert: 𝑒 =𝑟−𝑦 konstant r: pådraget økes når y reduseres Direkte: 𝑒 =𝑦−𝑟 konstant r: pådraget økes når y økes Hvor r = referansen og y = måltverdi Inn- og utgangsverdier på AD/DA omformer 4-20 mA gjøres om til 0-250 i digitale verdier for AD. 0-250 i digitale verdier gjøres om til 4-20 mA i DA. Figur 12 Karakteristikk AD/DA omformer Serieregulator (Hovedregulator) P-regulator med nominelt pådrag Desimaltallalgoritme: 𝑢(𝑘) = 𝐾𝑝 ∗ 𝑒(𝑘) + 𝑢0 Heltallsalgoritme: 𝑢= 𝐾𝑝10 ∗ 𝑒(𝑘) + 𝑢0 10 PI-regulator Desimaltallalgoritme: 𝑢(𝑘) = 𝑢(𝑘 − 1) + 𝐾𝑝 ∗ ((1 + ℎ ) ∗ 𝑒(𝑘) − 𝑒(𝑘 − 1)) 𝑇𝑖 Heltallsalgoritme: 𝐻𝑗𝑒𝑙𝑝𝑒𝑣𝑎𝑟𝑖𝑎𝑏𝑒𝑙: 𝑋 = 𝑢(𝑘) = 𝑢(𝑘 − 1) + 𝑇𝑖10 ℎ (𝐾𝑝10 ∗ (𝑒(𝑘) − 𝑒(𝑘 − 1)) + 𝐾𝑝10 ∗ 𝑒(𝑘) ) 𝑋 10 Side 17 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Foroverkobling P-regulator Desimalalgoritme: 𝑢𝑃𝑓𝑓 (𝑘) = 𝐾𝑝𝑓𝑓 ∗ (𝑣(𝑘) − 𝑣(𝑘 − 1)) Heltallsalgoritme: 𝑢𝑃𝑓𝑓 (𝑘) = 𝐾𝑝𝑓𝑓10 ∗ (𝑣(𝑘) − 𝑣(𝑘 − 1)) 10 Figur 13 Prinsipp P-reg foroverkobling D-regulator Heltallalgoritme: 𝑢𝐷𝑓𝑓 (𝑘) = 𝑇𝑑𝑓𝑓10 ∗ 𝑢𝐷𝑓𝑓 (𝑘 − 1) 𝐾𝑝𝑓𝑓10 ∗ 𝑇𝑑𝑓𝑓10 (𝑣(𝑘) − 𝑣(𝑘 − 1)) + 𝑇𝑑𝑓𝑓 10 ∗ 𝑁 10 ∗ 10 ∗ (ℎ + 𝑁 ) 𝐾𝑝𝑓𝑓 settes til 1 ved ren D Figur 14 Prinsipp D-reg foroverkobling Side 18 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank PD-regulator 𝑢𝑃𝐷 (𝑘) = 𝑢𝐷 (𝑘) + 𝑢𝑃 (𝑘) Kun 𝑢𝑃 (𝑘) grensetestes i forbindelse med wind-up kontrollen. Figur 15 Prinsipp PD-reg foroverkobling Side 19 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.5 PLS programmering (EB) Slave-PLSen er den enheten hvor all regulering foregår. Den mottar datainput fra en maste-PLS virker som et bindeledd mellom slaven, InTouch og operatørpanelet. Videre vil vi først forklare noen grunnleggende instruksjoner i programmeringen for å enkelt kunne forstå hva som skjer. Deretter viser vi hva master gjør og deretter slave-PLSen. Detaljert beskrivelse av programkoden inne i funksjonsblokkene er gitt etter en generell beskrivelse av blokka. MOV-blokka Figur 16 MOV blokk MOV-blokka brukes til å kopiere data fra en plass til en annen. Den kan for eksempel kopiere data fra et dataregister over til et sett med minneceller. Da skrives dataregisteret på s-inngangen til blokka. På utgangen d kan man for eksempel skrive «K4M100». Da legges de 16-bits dataene fra dataregisteret over i 16 minneceller fra og med M100-M115. K4 betyr 4 kvartiler. I tilfellet i figur # kopierer den verdien 250 over i et dataregister som er kalt «Pådrag_u». TO- og FROM-blokkene Figur 17 TO blokk TO-blokka brukes for å skrive data til et bufferminne på Profibus. «s» angir hvilke data som skal sendes, n1 forteller hvilket slotnummer enheten som skal motta dataene har, n2 forteller hvilket bufferminne (BFM#) dataene skal sendes på og n3 forteller hvor mange 16-bits ord som skal sendes. Figur 18 FROM blokk FROM-blokka brukes til å lese data fra et bufferminne på Profibus. n1 angir slotnummeret for enheten dataene skal leses fra, n2 angir BFM# og n3 forteller hvor mange 16-bits ord som skal leses. Utgangen d angir hvor dataene skal leses til, for eksempel et dataregister eller et sett minneceller. Side 20 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank LD – sammenligningsblokker LD-blokkene er et sett med blokker som sammenligner to verdier. Om påstanden til blokka er sann, vil de etterfølgende instruksjonene bli utført. Denne funksjonen bruker vi for å grensesjekke verdier så de holder seg innenfor tillatte grenser. F.eks. kan ikke pådraget ut på DA-omformeren overskride 250 eller være mindre enn 0. Da må pådraget grensesjekkes etter utregning slik at det holder seg innenfor 0 og 250. Figur 19 LD blokk I figur # sjekkes «Pådrag_u» om verdien er over 250. Hvis den er det, kopieres verdien 250 til pådraget, slik at det ikke blir større. Dette er også en del av anti-windup-funksjonen til regulatoren, slik at integratoren ikke fortsetter å integrere opp når pådraget når sine grenser. PLS og PLF Mye av aksjonene og utregningene skal skje på et bestemt tidspunkt, og ikke kontinuerlig. Dette gjelder set/reset av minneceller som styrer aksjoner, utregning av pådrag fra regulatoren, oppdatering av gamle verdier etc. PLS-blokka går høy i et scan på positiv flanke når noe trigger den. PLF-blokka går høy et scan på negativ flanke. En kan se for seg en knapp som trykkes på. PLS-blokka går høy et scan når knappen trykkes inn (den forblir ikke høy selv om knappen holdes inne), og den PLF-blokka går høy et scan når knappen slippes. Figur 20 PLS / PLF blokk Det er også mulig å sette at en overgang skal trigge på positiv eller negativ flanke, at etterfølgende aksjoner bare trigges et scan på den respektive flanken. Pilen, vist i figur 21, indikerer om den trigger på positiv flanke (pil opp) eller negativ flanke (pil ned). Figur 21 Kontakt positiv flanke Side 21 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.5.1 Master-PLS Initiering og backup Først i programmet i master ligger en del som resetter alle statuser ved oppstart og henter tilstanden for aksjoner fra batterimatede minneceller. Oppgaven sier at regulering av tanken skal skje direkte etter strøminnkopling ved strømbrudd. Det medfører at vi må ta vare på regulatorparametere og aksjoner i batterimatede dataregistre og minneceller. Dataregistrene som er batterimatede er av typen R#, og minnecellene av typen L#. Disse beholder sine verdier selv om strømmen er borte, via et batteri i strømforsyningsenheten til master. Figur 22 PLS initiering status Statuser I master har vi satt av et sett med minneceller til indikering av statuser fra slave-PLSen. Master mottar et dataregister, D130, hvor verdiene kopieres over i minneceller for å lese av hvert enkelt bit. K4L16 betyr 4 kvartetter (4x4 bit) fra minnecelle L16 tom. L31. Ved oppstart/strøminnkopling nullstilles alle statuser med spesialminnecelle SM402, som kun er høy første scan etter oppstart. I figur 23 er programbiten for statushåndtering vist. Figur 23 PLS Flytte fra data til enkelte bit Status for kommunikasjon med Profibus er programmert på samme måte som i miniprosjektet. Side 22 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Aksjoner Aksjoner som skal styres settes via batterimatede minneceller samles i et dataregister og sendes ut på Profibus til slave. Dette er aksjoner som «start/stopp pumpe», «åpne en ventil» etc., hvor vi bruker bitverdier til å sette/resette utganger på slaven. Dette er vist i figur 24. Figur 24 PLS enkelt Bit til Data Sende regulatorparametere Det er master som sender ned alle parametere satt i InTouch eller operatørpanel ned til slave, og som mottar alle statuser sendt opp fra slaven og videreformidler disse til Intouch og operatørpanel. Da de batterimatede dataregistrene ikke automatisk sendes ut på ProfiBus, bruker vi en MOV-blokk for å kontinuerlig kopiere parameterne over i dataregistre som sendes ut på ProfiBus. Vi har laget en funksjonsblokk som flytter alle parameterne over i dataregister som går ut på ProfiBusen. Funksjonsblokka har ingen innganger eller utganger, da alle dataregistre fra D100-D115 automatisk sendes ut på ProfiBus. Hensikten med å samle koden i en blokk er å gjøre programmet kompakt og oversiktlig. Figur 25 PLS Flytte til batterimatede minneceller Figur 26 PLS Flytte parametre til Profibus Side 23 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Starte og stoppe pumpa Pumpa skal startes både fra Intouch og operatørpanel. Vi har brukt et batterimatet dataregister som vi har kalt «PUMPE_data» som enten har verdien 0 eller 1 ettersom pumpa skal starte (1) elle stoppe (0). Ved strømbrudd beholder dataregisteret sin verdi slik at pumpa beholder samme status etter som før strømbruddet. Figur 27 PLS Start/Stopp pumpe Å få pumpa til å starte etter strømbrudd var et problem vi jobbet en stund, da de batterimatede minnecellene vi satte ble resatt etter strøminnkopling av ukjent grunn. Derfor endte vi opp med å la verdien på et dataregister bestemme om minnecellene skulle være satt eller ikke. Pumpa stoppes automatisk ved kritisk lavt eller høyt nivå (over 90% eller under 10%). Denne programbiten er presentert i alarmdelen for slaven. Auto/manuell regulering Det er gitt i oppgaven at regulatoren, i tillegg til automatisk regulering, også skal kunne styres manuelt. Dette gjøres ved å sette den i manuell modus hvor pådraget blir gitt av operatør som «manuelt pådrag». Denne funksjonen må også ha en set/reset-funksjon av samme grunn som pumpa. Vi har programmert regulatoren til å være i auto så lenge «AUTO_MAN_IN» er resatt (lav). InTouch og operatørpanelet kommuniserer med «Aktiver_manuell» og «Stopp_manuell», se figur 28. Figur 28 PLS Auto/Manuell Side 24 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Regulatormoduser Regulatoren skal kunne fungere både som P- og PI-regulator, og begge enten uten eller med P-, D-, eller PD-foroverkobling. I Intouch har vi brukt «radio buttons», som ikke kunne gi diskrete, men bare analoge verdier, 1, 2, 3 osv. Dermed har vi måtte lage en programdel som legger verdiene fra knappene i Intouch over i dataregistre, for så å sammenligne disse med bestemte verdier for å sette eller resette bitverdiene som angir regulatormodus. Valg av regulatormodus settes bare i Intouch, ikke i operatørpanel. Valg av P- og PI-regulator er vist i figur 29. Figur 29 Velge P/PI regulator «Radio»-Knappene i Intouch har verdiene 1 og 2 når det er to knapper som står sammen, som her styrer P- og PI-modus. Det samme er tilfellet med aktivering/deaktivering av foroverkoblingen, som vist i figur 30, mens for valg av type foroverkobling gir knappene verdiene 1, 2 eller 3, da det er tre valg. Dette har resultert i at vi bruker verdien i gitte dataregistre for å bestemme hvilken regulatormodus som skal være satt. Programdelen for valg av foroverkoblingsmodus er vist i figur 30. Her er det programmert slik at hvis D- og PD-foroverkobling er resatt, er P-foroverkoblingsmodus satt. Hvordan dette settes i slaven er vist under avsnitt 2.5.3 Foroverkoblinsregulator. Figur 30 PLS valg av foroverkobling Side 25 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Styring magnetventiler Riggen har tre magnetventiler som vi kan styre via Intouch eller operatørpanelet. Vi har laget programmet slik at vi kan sette utløp til 0% (alle lukket), 33% (en ventil åpen), 66% (to ventiler åpne) eller 100% (alle ventiler åpne), se figur #. Dette settes både i Intouch og i operatørpanelet. For at statusen for ventilene skulle holde seg etter strømbrudd, måtte vi også bruke dataregistre for indikasjon på hvor mange ventiler som skulle åpnes. Hvis vi brukte direkte set/reset-funksjon uten dataregistre, beholdt de bare statusen sin en kort stund (ca. et scan) før de ble resatt. Dette problemet var gjengående for alle aksjoner som skulle starte etter strømstans. Under, i figur 31 vises programkoden som lukker alle ventilene, og her vises også koden som åpner to ventiler. Den samme koden gjelder for alle utløp, null, en, to og tre ventiler åpne. Verdien i «VENTIL_data» gjenspeiler antall åpne ventiler. Figur 31 PLS Valg av utløp / Magnetventiler Side 26 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank En egen programdel gir status på hvor mange ventiler som er åpne til Intouch og operatørpanelet. Dette er vist i figur 32 under. Figur 32 PLS Status magnetventiler 2.5.2 Slave-PLS For å holde oversikt over hva som skjer i de forskjellige programdelene og for lett å kunne feilsøke, har vi delt inn programmet i flere deler med hver sin oppgave. Dette er også viktig for å styre rekkefølgen oppgaver utføres i. F.eks. må avleste verdier som vi tar vare på for videre beregninger, oppdateres til slutt i programsekvensen, etter at pådraget ut fra regulatoren er sendt ut på DAomformeren. For å styre denne rekkefølgen legges programdelene i «Task 1», «Task 2» osv etter hvilken rekkefølge de skal utføres i. Dette er vist i figur 33. Figur 33 PLS Slave struktur I Task 1 ligger programdelene for skriving og henting av data til og fra master, styring av pumpe og ventiler, regulatorene og alarmhåndteringen. I Task 2 ligger programdelen som skriver og leser til og fra AD/DA-omformeren. Det er viktig at denne oppgaven ikke gjøres samtidig som utregningene fra regulatoren, men etter pådraget er regnet ut. I Task 3 oppdateres «forrige verdier». Dette må skje til slutt etter at pådraget er sendt ut på DA og dataene er lest av. Side 27 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Til/Fra Profibus «Til_Fra_Bus» inneholder programkoden som sender og henter all data til og fra Profibus/masterPLS. Vi har laget funksjonsblokker som bruker TO- og FROM-blokker til å sende og hente data. Når vi samler alle disse blokkene i egne funksjonsblokker blir programmet mer oversiktlig og lettere å lese under monitorering når vi kjører reguleringen. Da kan vi enkelt lese av hvilke verdier som sendes og hentes til og fra master. Figur 34 PLS Slave til/fra Master De ledige utgangene fra funksjonsblokkene er utganger fra bufferminner som ikke brukes. Vi har mulighet til å hente og sende data fra og til totalt 15 bufferminner fra ProfiBus. Ved å lage en funksjonsblokk som leser/skriver fra/til alle og tildeler hvert bufferminne et dataregister, kan vi enkelt delegere hvilke verdier som skal hvor i slaven. Da har vi også oversikt over hva som er i bruk og hva som er ledig av bufferminner og dataregistre. Programdelen i funksjonsblokkene i figur # og # er vist i vedlegg #. Side 28 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Statuser fra slave I slaven har vi satt av 16 minneceller for statusindikasjoner som samles i et dataregister og sendes opp til master. Statusene brukes som bekreftelser på at de aksjoner og innstillinger vi har satt fra pc eller operatørpanel er utført/satt. Statuser som sendes opp er status for: Pumpe (Start eller stopp) Magnetventiler (åpen eller lukket) Alarmer (avvik fra referanse og kritisk høyt eller lavt nivå) MOV-blokka kopierer 16 minneceller fra M500-M515 over i dataregister D130 som sendes ut på Profibus opp til master. K4 bety fire kvartetter som er lik 16 minneceller. Figur 35 PLS Status bit sendes via Dataregister Aksjoner fra master Slaven mottar også et sett med minneceller «pakket» inn i et dataregister fra master på samme måte som statuser fra slaven blir sendt. Dataregisteret kopieres over til et sett med minneceller med ei MOV-blokk. Hvert enkelt bit setter hver sin funksjon, som er kommentert i figur 36. Figur 36 PLS Aksjoner mottatt fra Master Styring av pumpe og magnetventiler, slave Pumpa på riggen startes ved å sette utgang Y4 på slaven høy. Det er et krav i oppgaven at den skal stoppe om nivået når kritisk lavt (under 10%) eller høyt (over 90%) nivå, og tilstanden varer i over fem sekunder. Om enten «LowLevelAlarm» eller «HighLevelAlarm» aktiveres, stopper pumpa. Pumpa må også kunne overstyre i manuell modus, slik at man kan komme seg opp fra et kritisk lavt nivå, eller ved en oppstartsfase av tanken. Magnetventilene på riggen styres av utgangene Y10, Y11 og Y12. Status på utgangene sendes opp til master. Side 29 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur 37 PLS Styring utganger Slave Avlesning av nivå, utstrømning og skriving av pådrag I miniprosjektet laget vi en funksjonsblokk som skrev pådrag ut på DA-omformeren og leste av nivå og utstrømning (flow) fra AD-omformeren. Denne funksjonsblokka har vi brukt videre i entankprosjektet, men vi gjentar ikke innholdet inne i funksjonsblokka. Figur 38 PLS Skriv/les AD/DA slave Side 30 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.5.3 Serieregulator P-regulator Funksjonsblokka for P-regulatoren er vist over i figur #. Inn i blokka sendes Kp-verdien (Kp10), nominelt pådrag (NomineltPadrag_u0), referanse (Referanse_r), avvik, aktivering av P-regulator (RegModus) og indikasjon for manuell eller automatisk modus (ManAuto). Kp- og Ti-verdiene er multiplisert med 10 før de blir sendt til slaven pga. heltallalgoritmen. Dette gjelder også for PIregulatoren og foroverkoblingen (Kpff og Tdff). Ut fra blokka sendes pådraget, som videre legges sammen med et eventuelt pådrag fra foroverkoblingen og det grensesjekkes og sendes ut på DAomformeren. Figur 39 PLS P-regulator Funksjonsblokken inneholder heltallsalgoritmen for P-regulator hentet fra avsnitt 2.4: 𝑢= 𝐾𝑝10 ∗𝑒(𝑘) 10 + 𝑢0 . Når P-foroverkobling er valg skal ikke det nominelle pådraget skrives til pådraget fra P-regulatoren. Dette er det satt opp en sperre for i programmet. Figur 40 PLS P-regulator algoritme - mellomregning Side 31 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank «Mellomverdi» er pådraget fra P-regulatoren før det er grensesjekket. Pådraget skal skrives som en 8-bits verdi fra 0-250. Hvis utregningen blir negativ, settes pådraget til null, og hvis det blir over 250, settes det til 250 før det kopieres over i den endelige variabelen for pådraget, «P_Pådrag», som går ut av funksjonsblokka. Grensesjekken er vist i figur 41. Det er lagt inn sperrer for skriving til pådraget hvis PI-regulator eller manuell modus er aktivert. Figur 41 PLS Grensesjekk og pådrag Under, i figur 42, er programbiten som kopierer 0 over til pådraget fra P-regulatoren om PIregulatoren er aktivert. Når «Regmod» er høy, betyr det at PI-regulator er aktivert. Figur 42 PLS Av/På P-regulator Side 32 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank PI-regulator Figur 43 PLS PI-regulator PI-regulatoren er også programmert som en egen funksjonsblokk. Parameterne som sendes inn i blokka er referanse (Referanse_r), avvik, Kp (Kp10), integrasjonstid Ti (Ti10), forrige pådrag (Um1), forrige avvik (em1), aktivering av PI-regulatoren (RegModus), indikasjon på manuell eller automatisk modus (ManAuto) og samplingstiden (h_sampling). Ut fra blokka sendes pådraget, «Pådrag_PI», som videre legges sammen med et eventuelt pådrag fra foroverkoblingen og deretter grensesjekkes før det sendes ut på DA-omformeren. Algoritmen som er brukt i regulatoren er hentet fra boka «Sanntidsdatateknikk. Per Hveem, 2014». Først innfører vi hjelpevariabelen 𝑇𝑖ℎ = 𝑇𝑖 ℎ Del 1 av mellomregningene vist under: 𝛥𝑈𝑖𝑘 = 𝐾𝑝10 ∗𝑒𝑘 +𝛥𝐼𝑅𝑒𝑠𝑡𝑘−1 𝑇𝑖ℎ∗10 Figur 44 PLS PI mellomregning 1 Del 2 av mellomregningene vist under: Δ𝑈𝑖𝑟𝑒𝑠𝑡𝑘 = (𝐾𝑝10 ∗ 𝑒𝑘 + Δ𝑖𝑅𝑒𝑠𝑡𝑘−1 )%(𝑇𝑖ℎ ∗ 10) Uttrykket er det samme som i del 1, med en modulofunksjon, %, er brukt for å tar vare på resten av heltallsdivisjonen som senere legges til. Den er representert av MOD_E-blokka. Figur 45 PLS PI mellomregning 2 Side 33 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Til slutt regnes det endelige pådraget ut, som så grensesjekkes før det sendes ut av funksjonsblokka. 𝑈𝑘 = 𝑈𝑘−1 + Δ𝑈𝑖𝑘 + 𝐾𝑝10 ∗ (𝑒𝑘 − 𝑒𝑘−1 ) 10 Figur 46 PLS PI grensesjekk og pådrag Resten av hjelpevariabelen Δ𝑖𝑅𝑒𝑠𝑡𝑘 oppdateres på negativ flanke, når samplingstimeren går lav. Det gis bare bidrag fra «PI_Pådrag» om «Regmodus», altså PI-regulatoren, er aktivert og den ikke står i manuell modus. Pådraget skrives på positiv flanke når samplingstimeren går høy. Figur 47 PLS PI-reg pådrag Side 34 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.5.4 Foroverkobling Foroverkoblingen er et tillegg til hovedregulatoren og gir ekstra pådrag på bakgrunn av utstrømningen. Flowmåleren måler utstrømningen, som reagerer raskere enn målingen av nivået i tanken. Ved å gi et pådrag på bakgrunn av utstrømningen kan man raskere regulere inn nivået ved åpningen av ventilene. Foroverkoblingen skal fungere enten som P-, D-, eller PD-foroverkobling som skal styres fra PC. Vi har laget en funksjonsblokk som inneholder mulighet for alle typene foroverkobling. Figur 48 PLS Foroverkobling P-foroverkobling Algoritmen i sin helhet er vist i avsnitt 2.4. PLS-programmet for heltallsalgoritmen som regner ut pådraget er vist i figur #: 𝑢𝑃𝑓𝑓 (𝑘) = 𝐾𝑝𝑓𝑓10 ∗ (𝑣(𝑘) − 𝑣(𝑘 − 1)) 10 Pådraget skal regnes ut enten når P-foroverkobling eller PD-foroverkobling er aktivert. Differansen mellom nåværende og forrige utstrømning multipliseres med en K-forsterkning og divideres til slutt på 10. Jo større differanse det er mellom dem i nåværende utstrømnings favør, jo større blir pådraget. Figur 49 PLS Foroverkobling P-Reg pådrag Pådraget fra P-foroverkoblingen grensesjekkes før det legges til pådraget fra serieregulatoren og sendes ut på DA. Side 35 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank D-foroverkobling Foroverkoblingen skal også ha en ren D-foroverkobling. Derivatordelen registrerer hvor hurtig endringer skjer, i vårt tilfelle hvor hurtig utstrømningen endres. Den gir så pådrag etter hvor hurtig endringene skjer. Når ren D-foroverkobling er aktivert settes 𝐾𝑝𝑓𝑓 = 1 → 𝐾𝑝𝑓𝑓10 = 10. Dette skjer utenom funksjonsblokka, under POUen «Parametere». Figur 50 PLS Foroverkobling D-Reg endring av Kp til 1 Heltallsalgoritme for D-foroverkobling: 𝑢𝐷𝑓𝑓 (𝑘) = 𝑇𝑑𝑓𝑓10 ∗ 𝑢𝐷𝑓𝑓 (𝑘 − 1) 𝐾𝑝𝑓𝑓10 ∗ 𝑇𝑑𝑓𝑓10 (𝑣(𝑘) − 𝑣(𝑘 − 1)) + 𝑇𝑑𝑓𝑓 10 ∗ 𝑁 10 ∗ 10 ∗ (ℎ + ) 𝑁 Figur 51 PLS Foroverkobling D-Reg De tre øverste blokkene, i figur 51 over, representerer den første brøken i uttrykket. Den nedre halvdel, bestående av sju blokker representerer den andre brøken. Disse brøkene adderes til slutt. Ddelen av foroverkoblingen skal være utenfor anti-windup (grensesjekk), så det sendes rett ut av funksjonsblokka og adderes til pådraget fra serieregulatoren. Figur 52 PLS Foroverkobling pådrag D-del Side 36 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank PD-foroverkobling PD-foroverkoblingen summerer pådragene fra P- og D-delen. P-delen grensesjekkes, og deretter legges bidraget fra D-delen til. Etter de er summert sendes de ut av funksjonsblokka. Figur 53 PLS Foroverkobling PD-Reg Pådrag ut på DA-omformer Når pådraget fra serieregulatoren og foroverkoblingen er regnet ut, legges de sammen etter hvilken regulatortype som er valgt i pc eller operatørpanel. «Pådrag_u» grensesjekkes så, før det kopieres over i «Pådrag_ut», som skrives til DA-omformeren. Figur 54 PLS Pådrag til DA-omformer Side 37 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Manuelt pådrag Når manuelt pådrag er valgt, er skriving fra regulatorpådraget deaktivert. Figur 55 PLS Manuelt pådrag Rykkfrie overganger Rykkfrie overganger (Bumpless Transfer) vil si at endring av regulatortype eller fra manuell til auto og motsatt ikke skaper rykk/hopp i prosessen eller pådraget. Oppgaven vår setter rykkfrie overganger som et krav. Vi har sørget for at overgangen mellom P og PI går rykkfritt ved at begge pådragene regnes ut kontinuerlig, og at vi bestemmer hvem som skal skrive til det endelige pådraget ut på DAomformeren. Pådraget mellom manuell og auto har vi satt slik at om manuell settes, blir pådraget som er skrevet inn i Intouch eller operatørpanel, satt. Det forutsetter at manuelt pådrag er satt lik det automatiske pådraget for at pådraget skal ligge urørt etter overgang. Figur 56 PLS Rykkfrie overganger Sampling Vi har laget en timer som bestemmer når verdier skal skrives, leses og oppdateres under reguleringen. Samplingstiden til regulatoren kan settes i Intouch, og bestemmer hvor ofte regulatoren skal avlese nivå og utstrømning og skrive pådrag. Standard samplingstid for regulatoren vår er 0.1 sekund. Timeren er laget slik at den resettes seg selv. Figur 57 PLS Samplingstid Side 38 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Revers og direkte modus Oppgaven er det gitt at det skal være mulig å velge revers eller direkte modus for regulatoren. Forskjellen er måten avviket regnes ut på. Det var ikke videre gitt at regulatorens skulle fungere i begge moduser, så regulatoren er bare skikkelig fungerende i reversert modus, hvor avviket er lik referansen minus nivået. Ved direkte modus er avviket lik nivået minus referansen. Figur 58 PLS Revers/Direkte regulering 2.5.5 Alarmhåndtering (Skrevet av MB) Programmeringen av alarmer på nivå og referanse ble gjort i slaven ettersom alle verdiene vi trenger ligger der, samt utgangen til alarmlampen er i slaven. Alarm for kommunikasjon ble programmert i master. Statusen for ProfiBus-kommunikasjonen ligger i bufferminne nr. 21. Dersom kommunikasjonen mellom master og slave ikke fungerer går bit 12 i BFM#21 høy. Vi henter ut denne biten med en FROM-blokk. Dersom statusen er lik 1 settes ett flagg som indikerer at Profibus-kommunikasjonen er nede. Figur 59 PLS Status Profibus Side 39 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Vi laget en egen funksjonsblokk for alarmhåndteringen i slaven slik at alt som går inn og ut av programbiten blir oversiktlig framstilt. Vi trengte kun nivået i tanken og referansen på inngangene til funksjonsblokken for å regne ut alarmtilstandene. I tillegg måtte kvitteringen av alarmer fra brukergrensesnittene inn på blokka. Ut fra blokka kommer alle alarmtilstandene pluss utgangen til alarmlampen. Figur 60 PLS funksjonsblokk Alarmer Hvis nivået avviker mer enn 25% fra referansen skal det gå vanlig alarm. Det ble delvis utført på måten vist i bildet under. I neste bilde regner vi ut om nivået er 25% under referansen. Referansen blir trukket fra verdien 62 som er 25% av det totale nivået i tanken uttrykt i bit verdi. Dette blir gjort med SUB-blokken vist i bildet nedenfor. Så blir verdien fra subtraksjonen sendt videre til sammenligningsblokken LD<. Her blir verdien sammenlignet med nivået i tanken. Hvis nivået er mindre enn verdien sendt fra SUB-blokka, settes et flagg for at avviket mellom nivå og referanse er for stort. En lik programkode ble skrevet for avvik over referansen. SUB-blokka ble da byttet ut med en ADD-blokk med de samme verdiene. Verdien blir sendt videre til en blokk som sammenligner om nivået er større enn denne verdien. Figur 61 PLS Alarm 25% under ref. Kritisk alarm skal aktiveres om nivået går over 90% av tanken eller under 10%. I bildet under regner vi ut om nivået er mindre enn verdien 25, som er 10% av det absolutte nivået i tanken. Når verdien i Nivå er mindre enn 25 settes ett flagg for kritisk lavt nivå i tanken. For å regne ut kritisk alarm når nivået er over 90% brukte vi en «større enn»-blokk som regner ut om nivået er større enn verdien 225 som er 90% av det absolutte nivået i tanken uttrykt i bitverdi. Når den kritiske alarmen går skal pumpa automatisk stoppes. Figur 62 PLS Alarm Kritisk lavt nivå Side 40 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Ett av kravene til alarmene var at en alarmtilstand som ikke varte lenger enn 5 sekunder ikke skulle utløse noen alarm. Det ble realisert på følgende måte, som også er vist i bildet under. Alarmflaggene som blir satt etter utregningene får sine egne «timere». Så lenge ett av flaggene er satt vil den respektive blokka OUT_T begynne å telle opp til verdien som er satt i inngangen «TValue». Verdien er oppgitt i tidels sekund. Når blokka har telt opp til 5 settes en individuell bit for hver blokk. Figur 63 PLS Alarmer tidsbegresning For blokka «TC1» heter den individuelle bit’en «TS1». Når denne blir satt høy 5 sekunder etter at alarmtilstanden ble satt, får vi varsel om alarmtilstanden. Varselet sendes på utgangen til funksjonsblokka ved at utgangen settes høy. Figur 64 PLS Alarmer Tidsforsinkelse Alarmen kan kun resettes dersom tanken går ut av alarmtilstand, som igjen setter TS1 lav, i tillegg til at det fysisk må kvitteres fra ett av brukergrensesnittene som er koblet til systemet. Figur 65 PLS Alarmer Kvittering I tillegg til at alarmer skal vises i brukergrensesnittene skal en lampe på selve riggen indikere om en alarm er kritisk, vanlig, eller kvittert. Ved vanlig alarm skal lampen blinke på og av med 0,5 sekunders intervaller. Ved kritisk alarm skal lampen blinke med 0,2 sekunders intervaller. Når en alarm er kvittert men det fortsatt er alarmtilstand skal lampen lyse konstant. Når det ikke lenger er alarmtilstand og den er kvittert slukkes lampen. Neste bilde viser hvordan vi realiserte den kritiske alarm frekvensen ved hjelp av en timer og en holdekrets. En timer sender ut en puls hvert 2. tidels sekund ved at timeren resetter seg selv ett scan etter at den er ferdig å telle. For hver puls på TS5 vil M1 bytte status mellom høy og lav. For vanlig alarm på 0,5 sekunds intervaller ble en identisk programkode laget med en endret «TValue» på 5. For vanlig alarm brukte vi minnecelle M0 i holdekretsen. Side 41 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur 66 PLS Alarmlampe blink Neste bilde viser programbiten for alarmlampen. Vi ser at når vi har vanlig alarm men ikke kritisk alarm, i tillegg til at vi ikke har fått noen kvittering fra operatøren, vil M0 gjøre at alarmlampen blinker med frekvens på 0,5 sekund på og 0,5 sekund av. Skulle en kritisk alarm bli utløst derimot, vil minnecelle M1 gjøre at lampen blinker med frekvens 0,2 sekund. Dersom vi har kvittert alarmen men fortsatt har alarmtilstand vil lampen lyse konstant. Figur 67 PLS Alarmlampe For å sørge for at alle alarmer må kvitteres blir kvitteringen satt og resatt. Kvitteringen blir satt av operatør på ett av brukergrensesnittene. Kvitteringen resettes hver gang en alarm går. På denne måten vil alle nye alarmer resette kvitteringen, som sørger for at operatøren fysisk må kvittere for alle alarmer som går. Figur 68 PLS Alarmer kvittering Side 42 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.6 HMI programmering 2.6.1 OPC-server og tagger (Skrevet av MB) OPC gjør kommunikasjonen mellom produkter fra forskjellige produsenter mulig. En OPC server ble derfor satt opp for å muliggjøre kommunikasjon mellom Mitsubishi master-PLS og brukergrensesnittet som ble laget i Wonderware Intouch. Det er viktig at PLS-programmet er overført til PLSen, og at GX Works er lukket før man setter opp OPC serveren første gang. Det første vi gjør etter vi har åpnet OPC serveren er å konfigurere den for vår master-PLS som er en Mitsubishi Q-E71. Vi velger merke og serie og skriver inn PLSen sin IPadresse. Nå vet OPC serveren hvilken adresse den skal kommunisere med på Ethernettet. I master-PLSen brukes bit- og ordadresser for å overføre informasjon til og fra både slaven og brukergrensesnittene. I OPC serveren definerer vi alle de brukte adressene som tagger. Vi spesifiserer også hva slags type adresse den skal prate med enten det er en bitadresse, for eksempel en minnecelle, eller en ordadresse, eller et dataregister. Nå vet serveren hvilke adresser den skal kommunisere med i selve PLSen. Taggene får samme verdi i OPC som i PLSen, og disse endres ettersom verdiene endres i PLS. Når vi er ferdig med å opprette alle taggene vi trenger startes OPC serveren. Den har nå forbindelse til PLSen og vi kan monitorere verdiene til alle adressene som vi har definert i serveren. Vi kan også monitorere statusen på forbindelsen mellom server og PLS. Så lenge serveren er oppe og går kan vi ikke endre de taggene vi allerede har opprettet, men vi kan opprette nye tagger og grupper. OPC serveren er nå oppe og går, og klar til bruk. Vinduet må ikke lukkes så lenge vi skal ha kommunikasjon mellom utstyret. Figur 69 OPC Tag liste I tillegg til en OPC server trenger vi en OPC klient som er forbindelse fra utstyret inn til serveren. Klienten som oversetter data inn fra/ut til PLSen er innebygd i OPC serveren. OPC klienten som forbinder OPC server og Intouch heter Wonderware OPC Link og følger med Intouch. Når man åpner OPC Link må man opprette en konfigurasjonsfil hvor de satte innstillingene lagres. Dette fordi Intouch skal kunne åpne OPC Link automatisk når man åpner prosjektet. Etter man har opprettet filen definerer man hva OPC serveren heter som Intouch skal ha forbindelse med. I vårt tilfelle Beijer.Electronics.OPC.Server. I tillegg definerer vi hva PLSen heter. Dette gjøres fordi man i Intouch gjerne styrer mange forskjellige PLSer. Vi har nå kommunikasjon mellom Intouch og server, og videre til master-PLS. Side 43 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Det første vi gjorde i Intouch var å opprette tagger for de adressene som brukes i PLSen. Taggene kan man si er et duplikat av adressene i PLSen, og vi kan aktivere disse for å styre adressene i PLSen. Vi vil at taggene som brukes skal referere til de taggene vi har opprettet i OPC serveren og må derfor bruke en modul i Intouch som heter OPC TagCreator. Etter at vi har koblet OPC serveren opp mot Intouch med OPC Link finner vi nå de samme taggene som vi opprettet i serveren igjen i TagCreator. Først velger vi den topicen vi ønsker fra OPC Link. Her finner vi igjen navnet på PLSen. Så lager vi et accessname for de taggene vi skal opprette. Vi laget bare ett accessname kalt ”master”, men om man har flere PLSer og massevis av tagger er det viktig å organisere taggene med flere accessnames. Så oppretter vi en og en tag som deretter dukker opp i en liste i et eget vindu nederst på skjermen. Vi importerer taggene til Intouch. Vi kan se at TagCreator har importert gruppene vi laget i OPC serveren og taggene som ligger i hver gruppe. Når vi markerer en tag kan åpnes muligheten for å trykke ”Create Tag”. Hvis vi trykker på denne vises den nye taggen i en liste. En liste over alle tagger finner vi under Tag Directory. Her kan man også redigere navnet på taggene, hva slags type tag det skal være og andre detaljer. Noe vi fikk mye bruk for i dette prosjektet var skaleringen av taggene. Dette betyr at verdien endres i Intouch før den sendes ut på OP serveren. Som vi ser på figur 70 skriver vi inn en verdi mellom 0 og 100 i Intouch. Verdien blir skalert til en verdi mellom 0 0g 250 og denne verdien sendes ut til OPC serveren Figur 70 OPC Tag eksempel skalering Side 44 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.6.2 Design InTouch (Skrevet av MB) Det første som ble laget i Intouch var det hele prosjektet egentlig handler om, nemlig tanken. Det var viktig at designet av tankgrafikken var enkel, lett gjenkjennelig, samtidig som den skal passe inn i et større system av grafikk med ventiler, pumpe og andre komponenter. Hovedpoenget med designet av tanken var allikevel å vise nivået i tanken på en måte som gjør at man umiddelbart får en ide om hvor høyt vannstanden ligger. Vanntanken ble designet meget enkelt som en gjennomsiktig tank med sorte kantlinjer, blått fyll og en anelse lysere bakgrunn enn resten av skjermbildet. På denne måten skjønner operatøren umiddelbart hva dette er, samtidig som framstillingen er enkel og grafikken blir «ren» og ryddig. Tanken ble plassert midt i hovedprosessbildet for videre å tydeliggjøre at dette er hva hele programmet handler om. Fyllet i tanken ble koblet til taggen for nivået i tanken i menyen Animation Links->Vertical Fill. Man kommer seg til denne menyen ved å dobbeltklikke på grafikken man vil endre animasjonsinnstillingene på. Her skriver man også inn hva verdien på taggen man bruker er ved maksimum fyll og minimum fyll. Figur 71 InTouch Nivå tag Neste steg ble å legge inn referansen som en stripe på tankgrafikken. Vi valgte å bruke en fargen gul for å framheve at dette ikke er nivået i tanken. Vi unngår å bruke fargen rød da denne fargen brukes utelukkende på alarmer for å unngå forvirring. Vi vil at denne referanse-stripen skal flyttes opp og ned etter hva vi setter referansen til. Vi går derfor inn i Animation Links->Vertical Location hvor vi kobler denne til referanse-taggen. Ved denne innstillingen kan vi få referanse-stripen til å bevege seg vertikalt etter hva verdien på referanse-taggen er. Måten vi gjorde dette på var ved å plassere stripen der hvor 100 % av referansen ville være, og brukte koordinatene på windows-pilen som ligger nede til høyre i InTouch vinduet til å finne koordinatene til det som ville være 0 % av referansen. Verdiene ble skrevet inn i Vertical Location-vinduet som vist i figur 72. Side 45 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur 72 InTouch Plassering av referanse Etter vi følte oss ferdig med tanken kom designet og animasjon av resten av riggen. Vi begynte med reguleringsventilen. Vi ville fortsette med det enkle, rene designet som vi begynte med på tanken og bestemte oss for å lage en ventil som viser pådraget som fyll. Dette gir operatøren raskt en anelse om hvor stort pådraget er i forhold til maksimum pådrag. Symbolet for reguleringsventilen ble bygget opp av flere andre symboler, noe som gjør at muligheten til å lage celler i Intouch kommer godt til nytte. Denne funksjonen gjør at vi kan sette flere symbol sammen til én celle, noe som gjør alt mye lettere i Intouch om man for eksempel skal flytte om på grafikk man har laget. Vi kan lett se for oss forskjellen på figur 73 under. Figur 73 InTouch Reguleringsventil Utløpsventilene på selve tankriggen er magnetventiler så de måtte designes på en annen måte enn reguleringsventilen. Ventilene er enten åpen eller lukket så fargen på fyllet ble satt til enten fullt eller tomt. Det var viktig å få fram statusen på pumpen på tankriggen på en tydelig måte. Vi valgte å fortsette trenden med grønt fyll når ting i systemet var åpent, eller på. Dette gjorde vi også for pumpa, men i tillegg ville vi endre posisjon på symbolet for å tydeliggjøre om pumpa var på eller av. Vi ville derfor vri symbolet 90 grader når pumpa var slått av. Figur 74 InTouch Pumpe Side 46 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Dette gjøres ganske enkelt i Animation Links->Orientation. Man skriver inn hva verdien på taggen er i posisjonene maksimum moturs og maksimum medurs, i tillegg til hvor mange grader man vil at symbolet skal vris og i hvilken retning i forhold til startposisjon. Figur 75 InTouch Animering pumpe Til slutt lagde vi rørene mellom de forskjellige komponentene på riggen. Vi valgte å animere rørene for å tydeliggjøre hvor det faktisk renner vann i rørsystemet. Fyllet endrer dermed farge i forhold til hvilke komponenter som er åpen eller lukket. På denne måten kan enhver person oppfatte hva som skjer i prosessbildet. Dette vil i tillegg få fram statusen på de forskjellige komponentene på en bedre måte enn om rørene hadde en konstant farge. Vi valgte selvfølgelig blå farge når det renner vann i rørene, mens vi valgte en mørkgrå tone når rørene er tomme. Grunnen til dette var for å skille rørene fra bakgrunnen og i tillegg få en kontrast til tanken i tom tilstand. Figur 76 InTouch Animering rør/ventil Vi valgte å legge til små vinduer med de forskjellige målte verdiene slik at man i tillegg til å se på de grafiske modellene, kan lese av en eksakt verdi for målingene. Figur 77 InTouch display av verdier Side 47 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Vi valgte å plassere prosessbildet i midten av fanen for å framheve at dette er midtpunktet i hele programmet. Til venstre begynte vi å plassere små ruter for de forskjellige parameterne på regulatoren og foroverkoblingen. Vi skiller mellom de forskjellige gruppene parametere ved å ramme de inn slik som vist på figur 78. Vi valgte radioknapper for å bytte mellom P og PI for regulatoren, og P, D og PD for foroverkoblingen. Disse ble valgt på grunn av det enkle designet, samt at man lett ser hva slags innstilling man står i. Figur 78 InTouch Regulator parametere Vi valgte å se på de tre utløpsventilene som en ventil når vi setter den fra Intouch. Vi laget derfor fire knapper som setter utløpet i prosent. Statusen på ventilene vises fortsatt som tre individuelle ventiler på prosessbildet. Vi valgte å gjøre det på denne måten for å gjøre presentasjonen så enkel som mulig. Da kan man enkelt hoppe fra én åpen ventil til tre åpne ventiler i ett klikk. Figur 79 InTouch Knapper utløpsventiler For innstillingene av pumpa og det manuelle pådraget valgte vi trykknapper som vist i figur 80. Grunnen til dette var at disse funksjonene skal kunne styres både fra Intouch og iX Panelet, noe som gjør at sett og reset-knapper er mest hensiktsmessig. Da kan begge funksjonene styres og endres samtidig av både Intouch og iX panelet. Det vil si at om pumpa startes i Intouch vises dette i iX panelet. Figur 80 InTouch Knapper Side 48 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Sanntidstrender er viktig for å vise utviklingen av en prosess den siste tiden. En egen sanntidsfane ble laget med to forskjellige trender. Den ene viser nivået med referansen og pådraget. Den andre viser pådrag og flow i forhold til hverandre. Begge viser trenden de siste 5 minuttene. I tillegg til dette ønsket vi å ha en trend i hovedfanen slik at man lett kan se hva som har skjedd i prosessen uten å bytte fane. Dette er hjelpsomt om man er borte fra arbeidsstasjonen i en stund eller opptatt med noe annet i et øyeblikk. I figur 81 vises innstillingene for et sanntidstrendvindu. Vi ser hvordan trenden blir med disse innstillingene også. Figur 81 InTouch Trender En historisk trend ble også laget slik at man kan søke seg tilbake flere timer eller dager for å se hvordan utviklingen av prosessen har vært over lengre tid. Dette kan være viktig om man ser at prosessen ikke er som den skal og man vil finne ut når dette skjedde, og hva som skjedde med de andre målte verdiene. 2.6.3 Design iX-panel (Skrevet av AA) For En-tank prosjektet ligger det klare føringer i oppgaveteksten for hvilke betjeningsmuligheter man skal ha på operatørpanelet. Dette operatørpanelet vil ikke ha brukerkontroll i form av innlogging eller andre sperrer. Dermed er det hensiktsmessig å ikke legge for mange innstillingsrettigheter på operatørpanelet. Derfor er det hos oss kun mulig å bytte mellom manuell og automatisk regulator. Man må også ha muligheten for å sette manuelt pådrag for regulatoren i manuell modus. Man kan også sette referanse fra operatørpanelet. Da operatørpanelet kun er ett alternativ til InTouch, må man lage skjermbildene slik at de ikke overstyrer og blokkerer for hverandre. Dette løser man med å velge variabler/tagger som har muligheten til både å lese og skrive. Disse «Read/Write» variablene velger man i starten av prosjektet under opprettelsen av tagger. Disse kommuniserer mot ett dataregister eller ett bit i master-PLSen. Her leser det stadig av verdien, slik at panelet vil vise riktig verdi dersom verdien endres fra ett annet sted enn operatørpanelet. Dette er viktig for å unngå forvirring. Side 49 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Dersom kommunikasjonen mellom operatørpanelet og controlleren faller ut, vil man få feilmeldingen «comm err station 1». Da fungerer selvfølgelig ikke panelet på noen som helst måte. Operatørpanelet har vi designet slik at det skal være enkelt å finne den informasjonen du er ute etter. Det skal ikke ha for mange momenter som tiltrekker seg din oppmerksomhet uten å være viktig. Derfor bruker vi grå og rolige farger. Ved grafisk illustrering bør man holde grafikken på ett fornuftig nivå. Her kan det fort bli for mye unødvendige illustrasjoner. Vi har valgt å kun animere tanken for å vise nivået. Alle de andre komponenter i systemet har vi laget lamper og brytere til. Dette fordi vi mener at alle rør og detaljerte tegninger over prosessen hører hjemme på InTouch, og kun vil virke forstyrrende på operatørpanelet. Operatøren kjenner likevel prosessen, slik at vi trenger ikke vise hvor pumpen henter vannet, og hvor den leverer det. Ventilene er også åpenbart i bunnen. Slike animasjoner og grafikk virker ofte mot sin hensikt. Det viser seg at analoge animerte verdier oppfattes raskere og enklere av mennesker enn digitale verdier. Dette er grunnen til at vi animerer tankverdien. Informasjonen på operatørpanelet bør deles inn i ulike grupper ut ifra hvor i prosessen de forskjellige komponentene befinner seg. Man kan også dele opp i forskjellige komponentkategorier og funksjoner i egne «rammer» på skjermen. Dette gjør at man enklere finner riktig komponent. Vi har total fem vinduer å velge mellom i operatørpanelet Oversiksvindu 2 x trendvinduer Vindu for Innstillinger Alarmvindu Navigasjonen mellom vinduene gjøres ved hjelp av knapper plassert i bunnen av skjermbildene. Vinduet som heter Oversikt er utgangsvinduet vårt som man kan navigere frem og tilbake fra. Figur 82 iX-panel Navigasjonsmuligheter Side 50 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Oversiktsbilde Det første vinduet om kommer opp er et oversiktsbilde hvor nødvendig informasjon vises og man kan bestemme utløpet man vil ha. Hver knapp og indikator er knyttet opp mot en tag som gjør kommunikasjonen mellom panelet og PLS mulig. Helt til høyre i panelet står det en indikator som leser nivået i tanken, det er også en rute som viser nivået i prosent. Figur 83 iX-panel Nivåindikator I bildet over vises hvordan indikatoren er knyttet til tag Niva_tank_1, mer om tagger er beskrevet senere i dette avsnittet. En utfordring med knappene i panelet var å få de til å gi pulser i stedet for å sette en verdi høy hele tiden. Eksempelvis hvis det ønskes 33% utløp, og det trykkes på knappen for 33% utløp vil den sette en minnecelle høy i PLS, og den vil derfor være «oppbrukt». Dette løste vi med en innebygd funksjon i iX Developer som lar oss sette og resette taggene ved forskjellige handlinger. Vi har valg at taggen settes når knappen blir trykt ned, og resatt når den slippes opp. Figur 84 iX-panel Actions til knapper Side 51 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Trend Vi ønsker å kunne vise historisk trend på operatørpanelet. Dette for at operatøren ute i felt ønsker å raskt kunne se om prosessen tilfredsstiller kravene som stilles. Dette trenger ikke å være avansert, med god oppløsning, kun en rask visning av hvordan ting utvikler seg. iXpanelet har muligheten til å vise flere grafer i samme vindu. Dette er greit når dataen som skal vises er innenfor omtrent samme område. Dersom det er store sprik i størrelsene på verdiene bør man bruke flere trendvinduer. Dette for at vi skal få en grei oppløsning på Yaksen. Hos oss ønsker vi å vise settpunkt, nivå og pådrag. Alle disse verdiene er i prosent, og kan da vises i ett vindu med grei skalering av Y-aksen. Figur 85 iX-panel Trendvindu Figur 86 iX-panel Trendkurver oppsett Man velger selv hvor lang tid man ønsker å vise i trendvinduet. Dersom prosessen er rask, bør man velge ett kort tids-intervall for å få ei grei oppløsning i grafen. Hvis prosessen har en form for svingninger kan det være lurt å ha ett mye lenger tidsvindu enn periodetiden på svingningene. Da spiller ikke oppløsningen på kurven noen stor rolle, men derimot muligheten til å se flere svingninger på samme bilde. Dette gjør at man kan danne seg ett bilde av om svingningene tiltar eller avtar i amplitude. Her bør man ha muligheten til å se mange svingninger for å se hvordan de forskjellige innsvingningsforløpene ser ut med forskjellige innstillinger. Når man arbeider med å trimme inn en prosess, kan det noen ganger være ønskelig å stanse loggingen for å se nøyere på en spesiell tidsperiode. Dette kan man enkelt gjøre i iX-panelet. Man oppretter bare en knapp som man tildeler de riktige egenskapene i forhold til trendviseren. Dersom man under logging opplever kommunikasjonsproblemer mellom operatørpanelet og controlleren den er tilkoblet vil man se på kurvene at tegningen stanser i den perioden kommunikasjonen er nede. Kurvetegning starter igjen automatisk når kommunikasjon på nytt er etablert. Vi har to trendvinduer i panelet, et med en oppløsning på ett minutt og et med oppløsning på en time. Side 52 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Innstillinger På en arbeidsplass med hvor de ansatte har varierende kunnskap om utstyret kan det lønne seg å sortere hvem som skal få gjøre kritiske forandringer på systemet. Det er kritisk at regulatorparameterne blir forandret av en som vet hva han driver med. Vinduet for innstillinger er derfor brukerbegrenset. Figur 87 iX-panel Skjermbilde Instillinger Her kan regulatorparameterene leses og skrives, og man kan bytte fra Auto til Manuell og fra P til PI. Lampene indikerer hva som er av og hva som er på ved grå og grønn farge. Dette er gjort ved å knytte de til statusminneceller. Byttet mellom P og PI gjøres ved at en minnecelle settes høy ved PIregulering og resettes ved P-regulering. Vi har valgt å ha med indikatoren for nivået i tanken her slik at man hele tiden har god oversikt over prosessen. Figur 88 iX-panel Indikatorfarger Side 53 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.6.4 Alarmhåndtering InTouch (Skrevet av MB) Det første vi måtte gjøre var å la Intouch få vite hvilke tagger som skal gi alarm. Dette gjøres i Tagname Dictionary. I figur 2.6.4.1 under kan man se dette vinduet. Hvis vi klikker på alarmer kan vi velge om det skal gå alarm når taggen går høy under Alarm state. Siden alle våre alarmer er diskrete er dette det eneste vi trenger å gjøre for at en tag skal gi alarm. I tillegg kan vi velge hvilken prioritet alarmen skal ha under Priority. Prioriteten på alarmene går fra 1-249 for kritisk prioritet, 250-499 for høy prioritet, 500-749 for liten prioritet og 750-999 for de som kun er til informasjon. I tillegg kan vi legge inn en kommentar som skal vises i alarmvinduet når en eventuell alarm går. Figur 89 InTouch Alarmtag Alarmhåndteringen i Intouch blir utført fra et eget vindu kalt «alarmer». Knappen for å komme til denne siden ligger på menylinjen øverst i programbildet. Her skal vi kunne lese alarmer som har gått, kvittere alarmer, og lese alarmer som er kvittert. Vi valgte å legge inn et vindu som lister alle alarmer som går. Dette vinduet ligger forhåndslaget i InTouch. Her får vi oppgitt massse info om alarmen blant annet tidspunkt for alarmen, hvilket prioritet alarmen har og operatøren som var innlogget ved alarmtidspunktet. Figur 90 InTouch Alarmvindu Side 54 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Vi trengte også en måte å kvittere alarmene på. Dette kan gjøres ved å høyreklikke på det forhåndslagde alarmvinduet og kvittere derfra, men vi ville ha en enklere måte å gjøre dette på. I tillegg til å kvittere alarmene i InTouch måtte vi også sende en kvittering til PLS for å kunne starte pumpe og slukke alarmlampe på riggen. Dette ble kombinert ved å lage en knapp som kvitterer alarmene både i Intouch og i PLSen. I menyen Animation Links->Touch Pushbuttons->Action kan vi skrive et skript som utfører flere aksjoner i Intouch ved forskjellige steg i utførelsen av selve trykket på knappen. I figur 91 ser vi hvordan vi kvitterer for alarmene i Intouch samtidig som vi setter taggen som kvitterer alarmer i PLSen høy når venstre museknapp trykkes ned. For å resette taggen som kvitterer i PLS velger vi at når venstre museknapp slippes skal kvitteringstaggen settes lav igjen. På denne måten sender vi kun en puls ned til PLS. Dette fordi kvitteringen i PLSen skjer på puls. Figur 91 InTouch Kvitterings script Det som nå gjensto var å finne en måte å alarmere operatøren på, på en enkel men effektiv måte. Vi ble enig om at hvis knappen som åpner alarmvinduet blinker rødt ved alarm ville dette være hensiktsmessig på flere måter. Først og fremst fordi knappen er ganske stor i seg selv så hvis det blinker rødt rundt den ville dette vises veldig godt i programvinduet. I tillegg viser det med en gang hvor operatøren skal klikke for å finne ut alle detaljer om hva det er som har skjedd. Dette ble gjennomført ved delvis å gjemme en rød rute bak alarmknappen som kun vises og blinker ved alarmtilstand. Figur 92 InTouch Alarmknapp animering Under Animation Links->Miscellaneous->Blink gjøres dette ganske lett ved å velge en tagg som skal bestemme når den røde ruten skal blinke. Vi krysser av for at den skal «Blink Invisible». Så går vi under Visibility og velger at når taggen som gjør at ruten blinker går lav, skal ruten ikke vises i det hele tatt. Dette er vist i figur 93. Side 55 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Figur 93 InTouch Oppsett blinking alarm For å gi operatøren en viss anelse om hvilken alarm det er som har gått laget vi tre lamper for de tre alarmkategoriene vi har på dette prosjektet. Vi laget en for kommunikasjonen mellom master- og slave-PLS, en for kritisk alarm som gjelder nivået i tanken, og en for vanlig alarm som gjelder for store avvik fra referansen. Figur 94 InTouch Alarm indikatorer Side 56 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.6.5 Alarmhåndtering iX-panel (Skrevet av AA) Ix Developer programmet har en egen alarmkontroller. I denne kontrolleren kan man legge til tagger som skal gi alarm på panelet. Man har muligheter til å lage alle betingelsene for alarm lokalt i operatørpanelet. Dette kan eksempelvis være: «Nivå>65». Dette vil gi en alarm når verdien for taggen «nivå» overstiger 65. Man kan også lage digitale alarmer ved å gi betingelsen >0. Normalt bør man holde opprettelsen av alarmer til PLSen. Dette på grunn av at alarmer bør opprettes på ett sted for å ha et godt system i alarmene. Figur 95 iX-panel Alarmvindu Det å få Ack’et alarmene på panelet og videre i PLS viste seg å bli et problem når vi brukte standardoppsettet i iX-developer. I standardoppsettet ligger det en Ack-knapp ved clearknappen i bildet over. Problemet var at vi ikke fikk resatt minnecellen vi heftet til knappen. Løsningen ble å lage «Ack all alarms»knappen som setter og resetter minnecellen ved trykk som nevnt tidligere. I alarmserveren lager man en tekst som vil bli den teksten som vises på skjermen i det alarmen trigges. Dette bør være kort, men beskrivende for hvilken tilstand som har oppstått. Dette for å raskt kunne få forståelse for hva som har skjedd. Figur 96 iX-panel Alarmserver Side 57 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Man bør gi en alarm for den første feilen som oppstår. Feil som oppstår som en følge av den første feilen bør ikke gi alarm, da de som regel er «følgefeil», og ikke relevant. Hvordan dette skal presenteres velger man blant mange alternativ i menyen. Dersom man har flere operatørpanel eller skjermsystemer bør man velge en metode som avstiller og resetter alarmene på alle steder samtidig. Dette gjøres ved å velge «Remote Acknowledge» i innstillingene. Dette vil være et bit som kommer fra controlleren, men kan settes hvor som helst blant operatørpanelene. Dersom man kun har ett operatørpanel trenger man ikke å bruke denne funksjonen, da alarmviseren har en innebygget knapp for resetting av alarmer. 2.6.6 Operatørnivåer og rettigheter (Skrevet av AA) Både i InTouch og på operatørpanelet har vi laget forskjellige nivåer av rettigheter. Her vil vi tildele forskjellige muligheter til de ulike nivåene av kompetanse brukerne sitter med. Det laveste nivået 1 vil ha muligheter til å lese av driftsstatus på deler av prosessen, samt noen alarmer. Denne brukeren vil ha sterk begrensede muligheter for å skrive inn ny data til prosessen. Nivå 2 vil være den typiske operatøren som kjenner prosessen godt, og som vet hva han/hun holder på med. Dette vil tillate endring av settpunkt, samt kvittering av alarmer. Dette vil være nok rettigheter til å kjøre prosessen i en normal driftssituasjon. Nivå 3 vil være «superbrukeren». Dette er personell som har dyptgående kompetanse, og har ofte vært deltagende i designet av anlegget. Disse kan endre på måten prosessen kjøres på. Dette vil være endring av regulatortype og regulatorparameter. Her vil man som regel være svært restriktiv i å tildele personell tilgang, da disse innstillingene ofte er ett resultat av erfaringene fra lang tids drift av anlegget. Side 58 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Rettigheter for tilgangsnivåer i InTouch Variabel Operatør 1 Leses Operatør 2 Operatør 3 Operatør 1 Skrives Operatør 2 Operatør 3 X X Referanse X X X Nivå I tank Kp til regulator X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X Ti til regulator U0 til regulator Valg mellom P- og PI-regulator KpFF til regulator TdFF til regulator NFF til regulator Valg av forroverkoblingstype. Ingen, P, D, eller PD Magnetventiler utløp Utstrømming fra gjennomstrømningsmåler Start/stopp tilstand til pumpe Auto/manuell tilstand Pådrag Melding om alarmer Kvittering av alarmer Samplingstid tank X X X X X X X X X X X Side 59 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Rettigheter for tilgangsnivåer i iX-panelet Variabel Alle Skrive Lese Referanse X X Operatør 3 Skrive Lese X X Ekstra Manuelt pådrag X X X X Modus: Auto / Manuell X X X X Pådrag - X - X Nivå i tank - X - X Melding om alarmer - X - X X X X X Kp til regulator X X * Ti til regulator X X * Samplingstid X X * KpFF til foroverkobling X X * TdFF til foroverkobling X X * NFF til foroverkobling X X * Valg av modus serieregulator, P/PI Åpning utløp, magnetventiler X X * X X * Kvittering alarm Start/stopp pumpe X X X X Vi har valgt å legge til noen ekstra funksjoner til iX-panelet, utover de som er beskrevet i oppgaveteksten. Alle disse krever at brukeren logger inn med tilgangsnivå «Operatør 3». Side 60 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Innlogging iX panel Vi har i utgangspunktet ikke laget noen innlogging for bruk av operatørpanelet. Dette for at det skal være raskt og enkelt å bruke. På siden for innstillinger har vi likevel valgt å legge noen restriksjoner. Vi har laget knappen som sender deg til bildet «Innstillinger» på en slik måte at den kun er synlig når man har logget seg inn med brukeren «Operatør3» som i InTouch har alle rettigheter. Dette vil forhindre at en uautorisert bruker roter til innstillingene i prosessen. Figur 97 iX-panel innlogging Man kan også gjøre det nødvendig å logge seg inn for i det hele tatt å bruke panelet. Dette vi være aktuelt i områder der ikke-kyndige ferdes, og i offentlige rom. Da er det også lurt å benytte seg av muligheten for at panelet automatisk logger ut brukeren dersom denne er inaktiv i noen minutter. Dersom det er påkrevd kan man lage flere nivåer i rettighetene. Dette kan gjøres for å la noen personer endre standard verdier som settpunkt, modus, pådrag etc. Andre derimot kan ha tilgang til å endre regulatorinnstillinger, alarmgrenser, slette loggfiler eller andre kritiske håndgrep. Figur 98 iX-panel operatørnivåer Side 61 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.6.7 Web-grensesnitt for iX panel (Skrevet av ØE) iX TA-100 panelet har mulighet til å settes opp med webgrensesnitt, for fjernstyring av prosessen. Det er flere måter å gjøre dette på. Panelet har en innebygget webserver, som viser en hjemmeside som ligger lagret i panelet, denne er kommuniserer. Panelet kan også settes opp slik at man koblet til via en Java® Server, som viser skjermbildene fra panelet i webleseren. Via hjemmesiden (http://www.hekta.org/~p2ea1) er det lagt ut link til begge funksjonene. Webgrensesnitt Figur 99 iX-panel Webgrensesnitt For å lese ut og sette verdier benyttes det et innebygget Java Script i panelet. Vi hadde kun dokumentasjon på hvordan vi leste/skrev til dataregistre, og ikke til bit. Derfor fungerer ikke funksjonene som styrer pumpen, utløpet og kvittering av alarmer fra webgrensesnittet. Webgrensesnittet er kodet helt fra bunnen av, og formattert som selve hjemmesiden. Se kapittel 1.3 Hjemmesidefor mer informasjon om hvordan hjemmesiden er bygget opp. Figur 100 iX-panel HTML kode eksempel I figuren over ser vi eksempel på koden for å lese og endre referansen til systemet. Denne skriver til selve taggen i iX panelet. For å komme inn på webgrensesnittet må du logge inn. Brukernavn: Op3 Passord: gruppe1 Side 62 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Javagrensesnitt Når du logger inn ved hjelp av Java Serveren vil du få opp samme bilde som vises på skjermen til panelet, bare via webleseren. Link til å logge på finner du på hjemmesiden (http://www.hekta.org/~p2ea1). I panelet ligger det en eldre versjon av Java, versjon 7.0. Denne har flere sikkerhetshull, og sider som kjører denne versjonen blir automatisk blokkert av nyere versjoner av Java. Derfor må vi nedgradere versjonen av Java til en eldre, for å få denne funksjonen til å fungere. Dette medfører en sikkerhetsrisiko som vi ikke anbefaler. En bedre løsning vil være å fjernstyre PCen med InTouch på. Enten via RemoteDesktop i Windows eller programvare, som for eksempel TeamViewer. På den måten vil vi få samme muligheter til å betjene systemet som i InTouch. Side 63 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.7 Simulering Her kommer utdrag fra simuleringsnotatet som ble utformet tidligere i prosjektet. Hele Simuleringsnotatet finner du som vedlegg til denne rapporten, eller på hjemmesiden (http://www.hekta.org/~p2ea1). I simuleringsnotatet er det gjort en feil i modellen for utløpet, hvor maksimal utstrømning i FT01 er beregnet feil. Feilen ligger i at det er lagt til «offset» på +4mA to ganger. 2.7.1 Serieregulering (Skrevet av ØE) Figur 101 Simulering Serieregulering Ved bruk av serieregulering, regulerer vi på avviket mellom referansen og den målte verdien. Ziegler-Nichols metode For å komme frem til passende regulatorparametere har vi benyttet Ziegler-Nichols metode. Der har vi koblet vekk integrator delen av regulatoren, og skrudd opp Kp til vi har fått stående svingninger. Denne verdien for Kp blir den Ziegler Nicholls - Stående svingninger kritiske verdien, Kk. I vårt tilfelle var Kk = 20. Vi måler så periodetiden, som blir den kritiske periodetiden. Tk = 4.9 sekunder. PI-regulator: 𝐾𝑝 = 0.45 ∗ 𝐾𝑘 = 9.0 Tid i sekunder Figur 102 Simulering Ziegler-Nichols 𝑇𝑖 = 0.85 ∗ 𝑇𝑘 = 4.165 𝑠𝑒𝑘 P-regulator: 𝐾𝑝 = 0.5 ∗ 𝐾𝑘 = 10 Side 64 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Etterjustering Vi ser av grafene i 3.1.2 at vi har et innsvingningsforløp som er mer likt «minimum amplitude», hvor vi har rundt 10 svingninger før det blir stasjonært. Vi ønsker «minimum areal», hvor vi kun har ca. 4-6 svingninger. For å få til dette må vi etterjustere. Ser på faseforskyvningen mellom den målte verdien og pådraget fra regulatoren. Blå kurve: Målt verdi,y. Rød kurve: Pådrag, u Pådraget og den målte verdien ligger ca. 180 ° forskjøvet i forhold til hverandre. Dette tyder på at vi har P-svingninger, som vi må etterjustere for. [Kilde: Reguleringsteknikk Grunnkurs: Bjørvik og Hveem, s. 55] Tid i sekunder Figur 103 Simulering Etterjustering Blå kurve: Ziegler-Nichols Rød kurve: Etterjustert Vi forsøker å senke P-forsterkningen. Da vil vi få en langsommere og roligere prosess. Vi ender opp med en Pforsterkning på 5.5, med I-tid på 4.165 som vi fikk fra 3.1.1 Tid i sekunder Figur 104 Simulering Etterjustering Side 65 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 2.7.2 Foroverkobling (Skrevet av TM) I tillegg til en serieregulering av tanken, skulle vi dimensjonere en foroverkobling i reguleringssløyfen. En foroverkobling er enkelt forklart en ekstra regulator som leser direkte på forstyrrelsen, og kompenserer ved endringer. Figur 105 Simulering Forenklet foroverkobling Styrken til en foroverkobling er at man får kompensert for forstyrrelsen før den rekker å påvirke systemet i stor grad. I vårt tilfelle vil det si at foroverkoblingen registrerer økt flow ut av tanken hvis vi lukker to ventiler, og den vil kompensere ved å bidra til økt pådrag. Dette er mye raskere enn at vi skal få et avvik som registreres av nivåmåleren. Figur 106 Simulering Modell for foroverkobling Illustrasjonen viser hvordan vi har modellert foroverkoblingen i simulink. Side 66 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Vi fikk best resultat ved å bruke PI-regulator som hovedregulator, og PD-regulator til foroverkoblingen. Vi brukte følgende innstillinger: PI-reg: P: 5.5 I-tid: 4.165 sekunder PD-foroverkobling: P: 0.75 D-tid: 0.25 Vi fikk da følgende innsvingningsforløp: Innsvingningsforløp med PI-reg, og PD-foroverkobling Dette ga det minste dynamiske avviket og den korteste innsvingningstiden. Vi har også rundt 4 halvperioder i innsvingningene, slik vi skal ha i «minimum areal». Tid i sekunder Figur 107 Simulering Innsvingningsforløp med PD-foroverkobling Side 67 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 3.0 Innregulering (Skrevet av ØE og MB) 3.1 Krav til reguleringen Reguleringsmetodene som kan benyttes er følgende: Serieregulering: P-Regulator med nominelt pådrag. PI-Regulator (uten nom. pådrag). Foroverkobling: P-regulator med P-regulator foroverkobling PI-regulator med P-regulator foroverkobling. P-regulator med D-regulator foroverkobling. PI-regulator med D-regulator foroverkobling. P-regulator med PD-regulator foroverkobling. PI-regulator med PD-regulator foroverkobling. Kravene til reguleringen er: Intet stasjonært avvik. Innsvingningsforløp av typen «minimum areal». Kjappest mulig innsvingning til ±2% av måleområdet når referansen er 60%. For å klare kravet om intet stasjonært avvik må hovedregulatoren være av typen PI. 3.2 Manuelle innjusteringsmetoder Ziegler-Nichols For å finne regulatorparametere som fungere til prosessen prøvde vi først Ziegler-Nichols metode. Den går ut på å bruke kun P-regulator, for så å justere opp forsterkningen til vi får stående svingninger i prosessen. På denne måten finner vi kritisk forsterkning, Kk, til systemet. Periodetiden til svingningene utgjør den kritiske periodetiden, Tk. Vi hadde store problemer med å få stående svingninger i systemet. Vi prøvde helt opp til Kk = 60, noe som ville gitt en usannsynlig høy Kp i systemet. Vi måtte derfor gå over til en annen strategi for å finne parameterne. Side 68 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Manuell selvjustering Manuell selvjustering går ut på å bruke en P-regulator med maksimal P-forsterkning, som en Av/Påregulator. Ved å lese av grafen, og benytte formelen for Kk og Tk, finner vi forslag til parameterne. Figur 108 Manuell selvjustering 𝐾𝑘 = 𝑇𝑜𝑝𝑝 − 𝑡𝑖𝑙 − 𝑏𝑢𝑛𝑛 − 𝑝å𝑑𝑟𝑎𝑔 100 ∗ 1.27 = ∗ 1.27 = 15.875 𝑇𝑜𝑝𝑝 − 𝑡𝑖𝑙 − 𝑏𝑢𝑛𝑛 − 𝑝𝑟𝑜𝑠𝑒𝑠𝑠𝑣𝑒𝑟𝑑𝑖 8 𝑇𝑘 = 𝑝𝑒𝑟𝑖𝑜𝑑𝑒𝑡𝑖𝑑 𝑓𝑜𝑟 𝑒𝑛 𝑠𝑣𝑖𝑛𝑔𝑛𝑖𝑛𝑔 = 14 𝑠𝑒𝑘 Bruker tabellen for Ziegler-Nichols for å finne Kp og Ti for PI-reg: 𝐾𝑝 = 0.45 ∗ 𝐾𝑘 = 7.14 𝑇𝑖 = 0.85 ∗ 𝑇𝑘 = 11.9 𝑠𝑒𝑘 3.3 Serieregulering Her har vi benyttet parameterne vi fant i 3.2. Sprang i utløpet, fra 1 til 3 ventiler åpne. Vi ser at innsvingningsforløpet er innenfor kravet om ±2% av referansen innen ca. 3 sekunder. Vi har heller ikke innsvingningsforløp som er av typen «minimum areal». Vi har 1-2 halvperioder, noe som gir oss «minimum forstyrrelse». Figur 109 Serieregulering Side 69 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Vi har prøvd å senke P-forsterkningen for å komme nærmere et innsvingningsforløp av typen «minimum areal», men siden dynamikken til systemet er så hurtig, får vi sjeldent oversving i innsvingningsforløpet. Ved å kun benytte de tre magnetventilene i utløpet får vi ikke store utslag i det dynamiske avviket. 3.4 Foroverkobling Siden systemet i utgangspunktet er ganske hurtig, vil det være tilstrekkelig med å kun bruke serieregulering. Foroverkoblingen vil gjøre innsvingningen enda kjappere, når det kommer forstyrrelser i utløpet. Forskjellen er at vi nå får et oversving med i innsvingningsforløpet. Vi har prøvd med PD-foroverkobling, hvor vi har valgt KpFF = 0.7 og TdFF = 0.3 Vi ser at det dynamiske avviket ikke går utover grensen på ±2% av referansen. Figur 110 Foroverkobling Side 70 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 3.5 Parametere fra simulering Fra simuleringsnotatet fikk vi følgende parametere: PI-reg: P: 5.5 I-tid: 4.165 sekunder PD-foroverkobling: P: 0.75 D-tid: 0.25 Også her får vi et dynamisk avvik som ligger innenfor ±2% av referansen. Vi får ikke et oversving som vi hadde i simuleringen, men vi fikk to undersving, jf. Figur #. Generelt sett fungerer parameterne godt, og vi føler at dynamikken er forholdsvis lik som i modellene som er laget. Figur 111 Test av parametere Side 71 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 4.0 Testskjema 4.1 Operatørpanel Funksjon: Start/stopp pumpe Lukke alle magnetventiler Åpne/lukke 1 magnetventil (33% utløp) Åpne/lukke 2 magnetventiler (66% utløp) Åpne/lukke 3 magnetventiler (100% utløp) Nivåmåler % Flowmåler % Alarmtilstand: 25% under referanse Alarmtilstand: 25% over referanse Alarmtilstand: Nivå over 90% Alarmtilstand: Nivå under 10% Alarmtilstand < 5 sek. gir ingen alarm Ok/Not Ok: OK OK OK OK OK OK OK OK OK OK OK OK Alarmlampe fast lys OK Velge P-regulator Velge PI-regulator Sette manuelt pådrag Kvittering alarm Rykkfri overganger Regulatorparametere serieregulator Regulatorparametere foroverkobling Beholder verdier etter strømbrudd Avlesning pådrag OK OK OK OK Not OK OK OK OK OK Aksjon/Kommentar Starter/Stopper pumpe Lukker alle ventiler Åpner 1 ventil Åpner 2 ventiler Åpner 3 ventiler Måler nivået i prosent Måler utløpet i prosent 0.5 sek blink 0.5 sek blink 0.2 sek blink, pumpestopp 0.2 sek blink, pumpestopp Alarm utløses kun ved alarmtilstand over 5 sekunder Lampa lyser fast om alarmtilstand og det er kvittert Manuell/Auto-overgang fungerer ikke Får ikke satt desimaltall Får ikke satt desimaltall 4.2 InTouch Funksjon: Start/stopp pumpe Lukke alle magnetventiler Åpne/lukke 1 magnetventil (33% utløp) Åpne/lukke 2 magnetventiler (66% utløp) Åpne/lukke 3 magnetventiler (100% utløp) Nivåmåler % Flowmåler % Alarmtilstand: 25% under referanse Alarmtilstand: 25% over referanse Alarmtilstand: Nivå over 90% Alarmtilstand: Nivå under 10% Alarmtilstand < 5 sek. gir ingen alarm Ok/Not Ok: OK OK OK OK OK OK OK OK OK OK OK OK Alarmlampe fast lys OK P-regulator P-reg. med P-foroverkobling OK OK Aksjon/Kommentar Starter/Stopper pumpe Lukker alle ventiler Åpner 1 ventil Åpner 2 ventiler Åpner 3 ventiler Måler nivået i prosent Måler utløpet i prosent 0.5 sek blink 0.5 sek blink 0.2 sek blink, pumpestopp 0.2 sek blink, pumpestopp Alarm utløses kun ved alarmtilstand over 5 sekunder Lampa lyser fast om alarmtilstand og det er kvittert Side 72 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank P-reg. med D-foroverkobling P-reg. med PD-foroverkobling PI-regulator PI-reg. med P-foroverkobling PI-reg. med D-foroverkobling PI-reg. med PD-foroverkobling Sette manuelt pådrag Kvittering alarm Rykkfri overganger Regulatorparametere serieregulator Regulatorparametere foroverkobling Beholder verdier etter strømbrudd Avlesning pådrag OK OK OK OK OK OK OK OK Not OK OK OK OK OK Lite bidrag fra D-delen Lite bidrag fra D-delen Funksjon: Start/stopp pumpe Lukke alle magnetventiler Åpne/lukke 1 magnetventil (33% utløp) Åpne/lukke 2 magnetventiler (66% utløp) Åpne/lukke 3 magnetventiler (100% utløp) Nivåmåler % Flowmåler % Alarmtilstand: 25% under referanse Alarmtilstand: 25% over referanse Alarmtilstand: Nivå over 90% Alarmtilstand: Nivå under 10% Alarmtilstand < 5 sek. gir ingen alarm Ok/Not Ok: OK OK OK OK OK OK OK OK OK OK OK OK Alarmlampe fast lys OK Aksjoner/kommentar Starter/Stopper pumpe Lukker alle ventiler Åpner 1 ventil Åpner 2 ventiler Åpner 3 ventiler Måler nivået i prosent Måler utløpet i prosent 0.5 sek blink 0.5 sek blink 0.2 sek blink, pumpestopp 0.2 sek blink, pumpestopp Alarm utløses kun ved alarmtilstand over 5 sekunder Lampa lyser fast om alarmtilstand og det er kvittert P-regulator P-reg. med P-foroverkobling P-reg. med D-foroverkobling P-reg. med PD-foroverkobling PI-regulator PI-reg. med P-foroverkobling PI-reg. med D-foroverkobling PI-reg. med PD-foroverkobling Sette manuelt pådrag Kvittering alarm Rykkfri overganger Regulatorparametere serieregulator Regulatorparametere foroverkobling Beholder verdier etter strømbrudd Avlesning pådrag OK OK OK OK OK OK OK OK OK OK Not OK OK OK OK OK Lite bidrag fra D-delen Lite bidrag fra D-delen Manuell/Auto-overgang fungerer ikke 4.3 PLS Lite bidrag fra D-delen Lite bidrag fra D-delen Lite bidrag fra D-delen Lite bidrag fra D-delen Manuell/Auto-overgang fungerer ikke Side 73 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 5.0 Prosjektgjennomføring, erfaringer og konklusjon 5.1 Prosjektgjennomføring (Skrevet av ØE) Gruppa har jobbet jevnt og trutt igjennom hele prosjektperioden, unntatt i påsken, hvor vi alle hadde ferie. Alt arbeid har i utgangspunktet foregått på dagtid. I periodene før innlevering av rapportene har vi lagt ned noe «overtid», med jobbing til ca. 19-20 og 2 helger med jobbing. Vi har ikke klart å bli ferdige med «Entank» delen i god tid før fristen som vi hadde planlagt. Noen uforutsette problemer har oppstått, og det har vært mye prøving og feiling med programmeringen. Vi har i utgangspunktet latt de prosjektdeltakerne med minst PLS og HMI erfaring få ansvaret for akkurat disse delene, og alle har hatt godt utbytte av erfaringen de nå har fått. Igjennom hele prosjektperioden har det også vært tilfeller hvor prosjektmedlemmene har hatt forpliktelser på privat hold. Vi har derfor mistet ca. 25 arbeidsdager totalt i gruppen. Dette har vært legitime fravær som for eksempel militærøvelse, syke barn, jobb eller reise. Tross dette har vi klart å følge de tidsfristene som har vært gitt. 5.2 Erfaringer og forslag til forbedringer (Skrevet av AA) Denne riggen er laget som en teststasjon for studentoppgaver. Den er derfor ikke laget optimalt. Dette har medført noen ekstra utfordringer for oss. Noen av disse kunne vært unngått med små endringer. Ett eksempel på dette er røret som går fra pumpen til tanken. Innløpet i tanken er avsluttet i toppen av tanken. Dette gjør at det faller langt ned før det treffer overflaten. Slike plask i overflaten skaper slag på trykksensoren, som igjen lager skjelvinger i signalet for nivå. Dette røret kunne med fordel være strukket helt ned til bunnen av tanken. Dette kunne vi prøvd å filtrere bort med ett digitalt filter i PLSen. Normalt gjøres dette ved å ta ett gjennomsnitt av for eksempel 5 målinger. Da vil man som regel utjevne slike topper. Her må man prøve seg fram. Noe av dette vil også bli filtrert bort av ett godt dimensjonert analogt filter. Magnetventilene lager store «peaker»/spikere i det målte nivået når de stenges. Dette kan vi se dersom vi logger inngangene. Noe av dette hadde blitt borte om det hadde vært brukt skjermet kabel til spolene. Dette vil også bli noe dempet av et analogt filter, men her er plasseringen av filteret relevant for effektiviteten, da støyen kan tilføres på det allerede filtrerte signalet dersom filteret plasseres for nær støykilden. Frekvensomformeren som driver pumpen er også en stor støykilde. Her er det vanlig å bruke skjermet kabel, noe som ikke er brukt her. Man må da bruke EMC kabelinnføringsnippel, og terminere denne riktig i henhold til brukermanualen for frekvensomformeren. Dette er ett krav i forskriftene angående EMC støy, og at man skal sikre at man ikke lager problemer i form av støy for andre. Side 74 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank Nivåsensor, strømningsmåler og reguleringsventil er tilkoblet med uskjermet kabel. Dette gjøres normalt ikke. Man bruker en kabel med flettet skjerm rundt hele kabelen, slik at støyen inn på kabelen blir redusert så mye som mulig. Denne støyen vil da bli ledet til jord, normalt i den enden som er tilkoblet I/O modulen. Dette må man teste ut i hvert enkelt tilfelle, da man også kan bli tvunget til å koble til skjermen i begge ender. Man må da først kontrollere anleggets generelle jording, da manglende utjevningsforbindelser kan føre til store problemer. Da først og fremst med tanke på at signalkablene vil fungere som utjevningsforbindelser. 5.3 Konklusjon For å unngå stasjonært avvik er vi nødt til å bruke PI-regulator. PI-regulatoren virker såpass raskt på systemet, at en foroverkobling nesten blir overflødig. Vi la merke til at det var fort gjort å la seg rive med under utviklingen av HMI-biten. Læringskurven er bratt og man kan fort gå i den fellen hvor man lager et overkomplisert brukergrensesnitt med mange overflødige funksjoner. Kravet til innsvingningsforløpet var minimum areal. Vi endte opp med minimum forstyrelse, som i grunn er et bedre innsvingningsforløp. Regulatorparameterne vi fikk ut fra simuleringsnotatet stemte meget godt overens med dynamikken til riggen, vi endte derfor opp med å bruke disse parameterne. Antialiasingfilteret fungerte meget godt, da det fjernet uønsket støy og tjente sin hensikt. Vi har også sett viktigheten av å ha god oversikt over adresser som er i bruk, og at disse blir kontinuerlig oppdatert. Trondheim 28.04.2015 Torbjørn Morken Øyvind Eklo Eyvind Bjørsland Magnus Bergsbakk Anders Aabakken Side 75 av 75 Prosjekt i styresystemer 2015 Gruppe 1 Rapport Entank 6.0 Vedlegg Vedleggene er lagt ved som filer i rapporten. Dobbelt klikk på ikonet for å åpne vedlegget. For å åpne vedleggene trenger du internett tilkobling. 6.1 PLS program Master pls_master_entank.pdf Her ligger dokumentasjonen for Master PLSen 6.2 PLS program Slave pls_slave_entank.pdf Her ligger dokumentasjon for Slave PLSen 6.3 Simuleringsnotat Arbeidsnotat - Simulering.pdf Her ligger Arbeidsnotatet fra simulering av tanken.
© Copyright 2025