Tuesday, 14 November 2017

Handels System Arkitektur Diagram


LMAX-arkitekturen De siste årene har vi hørt at gratis lunsj er over1 - vi kan ikke forvente økning i individuell CPU-hastighet. Så for å skrive hurtig kode må vi eksplisitt bruke flere prosessorer med samtidig programvare. Dette er ikke gode nyheter - å skrive samtidig kode er veldig vanskelig. Låser og semaforer er vanskelig å argumentere for og vanskelig å teste - det betyr at vi bruker mer tid på å bekymre oss for å tilfredsstille datamaskinen enn vi løser domeneproblemet. Ulike samtidige modeller, som skuespillere og programvaretransaksjonsminne, tar sikte på å gjøre dette enklere - men det er fortsatt en byrde som introduserer feil og kompleksitet. Så jeg var fascinert med å høre om en prat på QCon London i mars i fjor fra LMAX. LMAX er en ny finansiell handelsplattform for detaljhandel. Dens forretningsinnovasjon er at det er en detaljhandel plattform - slik at alle kan handle i en rekke finansielle derivatprodukter2. En handelsplattform som dette trenger svært lav ventetid - handler må behandles raskt fordi markedet beveger seg raskt. En detaljhandel plattform legger til kompleksitet fordi det må gjøre dette for mange mennesker. Så resultatet er flere brukere, med mange handler, som alle må behandles raskt.3 Gitt skiftet til multi-core tenkning, ville denne typen krevende ytelse naturligvis foreslå en eksplisitt samtidig programmeringsmodell - og dette var faktisk deres Utgangspunktet. Men det som fikk folk oppmerksomhet på QCon var at dette var ikke der de endte opp. Faktisk endte de med å gjøre all forretningslogikk for plattformen: alle handler, fra alle kunder, i alle markeder - på en enkelt tråd. En tråd som vil behandle 6 millioner ordrer per sekund ved hjelp av råvarehardware.4 Behandling av mange transaksjoner med lav ventetid og ingen av kompleksiteten til samtidskode - hvordan kan jeg motstå å grave inn i det Heldigvis har en annen forskjell LMAX til andre finansielle selskaper det De er ganske glade for å snakke om deres teknologiske beslutninger. Så nå har LMAX vært i produksjon for en stund sin tid til å utforske deres fascinerende design. Samlet struktur Figur 1: LMAXs arkitektur i tre blokker På toppnivå har arkitekturen tre deler business logic processor5 input disruptor output disruptors Som navnet tilsier, håndterer forretningslogikkprosessoren all forretningslogikken i applikasjonen. Som jeg angitt ovenfor, gjør det dette som et enkelt-threaded java-program som reagerer på metallsamtaler og produserer utgangshendelser. Derfor er det et enkelt java-program som ikke krever noen plattformsrammer for å kjøre annet enn selve JVM-en, noe som gjør det enkelt å kjøre i testmiljøer. Selv om Business Logic Processor kan kjøre i et enkelt miljø for testing, er det nok mer involvert koreografi for å få det til å kjøre i en produksjonsinnstilling. Inngangsmeldinger må tas av en nettverksgateway og umassortert, replikert og journalisert. Utdata meldinger må marshales for nettverket. Disse oppgaver håndteres av inngangs - og utgangsforstyrrelser. I motsetning til Business Logic Processor er disse samtidige komponenter, siden de involverer IO-operasjoner som er både sakte og uavhengige. De ble designet og bygget spesielt for LMAX, men de (som den generelle arkitekturen) gjelder andre steder. Business Logic Processor Holder alt i minne Forretningslogikkprosessoren tar inn meldinger i rekkefølge (i form av en metodeanrop), kjører forretningslogikk på den og sender ut utgående hendelser. Den opererer helt i minnet, det er ingen database eller annen vedvarende butikk. Å holde all data i minnet har to viktige fordeler. For det første er det raskt, det er ingen database for å gi langsom IO for tilgang, og det er heller ingen transaksjonsadferd som skal utføres siden all behandling foregår i rekkefølge. Den andre fordelen er at det forenkler programmering - det er ingen objektrelasjonell kartlegging å gjøre. Alt koden kan skrives med Javas objektmodell uten å måtte gjøre kompromisser for kartlegging til en database. Bruke en minnekonstruksjon har en viktig konsekvens - hva skjer hvis alt går i stykker Selv de mest robuste systemene er sårbare for at noen trekker strømmen. Hjertet i å håndtere dette er Event Sourcing - noe som betyr at den nåværende tilstanden til Business Logic Processor er helt avledbar ved å behandle inngangshendelsene. Så lenge inngangshendelsesstrømmen holdes i en varig butikk (som er en av jobbene til inngangsforstyrrelsen), kan du alltid gjenskape den nåværende tilstanden til forretningslogikkmotoren ved å spille av hendelsene igjen. En god måte å forstå dette på er å tenke på et versjonskontrollsystem. Versjonskontrollsystemer er en rekke forpliktelser, når som helst du kan bygge en arbeidskopi ved å bruke disse forpliktelsene. VCS er mer kompliserte enn Business Logic Processor fordi de må støtte forgrening, mens Business Logic Processor er en enkel sekvens. Så i teorien kan du alltid gjenoppbygge tilstanden til Business Logic Processor ved å reprosessere alle hendelsene. I praksis vil det imidlertid ta for lang tid å måtte spinne opp. Så, akkurat som med versjonskontrollsystemer, kan LMAX lage stillbilder av Business Logic Processor-tilstanden og gjenopprette fra øyeblikksbilder. De tar et øyeblikksbilde hver natt i perioder med lav aktivitet. Omstart av forretningslogikkprosessoren er rask, en fullstendig omstart - inkludert omstart av JVM, lasting av et nytt øyeblikksbilde og gjengivelse av en dagers dagbok - tar mindre enn et minutt. Snapshots gjør det mulig å starte en ny Business Logic Processor raskere, men ikke raskt nok bør en Business Logic Processor krasje klokken 14:00. Som følge heraf holder LMAX flere Business Logic-prosessorer i gang hele tiden6. Hver inngangshendelse behandles av flere prosessorer, men alt annet enn en prosessor har sin utgang ignorert. Skulle levende prosessor mislykkes, bytter systemet til en annen. Denne muligheten til å håndtere mislykkes er en annen fordel ved å bruke Event Sourcing. Ved hendelse innhenting i replikaer kan de bytte mellom prosessorer i løpet av mikrosekunder. I tillegg til å ta snapshots hver kveld, starter de også Business Logic Processors på nytt hver natt. Replikasjonen gjør det mulig for dem å gjøre dette uten nedetid, slik at de fortsetter å behandle handler 247. For mer bakgrunn på Event Sourcing, se utkastsmønsteret på nettstedet mitt for noen år siden. Artikkelen er mer fokusert på å håndtere tidsrelaterte forhold enn de fordelene som LMAX bruker, men det forklarer kjernen ideen. Event Sourcing er verdifull fordi det tillater at prosessoren kjører helt i minnet, men det har en annen betydelig fordel for diagnostikk. Hvis det oppstår en uventet oppførsel, kopierer laget rekkefølgen av hendelser til utviklingsmiljøet og gjengir dem igjen. Dette gjør at de kan undersøke hva som skjedde mye lettere enn det er mulig i de fleste miljøer. Denne diagnostiske evnen strekker seg til bedriftsdiagnostikk. Det er noen forretningsoppgaver, for eksempel i risikostyring, som krever betydelig beregning som ikke er nødvendig for behandling av ordrer. Et eksempel er å få en liste over de 20 beste kundene etter risikoprofil basert på deres nåværende handelsstillinger. Teamet håndterer dette ved å spole opp en replikat domenemodell og utføre beregningen der, der det ikke vil forstyrre kjernevalgsbehandlingen. Disse analyse domene modellene kan ha variant datamodeller, holde forskjellige datasett i minnet, og kjøre på forskjellige maskiner. Tuning ytelse Så langt har jeg forklart at nøkkelen til hastigheten til Business Logic Processor gjør alt i rekkefølge, i minnet. Bare å gjøre dette (og ingenting veldig dumt) lar utviklere skrive kode som kan behandle 10K TPS7. De fant da at det å konsentrere seg om de enkle elementene i god kode kunne føre til dette i 100K TPS-serien. Dette trenger bare velkjente kode og små metoder - i hovedsak lar dette Hotspot gjøre en bedre jobb med å optimalisere og at CPUer skal være mer effektive når det gjelder å cache koden som kjører. Det tok litt mer klokhet å gå opp en annen størrelsesorden. Det finnes flere ting som LMAX-teamet har funnet å være nyttig for å komme seg dit. Den ene var å skrive tilpassede implementeringer av java samlingene som ble designet for å være hurtigbuffer og forsiktig med søppel8. Et eksempel på dette bruker primitive java lengder som hashmap-nøkler med en spesielt skrevet array-støttet kartimplementering (LongToObjectHashMap). Generelt har de funnet at valget av datastrukturer ofte gjør stor forskjell. De fleste programmører tar bare hva som helst liste de brukte sist gang, i stedet for å tenke hvilken implementering som er den rette for denne konteksten.9 En annen teknikk for å nå det øverste nivået av ytelse er å sette oppmerksomhet i ytelsestesting. Jeg har lenge lagt merke til at folk snakker mye om teknikker for å forbedre ytelsen, men det som virkelig gjør en forskjell er å teste den. Selv gode programmerere er veldig gode til å konstruere ytelsesargumenter som ender opp med å bli feil, så de beste programmene foretrekker profiler og testfall til spekulasjon.10 LMAX-teamet har også funnet ut at skrivetester først er en svært effektiv disiplin for ytelsestester. Programmeringsmodell Denne prosesseringsstilen innfører noen begrensninger i måten du skriver og organiserer forretningslogikken. Den første av disse er at du må tømme noen interaksjon med eksterne tjenester. Et eksternt serviceanrop kommer til å være sakte, og med en enkelt tråd stopper hele bestillingsbehandlingsmaskinen. Som et resultat kan du ikke ringe til eksterne tjenester innenfor forretningslogikken. I stedet må du fullføre denne samspillet med en utgangshendelse, og vente på en annen inngangshendelse for å plukke den opp igjen. Jeg bruker et enkelt ikke-LMAX-eksempel for å illustrere. Tenk deg at du lager en bestilling for gelébønner med kredittkort. Et enkelt detaljhandelssystem vil ta bestillingsinformasjonen din, bruk en kredittkortvalideringstjeneste for å sjekke kredittkortnummeret ditt, og bekreft bestillingen din - alt innen en enkelt operasjon. Tråden som behandler bestillingen din, vil blokkere mens du venter på at kredittkortet skal kontrolleres, men det vil ikke være veldig lenge for brukeren, og serveren kan alltid kjøre en annen tråd på prosessoren mens den venter. I LMAX-arkitekturen deler du denne operasjonen i to. Den første operasjonen vil fange opp bestillingsinformasjonen og avsluttes ved å utstede en hendelse (kredittkortvalidering forespurt) til kredittkortselskapet. Forretningslogikkprosessoren vil deretter fortsette å behandle hendelser for andre kunder inntil den mottok et kredittkort-validert arrangement i sin inngangshendelsesstrøm. Ved behandling av hendelsen ville det utføre bekreftelsesoppgavene for den ordren. Arbeidet i denne typen hendelsesdrevet, asynkron stil er noe uvanlig - selv om bruk av asynkroni for å forbedre responsen til et program er en kjent teknikk. Det hjelper også forretningsprosessen å være mer motstandsdyktig, da du må være mer eksplisitt i å tenke på de forskjellige tingene som kan skje med fjernprogrammet. Et annet trekk ved programmeringsmodellen ligger i feilhåndtering. Den tradisjonelle modellen for økter og databasetransaksjoner gir en nyttig feilhåndteringsevne. Skulle noe gå galt, er det lett å kaste bort alt som skjedde så langt i samspillet. Session data er forbigående, og kan kasseres, på bekostning av noen irritasjon for brukeren hvis i midten av noe komplisert. Hvis det oppstår en feil på databasesiden, kan du tilbakestille transaksjonen. LMAXs i-minne strukturer er vedvarende på tvers av inngangshendelser, så hvis det er en feil, er det viktig å ikke forlate det minnet i en inkonsekvent tilstand. Men det er ingen automatisert tilbakeleveringsfasilitet. Som en konsekvens legger LMAX-teamet mye oppmerksomhet på å sikre at inngangshendelsene er fullt gyldige før de gjør en mutasjon av den vedvarende tilstanden i minnet. De har funnet ut at testing er et viktig verktøy for å spyle ut slike problemer før de går i produksjon. Input og Output Disruptors Selv om forretningslogikken forekommer i en enkelt tråd, er det en rekke oppgaver som skal gjøres før vi kan påberope en forretningsmetode metode. Den opprinnelige inngangen til behandling kommer av ledningen i form av en melding, denne meldingen må være ukjent i et form som er praktisk for Business Logic Processor å bruke. Event Sourcing er avhengig av å holde en holdbar journal over alle inngangshendelser, så hver innspillingsmelding må journaliseres på en holdbar butikk. Endelig bygger arkitekturen på en klynge av forretningslogikkprosessorer, så vi må replikere inngangsmeddelelsene over hele klyngen. På samme måte på utgangssiden må utgangshendelsene marshales for overføring over nettverket. Figur 2: Aktiviteten utført av inngangsforstyrrelsen (ved bruk av UML-aktivitetsdiagramnotasjon) Replikatoren og journalen involverer IO og er derfor relativt sakte. Etter alt den sentrale ideen om Business Logic Processor er at det unngår å gjøre noen IO. Også disse tre oppgavene er relativt uavhengige, alle må gjøres før Business Logic Processor jobber med en melding, men de kan gjøres i hvilken som helst rekkefølge. Så i motsetning til Business Logic Processor, hvor hver handel endrer markedet for etterfølgende bransjer, er det naturlig passform for samtidighet. For å håndtere denne samtidigheten utviklet LMAX-teamet en spesiell concurrency-komponent, som de kaller Disruptor 11. LMAX-teamet har gitt ut kildekoden for Disruptor med en åpen kildekode lisens. På rå nivå kan du tenke på en Disruptor som en multicastgrafikk av køer der produsentene legger objekter på den som sendes til alle forbrukerne for parallelt forbruk gjennom separate nedstrøms køer. Når du ser på innsiden ser du at dette nettverket av køer egentlig er en enkelt datastruktur - en ringbuffer. Hver produsent og forbruker har en sekvenskant som angir hvilket spor i bufferen den for tiden arbeider med. Hver produsent forbruker skriver sin egen sekvens teller, men kan lese de andre sekvens tellere. På denne måten kan produsenten lese forbrukerens tellere for å sikre at sporet det vil skrive inn, er tilgjengelig uten låser på tellerne. På samme måte kan en forbruker sørge for at det kun behandler meldinger når en annen forbruker er ferdig med det ved å se på tellerne. Figur 3: Inndataforstyrrelseskoordinatene en produsent og fire forbrukere Utgangsforstyrrelser er liknende, men de har bare to sekvensielle forbrukere for marshaling og output.12 Utgangshendelser er organisert i flere emner, slik at meldinger kun kan sendes til mottakere som er interessert i dem. Hvert emne har sin egen forstyrrelse. De forstyrrelser jeg har beskrevet er brukt i en stil med en produsent og flere forbrukere, men dette er ikke en begrensning av utformingen av disruptoren. Forstyrrelsen kan også fungere med flere produsenter. I dette tilfellet trenger det likevel ikke lås. 13 En fordel med disruptor-designen er at det gjør det lettere for forbrukerne å hente seg raskt hvis de løper inn i et problem og faller bak. Hvis unmarshaleren har et problem ved behandling på sporet 15 og returnerer når mottakeren er på sporet 31, kan den lese data fra spalter 16-30 i en batch for å fange opp. Denne batchavlesningen av dataene fra forstyrrelsen gjør det lettere for forbrukere å fange opp raskt, og dermed redusere total latens. Ive beskrev ting her, med en hver av journalisten, replikatoren og unmarshaler - dette er faktisk hva LMAX gjør. Men designet ville tillate at flere av disse komponentene skulle kjøre. Hvis du kjørte to journalister, ville man ta selvsporene og den andre journalisten ville ta de ulike sporene. Dette tillater videre samtidighet av disse IO-operasjonene dersom dette måtte bli nødvendig. Ringbuffere er store: 20 millioner spor for inngangsbuffer og 4 millioner spor for hver av utgangsbuffere. Sekvenstellerne er 64bit lange heltall som øker monotont, til og med når ringsporene vikles.14 Bufferen er satt til en størrelse som er en kraft på to, slik at kompilatoren kan gjøre en effektiv moduloperasjon for å kartlegge fra sekvensnummeret til spornummeret . I likhet med resten av systemet hopper disruptorsene over natten. Denne sprettingen gjøres hovedsakelig for å tørke minne slik at det er mindre sjanse for en dyr søppelsamlingshendelse under handel. (Jeg synes også det er en god vane å regelmessig starte på nytt, slik at du skal øve på hvordan du gjør det for nødsituasjoner.) Jobbmesterens jobb er å lagre alle hendelsene i en holdbar form, slik at de kan spilles på igjen hvis noe går galt. LMAX bruker ikke en database for dette, bare filsystemet. De streamer hendelsene på disken. I moderne termer er mekaniske disker horribelt sakte for tilfeldig tilgang, men veldig rask for streaming - derfor er taglinjeskiven den nye båndet.15 Tidligere nevnte jeg at LMAX kjører flere kopier av sitt system i en klynge for å støtte rask failover . Replikatoren holder disse nodene synkronisert. All kommunikasjon i LMAX bruker IP multicasting, slik at klienter ikke trenger å vite hvilken IP-adresse som er hovednoden. Bare hovednoden lytter direkte til innspillingshendelser og kjører en replikator. Replikatoren sender inn hendelsene til slave noder. Skal hovednoden gå ned, blir den manglende hjerteslag lagt merke til, en annen node blir mester, begynner å behandle inngangshendelser, og starter replikatoren. Hver knute har sin egen inngangsforstyrrelser og har dermed sin egen journal og gjør sin egen unmarshaling. Selv med IP multicasting, er det fortsatt nødvendig med replikering fordi IP-meldinger kan komme i en annen rekkefølge på forskjellige noder. Hovednoden gir en deterministisk sekvens for resten av behandlingen. Unmarshaler skifter hendelsesdataene fra ledningen til en java-gjenstand som kan brukes til å påberope segferd på Business Logic Processor. Derfor, i motsetning til de andre forbrukerne, må den modifisere dataene i ringbufferen, slik at den kan lagre dette ubemerkede objektet. Regelen her er at forbrukerne har lov til å skrive til ringbufferen, men hvert skrivbart felt kan bare ha en parallell forbruker som har lov til å skrive til den. Dette bevarer prinsippet om bare å ha en enkelt forfatter. 16 Figur 4: LMAX-arkitekturen med disruptors utvidet Disruptoren er en generell komponent som kan brukes utenfor LMAX-systemet. Vanligvis er finansielle selskaper veldig hemmelige om systemene sine, og holder seg stille selv om ting som er tydelige for deres virksomhet. Ikke bare har LMAX vært åpen om sin overordnede arkitektur, de har åpnet forstyrrelseskoden - en handling som gjør meg veldig glad. Ikke bare vil dette tillate andre organisasjoner å benytte seg av forstyrrelsen, det vil også tillate mer testing av sine samtidige egenskaper. Køer og deres mangel på mekanisk sympati LMAX-arkitekturen fanget folks oppmerksomhet fordi det er en helt annen måte å nærme seg et høyytelsessystem til hva folk flest tenker på. Så langt har jeg snakket om hvordan det fungerer, men har ikke dratt for mye inn i hvorfor det ble utviklet på denne måten. Denne fortellingen er interessant i seg selv, fordi denne arkitekturen ikke bare ble vist. Det tok lang tid å prøve flere konvensjonelle alternativer, og innse hvor de var feil, før laget slo seg på denne. De fleste forretningssystemer i disse dager har en kjernearkitektur som er avhengig av flere aktive økter koordinert gjennom en transaksjonsbasert database. LMAX-teamet var kjent med denne tilnærmingen, og trygg på at det ikke ville fungere for LMAX. Denne vurderingen ble grunnlagt i erfaringene fra Betfair - morselskapet som etablerte LMAX. Betfair er et spillområde som gjør at folk kan satse på sportsbegivenheter. Den håndterer svært høye trafikkvolumer med mye påstand - sportsspill har en tendens til å sprekke rundt bestemte hendelser. For å gjøre dette arbeidet har de en av de hotteste databaseinstallasjonene rundt, og har måttet gjøre mange unaturlige handlinger for å få det til å fungere. Basert på denne erfaringen visste de hvor vanskelig det var å opprettholde Betfairs ytelse og var sikker på at denne typen arkitektur ikke ville fungere for den svært lave ventetiden som et handelssted ville kreve. Som et resultat måtte de finne en annen tilnærming. Deres opprinnelige tilnærming var å følge det som så mange sier i disse dager - for å få høy ytelse må du bruke eksplisitt samtidighet. For dette scenariet betyr dette at ordrer kan behandles av flere tråder parallelt. Men som det ofte er tilfellet med samtidighet, kommer vanskeligheten fordi disse trådene må kommunisere med hverandre. Behandler en ordre endrer markedsforholdene og disse betingelsene må kommuniseres. Tilnærmingen de utforsket tidlig var skuespillermodellen og sin fetter SEDA. Skuespillermodellen er avhengige av uavhengige, aktive objekter med egen tråd som kommuniserer med hverandre via køer. Mange mennesker finner denne typen samtidighetsmodell mye lettere å håndtere enn å prøve å gjøre noe basert på låsende primitiver. Laget bygde en prototype utveksling ved hjelp av skuespillermodellen og gjorde ytelsestester på den. Det de fant var at prosessorene brukte mer tidskrevende køer enn å gjøre den virkelige logikken til applikasjonen. Kjøttilgang var en flaskehals. Når du trykker på ytelse som dette, begynner det å bli viktig å ta hensyn til måten moderne maskinvare er konstruert på. Uttrykket Martin Thompson liker å bruke er mekanisk sympati. Begrepet kommer fra racerbilkjøring, og det gjenspeiler at sjåføren har en medfødt følelse for bilen, slik at de kan føle hvordan man får det beste ut av det. Mange programmerere, og jeg bekrefter at jeg faller inn i denne leiren, har ikke mye mekanisk sympati for hvordan programmering samhandler med maskinvare. Hva er verre er at mange programmerere tror de har mekanisk sympati, men det bygger på ideer om hvordan maskinvare brukes til å jobbe som nå er mange år utdatert. En av de dominerende faktorene med moderne CPUer som påvirker latens, er hvordan CPUen samhandler med minne. Disse dagene som går til hovedminne er en veldig langsom operasjon i CPU-vilkår. CPUer har flere nivåer av cache, hver av disse er betydelig raskere. Så for å øke hastigheten vil du få koden og dataene i de cachene. På et nivå hjelper skuespillermodellen her. Du kan tenke på en skuespiller som sitt eget objekt som klynger kode og data, som er en naturlig enhet for caching. Men skuespillere trenger å kommunisere, som de gjør gjennom køer - og LMAX-teamet observerte at det er køene som forstyrrer caching. Forklaringen løper slik: For å kunne legge inn data i en kø, må du skrive til den køen. På samme måte, for å ta data ut av køen, må du skrive til køen for å utføre fjerningen. Dette er skrivekvittering - mer enn en klient må kanskje skrive til samme datastruktur. For å håndtere skriveforespørsler bruker en kø ofte låser. Men hvis en lås brukes, kan det føre til en kontekstbryter til kjernen. Når dette skjer, vil prosessoren involvert sannsynligvis miste dataene i sine caches. Konklusjonen de kom til var å få den beste caching-oppførselen, du trenger et design som bare har en kjerne som skriver til en hvilken som helst minnested17. Flere lesere er fine, prosessorer bruker ofte spesielle høyhastighetsforbindelser mellom sine caches. Men køer feiler prinsippet om enforfatter. Denne analysen førte LMAX-teamet til et par konklusjoner. For det første førte det til utformingen av forstyrrelsen, som bestemt følger etterforfatterens begrensning. For det andre førte det til ideen om å utforske den enkeltrådede forretningslogikkmetoden, og spørsmålet om hvor fort en enkelt tråd kan gå hvis den er frigjort av likviditetsstyring. Essensen av å jobbe på en enkelt tråd, er å sikre at du har en tråd som kjører på en kjerne, cachene varmes opp, og så mye minnestilgang som mulig går til cachene i stedet for hovedminne. Dette betyr at både koden og datasettet må være så konsekvent tilgjengelig som mulig. Ved å holde små objekter med kode og data sammen, kan de også byttes mellom cachene som en enhet, forenkle hurtigbehandlingen og igjen forbedre ytelsen. En viktig del av veien til LMAX-arkitekturen var bruken av ytelsestesting. Betraktningen og nedleggelsen av en skuespillerbasert tilnærming kom fra bygging og ytelsesprøving av en prototype. Tilsvarende ble mye av trinnene i å forbedre ytelsen til de forskjellige komponentene aktivert ved ytelsestester. Mekanisk sympati er veldig verdifull - det hjelper til med å danne hypoteser om hvilke forbedringer du kan gjøre, og hjelper deg med å videresende trinn i stedet for bakover - men til slutt gir testen deg overbevisende bevis. Prestasjonsprøving i denne stilen er imidlertid ikke et godt forstått emne. LMAX-teamet legger regelmessig vekt på at det å oppnå meningsfulle ytelsestester er ofte vanskeligere enn å utvikle produksjonskoden. Igjen er mekanisk sympati viktig for å utvikle de riktige testene. Testing av en lavnivåkompatibilitetskomponent er meningsløs, med mindre du tar hensyn til CPU-prosessens cachingegenskaper. En spesiell leksjon er viktigheten av å skrive tester mot nullkomponenter for å sikre at ytelsestesten er rask nok til virkelig å måle hvilke virkelige komponenter som gjør. Å skrive rask testkode er ikke enklere enn å skrive rask produksjonskode, og det er for lett å få falske resultater fordi testen ikke er så fort som komponenten prøver å måle. Skal du bruke denne arkitekturen Ved første øyekast ser denne arkitekturen ut til å være en veldig liten nisje. Etter at alle sjåførene som førte til det, var å kunne kjøre mange komplekse transaksjoner med svært lav ventetid - de fleste applikasjoner trenger ikke å kjøre på 6 millioner TPS. Men det som fascinerer meg om denne applikasjonen, er at de har endte med et design som fjerner mye av programmeringskompleksiteten som plager mange programvareprosjekter. Den tradisjonelle modellen av samtidige økter rundt en transaksjonsbasert database er ikke fri for problemer. Det er vanligvis en ikke-trivial innsats som går inn i forholdet til databasen. Objektrelaterte kartverktøy kan hjelpe mye av smerten ved å håndtere en database, men det handler ikke om alt. Mest ytelse tuning av enterprise applikasjoner innebærer futzing rundt med SQL. I disse dager kan du få mer hovedminne i serverne dine enn oss gamle gutta kunne få som diskplass. Flere og flere applikasjoner er ganske i stand til å sette alt sitt arbeidssett i hovedminne, og dermed eliminere en kilde til både kompleksitet og treghet. Event Sourcing gir en måte å løse holdbarhetsproblemet for et in-memory-system, kjører alt i en enkelt tråd, løser problemet med samtidighet. LMAX-opplevelsen antyder at så lenge du trenger mindre enn noen få millioner TPS, har du nok ytelse på hodet. Det er en betydelig overlapping her med den økende interessen for CQRS. En hendelse som er hentet, er et naturlig valg for kommandosiden til et CQRS-system. (Selv om LMAX-teamet for øyeblikket ikke bruker CQRS.) Så det som indikerer at du ikke bør gå ned denne banen. Dette er alltid et vanskelig spørsmål for lite kjente teknikker som dette, siden yrket trenger mer tid til å utforske sine grenser. Et utgangspunkt er imidlertid å tenke på egenskapene som oppmuntrer arkitekturen. En egenskap er at dette er et tilkoblet domene der prosessering av en transaksjon alltid har potensial til å endre hvordan de følgende behandles. Med transaksjoner som er mer uavhengige av hverandre, trenger det mindre å koordinere, så bruk av separate prosessorer som går parallelt blir mer attraktive. LMAX konsentrerer seg om å finne konsekvensene av hvordan hendelser forandrer verden. Mange steder handler om å ta en eksisterende butikk med informasjon og gjøre ulike kombinasjoner av den informasjonen til så mange eyeballs som de kan finne - for eksempel tenk på et hvilket som helst medieområde. Her fokuserer den arkitektoniske utfordringen ofte på å få cachene dine riktig. Et annet kjennetegn ved LMAX er at dette er et backend-system, så det er rimelig å vurdere hvor aktuelt det ville være for noe som handler i en interaktiv modus. Økende webapplikasjon hjelper oss med å bli vant til server-systemer som reagerer på forespørsler, et aspekt som passer godt inn i denne arkitekturen. Hvor denne arkitekturen går lenger enn de fleste slike systemer, er det absolutt bruk av asynkron kommunikasjon, noe som resulterer i endringene i programmeringsmodellen som jeg skisserte tidligere. Disse endringene vil få litt til å bli vant til for de fleste lag. De fleste har en tendens til å tenke på programmering på synkron måte og er ikke vant til å håndtere asynkroni. Likevel har det lenge vært sant at asynkron kommunikasjon er et viktig verktøy for respons. Det vil være interessant å se om bredere bruk av asynkron kommunikasjon i javascript-verdenen, med AJAX og node. js, vil oppmuntre flere personer til å undersøke denne stilen. LMAX-teamet fant at mens det tok litt tid å justere seg til asynkron stil, ble det snart naturlig og ofte lettere. Spesielt var feilhåndtering mye lettere å håndtere under denne tilnærmingen. LMAX-teamet føler sikkert at dagene til den koordinerende transaksjonsdatabasen er nummerert. Det faktum at du lettere kan skrive programvare ved hjelp av denne typen arkitektur, og at den går raskere, fjerner mye av begrunnelsen for den tradisjonelle sentrale databasen. For min del finner jeg dette en veldig spennende historie. Mye av mitt mål er å konsentrere seg om programvare som modellerer komplekse domener. En arkitektur som dette gir god adskillelse av bekymringer, slik at folk kan fokusere på domene-drevet design og holde mye av plattformens kompleksitet godt separert. Den nære koblingen mellom domeneobjekter og databaser har alltid vært en irritasjon - tilnærminger som dette tyder på en vei ut. Hvis du fant denne artikkelen nyttig, vennligst del den. Jeg setter pris på tilbakemeldingen og oppmuntringMatematikken i arkitektur - PowerPoint PPT-presentasjon Transkripsjon og presentasjonsnotater Tittel: Matematikk i arkitektur 1 Matematikken i arkitektur Denne hele presentasjonen er viet til hvordan matematikk passer inn i arkitektur. 2 Matematikkhistorie i arkitektur I gammel tid var arkitektur et felt av matematikk. Arkitekter var bare matematikere som noen ville ansette. Første gangs arkitektur ble nevnt i tekst, handlet det om de egyptiske pyramidene. Det er et gyldent tall i arkitekturen er (1square rot av 5) 21.618033989 (1.618033989) 51degrees 50 minutter er de egyptiske pyramidene basert på dette nummeret. Vi vet ikke om det var prøve og feil, eller hvis de allerede hadde oppdaget det gyldne nummeret. 3 Pythagoras Pythagoras var en av de tidligste påvirkningen på arkitekturen. Tall i deres kultur hadde en religiøs betydning. Pythagoras tok den grunnleggende musikkteorien (som de opprettet), som er lydene en streng avhenger av dens lengde, det som førte til var den grunnleggende enhetslengden for byggekonstruksjoner. 4 Where math fits in Every building is measured and level which involves very basic math, In more complex buildings, for an example the Eiffel tower, it needed to be a perfect triangle and have its special curves at a special angle. Also it weighs many tons so it needed to be able to support its own weight. As you can see there are many different types of math needed, which include trigonometry basic measurements proportion and complex multiplications. 5 Obstacles solved with math In Asia there is a building that is very tall and was in danger of earthquakes. They decided to put a giant pendulum in the tower to keep it from tipping or losing its stability. Many buildings are aerodynamically designed so decrease air drag, so that they dont sway too much causing uncomfort or sickness to the people in them, or in very serious cases failure of the building structure. 6 Modern Architecture In the modern era, there is much less calculation done by people. It is all done with computer programming. It could be as simple to bringing the building up to scale, or even to find out how many diamond shaped pieces you needs for a certain area on the building. Computer programming allows us to be much more precise in the work that needs to be done, and also puts a lot less stress on the designer. 7 Activity I will make groups of three or four for this activity. There are so many building shapes youll be given and you have to make the most aerodynamicstructur ally secure building you can make. 8 Questions What is the angle of the pyramids (among many modern buildings). This angle is used to find a certain number Why must skyscrapers be aerodynamic What significance did numbers have for the Pythagoras Why do we now use computers for architecture as a planning tool 9 Answers The angle is 50 degrees and 51 minutes. Skyscrapers are aerodynamic to avoid rocking back and forth or maybe even structural damage. The significance is it represented religious beliefs. We use computers because its much more precise, less time consuming and less room for human error. 10 Bibliography gap. system. org-historyHistTopicsArchitectur e. html Semptember 8th 2009 wwwplus. math. orgissue42featuresfrostersinde x. html September 8th 2009 boelgen vejile. dk October 5th 2009 Cache. ebebimageid75854rendType4 October 5th 2009 your-info-hubguitarratateimage. php October 5th 2009 delhivewarminaryanakshardham-temple0 October 5th 2009 PowerShow is a leading presentationslideshow sharing website. Om din søknad er forretning, hvordan, utdanning, medisin, skole, kirke, salg, markedsføring, nettbasert trening eller bare for moro skyld, er PowerShow en god ressurs. Og best av alt er de fleste av sine kule funksjoner gratis og enkle å bruke. Du kan bruke PowerShow til å finne og laste ned eksempel online PowerPoint ppt-presentasjoner på omtrent hvilket som helst emne du kan forestille deg, slik at du kan lære å forbedre dine egne lysbilder og presentasjoner gratis. Eller bruk den til å finne og laste ned høykvalitets PowerPoint ppt-presentasjoner med illustrert eller animert lysbilder som vil lære deg hvordan du gjør noe nytt, også gratis. Eller bruk den til å laste opp dine egne PowerPoint-lysbilder, slik at du kan dele dem med lærere, klasser, studenter, sjefer, ansatte, kunder, potensielle investorer eller verden. Eller bruk den til å lage virkelig kule bildeserier - med 2D - og 3D-overganger, animasjon og musikkvalg - som du kan dele med Facebook-vennene dine eller Google-kretsene. Det er alt gratis også. For en liten avgift kan du få bransjens beste online personvern eller offentlig markedsføre presentasjoner og lysbildefremvisninger med topprangeringer. Men bortsett fra det er det gratis. Du kan også konvertere presentasjoner og lysbildefremvisninger til det universelle Flash-formatet med all sin originale multimedia-herlighet, inkludert animasjon, 2D - og 3D-overgangseffekter, innebygd musikk eller annen lyd, eller til og med video innebygd i lysbildene. Alt gratis. De fleste presentasjoner og lysbildefremvisninger på PowerShow er gratis å vise, mange er også gratis å laste ned. (Du kan velge om du vil tillate folk å laste ned de opprinnelige PowerPoint-presentasjonene og bildediagrammer mot en avgift eller gratis eller ikke.) Sjekk ut PowerShow i dag - GRATIS. Det er virkelig noe for alle presentasjoner gratis. Eller bruk den til å finne og laste ned høykvalitets PowerPoint ppt-presentasjoner med illustrert eller animert lysbilder som vil lære deg hvordan du gjør noe nytt, også gratis. Eller bruk den til å laste opp dine egne PowerPoint-lysbilder, slik at du kan dele dem med lærere, klasser, studenter, sjefer, ansatte, kunder, potensielle investorer eller verden. Eller bruk den til å lage virkelig kule bildeserier - med 2D - og 3D-overganger, animasjon og musikkvalg - som du kan dele med Facebook-vennene dine eller Google-kretsene. Det er alt gratis også. For en liten avgift kan du få bransjens beste online personvern eller offentlig markedsføre presentasjoner og lysbildefremvisninger med topprangeringer. Men bortsett fra det er det gratis. Du kan også konvertere presentasjoner og lysbildefremvisninger til det universelle Flash-formatet med all sin originale multimedia-herlighet, inkludert animasjon, 2D - og 3D-overgangseffekter, innebygd musikk eller annen lyd, eller til og med video innebygd i lysbildene. Alt gratis. De fleste presentasjoner og lysbildefremvisninger på PowerShow er gratis å vise, mange er også gratis å laste ned. (Du kan velge om du vil tillate folk å laste ned de opprinnelige PowerPoint-presentasjonene og bildediagrammer mot en avgift eller gratis eller ikke.) Sjekk ut PowerShow i dag - GRATIS. There is truly something for everyoneThe history of information systems (IS) only span five decades. Yet from its inception, IS has done more to expand business and industry into global markets than any other convention in history. Today the backbone of IS is know as the World Wide Web, Internet, or with a business a Local Area Network, along with lists of acronym buzz word EDI, EIS, ERP, SCM and host of others to describe new ways in which IS can be employed to grow business. Contrary to the speed of information today, just over forty years ago, the business climate in United States was experiencing post-war growth much like it had never seen. Much of the experience that grew the economy had been learned during World War Two in tooling up the nations industries into producing an effective war machine. The field that developed out of this push to win the war was Operations Research (OR). When the war end those involved with OR were released from government work, thus unleashing an experienced and highly skilled field, like no other in history, into business and industry, which launched the US into a era of prosperity and growth that lasted over twenty-years. World War Two also saw the birth of the first practical computers or Turing Machines, which were responsible for cracking the German codes and giving the allies advanced warning of enemy movements. By todays standards these first practical computers were not that practical, half a million dollars and far less powerful than a pocket calculator which today purchased for under ten dollars. However these first computers gave Operations Researchers the power they needed to begin simulate larger and more complicated systems which in business and industry help greatly to hone uses capital expenditures into profitable ventures. This background from the early days of simulation, OR, and new technologies birthed studies into the areas of what became known as Information Systems. When and how were they first used Formalized By the mid-sixties IS was already forging its way into business mainstream. While computers remained out of reach for most businesses, telecommunications made its mark with the TELEX machine. This step gave businesses the ability to communicate within its own organization anywhere in the world at any time and effectively pass instructions and information. The use of computer in business and industry usually started off in the accounting departments. It was assumed that this area would know the most about using numerical machines and the lack of understanding in how important databases could be other areas of the business. By this time a number of business school began developing Management Information System (MIS) programs to meet the growing need of IS managers. During the seventies more upper management recognized the importance of IS and the flexibility it was bring to business. The TELEX became the standard of information transfer and the mainframe computer became the standard for database creation. As the need for organized and easy access to data became apparent, information based businesses began moving the mainframes from under the accounting management to it own department. Approaches toward IS Design and Why As IS begins to receive its own autonomy and large budgets in corporations, many technical savvy managers of these new departments begin spending huge amount of money on systems and software at their own discretion and many time out spend all other departments without any returns to the business. These were troubling and risky times for CEOs deciding to direct the business into IS based systems. The systems and software were complex, continually changing, and the people that knew the systems tended have their own agendas. Out of this turmoil came the basis of how IS develops with in businesses. Mainframes Vs PCs This new rush in what is now referred to as e-mail, was brought about by the invention of the mini and micro computer, which could put and entire system on an executives desk for a very low price compared to mainframes and the ability to have an autonomous system with out pay huge amounts of money to process information. Once again turmoil enters the relationships of IS and businesses, where software and hardware vendors begin making demands on businesses to switch there style of business to fit the computer systems. There was little standardization of software and hardware with many start up companies that went under there after leaving business with out any technical or system support, resulting in spending above budgets to install entirely new systems. As the desire to support different departments of a corporation with IS and the new affordability of hardware and software each department began to put IS programs together independently of MIS department. This result in a new position in companies: Chief Information Officer (CIO), a position that in many companies at this time rivaled the CEO. The need for this position was to standardize all of the electronic data interfaces (EDI) between all departments so information could be more efficiently. Quality Initiatives in IS Development The mid-eighties were the time most manufacturing companies began to shift to IS to forecast sales, take orders, and manage distribution of products. Time Berners-Lee developed the World Wide Web in 1989. This protocol HTML used over the existing Internets that had been constructed opened up a new era of EDI the world had never seen. Where by the mid-1990s it became apparent that there is no way for a corporation to efficiently do business without a solid functioning IS setup inside its own walls as well as connected with its supply-chain vendors and distributors. EDI once known as Electronic Data Processing (EDP) have now brought profit margins so low that any business that does not prepare itself will be out of business in the next five years. IS is a technology driven system. With out it, business would not be what it is today. It has evolved over the past forty years to being the back bone of business, yet the simple application rules created in the 1960s and 1970s are still very relevant in any application where data or information is transferred in what ever business model it is applied to no matter the complexity. Home CHAPTER 3 INFORMATION SYSTEMS - AN INTRODUCTION (TM) Basically an Information System handles the flow and maintenance of information that supports a business or some other operation. It contains information about significant people, places and things within the organization or in the environment surrounding it. Information is derived from meaningful interpretation of data. Data consists of the raw facts representing events occurring in the organization before they are organized into an understandable and useful form for humans. An Information System can be defined technically as a set of interrelated components that collect (or retrieve), process, store and distribute information to support decision making and control in an organization. Another definition of an Information system (by Buckingham et al (1987b) is. A system which assembles, stores, processes, and delivers information relevant to an organization (or to a society), in such a way that the information is accessible and useful to those who wish to use it, including managers, staff, clients and citizens. An information system is a human activity (social) system, which may or may not involve the use of computer systems. Also, in addition to supporting decision-making, information systems help workers and managers to analyze complex problems, to develop new products and to integrate the various modules and departments. Moreover the transmission lossesn inter-departmental communication are reduced considerably leading to better coordination and improved transparency (information sharing) within the organization as a whole. Three activities provide the information that organizations need. These activities are Input, Processing and Output. Input consists of acqui sition of the raw data, which is transformed into more meaningful packets of Information by means of Processing . The processed information now flows to the users or activities also called as Output . The shortcomings are analyzed and the information is sent back to the appropriate members of the organization to help them evaluate and refine the input. This is termed as feedback . Examples of Information Inputs would be Transactions, events which would undergo processing in the form of sorting, listing, merging and updating resulting in outputs such as detailed reports, lists and summaries. Another example would be in the manufacturing environment with information inputs such as design specs material requirements and the SOPs (standard operating procedures). These would be processed by the information system by modeling and simulation techniques and would result in standard production models along with the overall cost of the production process which is calculated by the information system from the knowledge base containing material costs, hourly labor costs and other indirect costs. Hence almost totally eliminating a distinct costing function in the scheme of things. However an information system cannot just be broadly described as an Input-Process-output mechanism in vacuum. It is required to provide major organizational solutions to challenges and problems posed in the business environment. Hence a manager needs to be not just computer-literate but also have a good idea of the organizational structure and functions as a whole. This concept is illustrated in the figure on the opening page. Also, at the heart of the issue Information systems should not be confused with information technology . They exist independent of each other and irrespective of whether they are implemented well. Information systems use computers (or Information Technology) as tools for the storing and rapid processing of information leading to analysis, decision-making and better coordination and control. Hence information technology forms the basis of modern information systems. 3.1 Types of Information Systems Types of Information systems (Source: Management Information Systems, Laudon and laudon) The six major types of information systems corresponding to each organizational level (the four levels shown in figure above) are: 1. Transaction Processing Systems (TPS): serve the operational level of an organization. 2. Knowledge work systems (KWS) 3. Office automation systems (OAS) to serve the knowledge level of an organization. 4. Decision-support systems (DSS) 5. Management information systems (MIS) serve the management level of the organization. 6. Executive support systems (ESS) serve the strategic level of an organization. (Source: Management Information Systems, Laudon and laudon) CHAPTER 4 DEVELOPMENT OF INFORMATION SYSTEMS (TM) As mentioned earlier, every company to start with, has an information system already in place, be it a file card and pencil based system, a computerized system or an intermediate of the two. Hence the IS development process involves work on an existing system - mapping the system, automating it and making sure that it functions according to user requirements. Hence in its first phase the process attempts to determine the scope and type of new system that the user wants. The next phase analyzes the above requirement in two parts to facilitate detailed verification and validation before the system is actually designed and implemented. 4.1 Beginning with the users Infact the entire concept of Information systems development revolves around the users - their needs, performance expectations, requirements and other specifications. The very succcess or failure of an information system may be measured by the level of satisifaction of its basic users in the organisaiton. It is very essential that the database satisfy the requirements of the user, otherwise he or she will continue with his or her own system and thereby defeat the purpose of the central database. The key element in this concept is that each subsystem utilize the same database in the satisfaction of its information needs. This will yield an additional significant advantage - the integration of departments and functions. Thus each department, through its access and interface with the total information resources of the company, gains a greater understanding and appreciation of how its actions and plans affect others throughout the organization. An important question that can be raised is why is it important to analyzeand design information systems before you build them. Why cant you build the information systems directly The main reasons are: 1. It is important to build the information systems that the users really need. You dont know what they really need if you dont start with some kind of analysis and design. 2. It is a waste of resources to build information systems without sufficiently good blueprints because it takes more time and yields worse results if you dont have blueprints. Analysis and design is performed to meet information needs. If it is required to arrive at models that describe information systems that the users really need, then interest groups (or user groups) generally have to participate in the work. Another reason for performing analysis and design is that those who participate in such work learn much about the new information systems. To be able to use information systems requires knowledge about how these systems work. Participating in the analysis and design work is one way of obtaining such knowledge. 4.2 Determining need and performance expectations As every company has an existing system and the process of IS development involves system conversion. The general steps involved in the conversion are: 1. System Description (narrative or pictorial) 2. Input Documents ( item description, layouts etc.) 3. Output Documents ( report formats, output requirements etc.) 4. File Design (involves the system design process explained in the next section) 5. Program Logic (by the use flow charts or other methods) 6. Computer Program (COBOL, DYNAMO, BASIC, PASCAL, FORTRAN to name a few ) 7. System Verfication 8. Documetation Potential problem requirements surrounding database construction are generally those connected with interdepartmental coordination and agreement. These might include. - possibility of invalid input of information by a unit wishing to maintain information security. - the multiplier effect of erroneously entered data, which has an immediate influence on other departements utilizing the data. - the time dimension of input data, which requires that user departments agree on the time during which a transaction should be reflected data input. - the interdepartment agreement required concerning the degree of detail to be included in data elements of the database. As a consequence of the above problems that have been identified some of the desired features of the system would be. - Simplicity or ease of usage and handling (by employing graphic user interface - based entry and retrieval systems) - Adequate security featuresfirewalls for restricitng unauthorised access (both within the organisation and on the web) and - A very rigid backbone-operating system to support the numerous organizational functions at different levels. A clear-cut knowledge of the expectations or requirements of the system being developed would entail a listing of some performance metrics. The measurement of costs or benefits is a measurement of change between the old and the new. In other words we may measure the change in the total output of the system or measure the many changes accomplished throughout the system. The former is obviously the most desirable. It is probably rare that a measurement of the total system is attempted at the system level. Some broad concepts that need to be kept in mind during system development include. 1. System Integrity . How well are the sub systems integrated into the total system without redundancy. How flexible is the system. How easily may the system be expanded. 2. Operating Integrity . How skilled are the people operating the system What back-up is there to prevent system breakdown in the event of loss of key personnel or equipment failure. 3. Internal Integrity . How well does the system do what it is supposed to do. How valid are system outputs. How secure is the sytem against human error, manipulation, sabotage or theft. 4. Procedural Integrity . How good is the documentation of the system and procedures. Are procedures such that employees are motivated to follow them. How well are procedures followed in practice. What controls ensure that procedures are followed. - Change analysis has to be performed before information systems development is performed. Change analysis is the analysis of suitable changes of the activities of an enterprise in concrete situation. The purpose of change analysis is to formulate the problem before you start to solve it. Developing information systems is effective only if you have information system problems or needs. Problem oriented work must be performed before data oriented work is performed. Problem-oriented work in information systems development refers to the development parts whose purpose is to specify what the information systems will do (seen from the users view). Data-oriented work refers to the development parts whose purpose is to design technical solutions to this specification. It is only effective to perform data oriented work if you have a problem-oriented specification as a basis. The concept is explained in further detail in the first phase of process design,( i. e requirements analysis.) 4.3 Characteristics of good organisational IS talent A manager needs information for a variety of reasons concerned with the management process. The type of need that he or she will have at various times and for various purposes depends largely upon 2 factors that we shall examine briefly. the personal managerial attributes and the organizational environment in which decisions are made. 1. Knowledge of information systems If managers are aware of what computer-based systems can do, their information requests will probably be more sophisticated and more specific. Their knowledge of capabilities and costs places them in a much better position to aid in the design of a good system. 2. Managerial Style A managers technical background, leadership style, and decision-making ability all affect the kind and amount of information required. Some prefer a greater amount Others like to decide with a minimum of detail and prefer personal consulatation with subordiantes. 3. Managers perception of information needs You tell me what I need to know and get me all the facts represent two opposite perceptions of information needs. This dichotomy is due partly to the fact that many managers are ignorant of what information they need. Another dimension of the problem is the widely differing views of the managers regarding their obligation to disseminate information to subordinates and to groups outside the firm. Teh manager wh ocannot or will not delegate authority is likely to keep information closely held. 1. Nature of the company Problems in communication and in controlling operations seem to be a function of the comapnys size and the complexity of its organization. The larger more complex firms require more formal information systems, and the information needs of these systems become more critical to operations. 2. Level of Management There are three levels of management (i. e strategic planning, management control, operation control) and the varying needs for information at each. Each level needs different type of information, generally in different form. top levels need the one-time report, the summary, the single inquiry. The management control level needs the exception report the summary and the variety of periodic reports for regular evaluation. The operational control level requires teh formal report with fixed procedures, the day-to-day report of transactions, to maintain operational control of actions as they occur. Managers at all levels have changing information needs, depending on the nature and importance of the particular decision. 3. Structure of the organisation The more highly structured the organization, the easier it is to determine the information needs. Where authority and responsisbility are clearly speelled out, relationships understood, and decision-making areas defined, the information needs of managers can be determined more easily. (Above section adapted from Information systems for modern management by Murdick, Ross and Claggett) 4.4 Stages In Process Design: The Process of information systems development in its first phase attempts to determine the scope and type of system the user wants. The next phase analyzes the above requirement in two parts to facilitate detailed verification and validation before the system is actually designed and implemented. This stage consists of obtaining user needs and requirements which reflect the user-expectations from the IS being developed. It consists of several stages: 1) Problem definition 2) Feasibility Study 3) Requirements Acquisition 4) Requirements Analysis The problem definition and feasibility study stages consist of definition of a bare outline of the desired system. The Problem Definition Stage defines to a high level of detail the application for the desired IS and an indication of the advantages that will result from its implementation. The Feasibility Stage is the examination of the different alternatives with which a solution can be found for the design of the desired system. The Requirements Acquisition Stage results in a statement of requirements. The Requirements Analysis stage produces the requirements specification. Using the statement of requirements as the main input the aim of the requirements specification is to act as an overview of the desired system in a structured form. This phase analyzes the requirements from the previous phase and converts them into components, which are used to build a specification of the desired system. The specification is more precise than in the previous phase and adds more detail, at the same time retaining user semantics, so that the description would be recognizable to the user. However the model is at an abstract level, that is, with no details concerning data representation or computer implementation. This phase produces a design of the desired system that will serve as a basis for computer implementation. There are two major tasks in logic design. Firstly the specification from the analysis phase is transferred and secondly the human computer system is designed. The significant difference in this phase is that the structure component is now represented by data. There will often be several possible ways of representing relationships. We may also use normalization in this phase. We decide exactly what data types are required for data representation, how many characters are required for each data item and we design records and files or databases to store the data, taking into account the type of processes that will operate the data. An abstract programming form is often used here, such as structured English, JSP diagrams or action diagrams. In addition DFDs may be drawn showing the processes that occur, the data input to and output from each process etc. The second major task in logical design consists of design of human computer systems. Two levels of detail are normally considered here: - Design of user procedures which consist of tasks and processes with which users will be directly involved - Computer interface design consist of the detail of processes and the objects on which these processes operate, and may involve considerations related related to interaction style ( screen and report layouts, human-computer dialogues), specifications of manual or mechanical operations, and off-line or online processing. This is the last of the design phases. We may consider it as consisting of 3 components: Hardware, software and human-computer systems. The hardware design consists of a description of the computers, storage devices, inputoutput devices and possibly networking devices required for the desired system. Software consists of the programs that run on the hardware. The physical design of data needs to be considered as the kind of data invariably affects the programs that process the data. It will be necessary to decide on the appropriate types of applications software, including languages and packages as well as systems software required for supporting the eventual system. There are four options for process design 1. For standard processes, we can buy packaged software. For example, accounting software is largely standardized. 2. Use of a fourth-generation language such as lotus123, VB, Oracle etc. 3. Generate code using a CASE tool 4. Write our own code. If in-house coding is done data structures are chosen for the representation of data in the programs, together with decisions as to the programming language required for eg. COBOL, C etc. Issues such as execution speed and ease of maintainability of program code are considered. Human Computer system design Some of the design of this system specifies the activities to be followed when communicating with the computer, for example, detail of dialogue between computer and operator, procedures for starting-up and shutting down the system and screen contents such as windows or colors etc. Implementation And Testing The major output of the implementation and testing phase is a physical information system and not a design. Of course the physical and earlier designs remain available for reference, as they form the specification. The major tasks consist of: Acquiring and integrating hardware, producing software, generating data for the files or databases and producing the human-computer system. System is tested, user comments are evaluated, perhaps to redesign the system. The operation of the implemented system in the user-organization if monitored closely for a limited period. Maintenance The maintenance phase consists of correcting errors in the system or responding to changes in the user requirement, due, for example, to environmental changes or personal preferences for system operation and it may require reworking of all the previous phases for the part of the system that requires changing. 5.1 System Design The basic information model consists of three parts as shown below and the data dictionary. The external models represent the user views of the system. These are brought together into a single global conceptual model as illustrated below. The conceptual model does not take into consideration how the data and processes will be implemented on the computer. This is accomplished through the internal model (shown as schemas and programs in the diagram below) 5.2 Stages in IS modeling As mentioned earlier, we do not design the internal model right away. A conceptual information model is first formulated and this is then translated into an internal model. Also we need to develop two conceptual models (a) A conceptual data model and (b) A conceptual process model. These are then checked for consistency and, any necessary modifications are made to arrive at the data processing model. This is the first level information model. (the data model, the process model and the data processing model) otherwise called first level design . Second level design is concerned with adapting the first level design to the specific requirements of the processing required. It may be that the first level design consists of so many relations that it would not achieve an acceptable level of performance if it were implemented in that form. Hence the model may need flexing to accommodate the demands of the functions which the information system may support. The result of this is the second level design information model. The final stage is the third level design where the model is mapped into the internal schemas required by the software being used to implement the system. The process of moving form first to second to third level design may seem rather long but it is important for a number of reasons. The first level will provide a transaction-independent view of the information content of the system. However it will still be enterprise-dependent because the data model will only reflect the things of interest to that enterprise. The second level design is enterprise or transaction dependent, but is still independent of hardware and software. Hence the second level can be used to evaluate alternative implementations and assist in the selection of hardware and software. Third level design is enterprise, transaction and software dependent. The process of design is shown in the diagram below. IT is important to note that this process does not equate the design of the entire information system. In particular it does not cover data on establishing the feasibility of an IS, nor on strategic decisions involved in selecting an information area. Similarly nothing is said about the design of forms, codes, screens and reports nor of the techniques for the analysis of the requirements of the users. 6.1 System Development Methods (MR) ( Source. Yourdon system methods, model driven methods, 1993) The evolution of system development methods has been gradual. The three stages in the evolution of system development methods may be identified as. 1) First generation methods. 2) Second generation methods. 3) Third generation methods. First Generation Methods These methods includes various structured techniques developed during late 1960s and 1970s. Structured techniques breakdown a complex problems into smaller components with well defined inter-relationships between components. DIVIDE and RULE Components of First generation methods: 1) Structured programming. 2) Modular design and structure charts. 3) Programming style. Modular design . many programming languages allow groups of statements to be reused, such a group of statements are called program module and their use is referred as modular programming. structure charts show how modules are connected to form a program. Programming style . using standard constructs, code can be complex and difficult to understand and it was also understood that maintainable code also required style guidelines ( 1970s). Data Structures . data design tech. used in 1970s were pragmatic ways of building data structures and files to support programs. CODASYL organization was upfront in database design in late 60s. Structured Design . structured programming technique only addresses design in small. these never gave any guidelines on how to carry out design in the large. Successive refinement (Top Down Functional Design): A required system function was broken-down to smaller number of tasks that could be combine to accomplish the function. Each of these were in turn broken down into smaller sub-tasks. The process was continued until the subtask was so simple that it could be coded with little chance of error. Techniques based on the semantics of the structure chart Main criteria for improving program design were based upon. Coupling: measures the complexity of interfaces, If interfaces between module are simple, design is described as having low coupling. Cohesion: measure of how single-minded a module is. If module carries out exactly one well defined function it is described as having functional cohesion. Data Refinement . Relation data model, which treats all the data as tables. Refinement criteria were used to check the quality of design. Application of these criteria is called normalization. Structured Analysis . The set of tools and techniques referred to as structured analysis were developed to address the problem of identifying and stating the user requirement in an unambiguous, understandable form. These techniques were mainly Process-oriented concentrating on required system functions. Modeling tools . The main need was for modeling tools that would help to partition complex requirements into smaller units with well defined inter-relationships. The modeling tools used were. 1) Data Flow Diagrams to show the portioning of proposed system into smaller functional areas or mini-systems. 2) Mini-specs to specify each mini-system. The use of review sessions, where part of the requirements was also presented was a key technique capturing user requirements. These review sessions were termed as structure walkthroughs. Information Modeling: at the same time as structure analysis were developed, a semantic approach to information modeling was formulated. This was based on real-world entities and relationships. Problems with top down functional decomposition (TDFD) : Top down functional decomposition was carried out by trying to guess what main functional area were. Each functional area was then examined in turn and successively broken down until the functions were simple enough to verify with the user. This lead to second problem that caused TDFD to be supplemented or replaced in the second generation methods. Correct partitioning of the system could not be done until system was understood and system couldnt be understood until it had been partitioned. Because of this problem an optimal statement and organization of the user requirement was very time consuming, required considerable reworking of the models and due to time pressure it compromise on quality of work. TDFD is creative technique and reflects the way the analyst thinks or perceives the system. The logical model tends to reflect the unconscious bias of analyst towards a specific solution. Fragmentation of Policy Although there were guidelines that helped identify the best organization of the user requirements, it was sometimes found that functions which were widely separated in the model needed to be cross-checked. Different system development philosophies: 1) Process and data driven methods. 2) Phase oriented and model oriented development. Process oriented: concentrating on system functions and regarding the data as only being present to support system functions. Data Driven methods: Concentrating on information requirements, particularly in terms of identifying the data to be stored in database. Systems functions were considered to be less important. Phase oriented. System development life cycle was seen as sequence of phase, each consisting of well defined activities that had to be carried out. Model oriented. here life cycle was seen as a sequence of models of system requirements. Each model had a defined structure that could be checked. Second Generation Methods In First Generation (FG) methods developers were process oriented or data oriented and used modeling in fairly informal way. In all Second generation methods main stress is on the construction and checking of models. FG methods are largely independent approaches for dealing with each stages of system development life cycle. Second Generation methods provide a smoother development path from requirements analysis to later design and implementation stages. FG model is used to capture system requirements in policy terms, later models elaborate on how the model is mapped onto available technology because models are not independent but each model evolves into the next, taking into account another layer of technology. FG methods viewed system from one viewpoint with relative poor modeling from other viewpoints. SG methods regard system functions and data as two equally important aspects the system. Second generation methods were externally oriented. Analysis techniques are based on real world requirements of two types a) response to real world events and b) store information about real world entities. Real World Events. Time is more explicitly modeled in terms of events that occur in the environment of system. System behaves as they do only because of these events that occur and requires policy for responding to these events. Real World Entities. By collecting information about real world entities and the relationships between them, the analyst avoids bias towards any possible data storage organization. CASE (Computer Aided Software Engineering ) Use of CASE was not common until 1980s although such tools become available from about 1975.Some case products have draw what u want approach and some have more well defined grammar that the diagrams can be checked against. The second generation technique are mainly Diagram Oriented unit of modeling is a diagram. Diagrams are drawn and checked. Reasons For Third Generation Methods The second generation view of models is rather low-level. It deals with individual diagrams rather than the larger issues of how individual analysis and design unit fit together and interact. Third generation methods will be distinguished by a philosophy that is more concerned with the whole rather than parts. 6.2 Techniques (TM) An information systems development methodology can be defined as a collection of procedures, techniques, tools and documentation aids that will help the systems developers in their efforts to implement a new information system. A methodology will consist of phases, themselves consisting of sub-phases, which will guide the systems developers in their choice of techniques that might be appropriate at each stage of the project and also help them plan, manage, control and evaluate IS projects. Methodology . As defined above it basically represents a way to develop IS systematically. Techniques: May involve the use of one or more tools which represent some of the artifacts used in information systems development. Verktøy . Tools are usually automated, that is, computer tools normally software to help the development of an IS. Techniques may be used in common among several methodologies. However they are not interchangeable because when used in a particular methodology they could address different parts of the development process, be used for different purposes or be applicable to different objects. Listed below are the techniques used in the information systems development process: 1. Rich pictures 2. Root Definitions 3. Conceptual models 4. Entity modeling 6. Data flow diagramming 7. Decision trees 8. Decision tables 9. Structured English 10. Action diagrams 11. Entity life cycle 12. Object orientation 13. Structure diagrams The above table shows the position or stage in the development where any particular technique is utilized and whether it is primarily regarded as general, or data or process-oriented. The asterisk indicates the IS development stage or stages (discussed previously) in which the technique is most commonly used. For example entity modeling is used in two stages but its use at the logical design stage is most common. Tools (especially automated tools) are available in plenty for the system development process. Listed below are a few tools classified (and thereby defined) into some significant groupings. 1. Project management tools 2. Database management systems 3. Data dictionary systems 4. Systems repositories 5. Drawing tools 6. CASE (computer aided software engineering) tools Methodologies for information systems development make use of some of the process-oriented techniques of functional decomposition such as data flow diagrams, decision trees, decision tables and structured English. Functional decomposition gives structure to the processes reflected in particular by the most important technique of data flow diagrams. This emphasis on structure gives the name of the first methodology STRADIS. Some of the several methodologies proposed for IS development include: STRADIS (Structured Analysis And Design of Information Systems) follows the Top-down approach (functional decomposition) for analyzing processes. YSM (Yourdon Systems Method) Although, at the outset, this was very similar to STRADIS it differs in the more recent versions wherein it follows a middle-up approach to analyzing processes also called as event partitioning, which is more appropriate than the top-down approach. As a result of some such features as the above and also due to better ease of understanding and clarity of depiction, we employ the YSM in our future study and analysis of IS in industry. IE (Information Engineering). Whereas the fundamental techniques of the above two process-oriented approaches are functional decomposition and data-flow diagrams, the basic approach in IE is the data-oriented entity relationship approach. SSADM (Structured systems analysis and design methodology). It can be said to be the modern version of the traditional Information systems development life cycle approach. It includes the techniques of data flow diagramming and entity life histories, and recommends the use of tools, such as CASE tools and workbenches. Merise Unlike as in the previous methodologies wherein emphasis has been placed on either process or data aspects, Merise has been designed such that both are considered equally important and these aspects are analyzed and designed in parallel. JSD (Jackson Systems Development) is the development of Jackson systems programming (JSP) (which has had a profound effect on the teaching and practice of commercial computer programming.) into systems development as a whole. This methodology concentrated on the design of efficient and well-tested software, which reflect the specifications and is particularly applicable where efficiency is of paramount importance, for example in process control applications. Object oriented Analysis. This approach reflects the view that in defining objects and their component parts (attributes) we capture the essential building blocks of information systems. Also it is a unifying approach as analysis and design can be undertaken following this approach. ISAC (Information Systems Work and Analysis) This methodology seeks to identify the fundamental causes of users problems and suggests ways in which the problems may be overcome (not necessarily through the use of computer information systems) by the analysis of activities and the initiation of change processes. It is therefore a people-oriented approach with emphasis on the analysis of change and the change process. (Source: Information Systems Development: Methodologies, Techniques and Tools by Avison, Fitzgerald) ETHICS ( Effective Technical and Human Implementation of Computer based Systems). Also a people-oriented approach and encompasses a socio-technical view that, in order to be effective, the technology must fit closely with the social and organizational factors in the application domain. SSM (Soft Systems Methodology). Whereas most of the earlier approaches stress on scientific analysis, breaking up a complex system into its constituent parts to enable analysis, systems thinking might suggest that properties of the whole are not entirely explicable in terms of the properties of its constituent elements. SSM addresses the fuzzy, ill-structured or soft problem situations which are the true domain of information systems development methodologies, not simple technical problems. (Source: Information Systems Development: Methodologies, Techniques and Tools by Avison, Fitzgerald) Multiview is a hybrid methodology that brings in aspects of other methodologies and adopts techniques and tools as appropriate. Basically a contingency approach. techniques and tools being used as the problem situation demands. Process innovation does most to tie business process reengineering with information technology and information systems, IT being seen as the primary enabler of process innovation as it gives an opportunity to change processes completely. (Source: Information Systems Development: Methodologies, Techniques and Tools by Avison, Fitzgerald) RAD (Rapid application development) is in response to the need of rapidly changing business environments. It is usually enabled by CASE tools and systems repositories. KADS is the outcome of a European research project to develop a comprehensive, commercially viable methodology for knowledge-based systems construction.. Euromethod also results from a european initiative and is more of a framework for the procurement and management of services for the investigation, development or amendment of information systems than methodology. (Source: Information Systems Development: Methodologies, Techniques and Tools by Avison, Fitzgerald)CHAPTER 7 SYSTEM DESIGN AND MODELLING (MR) 7.1 Business Process Redesign (Ref: Engineering management review (Vol 26,number 3, fall) Business Process Redesign is defined as the critical analysis and radical redesign of existing business processes to achieve breakthrough improvements in performance measures. In 90s 2 tools revolutionised the organisations these were. 1) Information Technology 2) BPR ( Business Process Redesign ) IT . This includes the capabilities offered by computers, software and telecom. IT is considered as analysis and modeling tool. Thinking about IT should be in terms of How it supports new or redesigned business processes. Use of IT in Manufacturing Industries. a) Process Modeling. b) Production Scheduling and Controls. c) Materials and Management Information Systems. Business Process ( BP ) . Business processes are defined as set of logically related tasks performed to achieve a defined business outcome. Set of business processess forms a business system. Business processes have two important characteristics. a) They have Customers. Recipients of outcome. b) They cross Organizational Boundaries. Five steps in (PD) Process design. 1) Develop Business Vision and Process Objectives. Prioritize objectives and setstretch targets. 2) Identify the Process to be Redesign. To find out critical processes. 3) Understand and measure existing process. Identify current problems. 4) Identify IT levers. To think of new process approach. 5) Design and build a prototype of the process. Implementation. Develop Business Vision and Process Objectives. In past process redesign was to rationalize the process, i. e to eliminate obvious bottlenecks and inefficiencies. Most likely Objectives. Cost Reduction . Important objective with others but insufficient in itself, while optimizing other objectives seems to bring the cost inline but not the vice-versa. Time Reduction . Common approach for reducing time is to make steps simultaneously rather than sequentially, using IT to co-ordinate. Output Quality . Specific measures may be uniformity, variability or freedom from defects. This is mostly defined by customer of the process. Setting goals that will stretch the organization will also provide inspiration and stimulate creative thinking. Identify the processes to be redesigned. Most of organisation could get benifit from IT - enabled redesign of critical (if not all) business process. Two major approaches. Exhaustive approach High Impact approach Exhaustive approach :Attempts to identify all the processes within an organization and prioritize them in order of redesign urgency. High Impact approach . Attempts to identify only most important processes Redesign process should be containing . a) Begining and end points. b) Interfaces. c) Organisation units involved. Understand and Measure existing process . This is required because. a) Problems must be understood so that they are not repeated. b) It can act as a baseline for future improvements. Identify IT Levers . Role of IT in process design should be considered in early stages of redesign. All of IT capabilities involve improving coordination and information access across organizational units, thereby allowing more effective management of task interdependence. Design and Build a prototype of the process . After all the studies and data collection, brainstorming workshops bring a design which also goes through successive iterations. Building a prototype of IT change usually achieves results faster than conventional life cycle. The process design after agreements by owners and stakeholders are implemented on pilot basis ( Parallel with the existing processess) examined regularly for problems and as the process reaches final acceptance, it is phased into full implementation. Defining Process Types : Three major dimensions can be used to define processess, 1) Organisational entities or subunits involved in the process. 2) Type of objects manipulated. 3) Type of activities taking place. Defining Process entities . Inter-organizational Processes. These are the processes where two or more business organization co-ordinates with each other. Inter-functional Processes. Achieve major operational objective such as new product realization, asset management, production scheduling. Interpersonal Processes: These are the processes within and across small groups. Using electronic mail and conferencing. Defining Process Objects . There are 2 primary object types. a) Physical b) Informationl In Physical object processes real, tangible things are either created or manipulated. informational object processes create or manipulate information. Adding information to a physical object as it moves through a process is a common way of adding value. Using IT to improve physical processess allows greater flexibility and variety of outcomes, more precise control of process, reduction in throughtput time, and elimination of human labor. Defining Process Activities . There are 2 Activity types. a) Operational b) Managerial Operational activities involves basic business activities in the orgainisation. Mangerial activities includes control, plan or providing resources for operational processess. Capabilities of Information Technology for reshaping management issues includes . a) improve analytical accuracy b) enable broader management participation c) can generate feedbacks d) can streamline the time and resources a specific process consumes. To attain SCM integration, it is necessary to understand the infromation requirements of all the participants and design system that facilitate co-operation . Why BPR Project fails 1) Lack of sustained management commitment and leadership. 2) Unrealistic scopes and expectations. 3) Resistance to change. 4) Narrow technical approach. 5) Cost-Cutting focus. What can be done to make a BPR a Success 1) Do something smaller first ( Pilot Experiments ). 2) Conduct personal transformation ( change of mindset ). 3) Get IS and HR involved. 4) Empowered and collaborative workers support. 5) Realistic expectations. 6) Prioritise the objectives. SUCESS OF BPR DEPENDS ON THE PEOPLE WHO DO IT AND HOW WELL MOTIVATED ARE THEY. 7.2 System Modeling (Source. Yourdon system methods, model driven methods, 1993 ) Uses of Modelling Tools. 1) Focus on important system features. 2) Medium of communication with users. 3)Document the systems analysts understanding for the impementation for implementation by designers and programmers. There are 4 main types of modeling tools used inYSM ( Yourdon System Methods ) 1) Graphic 2) Tabular 3) Frame 4) Textual Graphic Tools . These are used to show high level components of particular aspect of a model. Each graphic modeling tools has set of icons used to represent specific model component. Graphic tools are preferred type of modeling tools when the connection between model components is important. Graphic tools in essential modeling are mainly of a semantic nature highlighting the meaning of the requirements. Graphic tools in implementation modeling are mainly concerned with syntax or structure. Tabular Tools . Some information is usefully laid out in tabular forms. Tabular tools may be useful in some circumstances particularly if subject matter expert finds the graphic modeling tool difficult to relate to. Frames . Frame is used informally for a certain type of specification tool. Frame specifications are used to specify all relevant info about a model component that has been declared on a diagram or another frame. Textual Tools . Textual grammar is defined formally, using meta language or set theory. 7.2a Entity Relationship Diagram (ERD) . ERD is semantic modeling tool used to identify and organize information and to model particular roles of importance to the enterprise and relationships between them. This may also be used as a tool for discovery of rules and events. These are not contingent on the modelers point of view or interpretation as these are real world facts. Enterprise Essential Model uses ERD to define entities it uses and the relationships between them. System essential modes uses ERD to show the entities and relationships that the system has responsibility for collecting or using information about. Components of ERD. Entity . Entity is a class of real world thing whose role of interaction with the enterprise is well-defined. Each entity has a unique name which should reflect the role that is played by that type of object. These things may be physical objects abstract concepts. Each entity must be distinct from but fulfill the same role as other occurrence of the entity. Instructor in ERD defines entity. Relationship . relationship represent possible associations that may occur between occurrence of entities. On diagram, each relationship is shown linked by lines to entities to which it refers. Occurrence of the relationship represents a single instance of the association between entities. Relationship Frame . Each relationship frame that includes the entities involved and other text forming a complete sentence. kilde. Yourdon system methods, model driven methods, 1993. Each occurrence of relationship corresponds to a specific occurrence of a Course and a specific occurrence of Topic. Binary Relationship . A relationship that refers to two entity occurrences is called binary relationship. Higher order Relationship . A relationship involving more than 2 entity occurrences is referred to as higher order relationship. kilde. Yourdon system methods, model driven methods, 1993. When entity is repeated in relationship, the relationship is referred to as being recursive. For recursive relationships, the role for the entities must distinguished as it can be seen in the frame that employee reports to other employee who is manager. kilde. Yourdon system methods, model driven methods, 1993. If the occurrence of entities in a recursive frame is not significant the relationship is known as symmetric. The relationship is friend of is an example of symmetric relationship. For symmetric relationships. the role for the entities doesnt have to be distinguished. kilde. Yourdon system methods, model driven methods, 1993. Associative Entity . This is the entity which acts as entity and relationship both. As a relationship it indicates a group of real world associations between entities. Attributes of associative entity do not describe the entities that participate in relationship but the occurrence of relationship between them. kilde. Yourdon system methods, model driven methods, 1993. a - describes a relationship. b - date on which marriage took place is neither an attribute of man nor woman but it describe the occurrence of relationship. marriage - associative entity date-as an attribute. Each occurrence of marriage records the fact that specific man was married to a specific woman on a specific date. Subtype, Subtyping and Supertyping . Subtype. Subtype of entity is a well defined group of occurrences of entity that may be regarded as entity in its own right. Subtyping indicates that the enterprise regards the entity as being made up of number of distinct identifiable groups each of which is referred to as a subtype. Supertype. supertype is regarded as a general grouping of several entities. kilde. Yourdon system methods, model driven methods, 1993. 7.2b State Transition Diagram ( STD ) STD models time dependent behavior. In STD, each state represents a period of time during which the system exhibits some observable behavior. kilde. Yourdon system methods, model driven methods, 1993. Components of STDs Access : Access on STD shows the possible access to the occurrence of entity when change of state occurs. Create Access : causes a new occurrence of entity to exist. occurs for initial transition. Read Access : for an event which occurs and requires some attributes to be used but not necessarily changed. Update Access : used where some of attributes of entity are to be changed. Delete Access : after this entity do not exists. Match Access : to check whether a specific occurrence of the entity exists. Connector : Where it is difficult to draw diagrams without crossing transaction lines a pair of connector symbols may be used. On diagram connector opis used in this way. Entity : each STD is for one state variable of specific entity. Example shown is for associative entity scheduled course. An entity may have several STD one for each of its state variable. Entity death. this indicates that occurrence of entity no longer exists and cannot be accessed. Event . event is the thing which causes transition to take place. When this event occurs a change of state may occur for one occurrence of the entity but it doesnt always occur. The responsibility whether or not it does occur resides in a data process. Initial State . state of the occurrence of entity when it is created. A transition to this initial state is referred to as an initial transition and must always include create. State . Each occurrence of the entity have a well defined state for a given state variable. Each schedule course may have a status of open, running, full or finished. 7.2c CONTEXT DIAGRAMS This is a diagram where systems is represented as a system diagram in whole. Purpose of context diagram is to depict how the system is connected to, interacts with other entities which makes its ( data ) environment. kilde. Yourdon system methods, model driven methods, 1993. Context diagram show all external entities which interact with the system and all data flows between these and the system. Components of Context Diagrams: Access Flow . access flow indicates that the system uses stored data which is shared between it and its environment. Continuous access flow. if system or a terminator continually updates or monitors the value in a store it is shown as continuous access flow. Discrete access flow. Access toa store that takes place at a particular instant of time. Data is present in store and can be accessed anytime. Context Process . This is a process group which represent the system. On context diagram system is regarded as a Black Box. All requirements for behavior or data storage by the system is considered to be within this process. Dataflow . data flow on context diagram either represents information produced within or outside the system which is used by outside world or by the system itself. Continuous data flow. continuous data flow represents a value that is available over a period of time. Discrete data flow. data flow that is only present for a instant of a time. Dialogue data flow. a data flow generated by the terminator for the use of system is combined with a data flow created by the system for use of terminator. Event Flow . indicates synchronization between the system and its environment. Continuous event flow. represents a status that is indicated over a period of time. Discrete event flow. event flow that is only present for an instant of time. Dialogue event flow. pair of event flows that occur at the same time may be combined and shown as a dialogue event flow. provided that they are tofrom the same terminator. Dialogue event flow is used to show a group of input flows, together with corresponding response flows either initiated by terminator or the system. Terminator . terminator is a producer or user of data that interfaces with the system. Data Store . a data store on the context diagram shows an interfaces between system and its environment. The store indicates that the system and terminator are decoupled in the sense that one can change values in the store independently of the other. 7.2d DATA FLOW DIAGRAMS (DFD) : A data flow diagram is the most important technique for modeling high level detail of the process within a system. These highlights the functions of the system and how they use stored information and transfer information between each other. kilde. Yourdon system methods, model driven methods, 1993. They show how input data is transformed to outputs results through sequence of functional transformations. Components of DFDs. Access Flow . access flow is used to show that a process needs to use or change stored information to accomplish its purpose. An access flow from a store show that the process uses information held in the store. This may correspond to:- Match Access. The process checks whether an entity or relationship occurrence matching a particular criterion exists. Read Access. The process uses the values of one ( or more) attributes for a selected occurrence of the entity. Check Access. The value of a state variable needs to be checked. An access flow going to a store shows that the process will alter information held in the store, This may correspond to a :-a) Create access. to create a new occurrence of an entity or relationship. b) Delete access. to delete one ( or more) occurrence of an entity or relationship. c) Update access. to modify the value of an attribute. d) Change access. to change the state of a state variable. Continuous Access Flow . In some situations it is necessary to continuously monitor the value in the store. This is carried out using data process. Link between this data process and the store is shown as continuous access flow. Control Process . Control process coordinate the activation of processes and signal to other components of system essential model. The coordination is carried out by interpreting and generating event flows and controlling processes by triggering or enabling or disabling them. In figure control process control car oxidation shows that control logic must be present to coordinate the monitoring, changing and replacing of solutions. It also derives the movement of the car body by interpreting the state of the oxidation bath and generating required signals such as move car signal to move the car body. Continuous event flow . continuous event flow is one that is available over a period of time, such as the status of a device. Continuous event flows represent a situation or status that is either true or not. Data Flow . a data flow represents the information generated by a source and used by another system function or terminator. On a data flow diagram the source of the data flow may be. a data process. the function represented by the data process is the one that generates the information. a process group. the function that generates the information within this group. Continuous Data Flow. Data Flow that persists over a period of time is called as continuous data flow. The value is present over a period of time and may change during that time. The figure shows a continuous data flow solution strength used by the process monitor solution strength. Solution strength is the present strength of solution which is continuously present. Dialogue data flow. dialogue data flow contains several data flows as an interface. At lowest level there can be two data flows in direct relation to each other, one causes the other to occur. Comment . free-format comments may be added to the DFD to elucidate or stress any important points. Comments may be used to highlight any aliases, ties to previous or anticipated implementation. Data flow diagram name ( DFD Name ) A data flow diagram has the same name as the corresponding process group show on the parent DFD. The context diagram is treated as a DFD with one process group. Data flow diagram number ( DFD Number ) A data flow diagram has the same number as the process group it describes in more detail. The child diagram of the context diagram is numbered 0. Data Process . A data process is a process that solely transforms data. Data processes may be continuous or descrete. A continuous data process may generate continuous or discrete event flows. A discrete data process cannot generate continuous event flows. Data Store . Stores act as buffers between processes that are active at different times. A data store holds the data at rest. A data store between two processes decouples them a data flow between them synchronizes them. In the figure the data store solutions is a collection of entity occurrence of all possible solutions used in the bathing of car bodies. Dialogue event flow . Dialogue event flow is a packing of several event flows between two processes or between a process and a terminator. Discrete access flow . A discrete access flow is an access to a store that takes place under the control of the system at a particular instant of time. In figure the process Check solution is correct accesses the store solution in tank to insure that the solution is correct for the car that is about to be bathed. Discrete data flow . data flow that is variable for an instant of time is discrete data flow. A discrete data flow is transient and must be processed at the moment it occurs. In the figure solution change, generated by change to new solution represents the need to tell the operators that they must change to a certain solution. This is an example of discrete data flow. Discrete event flow . event flow available for an instant of time is called as discrete event flow. If a control process detecting the discrete flow is not active at the time it occurs, the event flow will be lost. Enable Disable . This represents a process being enabled and disabled from a control process. An ED represents the fact that the control process enables the process at one time and disables it subsequently. A process that is enabled will run whenever its stimulus occurs or run continuously until disabled. Event Flow . An event flow represents the occurrence of an event ( discrete ). or the state of something ( Continuous ). Event store . An event store is a mechanism for storing events relating to resources until they can be used by a control process. When an event detector signals an event store ( rather than use a discrete event flow), it can respond, or until the store is reinitialized. Process . A process is a system function. It is either a data process. a control process. or a process group. It may be either continuous or discrete. Process group . A process group represents a group of processes as a single icon on the diagram. This group may also contains internal stores and flows to accomplish its purpose - these are hidden within the process group. Process group are used to reduce the complexity of any one data flow diagram by combining related functions and naming the combinations for the general function that this group carries out. In the figure change to new solution is a process group comprising processes control solution change, determine new solution, detect empty tank, etc. A process group is drawn on the diagram as a solid circle, it cannot be visually distinguished from a data process without looking at its specification. Trigger . A prompt labeled T represents a trigger. The trigger will activate a discrete process. which will then run to completion and stop. In figure check solution is correct is triggered. as it will run in zero time and immediately reply with one of the two event flows correct solution or incorrect solution. Strengths and Weaknesses of DFDs Strengths . DFD method is an object oriented method that allows to design systems using objects. It is widely used and promotes easy architecture and coding of a project. This method is also easy to learn. The symbols are few and simple and easy to translate. Svakheter . There arent many weaknesses associated with this method. The DFD for large programs can be hard to translate and take a lot of time. Also, once the DFD is drawn for such a program, it becomes difficult to read and understand what is going on. The data flow can become confusing to the programmer in such an instance. Also, if the DFD is not drawn with the great amount of detail, then it is not useful to the programmer. Another disadvantage of using the DFD model is that the symbols used are not common to all DFDs. Different models use different symbols for the structure of a DFD. 7.2e DATA DICTIONARY (ref :1. E. Yourdon (1989). Modern Structured Analysis, Prentice-Hall. 2. T. De Marco (1991). Introduction to System Analysis and Design. IInd edition, Prentice-Hall ) During the analysis and design of a system, huge amount of data is collected. If data is going to be referenced throughout the design, and several people are responsible for that design notation, then individuals who may not have initialized that data but will need to reference it need to know where it came from. Manually thumbing through several volumes of the data is not the most efficient way to find such information. To make sure that everyone can access it, it needs to be stored centrally in one document. A Data Dictionary fulfills that role. Dictionary is basically a way of organizing the information, which is collected. This information enables us to work out the composition of the data, uniqueness and consistency of names and definitions of terms, and document them in dictionary which all team members can use. Ultimately it contain all information that enters, leaves and is transformed by the system, the policies surrounding that information, and description of all other objects and events of interest. This includes: data composition policies about data object and attribute descriptions event and state descriptions entity descriptions and relationship descriptions process descriptions System aspects discovered during analysis may be lost unless they are not documented in dictionary, but if everything is documented in dictionary there are all chances that dictionary is huge and contains lots of data about data.2 good ways for proper management are. Strict discipline: there should be a shared understanding between project members about what needs to be documented and how, who maintains and updates what-and severe penalties for anyone not sticking to it. Computerize it: with a project of any size, the data volume contained in the dictionary becomes too big to be handled by manual methods so it must be computerized to make the access quicker. Concepts of notationNotation helps to denote the basic kind of relationships betweenamong data items and elements, plus other information. These are some examples of data dictionary notation. 1) entity 1 entity A element B element C ( element D ) here it is shown that an entity A is made up of element B and element C and may or maynot contain element D. 2) entity 1 travel claim approval form 2 it shows that travel claim contains 2 elements, approval form and set of expense receipts. entity 2 expense receipts travel receipt expense receipts consists of travel receipt and additionaly it could also consist of number of incidental expendature. entity 3 travel receipt coach receipt air receipt rail receipt receipts not needed for a car travel travel receipt is needed for any form of travel undertaken with one exception that receipt is not needed if journey is done by car. entity 4 approval form name ref. Nei. claim total approval form has three parts, name of the person making the claim, the reference under which claim is made up and total being claimed. entity 5 ref. Nei. B123 reference number has a discrete value, the claim needs to be referenced as B123. entity 6 name 2 a name must be 2 character long entity 7 claim 1 .2 2 Claim figure must be made up of 1 or more numbers, a decimal point, and another 2 numbers to indicate fractions. Problems with building and maintaining Data Dictionary If the data dictionaries are poorly maintained, even on a fair sized project problems can arise. Aliases, imposters, hybrids, and real-time or orphaned data cause some of problems. Aliases: same definition given to several items with different names. Giving a common name so that we have a single word defining them all can solve this problem. Imposters: items having the same name but multipledifferent definitions. Giving a different (logical)name or new name can solve this problem. Hybrid data: when definition has a hidden or mixed use. Using meaningful names and do the things right away without thinking of changing in future can avoid this very crucial problem. Orphaned data: when nobody owns data, and nobody knows who created them. Author, data of entry and other pedigree information should be recorded. Det er. therefore, a number of ways in which the data dictionary will be impacted when designing the system. Definitions need to be put through a filtering process in order to make sure that rogue definitions do not go undetected. Regular analysis of data definitions is a time consuming but important and necessary exercise. Home An increase in company size results in an increase in information collection, processing and distribution. Hence it becomes necessary to handle many customer accounts and production records with many more interrelationships. In addition to increased information records, information needs and associated difficulties there arises the problem of delegation of authority and responsibilities. Basic Information System The basic functions of the company such as production, sales, finance and management functions will not change. However the introduction of an MIS will facilitate fantastic improvement in the information communications network. The objective of developing or improving a management information system can be stated as below: To provide the type of information environment that will integrate the basic operating functions and To provide management with access to information relative to complex activities in decentralized organizations. Also, as the company grows and becomes more complex much of the basic functions and information needs remain the same. Some of these internal information needs are shown as below:1. Accounting Control 2. Plans and budgets 3. Payroll by hourly and salaried groups 4. Inventory of materials, in-process and finished goods 5. Sales by product, salesman. customer and Area 6. Purchasing records, vendors, commitments 7. Distribution-Transportation and warehousing 8. Production by product, customer, cost, overruns and backlog 9. Engineering-new products, schedules, equipment, costs 10. RampD etc. etc. Although the current trend is to develop IS (with computer applications) in the areas other than the traditional areas, the bulk of information systems lie in the following categories. Over time, a typical manufacturing company has developed the major information systems shown above. These systems are not separate and distinct they connect interact and otherwise tie the subsystems of the organization together through the medium of information. 9.1 Financial Information System The financial system is probably the most important single management information system, in the company, and in most companies it is the oldest and the best developed. These systems basically deal with large amounts of data and involve planning in the financial sector. However the budgeting function performed is wholly futuristic. Periodically the management approves a financial plan (the master budget) that assigns responsibility for maintaining incomes, investments and costs within standard limits. These plans are the basis for periodic financial reports and these reports are used by the system for exercising control and for futuristic planning. The major operating systems of a company along with their respective functions (Shown in figure above) merge or integrate with the Accounting and Financial Information System to facilitate financial reporting and for management information for planning and control. Moreover, the financial system has a very significant impact on other systems when one considers that the ultimate common denominator of many operating decisions is the dollar. Perhaps, Billing (Invoice Preparation) is the most widely used data processing application among financial information systems. 9.2 ProductionOperation System Model From an operating standpoint, such a system is undoubtedly the most important in a manufacturing company. It crosses all subsystem boundaries and has an effect throughout the company. The production Operations system is concerned with information about the physical flow of goods or the production of goods and services. It covers such activities as production planning and control, inventory control and management, purchasing, distribution and transportation. Because the quantities of data are so large and the timing of information so essential, the productionoperations system is the most adaptable to automation and yields the largest benefits in terms of immediate solution of critical and costly problems. Although other applications (eg. decision-making, total system simulation) may offer greater potential, this functional area usually offers immediate pay-offs. Sales Analysis Engineering Inventory Control and Production Scheduling ProductionOperations Facilities Purchasing Financial Sales and Distribution Integration of subsystems through the information flow in the productionOperations System (Adapted from. Information systems for modern management by Murdick, Ross, Claggett)9.3 Marketing Management Information System The basic areas of the marketing function that lend themselves to improvement through information systems include: (1) ForecastingSales planning (2) Market research (3) Advertising (4) Operating and control information. Examples include sales reports and distribution cost reports. A marketing systems should also take into account of the necessity elsewhere in the organization concerning for information concerning market sales, and other internal information that affects decisions in other subsystems of the company. Three types of marketing systems may be summarized as 1. Control systems 2. Planning systems and 3. Market research systems. Customer invoices Sales Profitability Marketing budgets by product by product Sales call reports product line product line Cost reports customer class customer Inventory reports cost center salesman Accounts receivable region Accounts payable salesman Annual Reports (customers, suppliers etc.) Analyses done by the system for periodic automated reporting. -- Life cycle analysis -- Marketing Personnel Analysis Also OUTPUTS of the system include (Adapted from. Information systems for modern management by Murdick, Ross, Claggett) CHAPTER 10 STRATEGIES FOR IS (JMJ) The face of business is changing. Businesses that do not become an e-business will not be around in five years. After watching the Superbowl this year, one might be will to accept these statements at face value. These statements lend themselves into being the mottoes of Silicon Valley, knowing these quotes come from Andy Grove chairman on Intel and also from a recent article in the Harvard Business Review by Hamel. It should obvious that an industry representative would make claims on the future that are much more hype than reality, but when these same statements are made in prestigious business journals, how does the business world react Information Systems are the medium of this evolution in business and the proliferation of technologies is the catalyst IS change. The major shift coming is the impact of the internet-platform for doing business, which is currently being done on proprietary EDI systems. It is believed by businesses on the cutting edge of technology that the internet will be a leveling field for businesses that could not afford EDI in the past. EDI also was once claimed to be an evolutionary business step, but at an average cost of 50 million dollars for the system and in many cases no return on the investment. the future of EDI looks very grim, so say some of the successful practitioners of EDI. In a recent joint study by the Economic Research Council and Oasig concluded that between eighty and ninety percent of EDI systems do not meet original performance goals. So while EDI is in its decline, is it prudent to embrace the new technologies of e-business Forecasts call for a growth of e-business from 43 billion in 1998 to 1.3 trillion in 2002. The world has been wrapped many times over with internet connection lines and business already make up ninety percent of internet traffic. There is little doubt that the internet is here to stay and it will have an impact on business, especially in the areas of information systems. If IS were about technology alone, its future would the very bright. Yet, information systems are more about the data and the people that use them to resolve problems. The technology is only a tool and not the answer to IS. Many software companies that do IS consulting and IS teams within the company may not agree with that philosophy, but software vendors have a tendency to be inflexible with their platforms and IS departments have a history of being rouge divisions within company structure. A strategy to look at the future of IS, really needs to examine the past, and take a sober look at how IS in its many forms have fallen short of its promises. Steve Cardell and Neil Tiffin in an article in Industrial Management compiled six rules for putting together information systems. 1. Do not re-engineer and implement systems concurrently. From there studies the success rate is less than five percent. 2. Recognize that people fix things and information technology does not. They site Henry Ford as an example, his plants were able to process steel from iron ore to finished product in three days, in which he kept a few days inventory. 3. The business, not the IS department owns the system. This keeps costs under control and implementation on track. 4. Have an effective decision making forum. Managers and department heads are already busy, incorporating a new system that changes policy can be made very difficult if they are not kept up on what changes are taking place. 5. Configure only what the business needs. 6. When given a choice, choose flexibility In reality strategies for IS come from studying data-flow with in an organization, and clearly defining the goals for the system and the users. If consultants are hired in they need to configure the system to fit the data flow of the business. Many EDIERP software companies had businesses reshape their data-flow, resulting in suboptimal returns. The new frontier of the internet and the information technology that drives it along with the heavy performances of high-tech industry market can be intoxicating to businesses, especially those IS illiterate. From the UH panel discussions, it becomes obvious EDI has work in only a few cases, there is no standard of IS software for the internet, everyone knows they must move to the internet, some of the companies invited to the panels do not have clear goals of how their organization should work with IS, and not one company was a the same level information technology if this is the picture of the real world, the opening statements quoted are very risky, either very naiumlve or very arrogant. Quietly below the surface-hype of technology lies the ultimate future of IS, in the areas of data flow analysis. This is the one common thread for all the business that have succeed with any IS system no matter the decade it occurred in. CHAPTER 11 E-Commerce and EDI 11.1 ELECTRONIC COMMERCE (TM) Electronic commerce may be defined as the entire set of processes that support commercial activities on a network and involve information analysis. These activities spawn product information and display events, services, providers, consumers advertisers, support for transactions, brokering systems for a variety of services and actions (e. g. Finding certain products, finding cheaply priced products etc.), security of transactions, user authentication. etc. Ref. N. R Adam and Y. Yesha. Electronic commerce: an Overview There have been several similar electronic technologies in the past, for example Electronic data interchange (EDI) and Electronic funds tranfer (EFT) have been around for more than 20 years now. While many of these have electronic trading technologies have had radical effects within their own markets and created their fair share of publicity, none have attracted the level of hype or have been hailed as purveyors of economic transformation to the extent that e-commerce has in recent years. Ref. The Economist The Economist Electronic commerce survey :In search of the perfect market For example, EDI never gained the ubiquitous acceptance that was initially anticipated for it. High costs for initial investment, maintenance costs, or simply lack of preference by potential users kept EDI technologies from developing at a more rapid pace and has traditionally restricted its use to very large corporations. Electronic commerce has experienced an explosion due to the convergence of these technology developments, the merging of the telecommunications and computing industries, and the business climate. Ref. C Beam and A Segev The rise of Electronic commerce :Contributions from three factors A ubiquitous digital infrastructure that provides an efficient means for communication and information sharing presents an extremely attractive new medium for electronic commerce and for the first time has the potential to deliver what the notion of EC has always implied. D. Tapscott. The Digital Economy: Promise and peril in the age of networked intelligence Electronic commerce involves issues (both technical and non technical) that are multi - disciplinary in nature. They are complex in nature and overlap significantly with each other. Technical research issues overlap with other technical research areas. For example, finding and filtering information is a fundamental requirement of an electronic commerce system but can be an equally important service for a digital library. The figure below depicts the multidisciplinary nature of EC. As shown in the fig. The model is made up of several major components, beginning with the consumer who is interested in purchasing some goods electronically from some vendors whose product lines are represented in and are part of a global electronic marketplace. The objectives of E-Commerce are several. Primarily they involve increasing the speed and efficiency of business transactions and processes, and improving customer service. Also EC should. - Streamline procurement processes thereby cutting overall costs via a more competitive process - Contribute to a decrease in the length of production cycles. - Enable enterprises to conduct business with distant partners the same way they do with neighboring partners. - Empower small businesses. - Create new services and businesses. - Help expand the horizon of participants. In contrast to the emerging area of EC, EDI (Electronic data interchange) which has been around (in the same form) for 20 years now is the cause of positive and negative effects on industrial structures. A true cost benefit analysis of the effects can be difficult to assess, however the costs become much easier to quantify than the benefits. Reduced personnel expense for data entry, paper and postage savings, and shortened receivable cycles are all quantifiable benefits, but the thousands to hundreds of thousands of dollars required to set up and maintain the implementation of traditional EDI needs to be justified with more significant benefits than these. For an EDI implementation to be successful, it needs to be the direct cause of improved productivity and internal operations, create closer customer vendor relations, provide a competitive advantage in the marketplace, and open up the procurement process. Historically this has not been the case for two reasons :The high cost involved with EDI, especially for small to medium-sized enterprises(SMEs), and what we refer to as standard issues. (Ref. Electronic commerce Nabil Adam, Oktay Dogramaci et al.) E-C applications in Supply-Chain and manufacturing Another area where EC applications facilitate improvement is supply chain management. The objective of an electronic commerce strategy is to provide purchasing managers with better control over their companies purchasing habits and relationships with suppliers Continuous improvement of an organizations supply-chain is directly related to its performance, and EC applications are being used in procurement processes more and more frequently to this end. Changes in the supply chain are closely related to inter-business retail processes. The advantages of EC in supply-chain management include access to a wide range of suppliers and effective use of organizational resources that are essential for implementing just-in-time (JIT) manufacturing systems..Ref. C Curtis Getting on to the e-Commerce supply chain Just in time Internet week Sept. 1997 These automated systems provide new types of information for businesses that implement them. Among the enhanced capabilities for managers are improved sales forecasts, more accurate balance sheets, and closer relationships with customers using a new interface. Direct communications between suppliers and customers streamlines the supply chain and delivers new relevant information to manufacturers in real-time. For one example of how businesses are accomplishing these goals, craig (in internet Week Nov. 1997) describes a joint venture between SAP and Digital Equipment Co. to keep vending machines filled to demand with a web-based EDI system. An embedded computer in the vending machines is connected to the internet, and each time a product is purchased a message is sent to the supplier. This gives suppliers crucial information about their distribution channels in real-time, and removes the requirement for vending machine operators to use non standard proprietary software that accomplished this task in the past. 11.2 ELECTRONIC DATA INTERCHANGE (EDI) (MR) (Source. EDI ebook, at editraining) Electronic Data Interchange or EDI is the electronic exchange of business documents from one companys computer to anothers computer in nationally standard structured data formats. Using EDI to exchange business documents eliminates the rekeying of the data, resulting in more accurate data. In EDI, data necessary for conducting business is transmitted directly into a system without human intervention. We can transmit and receive EDI documents with companies such as banks, railroads, customers and suppliers. The companies who send and receive EDI with are referred to as trading partners. For many years business data has been exchanged electronically on tapes, disks. diskettes and over direct computer to computer hookups. Companies realized replacing the paper used in business transactions with electronic communication saved both money and time Customers and suppliers were interested in sending and receiving electronic documents however, each company had different documents need and different computer and communication medium. The effort to maintain different document formats and different communications hookups became time consuming and costly. Electronic transactions started becoming standardize. Different standards for different industries still exist. The Accredited Standards Committee (ASC) X12 of the ANSI was created to support the national standards of EDI. Transaction sets (standard business transaction formats) are developed and maintained by the ASC X12. Most of Industries use subset of the X12 standards. Following are some major industries that use subsets. AFPA Paper Industry CIDX Chemical Industry WINS Warehouse Industry VICS Retail Industry UNEDIFACT Standards are used internationally. EDI Data Structure Individual electronic transmission between trading partners is grouped in an electronic envelope similar to putting paper documents into paper envelopes. The electronic envelope specifies who is sending and who is receiving the documents. Within each electronic envelope is a collection of documents of the same type, this is called a functional group. An example of the functional group is a collection of invoices. You can group several invoices together and send them in a functional group in EDI. Documents (purchase orders, invoices..) are referred to as transaction sets in ANSI X 12 standards and messages in UNEDIFACT standards. There are hundreds of document types defined by EDI standards. A document contains segments that are logical groups of information. Each segment is preceded by a segment identifier and terminated by a segment separator. A segment is made up of data elements. This is where the information is stored . How Does EDI Work EDI involves three functions within each computer system: 1) Application Interface System. 2) EDI Software 3) Communications Handler Application Interface System Processes the data to be sent to, or received from, the trading partner. Moves electronic transactions to or from the application system. Programs separate and deliver inbound transactions to the application systems. 4. Delivers inbound transactions to the applications systems and gathers transactions from the application systems for outbound transmission. EDI Software 1. Manipulates and routes data between the application system and the communications handler. 2. Translates Business documents into and out of the X12 formats. 3. Creates Functional Acknowledgments (EDI transaction that notifies the trading partner that an electronic document was received). 4. Verifies the identity of trading partners. 5. Validates the transactions by checking a master file against the information transmitted. Communications Handler Transmits data to and from the trading partner through a value-added network. Protects against transmission errors or interruptions. Example of EDI Process: This example shows the process of a shipment notice from the manufacturer to the customer. These are various steps involved in process: 1. The data is extracted from the shipment and database. 2. The data is translated by the EDI software into a standard X12 EDI shipment notice format. 3. The EDI shipment notice is transmitted through a Value Added Network (VAN) to the company. 4. The company receives the EDI shipment notice. 5. The EDI shipment notice is translated into a format that can be used to update the database of the company. (Source. Article by G. Berton Latamore, Apics, February 1999,No.2) Although EDI has been the traditional approach to automating business transactions between trading partners, e-commerce, using Java applets embedded in Internet-enabled applications, is coming on strong. E-commerce offers several advantages over EDI. The initial investment in technology is much less. For smaller companies with lower trading volumes, the internet costs much less than a VAN. Internet reaches everyone in the supply chain, supports near real-time messaging, and supports both machine-to-machine and human-to-machine transactions. EDI has advantages for larger manufacturers that must automate complex transactions among a large community of suppliers. It provides a standard way to format key transaction data and provides a complete set of messages, including acknowledgements. EDI also includes built-in security . while the Internet is still a very insecure environment. E-commerce sites focused on the supply chain have been designed to extend electronic commerce to supply chain members that have not invested in EDI, rather than replacing existing EDI sites. Most experts expect this pattern to continue and advise manufacturers with EDI systems to consider adding e-commerce front ends to allow smaller suppliers or customers to communicate directly with their existing infrastructure. However, experts caution that EDI and e-commerce are not necessarily antagonistic and agree most companies need a combination both to effectively reach their entire supply chain. Where EDI Excels Less expensive and easier to implement for simple transactions bteween two trading partners. However becomes expensive and complex when trying to support sets of complex transactions among large groups of trading partners. Provides a complete, integrated package to support transactions . including receipts showing that transactions were received e-commerce only provides a template from which each form must be created and each response programmed Supports near real-time transactions. Handles a much wider range of transaction types and can be used for any kind of transaction between trading partners. Provides a complete security package e-commerce has no built-in security and requires that a suite of separate security applications be custom integrated. Supports both machine-to-machine and man-to-machine transactions EDI only does machine-to-machine, making it an impractical answer for handling specialty or occasional orders. VANs are very secure the Internet, by design, is insecure . Reaches everyone over the Internet EDI only reaches trading partners who can afford connectivity to the VAN of choice. Optimized for large volumes of transactions processed on large servers or mainframes e-commerce is most successful in low-volume environments running on PCs or smaller servers. 12.3 Distribution and Transportation System ACQUISITION COSTS: these costs include the price of the items, the shopping time, the paper work, expediting (emergency buy, down time), mistakes (returns, rejects, quantity errors this will generate expediting costs), and the price for internal handling (receiving and storing). BREAK-BULK CARGO: Cargo, which is, shipped a unit (i. e. Palletized cargo, boxed Cargo, large machinery, trucks and pre-slung cargo). BULK CARGO: Loose cargo that is loaded directly into a ships hold. BULK CARRIER: There are two types of bulk carrier, the dry-bulk carrier and the liquid-bulk carrier better known as a tanker. Bulk cargo is a shipment such as oil, grain, or ore which is not packaged, bundled, bottled, or otherwise packed and is loaded without counting or marking. BUSINESS PROCESS (BP) : A set of logically related tasks performed to achieve a defined business outcome. CARRIER(S) CONTAINER(S)SHIPPER(S) CONTAINER(S): The term Carrier(s) Container(s) or Shipper(s) Container(s) means containers over which the carrier or the shipper has control either by ownership or by the acquisition thereof under lease or rental from container companies or container suppliers or from similar sources. Carriers are prohibited from purchasing, leasing or renting shipper owned containers. CHANGE ANALYSIS: Study of suitable changes of the activities of an enterprise in concrete situation CORRUGATED CASES: Built like a sandwich cardboard - characteristic arches of wavy fluting lying between two pieces of smooth board on the outside. CONTAINER: The term container means a single rigid, non-disposable dry cargo, insulated, temperature controlled flatrack, vehicle rack portable liquid tank, or open top container without wheels or bogies attached, having not less than 350 cubic feet capacity, having a closure or permanently hinged door that allows ready access to the cargo (closure or permanently hinged door not applicable to flatrack vehicle rack or portable liquid tank). CONTAINER SHIP: Ocean going ship designed to carry containers both internally and on deck. Some are self-sustaining. CONTAINERIZATION: Concept for the ultimate unitizing of cargo used by both steamship lines and air cargo lines. Containers allow a greater amount of cargo protection from weather, damage, and theft. DATA: Raw information representing events occurring in the organization before they are organized into an understandable and useful form for humans DATA DICTIONARY: A way of organizing information, which is collected. This information enables one to work out the composition of the data, uniqueness and consistency of names and definitions of terms, and document them in dictionary which all team members can use DATA FLOW: Data flow on context diagram either represents information produced within or outside the system which is used by outside world or by the system itself DATA FLOW DIAGRAM: An important technique for modeling high level detail in a process within a system. They highlight the functions of the system and how they use stored information and transfer information between each other. DATA-ORIENTED WORK: Refers to the development parts whose purpose is to design technical solutions to this specification. DISTRIBUTION CHANNELS: Methods by which distribution get products to market. EDI: Electronic Data Interchange Proprietary systems by which companies share information. END-USERS: Customers that are served by distribution. ENTITIES RELATIOINSHIP DIAGRAMS (ERD): A semantic modeling tool used to identify and organize information and to model particular roles of importance to the enterprise and relationships between them ENTITIES: A class of real world thing whose role of interaction with the enterprise is well defined. INFORMATION: A derivative from meaningful interpretation of data. INFORMATION SYSTEM: A set of interrelated components that collect (or retrieve), process, store and distribute information to support decision making and control in an organization. INFROMATION TECNOLOGY (IT) : This includes the capabilities offered by computers, Software and telecom. The current media by which information is transferred. HOLDING COSTS: are the interest costs, the storage cost, the control cost (shipping, transportation, security), taxes, insurance, and the shrinkage cost (shipped short or long, stolen, obsolescence). HUB: A central location to which traffic from many cities is directed and from which traffic is fed to other areas. MANAGEMENT INFORMATION SYSTEMS (MIS): A division in corporate structure that creates and maintains IS for the management levels of an organization. OFFICE AUTOMATION SYSTEMS (OAS): Serves the knowledge level of an organization. PALLET: Load carrying platform to which loose cargo is secured before placing aboard the aircraft. PERISHABLES: Any cargo that loses considerable value if it is delayed in transportation (Usually refers to fresh fruit and vegetables). PROBLEM-ORIENTED WORK: In information systems development, refers to the development parts whose purpose is to specify what the information systems will do. STRADIS (Structured Analysis And Design of Information Systems): follows the Top-down approach (functional decomposition) for analyzing processes. TOTAL PROCUREMENT COSTS: are the holding costs and the acquisition costs. TRANSACTION: A performance or management of a business. In the context of distribution, it is all the interactions between manufacturing, distribution and end-users. TRANSACTION PROCESSING SYSTEMS (TPS): Serves the operational level of an organization. UNITISATION: The packing of single or multiple consignments into ULDs or pallets. USER: One who would be accessing an IS interface in order to gain a knowledge, to apply to a decision making process.

No comments:

Post a Comment