Dekorationsartikel gehören nicht zum Leistungsumfang.
Sprache:
Englisch
61,95 €*
Versandkostenfrei per Post / DHL
auf Lager, Lieferzeit 1-2 Werktage
Kategorien:
Beschreibung
Strategies for building large systems that can be easily adapted for new situations with only minor programming modifications.
Time pressures encourage programmers to write code that works well for a narrow purpose, with no room to grow. But the best systems are evolvable; they can be adapted for new situations by adding code, rather than changing the existing code. The authors describe techniques they have found effective--over their combined 100-plus years of programming experience--that will help programmers avoid programming themselves into corners.
The authors explore ways to enhance flexibility by:
• Organizing systems using combinators to compose mix-and-match parts, ranging from small functions to whole arithmetics, with standardized interfaces
• Augmenting data with independent annotation layers, such as units of measurement or provenance
• Combining independent pieces of partial information using unification or propagation
• Separating control structure from problem domain with domain models, rule systems and pattern matching, propagation, and dependency-directed backtracking
• Extending the programming language, using dynamically extensible evaluators
Time pressures encourage programmers to write code that works well for a narrow purpose, with no room to grow. But the best systems are evolvable; they can be adapted for new situations by adding code, rather than changing the existing code. The authors describe techniques they have found effective--over their combined 100-plus years of programming experience--that will help programmers avoid programming themselves into corners.
The authors explore ways to enhance flexibility by:
• Organizing systems using combinators to compose mix-and-match parts, ranging from small functions to whole arithmetics, with standardized interfaces
• Augmenting data with independent annotation layers, such as units of measurement or provenance
• Combining independent pieces of partial information using unification or propagation
• Separating control structure from problem domain with domain models, rule systems and pattern matching, propagation, and dependency-directed backtracking
• Extending the programming language, using dynamically extensible evaluators
Strategies for building large systems that can be easily adapted for new situations with only minor programming modifications.
Time pressures encourage programmers to write code that works well for a narrow purpose, with no room to grow. But the best systems are evolvable; they can be adapted for new situations by adding code, rather than changing the existing code. The authors describe techniques they have found effective--over their combined 100-plus years of programming experience--that will help programmers avoid programming themselves into corners.
The authors explore ways to enhance flexibility by:
• Organizing systems using combinators to compose mix-and-match parts, ranging from small functions to whole arithmetics, with standardized interfaces
• Augmenting data with independent annotation layers, such as units of measurement or provenance
• Combining independent pieces of partial information using unification or propagation
• Separating control structure from problem domain with domain models, rule systems and pattern matching, propagation, and dependency-directed backtracking
• Extending the programming language, using dynamically extensible evaluators
Time pressures encourage programmers to write code that works well for a narrow purpose, with no room to grow. But the best systems are evolvable; they can be adapted for new situations by adding code, rather than changing the existing code. The authors describe techniques they have found effective--over their combined 100-plus years of programming experience--that will help programmers avoid programming themselves into corners.
The authors explore ways to enhance flexibility by:
• Organizing systems using combinators to compose mix-and-match parts, ranging from small functions to whole arithmetics, with standardized interfaces
• Augmenting data with independent annotation layers, such as units of measurement or provenance
• Combining independent pieces of partial information using unification or propagation
• Separating control structure from problem domain with domain models, rule systems and pattern matching, propagation, and dependency-directed backtracking
• Extending the programming language, using dynamically extensible evaluators
Über den Autor
Chris Hanson is on the technical staff at Datera.
Gerald Jay Sussman is Panasonic Professor of Electrical Engineering at MIT. He is the coauthor of Structure and Interpretation of Computer Programs, Structure and Interpretation of Classical Mechanics, and Functional Differential Equations (all published by the MIT Press).
Gerald Jay Sussman is Panasonic Professor of Electrical Engineering at MIT. He is the coauthor of Structure and Interpretation of Computer Programs, Structure and Interpretation of Classical Mechanics, and Functional Differential Equations (all published by the MIT Press).
Inhaltsverzeichnis
Foreword xi
Preface xiii
Acknowledgments xix
1 Flexibility in Nature and in Design 1
2 Domain-Specific Languages 21
3 Variations on an Arithmetic Theme 67
4 Pattern Matching 157
5 Evaluation 233
6 Layering 299
7 Propagation 327
8 Epilogue 373
A Appendix: Supporting Software 377
B Appendix: Scheme 379
Preface xiii
Acknowledgments xix
1 Flexibility in Nature and in Design 1
2 Domain-Specific Languages 21
3 Variations on an Arithmetic Theme 67
4 Pattern Matching 157
5 Evaluation 233
6 Layering 299
7 Propagation 327
8 Epilogue 373
A Appendix: Supporting Software 377
B Appendix: Scheme 379
Details
Erscheinungsjahr: | 2021 |
---|---|
Fachbereich: | EDV |
Genre: | Informatik |
Rubrik: | Naturwissenschaften & Technik |
Thema: | Lexika |
Medium: | Buch |
Inhalt: | Einband - fest (Hardcover) |
ISBN-13: | 9780262045490 |
ISBN-10: | 0262045494 |
Sprache: | Englisch |
Einband: | Gebunden |
Autor: |
Hanson, Chris
Sussman, Gerald Jay |
Hersteller: | MIT Press Ltd |
Maße: | 236 x 158 x 35 mm |
Von/Mit: | Chris Hanson (u. a.) |
Erscheinungsdatum: | 09.03.2021 |
Gewicht: | 0,727 kg |
Über den Autor
Chris Hanson is on the technical staff at Datera.
Gerald Jay Sussman is Panasonic Professor of Electrical Engineering at MIT. He is the coauthor of Structure and Interpretation of Computer Programs, Structure and Interpretation of Classical Mechanics, and Functional Differential Equations (all published by the MIT Press).
Gerald Jay Sussman is Panasonic Professor of Electrical Engineering at MIT. He is the coauthor of Structure and Interpretation of Computer Programs, Structure and Interpretation of Classical Mechanics, and Functional Differential Equations (all published by the MIT Press).
Inhaltsverzeichnis
Foreword xi
Preface xiii
Acknowledgments xix
1 Flexibility in Nature and in Design 1
2 Domain-Specific Languages 21
3 Variations on an Arithmetic Theme 67
4 Pattern Matching 157
5 Evaluation 233
6 Layering 299
7 Propagation 327
8 Epilogue 373
A Appendix: Supporting Software 377
B Appendix: Scheme 379
Preface xiii
Acknowledgments xix
1 Flexibility in Nature and in Design 1
2 Domain-Specific Languages 21
3 Variations on an Arithmetic Theme 67
4 Pattern Matching 157
5 Evaluation 233
6 Layering 299
7 Propagation 327
8 Epilogue 373
A Appendix: Supporting Software 377
B Appendix: Scheme 379
Details
Erscheinungsjahr: | 2021 |
---|---|
Fachbereich: | EDV |
Genre: | Informatik |
Rubrik: | Naturwissenschaften & Technik |
Thema: | Lexika |
Medium: | Buch |
Inhalt: | Einband - fest (Hardcover) |
ISBN-13: | 9780262045490 |
ISBN-10: | 0262045494 |
Sprache: | Englisch |
Einband: | Gebunden |
Autor: |
Hanson, Chris
Sussman, Gerald Jay |
Hersteller: | MIT Press Ltd |
Maße: | 236 x 158 x 35 mm |
Von/Mit: | Chris Hanson (u. a.) |
Erscheinungsdatum: | 09.03.2021 |
Gewicht: | 0,727 kg |
Warnhinweis